Class: Toys::Context

Inherits:
Object
  • Object
show all
Defined in:
core-docs/toys/context.rb

Overview

Defined in the toys-core gem

This is the base class for tool execution. It represents self when your tool's methods (such as run) are called, and it defines the methods that can be called by your tool (such as #logger and #exit.)

This class also manages the "data" available to your tool when it runs. This data is a hash of key-value pairs. It consists of values set by flags and arguments defined by the tool, plus some "well-known" values such as the logger and verbosity level.

You can obtain a value from the data using the #get method. Additionally, convenience methods are provided for many of the well-known keys. For instance, you can call #verbosity to obtain the value for the key Key::VERBOSITY. Finally, flags and positional arguments that store their data here will also typically generate convenience methods. For example, an argument with key :abc will add a method called abc that you can call to get the value.

By convention, flags and arguments defined by your tool should use strings or symbols as keys. Keys that are not strings or symbols should either be well-known keys such as Key::VERBOSITY, or should be used for internal private information needed by middleware and mixins. The module Key defines a number of well-known keys as constants.

Direct Known Subclasses

Tool

Defined Under Namespace

Modules: Key

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.exit(code = 0) ⇒ void

This method returns an undefined value.

Exit immediately with the given status code. This class method can be called if the instance method is or could be replaced by the tool.

Parameters:

  • code (Integer) (defaults to: 0)

    The status code, which should be 0 for no error, or nonzero for an error condition. Default is 0.



369
370
371
# File 'core-docs/toys/context.rb', line 369

def self.exit(code = 0)
  # Source available in the toys-core gem
end

Instance Method Details

#[](key) ⇒ Object Also known as: get, __get

Fetch an option or other piece of data by key.

If the get method is overridden by the tool, you can still access it using the name __get or the [] operator.

Parameters:

  • key (Symbol)

Returns:

  • (Object)


272
273
274
# File 'core-docs/toys/context.rb', line 272

def [](key)
  # Source available in the toys-core gem
end

#[]=(key, value) ⇒ Object

Set an option or other piece of context data by key.

Parameters:

  • key (Symbol)
  • value (Object)


284
285
286
# File 'core-docs/toys/context.rb', line 284

def []=(key, value)
  # Source available in the toys-core gem
end

#__exitvoid

This method returns an undefined value.

Exit immediately with the given status code.

If the exit method is overridden by the tool, you can still access it using the name __exit or by calling exit. Source available in the toys-core gem

Parameters:

  • code (Integer)

    The status code, which should be 0 for no error, or nonzero for an error condition. Default is 0.



359
360
361
# File 'core-docs/toys/context.rb', line 359

def exit(code = 0)
  # Source available in the toys-core gem
end

#argsArray<String> Also known as: __args

The raw arguments passed to the tool, as an array of strings. This does not include the tool name itself.

This is a convenience getter for Toys::Context::Key::ARGS.

If the args method is overridden by the tool, you can still access it using the name __args.

Returns:

  • (Array<String>)


149
150
151
# File 'core-docs/toys/context.rb', line 149

def args
  # Source available in the toys-core gem
end

#cliToys::CLI Also known as: __cli

The currently running CLI.

This is a convenience getter for Toys::Context::Key::CLI.

If the cli method is overridden by the tool, you can still access it using the name __cli.

Returns:



164
165
166
# File 'core-docs/toys/context.rb', line 164

def cli
  # Source available in the toys-core gem
end

#context_directoryString? Also known as: __context_directory

Return the context directory for this tool. Generally, this defaults to the directory containing the toys config directory structure being read, but it may be changed by setting a different context directory for the tool.

This is a convenience getter for Toys::Context::Key::CONTEXT_DIRECTORY.

If the context_directory method is overridden by the tool, you can still access it using the name __context_directory.

Returns:

  • (String)

    Context directory path

  • (nil)

    if there is no context.



183
184
185
# File 'core-docs/toys/context.rb', line 183

def context_directory
  # Source available in the toys-core gem
end

#exit(code = 0) ⇒ void

This method returns an undefined value.

Exit immediately with the given status code.

If the exit method is overridden by the tool, you can still access it using the name __exit or by calling exit.

Parameters:

  • code (Integer) (defaults to: 0)

    The status code, which should be 0 for no error, or nonzero for an error condition. Default is 0.



356
357
358
# File 'core-docs/toys/context.rb', line 356

def exit(code = 0)
  # Source available in the toys-core gem
end

#find_data(path, type: nil) ⇒ String? Also known as: __find_data

Find the given data file or directory in this tool's search path.

If the find_data method is overridden by the tool, you can still access it using the name __find_data.

Parameters:

  • path (String)

    The path to find

  • type (nil, :file, :directory) (defaults to: nil)

    Type of file system object to find, or nil to return any type.

Returns:

  • (String)

    Absolute path of the result

  • (nil)

    if the data was not found.



341
342
343
# File 'core-docs/toys/context.rb', line 341

def find_data(path, type: nil)
  # Source available in the toys-core gem
end

#loggerLogger Also known as: __logger

The logger for this execution.

This is a convenience getter for Toys::Context::Key::LOGGER.

If the logger method is overridden by the tool, you can still access it using the name __logger.

Returns:

  • (Logger)


198
199
200
# File 'core-docs/toys/context.rb', line 198

def logger
  # Source available in the toys-core gem
end

#optionsHash Also known as: __options

The subset of the context that uses string or symbol keys. By convention, this includes keys that are set by tool flags and arguments, but does not include well-known context values such as verbosity or private context values used by middleware or mixins.

If the options method is overridden by the tool, you can still access it using the name __options.

Returns:

  • (Hash)


323
324
325
# File 'core-docs/toys/context.rb', line 323

def options
  # Source available in the toys-core gem
end

#set(key, value) ⇒ self #set(hash) ⇒ self Also known as: __set

Set one or more options or other context data by key.

If the set method is overridden by the tool, you can still access it using the name __set.

Overloads:

  • #set(key, value) ⇒ self

    Set an option or other piece of context data by key.

    Parameters:

    • key (Symbol)
    • value (Object)

    Returns:

    • (self)
  • #set(hash) ⇒ self

    Set multiple content data keys and values

    Parameters:

    • hash (Hash)

      The keys and values to set

    Returns:

    • (self)

Returns:

  • (self)


307
308
309
# File 'core-docs/toys/context.rb', line 307

def set(key, value = nil)
  # Source available in the toys-core gem
end

#tool_nameArray<String> Also known as: __tool_name

The full name of the tool being executed, as an array of strings.

This is a convenience getter for Toys::Context::Key::TOOL_NAME.

If the tool_name method is overridden by the tool, you can still access it using the name __tool_name.

Returns:

  • (Array<String>)


213
214
215
# File 'core-docs/toys/context.rb', line 213

def tool_name
  # Source available in the toys-core gem
end

#tool_sourceToys::SourceInfo Also known as: __tool_source

The source of the tool being executed.

This is a convenience getter for Toys::Context::Key::TOOL_SOURCE.

If the tool_source method is overridden by the tool, you can still access it using the name __tool_source.

Returns:



228
229
230
# File 'core-docs/toys/context.rb', line 228

def tool_source
  # Source available in the toys-core gem
end

#usage_errorsArray<Toys::ArgParser::UsageError> Also known as: __usage_errors

The (possibly empty) array of errors detected during argument parsing.

This is a convenience getter for Toys::Context::Key::USAGE_ERRORS.

If the usage_errors method is overridden by the tool, you can still access it using the name __usage_errors.

Returns:



243
244
245
# File 'core-docs/toys/context.rb', line 243

def usage_errors
  # Source available in the toys-core gem
end

#verbosityInteger Also known as: __verbosity

The current verbosity setting as an integer.

This is a convenience getter for Toys::Context::Key::VERBOSITY.

If the verbosity method is overridden by the tool, you can still access it using the name __verbosity.

Returns:

  • (Integer)


258
259
260
# File 'core-docs/toys/context.rb', line 258

def verbosity
  # Source available in the toys-core gem
end