File: demo_tokenre2

package info (click to toggle)
runawk 1.6.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 712 kB
  • sloc: awk: 1,127; ansic: 736; sh: 420; makefile: 103
file content (24 lines) | stat: -rwxr-xr-x 520 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#!/usr/bin/env runawk 

#use "tokenre.awk" 

# This demo splits input line into tokens according to regexp that
# defines lexem of hypotetic programming language.

# Input files for this demo: examples/demo_tokenre2.in*

BEGIN { 
	TRE =         "if|then|else|while|do|end" 
	TRE = TRE "|" "[0-9]+([.][0-9]+)?" 
	TRE = TRE "|" ":=|=|<|>|!=|[+]|-|[*]|/|[.][.]" 
	TRE = TRE "|" "[()]" 
	TRE = TRE "|" "[[:alpha:]_][[:alnum:]_]*" 
	TRE = TRE "|" "'[^']*'" 
} 

{ 
	for (i=1; i <= NF; ++i){ 
		print $i 
	} 
	print "<NL>" 
}