tools.ml 3.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. (******************************************************************************)
  2. (* Copyright © Joly Clément, 2015 *)
  3. (* *)
  4. (* leowzukw@oclaunch.eu.org *)
  5. (* *)
  6. (* Ce logiciel est un programme informatique servant à exécuter *)
  7. (* automatiquement des programmes à l'ouverture du terminal. *)
  8. (* *)
  9. (* Ce logiciel est régi par la licence CeCILL soumise au droit français et *)
  10. (* respectant les principes de diffusion des logiciels libres. Vous pouvez *)
  11. (* utiliser, modifier et/ou redistribuer ce programme sous les conditions *)
  12. (* de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA *)
  13. (* sur le site "http://www.cecill.info". *)
  14. (* *)
  15. (* En contrepartie de l'accessibilité au code source et des droits de copie, *)
  16. (* de modification et de redistribution accordés par cette licence, il n'est *)
  17. (* offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons, *)
  18. (* seule une responsabilité restreinte pèse sur l'auteur du programme, le *)
  19. (* titulaire des droits patrimoniaux et les concédants successifs. *)
  20. (* *)
  21. (* A cet égard l'attention de l'utilisateur est attirée sur les risques *)
  22. (* associés au chargement, à l'utilisation, à la modification et/ou au *)
  23. (* développement et à la reproduction du logiciel par l'utilisateur étant *)
  24. (* donné sa spécificité de logiciel libre, qui peut le rendre complexe à *)
  25. (* manipuler et qui le réserve donc à des développeurs et des professionnels *)
  26. (* avertis possédant des connaissances informatiques approfondies. Les *)
  27. (* utilisateurs sont donc invités à charger et tester l'adéquation du *)
  28. (* logiciel à leurs besoins dans des conditions permettant d'assurer la *)
  29. (* sécurité de leurs systèmes et ou de leurs données et, plus généralement, *)
  30. (* à l'utiliser et l'exploiter dans les mêmes conditions de sécurité. *)
  31. (* *)
  32. (* Le fait que vous puissiez accéder à cet en-tête signifie que vous avez *)
  33. (* pris connaissance de la licence CeCILL, et que vous en avez accepté les *)
  34. (* termes. *)
  35. (******************************************************************************)
  36. open Core.Std;;
  37. (* Various tools for the program *)
  38. (* Printing methods, common to all function in this modules *)
  39. let printing = Messages.debug;;
  40. (* Spying expression, template for the others. Takes the string corespondig to
  41. * the original value and return the original one *)
  42. let spy orig (value : string) =
  43. printing value;
  44. orig
  45. ;;
  46. (* Functions exposed to spy special types *)
  47. let spy1_int i =
  48. sprintf "%i" i
  49. |> spy i
  50. ;;
  51. let spy1_int_option io =
  52. let i = io |> (function
  53. None -> "None"
  54. | Some i -> sprintf "Some %i" i)
  55. in
  56. spy io i
  57. ;;
  58. let spy1_string str =
  59. spy str str
  60. ;;
  61. let spy1_float f =
  62. sprintf "%f" f
  63. |> spy f
  64. ;;
  65. let spy1_list ~f list =
  66. let list_str = List.map list ~f:(fun element ->
  67. sprintf "\"%s\"; " (f element))
  68. in
  69. "[ " ^ (String.concat list_str) ^ " ]"
  70. |> printing;
  71. list
  72. ;;
  73. let spy1_log (log : (string * int) list) =
  74. let log_str = List.map log ~f:(fun (s, i) ->
  75. sprintf "( \"%s\", %i ); " s i)
  76. in
  77. "[ " ^ (String.concat log_str) ^ " ]"
  78. |> printing;
  79. log
  80. ;;
  81. let spy1_rc rc =
  82. failwith "Not implemented"
  83. ;;