# `Term::ReadLine::Gnu` --- The GNU Readline Library Wrapper Module Copyright (c) 1996-2022 Hiroo Hayashi. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. ## Description `Term::ReadLine::Gnu` (TRG) is an implementation of the interface to [the GNU Readline Library](https://tiswww.case.edu/php/chet/readline/rltop.html). This module gives you input line editing facility, input history management facility, word completion facility, etc. It uses the real GNU Readline Library and has the interface with the almost all variables and functions which are documented in [the GNU Readline/History Library Manual](https://tiswww.case.edu/php/chet/readline/rltop.html). So you can program your custom editing function, your custom completion function, and so on with Perl. TRG may be useful for a C programmer to prototype a program which uses the GNU Readline Library. TRG is upper compatible with `Term::ReadLine` included in Perl distribution. `Term::ReadLine` uses TRG automatically when TRG is available. You can enjoy full line-editing feature with Perl debugger which use `Term::ReadLine` without any additional settings. Ilya Zakharevich has been distributing his implementation, `Term::ReadLine::Perl`, which bases on Jeffrey Friedl's `readline.pl`. His module works very well, and is easy to install because it is written by only Perl. I tried to make my module compatible with his. He gave me a lot of valuable advises. Unfortunately `readline.pl` simulated old GNU Readline library before TRG was born. For example, it was not 8 bit clean and it warns to the variables in `~/.inputrc` which it did not know yet. We Japanese usually use 8 bit characters, so this was a bad feature for me. I could make a patch for these problems but I had interest with C interface facility and dynamic loading facility of Perl, so I thought it was a good chance for me to study them. Then I made this module instead of fixing his module. ## Prerequisites You must have Perl 5.8 or later. If you have to use old Perl for some reason, use `Term::ReadLine::Gnu` 1.09. (I recommend you to use newer Perl.) You must have GNU Readline Library Version 2.1 or later. See [INSTALL](./INSTALL.md) for more detail. A report said GNU Readline Library might not work with perl with `sfio`, which was deprecated by Perl 5.20. ## How to build/install See [INSTALL](./INSTALL.md). ## Bugs There may be some bugs in both programs and documents. Comments and bug reports are very welcome. Send me a E-Mail or open a ticket on [the bug tracker on GitHub](https://github.com/hirooih/perl-trg/issues) ## Author Hiroo Hayashi <hiroo.hayashi@computer.org> ## Links - [Term::ReadLine::Gnu](https://metacpan.org/dist/Term-ReadLine-Gnu) - [Term::ReadLine::Gnu Users' Manual](https://metacpan.org/pod/Term::ReadLine::Gnu) - [Term::ReadLine::Gnu GitHub Repository](https://github.com/hirooih/perl-trg) - [The GNU Readline Library Manual](https://tiswww.cwru.edu/php/chet/readline/readline.html) - [The GNU History Library Manual](https://tiswww.cwru.edu/php/chet/readline/history.html) - [Term::ReadLine](https://metacpan.org/dist/Term-ReadLine) ## Revision History See [Changes](./Changes).