fix-indent.ml 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #!/usr/bin/env coretop
  2. (******************************************************************************)
  3. (* Copyright © Joly Clément, 2016 *)
  4. (* *)
  5. (* leowzukw@oclaunch.eu.org *)
  6. (* *)
  7. (* Ce logiciel est un programme informatique servant à exécuter *)
  8. (* automatiquement des programmes à l'ouverture du terminal. *)
  9. (* *)
  10. (* Ce logiciel est régi par la licence CeCILL soumise au droit français et *)
  11. (* respectant les principes de diffusion des logiciels libres. Vous pouvez *)
  12. (* utiliser, modifier et/ou redistribuer ce programme sous les conditions *)
  13. (* de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA *)
  14. (* sur le site "http://www.cecill.info". *)
  15. (* *)
  16. (* En contrepartie de l'accessibilité au code source et des droits de copie, *)
  17. (* de modification et de redistribution accordés par cette licence, il n'est *)
  18. (* offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons, *)
  19. (* seule une responsabilité restreinte pèse sur l'auteur du programme, le *)
  20. (* titulaire des droits patrimoniaux et les concédants successifs. *)
  21. (* *)
  22. (* A cet égard l'attention de l'utilisateur est attirée sur les risques *)
  23. (* associés au chargement, à l'utilisation, à la modification et/ou au *)
  24. (* développement et à la reproduction du logiciel par l'utilisateur étant *)
  25. (* donné sa spécificité de logiciel libre, qui peut le rendre complexe à *)
  26. (* manipuler et qui le réserve donc à des développeurs et des professionnels *)
  27. (* avertis possédant des connaissances informatiques approfondies. Les *)
  28. (* utilisateurs sont donc invités à charger et tester l'adéquation du *)
  29. (* logiciel à leurs besoins dans des conditions permettant d'assurer la *)
  30. (* sécurité de leurs systèmes et ou de leurs données et, plus généralement, *)
  31. (* à l'utiliser et l'exploiter dans les mêmes conditions de sécurité. *)
  32. (* *)
  33. (* Le fait que vous puissiez accéder à cet en-tête signifie que vous avez *)
  34. (* pris connaissance de la licence CeCILL, et que vous en avez accepté les *)
  35. (* termes. *)
  36. (******************************************************************************)
  37. open Core.Std;;
  38. (* Exit codes *)
  39. let exit_ok () = exit 0;;
  40. let exit_arg_lack () = exit 1;;
  41. let exit_ocp_indent_error () = exit 2;;
  42. let ignored =
  43. (* File (space separated) to be ignored, regexp passed to tree command *)
  44. "src/third-part/ src/color_print.ml \
  45. src/settings_j.ml src/settings_t.ml src/settings_v.ml \
  46. src/settings_j.mli src/settings_t.mli src/settings_v.mli \
  47. src/tmp_biniou_b.ml src/tmp_biniou_t.ml src/tmp_biniou_v.ml \
  48. src/tmp_biniou_b.mli src/tmp_biniou_t.mli src/tmp_biniou_v.mli \
  49. " (* The following code prevent strange filename to appear *)
  50. |> String.split ~on:' '
  51. |> List.filter_map ~f:(function
  52. | "" | " " | " " | " " | " " -> None
  53. | path -> Some path)
  54. ;;
  55. (* List ml files *)
  56. let list_mlfiles ?(follow_symlinks=true) path =
  57. let is_dotml file =
  58. String.split ~on:'.' file
  59. |> List.last
  60. |> function
  61. | None -> false
  62. | Some ext -> ext = "ml"
  63. in
  64. let is_ignored file =
  65. List.find ignored (fun to_ignore -> to_ignore = file)
  66. |> Option.is_some
  67. in
  68. let rec ls_rec s =
  69. (* If follow_symlinks is set to false then any symlink seems do not to be a
  70. * file *)
  71. if Sys.is_file_exn ~follow_symlinks s
  72. then [s]
  73. else Sys.ls_dir s |> List.map ~f:(fun sub -> ls_rec (s ^/ sub))
  74. |> List.concat
  75. in
  76. List.filter (ls_rec path)
  77. ~f:(fun file -> not (is_ignored file) && is_dotml file)
  78. ;;
  79. (* Call ocp-indent for indentation *)
  80. let ocp_indent file =
  81. let args = "--inplace" in
  82. String.concat [ "ocp-indent "; args; " "; file]
  83. |> Sys.command
  84. |> function
  85. | 0 -> printf "File: '%s' ok\n" file
  86. | error ->
  87. printf "Error with file: '%s'; code: %i\n%!" file error;
  88. exit_ocp_indent_error ()
  89. ;;
  90. let () =
  91. Sys.argv |> function
  92. [| _; path |] ->
  93. list_mlfiles path |> List.iter ~f:ocp_indent;
  94. printf "Done\n%!";
  95. exit_ok ()
  96. | _ -> printf "Usage: %s [directory containing file to indent]\n"
  97. Sys.executable_name;
  98. exit_arg_lack ()
  99. ;;