lock.ml 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. (******************************************************************************)
  2. (* Copyright © Joly Clément, 2014-2015 *)
  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. (* Module to mange locking, when another instance of OcLaunch is running *)
  38. (* Status of the locker *)
  39. type lock_status =
  40. Locked
  41. | Free
  42. | Error
  43. ;;
  44. (* Name of the lock file *)
  45. (* TODO Put it in Const *)
  46. let lock_name = "/tmp/.ocl.lock";;
  47. (* Create lock file *)
  48. let lock () =
  49. try Out_channel.write_all lock_name ~data:"OcLaunch is running and did not finish."
  50. with Sys_error msg -> Messages.debug "Couldn't write in lock file."
  51. ;;
  52. (* To know if we are locked, return None if there is no locker, *)
  53. let status () =
  54. match Sys.file_exists lock_name with
  55. `Yes -> Locked
  56. | `No -> Free
  57. | `Unknown -> Error
  58. ;;
  59. (* Remove the lock file *)
  60. let remove () =
  61. Sys.remove lock_name
  62. ;;
  63. (* Pause the program until lock file is removed, until argument is the second *)
  64. (* We hide loop argument from outside, since it's used internally, to
  65. * count number of passages and make until argument useful *)
  66. let wait ?(until=10) ?(delay=1) () =
  67. let rec wait_loop loop =
  68. (* Actually wait, returning what has been done (Something or Nothing) *)
  69. sprintf "Waiting for locker, loop: %i" loop
  70. |> Messages.debug;
  71. match status () with
  72. Locked ->
  73. if loop < until; then (* < because we start from 0 *)
  74. begin
  75. Unix.sleep delay;
  76. wait_loop (succ loop)
  77. end
  78. else
  79. None
  80. | Free -> Some (lock ())
  81. | Error -> failwith "Problem with lock file"
  82. in
  83. wait_loop 0
  84. |> (function
  85. None ->
  86. Messages.warning "Removing lock file, ran out of patience";
  87. remove ();
  88. (* We need to lock back, since it's the purpose of this function *)
  89. lock ()
  90. | _ -> ()
  91. )
  92. ;;