Skip to content
/ textpow Public
forked from grosser/textpow

Read TextMate syntax files and parse text with them

License

Notifications You must be signed in to change notification settings

jankap/textpow

 
 

Repository files navigation

Read TextMate syntax files and parse text with them.

INSTALL:

gem install textpow

Ruby 1.8

Install oniguruma

# Ubuntu
sudo apt-get -y install libonig-dev

# OSX via brew or port
brew install onigumura
port install oniguruma5

# Then
gem install oniguruma

Demo

USAGE:

  1. Load a Syntax File list of included syntax

require 'textpow'
syntax = Textpow.syntax('ruby') # or 'source.ruby' or 'lib/textpow/syntax/source.ruby.syntax'
  1. Initialize a processor:

processor = Textpow::DebugProcessor.new
  1. Parse some text:

syntax.parse(text,  processor)

Syntax-files

Syntax files are written with Textmate grammer. They are written in text/binary/xml/yaml format (all can be translated into each other). Textpow can understand the yaml form (ending in .syntax) and the xml form (ending in .tmSyntax or .plist or tmLanguage) via plist library, but not the text or binary form. All syntax files shipped with textpow are in the yaml form, since its easiest to read and less verbose.

Adding a new syntax:

  • add download location and scopeName to update_syntax task in Rakefile

  • rake update_syntax

  • run tests rake to see if the syntax is parseable

Processors

A processors is a hook that is called while parsing a text. It must implement these methods:

class MyProcessor
  def open_tag(tag_name, position_in_current_line); end
  def close_tag(tag_name, position_in_current_line); end

  # called before processing a line
  def new_line(line_content); end

  # called before parsing anything
  def start_parsing(scope_name); end

  # called before parsing everything
  def end_parsing(scope_name); end
end

Textpow ensures that the methods are called in parsing order. If there are two subsequent calls to open_tag, the first having name="text.string", position=10 and the second having name="markup.string", position=10, it means that the "markup.string" tag is inside the "text.string" tag.

TODO

  • smart + mel + applescript have some invalid utf8 characters that are currently ignored (search for INVALID_UTF8))

  • fix markdown and php syntax

  • parse text plist files example

  • update more languages via github urls

Examples of uses

  • Textpow is used by the Ultraviolet gem rubygems.org/gems/ultraviolet

  • The Ultraviolet gem is used by the Redmine_ultraviolet plugin github.com/jbbarth/redmine_ultraviolet

    With Redmine, Textpow warnings still exist when Rails is launched :

    /home/projets/redmine/trunk/plugins/redmine_ultraviolet/lib/uv_syntax_highlighting.rb:5: warning: already initialized constant CUSTOM_FIELD_NAME
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: invalid back reference: /\\(\n\d+|\k\w+|(?<!\|)\g\w+)/
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: invalid subexp call: /\\(\n\d+|\k\w+|(?<!\|)\g\w+)/
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: character class has ']' without escape
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: character class has ']' without escape
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: character class has ']' without escape
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: character class has ']' without escape
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: character class has ']' without escape
    /var/lib/gems/1.9.1/gems/textpow-1.3.1/lib/textpow/syntax.rb:120: warning: character class has ']' without escape

LICENSE: MIT

<img src=“https://secure.travis-ci.org/grosser/textpow.png” />

About

Read TextMate syntax files and parse text with them

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 100.0%