annotaterb 4.19.0 → 4.20.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/CHANGELOG.md +23 -0
- data/README.md +2 -2
- data/VERSION +1 -1
- data/lib/annotate_rb/config_generator.rb +3 -0
- data/lib/annotate_rb/model_annotator/annotation/annotation_builder.rb +15 -3
- data/lib/annotate_rb/model_annotator/annotation/schema_header.rb +21 -3
- data/lib/annotate_rb/model_annotator/column_annotation/column_component.rb +7 -3
- data/lib/annotate_rb/model_annotator/model_wrapper.rb +4 -0
- data/lib/annotate_rb/parser.rb +2 -2
- data/lib/annotate_rb/route_annotator/base_processor.rb +4 -0
- metadata +2 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 9df7cea27e60968dc415cd65fc55696bfcb47444bdb0dc9964ce155bfbce4e40
         | 
| 4 | 
            +
              data.tar.gz: 6883710db1dd58633c3a349adec97257df9c2d809a220fd19ba90c2a4a584cb7
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 2e164027db851243b7a1fccf9590c4a7515f47454ec785070e8e1dcd71bc0de7bec2caea30d919e6497dedfe78180681828cd6f1e24c6f0539c1d4e6b7895c33
         | 
| 7 | 
            +
              data.tar.gz: 65629d818e0f3a92528deec50d5ba6adeb4a521058a174a7d463df1d565a8bf59eccd4ddb039ea68fe0dffed7329a994a5fbc1dae9cf19cb87cf9dcec7e308f2
         | 
    
        data/CHANGELOG.md
    CHANGED
    
    | @@ -1,5 +1,28 @@ | |
| 1 1 | 
             
            # Changelog
         | 
| 2 2 |  | 
| 3 | 
            +
            ## [v4.19.0](https://github.com/drwl/annotaterb/tree/v4.19.0) (2025-08-28)
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            [Full Changelog](https://github.com/drwl/annotaterb/compare/v4.18.0...v4.19.0)
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            **Implemented enhancements:**
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            - ignore ActiveRecord::AssociatedObject [\#172](https://github.com/drwl/annotaterb/issues/172)
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            **Closed issues:**
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            - STI classes blank [\#252](https://github.com/drwl/annotaterb/issues/252)
         | 
| 14 | 
            +
            - Model annotation issue [\#249](https://github.com/drwl/annotaterb/issues/249)
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            **Merged pull requests:**
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            - Bump version to v4.19.0 [\#259](https://github.com/drwl/annotaterb/pull/259) ([drwl](https://github.com/drwl))
         | 
| 19 | 
            +
            - Fix STI models not being annotated [\#256](https://github.com/drwl/annotaterb/pull/256) ([drwl](https://github.com/drwl))
         | 
| 20 | 
            +
            - refactor: relocate migration\_version\_for\_model method to ModelWrapper [\#255](https://github.com/drwl/annotaterb/pull/255) ([OdenTakashi](https://github.com/OdenTakashi))
         | 
| 21 | 
            +
            - Fix: Skip abstract models during annotation [\#253](https://github.com/drwl/annotaterb/pull/253) ([taise](https://github.com/taise))
         | 
| 22 | 
            +
            - Fix Ruby 3.3.8 compatibility and improve Zeitwerk support for non-Rails projects [\#250](https://github.com/drwl/annotaterb/pull/250) ([bradley2W1DL](https://github.com/bradley2W1DL))
         | 
| 23 | 
            +
            - Return a model files array even if it’s empty [\#248](https://github.com/drwl/annotaterb/pull/248) ([Flink](https://github.com/Flink))
         | 
| 24 | 
            +
            - Generate changelog for v4.18.0 [\#247](https://github.com/drwl/annotaterb/pull/247) ([drwl](https://github.com/drwl))
         | 
| 25 | 
            +
             | 
| 3 26 | 
             
            ## [v4.18.0](https://github.com/drwl/annotaterb/tree/v4.18.0) (2025-08-04)
         | 
| 4 27 |  | 
| 5 28 | 
             
            [Full Changelog](https://github.com/drwl/annotaterb/compare/v4.17.0...v4.18.0)
         | 
    
        data/README.md
    CHANGED
    
    | @@ -146,10 +146,10 @@ Annotate model options: | |
| 146 146 | 
             
                    --ignore-unknown-models      don't display warnings for bad model files
         | 
| 147 147 | 
             
                -I, --ignore-columns REGEX       don't annotate columns that match a given REGEX (i.e., `annotate -I '^(id|updated_at|created_at)'`
         | 
| 148 148 | 
             
                    --with-comment               include database comments in model annotations
         | 
| 149 | 
            -
                    --without-comment             | 
| 149 | 
            +
                    --without-comment            exclude database comments in model annotations
         | 
| 150 150 | 
             
                    --with-column-comments       include column comments in model annotations
         | 
| 151 151 | 
             
                    --without-column-comments    exclude column comments in model annotations
         | 
| 152 | 
            -
                    --position-of-column- | 
| 152 | 
            +
                    --position-of-column-comment [with_name|rightmost_column]
         | 
| 153 153 | 
             
                                                 set the position, in the annotation block, of the column comment
         | 
| 154 154 | 
             
                    --with-table-comments        include table comments in model annotations
         | 
| 155 155 | 
             
                    --without-table-comments     exclude table comments in model annotations
         | 
    
        data/VERSION
    CHANGED
    
    | @@ -1 +1 @@ | |
| 1 | 
            -
            4. | 
| 1 | 
            +
            4.20.0
         | 
| @@ -13,6 +13,9 @@ module AnnotateRb | |
| 13 13 | 
             
                    differences = defaults.keys - user_defaults.keys
         | 
| 14 14 | 
             
                    result = defaults.slice(*differences)
         | 
| 15 15 |  | 
| 16 | 
            +
                    # Return empty string if no differences to avoid appending empty hash
         | 
| 17 | 
            +
                    return "" if result.empty?
         | 
| 18 | 
            +
             | 
| 16 19 | 
             
                    # Generates proper YAML including the leading hyphens `---` header
         | 
| 17 20 | 
             
                    yml_content = YAML.dump(result, StringIO.new).string
         | 
| 18 21 | 
             
                    # Remove the header
         | 
| @@ -5,7 +5,7 @@ module AnnotateRb | |
| 5 5 | 
             
                module Annotation
         | 
| 6 6 | 
             
                  class AnnotationBuilder
         | 
| 7 7 | 
             
                    class Annotation < Components::Base
         | 
| 8 | 
            -
                      attr_reader :version, :table_name, :table_comment, :max_size
         | 
| 8 | 
            +
                      attr_reader :version, :table_name, :table_comment, :max_size, :database_name
         | 
| 9 9 |  | 
| 10 10 | 
             
                      def initialize(options, **input)
         | 
| 11 11 | 
             
                        @options = options
         | 
| @@ -15,12 +15,13 @@ module AnnotateRb | |
| 15 15 | 
             
                        @table_comment = input[:table_comment]
         | 
| 16 16 | 
             
                        @max_size = input[:max_size]
         | 
| 17 17 | 
             
                        @model = input[:model]
         | 
| 18 | 
            +
                        @database_name = input[:database_name]
         | 
| 18 19 | 
             
                      end
         | 
| 19 20 |  | 
| 20 21 | 
             
                      def body
         | 
| 21 22 | 
             
                        [
         | 
| 22 23 | 
             
                          MainHeader.new(version, @options[:include_version]),
         | 
| 23 | 
            -
                          SchemaHeader.new(table_name, table_comment, @options),
         | 
| 24 | 
            +
                          SchemaHeader.new(table_name, table_comment, database_name, @options),
         | 
| 24 25 | 
             
                          MarkdownHeader.new(max_size),
         | 
| 25 26 | 
             
                          *columns,
         | 
| 26 27 | 
             
                          IndexAnnotation::AnnotationBuilder.new(@model, @options).build,
         | 
| @@ -63,10 +64,21 @@ module AnnotateRb | |
| 63 64 | 
             
                      table_name = @model.table_name
         | 
| 64 65 | 
             
                      table_comment = @model.connection.try(:table_comment, @model.table_name)
         | 
| 65 66 | 
             
                      max_size = @model.max_schema_info_width
         | 
| 67 | 
            +
                      database_name = @model.database_name if multi_db_environment?
         | 
| 66 68 |  | 
| 67 69 | 
             
                      _annotation = Annotation.new(@options,
         | 
| 68 70 | 
             
                        version: version, table_name: table_name, table_comment: table_comment,
         | 
| 69 | 
            -
                        max_size: max_size, model: @model).build
         | 
| 71 | 
            +
                        max_size: max_size, model: @model, database_name: database_name).build
         | 
| 72 | 
            +
                    end
         | 
| 73 | 
            +
             | 
| 74 | 
            +
                    private
         | 
| 75 | 
            +
             | 
| 76 | 
            +
                    def multi_db_environment?
         | 
| 77 | 
            +
                      if defined?(::Rails) && ::Rails.env
         | 
| 78 | 
            +
                        ActiveRecord::Base.configurations.configs_for(env_name: ::Rails.env).size > 1
         | 
| 79 | 
            +
                      else
         | 
| 80 | 
            +
                        false
         | 
| 81 | 
            +
                      end
         | 
| 70 82 | 
             
                    end
         | 
| 71 83 | 
             
                  end
         | 
| 72 84 | 
             
                end
         | 
| @@ -20,11 +20,28 @@ module AnnotateRb | |
| 20 20 | 
             
                      end
         | 
| 21 21 | 
             
                    end
         | 
| 22 22 |  | 
| 23 | 
            -
                     | 
| 23 | 
            +
                    class DatabaseName < Components::Base
         | 
| 24 | 
            +
                      attr_reader :name
         | 
| 25 | 
            +
             | 
| 26 | 
            +
                      def initialize(name)
         | 
| 27 | 
            +
                        @name = name
         | 
| 28 | 
            +
                      end
         | 
| 29 | 
            +
             | 
| 30 | 
            +
                      def to_default
         | 
| 31 | 
            +
                        "# Database name: #{name}"
         | 
| 32 | 
            +
                      end
         | 
| 33 | 
            +
             | 
| 34 | 
            +
                      def to_markdown
         | 
| 35 | 
            +
                        "# Database name: `#{name}`"
         | 
| 36 | 
            +
                      end
         | 
| 37 | 
            +
                    end
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                    attr_reader :table_name, :table_comment, :database_name
         | 
| 24 40 |  | 
| 25 | 
            -
                    def initialize(table_name, table_comment, options)
         | 
| 41 | 
            +
                    def initialize(table_name, table_comment, database_name, options)
         | 
| 26 42 | 
             
                      @table_name = table_name
         | 
| 27 43 | 
             
                      @table_comment = table_comment
         | 
| 44 | 
            +
                      @database_name = database_name
         | 
| 28 45 | 
             
                      @options = options
         | 
| 29 46 | 
             
                    end
         | 
| 30 47 |  | 
| @@ -32,8 +49,9 @@ module AnnotateRb | |
| 32 49 | 
             
                      [
         | 
| 33 50 | 
             
                        Components::BlankCommentLine.new,
         | 
| 34 51 | 
             
                        TableName.new(name),
         | 
| 52 | 
            +
                        (DatabaseName.new(database_name) if database_name),
         | 
| 35 53 | 
             
                        Components::BlankCommentLine.new
         | 
| 36 | 
            -
                      ]
         | 
| 54 | 
            +
                      ].compact
         | 
| 37 55 | 
             
                    end
         | 
| 38 56 |  | 
| 39 57 | 
             
                    def to_default
         | 
| @@ -22,12 +22,16 @@ module AnnotateRb | |
| 22 22 | 
             
                    def name
         | 
| 23 23 | 
             
                      case position_of_column_comment
         | 
| 24 24 | 
             
                      when :with_name
         | 
| 25 | 
            -
                        "#{column.name}(#{ | 
| 25 | 
            +
                        "#{column.name}(#{escaped_column_comment})"
         | 
| 26 26 | 
             
                      else
         | 
| 27 27 | 
             
                        column.name
         | 
| 28 28 | 
             
                      end
         | 
| 29 29 | 
             
                    end
         | 
| 30 30 |  | 
| 31 | 
            +
                    def escaped_column_comment
         | 
| 32 | 
            +
                      column.comment.to_s.gsub(/\n/, '\\n')
         | 
| 33 | 
            +
                    end
         | 
| 34 | 
            +
             | 
| 31 35 | 
             
                    def to_rdoc
         | 
| 32 36 | 
             
                      # standard:disable Lint/FormatParameterMismatch
         | 
| 33 37 | 
             
                      format("# %-#{max_name_size}.#{max_name_size}s<tt>%s</tt>",
         | 
| @@ -56,7 +60,7 @@ module AnnotateRb | |
| 56 60 | 
             
                      name_remainder = max_name_size - name.length - non_ascii_length(name)
         | 
| 57 61 | 
             
                      type_remainder = (MD_TYPE_ALLOWANCE - 2) - type.length
         | 
| 58 62 | 
             
                      attributes_remainder = max_attributes_size + 1 - joined_attributes.length
         | 
| 59 | 
            -
                      comment_rightmost = (position_of_column_comment != :rightmost_column) ? "" : " | `#{ | 
| 63 | 
            +
                      comment_rightmost = (position_of_column_comment != :rightmost_column) ? "" : " | `#{escaped_column_comment}`"
         | 
| 60 64 |  | 
| 61 65 | 
             
                      # standard:disable Lint/FormatParameterMismatch
         | 
| 62 66 | 
             
                      format(
         | 
| @@ -72,7 +76,7 @@ module AnnotateRb | |
| 72 76 | 
             
                    end
         | 
| 73 77 |  | 
| 74 78 | 
             
                    def to_default
         | 
| 75 | 
            -
                      comment_rightmost = (position_of_column_comment == :rightmost_column) ?  | 
| 79 | 
            +
                      comment_rightmost = (position_of_column_comment == :rightmost_column) ? escaped_column_comment : ""
         | 
| 76 80 | 
             
                      joined_attributes = attributes.join(", ")
         | 
| 77 81 | 
             
                      format(
         | 
| 78 82 | 
             
                        "#  %s:%s %s %s",
         | 
    
        data/lib/annotate_rb/parser.rb
    CHANGED
    
    | @@ -246,9 +246,9 @@ module AnnotateRb | |
| 246 246 | 
             
                    @options[:with_column_comments] = false
         | 
| 247 247 | 
             
                  end
         | 
| 248 248 |  | 
| 249 | 
            -
                  option_parser.on("--position-of-column- | 
| 249 | 
            +
                  option_parser.on("--position-of-column-comment [with_name|rightmost_column]",
         | 
| 250 250 | 
             
                    "set the position, in the annotation block, of the column comment") do |value|
         | 
| 251 | 
            -
                    @options[: | 
| 251 | 
            +
                    @options[:position_of_column_comment] = value.to_sym
         | 
| 252 252 | 
             
                  end
         | 
| 253 253 |  | 
| 254 254 | 
             
                  option_parser.on("--with-table-comments",
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: annotaterb
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 4. | 
| 4 | 
            +
              version: 4.20.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Andrew W. Lee
         | 
| 8 8 | 
             
            autorequire:
         | 
| 9 9 | 
             
            bindir: exe
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2025- | 
| 11 | 
            +
            date: 2025-10-20 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: activerecord
         |