2011-05-28 04:43:32 -04:00
|
|
|
require 'ostruct'
|
|
|
|
|
|
|
|
class Pry
|
|
|
|
class Config < OpenStruct
|
|
|
|
|
|
|
|
# Get/Set the object to use for input by default by all Pry instances.
|
|
|
|
# @return [#readline] The object to use for input by default by all
|
|
|
|
# Pry instances.
|
|
|
|
attr_accessor :input
|
|
|
|
|
|
|
|
# Get/Set the object to use for output by default by all Pry instances.
|
|
|
|
# @return [#puts] The object to use for output by default by all
|
|
|
|
# Pry instances.
|
|
|
|
attr_accessor :output
|
|
|
|
|
|
|
|
# Get/Set the object to use for commands by default by all Pry instances.
|
|
|
|
# @return [Pry::CommandBase] The object to use for commands by default by all
|
|
|
|
# Pry instances.
|
|
|
|
attr_accessor :commands
|
|
|
|
|
|
|
|
# Get/Set the Proc to use for printing by default by all Pry
|
|
|
|
# instances.
|
|
|
|
# This is the 'print' component of the REPL.
|
|
|
|
# @return [Proc] The Proc to use for printing by default by all
|
|
|
|
# Pry instances.
|
|
|
|
attr_accessor :print
|
|
|
|
|
|
|
|
# @return [Proc] The Proc to use for printing exceptions by default by all
|
|
|
|
# Pry instances.
|
|
|
|
attr_accessor :exception_handler
|
|
|
|
|
2011-09-17 21:45:46 -04:00
|
|
|
# @return [Array] The classes of exception that will not be caught by Pry.
|
|
|
|
attr_accessor :exception_whitelist
|
|
|
|
|
2011-10-16 02:49:33 -04:00
|
|
|
# @return [Fixnum] The number of lines of context to show before and after
|
2012-01-15 01:30:32 -05:00
|
|
|
# exceptions, etc.
|
|
|
|
attr_accessor :default_window_size
|
2011-10-16 02:49:33 -04:00
|
|
|
|
2011-05-28 04:43:32 -04:00
|
|
|
# Get/Set the Hash that defines Pry hooks used by default by all Pry
|
|
|
|
# instances.
|
|
|
|
# @return [Hash] The hooks used by default by all Pry instances.
|
|
|
|
# @example
|
|
|
|
# Pry.hooks :before_session => proc { puts "hello" },
|
|
|
|
# :after_session => proc { puts "goodbye" }
|
2012-01-23 07:10:51 -05:00
|
|
|
attr_reader :hooks
|
|
|
|
|
|
|
|
# FIXME:
|
|
|
|
# This is a hack to alert people of the new API.
|
|
|
|
# @param [Pry::Hooks] v Only accept `Pry::Hooks` now!
|
|
|
|
def hooks=(v)
|
|
|
|
if v.is_a?(Hash)
|
2012-01-24 03:44:21 -05:00
|
|
|
warn "Hash-based hooks are now deprecated! Use a `Pry::Hooks` object instead! http://rubydoc.info/github/pry/pry/master/Pry/Hooks"
|
|
|
|
@hooks = Pry::Hooks.from_hash(v)
|
|
|
|
else
|
|
|
|
@hooks = v
|
2012-01-23 07:10:51 -05:00
|
|
|
end
|
|
|
|
end
|
2011-05-28 04:43:32 -04:00
|
|
|
|
2011-09-15 05:08:05 -04:00
|
|
|
# Get/Set the stack of input objects that a Pry instance switches
|
|
|
|
# to when its current input object encounters EOF.
|
|
|
|
# @return [Array] The array of input objects.
|
|
|
|
# @example
|
|
|
|
# Pry.config.input_stack = [StringIO.new("puts 'hello world'\nexit")]
|
|
|
|
attr_accessor :input_stack
|
|
|
|
|
2011-05-28 04:43:32 -04:00
|
|
|
# Get the array of Procs to be used for the prompts by default by
|
|
|
|
# all Pry instances.
|
|
|
|
# @return [Array<Proc>] The array of Procs to be used for the
|
|
|
|
# prompts by default by all Pry instances.
|
|
|
|
attr_accessor :prompt
|
|
|
|
|
|
|
|
# The default editor to use. Defaults to $EDITOR or nano if
|
|
|
|
# $EDITOR is not defined.
|
|
|
|
# If `editor` is a String then that string is used as the shell
|
|
|
|
# command to invoke the editor. If `editor` is callable (e.g a
|
|
|
|
# Proc) then `file` and `line` are passed in as parameters and the
|
|
|
|
# return value of that callable invocation is used as the exact
|
|
|
|
# shell command to invoke the editor.
|
|
|
|
# @example String
|
2011-08-29 11:00:13 -04:00
|
|
|
# Pry.config.editor = "emacsclient"
|
2011-05-28 04:43:32 -04:00
|
|
|
# @example Callable
|
2011-08-29 11:00:13 -04:00
|
|
|
# Pry.config.editor = proc { |file, line| "emacsclient #{file} +#{line}" }
|
2011-05-28 04:43:32 -04:00
|
|
|
# @return [String, #call]
|
|
|
|
attr_accessor :editor
|
|
|
|
|
2011-07-26 03:34:54 -04:00
|
|
|
# A string that must precede all Pry commands (e.g., if command_prefix is
|
|
|
|
# set to "%", the "cd" command must be invoked as "%cd").
|
|
|
|
# @return [String]
|
|
|
|
attr_accessor :command_prefix
|
|
|
|
|
2011-05-28 04:43:32 -04:00
|
|
|
# @return [Boolean] Toggle Pry color on and off.
|
|
|
|
attr_accessor :color
|
|
|
|
|
|
|
|
# @return [Boolean] Toggle paging on and off.
|
|
|
|
attr_accessor :pager
|
|
|
|
|
|
|
|
# Determines whether the rc file (~/.pryrc) should be loaded.
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :should_load_rc
|
2011-05-28 07:58:27 -04:00
|
|
|
|
|
|
|
# Determines whether plugins should be loaded.
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :should_load_plugins
|
2011-05-29 11:37:12 -04:00
|
|
|
|
2011-07-24 23:04:44 -04:00
|
|
|
# Determines whether to load files specified with the -r flag.
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :should_load_requires
|
|
|
|
|
2011-07-25 01:57:40 -04:00
|
|
|
# Determines whether to disable edit-method's auto-reloading behavior.
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :disable_auto_reload
|
|
|
|
|
2011-11-24 00:53:55 -05:00
|
|
|
# Determines whether Pry should trap SIGINT and cause it to raise an
|
2011-11-22 12:06:27 -05:00
|
|
|
# Interrupt exception. This is only useful on jruby, MRI does this
|
|
|
|
# for us.
|
|
|
|
# @return [Boolean]
|
|
|
|
attr_accessor :should_trap_interrupts
|
|
|
|
|
2011-05-29 11:37:12 -04:00
|
|
|
# Config option for history.
|
2011-12-11 03:16:09 -05:00
|
|
|
# sub-options include history.file, history.load, and history.save
|
|
|
|
# history.file is the file to save/load history to, e.g
|
2011-05-29 11:37:12 -04:00
|
|
|
# Pry.config.history.file = "~/.pry_history".
|
2011-12-11 03:16:09 -05:00
|
|
|
# history.should_load is a boolean that determines whether history will be
|
|
|
|
# loaded from history.file at session start.
|
|
|
|
# history.should_save is a boolean that determines whether history will be
|
|
|
|
# saved to history.file at session end.
|
2011-05-29 11:37:12 -04:00
|
|
|
# @return [OpenStruct]
|
|
|
|
attr_accessor :history
|
2011-06-02 05:41:41 -04:00
|
|
|
|
|
|
|
# Config option for plugins:
|
|
|
|
# sub-options include:
|
|
|
|
# `plugins.enabled` (Boolean) to toggle the loading of plugins on and off wholesale. (defaults to true)
|
|
|
|
# `plugins.strict_loading` (Boolean) which toggles whether referring to a non-existent plugin should raise an exception (defaults to `false`)
|
|
|
|
# @return [OpenStruct]
|
|
|
|
attr_accessor :plugins
|
2011-06-05 12:37:54 -04:00
|
|
|
|
2011-07-24 23:04:44 -04:00
|
|
|
# @return [Array<String>] Ruby files to be required after loading any plugins.
|
|
|
|
attr_accessor :requires
|
|
|
|
|
2011-06-11 06:44:30 -04:00
|
|
|
# @return [Integer] Amount of results that will be stored into out
|
2011-06-05 12:37:54 -04:00
|
|
|
attr_accessor :memory_size
|
2011-08-29 10:21:51 -04:00
|
|
|
|
|
|
|
# @return [Proc] The proc that manages ^D presses in the REPL.
|
|
|
|
# The proc is passed the current eval_string and the current pry instance.
|
|
|
|
attr_accessor :control_d_handler
|
2011-09-17 02:35:17 -04:00
|
|
|
|
|
|
|
# @return [Proc] The proc that runs system commands
|
2011-09-17 08:42:29 -04:00
|
|
|
# The proc is passed the pry output object, the command string
|
|
|
|
# to eval, and a reference to the pry instance
|
2011-09-17 02:35:17 -04:00
|
|
|
attr_accessor :system
|
2011-10-05 13:04:44 -04:00
|
|
|
|
2011-10-08 07:40:55 -04:00
|
|
|
# @return [Boolean] Whether or not code should be indented
|
2011-10-05 13:04:44 -04:00
|
|
|
# using Pry::Indent.
|
2011-10-08 07:40:55 -04:00
|
|
|
attr_accessor :auto_indent
|
2011-10-28 02:57:01 -04:00
|
|
|
|
|
|
|
# @return [Boolean] Whether or not indentation should be corrected
|
|
|
|
# after hitting enter. This feature is not supported by all terminals.
|
|
|
|
attr_accessor :correct_indent
|
2011-11-16 22:00:46 -05:00
|
|
|
|
|
|
|
# @return [Boolean] Whether or not a warning will be displayed when
|
|
|
|
# a command name collides with a method/local in the current context.
|
|
|
|
attr_accessor :collision_warning
|
2011-12-11 03:16:09 -05:00
|
|
|
|
|
|
|
|
|
|
|
# Config option for gist.
|
|
|
|
# sub-options include `gist.inspecter`,
|
|
|
|
# `gist.inspecter` is a callable that defines how the expression output
|
|
|
|
# will be displayed when using the `gist -i` command.
|
|
|
|
# @example Pretty inspect output
|
|
|
|
# Pry.config.gist.inspecter = proc { |v| v.pretty_inspect }
|
|
|
|
# @example Regular inspect
|
|
|
|
# Pry.config.gist.inspecter = proc &:inspect
|
|
|
|
# @return [OpenStruct]
|
|
|
|
attr_accessor :gist
|
2011-05-28 04:43:32 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|