Class: AppMap::Config::Package
Overview
Specifies a logical code package be mapped. This can be a project source folder, a Gem, or a builtin.
Options:
-
pathindicates a relative path to a code folder. -
gemmay indicate a gem name that “owns” the path -
require_namecan be used to make sure that the code is required so that it can be loaded. This is generally used with builtins, or when the path to be required is not automatically required when bundler requires the gem. -
excludecan be used used to exclude sub-paths. Generally not used withgem. -
labelsis used to apply labels to matching code. This is really only useful when the package will be applied to specific functions, via TargetMethods. -
shallowindicates shallow mapping, in which only the entrypoint to a gem is recorded.
Instance Attribute Summary collapse
-
#builtin ⇒ Object
Returns the value of attribute builtin.
-
#exclude ⇒ Object
Returns the value of attribute exclude.
-
#gem ⇒ Object
Returns the value of attribute gem.
- #handler_class ⇒ Object
-
#labels ⇒ Object
Returns the value of attribute labels.
-
#name ⇒ Object
Returns the value of attribute name.
-
#path ⇒ Object
Returns the value of attribute path.
-
#require_name ⇒ Object
Returns the value of attribute require_name.
-
#shallow ⇒ Object
Returns the value of attribute shallow.
Class Method Summary collapse
- .build_from_builtin(path, shallow: false, require_name: nil, exclude: [], labels: []) ⇒ Object
-
.build_from_gem(gem, shallow: true, require_name: nil, exclude: [], labels: [], optional: false, force: false) ⇒ Object
Builds a package for gem.
-
.build_from_path(path, shallow: false, require_name: nil, exclude: [], labels: []) ⇒ Object
Builds a package for a path, such as ‘app/models` in a Rails app.
Instance Method Summary collapse
-
#shallow? ⇒ Boolean
Indicates that only the entry points to a package will be recorded.
-
#subpackage(location, config) ⇒ Object
Clones this package into a sub-package, if needed.
- #to_h ⇒ Object
Instance Attribute Details
#builtin ⇒ Object
Returns the value of attribute builtin
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def builtin @builtin end |
#exclude ⇒ Object
Returns the value of attribute exclude
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def exclude @exclude end |
#gem ⇒ Object
Returns the value of attribute gem
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def gem @gem end |
#handler_class ⇒ Object
35 36 37 38 |
# File 'lib/appmap/config.rb', line 35 def handler_class require 'appmap/handler/function_handler' @handler_class || AppMap::Handler::FunctionHandler end |
#labels ⇒ Object
Returns the value of attribute labels
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def labels @labels end |
#name ⇒ Object
Returns the value of attribute name
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def name @name end |
#path ⇒ Object
Returns the value of attribute path
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def path @path end |
#require_name ⇒ Object
Returns the value of attribute require_name
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def require_name @require_name end |
#shallow ⇒ Object
Returns the value of attribute shallow
28 29 30 |
# File 'lib/appmap/config.rb', line 28 def shallow @shallow end |
Class Method Details
.build_from_builtin(path, shallow: false, require_name: nil, exclude: [], labels: []) ⇒ Object
69 70 71 |
# File 'lib/appmap/config.rb', line 69 def build_from_builtin(path, shallow: false, require_name: nil, exclude: [], labels: []) Package.new(path, path, nil, require_name, exclude, labels, shallow, true) end |
.build_from_gem(gem, shallow: true, require_name: nil, exclude: [], labels: [], optional: false, force: false) ⇒ Object
Builds a package for gem. Generally corresponds to a ‘gem:` entry in appmap.yml. Also used when mapping a builtin.
75 76 77 78 79 80 81 82 83 84 85 86 |
# File 'lib/appmap/config.rb', line 75 def build_from_gem(gem, shallow: true, require_name: nil, exclude: [], labels: [], optional: false, force: false) if !force && %w[method_source].member?(gem) warn "WARNING: #{gem} cannot be AppMapped because it is a dependency of the appmap gem" return end path = gem_path(gem, optional) if path Package.new(gem, path, gem, require_name, exclude, labels, shallow) else AppMap::Util. "#{gem} is not available in the bundle" end end |
.build_from_path(path, shallow: false, require_name: nil, exclude: [], labels: []) ⇒ Object
Builds a package for a path, such as ‘app/models` in a Rails app. Generally corresponds to a `path:` entry in appmap.yml. Also used for mapping specific methods via TargetMethods.
65 66 67 |
# File 'lib/appmap/config.rb', line 65 def build_from_path(path, shallow: false, require_name: nil, exclude: [], labels: []) Package.new(path, path, nil, require_name, exclude, labels, shallow) end |
Instance Method Details
#shallow? ⇒ Boolean
Indicates that only the entry points to a package will be recorded. Once the code has entered a package, subsequent calls within the package will not be recorded unless the code leaves the package and re-enters it.
43 44 45 |
# File 'lib/appmap/config.rb', line 43 def shallow? shallow end |
#subpackage(location, config) ⇒ Object
Clones this package into a sub-package, if needed. For example, suppose the appmap.yml specifies package ‘app/models`. If some code in `app/models/dao/user.rb` is mapped, it will be associated with a sub-package `app/models/dao`.
51 52 53 54 55 56 57 58 59 60 |
# File 'lib/appmap/config.rb', line 51 def subpackage(location, config) return self if gem path = location.split('/')[0...-1].join('/') clone.tap do |pkg| pkg.name = path pkg.path = path config.packages << pkg end end |
#to_h ⇒ Object
100 101 102 103 104 105 106 107 108 109 110 111 |
# File 'lib/appmap/config.rb', line 100 def to_h { name: name, path: path, gem: gem, require_name: require_name, handler_class: handler_class ? handler_class.name : nil, exclude: Util.blank?(exclude) ? nil : exclude, labels: Util.blank?(labels) ? nil : labels, shallow: shallow.nil? ? nil : shallow, }.compact end |