Class: Rouge::Lexers::Smarty

Inherits:
TemplateLexer show all
Defined in:
lib/rouge/lexers/smarty.rb

Constant Summary

Constants inherited from RegexLexer

RegexLexer::MAX_NULL_SCANS

Constants included from Token::Tokens

Token::Tokens::Num, Token::Tokens::Str

Class Method Summary collapse

Methods inherited from TemplateLexer

#parent

Methods inherited from RegexLexer

append, #delegate, get_state, #get_state, #goto, #group, #groups, #in_state?, #pop!, prepend, #push, #recurse, replace_state, #reset!, #reset_stack, #stack, start, start_procs, #state, state, #state?, state_definitions, states, #step, #stream_tokens, #token

Methods inherited from Rouge::Lexer

aliases, all, assert_utf8!, #debug, default_options, demo, demo_file, desc, filenames, find, find_fancy, guess, guess_by_filename, guess_by_mimetype, guess_by_source, guesses, #initialize, lex, #lex, mimetypes, #option, #options, #reset!, #stream_tokens, tag, #tag, title

Methods included from Token::Tokens

token

Constructor Details

This class inherits a constructor from Rouge::Lexer

Class Method Details

.analyze_text(text) ⇒ Object



13
14
15
16
17
18
19
20
# File 'lib/rouge/lexers/smarty.rb', line 13

def self.analyze_text(text)
  rv = 0.0
  rv += 0.15 if text =~ /\{if\s+.*?\}.*?\{\/if\}/
  rv += 0.15 if text =~ /\{include\s+file=.*?\}/
  rv += 0.15 if text =~ /\{foreach\s+.*?\}.*?\{\/foreach\}/
  rv += 0.01 if text =~ /\{\$.*?\}/
  return rv
end

.builtinsObject



24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# File 'lib/rouge/lexers/smarty.rb', line 24

def self.builtins
  @builtins ||= %w(
    append assign block call capture config_load debug extends
    for foreach foreachelse break continue function if elseif
    else include include_php insert ldelim rdelim literal nocache
    php section sectionelse setfilter strip while
    counter cycle eval fetch html_checkboxes html_image html_options
    html_radios html_select_date html_select_time html_table
    mailto math textformat
    capitalize cat count_characters count_paragraphs
    count_sentences count_words date_format default escape
    from_charset indent lower nl2br regex_replace replace spacify
    string_format strip strip_tags to_charset truncate unescape
    upper wordwrap
  )
end