tools/unitCycles.hs
author unC0Rr
Wed, 17 Nov 2010 16:19:28 +0300
changeset 4353 671d66ba3af6
child 4355 4554c4df9f1a
permissions -rw-r--r--
Dumb parser of pascal, and a program which lists unit dependencies

module Main where

import PascalParser
import System
import Control.Monad
import Data.Either
import Data.List

unident :: Identificator -> String
unident (Identificator s) = s

extractUnits :: PascalUnit -> (String, [String])
extractUnits (Program (Identificator name) (Implementation (Uses idents) _ _) _) = ("program " ++ name, map unident idents)
extractUnits (Unit (Identificator name) (Interface (Uses idents1) _) (Implementation (Uses idents2) _ _) _ _) = (name, map unident $ idents1 ++ idents2)

main = do
    fileNames <- getArgs
    files <- mapM readFile fileNames
    mapM_ (putStrLn . show . extractUnits) . rights . map parsePascalUnit $ files