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:
-
path
indicates a relative path to a code folder. -
gem
may indicate a gem name that “owns” the path -
require_name
can 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. -
exclude
can be used used to exclude sub-paths. Generally not used withgem
. -
labels
is used to apply labels to matching code. This is really only useful when the package will be applied to specific functions, via TargetMethods. -
shallow
indicates 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
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def builtin @builtin end |
#exclude ⇒ Object
Returns the value of attribute exclude
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def exclude @exclude end |
#gem ⇒ Object
Returns the value of attribute gem
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def gem @gem end |
#handler_class ⇒ Object
34 35 36 37 |
# File 'lib/appmap/config.rb', line 34 def handler_class require 'appmap/handler/function_handler' @handler_class || AppMap::Handler::FunctionHandler end |
#labels ⇒ Object
Returns the value of attribute labels
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def labels @labels end |
#name ⇒ Object
Returns the value of attribute name
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def name @name end |
#path ⇒ Object
Returns the value of attribute path
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def path @path end |
#require_name ⇒ Object
Returns the value of attribute require_name
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def require_name @require_name end |
#shallow ⇒ Object
Returns the value of attribute shallow
27 28 29 |
# File 'lib/appmap/config.rb', line 27 def shallow @shallow end |
Class Method Details
.build_from_builtin(path, shallow: false, require_name: nil, exclude: [], labels: []) ⇒ Object
68 69 70 |
# File 'lib/appmap/config.rb', line 68 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.
74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/appmap/config.rb', line 74 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.
64 65 66 |
# File 'lib/appmap/config.rb', line 64 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.
42 43 44 |
# File 'lib/appmap/config.rb', line 42 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`.
50 51 52 53 54 55 56 57 58 59 |
# File 'lib/appmap/config.rb', line 50 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
99 100 101 102 103 104 105 106 107 108 109 110 |
# File 'lib/appmap/config.rb', line 99 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 |