123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- #!/usr/bin/env coretop
- (******************************************************************************)
- (* Copyright © Joly Clément, 2016 *)
- (* *)
- (* leowzukw@oclaunch.eu.org *)
- (* *)
- (* Ce logiciel est un programme informatique servant à exécuter *)
- (* automatiquement des programmes à l'ouverture du terminal. *)
- (* *)
- (* Ce logiciel est régi par la licence CeCILL soumise au droit français et *)
- (* respectant les principes de diffusion des logiciels libres. Vous pouvez *)
- (* utiliser, modifier et/ou redistribuer ce programme sous les conditions *)
- (* de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA *)
- (* sur le site "http://www.cecill.info". *)
- (* *)
- (* En contrepartie de l'accessibilité au code source et des droits de copie, *)
- (* de modification et de redistribution accordés par cette licence, il n'est *)
- (* offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons, *)
- (* seule une responsabilité restreinte pèse sur l'auteur du programme, le *)
- (* titulaire des droits patrimoniaux et les concédants successifs. *)
- (* *)
- (* A cet égard l'attention de l'utilisateur est attirée sur les risques *)
- (* associés au chargement, à l'utilisation, à la modification et/ou au *)
- (* développement et à la reproduction du logiciel par l'utilisateur étant *)
- (* donné sa spécificité de logiciel libre, qui peut le rendre complexe à *)
- (* manipuler et qui le réserve donc à des développeurs et des professionnels *)
- (* avertis possédant des connaissances informatiques approfondies. Les *)
- (* utilisateurs sont donc invités à charger et tester l'adéquation du *)
- (* logiciel à leurs besoins dans des conditions permettant d'assurer la *)
- (* sécurité de leurs systèmes et ou de leurs données et, plus généralement, *)
- (* à l'utiliser et l'exploiter dans les mêmes conditions de sécurité. *)
- (* *)
- (* Le fait que vous puissiez accéder à cet en-tête signifie que vous avez *)
- (* pris connaissance de la licence CeCILL, et que vous en avez accepté les *)
- (* termes. *)
- (******************************************************************************)
- open Core.Std;;
- (* Exit codes *)
- let exit_ok () = exit 0;;
- let exit_arg_lack () = exit 1;;
- let exit_ocp_indent_error () = exit 2;;
- let ignored =
- (* File (space separated) to be ignored, regexp passed to tree command *)
- "src/third-part/ src/color_print.ml \
- src/settings_j.ml src/settings_t.ml src/settings_v.ml \
- src/settings_j.mli src/settings_t.mli src/settings_v.mli \
- src/tmp_biniou_b.ml src/tmp_biniou_t.ml src/tmp_biniou_v.ml \
- src/tmp_biniou_b.mli src/tmp_biniou_t.mli src/tmp_biniou_v.mli \
- " (* The following code prevent strange filename to appear *)
- |> String.split ~on:' '
- |> List.filter_map ~f:(function
- | "" | " " | " " | " " | " " -> None
- | path -> Some path)
- ;;
- (* List ml files *)
- let list_mlfiles ?(follow_symlinks=true) path =
- let is_dotml file =
- String.split ~on:'.' file
- |> List.last
- |> function
- | None -> false
- | Some ext -> ext = "ml"
- in
- let is_ignored file =
- List.find ignored (fun to_ignore -> to_ignore = file)
- |> Option.is_some
- in
- let rec ls_rec s =
- (* If follow_symlinks is set to false then any symlink seems do not to be a
- * file *)
- if Sys.is_file_exn ~follow_symlinks s
- then [s]
- else Sys.ls_dir s |> List.map ~f:(fun sub -> ls_rec (s ^/ sub))
- |> List.concat
- in
- List.filter (ls_rec path)
- ~f:(fun file -> not (is_ignored file) && is_dotml file)
- ;;
- (* Call ocp-indent for indentation *)
- let ocp_indent file =
- let args = "--inplace" in
- String.concat [ "ocp-indent "; args; " "; file]
- |> Sys.command
- |> function
- | 0 -> printf "File: '%s' ok\n" file
- | error ->
- printf "Error with file: '%s'; code: %i\n%!" file error;
- exit_ocp_indent_error ()
- ;;
- let () =
- Sys.argv |> function
- [| _; path |] ->
- list_mlfiles path |> List.iter ~f:ocp_indent;
- printf "Done\n%!";
- exit_ok ()
- | _ -> printf "Usage: %s [directory containing file to indent]\n"
- Sys.executable_name;
- exit_arg_lack ()
- ;;
|