NAME

Gherkin - a parser and compiler for the Gherkin language

SYNOPSIS

use Gherkin;


sub sink {
   my $msg = shift;
   use Data::Dumper;

   print Dumper($msg);
}

my $id = 0;
my gen { $id++ };

Gherkin->from_paths( [ 'your.feature' ],
                     \&gen, \&sink );

DESCRIPTION

This is the Perl implementation of the Gherkin language parser and compiler as developed by the Cucumber project (https://github.com/cucumber).

Gherkin is a simple language, with a formal specification. The parser in this implementation is generated off the official language grammar.

NOTE Versions 21 and lower of this library used to send hashes to the $sink, whereas the current version sends Cucumber::Messages.

OVERVIEW

The Cucumber toolkit consists of a set of tools which form a pipe line: each consumes and produces protobuf messages (See https://github.com/cucumber/common/tree/main/messages). Messages use ndjson formatting.

The start of the pipeline is the Gherkin language parser. Gherkin implements that functionality in Perl. It's the first building block in the pipe line and intended to be used to build further tooling upon.

CLASS METHODS

new(%options)

Constructor.

Accepted %options are:

include_source

Boolean. Indicates whether the text of the source document is to be included in the output stream using a Source message.

include_ast

Boolean. Indicates whether the parsed source (AST or Abstract Syntax Tree) is to be included in the output stream using a GherkinDocument message.

include_pickles

Boolean. Indicates whether the expanded-and-interpolated (executable) scenarios are to be included in the output stream using Pickle messages.

from_paths($paths, $id_gen, $sink, %options)

Constructs a Gherkin instance and calls its from_source method for each of the paths in the arrayref $paths.

$id_gen is a coderef to a function generating unique IDs which messages in the output stream can use to refer to other content in the stream. $sink is a coderef to a function taking the next message in the stream as its argument. Each message is encapsulated in an Envelope message.

%options are passed to new.

METHODS

from_source($source_msg, $id_gen, $sink)

Generates a stream of AST and pickle messages sent to $sink. The source text in the message's data attribute is assumed to be utf8 or UTF-8 encoded. The document header is scanned for an # encoding: ... instruction. If one is found, the text is recoded from that encoding into Perl's internal Unicode representation.

The Source message sent to the sink is wrapped in an envelope which has a to_json method to create UTF-8 encoded NDJSON output.

$id_gen and $sink are as documented in from_paths.

SEE ALSO

LICENSE

Please see the included LICENSE.txt for the canonical version. In summary:

The MIT License (MIT)

Copyright (c) 2020-2021 Erik Huelsmann
Copyright (c) 2016      Peter Sergeant

This work is a derivative of work that is: Copyright (c) 2014-2016 Cucumber Ltd, Gaspar Nagy