Module CPP.ICode.TransICode

Translator from Curry with Integrated Code to Curry

Integrated Code can be used in Curry in the form

AccentGraves Langtag Whitespaces Code SingleQuotes

where AccentGraves is a number of greater than 2 SingleQuotes is the same number of ' Langtag is an arbitrary sequence of characters without whitespaces, tabs and newlines, Whitespaces is a combination of spaces, tabs and newlines, and Code is code in the language Langtag. Is is allowed to use and ' in the code, as long as they amount of sequential ` or ' is smaller than their number in AccentGraves.

If there is a corresponding parser to the langtag, the expression can be translated into type-safe Curry code.

Currently available Langtags: format - see the FormatParser and Format library regex - see the RegexParser and Regex library html - see the MLParser and HTML library xml - see the MLParser and XML library sql - see the SQLConverter and CDBI-library

Author: Jasper Sikorra (with changes by Michael Hanus)

Version: January 2018

Summary of exported operations:

ciparser :: String -> String -> IO (PM [StandardToken])  Deterministic 
parsers :: Maybe String -> Either String ParserInfo -> Pos -> String -> IO (PM String)  Non-deterministic 
addRealFname :: String -> (Pos,String) -> (Pos,String)  Deterministic 
formatErrors :: [PError] -> IO a  Deterministic 
formatWarnings :: [(Pos,String)] -> String  Deterministic 
translateIntCode :: Int -> String -> String -> String -> IO String  Non-deterministic 
Translates a string containing a Curry program with Integrated Code into a string with pure Curry code.
tryReadParserInfoFile :: Int -> String -> String -> IO (Either String ParserInfo)  Deterministic 
Try to read parser info file for the SQL preprocessor.
findParserInfoFile :: [String] -> IO (Either String String)  Deterministic 
concatAllIOPM :: IO (PM [StandardToken]) -> IO (PM String)  Deterministic 
Handles the IO and PM monads around the StandardTokens for the concatenation, so they will not disturb in the real concat function concatAll
concatAll :: [StandardToken] -> String  Deterministic 
Concatenates the result of the translation process, inserting newlines and offsets if necessary
genLines :: Int -> String  Deterministic 
The function genLines generates lines
splitByLine :: String -> (String,String)  Deterministic 
The function splitByLine splits a string at the first newline
applyLangParsers :: Either String ParserInfo -> IO (PM [StandardToken]) -> IO (PM [StandardToken])  Non-deterministic 
Applies the corresponding translators of the DSL to Curry on the StandardTokens
applyLangParser :: Either String ParserInfo -> StandardToken -> IO (PM StandardToken)  Non-deterministic 
Select the right translator and apply it to a single StandardToken

Exported operations:

ciparser :: String -> String -> IO (PM [StandardToken])  Deterministic 

parsers :: Maybe String -> Either String ParserInfo -> Pos -> String -> IO (PM String)  Non-deterministic 

addRealFname :: String -> (Pos,String) -> (Pos,String)  Deterministic 

formatErrors :: [PError] -> IO a  Deterministic 

formatWarnings :: [(Pos,String)] -> String  Deterministic 

translateIntCode :: Int -> String -> String -> String -> IO String  Non-deterministic 

Translates a string containing a Curry program with Integrated Code into a string with pure Curry code. The second argument is, if non-empty, the name of an info file containing information about the data model in case of integrated SQL code.

Example call:
(translateIntCode verb model fname s)
Parameters:
  • verb : verbosity level
  • model : name of file containing information about the datamodel in case of SQL, an empty string otherwise
  • fname : The name of the original Curry file
  • s : The string that should be translated
Returns:
The translated string

tryReadParserInfoFile :: Int -> String -> String -> IO (Either String ParserInfo)  Deterministic 

Try to read parser info file for the SQL preprocessor.

findParserInfoFile :: [String] -> IO (Either String String)  Deterministic 

concatAllIOPM :: IO (PM [StandardToken]) -> IO (PM String)  Deterministic 

Handles the IO and PM monads around the StandardTokens for the concatenation, so they will not disturb in the real concat function concatAll

Example call:
(concatAllIOPM ioprpt)
Parameters:
  • ioprpt : A list of StandardTokens wrapped in IO and a ParserMonad

concatAll :: [StandardToken] -> String  Deterministic 

Concatenates the result of the translation process, inserting newlines and offsets if necessary

Example call:
(concatAll tks)
Parameters:
  • tks : A list of StandardTokens containing the results

genLines :: Int -> String  Deterministic 

The function genLines generates lines

Example call:
(genLines n)
Parameters:
  • n : The number of line to be generated

splitByLine :: String -> (String,String)  Deterministic 

The function splitByLine splits a string at the first newline

Example call:
(splitByLine s)
Parameters:
  • s : The string

applyLangParsers :: Either String ParserInfo -> IO (PM [StandardToken]) -> IO (PM [StandardToken])  Non-deterministic 

Applies the corresponding translators of the DSL to Curry on the StandardTokens

Example call:
(applyLangParsers model iotks)
Parameters:
  • model : data model information (required in case of SQL code), otherwise an error message
  • iotks : The input StandardTokens wrapped in IO and ParserMonad

applyLangParser :: Either String ParserInfo -> StandardToken -> IO (PM StandardToken)  Non-deterministic 

Select the right translator and apply it to a single StandardToken

Example call:
(applyLangParser model t)
Parameters:
  • model : data model information in case of SQL code, error message otherwise
  • t : The input StandardToken result - The translated StandardToken wrapped in IO and ParserMonad