summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorKrasimir Angelov <kr.angelov@gmail.com>2017-08-30 15:59:43 +0200
committerKrasimir Angelov <kr.angelov@gmail.com>2017-08-30 15:59:43 +0200
commit08a728799a8920fc3d82cdb8c1bdba99a0d1afdf (patch)
tree0a027f963a5b78997a5f284a080ff376fff8cbd0 /src
parent97fe5df267dc7e5611a5a93699d031727165bd2a (diff)
change tabularLinearize in the Haskell binding to return a list instead of map this preserves the order
Diffstat (limited to 'src')
-rw-r--r--src/runtime/haskell-bind/PGF2.hsc6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/runtime/haskell-bind/PGF2.hsc b/src/runtime/haskell-bind/PGF2.hsc
index 104d06cb1..7ebba4846 100644
--- a/src/runtime/haskell-bind/PGF2.hsc
+++ b/src/runtime/haskell-bind/PGF2.hsc
@@ -648,7 +648,7 @@ linearizeAll lang e = unsafePerformIO $
throwIO (PGFError "The abstract tree cannot be linearized")
-- | Generates a table of linearizations for an expression
-tabularLinearize :: Concr -> Expr -> Map.Map String String
+tabularLinearize :: Concr -> Expr -> [(String, String)]
tabularLinearize lang e = unsafePerformIO $
withGuPool $ \tmpPl -> do
exn <- gu_new_exn tmpPl
@@ -660,7 +660,7 @@ tabularLinearize lang e = unsafePerformIO $
peek ptr
if ctree == nullPtr
then do touchExpr e
- return Map.empty
+ return []
else do labels <- alloca $ \p_n_lins ->
alloca $ \p_labels -> do
pgf_lzr_get_table (concr lang) ctree p_n_lins p_labels
@@ -670,7 +670,7 @@ tabularLinearize lang e = unsafePerformIO $
labels <- mapM peekCString labels
return labels
lins <- collect lang ctree 0 labels exn tmpPl
- return (Map.fromList lins)
+ return lins
where
collect lang ctree lin_idx [] exn tmpPl = return []
collect lang ctree lin_idx (label:labels) exn tmpPl = do