diff options
author | Chimrod <> | 2024-12-02 09:05:18 +0100 |
---|---|---|
committer | Chimrod <> | 2024-12-02 09:05:18 +0100 |
commit | 53c02501935b3cb2db78e79deb4d38c997505a95 (patch) | |
tree | 88a75e012ee186ffb6c6e3e0c53ba80610ec3b0b /lib/syntax/nested_strings.ml | |
parent | 9e7b9de243e488e15d2c7528ce64e569eba8add2 (diff) |
Moved the checks in a dedicated library
Diffstat (limited to 'lib/syntax/nested_strings.ml')
-rw-r--r-- | lib/syntax/nested_strings.ml | 156 |
1 files changed, 0 insertions, 156 deletions
diff --git a/lib/syntax/nested_strings.ml b/lib/syntax/nested_strings.ml deleted file mode 100644 index dee7af0..0000000 --- a/lib/syntax/nested_strings.ml +++ /dev/null @@ -1,156 +0,0 @@ -open StdLabels - -let identifier = "escaped_string" -let description = "Check for unnecessary use of expression encoded in string" -let is_global = false -let active = ref true - -type context = unit - -let initialize = Fun.id -let finalize () = [] - -module TypeBuilder = Compose.Expression (Get_type) - -module Expression = TypeBuilder.Make (struct - type t = Report.t list - type t' = Report.t list - - let v : Get_type.t Lazy.t * t -> t' = snd - - (** Identify the expressions reprented as string. That’s here that the report - are added. - - All the rest of the module only push thoses warning to the top level. *) - let literal : - S.pos -> (Get_type.t Lazy.t * t) T.literal list -> Get_type.t Lazy.t -> t - = - fun pos content _type_of -> - match content with - | [ T.Expression (t', _); T.Text "" ] -> ( - match Get_type.get_type (Lazy.force t') with - | Get_type.Integer -> [] - | _ -> - let msg = Report.debug pos "This expression can be simplified" in - [ msg ]) - | _ -> [] - - let ident : - (S.pos, Get_type.t Lazy.t * t) S.variable -> Get_type.t Lazy.t -> t = - fun variable _type_of -> - match variable.index with None -> [] | Some (_, t) -> t - - let integer : S.pos -> string -> Get_type.t Lazy.t -> t = - fun pos t _type_of -> - ignore pos; - ignore t; - [] - - let function_ : - S.pos -> - T.function_ -> - (Get_type.t Lazy.t * t) list -> - Get_type.t Lazy.t -> - t = - fun pos f expressions _type_of -> - ignore pos; - ignore f; - let exprs = - List.fold_left ~init:[] expressions ~f:(fun acc el -> - List.rev_append (snd el) acc) - in - exprs - - let uoperator : - S.pos -> T.uoperator -> Get_type.t Lazy.t * t -> Get_type.t Lazy.t -> t = - fun pos op r _type_of -> - ignore op; - ignore pos; - snd r - - let boperator : - S.pos -> - T.boperator -> - Get_type.t Lazy.t * t -> - Get_type.t Lazy.t * t -> - Get_type.t Lazy.t -> - t = - fun pos op (_, r1) (_, r2) _type_of -> - ignore pos; - ignore op; - r1 @ r2 -end) - -module Instruction : - S.Instruction with type t' = Report.t list and type expression = Expression.t' = -struct - type t = Report.t list - (** Internal type used in the evaluation *) - - type t' = t - - let v : t -> t' = Fun.id - - type expression = Expression.t' - - let call : S.pos -> T.keywords -> expression list -> t = - fun pos k exprs -> - ignore pos; - ignore k; - List.concat exprs - - let location : S.pos -> string -> t = fun _ _ -> [] - let comment : S.pos -> t = fun _ -> [] - let expression : expression -> t = Fun.id - - let act : S.pos -> label:expression -> t list -> t = - fun pos ~label instructions -> - ignore pos; - List.concat (label :: instructions) - - let fold_clause : (expression, t) S.clause -> t = - fun (_pos1, expression, ts) -> List.concat (expression :: ts) - - let if_ : - S.pos -> - (expression, t) S.clause -> - elifs:(expression, t) S.clause list -> - else_:(S.pos * t list) option -> - t = - fun pos clause ~elifs ~else_ -> - ignore pos; - - let init = - match else_ with - | None -> fold_clause clause - | Some (_, ts) -> List.rev_append (fold_clause clause) (List.concat ts) - in - - List.fold_left elifs ~init ~f:(fun t clause -> - List.rev_append (fold_clause clause) t) - - let assign : - S.pos -> - (S.pos, expression) S.variable -> - T.assignation_operator -> - expression -> - t = - fun pos variable op expression -> - ignore pos; - ignore op; - match variable.index with - | None -> expression - | Some v -> List.rev_append v expression -end - -module Location = struct - type t = Report.t list - type instruction = Instruction.t' - - let v = Fun.id - - let location : unit -> S.pos -> instruction list -> t = - fun () pos intructions -> - ignore pos; - List.concat intructions -end |