aboutsummaryrefslogtreecommitdiff
path: root/lib/configuration/importConf.ml
blob: 8516008ff46a26d87c4fbe4ea99abc677a8bd7c6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
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 =
 fun toml ->
  let version =
    Otoml.find_or ~default:latest_version toml
      (Otoml.get_integer ~strict:false)
      [ "version" ]
  in
  match version with
  | n when n = 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