# # This software is Copyright 2005 by Elsevier Inc. You may use it # under the terms of the license at http://perl.plover.com/hop/LICENSE.txt . # ### ### Lexutil.pm ### ## Chapter 9 section 1.1 sub make_charstream { my $fh = shift; return sub { return getc($fh) }; } ## Chapter 9 section 1.1 sub blocks { my $fh = shift; my $blocksize = shift || 8192; sub { return unless read $fh, my($block), $blocksize; return $block; } } sub records { my $blocks = shift; my $terminator = @_ ? shift : quotemeta($/); my @records; my ($buf, $finished) = (""); sub { while (@records == 0 && ! $finished) { if (defined(my $block = $blocks->())) { $buf .= $block; my @newrecs = split /($terminator)/, $buf; while (@newrecs > 2) { push @records, shift(@newrecs).shift(@newrecs); } $buf = join "", @newrecs; } else { @records = $buf; $finished = 1; } } return shift(@records); } } ## Chapter 9 section 1.3 sub tokens { my ($input, $label, $pattern, $maketoken) = @_; my $maketoken ||= sub { [ $_[1], $_[0] ] }; my @tokens; my $buf = ""; # set to undef to when input is exhausted my $split = sub { split /($terminator)/, $_[0] }; sub { while (@tokens == 0 && defined $buf) { my $i = $input->(); if (ref $i) { my ($sep, $tok) = $split->($buf); $tok = $maketoken->($tok, $label) if defined $tok; push @tokens, grep $_ ne "", $sep, $tok, $i; $buf = ""; last; } $buf .= $i if defined $i; my @newtoks = $split->($buf); while (@newtoks > 2 || @newtoks && ! defined $i) { push @tokens, shift(@newtoks); push @tokens, $maketoken->(shift(@newtoks), $label) if @newtoks; } $buf = join "", @newtoks; undef $buf if ! defined $i; @tokens = grep $_ ne "", @tokens; } return shift(@tokens); } } 1;