add_command.ml 4.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  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 add command without editing the rc file directly *)
  38. (* Function to create a new list augmented by some commands *)
  39. let new_list current_list position new_items =
  40. match position with
  41. | None -> List.append current_list new_items
  42. | Some n ->
  43. (* If a number is given, add commands after position n by
  44. splitting the list and concatenating all. List.split_n works like this:
  45. * #let l1 = [1;2;3;4;5;6] in
  46. * # List.split_n l1 2;;
  47. * - : int list * int list = ([1; 2], [3; 4; 5; 6]) *)
  48. let l_begin,l_end = List.split_n current_list n in
  49. List.concat [ l_begin ; new_items ; l_end ]
  50. ;;
  51. (* Function which add the commands (one per line) ridden on stdin to the rc
  52. * file, and then display th new configuration *)
  53. let run ~(rc:File_com.t) position =
  54. (* Read command from stdin, as a list. fix_win_eol removes \r\n *)
  55. let cmd_list = In_channel.input_lines ~fix_win_eol:true In_channel.stdin in
  56. (* Create an updated rc file *)
  57. let updated_rc =
  58. { rc with
  59. Settings_t.progs = (new_list rc.Settings_t.progs position cmd_list)
  60. }
  61. in
  62. File_com.write updated_rc;
  63. (* Display the result *)
  64. let reread_rc = File_com.init_rc () in
  65. List_rc.run ~rc:reread_rc ()
  66. ;;