= 3.0.1 / 2014-03-14 * Fixed bad 3.0.0 release. = 3.0.0 / 2014-03-14 * Moved Object#grammar to citrus/core_ext.rb. Citrus no longer installs core extensions by default. Use "require 'citrus/core_ext.rb'" instead of "require 'citrus'" to keep the previous behavior. * Removed Match#method_missing, added #capture(name) and #captures(name) Match#method_missing is unsafe as illustrated in Github issue #41. In particular, it makes composing a grammar with aribitrary gems unsafe (e.g. when the latter make core extensions), leads to unexpected results with labels match existing Kernel methods (e.g. `p`), and prevents Match from getting new methods in a backward compatible way. This commit therefore removes it. In Citrus 2.x, method_missing allowed rule productions to denote captured matches by label name: rule pair (foo ':' bar) { [foo.value, bar.value] } end Also, it allowed invoking String operators on the Match's text: rule int [0-9]+ { to_i } end Those two scenarios no longer work out of the box in Citrus 3.0. You must use capture(label) for the former, and to_str for the latter: rule pair (foo ':' bar) { [capture(:foo).value, capture(:bar).value] } end rule int [0-9]+ { to_str.to_i } end Match#captures now accepts an optional label name as first argument and returns the corresponding array of matches for that label (useful in case the label belongs to a repetition). = 2.5.0 / 2014-03-13 * Inputs may be generated from many different sources, including Pathname and IO objects (thanks blambeau). * Matches keep track of their offset in the original source (thanks blambeau). * Citrus.load no longer raises Citrus::LoadError for files that can't be found or are not readable. Users must rescue Errno::ENOENT instead, for example. * Removed a few ruby warnings (thanks tbuehlmann) = 2.4.1 / 2011-11-04 * Fixed a bug that prevented rule names from starting with "super". * Several minor bug fixes. = 2.4.0 / 2011-05-11 * Fixed a bug that prevented parsing nested blocks correctly (issue #21). * Added URI example. * Moved example grammars inside lib/citrus/grammars and added lib/citrus/grammars.rb for easily requiring Citrus example grammars. = 2.3.7 / 2011-02-20 * Fixed a bug that prevented forward slashes from being used inside character class literals. * Added email address example. = 2.3.6 / 2011-02-19 * Fixed a bug that prevented memoization from advancing the input's pointer properly (thanks joachimm). * Several additions to the TextMate bundle (thanks joachimm). = 2.3.5 / 2011-02-07 * Fixed a bug that prevented Match objects from being printed properly using Kernel#puts (thanks joachimm). * Fixed a bug that prevented using rules with names that begin with "end" (thanks Mark Wilden). * Citrus#require accepts relative file paths, in addition to absolute ones. * Simplified/cleaned up some example files. = 2.3.4 / 2011-01-17 * Added CHANGES file. = 2.3.3 / 2011-01-17 * Added self to Match#captures hash. This means that a Match may retrieve a reference to itself by using its own label, proxy name, or index 0 in the hash. * Match#captures returns an empty array for unknown Symbol keys, coerces String keys to Symbols, and returns nil for unknown Numeric keys. * Moved Citrus::VERSION to its own file. * Citrus::LoadError is raised when Citrus is unable to load a file from the file system because it cannot be found or it is not readable. * Citrus::SyntaxError is raised when Citrus::File is unable to parse some Citrus syntax. * Added Citrus.require for requiring .citrus grammar files in a similar way to Ruby's Kernel.require. Also, overloaded the require operator in Citrus grammar files to failover to Citrus.require when Kernel.require raises a LoadError. * Improved UTF-8 support.