diff --git a/CHANGES.md b/CHANGES.md index 9e7d0697cd..6f10b39342 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -19,7 +19,7 @@ + Replace pre_break and if_newline by cbreak (#1090) (Guillaume Petiot) + Use opt and fmt_opt to simplify formatting (#1150) (Guillaume Petiot) + Replace inplace formatting by dune staging for make fmt (#1151) (Guillaume Petiot) - + Refactor code that interprets CLI options (#1127) (Jules Aguillon) + + Refactor code that interprets CLI options (#1127, #1156) (Jules Aguillon) + Testing interactions between break-infix and break-infix-before-func (#1136) (Guillaume Petiot) + Add dune to repositories checked for regressions (#1129) (Jules Aguillon) + Use an expect test for cli tests (#1126) (Etienne Millon) diff --git a/lib/Conf.ml b/lib/Conf.ml index ffd0828f1e..42cb6e255c 100644 --- a/lib/Conf.ml +++ b/lib/Conf.ml @@ -1753,12 +1753,6 @@ let ocp_indent_janestreet_profile = ; ("align_ops", "true") ; ("align_params", "always") ] -let root = - Option.map !root ~f:Fpath.(fun x -> v x |> to_absolute |> normalize) - -let enable_outside_detected_project = - !enable_outside_detected_project && Option.is_none root - let parse_line config ~from s = let update ~config ~from ~name ~value = let name = String.strip name in @@ -1828,7 +1822,7 @@ let parse_line config ~from s = | name -> update ~config ~from ~name ~value:"true" ) | _ -> Error (`Malformed s) -let is_project_root dir = +let is_project_root ~root dir = match root with | Some root -> Fpath.equal dir root | None -> @@ -1843,11 +1837,13 @@ let dot_ocamlformat_ignore = ".ocamlformat-ignore" let dot_ocamlformat_enable = ".ocamlformat-enable" -let rec collect_files ~segs ~ignores ~enables ~files = +let rec collect_files ~enable_outside_detected_project ~root ~segs ~ignores + ~enables ~files = match segs with | [] | [""] -> (ignores, enables, files, None) | "" :: upper_segs -> - collect_files ~segs:upper_segs ~ignores ~enables ~files + collect_files ~enable_outside_detected_project ~root ~segs:upper_segs + ~ignores ~enables ~files | _ :: upper_segs -> let sep = Fpath.dir_sep in let dir = String.concat ~sep (List.rev segs) |> Fpath.v in @@ -1867,9 +1863,11 @@ let rec collect_files ~segs ~ignores ~enables ~files = let f_2 = Fpath.(dir / dot_ocp_indent) in if Fpath.exists f_2 then `Ocp_indent f_2 :: files else files in - if is_project_root dir && not enable_outside_detected_project then - (ignores, enables, files, Some dir) - else collect_files ~segs:upper_segs ~ignores ~enables ~files + if is_project_root ~root dir && not enable_outside_detected_project + then (ignores, enables, files, Some dir) + else + collect_files ~enable_outside_detected_project ~root ~segs:upper_segs + ~ignores ~enables ~files let read_config_file conf filename_kind = match filename_kind with @@ -1985,13 +1983,14 @@ let is_in_listing_file ~listings ~filename = warn "ignoring %a, %s" Fpath.pp listing_file err ; None) -let build_config ~file ~is_stdin = +let build_config ~enable_outside_detected_project ~root ~file ~is_stdin = let vfile = Fpath.v file in let file_abs = Fpath.(vfile |> to_absolute |> normalize) in let dir = Fpath.(file_abs |> split_base |> fst) in let segs = Fpath.segs dir |> List.rev in let ignores, enables, files, project_root = - collect_files ~segs ~ignores:[] ~enables:[] ~files:[] + collect_files ~enable_outside_detected_project ~root ~segs ~ignores:[] + ~enables:[] ~files:[] in let files = match (xdg_config, enable_outside_detected_project) with @@ -2036,9 +2035,10 @@ let build_config ~file ~is_stdin = {conf with disable= not conf.disable} | None -> conf -let build_config ~file ~is_stdin = +let build_config ~enable_outside_detected_project ~root ~file ~is_stdin = let conf, warn_now = - collect_warnings (fun () -> build_config ~file ~is_stdin) + collect_warnings (fun () -> + build_config ~enable_outside_detected_project ~root ~file ~is_stdin) in if not conf.quiet then warn_now () ; conf @@ -2107,14 +2107,21 @@ type action = | Check of [`Impl | `Intf] input list | Print_config of t -let make_action action inputs = +let make_action ~enable_outside_detected_project ~root action inputs = let make_file ?(with_conf = fun c -> c) ?name kind file = - let conf = with_conf (build_config ~file ~is_stdin:false) in + let conf = + with_conf + (build_config ~enable_outside_detected_project ~root ~file + ~is_stdin:false) + in let name = Option.value ~default:file name in {kind; name; file= File file; conf} in let make_stdin ?(name = "") kind = - let conf = build_config ~file:name ~is_stdin:false in + let conf = + build_config ~enable_outside_detected_project ~root ~file:name + ~is_stdin:false + in {kind; name; file= Stdin; conf} in match (action, inputs) with @@ -2128,7 +2135,9 @@ let make_action action inputs = let root = Option.value root ~default:(Fpath.cwd ()) in (Fpath.(root / dot_ocamlformat |> to_string), true) in - let conf = build_config ~file ~is_stdin in + let conf = + build_config ~enable_outside_detected_project ~root ~file ~is_stdin + in Ok (Print_config conf) | (`No_action | `Output _ | `Inplace | `Check), `No_input -> Error "Must specify at least one input file, or `-` for stdin" @@ -2159,6 +2168,12 @@ let make_action action inputs = | `Check, `Stdin (name, kind) -> Ok (Check [make_stdin ?name kind]) let validate () = + let root = + Option.map !root ~f:Fpath.(fun x -> v x |> to_absolute |> normalize) + in + let enable_outside_detected_project = + !enable_outside_detected_project && Option.is_none root + in if !disable_outside_detected_project then warn "option `--disable-outside-detected-project` is deprecated and will \ @@ -2167,7 +2182,9 @@ let validate () = let open Result in validate_action () >>= fun action -> - validate_inputs () >>= fun inputs -> make_action action inputs + validate_inputs () + >>= fun inputs -> + make_action ~enable_outside_detected_project ~root action inputs with | Error e -> `Error (false, e) | Ok action -> `Ok action diff --git a/test/projects/dune b/test/projects/dune new file mode 100644 index 0000000000..cad0542887 --- /dev/null +++ b/test/projects/dune @@ -0,0 +1,31 @@ +(rule + (targets enable_outside_detected_project.output) + (deps enable_outside_detected_project/dune-project + enable_outside_detected_project/main.ml) + (action + (with-stdout-to + %{targets} + (chdir + enable_outside_detected_project + (run ocamlformat --enable-outside-detected-project main.ml))))) + +(alias + (name runtest) + (action + (diff enable_outside_detected_project.expected + enable_outside_detected_project.output))) + +(rule + (targets outside_detected_project.output) + (deps outside_detected_project/dune-project outside_detected_project/main.ml) + (action + (with-outputs-to + %{targets} + (chdir + outside_detected_project + (run ocamlformat main.ml))))) + +(alias + (name runtest) + (action + (diff outside_detected_project.expected outside_detected_project.output))) diff --git a/test/projects/enable_outside_detected_project.expected b/test/projects/enable_outside_detected_project.expected new file mode 100644 index 0000000000..97e7b078b7 --- /dev/null +++ b/test/projects/enable_outside_detected_project.expected @@ -0,0 +1,3 @@ +(* The following code should be formatted using OCamlformat's config and not + default *) +type t = {foooooo: string; baaaaar: Baaaaar.t} diff --git a/test/projects/enable_outside_detected_project/dune-project b/test/projects/enable_outside_detected_project/dune-project new file mode 100644 index 0000000000..0636ab6acf --- /dev/null +++ b/test/projects/enable_outside_detected_project/dune-project @@ -0,0 +1 @@ +(lang dune 1.11) diff --git a/test/projects/enable_outside_detected_project/main.ml b/test/projects/enable_outside_detected_project/main.ml new file mode 100644 index 0000000000..5e919f05ab --- /dev/null +++ b/test/projects/enable_outside_detected_project/main.ml @@ -0,0 +1,5 @@ +(* The following code should be formatted using OCamlformat's config and not default *) +type t = { + foooooo : string; + baaaaar : Baaaaar.t; +} diff --git a/test/projects/outside_detected_project.expected b/test/projects/outside_detected_project.expected new file mode 100644 index 0000000000..8d71968c20 --- /dev/null +++ b/test/projects/outside_detected_project.expected @@ -0,0 +1,7 @@ +File main.ml +Warning: Ocamlformat disabled because [--enable-outside-detected-project] is not set and no [.ocamlformat] was found within the project (root: ../outside_detected_project) +(* The following code should not be formatted *) +type t = { + foooooo : string; + baaaaar : Baaaaar.t; +} diff --git a/test/projects/outside_detected_project/dune-project b/test/projects/outside_detected_project/dune-project new file mode 100644 index 0000000000..0636ab6acf --- /dev/null +++ b/test/projects/outside_detected_project/dune-project @@ -0,0 +1 @@ +(lang dune 1.11) diff --git a/test/projects/outside_detected_project/main.ml b/test/projects/outside_detected_project/main.ml new file mode 100644 index 0000000000..8f4b7ca2f4 --- /dev/null +++ b/test/projects/outside_detected_project/main.ml @@ -0,0 +1,5 @@ +(* The following code should not be formatted *) +type t = { + foooooo : string; + baaaaar : Baaaaar.t; +}