Class: AppMap::Config::Package
- Inherits:
-
Struct
- Object
- Struct
- AppMap::Config::Package
- Defined in:
- lib/appmap/config.rb
Overview
Specifies a code path
to be mapped. Options:
-
gem
may indicate a gem name that “owns” the path -
package_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
-
#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.
-
#package_name ⇒ Object
Returns the value of attribute package_name.
-
#path ⇒ Object
Returns the value of attribute path.
-
#shallow ⇒ Object
Returns the value of attribute shallow.
Class Method Summary collapse
-
.build_from_gem(gem, shallow: true, package_name: nil, exclude: [], labels: [], optional: false, force: false) ⇒ Object
Builds a package for gem.
-
.build_from_path(path, shallow: false, package_name: nil, exclude: [], labels: []) ⇒ Object
Builds a package for a path, such as ‘app/models` in a Rails app.
Instance Method Summary collapse
- #name ⇒ Object
-
#shallow? ⇒ Boolean
Indicates that only the entry points to a package will be recorded.
- #to_h ⇒ Object
Instance Attribute Details
#exclude ⇒ Object
Returns the value of attribute exclude
19 20 21 |
# File 'lib/appmap/config.rb', line 19 def exclude @exclude end |
#gem ⇒ Object
Returns the value of attribute gem
19 20 21 |
# File 'lib/appmap/config.rb', line 19 def gem @gem end |
#handler_class ⇒ Object
26 27 28 29 |
# File 'lib/appmap/config.rb', line 26 def handler_class require 'appmap/handler/function' @handler_class || AppMap::Handler::Function end |
#labels ⇒ Object
Returns the value of attribute labels
19 20 21 |
# File 'lib/appmap/config.rb', line 19 def labels @labels end |
#package_name ⇒ Object
Returns the value of attribute package_name
19 20 21 |
# File 'lib/appmap/config.rb', line 19 def package_name @package_name end |
#path ⇒ Object
Returns the value of attribute path
19 20 21 |
# File 'lib/appmap/config.rb', line 19 def path @path end |
#shallow ⇒ Object
Returns the value of attribute shallow
19 20 21 |
# File 'lib/appmap/config.rb', line 19 def shallow @shallow end |
Class Method Details
.build_from_gem(gem, shallow: true, package_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.
47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/appmap/config.rb', line 47 def build_from_gem(gem, shallow: true, package_name: nil, exclude: [], labels: [], optional: false, force: false) if !force && %w[method_source activesupport].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(path, gem, package_name, exclude, labels, shallow) else warn "#{gem} is not available in the bundle" if AppMap::Hook::LOG end end |
.build_from_path(path, shallow: false, package_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.
41 42 43 |
# File 'lib/appmap/config.rb', line 41 def build_from_path(path, shallow: false, package_name: nil, exclude: [], labels: []) Package.new(path, nil, package_name, exclude, labels, shallow) end |
Instance Method Details
#name ⇒ Object
72 73 74 |
# File 'lib/appmap/config.rb', line 72 def name gem || path end |
#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.
34 35 36 |
# File 'lib/appmap/config.rb', line 34 def shallow? shallow end |
#to_h ⇒ Object
76 77 78 79 80 81 82 83 84 85 86 |
# File 'lib/appmap/config.rb', line 76 def to_h { path: path, package_name: package_name, gem: gem, handler_class: handler_class.name, exclude: exclude.blank? ? nil : exclude, labels: labels.blank? ? nil : labels, shallow: shallow }.compact end |