tmp_file.ml 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. (******************************************************************************)
  2. (* Copyright © Joly Clément, 2014 *)
  3. (* *)
  4. (* leowzukw@vmail.me *)
  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. (* Type of the values *)
  38. type t = Tmp_biniou_t.tmp_file;;
  39. (* Function to write the tmp file *)
  40. let write (tmp_file:t) =
  41. (* Short name *)
  42. let name = Const.tmp_file in
  43. let biniou_tmp = Tmp_biniou_b.string_of_tmp_file tmp_file in
  44. Out_channel.write_all name ~data:biniou_tmp
  45. ;;
  46. (* XXX Using and keyword because each function can call each other *)
  47. (* Function to read the tmp file *)
  48. let rec read () =
  49. (* Short name *)
  50. let name = Const.tmp_file in
  51. (* Get the string corresponding to the file *)
  52. let file_content = In_channel.read_all name in
  53. try
  54. Tmp_biniou_b.tmp_file_of_string file_content
  55. (* In previous version, the JSON format was used, otherwise the file can
  56. * have a bad format. In this case, the Ag_ob_run.Error("Read error (1)")
  57. * exeption is throw. We catch it here *)
  58. with _ ->
  59. (* If file is not in the right format, delete it and create a new one.
  60. * Then, read it *)
  61. Messages.ok "Reinitialises tmp file\n";
  62. Sys.remove name;
  63. create_tmp_file ();
  64. read ()
  65. (* Function to create the tmp file *)
  66. and create_tmp_file () =
  67. Tmp_biniou_v.create_tmp_file ~command:[] ~number:0 ()
  68. (* Convert it to biniou *)
  69. |> write
  70. ;;
  71. (* Function to open tmp file *)
  72. let rec init () =
  73. (* If file do not exists, create it *)
  74. let file_exists = Sys.file_exists Const.tmp_file in
  75. match file_exists with
  76. | `No -> create_tmp_file ();
  77. init ()
  78. | `Unknown -> begin
  79. Sys.remove Const.tmp_file;
  80. init ()
  81. end
  82. | `Yes -> read ()
  83. ;;
  84. (* Verify that the value exist *)
  85. let verify_key_exist ~key entry =
  86. if entry = key then
  87. true
  88. else
  89. false
  90. ;;
  91. (* Return true if a program is in the rc file *)
  92. let rec is_prog_in_rc list_from_rc_file program =
  93. match list_from_rc_file with
  94. (* | None -> is_prog_in_rc program ~liste_from_rc_file:rc_content.progs *)
  95. | [] -> false
  96. | hd :: tl -> if hd = program then true else is_prog_in_rc tl program
  97. ;;
  98. (* Log when a program has been launched in a file in /tmp
  99. ~func is the function applied to the value *)
  100. let log ?(func= (+) 1 ) () =
  101. (* Make sure that file exists, otherwise strange things appears *)
  102. let file = init () in
  103. (* Write the file with the new value *)
  104. write { file with Tmp_biniou_t.number = (func file.Tmp_biniou_t.number)}
  105. ;;
  106. (* Return current number *)
  107. let get_current () =
  108. (* Read tmp file *)
  109. let tmp_file = init () in
  110. (* Return the number *)
  111. tmp_file.Tmp_biniou_t.number;
  112. ;;
  113. (* Reset command number in two ways :
  114. * if cmd_num is 0, delete tmp file, to reinitialise program
  115. * if cmd_num is 0>, set to this value
  116. * else display an error message *)
  117. let reset cmd_num =
  118. let n = get_current () in
  119. sprintf "Last N was %i" n
  120. |> Messages.info;
  121. sprintf "Restore with 'oclaunch -r %i'" n
  122. |> Messages.tips;
  123. match cmd_num with
  124. | 0 -> (*Verify that file exist and if not, delete it *)
  125. Sys.file_exists Const.tmp_file
  126. |> (function
  127. | `No -> Messages.ok "Tmp file already removed"
  128. | `Unknown -> Messages.warning "Error while removing tmp file"
  129. | `Yes -> Sys.remove Const.tmp_file; Messages.ok "Tmp file removed"
  130. )
  131. | n when n > 0 ->
  132. (* Set the number *)
  133. log ~func:((fun a b -> a) n) ();
  134. sprintf "Tmp file reseted to %i" n |> Messages.ok
  135. | _ -> Messages.warning "Invalid number"
  136. ;;