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

Bump html-pipeline from 3.0.3 to 3.2.1 #656

Closed
wants to merge 1 commit into from

Conversation

dependabot[bot]
Copy link
Contributor

@dependabot dependabot bot commented on behalf of github Aug 1, 2024

Bumps html-pipeline from 3.0.3 to 3.2.1.

Release notes

Sourced from html-pipeline's releases.

v3.2.1

What's Changed

New Contributors

Full Changelog: gjtorikian/html-pipeline@v3.2.0...v3.2.1

v3.2.0

What's Changed

Full Changelog: gjtorikian/html-pipeline@v3.1.1...v3.2.0

v3.1.1

What's Changed

Full Changelog: gjtorikian/html-pipeline@v3.1.0...v3.1.1

v3.1.0

What's Changed

New Contributors

Full Changelog: gjtorikian/html-pipeline@v3.0.3...v3.1.0

Changelog

Sourced from html-pipeline's changelog.

[v3.2.1] - 16-07-2024

What's Changed

Full Changelog: gjtorikian/html-pipeline@v3.2.0...v3.2.1

[v3.2.0] - 30-04-2024

What's Changed

Full Changelog: gjtorikian/html-pipeline@v3.1.1...v3.2.0

[v3.1.1] - 09-04-2024

What's Changed

Full Changelog: gjtorikian/html-pipeline@v3.1.0...v3.1.1

[v3.1.0] - 28-02-2024

What's Changed

New Contributors

Full Changelog: gjtorikian/html-pipeline@v3.0.3...v3.1.0

Commits

Dependabot compatibility score

You can trigger a rebase of this PR by commenting @dependabot rebase.


Dependabot commands and options

You can trigger Dependabot actions by commenting on this PR:

  • @dependabot rebase will rebase this PR
  • @dependabot recreate will recreate this PR, overwriting any edits that have been made to it
  • @dependabot merge will merge this PR after your CI passes on it
  • @dependabot squash and merge will squash and merge this PR after your CI passes on it
  • @dependabot cancel merge will cancel a previously requested merge and block automerging
  • @dependabot reopen will reopen this PR if it is closed
  • @dependabot close will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
  • @dependabot show <dependency name> ignore conditions will show all of the ignore conditions of the specified dependency
  • @dependabot ignore this major version will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
  • @dependabot ignore this minor version will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
  • @dependabot ignore this dependency will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)

Note
Automatic rebases have been disabled on this pull request as it has been open for over 30 days.

@dependabot dependabot bot added dependencies ruby Pull requests that update Ruby code labels Aug 1, 2024
Copy link

github-actions bot commented Aug 1, 2024

gem compare html-pipeline 3.0.3 3.2.1

Compared versions: ["3.0.3", "3.2.1"]
  DIFFERENT date:
    3.0.3: 2024-02-02 00:00:00 UTC
    3.2.1: 2024-07-31 00:00:00 UTC
  DIFFERENT rubygems_version:
    3.0.3: 3.5.5
    3.2.1: 3.4.6
  DIFFERENT version:
    3.0.3: 3.0.3
    3.2.1: 3.2.1
  DIFFERENT files:
    3.0.3->3.2.1:
      * Changed:
            .github/workflows/publish.yml +7/-2
            CHANGELOG.md +104/-52
            Gemfile +1/-3
            README.md +26/-13
            UPGRADING.md +0/-2
            html-pipeline.gemspec +1/-1
            lib/html_pipeline.rb +17/-11
            lib/html_pipeline/convert_filter.rb +1/-1
            lib/html_pipeline/convert_filter/markdown_filter.rb +4/-4
            lib/html_pipeline/filter.rb +1/-1
            lib/html_pipeline/node_filter.rb +2/-0
            lib/html_pipeline/node_filter/syntax_highlight_filter.rb +1/-1
            lib/html_pipeline/text_filter.rb +8/-8
            lib/html_pipeline/text_filter/image_filter.rb +2/-2
            lib/html_pipeline/text_filter/plain_text_input_filter.rb +2/-2
            lib/html_pipeline/version.rb +1/-1
  DIFFERENT runtime dependencies:
    3.0.3->3.2.1:
      * Updated:
            selma from: ["~> 0.1"] to: ["~> 0.4"]
  DIFFERENT Gemfile dependencies
    3.0.3->3.2.1:
      * Deleted
            github_changelog_generator ["~> 1.16"] (runtime)
      * Updated
            commonmarker from: ["~> 1.0.0.pre7"] to: ["~> 1.1.2"]

Copy link

github-actions bot commented Aug 1, 2024

gem compare --diff html-pipeline 3.0.3 3.2.1

Compared versions: ["3.0.3", "3.2.1"]
  DIFFERENT files:
    3.0.3->3.2.1:
      * Changed:
        .github/workflows/publish.yml
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/.github/workflows/publish.yml	2024-08-01 02:40:31.088558873 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/.github/workflows/publish.yml	2024-08-01 02:40:31.092558935 +0000
                @@ -1 +1 @@
                -name: Release
                +name: Tag and Release
                @@ -9,0 +10,3 @@
                +  pull_request_target:
                +    types:
                +      - closed
                @@ -16 +19 @@
                -      gh_token: ${{ secrets.PUBLIC_PUSH_TO_PROTECTED_BRANCH }}
                +      gh_token: ${{ secrets.GITHUB_TOKEN }}
                @@ -19,0 +23,2 @@
                +      prepare: ${{ github.event_name == 'push' }}
                +      release: ${{ github.event_name == 'workflow_dispatch' || ((github.event.pull_request.merged == true) && (contains(github.event.pull_request.labels.*.name, 'release'))) }}
        CHANGELOG.md
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/CHANGELOG.md	2024-08-01 02:40:31.088558873 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/CHANGELOG.md	2024-08-01 02:40:31.096558997 +0000
                @@ -0,0 +1,42 @@
                +# [v3.2.1] - 16-07-2024
                +## What's Changed
                +* Update commonmarker requirement from ~> 1.0.0.pre7 to ~> 1.1.2 in the bundler-dependencies group by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/404
                +* Remove superfluous sanitization by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/408
                +
                +
                +**Full Changelog**: https://github.com/gjtorikian/html-pipeline/compare/v3.2.0...v3.2.1
                +## [v3.2.0] - 30-04-2024
                +## What's Changed
                +* Pass context along to every part of the pipeline by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/403
                +
                +
                +**Full Changelog**: https://github.com/gjtorikian/html-pipeline/compare/v3.1.1...v3.2.0
                +## [v3.1.1] - 09-04-2024
                +## What's Changed
                +* Correct missing method implementation by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/401
                +
                +
                +**Full Changelog**: https://github.com/gjtorikian/html-pipeline/compare/v3.1.0...v3.1.1
                +## [v3.1.0] - 28-02-2024
                +## What's Changed
                +* UPGRADING:  not removed by @dentarg in https://github.com/gjtorikian/html-pipeline/pull/397
                +* [BREAKING]  now requires instantiation by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/398
                +
                +## New Contributors
                +* @dentarg made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/397
                +
                +**Full Changelog**: https://github.com/gjtorikian/html-pipeline/compare/v3.0.3...v3.1.0
                +## [v3.0.3] - 02-02-2024
                +
                +## What's Changed
                +
                +- Fix typo in README by @ppworks in https://github.com/gjtorikian/html-pipeline/pull/394
                +- Prevent exception by @ppworks in https://github.com/gjtorikian/html-pipeline/pull/395
                +- Cut 3.0.3 by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/396
                +
                +## New Contributors
                +
                +- @ppworks made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/394
                +
                +**Full Changelog**: https://github.com/gjtorikian/html-pipeline/compare/v3.0.2...v3.0.3
                +
                @@ -1,0 +44 @@
                +
                @@ -3,2 +46,3 @@
                -* README.md: Fix example code by @grekko in https://github.com/gjtorikian/html-pipeline/pull/390
                -* Allow pipeline to run without node filters by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/392
                +
                +- README.md: Fix example code by @grekko in https://github.com/gjtorikian/html-pipeline/pull/390
                +- Allow pipeline to run without node filters by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/392
                @@ -7 +51,2 @@
                -* @grekko made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/390
                +
                +- @grekko made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/390
                @@ -9,0 +55 @@
                +
                @@ -10,0 +57 @@
                +
                @@ -12 +59,2 @@
                -* Handle odd numbers of NodeFilters to be configured by @stevehill1981 in https://github.com/gjtorikian/html-pipeline/pull/389
                +
                +- Handle odd numbers of NodeFilters to be configured by @stevehill1981 in https://github.com/gjtorikian/html-pipeline/pull/389
                @@ -15 +63,2 @@
                -* @stevehill1981 made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/389
                +
                +- @stevehill1981 made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/389
                @@ -17,0 +67 @@
                +
                @@ -18,0 +69 @@
                +
                @@ -20,20 +71,21 @@
                -* Switch to GitHub Actions by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/346
                -* add truffleruby-head by @gogainda in https://github.com/gjtorikian/html-pipeline/pull/348
                -* Add Rubocop by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/349
                -* Support multiple dependencies per filter by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/351
                -* Split filters up by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/360
                -* Migrate from Nokogiri to Selma by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/368
                -* You shall pass by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/369
                -* Update Selma signatures by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/370
                -* Close sanitization-related issues by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/371
                -* Drop SyntaxHighlightFilter by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/372
                -* V3 Release by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/347
                -* Use emoji from commonmarker by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/373
                -* req convert_filter if filter present by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/375
                -* Update selma requirement from ~> 0.0.1 to >= 0.0.1, < 0.2.0 by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/377
                -* Add the AssetProxyFilter by @digitalmoksha in https://github.com/gjtorikian/html-pipeline/pull/379
                -* Update rouge requirement from ~> 3.1 to ~> 4.1 by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/381
                -* Update gemoji requirement from ~> 3.0 to ~> 4.1 by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/382
                -* Have Zeitwerk not automatically load filters by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/383
                -* Bump the github-actions group with 1 update by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/384
                -* :gem: 3.0.0 by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/386
                +
                +- Switch to GitHub Actions by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/346
                +- add truffleruby-head by @gogainda in https://github.com/gjtorikian/html-pipeline/pull/348
                +- Add Rubocop by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/349
                +- Support multiple dependencies per filter by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/351
                +- Split filters up by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/360
                +- Migrate from Nokogiri to Selma by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/368
                +- You shall pass by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/369
                +- Update Selma signatures by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/370
                +- Close sanitization-related issues by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/371
                +- Drop SyntaxHighlightFilter by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/372
                +- V3 Release by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/347
                +- Use emoji from commonmarker by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/373
                +- req convert_filter if filter present by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/375
                +- Update selma requirement from ~> 0.0.1 to >= 0.0.1, < 0.2.0 by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/377
                +- Add the AssetProxyFilter by @digitalmoksha in https://github.com/gjtorikian/html-pipeline/pull/379
                +- Update rouge requirement from ~> 3.1 to ~> 4.1 by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/381
                +- Update gemoji requirement from ~> 3.0 to ~> 4.1 by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/382
                +- Have Zeitwerk not automatically load filters by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/383
                +- Bump the github-actions group with 1 update by @dependabot in https://github.com/gjtorikian/html-pipeline/pull/384
                +- :gem: 3.0.0 by @gjtorikian in https://github.com/gjtorikian/html-pipeline/pull/386
                @@ -42,3 +94,4 @@
                -* @gogainda made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/348
                -* @dependabot made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/377
                -* @digitalmoksha made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/379
                +
                +- @gogainda made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/348
                +- @dependabot made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/377
                +- @digitalmoksha made their first contribution in https://github.com/gjtorikian/html-pipeline/pull/379
                @@ -46,0 +100 @@
                +
                @@ -47,0 +102 @@
                +
                @@ -48,0 +104 @@
                +
                @@ -79 +135 @@
                -- req convert\_filter if `text/node`filter present [\#375](https://github.com/gjtorikian/html-pipeline/pull/375) ([gjtorikian](https://github.com/gjtorikian))
                +- req convert_filter if `text/node`filter present [\#375](https://github.com/gjtorikian/html-pipeline/pull/375) ([gjtorikian](https://github.com/gjtorikian))
                @@ -140 +196 @@
                -- Replace EscapeUtils.escape\_html with CGI.escape\_html [\#365](https://github.com/gjtorikian/html-pipeline/pull/365) ([ramhoj](https://github.com/ramhoj))
                +- Replace EscapeUtils.escape_html with CGI.escape_html [\#365](https://github.com/gjtorikian/html-pipeline/pull/365) ([ramhoj](https://github.com/ramhoj))
                @@ -312 +368 @@
                -- New feature request for hashtags \# filter  [\#301](https://github.com/gjtorikian/html-pipeline/issues/301)
                +- New feature request for hashtags \# filter [\#301](https://github.com/gjtorikian/html-pipeline/issues/301)
                @@ -415 +471 @@
                --   add korgi to 3rd party extensions \[ci skip\] [\#271](https://github.com/gjtorikian/html-pipeline/pull/271) ([jodeci](https://github.com/jodeci))
                +- add korgi to 3rd party extensions \[ci skip\] [\#271](https://github.com/gjtorikian/html-pipeline/pull/271) ([jodeci](https://github.com/jodeci))
                @@ -424 +480 @@
                -- Missing context keys for HTML::Pipeline::EmojiFilter: :asset\_root [\#262](https://github.com/gjtorikian/html-pipeline/issues/262)
                +- Missing context keys for HTML::Pipeline::EmojiFilter: :asset_root [\#262](https://github.com/gjtorikian/html-pipeline/issues/262)
                @@ -507,2 +563,2 @@
                -- Fix for calling mention\_link\_filter with only one argument [\#230](https://github.com/gjtorikian/html-pipeline/pull/230) ([benbalter](https://github.com/benbalter))
                -- Add html-pipeline-linkify\_github to 3rd Party Extensions \[ci skip\] [\#228](https://github.com/gjtorikian/html-pipeline/pull/228) ([JuanitoFatas](https://github.com/JuanitoFatas))
                +- Fix for calling mention_link_filter with only one argument [\#230](https://github.com/gjtorikian/html-pipeline/pull/230) ([benbalter](https://github.com/benbalter))
                +- Add html-pipeline-linkify_github to 3rd Party Extensions \[ci skip\] [\#228](https://github.com/gjtorikian/html-pipeline/pull/228) ([JuanitoFatas](https://github.com/JuanitoFatas))
                @@ -564 +620 @@
                -- MentionFilter base\_url config question [\#161](https://github.com/gjtorikian/html-pipeline/issues/161)
                +- MentionFilter base_url config question [\#161](https://github.com/gjtorikian/html-pipeline/issues/161)
                @@ -576,2 +632,2 @@
                -- Add 3rd party gem: html-pipeline-rouge\_filter. [\#174](https://github.com/gjtorikian/html-pipeline/pull/174) ([JuanitoFatas](https://github.com/JuanitoFatas))
                -- MentionFilter\#link\_to\_mentioned\_user: Replace String introspection with Regexp match [\#172](https://github.com/gjtorikian/html-pipeline/pull/172) ([simeonwillbanks](https://github.com/simeonwillbanks))
                +- Add 3rd party gem: html-pipeline-rouge_filter. [\#174](https://github.com/gjtorikian/html-pipeline/pull/174) ([JuanitoFatas](https://github.com/JuanitoFatas))
                +- MentionFilter\#link_to_mentioned_user: Replace String introspection with Regexp match [\#172](https://github.com/gjtorikian/html-pipeline/pull/172) ([simeonwillbanks](https://github.com/simeonwillbanks))
                @@ -579 +635 @@
                -- Implement new context option: ignored\_ancestor\_tags to accept more ignored tags. [\#170](https://github.com/gjtorikian/html-pipeline/pull/170) ([JuanitoFatas](https://github.com/JuanitoFatas))
                +- Implement new context option: ignored_ancestor_tags to accept more ignored tags. [\#170](https://github.com/gjtorikian/html-pipeline/pull/170) ([JuanitoFatas](https://github.com/JuanitoFatas))
                @@ -596 +652 @@
                -- @mention\_filter should not replace mentions in style blocks. [\#143](https://github.com/gjtorikian/html-pipeline/issues/143)
                +- @mention_filter should not replace mentions in style blocks. [\#143](https://github.com/gjtorikian/html-pipeline/issues/143)
                @@ -603 +659 @@
                -- Prefer http\_url in HttpsFilter [\#142](https://github.com/gjtorikian/html-pipeline/pull/142) ([bkeepers](https://github.com/bkeepers))
                +- Prefer http_url in HttpsFilter [\#142](https://github.com/gjtorikian/html-pipeline/pull/142) ([bkeepers](https://github.com/bkeepers))
                @@ -635 +691 @@
                -- Remove RUBY\_VERSION conditionals from gemspec [\#130](https://github.com/gjtorikian/html-pipeline/pull/130) ([mislav](https://github.com/mislav))
                +- Remove RUBY_VERSION conditionals from gemspec [\#130](https://github.com/gjtorikian/html-pipeline/pull/130) ([mislav](https://github.com/mislav))
                @@ -662 +718 @@
                -- AutolinkFilter link\_attr doesn't seem to work [\#114](https://github.com/gjtorikian/html-pipeline/issues/114)
                +- AutolinkFilter link_attr doesn't seem to work [\#114](https://github.com/gjtorikian/html-pipeline/issues/114)
                @@ -750 +806 @@
                -- Add link\_attr option to Autolink filter [\#89](https://github.com/gjtorikian/html-pipeline/pull/89) ([excid3](https://github.com/excid3))
                +- Add link_attr option to Autolink filter [\#89](https://github.com/gjtorikian/html-pipeline/pull/89) ([excid3](https://github.com/excid3))
                @@ -752 +808 @@
                -- use xml\_mini extracted from activesupport [\#85](https://github.com/gjtorikian/html-pipeline/pull/85) ([mojavelinux](https://github.com/mojavelinux))
                +- use xml_mini extracted from activesupport [\#85](https://github.com/gjtorikian/html-pipeline/pull/85) ([mojavelinux](https://github.com/mojavelinux))
                @@ -820 +876 @@
                -- Allow passing skip\_tags in autolink filter context [\#65](https://github.com/gjtorikian/html-pipeline/pull/65) ([pengwynn](https://github.com/pengwynn))
                +- Allow passing skip_tags in autolink filter context [\#65](https://github.com/gjtorikian/html-pipeline/pull/65) ([pengwynn](https://github.com/pengwynn))
                @@ -873 +929 @@
                -- add result\[:mentioned\_usernames\] for MentionFilter [\#42](https://github.com/gjtorikian/html-pipeline/pull/42) ([fahchen](https://github.com/fahchen))
                +- add result\[:mentioned_usernames\] for MentionFilter [\#42](https://github.com/gjtorikian/html-pipeline/pull/42) ([fahchen](https://github.com/fahchen))
                @@ -889 +945 @@
                -- Bump escape\_utils [\#41](https://github.com/gjtorikian/html-pipeline/pull/41) ([brianmario](https://github.com/brianmario))
                +- Bump escape_utils [\#41](https://github.com/gjtorikian/html-pipeline/pull/41) ([brianmario](https://github.com/brianmario))
                @@ -981,4 +1036,0 @@
                -
                -
                -
                -\* *This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)*
        Gemfile
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/Gemfile	2024-08-01 02:40:31.088558873 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/Gemfile	2024-08-01 02:40:31.096558997 +0000
                @@ -13,2 +12,0 @@
                -gem "github_changelog_generator", "~> 1.16"
                -
                @@ -30 +28 @@
                -  gem "commonmarker", "~> 1.0.0.pre7", require: false
                +  gem "commonmarker", "~> 1.1.2", require: false
        README.md
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/README.md	2024-08-01 02:40:31.088558873 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/README.md	2024-08-01 02:40:31.096558997 +0000
                @@ -3,3 +2,0 @@
                -> **Note**
                -> This README refers to the behavior in the new 3.0.0.pre gem.
                -
                @@ -63 +60 @@
                -As an example, suppose we want to transform Commonmark source text into Markdown HTML. With the content, we also want to:
                +As an example, suppose we want to transform Commonmark source text into Markdown HTML:
                @@ -65 +62,7 @@
                -- change every instance of `$NAME` to "`Johnny"
                +```
                +Hey there, @gjtorikian
                +```
                +
                +With the content, we also want to:
                +
                +- change every instance of `Hey` to `Hello`
                @@ -76 +79 @@
                -    text.gsub("$NAME", "Johnny")
                +    text.gsub("Hey", "Hello")
                @@ -107 +110 @@
                -context =  { markdown: { extensions: { footnotes: false } } }
                +context = { markdown: { extensions: { footnotes: false } } }
                @@ -111,0 +115,10 @@
                +Alternatively, you can construct a pipeline, and pass in a context during the call:
                +
                +```ruby
                +pipeline = HTMLPipeline.new(
                +  convert_filter: HTMLPipeline::ConvertFilter::MarkdownFilter.new,
                +  node_filters: [HTMLPipeline::NodeFilter::MentionFilter.new]
                +)
                +pipeline.call(user_supplied_text, context: { markdown: { extensions: { footnotes: false } } })
                +```
                +
                @@ -161 +174 @@
                -Because the web can be a scary place, HTML is automatically sanitized after the `ConvertFilter` runs and before the `NodeFilter`s are processed. This is to prevent malicious or unexpected input from entering the pipeline.
                +Because the web can be a scary place, **HTML is automatically sanitized** after the `ConvertFilter` runs and before the `NodeFilter`s are processed. This is to prevent malicious or unexpected input from entering the pipeline.
                @@ -163 +176 @@
                -The sanitization process takes a hash configuration of settings. See the [Selma](https://www.github.com/gjtorikian/selma) documentation for more information on how to configure these settings.
                +The sanitization process takes a hash configuration of settings. See the [Selma](https://www.github.com/gjtorikian/selma) documentation for more information on how to configure these settings. Note that users must correctly configure the sanitization configuration if they expect to use it correctly in conjunction with handlers which manipulate HTML.
                @@ -174 +187 @@
                -    HTMLPipeline::MarkdownFilter,
                +    HTMLPipeline::TextFilter::ImageFilter.new,
                @@ -202 +215 @@
                -    HTMLPipeline::MarkdownFilter,
                +    HTMLPipeline::TextFilter::ImageFilter.new,
                @@ -214 +227 @@
                -`NodeFilter` also has an optional method, `after_initialize`, which is run after the filter initializes. This can be useful in setting up a custom state for `result` to take advantage of.
                +`NodeFilter` also has an optional method, `after_initialize`, which is run after the filter initializes. This can be useful in setting up a fresh custom state for `result` to start from each time the pipeline is called.
                @@ -378 +391 @@
                -config = HTMLPipeline::SanitizationFilter::DEFAULT_CONFIG.dup
                +config = HTMLPipeline::SanitizationFilter::DEFAULT_CONFIG.deep_dup
        UPGRADING.md
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/UPGRADING.md	2024-08-01 02:40:31.088558873 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/UPGRADING.md	2024-08-01 02:40:31.096558997 +0000
                @@ -17 +16,0 @@
                -
                @@ -20 +18,0 @@
                -- `TextFilter`
        html-pipeline.gemspec
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/html-pipeline.gemspec	2024-08-01 02:40:31.088558873 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/html-pipeline.gemspec	2024-08-01 02:40:31.096558997 +0000
                @@ -28 +28 @@
                -  gem.add_dependency("selma", "~> 0.1")
                +  gem.add_dependency("selma", "~> 0.4")
        lib/html_pipeline.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -156 +156 @@
                -        text_filters: @text_filters.map(&:name),
                +        text_filters: @text_filters.map { |f| f.class.name },
                @@ -163 +163 @@
                -            perform_filter(filter, doc, context: context, result: result)
                +            perform_filter(filter, doc, context: (filter.context || {}).merge(context), result: result)
                @@ -174 +174 @@
                -        html = @convert_filter.call(text)
                +        html = @convert_filter.call(text, context: (@convert_filter.context || {}).merge(context))
                @@ -178 +178,11 @@
                -    unless @node_filters.empty?
                +    rewriter_options = {
                +      memory: {
                +        max_allowed_memory_usage: 5242880, # arbitrary limit of 5MB
                +      },
                +    }
                +
                +    if @node_filters.empty?
                +      instrument("sanitization.html_pipeline", payload) do
                +        result[:output] = Selma::Rewriter.new(sanitizer: @sanitization_config, handlers: @node_filters, options: rewriter_options).rewrite(html)
                +      end unless @convert_filter.nil? # no html, so no sanitization
                +    else
                @@ -180,2 +190,2 @@
                -        result[:output] = Selma::Rewriter.new(sanitizer: @sanitization_config, handlers: @node_filters).rewrite(html)
                -        html = result[:output]
                +        @node_filters.each { |filter| filter.context = (filter.context || {}).merge(context) }
                +        result[:output] = Selma::Rewriter.new(sanitizer: @sanitization_config, handlers: @node_filters, options: rewriter_options).rewrite(html)
                @@ -190,4 +199,0 @@
                -    instrument("html_pipeline.sanitization", payload) do
                -      result[:output] = Selma::Rewriter.new(sanitizer: @sanitization_config, handlers: @node_filters).rewrite(html)
                -    end
                -
                @@ -207 +213 @@
                -      filter: filter.name,
                +      filter: filter.class.name,
        lib/html_pipeline/convert_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/convert_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/convert_filter.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -8 +8 @@
                -      super(context: context, result: result)
                +      super
        lib/html_pipeline/convert_filter/markdown_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/convert_filter/markdown_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/convert_filter/markdown_filter.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -6 +6 @@
                -  class ConvertFilter
                +  class ConvertFilter < Filter
                @@ -15 +15 @@
                -        super(context: context, result: result)
                +        super
                @@ -19,2 +19,2 @@
                -      def call(text)
                -        options = @context.fetch(:markdown, {})
                +      def call(text, context: @context)
                +        options = context.fetch(:markdown, {})
        lib/html_pipeline/filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/filter.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -30 +30 @@
                -    attr_reader :context
                +    attr_accessor :context
        lib/html_pipeline/node_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/node_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/node_filter.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -6,0 +7,2 @@
                +    attr_accessor :context
                +
        lib/html_pipeline/node_filter/syntax_highlight_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/node_filter/syntax_highlight_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/node_filter/syntax_highlight_filter.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -18 +18 @@
                -        super(context: context, result: result)
                +        super
        lib/html_pipeline/text_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/text_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/text_filter.rb	2024-08-01 02:40:31.096558997 +0000
                @@ -7,6 +7,2 @@
                -    def initialize(text, context: {}, result: {})
                -      raise TypeError, "text must be a String" unless text.is_a?(String)
                -
                -      # Ensure that this is always a string
                -      @text = text.respond_to?(:to_str) ? text.to_str : text.to_s
                -      super(context: context, result: result)
                +    def initialize(context: {}, result: {})
                +      super
                @@ -16,2 +12,6 @@
                -      def call(input, context: {}, result: {})
                -        new(input, context: context, result: result).call
                +      def call(text, context: {}, result: {})
                +        raise TypeError, "text must be a String" unless text.is_a?(String)
                +
                +        # Ensure that this is always a string
                +        text = text.respond_to?(:to_str) ? text.to_str : text.to_s
                +        new(context: context, result: result).call(text)
        lib/html_pipeline/text_filter/image_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/text_filter/image_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/text_filter/image_filter.rb	2024-08-01 02:40:31.100559059 +0000
                @@ -12,2 +12,2 @@
                -      def call
                -        @text.gsub(%r{(https|http)?://.+\.(jpg|jpeg|bmp|gif|png)(\?\S+)?}i) do |match|
                +      def call(text, context: {}, result: {})
                +        text.gsub(%r{(https|http)?://.+\.(jpg|jpeg|bmp|gif|png)(\?\S+)?}i) do |match|
        lib/html_pipeline/text_filter/plain_text_input_filter.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/text_filter/plain_text_input_filter.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/text_filter/plain_text_input_filter.rb	2024-08-01 02:40:31.100559059 +0000
                @@ -8,2 +8,2 @@
                -      def call
                -        "<div>#{CGI.escapeHTML(@text)}</div>"
                +      def call(text, context: {}, result: {})
                +        "<div>#{CGI.escapeHTML(text)}</div>"
        lib/html_pipeline/version.rb
                --- /tmp/d20240801-1840-q1vjcs/html-pipeline-3.0.3/lib/html_pipeline/version.rb	2024-08-01 02:40:31.092558935 +0000
                +++ /tmp/d20240801-1840-q1vjcs/html-pipeline-3.2.1/lib/html_pipeline/version.rb	2024-08-01 02:40:31.100559059 +0000
                @@ -4 +4 @@
                -  VERSION = "3.0.3"
                +  VERSION = "3.2.1"

Copy link

github-actions bot commented Aug 1, 2024

gem compare rb_sys 0.9.88 0.9.99

Compared versions: ["0.9.88", "0.9.99"]
  DIFFERENT cert_chain:
    0.9.88: ["-----BEGIN CERTIFICATE-----\nMIIDfDCCAmSgAwIBAgIBATANBgkqhkiG9w0BAQsFADBCMRQwEgYDVQQDDAtpLmtl\ncnNleW1lcjEVMBMGCgmSJomT8ixkARkWBWdtYWlsMRMwEQYKCZImiZPyLGQBGRYD\nY29tMB4XDTIzMDQxNDEzMzYxNVoXDTI0MDQxMzEzMzYxNVowQjEUMBIGA1UEAwwL\naS5rZXJzZXltZXIxFTATBgoJkiaJk/IsZAEZFgVnbWFpbDETMBEGCgmSJomT8ixk\nARkWA2NvbTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMJ2pG+er4cP\nPasxsMIKL9/tmLL4gh80EMuF3SCS0qZoh+Oo8dkvRYxW8NXdwEIcp3cCNgE+5G+J\nTCMOVF8S15n1Z1P7xxXiXxa/BIofKKbtatVRngm14uR/6pjdkvLXqlrWdS57bNwv\n7LtpzYVfDHfsl/qRWaEi4jq00PNCRSWjcva8teqswjBg8KlwGtyygpezPbVSWP8Y\nvzWZmVF7fqRBXU78Ah0+pNOhslBXDTvI3xJdN4hQ3H7rLjpD/qxKWq/8o+Qvx6cX\ndNZ3ugH/Pr3BAsqt4JFLXin9AK7PO9GDMH5JXJrUb+hAt2VNIZqpz9VlKA6BA0jN\neWGea+yCZkECAwEAAaN9MHswCQYDVR0TBAIwADALBgNVHQ8EBAMCBLAwHQYDVR0O\nBBYEFOkrF6hsocaIMOjR/K3JBzyXCLJPMCAGA1UdEQQZMBeBFWkua2Vyc2V5bWVy\nQGdtYWlsLmNvbTAgBgNVHRIEGTAXgRVpLmtlcnNleW1lckBnbWFpbC5jb20wDQYJ\nKoZIhvcNAQELBQADggEBAMAohCl0cdVlYrJl9viGtzbEyLV/Krn0ZD/LM9d2cIRj\nWBu7HRkP6AfYVzhZwdgUgDYw67d715kOMpLNGeWQw3QGEHFqbVzRML64jL8IxuTz\nJ8ttZVqM8f4GrHyISJnL92u6iP4WzdbVqx89EFjrrHd14OJXK+ZpdRh0YvnN/vMJ\nt2EcDweRHkN/MEdrwbH+PbYjELnKcTIEZqcCWTk8pgssGrNyjkMhxGSsSUo9qTz0\nDIZ6NVmpBvohJVCCCDxQQxFKLXZp1ivoxjN+m7eJSW7yzIz062pH4u8pPNQsiVSb\nI5rgRPbDr2rAFGXKoQ0+u6CLkRxqrVsITl/OPfZhBQI=\n-----END CERTIFICATE-----\n"]
    0.9.99: ["-----BEGIN CERTIFICATE-----\nMIIDODCCAiCgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBCMRQwEgYDVQQDDAtpLmtl\ncnNleW1lcjEVMBMGCgmSJomT8ixkARkWBWdtYWlsMRMwEQYKCZImiZPyLGQBGRYD\nY29tMB4XDTI0MDQxODA1MzY0N1oXDTI1MDQxODA1MzY0N1owQjEUMBIGA1UEAwwL\naS5rZXJzZXltZXIxFTATBgoJkiaJk/IsZAEZFgVnbWFpbDETMBEGCgmSJomT8ixk\nARkWA2NvbTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMJ2pG+er4cP\nPasxsMIKL9/tmLL4gh80EMuF3SCS0qZoh+Oo8dkvRYxW8NXdwEIcp3cCNgE+5G+J\nTCMOVF8S15n1Z1P7xxXiXxa/BIofKKbtatVRngm14uR/6pjdkvLXqlrWdS57bNwv\n7LtpzYVfDHfsl/qRWaEi4jq00PNCRSWjcva8teqswjBg8KlwGtyygpezPbVSWP8Y\nvzWZmVF7fqRBXU78Ah0+pNOhslBXDTvI3xJdN4hQ3H7rLjpD/qxKWq/8o+Qvx6cX\ndNZ3ugH/Pr3BAsqt4JFLXin9AK7PO9GDMH5JXJrUb+hAt2VNIZqpz9VlKA6BA0jN\neWGea+yCZkECAwEAAaM5MDcwCQYDVR0TBAIwADALBgNVHQ8EBAMCBLAwHQYDVR0O\nBBYEFOkrF6hsocaIMOjR/K3JBzyXCLJPMA0GCSqGSIb3DQEBCwUAA4IBAQARHgco\nyCxWUqN+HBGewmSB7T4oq6YS2FtU62K+GuWWCTqjl5byLKMXQW8HPDja9TC1My1m\n2r0uDshtUvUjuB/Vfe9jVMTjnPBspHZYo0MRuMPc7owJaahjkqD3l7w9aa8Ci5aC\nYU4Aj71Sc8s7YIxgHn/yIUdCe1yu6cC0+h+Ss9r/Yjr53NNXwjGQlDmH1eHcVQGZ\nmEoVcZO1uWNtRPPsn1gfvKLPjRe5pclXQnGviS5DiH0Du+8QMxQGBJnYz2zSMW7G\nLvd35BNvZkhFzs9xfykhurpkT2TiP2F3ZFn9dwLXMFe41pwrtEYLIWhYi8mUG4Ek\n6aR8M/tqIpChVV39\n-----END CERTIFICATE-----\n"]
  DIFFERENT date:
    0.9.88: 1980-01-01 00:00:00 UTC
    0.9.99: 2024-07-25 00:00:00 UTC
  DIFFERENT required_ruby_version:
    0.9.88: >= 2.3.0
    0.9.99: >= 2.5.0
  DIFFERENT rubygems_version:
    0.9.88: 3.5.5
    0.9.99: 3.5.3
  DIFFERENT version:
    0.9.88: 0.9.88
    0.9.99: 0.9.99
  DIFFERENT files:
    0.9.88->0.9.99:
      * Changed:
            certs/ianks.pem +10/-11
            exe/rb-sys-dock +11/-5
            lib/rb_sys/cargo/metadata.rb +30/-0
            lib/rb_sys/cargo_builder.rb +20/-6
            lib/rb_sys/extensiontask.rb +1/-1
            lib/rb_sys/mkmf.rb +9/-6
            lib/rb_sys/mkmf/config.rb +6/-1
            lib/rb_sys/toolchain_info.rb +7/-0
            lib/rb_sys/toolchain_info/data.rb +1/-1
            lib/rb_sys/version.rb +1/-1

Copy link

github-actions bot commented Aug 1, 2024

gem compare --diff rb_sys 0.9.88 0.9.99

Compared versions: ["0.9.88", "0.9.99"]
  DIFFERENT files:
    0.9.88->0.9.99:
      * Changed:
        certs/ianks.pem
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/certs/ianks.pem	2024-08-01 02:40:36.804651419 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/certs/ianks.pem	2024-08-01 02:40:36.808651498 +0000
                @@ -2 +2 @@
                -MIIDfDCCAmSgAwIBAgIBATANBgkqhkiG9w0BAQsFADBCMRQwEgYDVQQDDAtpLmtl
                +MIIDODCCAiCgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBCMRQwEgYDVQQDDAtpLmtl
                @@ -4 +4 @@
                -Y29tMB4XDTIzMDQxNDEzMzYxNVoXDTI0MDQxMzEzMzYxNVowQjEUMBIGA1UEAwwL
                +Y29tMB4XDTI0MDQxODA1MzY0N1oXDTI1MDQxODA1MzY0N1owQjEUMBIGA1UEAwwL
                @@ -12,9 +12,8 @@
                -eWGea+yCZkECAwEAAaN9MHswCQYDVR0TBAIwADALBgNVHQ8EBAMCBLAwHQYDVR0O
                -BBYEFOkrF6hsocaIMOjR/K3JBzyXCLJPMCAGA1UdEQQZMBeBFWkua2Vyc2V5bWVy
                -QGdtYWlsLmNvbTAgBgNVHRIEGTAXgRVpLmtlcnNleW1lckBnbWFpbC5jb20wDQYJ
                -KoZIhvcNAQELBQADggEBAMAohCl0cdVlYrJl9viGtzbEyLV/Krn0ZD/LM9d2cIRj
                -WBu7HRkP6AfYVzhZwdgUgDYw67d715kOMpLNGeWQw3QGEHFqbVzRML64jL8IxuTz
                -J8ttZVqM8f4GrHyISJnL92u6iP4WzdbVqx89EFjrrHd14OJXK+ZpdRh0YvnN/vMJ
                -t2EcDweRHkN/MEdrwbH+PbYjELnKcTIEZqcCWTk8pgssGrNyjkMhxGSsSUo9qTz0
                -DIZ6NVmpBvohJVCCCDxQQxFKLXZp1ivoxjN+m7eJSW7yzIz062pH4u8pPNQsiVSb
                -I5rgRPbDr2rAFGXKoQ0+u6CLkRxqrVsITl/OPfZhBQI=
                +eWGea+yCZkECAwEAAaM5MDcwCQYDVR0TBAIwADALBgNVHQ8EBAMCBLAwHQYDVR0O
                +BBYEFOkrF6hsocaIMOjR/K3JBzyXCLJPMA0GCSqGSIb3DQEBCwUAA4IBAQARHgco
                +yCxWUqN+HBGewmSB7T4oq6YS2FtU62K+GuWWCTqjl5byLKMXQW8HPDja9TC1My1m
                +2r0uDshtUvUjuB/Vfe9jVMTjnPBspHZYo0MRuMPc7owJaahjkqD3l7w9aa8Ci5aC
                +YU4Aj71Sc8s7YIxgHn/yIUdCe1yu6cC0+h+Ss9r/Yjr53NNXwjGQlDmH1eHcVQGZ
                +mEoVcZO1uWNtRPPsn1gfvKLPjRe5pclXQnGviS5DiH0Du+8QMxQGBJnYz2zSMW7G
                +Lvd35BNvZkhFzs9xfykhurpkT2TiP2F3ZFn9dwLXMFe41pwrtEYLIWhYi8mUG4Ek
                +6aR8M/tqIpChVV39
        exe/rb-sys-dock
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/exe/rb-sys-dock	2024-08-01 02:40:36.804651419 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/exe/rb-sys-dock	2024-08-01 02:40:36.808651498 +0000
                @@ -21 +21,7 @@
                -  @cargo_metadata ||= RbSys::Cargo::Metadata.new("rb-sys-dock", deps: true)
                +  return @cargo_metadata if defined?(@cargo_metadata)
                +
                +  @cargo_metadata = begin
                +    RbSys::Cargo::Metadata.inferred(deps: true)
                +  rescue
                +    nil
                +  end
                @@ -175 +181 @@
                -  return File.join(ENV["XDG_CACHE_HOME"], "rb-sys-dock") if ENV["XDG_CACHE_HOME"]
                +  return File.join(ENV["XDG_CACHE_HOME"], "rb-sys") if ENV["XDG_CACHE_HOME"]
                @@ -177 +183 @@
                -  File.join(ENV["HOME"], ".cache", "rb-sys-dock")
                +  File.join(ENV["HOME"], ".cache", "rb-sys")
                @@ -362 +368 @@
                -      -v #{working_directory}:#{working_directory} \
                +      -v $(pwd):$(pwd) \
                @@ -424 +430 @@
                -  cargo_version = cargo_metadata.rb_sys_version
                +  cargo_version = cargo_metadata&.rb_sys_version || RbSys::VERSION
        lib/rb_sys/cargo/metadata.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/cargo/metadata.rb	2024-08-01 02:40:36.804651419 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/cargo/metadata.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -11,0 +12,20 @@
                +      class << self
                +        # Infers the Cargo project's name from the Cargo.toml file.
                +        #
                +        # @return [RbSys::Cargo::Metadata]
                +        def inferred(deps: false)
                +          new(File.read("Cargo.toml").match(/^name = "(.*)"/)[1], deps: deps)
                +        rescue
                +          new(File.basename(Dir.pwd), deps: deps)
                +        end
                +
                +        # Initializes a new Cargo::Metadata instance or infers the Cargo project's name.
                +        #
                +        # @param name [String] the name of the Cargo project
                +        def new_or_inferred(name, deps: false)
                +          new(name, deps: deps).load!
                +        rescue CargoMetadataError
                +          inferred
                +        end
                +      end
                +
                @@ -94,0 +115,2 @@
                +      #
                +      # @return [String]
                @@ -98,0 +121,8 @@
                +      end
                +
                +      # Eagerly run `cargo metadata`, raising a RbSys::CargoCargoMetadataError` if it fails.
                +      #
                +      # @return [RbSys::Cargo::Metadata]
                +      def load!
                +        cargo_metadata
                +        self
        lib/rb_sys/cargo_builder.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/cargo_builder.rb	2024-08-01 02:40:36.804651419 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/cargo_builder.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -12 +12 @@
                -      :extra_cargo_args
                +      :extra_cargo_args, :config
                @@ -69 +69,5 @@
                -      cmd += ["cargo", "rustc"]
                +      cmd += if config.use_cargo_build
                +        ["cargo", "build"]
                +      else
                +        ["cargo", "rustc"]
                +      end
                @@ -77,3 +81,5 @@
                -      cmd += ["--"]
                -      cmd += [*rustc_args(dest_path)]
                -      cmd += extra_rustc_args
                +      if !config.use_cargo_build
                +        cmd += ["--"]
                +        cmd += [*rustc_args(dest_path)]
                +        cmd += extra_rustc_args
                +      end
                @@ -144,0 +151,4 @@
                +      if musl?
                +        flags += ["-C", "target-feature=-crt-static"]
                +      end
                +
                @@ -331 +341,5 @@
                -      ENV.key?("SOURCE_DATE_EPOCH") && !ENV["RB_SYS_TEST"] == "1"
                +      ENV.key?("SOURCE_DATE_EPOCH") && ENV["RB_SYS_TEST"] != "1"
                +    end
                +
                +    def musl?
                +      RbConfig::CONFIG["target_os"] == "linux-musl" || RbConfig::CONFIG["CC"]&.include?("musl-gcc")
        lib/rb_sys/extensiontask.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/extensiontask.rb	2024-08-01 02:40:36.804651419 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/extensiontask.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -60 +60 @@
                -      @cargo_metadata ||= Cargo::Metadata.new(@name)
                +      @cargo_metadata ||= Cargo::Metadata.new_or_inferred(@name)
        lib/rb_sys/mkmf.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/mkmf.rb	2024-08-01 02:40:36.804651419 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/mkmf.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -13,3 +12,0 @@
                -    # @api private
                -    GLOBAL_RUSTFLAGS = ["--cfg=rb_sys_gem"]
                -
                @@ -35 +32 @@
                -    #     r.rustflags = %w[--cfg=foo]
                +    #     r.extra_rustflags = %w[--cfg=foo]
                @@ -56 +53,3 @@
                -      global_rustflags = GLOBAL_RUSTFLAGS.dup
                +
                +      global_rustflags = []
                +      global_rustflags << "--cfg=rb_sys_gem" unless builder.use_cargo_build
                @@ -172 +171,5 @@
                -      cmd.gsub!(/\Acargo rustc/, "$(CARGO) rustc $(RB_SYS_EXTRA_CARGO_ARGS) --manifest-path $(RB_SYS_CARGO_MANIFEST_DIR)/Cargo.toml")
                +      if builder.use_cargo_build
                +        cmd.gsub!(/\Acargo rustc/, "$(CARGO) build $(RB_SYS_EXTRA_CARGO_ARGS) --manifest-path $(RB_SYS_CARGO_MANIFEST_DIR)/Cargo.toml")
                +      else
                +        cmd.gsub!(/\Acargo rustc/, "$(CARGO) rustc $(RB_SYS_EXTRA_CARGO_ARGS) --manifest-path $(RB_SYS_CARGO_MANIFEST_DIR)/Cargo.toml")
                +      end
        lib/rb_sys/mkmf/config.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/mkmf/config.rb	2024-08-01 02:40:36.808651498 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/mkmf/config.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -27,0 +28,4 @@
                +      # Instead of the default `cargo rustc` behaviour, just call `cargo build`.
                +      # Requires manually setting relevant rb-sys environment (default: false)
                +      attr_accessor :use_cargo_build
                +
                @@ -29,0 +34 @@
                +        @builder.config = self
                @@ -58 +63 @@
                -        ENV.key?("SOURCE_DATE_EPOCH") && !ENV["RB_SYS_TEST"] == "1"
                +        ENV.key?("SOURCE_DATE_EPOCH") && ENV["RB_SYS_TEST"] != "1"
        lib/rb_sys/toolchain_info.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/toolchain_info.rb	2024-08-01 02:40:36.808651498 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/toolchain_info.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -30,0 +31,7 @@
                +      # Get all supported toolchain names, as strings.
                +      #
                +      # @return [Array<String>]
                +      def supported_ruby_platforms
                +        supported.map(&:platform)
                +      end
                +
        lib/rb_sys/toolchain_info/data.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/toolchain_info/data.rb	2024-08-01 02:40:36.808651498 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/toolchain_info/data.rb	2024-08-01 02:40:36.808651498 +0000
                @@ -8 +8 @@
                -    DATA = {"arm-linux" => {"rust-target" => "arm-unknown-linux-gnueabihf", "rake-compiler-dock" => {"cc" => "arm-linux-gnueabihf-gcc"}, "docker-platform" => "linux/arm/v7", "supported" => true}, "aarch64-linux" => {"rust-target" => "aarch64-unknown-linux-gnu", "rake-compiler-dock" => {"cc" => "aarch64-linux-gnu-gcc"}, "docker-platform" => "linux/arm64/v8", "supported" => true}, "arm64-darwin" => {"rust-target" => "aarch64-apple-darwin", "rake-compiler-dock" => {"cc" => "aarch64-apple-darwin-clang"}, "docker-platform" => "linux/arm64/v8", "supported" => true}, "x64-mingw-ucrt" => {"rust-target" => "x86_64-pc-windows-gnu", "rake-compiler-dock" => {"cc" => "x86_64-windows-gnu-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}, "x64-mingw32" => {"rust-target" => "x86_64-pc-windows-gnu", "rake-compiler-dock" => {"cc" => "x86_64-windows-gnu-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}, "x86-linux" => {"rust-target" => "i686-unknown-linux-gnu", "rake-compiler-dock" => {"cc" => "i686-redhat-linux-gcc"}, "docker-platform" => "linux/i386", "supported" => false}, "x86-mingw32" => {"rust-target" => "i686-pc-windows-gnu", "rake-compiler-dock" => {"cc" => "i686-w64-mingw32-gcc"}, "docker-platform" => "linux/i386", "supported" => false}, "x86_64-darwin" => {"rust-target" => "x86_64-apple-darwin", "rake-compiler-dock" => {"cc" => "x86_64-apple-darwin-clang"}, "docker-platform" => "linux/amd64", "supported" => true}, "x86_64-linux" => {"rust-target" => "x86_64-unknown-linux-gnu", "rake-compiler-dock" => {"cc" => "x86_64-redhat-linux-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}, "x86_64-linux-musl" => {"rust-target" => "x86_64-unknown-linux-musl", "rake-compiler-dock" => {"cc" => "x86_64-unknown-linux-musl-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}}
                +    DATA = {"arm-linux" => {"rust-target" => "arm-unknown-linux-gnueabihf", "rake-compiler-dock" => {"cc" => "arm-linux-gnueabihf-gcc"}, "docker-platform" => "linux/arm/v7", "supported" => true}, "aarch64-linux" => {"rust-target" => "aarch64-unknown-linux-gnu", "rake-compiler-dock" => {"cc" => "aarch64-linux-gnu-gcc"}, "docker-platform" => "linux/arm64/v8", "supported" => true}, "aarch64-linux-musl" => {"rust-target" => "aarch64-unknown-linux-musl", "rake-compiler-dock" => {"cc" => "aarch64-linux-musl-gcc"}, "docker-platform" => "linux/arm64/v8", "supported" => true}, "arm64-darwin" => {"rust-target" => "aarch64-apple-darwin", "rake-compiler-dock" => {"cc" => "aarch64-apple-darwin-clang"}, "docker-platform" => "linux/arm64/v8", "supported" => true}, "x64-mingw-ucrt" => {"rust-target" => "x86_64-pc-windows-gnu", "rake-compiler-dock" => {"cc" => "x86_64-windows-gnu-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}, "x64-mingw32" => {"rust-target" => "x86_64-pc-windows-gnu", "rake-compiler-dock" => {"cc" => "x86_64-windows-gnu-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}, "x86-linux" => {"rust-target" => "i686-unknown-linux-gnu", "rake-compiler-dock" => {"cc" => "i686-redhat-linux-gcc"}, "docker-platform" => "linux/i386", "supported" => false}, "x86-mingw32" => {"rust-target" => "i686-pc-windows-gnu", "rake-compiler-dock" => {"cc" => "i686-w64-mingw32-gcc"}, "docker-platform" => "linux/i386", "supported" => false}, "x86_64-darwin" => {"rust-target" => "x86_64-apple-darwin", "rake-compiler-dock" => {"cc" => "x86_64-apple-darwin-clang"}, "docker-platform" => "linux/amd64", "supported" => true}, "x86_64-linux" => {"rust-target" => "x86_64-unknown-linux-gnu", "rake-compiler-dock" => {"cc" => "x86_64-redhat-linux-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}, "x86_64-linux-musl" => {"rust-target" => "x86_64-unknown-linux-musl", "rake-compiler-dock" => {"cc" => "x86_64-unknown-linux-musl-gcc"}, "docker-platform" => "linux/amd64", "supported" => true}}
        lib/rb_sys/version.rb
                --- /tmp/d20240801-1929-r07ewd/rb_sys-0.9.88/lib/rb_sys/version.rb	2024-08-01 02:40:36.808651498 +0000
                +++ /tmp/d20240801-1929-r07ewd/rb_sys-0.9.99/lib/rb_sys/version.rb	2024-08-01 02:40:36.812651576 +0000
                @@ -4 +4 @@
                -  VERSION = "0.9.88"
                +  VERSION = "0.9.99"

Copy link

github-actions bot commented Aug 1, 2024

gem compare selma 0.2.2 0.4.5

Compared versions: ["0.2.2", "0.4.5"]
  DIFFERENT date:
    0.2.2: 2024-01-11 00:00:00 UTC
    0.4.5: 2024-07-31 00:00:00 UTC
  DIFFERENT require_paths:
    0.2.2: ["/opt/hostedtoolcache/Ruby/3.2.5/x64/lib/ruby/gems/3.2.0/extensions/x86_64-linux/3.2.0/selma-0.2.2", "lib"]
    0.4.5: ["/opt/hostedtoolcache/Ruby/3.2.5/x64/lib/ruby/gems/3.2.0/extensions/x86_64-linux/3.2.0/selma-0.4.5", "lib"]
  DIFFERENT version:
    0.2.2: 0.2.2
    0.4.5: 0.4.5
  DIFFERENT files:
    0.2.2->0.4.5:
      * Added:
            lib/selma/config.rb +12/-0
            lib/selma/html/element.rb +11/-0
      * Changed:
            Cargo.lock +124/-118
            README.md +135/-29
            ext/selma/Cargo.toml +5/-2
            ext/selma/src/html/element.rs +32/-27
            ext/selma/src/html/end_tag.rs +5/-5
            ext/selma/src/html/text_chunk.rs +18/-5
            ext/selma/src/native_ref_wrap.rs +30/-33
            ext/selma/src/rewriter.rs +286/-123
            ext/selma/src/sanitizer.rs +24/-18
            lib/selma/html.rb +2/-0
            lib/selma/sanitizer.rb +6/-1
            lib/selma/sanitizer/config/default.rb +1/-1
            lib/selma/sanitizer/config/relaxed.rb +1/-0
            lib/selma/version.rb +1/-1

Copy link

github-actions bot commented Aug 1, 2024

gem compare --diff selma 0.2.2 0.4.5

Diff too large (72685 chars)

Copy link

github-actions bot commented Aug 1, 2024

gem compare zeitwerk 2.6.13 2.6.17

Compared versions: ["2.6.13", "2.6.17"]
  DIFFERENT date:
    2.6.13: 2024-02-06 00:00:00 UTC
    2.6.17: 2024-07-29 00:00:00 UTC
  DIFFERENT rubygems_version:
    2.6.13: 3.5.5
    2.6.17: 3.5.15
  DIFFERENT version:
    2.6.13: 2.6.13
    2.6.17: 2.6.17
  DIFFERENT files:
    2.6.13->2.6.17:
      * Added:
            lib/zeitwerk/cref.rb +99/-0
      * Changed:
            README.md +51/-2
            lib/zeitwerk.rb +1/-0
            lib/zeitwerk/gem_loader.rb +1/-2
            lib/zeitwerk/loader.rb +123/-93
            lib/zeitwerk/loader/callbacks.rb +13/-14
            lib/zeitwerk/loader/eager_load.rb +12/-14
            lib/zeitwerk/loader/helpers.rb +25/-64
            lib/zeitwerk/version.rb +1/-1

Copy link

github-actions bot commented Aug 1, 2024

gem compare --diff zeitwerk 2.6.13 2.6.17

Compared versions: ["2.6.13", "2.6.17"]
  DIFFERENT files:
    2.6.13->2.6.17:
      * Added:
        lib/zeitwerk/cref.rb
                --- /tmp/20240801-2090-n5j59f	2024-08-01 02:40:48.556818371 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/cref.rb	2024-08-01 02:40:48.552818321 +0000
                @@ -0,0 +1,99 @@
                +# frozen_string_literal: true
                +
                +# This private class encapsulates pairs (mod, cname).
                +#
                +# Objects represent the constant cname in the class or module object mod, and
                +# have API to manage them that encapsulates the constants API. Examples:
                +#
                +#   cref.path
                +#   cref.set(value)
                +#   cref.get
                +#
                +# The constant may or may not exist in mod.
                +class Zeitwerk::Cref
                +  include Zeitwerk::RealModName
                +
                +  # @sig Symbol
                +  attr_reader :cname
                +
                +  # The type of the first argument is Module because Class < Module, class
                +  # objects are also valid.
                +  #
                +  # @sig (Module, Symbol) -> void
                +  def initialize(mod, cname)
                +    @mod   = mod
                +    @cname = cname
                +    @path  = nil
                +  end
                +
                +  if Symbol.method_defined?(:name)
                +    # Symbol#name was introduced in Ruby 3.0. It returns always the same
                +    # frozen object, so we may save a few string allocations.
                +    #
                +    # @sig () -> String
                +    def path
                +      @path ||= Object.equal?(@mod) ? @cname.name : "#{real_mod_name(@mod)}::#{@cname.name}"
                +    end
                +  else
                +    # @sig () -> String
                +    def path
                +      @path ||= Object.equal?(@mod) ? @cname.to_s : "#{real_mod_name(@mod)}::#{@cname}"
                +    end
                +  end
                +
                +  # The autoload? predicate takes into account the ancestor chain of the
                +  # receiver, like const_defined? and other methods in the constants API do.
                +  #
                +  # For example, given
                +  #
                +  #   class A
                +  #     autoload :X, "x.rb"
                +  #   end
                +  #
                +  #   class B < A
                +  #   end
                +  #
                +  # B.autoload?(:X) returns "x.rb".
                +  #
                +  # We need a way to retrieve it ignoring ancestors.
                +  #
                +  # @sig () -> String?
                +  if method(:autoload?).arity == 1
                +    # @sig () -> String?
                +    def autoload?
                +      @mod.autoload?(@cname) if self.defined?
                +    end
                +  else
                +    # @sig () -> String?
                +    def autoload?
                +      @mod.autoload?(@cname, false)
                +    end
                +  end
                +
                +  # @sig (String) -> bool
                +  def autoload(abspath)
                +    @mod.autoload(@cname, abspath)
                +  end
                +
                +  # @sig () -> bool
                +  def defined?
                +    @mod.const_defined?(@cname, false)
                +  end
                +
                +  # @sig (Object) -> Object
                +  def set(value)
                +    @mod.const_set(@cname, value)
                +  end
                +
                +  # @raise [NameError]
                +  # @sig () -> Object
                +  def get
                +    @mod.const_get(@cname, false)
                +  end
                +
                +  # @raise [NameError]
                +  # @sig () -> void
                +  def remove
                +    @mod.__send__(:remove_const, @cname)
                +  end
                +end
      * Changed:
        README.md
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/README.md	2024-08-01 02:40:48.548818271 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/README.md	2024-08-01 02:40:48.552818321 +0000
                @@ -62,0 +63 @@
                +    - [`Zeitwerk::Loader#all_expected_cpaths`](#zeitwerkloaderall_expected_cpaths)
                @@ -262 +263 @@
                -To trigger this behavior, the directory must contain non-ignored Ruby files with the `.rb` extension, either directly or recursively. Otherwise, the directory is ignored. This condition is reevaluated during reloads.
                +To trigger this behavior, the directory must contain non-ignored Ruby files with the ".rb" extension, either directly or recursively. Otherwise, the directory is ignored. This condition is reevaluated during reloads.
                @@ -1067 +1068 @@
                -There is an edge case related to nested root directories. Conceptually, root directories are independent source trees. If you ignore a parent of a nested root directory, the nested root directory is not affected. You need to ignore it explictly if you want it ignored too.
                +There is an edge case related to nested root directories. Conceptually, root directories are independent source trees. If you ignore a parent of a nested root directory, the nested root directory is not affected. You need to ignore it explicitly if you want it ignored too.
                @@ -1331,0 +1333,48 @@
                +
                +`Zeitwerk::Loader#cpath_expected_at` is designed to be used with individual paths. If you want to know all the expected constant paths in the project, please use `Zeitwerk::Loader#all_expected_cpaths`, documented next.
                +
                +<a id="markdown-zeitwerkloaderall_expected_cpaths" name="zeitwerkloaderall_expected_cpaths"></a>
                +#### `Zeitwerk::Loader#all_expected_cpaths`
                +
                +The method `Zeitwerk::Loader#all_expected_cpaths` returns a hash that maps the absolute paths of the files and directories managed by the receiver to their expected constant paths.
                +
                +Ignored files, hidden files, and files whose extension is not ".rb" are not included in the result. Same for directories, hidden or ignored directories are not included in the result. Additionally, directories that contain no files with extension ".rb" (recursively) are also excluded, since those are not considered to represent Ruby namespaces.
                +
                +For example, if `lib` is the root directory of a gem with the following contents:
                +
                +```
                +lib/.DS_Store
                +lib/my_gem.rb
                +lib/my_gem/version.rb
                +lib/my_gem/ignored.rb
                +lib/my_gem/drivers/unix.rb
                +lib/my_gem/drivers/windows.rb
                +lib/my_gem/collapsed/foo.rb
                +lib/tasks/my_gem.rake
                +```
                +
                +`Zeitwerk::Loader#all_expected_cpaths` would return (maybe in a different order):
                +
                +```ruby
                +{
                +  "/.../lib"                           => "Object",
                +  "/.../lib/my_gem.rb"                 => "MyGem",
                +  "/.../lib/my_gem"                    => "MyGem",
                +  "/.../lib/my_gem/version.rb"         => "MyGem::VERSION",
                +  "/.../lib/my_gem/drivers"            => "MyGem::Drivers",
                +  "/.../lib/my_gem/drivers/unix.rb"    => "MyGem::Drivers::Unix",
                +  "/.../lib/my_gem/drivers/windows.rb" => "MyGem::Drivers::Windows",
                +  "/.../lib/my_gem/collapsed"          => "MyGem"
                +  "/.../lib/my_gem/collapsed/foo.rb"   => "MyGem::Foo"
                +}
                +```
                +
                +In the previous example we assume `lib/my_gem/ignored.rb` is ignored, and therefore it is not present in the returned hash. Also, `lib/my_gem/collapsed` is a collapsed directory, so the expected namespace at that level is still `MyGem` (this is an edge case).
                +
                +The file `lib/.DS_Store` is hidden, hence excluded. The directory `lib/tasks` is also not present because it contains no files with extension ".rb".
                +
                +Directory paths do not have trailing slashes.
                +
                +The order of the hash entries is undefined.
                +
                +This method does not parse or execute file contents and does not guarantee files define the corresponding constant paths. It just says which are the _expected_ ones.
        lib/zeitwerk.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk.rb	2024-08-01 02:40:48.548818271 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk.rb	2024-08-01 02:40:48.552818321 +0000
                @@ -5,0 +6 @@
                +  require_relative "zeitwerk/cref"
        lib/zeitwerk/gem_loader.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk/gem_loader.rb	2024-08-01 02:40:48.548818271 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/gem_loader.rb	2024-08-01 02:40:48.552818321 +0000
                @@ -45 +45 @@
                -      ls(@root_dir) do |basename, abspath|
                +      ls(@root_dir) do |basename, abspath, ftype|
                @@ -51 +50,0 @@
                -        ftype = dir?(abspath) ? "directory" : "file"
        lib/zeitwerk/loader.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk/loader.rb	2024-08-01 02:40:48.552818321 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/loader.rb	2024-08-01 02:40:48.552818321 +0000
                @@ -25,2 +25 @@
                -    # executed--- to their corresponding parent class or module and constant
                -    # name.
                +    # executed--- to their corresponding Zeitwerk::Cref object.
                @@ -28,2 +27,2 @@
                -    #   "/Users/fxn/blog/app/models/user.rb"          => [Object, :User],
                -    #   "/Users/fxn/blog/app/models/hotel/pricing.rb" => [Hotel, :Pricing]
                +    #   "/Users/fxn/blog/app/models/user.rb"          => #<Zeitwerk::Cref:... @mod=Object, @cname=:User, ...>,
                +    #   "/Users/fxn/blog/app/models/hotel/pricing.rb" => #<Zeitwerk::Cref:... @mod=Hotel, @cname=:Pricing, ...>,
                @@ -32 +31 @@
                -    # @sig Hash[String, [Module, Symbol]]
                +    # @sig Hash[String, Zeitwerk::Cref]
                @@ -48 +47,4 @@
                -    #   "Admin::Role" => [".../admin/role.rb", [Admin, :Role]]
                +    #   "Admin::Role" => [
                +    #     ".../admin/role.rb",
                +    #     #<Zeitwerk::Cref:... @mod=Admin, @cname=:Role, ...>
                +    #   ]
                @@ -52,2 +54 @@
                -    # pair [Module, Symbol] is used to remove_const the constant from the class
                -    # or module object.
                +    # cref is used to remove the constant from the parent class or module.
                @@ -58 +59 @@
                -    # @sig Hash[String, [String, [Module, Symbol]]]
                +    # @sig Hash[String, [String, Zeitwerk::Cref]]
                @@ -157,3 +158,3 @@
                -        autoloads.each do |abspath, (parent, cname)|
                -          if parent.autoload?(cname)
                -            unload_autoload(parent, cname)
                +        autoloads.each do |abspath, cref|
                +          if cref.autoload?
                +            unload_autoload(cref)
                @@ -164 +165 @@
                -            unload_cref(parent, cname)
                +            unload_cref(cref)
                @@ -169 +170 @@
                -        to_unload.each do |cpath, (abspath, (parent, cname))|
                +        to_unload.each do |cpath, (abspath, cref)|
                @@ -172 +173 @@
                -              value = cget(parent, cname)
                +              value = cref.get
                @@ -182 +183 @@
                -          unload_cref(parent, cname)
                +          unload_cref(cref)
                @@ -233,3 +234,6 @@
                -  # @sig (String | Pathname) -> String?
                -  def cpath_expected_at(path)
                -    abspath = File.expand_path(path)
                +    # Returns a hash that maps the absolute paths of the managed files and
                +    # directories to their respective expected constant paths.
                +    #
                +    # @sig () -> Hash[String, String]
                +    def all_expected_cpaths
                +      result = {}
                @@ -237 +241,2 @@
                -    raise Zeitwerk::Error.new("#{abspath} does not exist") unless File.exist?(abspath)
                +      actual_roots.each do |root_dir, root_namespace|
                +        queue = [[root_dir, real_mod_name(root_namespace)]]
                @@ -239,2 +244,2 @@
                -    return unless dir?(abspath) || ruby?(abspath)
                -    return if ignored_path?(abspath)
                +        while (dir, cpath = queue.shift)
                +          result[dir] = cpath
                @@ -242 +247 @@
                -    paths = []
                +          prefix = cpath == "Object" ? "" : cpath + "::"
                @@ -244,3 +249,14 @@
                -    if ruby?(abspath)
                -      basename = File.basename(abspath, ".rb")
                -      return if hidden?(basename)
                +          ls(dir) do |basename, abspath, ftype|
                +            if ftype == :file
                +              basename.delete_suffix!(".rb")
                +              result[abspath] = prefix + inflector.camelize(basename, abspath)
                +            else
                +              if collapse?(abspath)
                +                queue << [abspath, cpath]
                +              else
                +                queue << [abspath, prefix + inflector.camelize(basename, abspath)]
                +              end
                +            end
                +          end
                +        end
                +      end
                @@ -248,4 +264 @@
                -      paths << [basename, abspath]
                -      walk_up_from = File.dirname(abspath)
                -    else
                -      walk_up_from = abspath
                +      result
                @@ -254 +267,3 @@
                -    root_namespace = nil
                +    # @sig (String | Pathname) -> String?
                +    def cpath_expected_at(path)
                +      abspath = File.expand_path(path)
                @@ -256,3 +271 @@
                -    walk_up(walk_up_from) do |dir|
                -      break if root_namespace = roots[dir]
                -      return if ignored_path?(dir)
                +      raise Zeitwerk::Error.new("#{abspath} does not exist") unless File.exist?(abspath)
                @@ -260,2 +273,2 @@
                -      basename = File.basename(dir)
                -      return if hidden?(basename)
                +      return unless dir?(abspath) || ruby?(abspath)
                +      return if ignored_path?(abspath)
                @@ -263,2 +276 @@
                -      paths << [basename, abspath] unless collapse?(dir)
                -    end
                +      paths = []
                @@ -266 +278,3 @@
                -    return unless root_namespace
                +      if ruby?(abspath)
                +        basename = File.basename(abspath, ".rb")
                +        return if hidden?(basename)
                @@ -268,4 +282,19 @@
                -    if paths.empty?
                -      real_mod_name(root_namespace)
                -    else
                -      cnames = paths.reverse_each.map { |b, a| cname_for(b, a) }
                +        paths << [basename, abspath]
                +        walk_up_from = File.dirname(abspath)
                +      else
                +        walk_up_from = abspath
                +      end
                +
                +      root_namespace = nil
                +
                +      walk_up(walk_up_from) do |dir|
                +        break if root_namespace = roots[dir]
                +        return if ignored_path?(dir)
                +
                +        basename = File.basename(dir)
                +        return if hidden?(basename)
                +
                +        paths << [basename, abspath] unless collapse?(dir)
                +      end
                +
                +      return unless root_namespace
                @@ -273,2 +302,2 @@
                -      if root_namespace == Object
                -        cnames.join("::")
                +      if paths.empty?
                +        real_mod_name(root_namespace)
                @@ -276 +305,7 @@
                -        "#{real_mod_name(root_namespace)}::#{cnames.join("::")}"
                +        cnames = paths.reverse_each.map { |b, a| cname_for(b, a) }
                +
                +        if root_namespace == Object
                +          cnames.join("::")
                +        else
                +          "#{real_mod_name(root_namespace)}::#{cnames.join("::")}"
                +        end
                @@ -279 +313,0 @@
                -  end
                @@ -411,2 +445,2 @@
                -      ls(dir) do |basename, abspath|
                -        if ruby?(basename)
                +      ls(dir) do |basename, abspath, ftype|
                +        if ftype == :file
                @@ -414 +448,2 @@
                -          autoload_file(parent, cname_for(basename, abspath), abspath)
                +          cref = Cref.new(parent, cname_for(basename, abspath))
                +          autoload_file(cref, abspath)
                @@ -419 +454,2 @@
                -            autoload_subdir(parent, cname_for(basename, abspath), abspath)
                +            cref = Cref.new(parent, cname_for(basename, abspath))
                +            autoload_subdir(cref, abspath)
                @@ -426,3 +462,2 @@
                -    private def autoload_subdir(parent, cname, subdir)
                -      if autoload_path = autoload_path_set_by_me_for?(parent, cname)
                -        cpath = cpath(parent, cname)
                +    private def autoload_subdir(cref, subdir)
                +      if autoload_path = autoload_path_set_by_me_for?(cref)
                @@ -437 +472 @@
                -          register_explicit_namespace(cpath)
                +          register_explicit_namespace(cref.path)
                @@ -442,2 +477,2 @@
                -        namespace_dirs[cpath] << subdir
                -      elsif !cdef?(parent, cname)
                +        namespace_dirs[cref.path] << subdir
                +      elsif !cref.defined?
                @@ -445,2 +480,2 @@
                -        namespace_dirs[cpath(parent, cname)] << subdir
                -        define_autoload(parent, cname, subdir)
                +        namespace_dirs[cref.path] << subdir
                +        define_autoload(cref, subdir)
                @@ -450,2 +485,2 @@
                -        log("the namespace #{cpath(parent, cname)} already exists, descending into #{subdir}") if logger
                -        define_autoloads_for_dir(subdir, cget(parent, cname))
                +        log("the namespace #{cref.path} already exists, descending into #{subdir}") if logger
                +        define_autoloads_for_dir(subdir, cref.get)
                @@ -456,2 +491,2 @@
                -    private def autoload_file(parent, cname, file)
                -      if autoload_path = strict_autoload_path(parent, cname) || Registry.inception?(cpath(parent, cname))
                +    private def autoload_file(cref, file)
                +      if autoload_path = cref.autoload? || Registry.inception?(cref.path)
                @@ -463,6 +498 @@
                -          promote_namespace_from_implicit_to_explicit(
                -            dir:    autoload_path,
                -            file:   file,
                -            parent: parent,
                -            cname:  cname
                -          )
                +          promote_namespace_from_implicit_to_explicit(dir: autoload_path, file: file, cref: cref)
                @@ -470 +500 @@
                -      elsif cdef?(parent, cname)
                +      elsif cref.defined?
                @@ -472 +502 @@
                -        log("file #{file} is ignored because #{cpath(parent, cname)} is already defined") if logger
                +        log("file #{file} is ignored because #{cref.path} is already defined") if logger
                @@ -474 +504 @@
                -        define_autoload(parent, cname, file)
                +        define_autoload(cref, file)
                @@ -481,2 +511,2 @@
                -    # @sig (dir: String, file: String, parent: Module, cname: Symbol) -> void
                -    private def promote_namespace_from_implicit_to_explicit(dir:, file:, parent:, cname:)
                +    # @sig (dir: String, file: String, cref: Zeitwerk::Cref) -> void
                +    private def promote_namespace_from_implicit_to_explicit(dir:, file:, cref:)
                @@ -486 +516 @@
                -      log("earlier autoload for #{cpath(parent, cname)} discarded, it is actually an explicit namespace defined in #{file}") if logger
                +      log("earlier autoload for #{cref.path} discarded, it is actually an explicit namespace defined in #{file}") if logger
                @@ -488,2 +518,2 @@
                -      define_autoload(parent, cname, file)
                -      register_explicit_namespace(cpath(parent, cname))
                +      define_autoload(cref, file)
                +      register_explicit_namespace(cref.path)
                @@ -493,2 +523,2 @@
                -    private def define_autoload(parent, cname, abspath)
                -      parent.autoload(cname, abspath)
                +    private def define_autoload(cref, abspath)
                +      cref.autoload(abspath)
                @@ -498 +528 @@
                -          log("autoload set for #{cpath(parent, cname)}, to be loaded from #{abspath}")
                +          log("autoload set for #{cref.path}, to be loaded from #{abspath}")
                @@ -500 +530 @@
                -          log("autoload set for #{cpath(parent, cname)}, to be autovivified from #{abspath}")
                +          log("autoload set for #{cref.path}, to be autovivified from #{abspath}")
                @@ -504 +534 @@
                -      autoloads[abspath] = [parent, cname]
                +      autoloads[abspath] = cref
                @@ -508,2 +538,2 @@
                -      unless parent.autoload?(cname)
                -        Registry.register_inception(cpath(parent, cname), abspath, self)
                +      unless cref.autoload?
                +        Registry.register_inception(cref.path, abspath, self)
                @@ -514,2 +544,2 @@
                -    private def autoload_path_set_by_me_for?(parent, cname)
                -      if autoload_path = strict_autoload_path(parent, cname)
                +    private def autoload_path_set_by_me_for?(cref)
                +      if autoload_path = cref.autoload?
                @@ -518 +548 @@
                -        Registry.inception?(cpath(parent, cname))
                +        Registry.inception?(cref.path)
                @@ -559,3 +589,3 @@
                -    private def unload_autoload(parent, cname)
                -      crem(parent, cname)
                -      log("autoload for #{cpath(parent, cname)} removed") if logger
                +    private def unload_autoload(cref)
                +      cref.remove
                +      log("autoload for #{cref.path} removed") if logger
                @@ -565 +595 @@
                -    private def unload_cref(parent, cname)
                +    private def unload_cref(cref)
                @@ -568 +598 @@
                -      crem(parent, cname)
                +      cref.remove
                @@ -573 +603 @@
                -      log("#{cpath(parent, cname)} unloaded") if logger
                +      log("#{cref.path} unloaded") if logger
        lib/zeitwerk/loader/callbacks.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk/loader/callbacks.rb	2024-08-01 02:40:48.552818321 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/loader/callbacks.rb	2024-08-01 02:40:48.552818321 +0000
                @@ -11,2 +11 @@
                -    cref  = autoloads.delete(file)
                -    cpath = cpath(*cref)
                +    cref = autoloads.delete(file)
                @@ -16,4 +15,4 @@
                -    if cdef?(*cref)
                -      log("constant #{cpath} loaded from file #{file}") if logger
                -      to_unload[cpath] = [file, cref] if reloading_enabled?
                -      run_on_load_callbacks(cpath, cget(*cref), file) unless on_load_callbacks.empty?
                +    if cref.defined?
                +      log("constant #{cref.path} loaded from file #{file}") if logger
                +      to_unload[cref.path] = [file, cref] if reloading_enabled?
                +      run_on_load_callbacks(cref.path, cref.get, file) unless on_load_callbacks.empty?
                @@ -21 +20 @@
                -      msg = "expected file #{file} to define constant #{cpath}, but didn't"
                +      msg = "expected file #{file} to define constant #{cref.path}, but didn't"
                @@ -26 +25 @@
                -      crem(*cref)
                +      cref.remove
                @@ -31 +30 @@
                -      to_unload[cpath] = [file, cref] if reloading_enabled?
                +      to_unload[cref.path] = [file, cref] if reloading_enabled?
                @@ -33 +32 @@
                -      raise Zeitwerk::NameError.new(msg, cref.last)
                +      raise Zeitwerk::NameError.new(msg, cref.cname)
                @@ -56,2 +55,2 @@
                -        autovivified_module = cref[0].const_set(cref[1], Module.new)
                -        cpath = autovivified_module.name
                +        implicit_namespace = cref.set(Module.new)
                +        cpath = implicit_namespace.name
                @@ -68 +67 @@
                -        on_namespace_loaded(autovivified_module)
                +        on_namespace_loaded(implicit_namespace)
                @@ -70 +69 @@
                -        run_on_load_callbacks(cpath, autovivified_module, dir) unless on_load_callbacks.empty?
                +        run_on_load_callbacks(cpath, implicit_namespace, dir) unless on_load_callbacks.empty?
        lib/zeitwerk/loader/eager_load.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk/loader/eager_load.rb	2024-08-01 02:40:48.552818321 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/loader/eager_load.rb	2024-08-01 02:40:48.556818371 +0000
                @@ -64,2 +64,2 @@
                -      return unless cdef?(namespace, cname)
                -      namespace = cget(namespace, cname)
                +      return unless namespace.const_defined?(cname, false)
                +      namespace = namespace.const_get(cname, false)
                @@ -148 +148 @@
                -      namespace = cget(namespace, cname)
                +      namespace = namespace.const_get(cname, false)
                @@ -153 +153 @@
                -    cget(namespace, base_cname)
                +    namespace.const_get(base_cname, false)
                @@ -167,4 +167,2 @@
                -    while to_eager_load = queue.shift
                -      dir, namespace = to_eager_load
                -
                -      ls(dir) do |basename, abspath|
                +    while (current_dir, namespace = queue.shift)
                +      ls(current_dir) do |basename, abspath, ftype|
                @@ -173 +171 @@
                -        if ruby?(abspath)
                +        if ftype == :file
                @@ -175 +173 @@
                -            cget(*cref)
                +            cref.get
                @@ -182 +180 @@
                -            queue << [abspath, cget(namespace, cname)]
                +            queue << [abspath, namespace.const_get(cname, false)]
                @@ -212,3 +210,3 @@
                -      while dir = dirs.shift
                -        ls(dir) do |basename, abspath|
                -          next unless dir?(abspath)
                +      while (dir = dirs.shift)
                +        ls(dir) do |basename, abspath, ftype|
                +          next unless ftype == :directory
        lib/zeitwerk/loader/helpers.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk/loader/helpers.rb	2024-08-01 02:40:48.552818321 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/loader/helpers.rb	2024-08-01 02:40:48.556818371 +0000
                @@ -33 +33,7 @@
                -        next if !has_at_least_one_ruby_file?(abspath)
                +
                +        if !has_at_least_one_ruby_file?(abspath)
                +          log("directory #{abspath} is ignored because it has no Ruby files") if logger
                +          next
                +        end
                +
                +        ftype = :directory
                @@ -35,0 +42 @@
                +        ftype = :file
                @@ -40 +47 @@
                -      yield basename, abspath.freeze
                +      yield basename, abspath.freeze, ftype
                @@ -43,0 +51,4 @@
                +  # Looks for a Ruby file using breadth-first search. This type of search is
                +  # important to list as less directories as possible and return fast in the
                +  # common case in which there are Ruby files.
                +  #
                @@ -48,2 +59,9 @@
                -    while dir = to_visit.shift
                -      ls(dir) do |_basename, abspath|
                +    while (dir = to_visit.shift)
                +      children = Dir.children(dir)
                +
                +      children.each do |basename|
                +        next if hidden?(basename)
                +
                +        abspath = File.join(dir, basename)
                +        next if ignored_path?(abspath)
                +
                @@ -51 +69 @@
                -          to_visit << abspath
                +          to_visit << abspath unless roots.key?(abspath)
                @@ -53 +71 @@
                -          return true
                +          return true if ruby?(abspath)
                @@ -85,58 +103 @@
                -  # --- Constants ---------------------------------------------------------------------------------
                -
                -  # The autoload? predicate takes into account the ancestor chain of the
                -  # receiver, like const_defined? and other methods in the constants API do.
                -  #
                -  # For example, given
                -  #
                -  #   class A
                -  #     autoload :X, "x.rb"
                -  #   end
                -  #
                -  #   class B < A
                -  #   end
                -  #
                -  # B.autoload?(:X) returns "x.rb".
                -  #
                -  # We need a way to strictly check in parent ignoring ancestors.
                -  #
                -  # @sig (Module, Symbol) -> String?
                -  if method(:autoload?).arity == 1
                -    private def strict_autoload_path(parent, cname)
                -      parent.autoload?(cname) if cdef?(parent, cname)
                -    end
                -  else
                -    private def strict_autoload_path(parent, cname)
                -      parent.autoload?(cname, false)
                -    end
                -  end
                -
                -  # @sig (Module, Symbol) -> String
                -  if Symbol.method_defined?(:name)
                -    # Symbol#name was introduced in Ruby 3.0. It returns always the same
                -    # frozen object, so we may save a few string allocations.
                -    private def cpath(parent, cname)
                -      Object == parent ? cname.name : "#{real_mod_name(parent)}::#{cname.name}"
                -    end
                -  else
                -    private def cpath(parent, cname)
                -      Object == parent ? cname.to_s : "#{real_mod_name(parent)}::#{cname}"
                -    end
                -  end
                -
                -  # @sig (Module, Symbol) -> bool
                -  private def cdef?(parent, cname)
                -    parent.const_defined?(cname, false)
                -  end
                -
                -  # @raise [NameError]
                -  # @sig (Module, Symbol) -> Object
                -  private def cget(parent, cname)
                -    parent.const_get(cname, false)
                -  end
                -
                -  # @raise [NameError]
                -  # @sig (Module, Symbol) -> Object
                -  private def crem(parent, cname)
                -    parent.__send__(:remove_const, cname)
                -  end
                +  # --- Inflection --------------------------------------------------------------------------------
        lib/zeitwerk/version.rb
                --- /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.13/lib/zeitwerk/version.rb	2024-08-01 02:40:48.552818321 +0000
                +++ /tmp/d20240801-2090-cwobx9/zeitwerk-2.6.17/lib/zeitwerk/version.rb	2024-08-01 02:40:48.556818371 +0000
                @@ -4 +4 @@
                -  VERSION = "2.6.13"
                +  VERSION = "2.6.17"

@dependabot dependabot bot force-pushed the dependabot/bundler/html-pipeline-3.2.1 branch 3 times, most recently from 4a5d4b0 to 41c68e5 Compare August 10, 2024 17:30
Bumps [html-pipeline](https://github.com/gjtorikian/html-pipeline) from 3.0.3 to 3.2.1.
- [Release notes](https://github.com/gjtorikian/html-pipeline/releases)
- [Changelog](https://github.com/gjtorikian/html-pipeline/blob/main/CHANGELOG.md)
- [Commits](gjtorikian/html-pipeline@v3.0.3...v3.2.1)

---
updated-dependencies:
- dependency-name: html-pipeline
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <[email protected]>
@dependabot dependabot bot force-pushed the dependabot/bundler/html-pipeline-3.2.1 branch from 41c68e5 to a8632c0 Compare August 10, 2024 17:32
Copy link
Contributor Author

dependabot bot commented on behalf of github Dec 16, 2024

Superseded by #700.

@dependabot dependabot bot closed this Dec 16, 2024
@dependabot dependabot bot deleted the dependabot/bundler/html-pipeline-3.2.1 branch December 16, 2024 03:47
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dependencies ruby Pull requests that update Ruby code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

0 participants