public
Description: An Actionscript 3 to haXe source converter written in Haskell
Homepage: http://geekrelief.wordpress.com
Clone URL: git://github.com/geekrelief/as3tohaxe.git
Click here to lend your support to: as3tohaxe and make a donation at www.pledgie.com !
as3tohaxe / Tokenize.hs
100644 41 lines (31 sloc) 1.512 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
{-
as3tohaxe - An Actionscript 3 to haXe source file translator
Copyright (C) 2008 Don-Duong Quach
 
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
 
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
 
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
-}
module Main where
 
import ActionhaXe.Lexer
 
import System.Environment (getArgs)
import Text.PrettyPrint
 
format:: Token -> Doc
format t = parens (hcat [text (tokenSource t), space, int (tokenLine t), colon, int (tokenCol t) ]) <+> text (tokenItemS t)
 
unknowns ts = [ format t | t@(s, TokenUnknown a) <- ts]
comments ts = [ format t | t@(s, TokenComment a) <- ts]
strings ts = [ format t | t@(s, TokenString a) <- ts]
xmls ts = [ format t | t@(s, TokenXml a) <- ts]
 
main = do args <- getArgs
          let filename = args!!0
          contents <- readFile filename
          let tokens = runLexer "" contents
          putStrLn $ render $ hcat $ punctuate (text "\n") $ unknowns tokens
          putStrLn "\n\nTokenized--"
          print tokens