summaryrefslogtreecommitdiff
path: root/src-3.0/GF/Command
diff options
context:
space:
mode:
authoraarne <aarne@cs.chalmers.se>2008-06-10 16:00:42 +0000
committeraarne <aarne@cs.chalmers.se>2008-06-10 16:00:42 +0000
commit9628eb6314bfcb827142d1869626696de101e245 (patch)
tree6800242a4ce3cd45a6dda7a4eb93d9aab588e5be /src-3.0/GF/Command
parent9c75bddcfc0340b6e5dd06a23d686113532d2726 (diff)
preliminary version of morpho analysis
Diffstat (limited to 'src-3.0/GF/Command')
-rw-r--r--src-3.0/GF/Command/Commands.hs34
1 files changed, 31 insertions, 3 deletions
diff --git a/src-3.0/GF/Command/Commands.hs b/src-3.0/GF/Command/Commands.hs
index 6aa19dfba..292e802b9 100644
--- a/src-3.0/GF/Command/Commands.hs
+++ b/src-3.0/GF/Command/Commands.hs
@@ -14,6 +14,7 @@ import PGF.CId
import PGF.ShowLinearize
import PGF.Macros
import PGF.Data ----
+import PGF.Morphology
import GF.Compile.Export
import GF.Infra.UseIO
import GF.Data.ErrM ----
@@ -60,9 +61,9 @@ commandHelp full (co,info) = unlines $ [
"flags: " ++ unwords (flags info)
] else []
--- this list must be kept sorted by the command name!
+-- this list must no more be kept sorted by the command name
allCommands :: PGF -> Map.Map String CommandInfo
-allCommands pgf = Map.fromAscList [
+allCommands pgf = Map.fromList [
("cc", emptyCommandInfo {
longname = "compute_concrete",
synopsis = "computes concrete syntax term using the source grammar",
@@ -144,15 +145,39 @@ allCommands pgf = Map.fromAscList [
options = ["all","record","table","term"],
flags = ["lang"]
}),
+
+ ("ma", emptyCommandInfo {
+ longname = "morpho_analyse",
+ synopsis = "print the morphological analyses of all words in the string",
+ explanation = unlines [
+ "Prints all the analyses of space-separated words in the input string,",
+ "using the morphological analyser of the actual grammar (see command pf)"
+ ],
+ exec = \opts ->
+ return . fromString . unlines .
+ map prMorphoAnalysis . concatMap (morphos opts) .
+ concatMap words . toStrings
+ }),
+
("p", emptyCommandInfo {
longname = "parse",
synopsis = "parse a string to abstract syntax expression",
explanation = "Shows all trees (expressions) returned for String by the actual\n"++
"grammar (overridden by the -lang flag), in the category S (overridden\n"++
"by the -cat flag).",
- exec = \opts -> return . fromTrees . concatMap (par opts). toStrings,
+ exec = \opts -> return . fromTrees . concatMap (par opts) . toStrings,
flags = ["cat","lang"]
}),
+ ("pf", emptyCommandInfo {
+ longname = "print_fullform",
+ synopsis = "print the full-form lexicon of the actual grammar",
+ explanation = unlines [
+ "Prints all the strings in the actual grammar with their possible analyses"
+ ],
+ exec = \opts _ ->
+ return $ fromString $ concatMap
+ (prFullFormLexicon . buildMorpho pgf . mkCId) $ optLangs opts
+ }),
("pg", emptyCommandInfo {
longname = "print_grammar",
synopsis = "print the actual grammar with the given printer",
@@ -206,3 +231,6 @@ allCommands pgf = Map.fromAscList [
prGrammar opts = case valIdOpts "printer" "" opts of
"cats" -> unwords $ categories pgf
v -> prPGF (read v) pgf (prCId (absname pgf))
+
+ morphos opts s =
+ [lookupMorpho (buildMorpho pgf (mkCId la)) s | la <- optLangs opts]