mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-27 03:38:55 -06:00
allow comments in dependency configs and fix conll output
This commit is contained in:
@@ -236,10 +236,18 @@ graphvizDependencyTree format debug mlab mclab pgf lang t =
|
|||||||
root_lbl = "ROOT"
|
root_lbl = "ROOT"
|
||||||
unspec = text "_"
|
unspec = text "_"
|
||||||
|
|
||||||
|
-- auxiliaries for UD conversion PK 15/12/2018
|
||||||
|
rmcomments :: String -> String
|
||||||
|
rmcomments [] = []
|
||||||
|
rmcomments ('-':'-':xs) = []
|
||||||
|
rmcomments ('-':x :xs) = '-':rmcomments (x:xs)
|
||||||
|
rmcomments (x:xs) = x:rmcomments xs
|
||||||
|
|
||||||
-- | Prepare lines obtained from a configuration file for labels for
|
-- | Prepare lines obtained from a configuration file for labels for
|
||||||
-- use with 'graphvizDependencyTree'. Format per line /fun/ /label/@*@.
|
-- use with 'graphvizDependencyTree'. Format per line /fun/ /label/@*@.
|
||||||
getDepLabels :: String -> Labels
|
getDepLabels :: String -> Labels
|
||||||
getDepLabels s = Map.fromList [(mkCId f,ls) | f:ls <- map words (lines s)]
|
-- getDepLabels s = Map.fromList [(mkCId f,ls) | f:ls <- map words (lines s)]
|
||||||
|
getDepLabels s = Map.fromList [(mkCId f,ls) | f:ls <- map (words . rmcomments) (lines s)]
|
||||||
|
|
||||||
-- the old function, without dependencies
|
-- the old function, without dependencies
|
||||||
graphvizParseTree :: PGF -> Language -> GraphvizOptions -> Tree -> String
|
graphvizParseTree :: PGF -> Language -> GraphvizOptions -> Tree -> String
|
||||||
@@ -784,6 +792,7 @@ getCncDepLabels =
|
|||||||
sortBy (comparing fst) .
|
sortBy (comparing fst) .
|
||||||
concatMap analyse .
|
concatMap analyse .
|
||||||
filter choose .
|
filter choose .
|
||||||
|
map rmcomments .
|
||||||
lines
|
lines
|
||||||
where
|
where
|
||||||
--- choose is for compatibility with the general notation
|
--- choose is for compatibility with the general notation
|
||||||
@@ -806,6 +815,7 @@ getCncDepLabels =
|
|||||||
toks s = case lex s of [(t,"")] -> [t] ; [(t,cc)] -> t:toks cc ; _ -> []
|
toks s = case lex s of [(t,"")] -> [t] ; [(t,cc)] -> t:toks cc ; _ -> []
|
||||||
unquote s = case s of '"':cc@(_:_) | last cc == '"' -> init cc ; _ -> s
|
unquote s = case s of '"':cc@(_:_) | last cc == '"' -> init cc ; _ -> s
|
||||||
|
|
||||||
|
-- added init to remove the last \n. otherwise, two empty lines are in between each sentence PK 17/12/2018
|
||||||
printCoNLL :: CoNLL -> String
|
printCoNLL :: CoNLL -> String
|
||||||
printCoNLL = unlines . map (concat . intersperse "\t")
|
printCoNLL = init . unlines . map (concat . intersperse "\t")
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user