-
Notifications
You must be signed in to change notification settings - Fork 219
Nano and Less Customization
Both nano
and less
commands can be customized using nanorc like configuration files: jnanorc
and jlessrc
.
ConfigurationPath configPath = new ConfigurationPath(Paths.get("/pub/myApp"), // application-wide settings
Paths.get(System.getProperty("user.home"), ".myApp")); // user-specific settings
Builtins builtins = new Builtins(Paths.get(""), configPath, null);
SystemCompleter systemCompleter = builtins.compileCompleters();
systemCompleter.compile();
LineReader reader = LineReaderBuilder.builder()
.terminal(terminal)
.completer(systemCompleter)
.parser(parser)
.build();
builtins.setLineReader(reader);
while (true) {
try {
String line = reader.readLine(prompt, rightPrompt, (MaskingCallback) null, null);
.....
.....
.....
ParsedLine pl = reader.getParser().parse(line, 0);
String[] argv = pl.words().subList(1, pl.words().size()).toArray(new String[0]);
String cmd = Parser.getCommand(pl.word());
if (builtins.hasCommand(cmd)) {
builtins.execute(cmd, argv, System.in, System.out, System.err);
}
.....
.....
.....
}
catch (HelpException e) {
HelpException.highlight(e.getMessage(), HelpException.defaultStyle()).print(terminal);
}
catch (UserInterruptException e) {
// Ignore
}
catch (EndOfFileException e) {
return;
}
catch (Exception e) {
System.out.println(e.getMessage());
}
}
The jnanorc
/jlessrc
file contains the default settings for nano
/less
. During startup, the command try first read the user-specific settings and then its application-wide settings. Application-wide settings are read only if user-specific settings does not exists.
The configuration file accepts a series of set and unset commands, which can be used to configure nano
/less
on startup without using the command line options.
In addition configuration file might have 'include syntaxfile' commands to read self-contained color syntaxes from syntaxfile. Syntax file parameter can have '*' and '?' wildcards in its file name.
In a case that neither of application-wide nor user-specific settings are not found at command startup then syntaxfiles are searched from a standard installation location: /usr/share/nano
.
Example: Configuration file jnanorc
. Note that historylog is saved in user-specific directory and the file can be shared between nano
and less
applications.
include /usr/share/nano/*.nanorc
set tabstospaces
set autoindent
set tempfile
set historylog search.log
JLine nanorc SyntaxHighlighter works with standard nanorc syntaxfiles.
JLine supported keywords: the syntax, color, and icolor are used to define syntax highlighting rules for different text patterns. Other nanorc keywords are quietly ignored.
Not supported.