asciidoctor-fb2 0.6.0 â 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +2 -1
- data/.github/workflows/release.yml +14 -1
- data/CHANGELOG.adoc +7 -0
- data/README.adoc +3 -2
- data/asciidoctor-fb2.gemspec +4 -4
- data/lib/asciidoctor_fb2/version.rb +1 -1
- data/lib/asciidoctor_fb2.rb +31 -9
- metadata +10 -10
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: c86e38af133de5a0b984e4ba98639333a483284a205f7fd118334248e48adfd5
         | 
| 4 | 
            +
              data.tar.gz: 6192121701d79223d0c44cb032c87b8be375b0177ce540394a1ef81ddc4a87e5
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 10f7f74ccaf1289f9a6cccfcf6c10938949bd959b22af0fd53a0a60b52a80f010dc0bb9b4bbbb6b3256a1a2f320f78f273e10d0a5339e47f6ddf397e2b726a88
         | 
| 7 | 
            +
              data.tar.gz: 500756c54b05993d00fa197079a59f19a11824121bfcfae61a1e1fea64b9ba2b7603717a53c6e4bfafefe44300779d264d7a73046a0909414991e369e26899f6
         | 
    
        data/.github/workflows/ci.yml
    CHANGED
    
    | @@ -16,7 +16,8 @@ jobs: | |
| 16 16 | 
             
              test:
         | 
| 17 17 | 
             
                strategy:
         | 
| 18 18 | 
             
                  matrix:
         | 
| 19 | 
            -
                     | 
| 19 | 
            +
                    # Test oldest and newest supported versions
         | 
| 20 | 
            +
                    ruby: ['jruby-9.2', 'jruby-9.4', '2.5', '3.1']
         | 
| 20 21 | 
             
                    os: [ubuntu-latest, macos-latest, windows-latest]
         | 
| 21 22 | 
             
                runs-on: ${{ matrix.os }}
         | 
| 22 23 | 
             
                steps:
         | 
| @@ -16,4 +16,17 @@ jobs: | |
| 16 16 | 
             
                  uses: dawidd6/action-publish-gem@v1
         | 
| 17 17 | 
             
                  with:
         | 
| 18 18 | 
             
                    api_key: ${{ secrets.RUBYGEMS_API_KEY }}
         | 
| 19 | 
            -
             | 
| 19 | 
            +
                - name: Set release version
         | 
| 20 | 
            +
                  run: echo "RELEASE_VERSION=${GITHUB_REF#refs/*/}" >> $GITHUB_ENV
         | 
| 21 | 
            +
                - name: Announcement
         | 
| 22 | 
            +
                  uses: zulip/github-actions-zulip/send-message@v1
         | 
| 23 | 
            +
                  with:
         | 
| 24 | 
            +
                    email: ${{ secrets.ZULIP_USERNAME }}
         | 
| 25 | 
            +
                    api-key: ${{ secrets.ZULIP_API_KEY }}
         | 
| 26 | 
            +
                    organization-url: 'https://asciidoctor.zulipchat.com'
         | 
| 27 | 
            +
                    to: '279652'
         | 
| 28 | 
            +
                    type: 'stream'
         | 
| 29 | 
            +
                    topic: 'releases'
         | 
| 30 | 
            +
                    content: |
         | 
| 31 | 
            +
                      Asciidoctor-FB2 ${{ env.RELEASE_VERSION }} is out!
         | 
| 32 | 
            +
                      https://github.com/asciidoctor/asciidoctor-fb2/releases/tag/${{ env.RELEASE_VERSION }}
         | 
    
        data/CHANGELOG.adoc
    CHANGED
    
    | @@ -7,6 +7,13 @@ | |
| 7 7 | 
             
            This document provides a high-level view of the changes to the {project-name} by release.
         | 
| 8 8 | 
             
            For a detailed view of what has changed, refer to the {uri-project}/commits/master[commit history] on GitHub.
         | 
| 9 9 |  | 
| 10 | 
            +
            == 0.7.0 (2022-12-18) - @slonopotamus
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            * fix handling of image paths with path separators
         | 
| 13 | 
            +
            * add support for image alignment. https://github.com/asciidoctor/asciidoctor-fb2/issues/16[#16]
         | 
| 14 | 
            +
            * add support for floating images
         | 
| 15 | 
            +
            * add naive admonition icons support. https://github.com/asciidoctor/asciidoctor-fb2/issues/18[#18]
         | 
| 16 | 
            +
             | 
| 10 17 | 
             
            == 0.6.0 (2022-10-30) - @slonopotamus
         | 
| 11 18 |  | 
| 12 19 | 
             
            * bump fb2rb to 0.7.0
         | 
    
        data/README.adoc
    CHANGED
    
    | @@ -3,13 +3,14 @@ Marat Radchenko <marat@slonopotamus.org> | |
| 3 3 | 
             
            :project-name: Asciidoctor FB2
         | 
| 4 4 | 
             
            :project-handle: asciidoctor-fb2
         | 
| 5 5 | 
             
            :slug: asciidoctor/{project-handle}
         | 
| 6 | 
            +
            :source-highlighter: rouge
         | 
| 6 7 | 
             
            :uri-project: https://github.com/{slug}
         | 
| 7 8 | 
             
            :uri-ci: {uri-project}/actions?query=branch%3Amaster
         | 
| 8 9 | 
             
            :uri-gem: https://rubygems.org/gems/{project-handle}
         | 
| 9 10 |  | 
| 10 11 | 
             
            image:https://img.shields.io/badge/zulip-join_chat-brightgreen.svg[project chat,link=https://asciidoctor.zulipchat.com/]
         | 
| 11 12 | 
             
            image:https://img.shields.io/gem/v/{project-handle}.svg[Latest Release,link={uri-gem}]
         | 
| 12 | 
            -
            image:{uri-project}/workflows/CI/badge.svg?branch= | 
| 13 | 
            +
            image:{uri-project}/workflows/CI/badge.svg?branch=main[Build Status,link={uri-ci}]
         | 
| 13 14 |  | 
| 14 15 | 
             
            {project-name} is an Asciidoctor extension for converting AsciiDoc documents directly to the FB2 e-book format.
         | 
| 15 16 |  | 
| @@ -39,7 +40,7 @@ This command should be available on your PATH if you installed the `{project-han | |
| 39 40 | 
             
            Otherwise, you can find the command in the [path]_bin_ folder of the project.
         | 
| 40 41 | 
             
            We also recommend specifying an output directory using the `-D` option flag.
         | 
| 41 42 |  | 
| 42 | 
            -
            [source,shell | 
| 43 | 
            +
            [source,shell]
         | 
| 43 44 | 
             
            ----
         | 
| 44 45 | 
             
            $ asciidoctor-fb2 -D output path/to/book.adoc
         | 
| 45 46 | 
             
            ----
         | 
    
        data/asciidoctor-fb2.gemspec
    CHANGED
    
    | @@ -10,7 +10,7 @@ Gem::Specification.new do |s| | |
| 10 10 | 
             
              s.summary = 'Converts AsciiDoc documents to FB2 e-book formats'
         | 
| 11 11 | 
             
              s.homepage = 'https://github.com/asciidoctor/asciidoctor-fb2'
         | 
| 12 12 | 
             
              s.license = 'MIT'
         | 
| 13 | 
            -
              s.required_ruby_version = '>= 2. | 
| 13 | 
            +
              s.required_ruby_version = '>= 2.5.0'
         | 
| 14 14 |  | 
| 15 15 | 
             
              s.files = `git ls-files`.split("\n").reject { |f| f.match(%r{^spec/}) }
         | 
| 16 16 | 
             
              s.executables = `git ls-files -- bin/*`.split("\n").map do |f|
         | 
| @@ -25,7 +25,7 @@ Gem::Specification.new do |s| | |
| 25 25 | 
             
              s.add_development_dependency 'asciidoctor-diagram', '~> 2.0'
         | 
| 26 26 | 
             
              s.add_development_dependency 'rake', '~> 13.0'
         | 
| 27 27 | 
             
              s.add_development_dependency 'rspec', '~> 3.12.0'
         | 
| 28 | 
            -
              s.add_development_dependency 'rubocop', '~> 1. | 
| 29 | 
            -
              s.add_development_dependency 'rubocop-rake', '~> 0. | 
| 30 | 
            -
              s.add_development_dependency 'rubocop-rspec', '~> 2. | 
| 28 | 
            +
              s.add_development_dependency 'rubocop', '~> 1.28.2'
         | 
| 29 | 
            +
              s.add_development_dependency 'rubocop-rake', '~> 0.6.0'
         | 
| 30 | 
            +
              s.add_development_dependency 'rubocop-rspec', '~> 2.10.0'
         | 
| 31 31 | 
             
            end
         | 
    
        data/lib/asciidoctor_fb2.rb
    CHANGED
    
    | @@ -282,7 +282,7 @@ module Asciidoctor | |
| 282 282 | 
             
                  # @param node [Asciidoctor::Inline]
         | 
| 283 283 | 
             
                  def convert_inline_image(node)
         | 
| 284 284 | 
             
                    image_attrs = register_binary(node, node.image_uri(node.target), 'image')
         | 
| 285 | 
            -
                    %(<image #{image_attrs * ' '}/>)
         | 
| 285 | 
            +
                    %(<image #{image_attrs.sort! * ' '}/>)
         | 
| 286 286 | 
             
                  end
         | 
| 287 287 |  | 
| 288 288 | 
             
                  # @param node [Asciidoctor::Inline]
         | 
| @@ -301,11 +301,18 @@ module Asciidoctor | |
| 301 301 | 
             
                  end
         | 
| 302 302 |  | 
| 303 303 | 
             
                  # @param node [Asciidoctor::Block]
         | 
| 304 | 
            -
                  def convert_image(node)
         | 
| 304 | 
            +
                  def convert_image(node) # rubocop:disable Metrics/AbcSize
         | 
| 305 305 | 
             
                    image_attrs = register_binary(node, node.image_uri(node.attr('target')), 'image')
         | 
| 306 306 | 
             
                    image_attrs << %(title="#{node.captioned_title}") if node.title?
         | 
| 307 307 | 
             
                    image_attrs << %(id="#{node.id}") if node.id
         | 
| 308 | 
            -
             | 
| 308 | 
            +
             | 
| 309 | 
            +
                    p_style = []
         | 
| 310 | 
            +
                    p_style << %(float: #{node.attr 'float'}) if node.attr? 'float'
         | 
| 311 | 
            +
                    p_style << %(text-align: #{node.attr 'align'}) if node.attr? 'align'
         | 
| 312 | 
            +
             | 
| 313 | 
            +
                    p_attrs = []
         | 
| 314 | 
            +
                    p_attrs << %(style="#{p_style.sort! * '; '}") unless p_style.empty?
         | 
| 315 | 
            +
                    %(<p #{p_attrs.sort! * ' '}><image #{image_attrs.sort! * ' '}/></p>)
         | 
| 309 316 | 
             
                  end
         | 
| 310 317 |  | 
| 311 318 | 
             
                  # @param node [Asciidoctor::Block]
         | 
| @@ -339,8 +346,8 @@ module Asciidoctor | |
| 339 346 |  | 
| 340 347 | 
             
                      if File.readable?(fs_path)
         | 
| 341 348 | 
             
                        # Calibre fails to load images if they contain path separators
         | 
| 342 | 
            -
                        target. | 
| 343 | 
            -
                        target. | 
| 349 | 
            +
                        target.gsub!('/', '_')
         | 
| 350 | 
            +
                        target.gsub!('\\', '_')
         | 
| 344 351 |  | 
| 345 352 | 
             
                        mime_type = determine_mime_type(target, media_type)
         | 
| 346 353 | 
             
                        @book.add_binary(target, fs_path, mime_type)
         | 
| @@ -352,11 +359,26 @@ module Asciidoctor | |
| 352 359 | 
             
                    image_attrs << %(alt="#{node.attr('alt')}") if node.attr? 'alt'
         | 
| 353 360 | 
             
                  end
         | 
| 354 361 |  | 
| 362 | 
            +
                  ADMONITION_ICONS = {
         | 
| 363 | 
            +
                    'caution' => 'đĨ',
         | 
| 364 | 
            +
                    'important' => 'â',
         | 
| 365 | 
            +
                    'note' => 'âšī¸',
         | 
| 366 | 
            +
                    'tip' => 'đĄ',
         | 
| 367 | 
            +
                    'warning' => 'â ī¸'
         | 
| 368 | 
            +
                  }.freeze
         | 
| 369 | 
            +
             | 
| 355 370 | 
             
                  # @param node [Asciidoctor::Block]
         | 
| 356 371 | 
             
                  def convert_admonition(node)
         | 
| 357 | 
            -
                    lines = [ | 
| 358 | 
            -
             | 
| 359 | 
            -
             | 
| 372 | 
            +
                    lines = ['<p>']
         | 
| 373 | 
            +
             | 
| 374 | 
            +
                    lines << if node.document.attr?('icons', 'font') && (icon = ADMONITION_ICONS[node.attr 'name'])
         | 
| 375 | 
            +
                               %(#{icon} )
         | 
| 376 | 
            +
                             else
         | 
| 377 | 
            +
                               %(<strong>#{node.title || node.caption}:</strong>)
         | 
| 378 | 
            +
                             end
         | 
| 379 | 
            +
             | 
| 380 | 
            +
                    lines << node.content
         | 
| 381 | 
            +
                    lines << '</p>'
         | 
| 360 382 | 
             
                    lines << '<empty-line/>' unless node.has_role?('last')
         | 
| 361 383 | 
             
                    lines * "\n"
         | 
| 362 384 | 
             
                  end
         | 
| @@ -465,7 +487,7 @@ module Asciidoctor | |
| 465 487 | 
             
                          ]
         | 
| 466 488 | 
             
                          cell_attrs << %(colspan="#{cell.colspan}") if cell.colspan
         | 
| 467 489 | 
             
                          cell_attrs << %(rowspan="#{cell.rowspan}") if cell.rowspan
         | 
| 468 | 
            -
                          lines << %(<#{cell_tag_name} #{cell_attrs * ' '}>#{cell_content}</#{cell_tag_name}>)
         | 
| 490 | 
            +
                          lines << %(<#{cell_tag_name} #{cell_attrs.sort! * ' '}>#{cell_content}</#{cell_tag_name}>)
         | 
| 469 491 | 
             
                        end
         | 
| 470 492 | 
             
                        lines << '</tr>'
         | 
| 471 493 | 
             
                      end
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: asciidoctor-fb2
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0. | 
| 4 | 
            +
              version: 0.7.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Marat Radchenko
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2022- | 
| 11 | 
            +
            date: 2022-12-18 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: asciidoctor
         | 
| @@ -106,42 +106,42 @@ dependencies: | |
| 106 106 | 
             
                requirements:
         | 
| 107 107 | 
             
                - - "~>"
         | 
| 108 108 | 
             
                  - !ruby/object:Gem::Version
         | 
| 109 | 
            -
                    version: 1. | 
| 109 | 
            +
                    version: 1.28.2
         | 
| 110 110 | 
             
              type: :development
         | 
| 111 111 | 
             
              prerelease: false
         | 
| 112 112 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 113 113 | 
             
                requirements:
         | 
| 114 114 | 
             
                - - "~>"
         | 
| 115 115 | 
             
                  - !ruby/object:Gem::Version
         | 
| 116 | 
            -
                    version: 1. | 
| 116 | 
            +
                    version: 1.28.2
         | 
| 117 117 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 118 118 | 
             
              name: rubocop-rake
         | 
| 119 119 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 120 120 | 
             
                requirements:
         | 
| 121 121 | 
             
                - - "~>"
         | 
| 122 122 | 
             
                  - !ruby/object:Gem::Version
         | 
| 123 | 
            -
                    version: 0. | 
| 123 | 
            +
                    version: 0.6.0
         | 
| 124 124 | 
             
              type: :development
         | 
| 125 125 | 
             
              prerelease: false
         | 
| 126 126 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 127 127 | 
             
                requirements:
         | 
| 128 128 | 
             
                - - "~>"
         | 
| 129 129 | 
             
                  - !ruby/object:Gem::Version
         | 
| 130 | 
            -
                    version: 0. | 
| 130 | 
            +
                    version: 0.6.0
         | 
| 131 131 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 132 132 | 
             
              name: rubocop-rspec
         | 
| 133 133 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| 134 134 | 
             
                requirements:
         | 
| 135 135 | 
             
                - - "~>"
         | 
| 136 136 | 
             
                  - !ruby/object:Gem::Version
         | 
| 137 | 
            -
                    version: 2. | 
| 137 | 
            +
                    version: 2.10.0
         | 
| 138 138 | 
             
              type: :development
         | 
| 139 139 | 
             
              prerelease: false
         | 
| 140 140 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 141 141 | 
             
                requirements:
         | 
| 142 142 | 
             
                - - "~>"
         | 
| 143 143 | 
             
                  - !ruby/object:Gem::Version
         | 
| 144 | 
            -
                    version: 2. | 
| 144 | 
            +
                    version: 2.10.0
         | 
| 145 145 | 
             
            description: 
         | 
| 146 146 | 
             
            email:
         | 
| 147 147 | 
             
            - marat@slonopotamus.org
         | 
| @@ -183,14 +183,14 @@ required_ruby_version: !ruby/object:Gem::Requirement | |
| 183 183 | 
             
              requirements:
         | 
| 184 184 | 
             
              - - ">="
         | 
| 185 185 | 
             
                - !ruby/object:Gem::Version
         | 
| 186 | 
            -
                  version: 2. | 
| 186 | 
            +
                  version: 2.5.0
         | 
| 187 187 | 
             
            required_rubygems_version: !ruby/object:Gem::Requirement
         | 
| 188 188 | 
             
              requirements:
         | 
| 189 189 | 
             
              - - ">="
         | 
| 190 190 | 
             
                - !ruby/object:Gem::Version
         | 
| 191 191 | 
             
                  version: '0'
         | 
| 192 192 | 
             
            requirements: []
         | 
| 193 | 
            -
            rubygems_version: 3.3. | 
| 193 | 
            +
            rubygems_version: 3.3.26
         | 
| 194 194 | 
             
            signing_key: 
         | 
| 195 195 | 
             
            specification_version: 4
         | 
| 196 196 | 
             
            summary: Converts AsciiDoc documents to FB2 e-book formats
         |