Extend IRB

From v1.13.0, IRB provides official APIs to extend its functionality. This feature allows libraries to customize and enhance their users’ IRB sessions by adding new commands and helper methods tailored for the libraries.

Helper Methods vs. Commands

If you don’t know what to pick, go with commands first. Commands are generally safer as they can handle a wider variety of inputs and use cases.

Commands

Commands are designed to complete certain tasks or display information for the user, similar to shell commands. Therefore, they are designed to accept a variety of inputs, including those that are not valid Ruby code, such as my_cmd Foo#bar or my_cmd --flag foo.

Example

require "irb/command"

class Greet < IRB::Command::Base
  category "Greeting"
  description "Greets the user"
  help_message <<~HELP
    Greets the user with the given name.

    Usage: greet <name>
  HELP

  # Any input after the command name will be passed as a single string.
  # If nothing is added after the command, an empty string will be passed.
  def execute(arg)
    puts "Hello! #{arg}"
  end
end

IRB::Command.register(:greet, Greet)

As long as the above code is loaded before the IRB session is started, such as in a loaded library or a user’s .irbrc file, greet will be accessible to the user.

irb(main):001> greet
Hello!
=> nil
irb(main):002> greet Stan
Hello! Stan
=> nil

And because the Greet command introduces a new category, Greeting, a new help message category will be created:

Help
  help           List all available commands. Use `help <command>` to get information about a specific command.

Greeting
  greet          Greets the user

IRB
  context        Displays current configuration.
  ...

If the optional help_message attribute is specified, help greet will also display it:

irb(main):001> help greet
Greets the user with the given name.

Usage: greet <name>

Helper methods

Helper methods are designed to be used as Ruby methods, such as my_helper(arg, kwarg: val).foo.

The main use case of helper methods is to provide shortcuts for users, providing quick and easy access to frequently used operations or components within the IRB session. For example, a helper method might simplify the process of fetching and displaying specific configuration settings or data structures that would otherwise require multiple steps to access.

Example

# This only loads the minimum components required to define and register a helper method.
# It does not load the entire IRB, nor does it initialize it.
require "irb/helper_method"

class MyHelper < IRB::HelperMethod::Base
  description "This is a test helper"

  def execute(arg, kwarg:)
    "arg: #{arg}, kwarg: #{kwarg}"
  end
end

IRB::HelperMethod.register(:my_helper, MyHelper)

As long as the above code is loaded before the IRB session is started, such as in a loaded library or a user’s .irbrc file, my_helper will be accessible to the user.

irb(main):001> my_helper("foo", kwarg: "bar").upcase
=> "ARG: FOO, KWARG: BAR"

The registered helper methods will also be listed in the help message’s Helper methods section:

Helper methods
  conf           Returns the current context.
  my_helper      This is a test helper