REPLy is a shard that provide a term reader for a REPL (Read Eval Print Loop).
It includes the following features:
- Multiline input
- History
- Pasting of large expressions
- Hook for Syntax highlighting
- Hook for Auto formatting
- Hook for Auto indentation
- Hook for Auto completion (Experimental)
- History Reverse i-search
- Commands with do_methods
- Work on Windows 10
It doesn't support yet:
- Customizable hotkeys
- Unicode characters
NOTE: REPLy was extracted from https://github.com/I3oris/ic, it was first designed to fit exactly the usecase of a crystal interpreter, so don't hesitate to open an issue to make REPLy more generic and suitable for your project if needed.
-
Add the dependency to your
shard.yml
:dependencies: reply: github: I3oris/reply
-
Run
shards install
require "reply"
reader = Reply::Reader.new
reader.read_loop do |expression|
# Eval expression here
puts " => #{expression}"
end
require "reply"
class MyReader < Reply::Reader
def prompt(io : IO, line_number : Int32, color : Bool) : Nil
# Display a custom prompt
end
def highlight(expression : String) : String
# Highlight the expression
end
def continue?(expression : String) : Bool
# Return whether the interface should continue on multiline, depending of the expression
end
def format(expression : String) : String?
# Reformat when expression is submitted
end
def indentation_level(expression_before_cursor : String) : Int32?
# Compute the indentation from the expression
end
def save_in_history?(expression : String) : Bool
# Return whether the expression is saved in history
end
def auto_complete(name_filter : String, expression : String) : {String, Array(String)}
# Return the auto-completion result from expression
end
end
require "reply"
class MyReader < Reply::Reader
include Commands
# Method starting with 'do_' will add a command.
def do_custom_command(arg1 : String, arg2 = nil)
puts "Executing command 'custom_command' with arguments: #{arg1} #{arg2}"
end
end
reader = Reply::Reader.new
reader.run_commands_loop
# Test with:
# $:010>custom_command foo
See examples/command_repl.cr for more details.
Free to pull request!
- Fork it (https://github.com/I3oris/reply/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- I3oris - creator and maintainer