Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Zenspider/warnings double loads and fixes #1962

Open
wants to merge 12 commits into
base: master
Choose a base branch
from

Conversation

zenspider
Copy link
Contributor

Fixes #1961

This PR fixes >300 warnings that are emitted while loading the code and/or running specs with warnings on.

Please consider reviewing this by commit.

Also consider turning off whitespace changes (for one commit on a rake task file). Tack on ?ws=1.

This is 12 commits, some should be squashed but I separated them because I didn't trust all my changes and this lets it be reviewable by the language owner.

Note: This completely removes use of (but not the definition of) Rouge.load_file and friends. They were not properly preventing double loads and eventually I decided it would be cleaner and easier if everything was just required via ruby to be more idiomatic and quell ~200 redefined method warnings. This does remove all of the "self-mutating" methods and eagerly loads the keyword files. It does not noticeably change load time at all. That might have been relevant when we all had slow spinning hard drives, but not anymore.

zenspider added 12 commits May 7, 2023 15:46
(no good way to set $VERBOSE from the outside)
Drops `rake check:specs VERBOSE=1` from 331 lines to 144.
load will load, always. Don't use it unless you really really mean it.
Most of these should just be removed instead of underscored... but I
want eyeballs on this first. Some aren't being used the way they think
they're being used.
Turns out it was one local variable used in a lot of regexps. This
updates the link to the reference and fixes it per reference.
…quire

Bundler shouldn't require everything. Slows down the world.
@zenspider
Copy link
Contributor Author

One warning is left for a regexp in julia that I am digging into but might best me:

lib/rouge/lexers/julia.rb:255: warning: character class has duplicated range: /[\p{L}\p{Nl}\p{S}_][\p{Word}\p{S}\p{Po}!]*/

I've figured out that it is it is the last half, and related to the ! being in Po, but when I reduce the regexp the warning goes away but when I put the fix back in the original it is still there... I'm a bit stumped.

@jneen
Copy link
Member

jneen commented May 17, 2023

Ya know, I've been against it in the past, but I wouldn't mind transitioning to require_relative. The current system comes from a time when ruby's require was painfully slow (and in my defense, require_relative wasn't standard in commonly used ruby versions), but I imagine that's been more or less fixed in the last 10 years.

@jneen
Copy link
Member

jneen commented May 17, 2023

That being said, I would not trust ruby's -w as some kind of northern star for "good code", especially when it comes to regular expressions. There are a large number of very odd design decisions in there that weren't very thought out IMO.

lib/rouge/lexers/xojo.rb Show resolved Hide resolved
Kernel::load File.join(Lexers::BASE_DIR, 'viml/keywords.rb')
self.keywords
end
require_relative "viml/keywords"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hm. The reason we did it this way was that these giant keyword files have a massive memory footprint, and we don't want Rouge to load them unless the lexer is actually in use. I think it'll still work if we use require_relative dynamically maybe?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

running the above benchmark code with /usr/bin/time -lph:

master:

            61194240  maximum resident set size
                3888  page reclaims
                   4  page faults
                  17  involuntary context switches
          6141564240  instructions retired
          1349472140  cycles elapsed
            55493952  peak memory footprint

mine:

            59604992  maximum resident set size
                3791  page reclaims
                   4  page faults
                  10  involuntary context switches
          6451778027  instructions retired
          1398372284  cycles elapsed
            51660096  peak memory footprint

(removed lines reporting 0)

I reran each 3 times and the numbers are all consistent...

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lib/rouge/lexers/syzlang.rb Show resolved Hide resolved
@@ -115,7 +115,7 @@ def self.keywords_type
rule %r/"/, Name::Variable, :double_string
rule %r/`/, Name::Variable, :backtick

rule %r/\w[\w\d]*/ do |m|
rule %r/\w+/ do |m|
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is probably a mistake and they meant either \p{L}\w+ or [a-zA-Z]\w+, would have to check the language spec for that.

lib/rouge/lexers/scala.rb Show resolved Hide resolved
@@ -73,7 +73,7 @@ def initialize(opts={})
end

state :export do
rule %r/[\w[\$]{1,2}{}()-]/, Name::Variable
rule %r/[\w\${}()-]/, Name::Variable
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not really this PR's fault, but we usually ask for + at the end of single-char-class regexes like this for perf reasons. This one's old enough it might have been my fault 😅

Copy link
Contributor Author

@zenspider zenspider May 29, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm fine adding the + ... but:

do you see how the {1,2} is also inside of a class, so it isn't a length specifier at all?... you might want to change the regexp to match more correctly. I haven't studied the make grammar in a really long time, but I'm pretty sure the above (either version) is incorrect.

Kernel::load File.join(Lexers::BASE_DIR, "llvm/keywords.rb")
types
end
require_relative "llvm/keywords"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Similar to before, we'd like to avoid loading these large keywords files for users who aren't highlighting LLVM. Though now I look at this it appears to have been a copy paste job and it will absolutely load that file multiple times 🤦

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The old code is wrong. It shouldn't use load. If that alone gets fixed, great... but seriously, The strategies you used 10 years ago to speed things up aren't the strategies you need today. Case in point:

$-w = nil

$: << "lib"
require "rouge"
keywords = Dir["lib/rouge/lexers/*/keywords.rb"]

iters = 30

t0 = Time.now
iters.times do
  keywords.each { |f| Kernel.load f }
end
t1 = Time.now

puts "Average time to load all keywords.rb: %8.5fs" % [(t1 - t0) / iters]

# Average time to load all keywords.rb:  0.00812s

It costs nearly nothing to load those keyword files... granted, every machine is different, but still. I suggest you measure and reevaluate whether self modifying code is worth it. I had thousands of lines of warnings when I was first evaluating whether to switch to rouge or not. Literally thousands. Those warnings have a cost too.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you really want to make rouge faster, don't load everything. Load (roughly) nothing. Push it towards a lazy loading system. But if you're going to load everything, let ruby do it and let it do it properly (and only once)

@zenspider
Copy link
Contributor Author

That being said, I would not trust ruby's -w as some kind of northern star for "good code", especially when it comes to regular expressions. There are a large number of very odd design decisions in there that weren't very thought out IMO.

Nobody is claiming this... Lack of output from -w doesn't mean "good code", but output from -w is evidence of "bad code" (for varying levels of "bad").

@zenspider
Copy link
Contributor Author

Where does this stand?

@zenspider
Copy link
Contributor Author

2 more weeks after months... Do what you want with this PR. I'm divesting myself of it.

@jneen
Copy link
Member

jneen commented Jul 25, 2023

Okay!

@tancnle
Copy link
Collaborator

tancnle commented Sep 6, 2023

Thank you for your hard work on this @zenspider 🙇🏼 ❤️

Sorry I am just catching up to this. I think the require_relative replacement makes sense to me. From the discussion threads above, I don't see there is any strong argument against it 🤔 (please correct me if I have misread). In that case, I think we should roll in the require_relative changes. The remaining can be broken down to smaller MRs so we can branch out further discussions. I can take point on splitting this MR. What do you think @zenspider @jneen?

@bkuhlmann
Copy link

bkuhlmann commented Sep 10, 2024

Hello. 👋 I'm running into this problem when warnings are enabled in my test environment. Here's what I'm using:

Implementation
# frozen_string_literal: true

require "asciidoctor"

module Milestoner
  module Renderers
    # Renders ASCII Doc as HTML.
    class Asciidoc
      SETTINGS = {
        safe: :safe,
        attributes: {
          "source-highlighter" => "rouge",
          "rouge-linenums-mode" => "inline"
        }
      }.freeze

      def initialize settings: SETTINGS, client: Asciidoctor
        @settings = settings
        @client = client
      end

      def call(content) = client.convert content, settings

      private

      attr_reader :settings, :client
    end
  end
end
Spec
require "spec_helper"

RSpec.describe Milestoner::Renderers::Asciidoc do
  subject(:renderer) { described_class.new }

  describe "#call" do
    it "answers HTML code block" do
      html = renderer.call <<~CONTENT
        [source,ruby]
        ----
        1 + 1 = 2
        ----
      CONTENT

      expect(html).to eq(<<~PROOF.strip)
        <div class="listingblock">
        <div class="content">
        <pre class="rouge highlight"><code data-lang="ruby"><span class="mi">1</span> <span class="o">+</span> <span class="mi">1</span> <span class="o">=</span> <span class="mi">2</span></code></pre>
        </div>
        </div>
      PROOF
    end
  end
end
Warnings

This is what I see in my console:

/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:18: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:18: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:29: warning: method redefined; discarding old keywords_type
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:29: warning: previous definition of keywords_type was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:50: warning: method redefined; discarding old reserved
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:50: warning: previous definition of reserved was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:59: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/c.rb:59: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/cpp.rb:23: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/cpp.rb:23: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/cpp.rb:37: warning: method redefined; discarding old keywords_type
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/cpp.rb:37: warning: previous definition of keywords_type was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/cpp.rb:43: warning: method redefined; discarding old reserved
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/cpp.rb:43: warning: previous definition of reserved was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:13: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:13: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:17: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:17: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:24: warning: method redefined; discarding old declarations
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:24: warning: previous definition of declarations was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:32: warning: method redefined; discarding old types
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:32: warning: previous definition of types was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:38: warning: method redefined; discarding old constants
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/groovy.rb:38: warning: previous definition of constants was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:52: warning: method redefined; discarding old initialize
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:52: warning: previous definition of initialize was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:63: warning: method redefined; discarding old allow_comments?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:63: warning: previous definition of allow_comments? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:72: warning: method redefined; discarding old comment_regex
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:72: warning: previous definition of comment_regex was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:76: warning: method redefined; discarding old end_chars
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:76: warning: previous definition of end_chars was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:86: warning: method redefined; discarding old error_regex
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:86: warning: previous definition of error_regex was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:92: warning: method redefined; discarding old lang_lexer
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:92: warning: previous definition of lang_lexer was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:105: warning: method redefined; discarding old line_regex
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:105: warning: previous definition of line_regex was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:109: warning: method redefined; discarding old output_lexer
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:109: warning: previous definition of output_lexer was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:122: warning: method redefined; discarding old process_line
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:122: warning: previous definition of process_line was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:167: warning: method redefined; discarding old prompt_prefix_regex
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:167: warning: previous definition of prompt_prefix_regex was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:175: warning: method redefined; discarding old prompt_regex
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:175: warning: previous definition of prompt_regex was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:181: warning: method redefined; discarding old stream_tokens
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/console.rb:181: warning: previous definition of stream_tokens was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:24: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:24: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:101: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:101: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:109: warning: method redefined; discarding old declarations
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:109: warning: previous definition of declarations was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:116: warning: method redefined; discarding old reserved
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:116: warning: previous definition of reserved was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:123: warning: method redefined; discarding old constants
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:123: warning: previous definition of constants was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:127: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:127: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:142: warning: method redefined; discarding old id_regex
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/javascript.rb:142: warning: previous definition of id_regex was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/julia.rb:255: warning: character class has duplicated range: /[\p{L}\p{Nl}\p{S}_][\p{Word}\p{S}\p{Po}!]*/
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lustre.rb:13: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lustre.rb:13: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lustre.rb:21: warning: method redefined; discarding old word_operators
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lustre.rb:21: warning: previous definition of word_operators was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lustre.rb:27: warning: method redefined; discarding old primitives
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lustre.rb:27: warning: previous definition of primitives was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/markdown.rb:15: warning: method redefined; discarding old html
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/markdown.rb:15: warning: previous definition of html was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:17: warning: method redefined; discarding old initialize
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:17: warning: previous definition of initialize was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:23: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:23: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:27: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:27: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:32: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/lua.rb:32: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:21: warning: method redefined; discarding old initialize
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:21: warning: previous definition of initialize was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:31: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:31: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:37: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:37: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:51: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:51: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:56: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/php.rb:56: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:15: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:15: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:19: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:19: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:28: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:28: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:42: warning: method redefined; discarding old builtins_pseudo
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:42: warning: previous definition of builtins_pseudo was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:46: warning: method redefined; discarding old exceptions
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:46: warning: previous definition of exceptions was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:73: warning: method redefined; discarding old current_string
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:73: warning: previous definition of current_string was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:248: warning: method redefined; discarding old delim?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:248: warning: previous definition of delim? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:252: warning: method redefined; discarding old register
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:252: warning: previous definition of register was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:256: warning: method redefined; discarding old remove
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:256: warning: previous definition of remove was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:260: warning: method redefined; discarding old type?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/python.rb:260: warning: previous definition of type? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/ruby.rb:18: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/ruby.rb:18: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/sql.rb:13: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/sql.rb:13: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/sql.rb:91: warning: method redefined; discarding old keywords_type
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/sql.rb:91: warning: previous definition of keywords_type was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/html.rb:13: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/html.rb:13: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:40: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:40: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:44: warning: method redefined; discarding old declarations
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:44: warning: previous definition of declarations was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:48: warning: method redefined; discarding old reserved
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:48: warning: previous definition of reserved was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:52: warning: method redefined; discarding old constants
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:52: warning: previous definition of constants was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:56: warning: method redefined; discarding old builtins
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/hcl.rb:56: warning: previous definition of builtins was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:16: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:16: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:24: warning: method redefined; discarding old tests
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:24: warning: previous definition of tests was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:30: warning: method redefined; discarding old pseudo_keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:30: warning: previous definition of pseudo_keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:34: warning: method redefined; discarding old word_operators
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/jinja.rb:34: warning: previous definition of word_operators was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xml.rb:17: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xml.rb:17: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:14: warning: method redefined; discarding old digits
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:14: warning: previous definition of digits was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:18: warning: method redefined; discarding old decimalLiteral
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:18: warning: previous definition of decimalLiteral was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:22: warning: method redefined; discarding old doubleLiteral
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:22: warning: previous definition of doubleLiteral was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:26: warning: method redefined; discarding old stringLiteral
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:26: warning: previous definition of stringLiteral was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:30: warning: method redefined; discarding old ncName
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:30: warning: previous definition of ncName was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:34: warning: method redefined; discarding old qName
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:34: warning: previous definition of qName was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:38: warning: method redefined; discarding old uriQName
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:38: warning: previous definition of uriQName was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:42: warning: method redefined; discarding old eqName
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:42: warning: previous definition of eqName was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:46: warning: method redefined; discarding old commentStart
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:46: warning: previous definition of commentStart was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:50: warning: method redefined; discarding old openParen
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:50: warning: previous definition of openParen was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:56: warning: method redefined; discarding old kindTest
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:56: warning: previous definition of kindTest was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:63: warning: method redefined; discarding old kindTestForPI
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:63: warning: previous definition of kindTestForPI was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:67: warning: method redefined; discarding old axes
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:67: warning: previous definition of axes was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:75: warning: method redefined; discarding old operators
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:75: warning: previous definition of operators was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:79: warning: method redefined; discarding old keywords
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:79: warning: previous definition of keywords was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:83: warning: method redefined; discarding old word_operators
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:83: warning: previous definition of word_operators was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:92: warning: method redefined; discarding old constructorTypes
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/xpath.rb:92: warning: previous definition of constructorTypes was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:16: warning: method redefined; discarding old detect?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:16: warning: previous definition of detect? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:25: warning: method redefined; discarding old reset_indent
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:25: warning: previous definition of reset_indent was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:32: warning: method redefined; discarding old indent
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:32: warning: previous definition of indent was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:37: warning: method redefined; discarding old dedent?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:37: warning: previous definition of dedent? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:41: warning: method redefined; discarding old indent?
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:41: warning: previous definition of indent? was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:46: warning: method redefined; discarding old save_indent
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:46: warning: previous definition of save_indent was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:62: warning: method redefined; discarding old continue_indent
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:62: warning: previous definition of continue_indent was here
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:67: warning: method redefined; discarding old set_indent
/Users/bkuhlmann/.cache/frum/versions/3.3.5/lib/ruby/gems/3.3.0/gems/rouge-4.3.0/lib/rouge/lexers/yaml.rb:67: warning: previous definition of set_indent was here

If I remove these attribues in my implementation:

attributes: {
  "source-highlighter" => "rouge",
  "rouge-linenums-mode" => "inline"
}

...the warnings go away. I don't think this is an Asciidoctor problem but with Rouge itself. It looks like this work is partially complete but I would expect these warnings to show up in the Rouge test suite when warnings are enabled?

I can make these warnings disappear by using the Warning gem to silence them for only the Rouge gem but it'd be great if this is fixed in Rouge proper.

Anyway, hope this helps.

@ashmaroli
Copy link
Contributor

Hello everyone, I know I am late to the party (I may have missed the notification from this an year ago), but to anyone coming across this pull request, the reason why the codebase contains numerous Kernel::load calls instead of require_relative is to allow reloading the various lexers while developing / enhancing a lexer.

The ideal solution here would be to have a custom loader that calls load in development mode but calls _require / require_relative in production mode.

Or, just delegate the loading process to gem "zeitwerk".

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Double loads, regex warnings, and cleanup, oh my!
5 participants