NAME
    Keyword::API

VERSION
    version 0.0001

SYNOPSIS
        use Keyword::API;

        sub import { 
            my ($class, %params) = @_; 

            my $name = %params && $params{-as} ? $params{-as} : "method";

            $class->install_keyword($name);
        }

        sub unimport { uninstall_keyword() }

        sub parser {
            lex_read_space(0);
            my $sub_name = lex_unstuff_token();
            my $sig = lex_unstuff_to('{');
            my ($roll) = $sig =~ /\((.+)\)\s*{/;
            lex_stuff("sub $sub_name {my (\$self, $roll) = \@_;");
        };

DESCRIPTION
    This is an experimental module to provide a pure perl interface for the
    keywords API added to the perl core in 5.12.

  EXPORT
        install_keyword
        uninstall_keyword 
        lex_read_space
        lex_read
        lex_read_token
        lex_stuff
        lex_unstuff
        lex_unstuff_to
        lex_unstuff_token

NAME
    Keyword::API - Perl interface to the keyword API

FUNCTIONS
  install_keyword
    class method, provide name of your keyword e.g 'method'

  uninstall_keyword
    remove the keyword hook, no arguments.

  lex_read_space
        lex_read_space(0);

    reads white space and comments in the text currently being lexed.

  lex_read
        my $str = lex_read($n);

    Consumes $n bytes of text from the lexer buffer.

  lex_read_token
        my $toke = lex_read_token();

    Consumes any text in the lexer until white space is reached.

  lex_stuff
        lex_stuff("sub foo { ...");

    Injects a string into the lexer buffer.

  lex_unstuff
        my $discarded_text = lex_unstuff($n);

    Discard $n bytes from the lexers buffer

  lex_unstuff_to
        my $discarded_text = lex_unstuff_to("{");

    Discard everything in the buffer until the character is met.

  lex_unstuff_token
        my $discarded_text = lext_unstuff_token();

    Discard everything in the buffer until white space is met

SEE ALSO
    perlapi Devel::Declare Filter::Simple

AUTHOR
    Robin Edwards <robin.ge@gmail.com>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2011 by Robin Edwards.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.