From 6412dbc18bc838c824f03502bb3221934eb74cd9 Mon Sep 17 00:00:00 2001 From: Stan Lo Date: Tue, 13 Aug 2024 12:40:35 +0100 Subject: [PATCH] Make configuration part of the index Since an Index's data is scoped by configuration, we should make the configuration part of the index. This is especially true with #2424 coming because changing the state of `RubyIndexer.configuration` to affect the index is surprising. --- exe/ruby-lsp | 8 ++++---- exe/ruby-lsp-check | 2 +- lib/ruby_indexer/lib/ruby_indexer/declaration_listener.rb | 2 +- lib/ruby_indexer/lib/ruby_indexer/index.rb | 7 ++++++- lib/ruby_indexer/ruby_indexer.rb | 8 -------- lib/ruby_indexer/test/configuration_test.rb | 2 +- lib/ruby_lsp/server.rb | 4 ++-- test/server_test.rb | 4 ++-- 8 files changed, 17 insertions(+), 20 deletions(-) diff --git a/exe/ruby-lsp b/exe/ruby-lsp index 0613c1491..4105cc6d1 100755 --- a/exe/ruby-lsp +++ b/exe/ruby-lsp @@ -112,20 +112,20 @@ if options[:time_index] end if options[:doctor] + index = RubyIndexer::Index.new + if File.exist?(".index.yml") begin config = YAML.parse_file(".index.yml").to_ruby rescue => e abort("Error parsing config: #{e.message}") end - RubyIndexer.configuration.apply_config(config) + index.configuration.apply_config(config) end - index = RubyIndexer::Index.new - puts "Globbing for indexable files" - RubyIndexer.configuration.indexables.each do |indexable| + index.configuration.indexables.each do |indexable| puts "indexing: #{indexable.full_path}" index.index_single(indexable) end diff --git a/exe/ruby-lsp-check b/exe/ruby-lsp-check index 447ca0949..ad2d3f6b3 100755 --- a/exe/ruby-lsp-check +++ b/exe/ruby-lsp-check @@ -44,7 +44,7 @@ puts "\n" puts "Verifying that indexing executes successfully. This may take a while..." index = RubyIndexer::Index.new -indexables = RubyIndexer.configuration.indexables +indexables = index.configuration.indexables indexables.each_with_index do |indexable, i| index.index_single(indexable) diff --git a/lib/ruby_indexer/lib/ruby_indexer/declaration_listener.rb b/lib/ruby_indexer/lib/ruby_indexer/declaration_listener.rb index 53c37a172..08c268bbe 100644 --- a/lib/ruby_indexer/lib/ruby_indexer/declaration_listener.rb +++ b/lib/ruby_indexer/lib/ruby_indexer/declaration_listener.rb @@ -552,7 +552,7 @@ def collect_comments(node) comment_content = comment.location.slice.chomp # invalid encodings would raise an "invalid byte sequence" exception - if !comment_content.valid_encoding? || comment_content.match?(RubyIndexer.configuration.magic_comment_regex) + if !comment_content.valid_encoding? || comment_content.match?(@index.configuration.magic_comment_regex) next end diff --git a/lib/ruby_indexer/lib/ruby_indexer/index.rb b/lib/ruby_indexer/lib/ruby_indexer/index.rb index c556e10a2..0c126588b 100644 --- a/lib/ruby_indexer/lib/ruby_indexer/index.rb +++ b/lib/ruby_indexer/lib/ruby_indexer/index.rb @@ -11,6 +11,9 @@ class NonExistingNamespaceError < StandardError; end # The minimum Jaro-Winkler similarity score for an entry to be considered a match for a given fuzzy search query ENTRY_SIMILARITY_THRESHOLD = 0.7 + sig { returns(Configuration) } + attr_reader :configuration + sig { void } def initialize # Holds all entries in the index using the following format: @@ -44,6 +47,8 @@ def initialize {}, T::Hash[String, T::Array[T.proc.params(index: Index, base: Entry::Namespace).void]], ) + + @configuration = T.let(RubyIndexer::Configuration.new, Configuration) end # Register an enhancement to the index. Enhancements must conform to the `Enhancement` interface @@ -296,7 +301,7 @@ def resolve(name, nesting, seen_names = []) block: T.nilable(T.proc.params(progress: Integer).returns(T::Boolean)), ).void end - def index_all(indexable_paths: RubyIndexer.configuration.indexables, &block) + def index_all(indexable_paths: @configuration.indexables, &block) RBSIndexer.new(self).index_ruby_core # Calculate how many paths are worth 1% of progress progress_step = (indexable_paths.length / 100.0).ceil diff --git a/lib/ruby_indexer/ruby_indexer.rb b/lib/ruby_indexer/ruby_indexer.rb index 6690f40ab..996af2f8c 100644 --- a/lib/ruby_indexer/ruby_indexer.rb +++ b/lib/ruby_indexer/ruby_indexer.rb @@ -15,12 +15,4 @@ require "ruby_indexer/lib/ruby_indexer/rbs_indexer" module RubyIndexer - @configuration = T.let(Configuration.new, Configuration) - - class << self - extend T::Sig - - sig { returns(Configuration) } - attr_reader :configuration - end end diff --git a/lib/ruby_indexer/test/configuration_test.rb b/lib/ruby_indexer/test/configuration_test.rb index 4ebffc7f1..9ba72f9a3 100644 --- a/lib/ruby_indexer/test/configuration_test.rb +++ b/lib/ruby_indexer/test/configuration_test.rb @@ -108,7 +108,7 @@ def test_configuration_raises_for_unknown_keys end def test_magic_comments_regex - regex = RubyIndexer.configuration.magic_comment_regex + regex = @config.magic_comment_regex [ "# frozen_string_literal:", diff --git a/lib/ruby_lsp/server.rb b/lib/ruby_lsp/server.rb index 7e1bfd125..b4cdbbce6 100644 --- a/lib/ruby_lsp/server.rb +++ b/lib/ruby_lsp/server.rb @@ -877,7 +877,7 @@ def process_indexing_configuration(indexing_options) if File.exist?(index_path) begin - RubyIndexer.configuration.apply_config(YAML.parse_file(index_path).to_ruby) + @global_state.index.configuration.apply_config(YAML.parse_file(index_path).to_ruby) send_message( Notification.new( method: "window/showMessage", @@ -906,7 +906,7 @@ def process_indexing_configuration(indexing_options) return unless indexing_options # The index expects snake case configurations, but VS Code standardizes on camel case settings - RubyIndexer.configuration.apply_config( + @global_state.index.configuration.apply_config( indexing_options.transform_keys { |key| key.to_s.gsub(/([A-Z])/, "_\\1").downcase }, ) end diff --git a/test/server_test.rb b/test/server_test.rb index 9fcf5d54b..70407fb7d 100644 --- a/test/server_test.rb +++ b/test/server_test.rb @@ -481,8 +481,8 @@ def test_handles_editor_indexing_settings }) end - assert_includes(RubyIndexer.configuration.instance_variable_get(:@excluded_gems), "foo_gem") - assert_includes(RubyIndexer.configuration.instance_variable_get(:@included_gems), "bar_gem") + assert_includes(@server.global_state.index.configuration.instance_variable_get(:@excluded_gems), "foo_gem") + assert_includes(@server.global_state.index.configuration.instance_variable_get(:@included_gems), "bar_gem") end def test_closing_document_before_computing_features_does_not_error