Sha256: fdfc7a4b317a8ed20948d8af1746163e262243e0887e1c96d94441eed29b46eb

Contents?: true

Size: 1.7 KB

Versions: 20

Compression:

Stored size: 1.7 KB

Contents

= Syntax

A syntax highlighting a library for Ruby.

== About

This is a simple syntax highlighting library for Ruby. It is a naive syntax analysis tool, meaning that it does not "understand" the syntaxes of the languages it processes, but merely does some semi-intelligent pattern matching.

== Usage

There are primarily two uses for the Syntax library:

# Convert text from a supported syntax to a supported highlight format (like HTML).
# Tokenize text in a supported syntax and process the tokens directly.

=== Highlighting a supported syntax

  require 'syntax/convertors/html'

  convertor = Syntax::Convertors::HTML.for_syntax "ruby"
  puts convertor.convert( File.read( "file.rb" ) )

The above snippet will emit HTML, using spans and CSS to indicate the different highlight "groups". (Sample CSS files are included in the "data" directory.)

=== Tokenize text

  require 'syntax'

  tokenizer = Syntax.load "ruby"
  tokenizer.tokenize( File.read( "file.rb" ) ) do |token|
    puts "group(#{token.group}, #{token.instruction}) lexeme(#{token})"
  end

Tokenizing is straightforward process. Each time a new token is discovered by the tokenizer, it is yielded to the given block.

* <tt>token.group</tt> is the lexical group to which the token belongs. Each supported syntax may have it's own set of lexical groups.
* <tt>token.instruction</tt> is an instruction used to determine how this token should be treated. It will be <tt>:none</tt> for normal tokens, <tt>:region_open</tt> if the token starts a nested region, and <tt>:region_close</tt> if it closes the last opened region.
* <tt>token</tt> is itself a subclass of String, so you can use it just as you would a string. It represents the lexeme that was actually parsed.

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
typo-3.99.0 vendor/syntax/README
typo-3.99.1 vendor/syntax/README
typo-3.99.3 vendor/syntax/README
typo-3.99.2 vendor/syntax/README
typo-3.99.4 vendor/syntax/README
typo-4.0.2 vendor/syntax/README
typo-4.0.1 vendor/syntax/README
typo-4.0.0 vendor/syntax/README
typo-4.0.3 vendor/syntax/README
typo-4.1.1 vendor/syntax/README
typo-5.0.2 vendor/syntax/README
typo-5.0.1 vendor/syntax/README
typo-4.1 vendor/syntax/README
typo-5.0.3.98.1 vendor/syntax/README
typo-5.0 vendor/syntax/README
typo-5.0.3.98 vendor/syntax/README
typo-5.1.1 vendor/syntax/README
typo-5.1.2 vendor/syntax/README
typo-5.1.3 vendor/syntax/README
typo-5.1 vendor/syntax/README