rubocop-sketchup 0.5.0 → 0.6.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/Gemfile +19 -19
- data/assets/output.html.erb +301 -301
- data/config/default.yml +355 -355
- data/lib/rubocop/sketchup/config.rb +63 -63
- data/lib/rubocop/sketchup/cop/deprecations/add_separator_to_menu.rb +25 -25
- data/lib/rubocop/sketchup/cop/deprecations/operation_next_transparent.rb +30 -30
- data/lib/rubocop/sketchup/cop/deprecations/require_all.rb +27 -27
- data/lib/rubocop/sketchup/cop/deprecations/set_texture_projection.rb +26 -26
- data/lib/rubocop/sketchup/cop/deprecations/show_ruby_panel.rb +25 -25
- data/lib/rubocop/sketchup/cop/deprecations/sketchup_set.rb +30 -30
- data/lib/rubocop/sketchup/cop/performance/openssl.rb +41 -41
- data/lib/rubocop/sketchup/cop/performance/operation_disable_ui.rb +33 -33
- data/lib/rubocop/sketchup/cop/performance/selection_bulk.rb +79 -79
- data/lib/rubocop/sketchup/cop/performance/type_check.rb +63 -63
- data/lib/rubocop/sketchup/cop/performance/typename.rb +24 -24
- data/lib/rubocop/sketchup/cop/requirements/api_namespace.rb +30 -30
- data/lib/rubocop/sketchup/cop/requirements/exit.rb +32 -32
- data/lib/rubocop/sketchup/cop/requirements/extension_namespace.rb +108 -108
- data/lib/rubocop/sketchup/cop/requirements/file_structure.rb +97 -97
- data/lib/rubocop/sketchup/cop/requirements/gem_install.rb +45 -45
- data/lib/rubocop/sketchup/cop/requirements/get_extension_license.rb +95 -95
- data/lib/rubocop/sketchup/cop/requirements/global_constants.rb +38 -38
- data/lib/rubocop/sketchup/cop/requirements/global_include.rb +42 -42
- data/lib/rubocop/sketchup/cop/requirements/global_methods.rb +65 -65
- data/lib/rubocop/sketchup/cop/requirements/global_variables.rb +95 -95
- data/lib/rubocop/sketchup/cop/requirements/language_handler_globals.rb +46 -46
- data/lib/rubocop/sketchup/cop/requirements/load_path.rb +83 -83
- data/lib/rubocop/sketchup/cop/requirements/minimal_registration.rb +73 -73
- data/lib/rubocop/sketchup/cop/requirements/observers_start_operation.rb +161 -161
- data/lib/rubocop/sketchup/cop/requirements/register_extension.rb +45 -45
- data/lib/rubocop/sketchup/cop/requirements/ruby_core_namespace.rb +291 -291
- data/lib/rubocop/sketchup/cop/requirements/ruby_stdlib_namespace.rb +634 -634
- data/lib/rubocop/sketchup/cop/requirements/shipped_extensions_namespace.rb +61 -61
- data/lib/rubocop/sketchup/cop/requirements/sketchup_extension.rb +119 -119
- data/lib/rubocop/sketchup/cop/requirements/sketchup_require.rb +163 -163
- data/lib/rubocop/sketchup/cop/suggestions/add_group.rb +49 -49
- data/lib/rubocop/sketchup/cop/suggestions/compatibility.rb +117 -117
- data/lib/rubocop/sketchup/cop/suggestions/dc_internals.rb +34 -34
- data/lib/rubocop/sketchup/cop/suggestions/file_encoding.rb +78 -78
- data/lib/rubocop/sketchup/cop/suggestions/model_entities.rb +58 -58
- data/lib/rubocop/sketchup/cop/suggestions/monkey_patched_api.rb +45 -45
- data/lib/rubocop/sketchup/cop/suggestions/operation_name.rb +103 -103
- data/lib/rubocop/sketchup/cop/suggestions/sketchup_find_support_file.rb +39 -39
- data/lib/rubocop/sketchup/cop/suggestions/tool_drawing_bounds.rb +44 -44
- data/lib/rubocop/sketchup/cop/suggestions/tool_invalidate.rb +66 -66
- data/lib/rubocop/sketchup/cop/suggestions/tool_user_input.rb +41 -41
- data/lib/rubocop/sketchup/cop/suggestions/toolbar_timer.rb +65 -65
- data/lib/rubocop/sketchup/cop.rb +111 -111
- data/lib/rubocop/sketchup/dc_globals.rb +24 -24
- data/lib/rubocop/sketchup/dc_methods.rb +130 -130
- data/lib/rubocop/sketchup/extension_project.rb +65 -65
- data/lib/rubocop/sketchup/features.rb +738 -738
- data/lib/rubocop/sketchup/formatter/extension_review.rb +259 -259
- data/lib/rubocop/sketchup/inject.rb +19 -19
- data/lib/rubocop/sketchup/namespace.rb +47 -47
- data/lib/rubocop/sketchup/namespace_checker.rb +46 -46
- data/lib/rubocop/sketchup/no_comment_disable.rb +17 -17
- data/lib/rubocop/sketchup/range_help.rb +52 -52
- data/lib/rubocop/sketchup/sketchup_version.rb +87 -87
- data/lib/rubocop/sketchup/tool_checker.rb +43 -43
- data/lib/rubocop/sketchup/version.rb +5 -5
- data/lib/rubocop/sketchup.rb +12 -12
- data/lib/rubocop-sketchup.rb +48 -48
- data/rubocop-sketchup.gemspec +27 -27
- metadata +4 -4
| @@ -1,46 +1,46 @@ | |
| 1 | 
            -
            # frozen_string_literal: true
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            module RuboCop
         | 
| 4 | 
            -
              module Cop
         | 
| 5 | 
            -
                module SketchupRequirements
         | 
| 6 | 
            -
                  # Avoid using globals in general, but especially these which are known to
         | 
| 7 | 
            -
                  # be in use by other extensions made by SketchUp.
         | 
| 8 | 
            -
                  # They are still in use due to compatibility reasons.
         | 
| 9 | 
            -
                  class LanguageHandlerGlobals < SketchUp::Cop
         | 
| 10 | 
            -
             | 
| 11 | 
            -
                    include SketchUp::NoCommentDisable
         | 
| 12 | 
            -
             | 
| 13 | 
            -
                    MSG = 'Avoid globals in general, but especially these which are known '\
         | 
| 14 | 
            -
                          'to be in use.'.freeze
         | 
| 15 | 
            -
             | 
| 16 | 
            -
                    LH_GLOBALS = %i[
         | 
| 17 | 
            -
                      $dc_strings
         | 
| 18 | 
            -
                      $devl_strings
         | 
| 19 | 
            -
                      $exStrings
         | 
| 20 | 
            -
                      $fs_strings
         | 
| 21 | 
            -
                      $make_pano_string
         | 
| 22 | 
            -
                      $oceanStrings
         | 
| 23 | 
            -
                      $sn_strings
         | 
| 24 | 
            -
                      $ssf_strings
         | 
| 25 | 
            -
                      $suStrings
         | 
| 26 | 
            -
                      $tStrings
         | 
| 27 | 
            -
                      $unitsStrings
         | 
| 28 | 
            -
                      $uStrings
         | 
| 29 | 
            -
                      $wt_strings
         | 
| 30 | 
            -
                    ].freeze
         | 
| 31 | 
            -
             | 
| 32 | 
            -
                    def hl_global_var?(global_var)
         | 
| 33 | 
            -
                      LH_GLOBALS.include?(global_var)
         | 
| 34 | 
            -
                    end
         | 
| 35 | 
            -
             | 
| 36 | 
            -
                    def on_gvasgn(node)
         | 
| 37 | 
            -
                      global_var, = *node
         | 
| 38 | 
            -
                      return unless hl_global_var?(global_var)
         | 
| 39 | 
            -
             | 
| 40 | 
            -
                      add_offense(node, location: :name)
         | 
| 41 | 
            -
                    end
         | 
| 42 | 
            -
             | 
| 43 | 
            -
                  end
         | 
| 44 | 
            -
                end
         | 
| 45 | 
            -
              end
         | 
| 46 | 
            -
            end
         | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            module RuboCop
         | 
| 4 | 
            +
              module Cop
         | 
| 5 | 
            +
                module SketchupRequirements
         | 
| 6 | 
            +
                  # Avoid using globals in general, but especially these which are known to
         | 
| 7 | 
            +
                  # be in use by other extensions made by SketchUp.
         | 
| 8 | 
            +
                  # They are still in use due to compatibility reasons.
         | 
| 9 | 
            +
                  class LanguageHandlerGlobals < SketchUp::Cop
         | 
| 10 | 
            +
             | 
| 11 | 
            +
                    include SketchUp::NoCommentDisable
         | 
| 12 | 
            +
             | 
| 13 | 
            +
                    MSG = 'Avoid globals in general, but especially these which are known '\
         | 
| 14 | 
            +
                          'to be in use.'.freeze
         | 
| 15 | 
            +
             | 
| 16 | 
            +
                    LH_GLOBALS = %i[
         | 
| 17 | 
            +
                      $dc_strings
         | 
| 18 | 
            +
                      $devl_strings
         | 
| 19 | 
            +
                      $exStrings
         | 
| 20 | 
            +
                      $fs_strings
         | 
| 21 | 
            +
                      $make_pano_string
         | 
| 22 | 
            +
                      $oceanStrings
         | 
| 23 | 
            +
                      $sn_strings
         | 
| 24 | 
            +
                      $ssf_strings
         | 
| 25 | 
            +
                      $suStrings
         | 
| 26 | 
            +
                      $tStrings
         | 
| 27 | 
            +
                      $unitsStrings
         | 
| 28 | 
            +
                      $uStrings
         | 
| 29 | 
            +
                      $wt_strings
         | 
| 30 | 
            +
                    ].freeze
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                    def hl_global_var?(global_var)
         | 
| 33 | 
            +
                      LH_GLOBALS.include?(global_var)
         | 
| 34 | 
            +
                    end
         | 
| 35 | 
            +
             | 
| 36 | 
            +
                    def on_gvasgn(node)
         | 
| 37 | 
            +
                      global_var, = *node
         | 
| 38 | 
            +
                      return unless hl_global_var?(global_var)
         | 
| 39 | 
            +
             | 
| 40 | 
            +
                      add_offense(node, location: :name)
         | 
| 41 | 
            +
                    end
         | 
| 42 | 
            +
             | 
| 43 | 
            +
                  end
         | 
| 44 | 
            +
                end
         | 
| 45 | 
            +
              end
         | 
| 46 | 
            +
            end
         | 
| @@ -1,83 +1,83 @@ | |
| 1 | 
            -
            # frozen_string_literal: true
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            module RuboCop
         | 
| 4 | 
            -
              module Cop
         | 
| 5 | 
            -
                module SketchupRequirements
         | 
| 6 | 
            -
                  # Do not modify the load path. Modifying `$LOAD_PATH` is bad practice
         | 
| 7 | 
            -
                  # because it can cause extensions to inadvertently load the wrong file.
         | 
| 8 | 
            -
                  class LoadPath < SketchUp::Cop
         | 
| 9 | 
            -
             | 
| 10 | 
            -
                    include SketchUp::NoCommentDisable
         | 
| 11 | 
            -
             | 
| 12 | 
            -
                    MSG = 'Do not modify the load path.'.freeze
         | 
| 13 | 
            -
             | 
| 14 | 
            -
                    def_node_matcher :load_path_mutator?, <<-PATTERN
         | 
| 15 | 
            -
                      (send
         | 
| 16 | 
            -
                        (gvar #load_path?) $#mutator?
         | 
| 17 | 
            -
                        ...
         | 
| 18 | 
            -
                      )
         | 
| 19 | 
            -
                    PATTERN
         | 
| 20 | 
            -
             | 
| 21 | 
            -
                    LOAD_PATH_ALIASES = %i[
         | 
| 22 | 
            -
                      $: $LOAD_PATH
         | 
| 23 | 
            -
                    ].freeze
         | 
| 24 | 
            -
             | 
| 25 | 
            -
                    MUTATORS = %i[
         | 
| 26 | 
            -
                      <<
         | 
| 27 | 
            -
                      []=
         | 
| 28 | 
            -
                      clear
         | 
| 29 | 
            -
                      collect!
         | 
| 30 | 
            -
                      compact!
         | 
| 31 | 
            -
                      concat
         | 
| 32 | 
            -
                      delete
         | 
| 33 | 
            -
                      delete_at
         | 
| 34 | 
            -
                      delete_if
         | 
| 35 | 
            -
                      drop
         | 
| 36 | 
            -
                      drop_while
         | 
| 37 | 
            -
                      fill
         | 
| 38 | 
            -
                      flatten!
         | 
| 39 | 
            -
                      insert
         | 
| 40 | 
            -
                      keep_if
         | 
| 41 | 
            -
                      map!
         | 
| 42 | 
            -
                      pop
         | 
| 43 | 
            -
                      push
         | 
| 44 | 
            -
                      reject!
         | 
| 45 | 
            -
                      replace
         | 
| 46 | 
            -
                      reverse!
         | 
| 47 | 
            -
                      rotate!
         | 
| 48 | 
            -
                      select!
         | 
| 49 | 
            -
                      shift
         | 
| 50 | 
            -
                      shuffle!
         | 
| 51 | 
            -
                      slice!
         | 
| 52 | 
            -
                      sort!
         | 
| 53 | 
            -
                      sort_by!
         | 
| 54 | 
            -
                      uniq!
         | 
| 55 | 
            -
                      unshift
         | 
| 56 | 
            -
                    ].freeze
         | 
| 57 | 
            -
             | 
| 58 | 
            -
                    def load_path?(sym)
         | 
| 59 | 
            -
                      LOAD_PATH_ALIASES.include?(sym)
         | 
| 60 | 
            -
                    end
         | 
| 61 | 
            -
             | 
| 62 | 
            -
                    def mutator?(sym)
         | 
| 63 | 
            -
                      MUTATORS.include?(sym)
         | 
| 64 | 
            -
                    end
         | 
| 65 | 
            -
             | 
| 66 | 
            -
                    def on_gvasgn(node)
         | 
| 67 | 
            -
                      global_var, = *node
         | 
| 68 | 
            -
                      return unless load_path?(global_var)
         | 
| 69 | 
            -
             | 
| 70 | 
            -
                      add_offense(node, location: :expression)
         | 
| 71 | 
            -
                    end
         | 
| 72 | 
            -
             | 
| 73 | 
            -
                    def on_send(node)
         | 
| 74 | 
            -
                      method_name = load_path_mutator?(node)
         | 
| 75 | 
            -
                      return unless method_name
         | 
| 76 | 
            -
             | 
| 77 | 
            -
                      add_offense(node, location: :expression)
         | 
| 78 | 
            -
                    end
         | 
| 79 | 
            -
             | 
| 80 | 
            -
                  end
         | 
| 81 | 
            -
                end
         | 
| 82 | 
            -
              end
         | 
| 83 | 
            -
            end
         | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            module RuboCop
         | 
| 4 | 
            +
              module Cop
         | 
| 5 | 
            +
                module SketchupRequirements
         | 
| 6 | 
            +
                  # Do not modify the load path. Modifying `$LOAD_PATH` is bad practice
         | 
| 7 | 
            +
                  # because it can cause extensions to inadvertently load the wrong file.
         | 
| 8 | 
            +
                  class LoadPath < SketchUp::Cop
         | 
| 9 | 
            +
             | 
| 10 | 
            +
                    include SketchUp::NoCommentDisable
         | 
| 11 | 
            +
             | 
| 12 | 
            +
                    MSG = 'Do not modify the load path.'.freeze
         | 
| 13 | 
            +
             | 
| 14 | 
            +
                    def_node_matcher :load_path_mutator?, <<-PATTERN
         | 
| 15 | 
            +
                      (send
         | 
| 16 | 
            +
                        (gvar #load_path?) $#mutator?
         | 
| 17 | 
            +
                        ...
         | 
| 18 | 
            +
                      )
         | 
| 19 | 
            +
                    PATTERN
         | 
| 20 | 
            +
             | 
| 21 | 
            +
                    LOAD_PATH_ALIASES = %i[
         | 
| 22 | 
            +
                      $: $LOAD_PATH
         | 
| 23 | 
            +
                    ].freeze
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                    MUTATORS = %i[
         | 
| 26 | 
            +
                      <<
         | 
| 27 | 
            +
                      []=
         | 
| 28 | 
            +
                      clear
         | 
| 29 | 
            +
                      collect!
         | 
| 30 | 
            +
                      compact!
         | 
| 31 | 
            +
                      concat
         | 
| 32 | 
            +
                      delete
         | 
| 33 | 
            +
                      delete_at
         | 
| 34 | 
            +
                      delete_if
         | 
| 35 | 
            +
                      drop
         | 
| 36 | 
            +
                      drop_while
         | 
| 37 | 
            +
                      fill
         | 
| 38 | 
            +
                      flatten!
         | 
| 39 | 
            +
                      insert
         | 
| 40 | 
            +
                      keep_if
         | 
| 41 | 
            +
                      map!
         | 
| 42 | 
            +
                      pop
         | 
| 43 | 
            +
                      push
         | 
| 44 | 
            +
                      reject!
         | 
| 45 | 
            +
                      replace
         | 
| 46 | 
            +
                      reverse!
         | 
| 47 | 
            +
                      rotate!
         | 
| 48 | 
            +
                      select!
         | 
| 49 | 
            +
                      shift
         | 
| 50 | 
            +
                      shuffle!
         | 
| 51 | 
            +
                      slice!
         | 
| 52 | 
            +
                      sort!
         | 
| 53 | 
            +
                      sort_by!
         | 
| 54 | 
            +
                      uniq!
         | 
| 55 | 
            +
                      unshift
         | 
| 56 | 
            +
                    ].freeze
         | 
| 57 | 
            +
             | 
| 58 | 
            +
                    def load_path?(sym)
         | 
| 59 | 
            +
                      LOAD_PATH_ALIASES.include?(sym)
         | 
| 60 | 
            +
                    end
         | 
| 61 | 
            +
             | 
| 62 | 
            +
                    def mutator?(sym)
         | 
| 63 | 
            +
                      MUTATORS.include?(sym)
         | 
| 64 | 
            +
                    end
         | 
| 65 | 
            +
             | 
| 66 | 
            +
                    def on_gvasgn(node)
         | 
| 67 | 
            +
                      global_var, = *node
         | 
| 68 | 
            +
                      return unless load_path?(global_var)
         | 
| 69 | 
            +
             | 
| 70 | 
            +
                      add_offense(node, location: :expression)
         | 
| 71 | 
            +
                    end
         | 
| 72 | 
            +
             | 
| 73 | 
            +
                    def on_send(node)
         | 
| 74 | 
            +
                      method_name = load_path_mutator?(node)
         | 
| 75 | 
            +
                      return unless method_name
         | 
| 76 | 
            +
             | 
| 77 | 
            +
                      add_offense(node, location: :expression)
         | 
| 78 | 
            +
                    end
         | 
| 79 | 
            +
             | 
| 80 | 
            +
                  end
         | 
| 81 | 
            +
                end
         | 
| 82 | 
            +
              end
         | 
| 83 | 
            +
            end
         | 
| @@ -1,73 +1,73 @@ | |
| 1 | 
            -
            # frozen_string_literal: true
         | 
| 2 | 
            -
             | 
| 3 | 
            -
            require 'pathname'
         | 
| 4 | 
            -
             | 
| 5 | 
            -
            module RuboCop
         | 
| 6 | 
            -
              module Cop
         | 
| 7 | 
            -
                module SketchupRequirements
         | 
| 8 | 
            -
                  # Don't load extension files in the root file registering the extension.
         | 
| 9 | 
            -
                  # Extensions should not load additional files when it's disabled.
         | 
| 10 | 
            -
                  #
         | 
| 11 | 
            -
                  # @example Bad - Extension will always load.
         | 
| 12 | 
            -
                  #   module Example
         | 
| 13 | 
            -
                  #     require 'example/main' # BAD! This will load even when extension
         | 
| 14 | 
            -
                  #                            #      is disabled.
         | 
| 15 | 
            -
                  #     unless file_loaded?(__FILE__)
         | 
| 16 | 
            -
                  #       extension = SketchupExtension.new('Hello World', 'example/main')
         | 
| 17 | 
            -
                  #       Sketchup.register_extension(extension, true)
         | 
| 18 | 
            -
                  #       file_loaded(__FILE__)
         | 
| 19 | 
            -
                  #     end
         | 
| 20 | 
            -
                  #   end
         | 
| 21 | 
            -
                  #
         | 
| 22 | 
            -
                  # @example Good - Extension doesn't load anything unless its enabled.
         | 
| 23 | 
            -
                  #   module Example
         | 
| 24 | 
            -
                  #     unless file_loaded?(__FILE__)
         | 
| 25 | 
            -
                  #       extension = SketchupExtension.new('Hello World', 'example/main')
         | 
| 26 | 
            -
                  #       Sketchup.register_extension(extension, true)
         | 
| 27 | 
            -
                  #       file_loaded(__FILE__)
         | 
| 28 | 
            -
                  #     end
         | 
| 29 | 
            -
                  #   end
         | 
| 30 | 
            -
                  class MinimalRegistration < SketchUp::Cop
         | 
| 31 | 
            -
             | 
| 32 | 
            -
                    include SketchUp::NoCommentDisable
         | 
| 33 | 
            -
                    include SketchUp::ExtensionProject
         | 
| 34 | 
            -
             | 
| 35 | 
            -
                    MSG = "Don't load extension files in the root file registering the "\
         | 
| 36 | 
            -
                          'extension.'.freeze
         | 
| 37 | 
            -
             | 
| 38 | 
            -
                    # Reference: http://rubocop.readthedocs.io/en/latest/node_pattern/
         | 
| 39 | 
            -
                    def_node_matcher :require_filename, <<-PATTERN
         | 
| 40 | 
            -
                      {
         | 
| 41 | 
            -
                        (send {(const nil? :Sketchup) nil?} {:require :load} (str $_))
         | 
| 42 | 
            -
                        (send nil? :require_relative (str $_))
         | 
| 43 | 
            -
                      }
         | 
| 44 | 
            -
                    PATTERN
         | 
| 45 | 
            -
             | 
| 46 | 
            -
                    def investigate(processed_source)
         | 
| 47 | 
            -
                      if root_file?(processed_source)
         | 
| 48 | 
            -
                        filename = processed_source.buffer.name
         | 
| 49 | 
            -
                        @extension_basename = File.basename(filename, '.*')
         | 
| 50 | 
            -
                      end
         | 
| 51 | 
            -
                    end
         | 
| 52 | 
            -
             | 
| 53 | 
            -
                    def extension_file?(filename)
         | 
| 54 | 
            -
                      return false unless filename.include?('/')
         | 
| 55 | 
            -
             | 
| 56 | 
            -
                      first_directory = filename.split('/').first
         | 
| 57 | 
            -
                      @extension_basename.casecmp(first_directory) == 0
         | 
| 58 | 
            -
                    end
         | 
| 59 | 
            -
             | 
| 60 | 
            -
                    def on_send(node)
         | 
| 61 | 
            -
                      return unless @extension_basename
         | 
| 62 | 
            -
             | 
| 63 | 
            -
                      filename = require_filename(node)
         | 
| 64 | 
            -
                      return if filename.nil?
         | 
| 65 | 
            -
                      return unless extension_file?(filename)
         | 
| 66 | 
            -
             | 
| 67 | 
            -
                      add_offense(node)
         | 
| 68 | 
            -
                    end
         | 
| 69 | 
            -
             | 
| 70 | 
            -
                  end
         | 
| 71 | 
            -
                end
         | 
| 72 | 
            -
              end
         | 
| 73 | 
            -
            end
         | 
| 1 | 
            +
            # frozen_string_literal: true
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            require 'pathname'
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            module RuboCop
         | 
| 6 | 
            +
              module Cop
         | 
| 7 | 
            +
                module SketchupRequirements
         | 
| 8 | 
            +
                  # Don't load extension files in the root file registering the extension.
         | 
| 9 | 
            +
                  # Extensions should not load additional files when it's disabled.
         | 
| 10 | 
            +
                  #
         | 
| 11 | 
            +
                  # @example Bad - Extension will always load.
         | 
| 12 | 
            +
                  #   module Example
         | 
| 13 | 
            +
                  #     require 'example/main' # BAD! This will load even when extension
         | 
| 14 | 
            +
                  #                            #      is disabled.
         | 
| 15 | 
            +
                  #     unless file_loaded?(__FILE__)
         | 
| 16 | 
            +
                  #       extension = SketchupExtension.new('Hello World', 'example/main')
         | 
| 17 | 
            +
                  #       Sketchup.register_extension(extension, true)
         | 
| 18 | 
            +
                  #       file_loaded(__FILE__)
         | 
| 19 | 
            +
                  #     end
         | 
| 20 | 
            +
                  #   end
         | 
| 21 | 
            +
                  #
         | 
| 22 | 
            +
                  # @example Good - Extension doesn't load anything unless its enabled.
         | 
| 23 | 
            +
                  #   module Example
         | 
| 24 | 
            +
                  #     unless file_loaded?(__FILE__)
         | 
| 25 | 
            +
                  #       extension = SketchupExtension.new('Hello World', 'example/main')
         | 
| 26 | 
            +
                  #       Sketchup.register_extension(extension, true)
         | 
| 27 | 
            +
                  #       file_loaded(__FILE__)
         | 
| 28 | 
            +
                  #     end
         | 
| 29 | 
            +
                  #   end
         | 
| 30 | 
            +
                  class MinimalRegistration < SketchUp::Cop
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                    include SketchUp::NoCommentDisable
         | 
| 33 | 
            +
                    include SketchUp::ExtensionProject
         | 
| 34 | 
            +
             | 
| 35 | 
            +
                    MSG = "Don't load extension files in the root file registering the "\
         | 
| 36 | 
            +
                          'extension.'.freeze
         | 
| 37 | 
            +
             | 
| 38 | 
            +
                    # Reference: http://rubocop.readthedocs.io/en/latest/node_pattern/
         | 
| 39 | 
            +
                    def_node_matcher :require_filename, <<-PATTERN
         | 
| 40 | 
            +
                      {
         | 
| 41 | 
            +
                        (send {(const nil? :Sketchup) nil?} {:require :load} (str $_))
         | 
| 42 | 
            +
                        (send nil? :require_relative (str $_))
         | 
| 43 | 
            +
                      }
         | 
| 44 | 
            +
                    PATTERN
         | 
| 45 | 
            +
             | 
| 46 | 
            +
                    def investigate(processed_source)
         | 
| 47 | 
            +
                      if root_file?(processed_source)
         | 
| 48 | 
            +
                        filename = processed_source.buffer.name
         | 
| 49 | 
            +
                        @extension_basename = File.basename(filename, '.*')
         | 
| 50 | 
            +
                      end
         | 
| 51 | 
            +
                    end
         | 
| 52 | 
            +
             | 
| 53 | 
            +
                    def extension_file?(filename)
         | 
| 54 | 
            +
                      return false unless filename.include?('/')
         | 
| 55 | 
            +
             | 
| 56 | 
            +
                      first_directory = filename.split('/').first
         | 
| 57 | 
            +
                      @extension_basename.casecmp(first_directory) == 0
         | 
| 58 | 
            +
                    end
         | 
| 59 | 
            +
             | 
| 60 | 
            +
                    def on_send(node)
         | 
| 61 | 
            +
                      return unless @extension_basename
         | 
| 62 | 
            +
             | 
| 63 | 
            +
                      filename = require_filename(node)
         | 
| 64 | 
            +
                      return if filename.nil?
         | 
| 65 | 
            +
                      return unless extension_file?(filename)
         | 
| 66 | 
            +
             | 
| 67 | 
            +
                      add_offense(node)
         | 
| 68 | 
            +
                    end
         | 
| 69 | 
            +
             | 
| 70 | 
            +
                  end
         | 
| 71 | 
            +
                end
         | 
| 72 | 
            +
              end
         | 
| 73 | 
            +
            end
         |