summaryrefslogtreecommitdiff
path: root/src/GF/Command/Importing.hs
blob: 73589533d32a9dd35a090cc2cbf045921750db38 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
module GF.Command.Importing (importGrammar) where

import GF.Compile.API
import GF.GFCC.DataGFCC
import GF.GFCC.API

import GF.Devel.UseIO
import GF.Infra.Option

import Data.List (nubBy)

-- import a grammar in an environment where it extends an existing grammar
importGrammar :: MultiGrammar -> Options -> [FilePath] -> IO MultiGrammar
importGrammar mgr0 opts files = do
  gfcc2 <- case fileSuffix (last files) of
    s | elem s ["gf","gfo"] -> compileToGFCC opts files
    "gfcc" -> 
      mapM file2gfcc files >>= return . foldl1 unionGFCC
  let gfcc3 = unionGFCC (gfcc mgr0) gfcc2
  return $ MultiGrammar gfcc3