Class: Solargraph::Shell

Inherits:
Thor
  • Object
show all
Includes:
ServerMethods
Defined in:
lib/solargraph/shell.rb

Instance Method Summary collapse

Methods included from ServerMethods

#available_port

Instance Method Details

#available_coresObject

Deprecated.


102
103
104
105
# File 'lib/solargraph/shell.rb', line 102

def available_cores
  puts 'The `available-cores` command is deprecated.'
  puts 'Current versions of Solargraph use RBS for core and stdlib documentation.'
end

#bundleObject



214
215
216
# File 'lib/solargraph/shell.rb', line 214

def bundle
  puts 'The `bundle` command is deprecated. Solargraph currently uses RBS instead.'
end

#clearObject



111
112
113
114
# File 'lib/solargraph/shell.rb', line 111

def clear
  puts "Deleting the cached documentation"
  Solargraph::Cache.clear
end

#config(directory = '.') ⇒ Object



52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# File 'lib/solargraph/shell.rb', line 52

def config(directory = '.')
  matches = []
  if options[:extensions]
    Gem::Specification.each do |g|
      if g.name.match(/^solargraph\-[A-Za-z0-9_\-]*?\-ext/)
        require g.name
        matches.push g.name
      end
    end
  end
  conf = Solargraph::Workspace::Config.new.raw_data
  unless matches.empty?
    matches.each do |m|
      conf['extensions'].push m
    end
  end
  File.open(File.join(directory, '.solargraph.yml'), 'w') do |file|
    file.puts conf.to_yaml
  end
  STDOUT.puts "Configuration file initialized."
end

#download_core(_version = nil) ⇒ Object

Deprecated.


80
81
82
83
# File 'lib/solargraph/shell.rb', line 80

def download_core _version = nil
  puts 'The `download-core` command is deprecated.'
  puts 'Current versions of Solargraph use RBS for core and stdlib documentation.'
end

#listObject



200
201
202
203
204
205
206
# File 'lib/solargraph/shell.rb', line 200

def list
  workspace = Solargraph::Workspace.new(options[:directory])
  unless options[:count]
    workspace.filenames.each { |f| puts f }
  end
  puts "#{workspace.filenames.length} files total."
end

#list_coresObject

Deprecated.


91
92
93
94
# File 'lib/solargraph/shell.rb', line 91

def list_cores
  puts 'The `list-cores` command is deprecated.'
  puts 'Current versions of Solargraph use RBS for core and stdlib documentation.'
end

#rdoc(_gem, _version = '>= 0') ⇒ Object



222
223
224
# File 'lib/solargraph/shell.rb', line 222

def rdoc _gem, _version = '>= 0'
  puts 'The `rdoc` command is deprecated. Solargraph currently uses RBS instead.'
end

#reportersObject



130
131
132
# File 'lib/solargraph/shell.rb', line 130

def reporters
  puts Solargraph::Diagnostics.reporters
end

#scanObject



175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
# File 'lib/solargraph/shell.rb', line 175

def scan
  require 'benchmark'
  directory = File.realpath(options[:directory])
  api_map = nil
  time = Benchmark.measure {
    api_map = Solargraph::ApiMap.load(directory)
    api_map.pins.each do |pin|
      begin
        puts pin_description(pin) if options[:verbose]
        pin.typify api_map
        pin.probe api_map
      rescue StandardError => e
        STDERR.puts "Error testing #{pin_description(pin)} #{pin.location ? "at #{pin.location.filename}:#{pin.location.range.start.line + 1}" : ''}"
        STDERR.puts "[#{e.class}]: #{e.message}"
        STDERR.puts e.backtrace.join("\n")
        exit 1
      end
    end
  }
  puts "Scanned #{directory} (#{api_map.pins.length} pins) in #{time.real} seconds."
end

#socketObject



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/solargraph/shell.rb', line 19

def socket
  require 'backport'
  port = options[:port]
  port = available_port if port.zero?
  Backport.run do
    Signal.trap("INT") do
      Backport.stop
    end
    Signal.trap("TERM") do
      Backport.stop
    end
    Backport.prepare_tcp_server host: options[:host], port: port, adapter: Solargraph::LanguageServer::Transport::Adapter
    STDERR.puts "Solargraph is listening PORT=#{port} PID=#{Process.pid}"
  end
end

#stdioObject



36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/solargraph/shell.rb', line 36

def stdio
  require 'backport'
  Backport.run do
    Signal.trap("INT") do
      Backport.stop
    end
    Signal.trap("TERM") do
      Backport.stop
    end
    Backport.prepare_stdio_server adapter: Solargraph::LanguageServer::Transport::Adapter
    STDERR.puts "Solargraph is listening on stdio PID=#{Process.pid}"
  end
end

#typecheck(*files) ⇒ Object



143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
# File 'lib/solargraph/shell.rb', line 143

def typecheck *files
  directory = File.realpath(options[:directory])
  api_map = Solargraph::ApiMap.load(directory)
  if files.empty?
    files = api_map.source_maps.map(&:filename)
  else
    files.map! { |file| File.realpath(file) }
  end
  probcount = 0
  filecount = 0
  files.each do |file|
    checker = TypeChecker.new(file, api_map: api_map, level: options[:level].to_sym)
    problems = checker.problems
    next if problems.empty?
    problems.sort! { |a, b| a.location.range.start.line <=> b.location.range.start.line }
    puts problems.map { |prob| "#{prob.location.filename}:#{prob.location.range.start.line + 1} - #{prob.message}" }.join("\n")
    filecount += 1
    probcount += problems.length
  end
  puts "#{probcount} problem#{probcount != 1 ? 's' : ''} found#{files.length != 1 ? " in #{filecount} of #{files.length} files" : ''}."
  exit 1 if probcount > 0
end

#uncache(*gems) ⇒ Object

Raises:

  • (ArgumentError)


119
120
121
122
123
124
125
126
127
# File 'lib/solargraph/shell.rb', line 119

def uncache *gems
  raise ArgumentError, 'No gems specified.' if gems.empty?
  gems.each do |gem|
    Dir[File.join(Solargraph::YardMap::CoreDocs.cache_dir, 'gems', "#{gem}-*")].each do |dir|
      puts "Deleting cache: #{dir}"
      FileUtils.remove_entry_secure dir
    end
  end
end

#versionObject



12
13
14
# File 'lib/solargraph/shell.rb', line 12

def version
  puts Solargraph::VERSION
end