summaryrefslogtreecommitdiff
path: root/src/runtime/haskell-bind/README.md
diff options
context:
space:
mode:
authorJohn J. Camilleri <john@digitalgrammars.com>2020-07-11 21:06:08 +0200
committerJohn J. Camilleri <john@digitalgrammars.com>2020-07-11 21:06:08 +0200
commit38f468eed3325d5e435021b8b137f80545f22a95 (patch)
treef495fbbadcdcae993108b022278861fbb955c3f4 /src/runtime/haskell-bind/README.md
parent88a73c1d9e9e9bf1ac4c4194917e50df1bcce635 (diff)
(pgf2) Readme, license, changelog
Diffstat (limited to 'src/runtime/haskell-bind/README.md')
-rw-r--r--src/runtime/haskell-bind/README.md46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/runtime/haskell-bind/README.md b/src/runtime/haskell-bind/README.md
new file mode 100644
index 000000000..a4ce0ef20
--- /dev/null
+++ b/src/runtime/haskell-bind/README.md
@@ -0,0 +1,46 @@
+# PGF2
+
+This is a Haskell binding to the PGF runtime in C.
+
+The exposed modules are:
+
+- `PGF2`: a user API similar to Python and Java APIs
+- `PGF2.Internal`: an internal module with FFI definitions for the relevant C functions
+
+## How to compile
+
+```
+cabal install
+```
+
+**Note:** you must have the PGF C runtime already installed and available.
+See <https://github.com/GrammaticalFramework/gf-core/blob/master/src/runtime/c/INSTALL>
+
+## How to use
+
+Import PGF to the Haskell program that you're writing.
+The Cabal infrastructure will make sure to tell the compiler
+where to find the relevant modules.
+
+## Example
+
+```haskell
+module Main where
+
+import PGF2
+import qualified Data.Map as Map
+
+main = do
+ pgf <- readPGF "App12.pgf"
+ let Just eng = Map.lookup "AppEng" (languages pgf)
+
+ -- Parsing
+ let res = parse eng (startCat pgf) "this is a small theatre"
+ let ParseOk ((tree,prob):rest) = res
+ print tree
+
+ -- Linearisation
+ let Just expr = readExpr "AdjCN (PositA red_A) (UseN theatre_N)"
+ let s = linearize eng expr
+ print s
+```