Perl 5 version 32.0 documentation

getc

  • getc FILEHANDLE

  • getc

    Returns the next character from the input file attached to FILEHANDLE, or the undefined value at end of file or if there was an error (in the latter case $! is set). If FILEHANDLE is omitted, reads from STDIN. This is not particularly efficient. However, it cannot be used by itself to fetch single characters without waiting for the user to hit enter. For that, try something more like:

    1. if ($BSD_STYLE) {
    2. system "stty cbreak </dev/tty >/dev/tty 2>&1";
    3. }
    4. else {
    5. system "stty", '-icanon', 'eol', "\001";
    6. }
    7. my $key = getc(STDIN);
    8. if ($BSD_STYLE) {
    9. system "stty -cbreak </dev/tty >/dev/tty 2>&1";
    10. }
    11. else {
    12. system 'stty', 'icanon', 'eol', '^@'; # ASCII NUL
    13. }
    14. print "\n";

    Determination of whether $BSD_STYLE should be set is left as an exercise to the reader.

    The POSIX::getattr function can do this more portably on systems purporting POSIX compliance. See also the Term::ReadKey module on CPAN.