Class: Solargraph::Workspace::Config

Inherits:
Object
  • Object
show all
Defined in:
lib/solargraph/workspace/config.rb

Overview

Configuration data for a workspace.

Constant Summary collapse

MAX_FILES =

The maximum number of files that can be added to a workspace. The workspace’s .solargraph.yml can override this value.

5000

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(directory = '') ⇒ Config

Returns a new instance of Config.

Parameters:

  • (defaults to: '')


22
23
24
25
26
27
# File 'lib/solargraph/workspace/config.rb', line 22

def initialize directory = ''
  @directory = File.absolute_path(directory)
  @raw_data = config_data
  included
  excluded
end

Instance Attribute Details

#directoryString (readonly)

Returns:



15
16
17
# File 'lib/solargraph/workspace/config.rb', line 15

def directory
  @directory
end

#raw_dataHash{String => undefined, nil} (readonly)

TODO:

To make JSON strongly typed we’ll need a record syntax

Returns:



19
20
21
# File 'lib/solargraph/workspace/config.rb', line 19

def raw_data
  @raw_data
end

Instance Method Details

#allow?(filename) ⇒ Boolean

Parameters:

Returns:



46
47
48
49
50
51
# File 'lib/solargraph/workspace/config.rb', line 46

def allow? filename
  filename = File.absolute_path(filename, directory)
  filename.start_with?(directory) &&
    !excluded.include?(filename) &&
    excluded_directories.none? { |d| filename.start_with?(d) }
end

#calculatedArray<String>

The calculated array of (included - excluded) files in the workspace.

Returns:



56
57
58
59
# File 'lib/solargraph/workspace/config.rb', line 56

def calculated
  Solargraph.logger.info "Indexing workspace files in #{directory}" unless @calculated || directory.empty? || directory == '*'
  @calculated ||= included - excluded
end

#domainsArray<String>

An array of domains configured for the workspace. A domain is a namespace that the ApiMap should include in the global namespace. It’s typically used to identify available DSLs.

@sg-ignore Need to validate config

Returns:



67
68
69
# File 'lib/solargraph/workspace/config.rb', line 67

def domains
  raw_data['domains']
end

#excludedArray<String>

An array of files excluded from the workspace.

Returns:



40
41
42
43
# File 'lib/solargraph/workspace/config.rb', line 40

def excluded
  return [] if directory.empty? || directory == '*'
  @excluded ||= process_exclusions(@raw_data['exclude'])
end

#formatterHash

A hash of options supported by the formatter

@sg-ignore Need to validate config

Returns:



98
99
100
# File 'lib/solargraph/workspace/config.rb', line 98

def formatter
  raw_data['formatter']
end

#includedArray<String>

An array of files included in the workspace (before calculating excluded files).

Returns:



32
33
34
35
# File 'lib/solargraph/workspace/config.rb', line 32

def included
  return [] if directory.empty? || directory == '*'
  @included ||= process_globs(@raw_data['include'])
end

#max_filesInteger

The maximum number of files to parse from the workspace.

@sg-ignore Need to validate config

Returns:



114
115
116
# File 'lib/solargraph/workspace/config.rb', line 114

def max_files
  raw_data['max_files']
end

#pluginsArray<String>

An array of plugins to require.

@sg-ignore Need to validate config

Returns:



106
107
108
# File 'lib/solargraph/workspace/config.rb', line 106

def plugins
  raw_data['plugins']
end

#reportersArray<String>

An array of reporters to use for diagnostics.

@sg-ignore Need to validate config

Returns:



90
91
92
# File 'lib/solargraph/workspace/config.rb', line 90

def reporters
  raw_data['reporters']
end

#require_pathsArray<String>

An array of load paths for required paths.

Returns:



82
83
84
# File 'lib/solargraph/workspace/config.rb', line 82

def require_paths
  raw_data['require_paths'] || []
end

#requiredArray<String>

An array of required paths to add to the workspace.

@sg-ignore Need to validate config

Returns:



75
76
77
# File 'lib/solargraph/workspace/config.rb', line 75

def required
  raw_data['require']
end

#type_checker_rulesHash{Symbol => Symbol}

Returns:



119
120
121
122
123
124
125
# File 'lib/solargraph/workspace/config.rb', line 119

def type_checker_rules
  # @type [Hash{String => String}]

  raw_rules = raw_data.fetch('type_checker', {}).fetch('rules', {})
  raw_rules.to_h do |k, v|
    [k.to_sym, v.to_sym]
  end
end