diff options
Diffstat (limited to 'lib/configuration/importConf.ml')
| -rw-r--r-- | lib/configuration/importConf.ml | 57 | 
1 files changed, 3 insertions, 54 deletions
| diff --git a/lib/configuration/importConf.ml b/lib/configuration/importConf.ml index 8516008..2df24bd 100644 --- a/lib/configuration/importConf.ml +++ b/lib/configuration/importConf.ml @@ -1,68 +1,17 @@ -open StdLabels -module Syntax = Syntax -module CTE = Cte -module Table = ImportDataTypes.Table -module Path = ImportDataTypes.Path -module T = Read_conf -module Expression = ImportExpression.T - -let latest_version = 1 -  module TomlReader = Read_conf.Make (Helpers.Toml.Decode) -let t_of_toml : Otoml.t -> (Syntax.t, string) result = +let t_of_toml : Otoml.t -> (ImporterSyntax.t, string) result =   fun toml ->    let version = -    Otoml.find_or ~default:latest_version toml +    Otoml.find_or ~default:ImporterSyntax.latest_version toml        (Otoml.get_integer ~strict:false)        [ "version" ]    in    match version with -  | n when n = latest_version -> TomlReader.read toml +  | n when n = ImporterSyntax.latest_version -> TomlReader.read toml    | _ ->        Printf.eprintf "Unsuported version : %d\n" version;        exit 1 -let dummy_conf = -  Syntax. -    { -      source = { file = ""; tab = 0; name = "" }; -      version = latest_version; -      locale = Some "C"; -      externals = []; -      columns = []; -      filters = []; -      sort = []; -      uniq = []; -    } - -let get_table_for_name : Syntax.t -> string option -> Table.t = - fun conf name -> -  match name with -  | None -> conf.source -  | Some name -> -      if String.equal name conf.source.name then conf.source -      else -        let ext = -          List.find conf.externals ~f:(fun (ext : Syntax.Extern.t) -> -              String.equal name ext.target.name) -        in -        ext.target - -let root_table : Syntax.t -> Table.t = fun conf -> conf.source - -let get_dependancies_for_table : Syntax.t -> Table.t -> Syntax.Extern.t list = - fun conf source -> -  let is_root = source = conf.source in - -  List.filter conf.externals ~f:(fun (ext : Syntax.Extern.t) -> -      (* Enumerate the intern_key and check the source pointed by each column *) -      Expression.fold_values ext.intern_key ~init:false ~f:(fun acc expr -> -          if acc then acc -          else -            match expr.Syntax.Path.alias with -            | Some v -> String.equal v source.name -            | None -> is_root)) -  let expression_from_string s =    Read_conf.ExpressionParser.of_string Read_conf.ExpressionParser.path s | 
