exec_cmd.ml 4.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  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. (* Function allowing to set the title of the current terminal windows
  38. * XXX Maybe better in some lib *)
  39. let set_title new_title =
  40. (* Use echo command to set term title *)
  41. Sys.command (sprintf "echo -en \"\\033]0;%s\\a\"" new_title)
  42. |> function | 0 -> () | _ -> sprintf "Error while setting terminal title"
  43. |> Messages.warning
  44. ;;
  45. (* Function to return the corresponding command to a number *)
  46. let num_cmd_to_cmd ~cmd_list number =
  47. (* List.nth return None if out of the list *)
  48. List.nth cmd_list number
  49. |> function
  50. (* If in range of the list, return the corresponding command else return
  51. * an empty string after displaying error. *)
  52. | Some x -> set_title x; x
  53. | None ->
  54. Messages.ok "All has been launched!";
  55. Messages.tips "You can reset with '-r'";
  56. (* Return empty string *)
  57. ""
  58. ;;
  59. (* Function to determinate what is the next command to
  60. * execute. It take the current number from tmp file. *)
  61. let what_next ~cmd_list =
  62. let tmp_file = Tmp_file.init () in
  63. num_cmd_to_cmd ~cmd_list:cmd_list tmp_file.Tmp_biniou_t.number
  64. ;;
  65. (* Display an error message if command can't run
  66. * if 0 status, do nothing
  67. * else display status number *)
  68. let display_result command status =
  69. match status with
  70. | 0 -> (* No problem, do nothing *) ()
  71. | _ -> (* Problem occur, display it *)
  72. sprintf "Problem while running: '%s'\nExited with code: %i\n"
  73. command status
  74. |> Messages.warning
  75. ;;
  76. (* Execute some command and log it *)
  77. let execute ?(display=true) cmd =
  78. Tmp_file.log ~func:((+) 1) ();
  79. if display then
  80. Messages.ok cmd;
  81. (* We can remove lock file since number in tmp_file has been incremented *)
  82. Lock.remove ();
  83. Sys.command cmd
  84. |> display_result cmd (* Make it settable in rc file *)
  85. ;;