fix-indent.ml 4.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #!/usr/bin/env coretop
  2. (******************************************************************************)
  3. (* Copyright © Joly Clément, 2016 *)
  4. (* *)
  5. (* leowzukw@vmail.me *)
  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 ("-e " ^ path ^ " "))
  54. |> String.concat
  55. ;;
  56. (* List ml files, basic regexp, should be enough *)
  57. let list_mlfiles path =
  58. (* 1st grep: select ocaml files,
  59. * 2nd grep: remove symlinks and ignored files *)
  60. sprintf "tree -if %s | grep -e '.*\\.ml$' | grep -v -e '.* -> .*' %s"
  61. path ignored
  62. |> (fun cmd -> print_endline cmd; cmd)
  63. |> Unix.open_process_in
  64. |> In_channel.input_all
  65. |> String.split ~on:'\n'
  66. |> List.filter ~f:(function "" -> false | _ -> true)
  67. ;;
  68. (* Call ocp-indent for indentation *)
  69. let ocp_indent file =
  70. let args = "--inplace" in
  71. String.concat [ "ocp-indent "; args; " "; file]
  72. |> Sys.command
  73. |> function
  74. | 0 -> printf "File: '%s' ok\n" file
  75. | error -> printf "Error with file: '%s'; code: %i\n%!" file error;
  76. exit_ocp_indent_error ()
  77. ;;
  78. let () =
  79. Sys.argv |> function
  80. [| _; path |] ->
  81. list_mlfiles path |> List.iter ~f:ocp_indent;
  82. printf "Done\n%!";
  83. exit_ok ()
  84. | _ -> printf "Usage: %s [directory containing file to indent]\n"
  85. Sys.executable_name;
  86. exit_arg_lack ()
  87. ;;