|
@@ -0,0 +1,68 @@
|
|
|
+(******************************************************************************)
|
|
|
+(* Copyright © Joly Clément, 2014 *)
|
|
|
+(* *)
|
|
|
+(* leowzukw@vmail.me *)
|
|
|
+(* *)
|
|
|
+(* Ce logiciel est un programme informatique servant à exécuter *)
|
|
|
+(* automatiquement des programmes à l'ouverture du terminal. *)
|
|
|
+(* *)
|
|
|
+(* Ce logiciel est régi par la licence CeCILL soumise au droit français et *)
|
|
|
+(* respectant les principes de diffusion des logiciels libres. Vous pouvez *)
|
|
|
+(* utiliser, modifier et/ou redistribuer ce programme sous les conditions *)
|
|
|
+(* de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA *)
|
|
|
+(* sur le site "http://www.cecill.info". *)
|
|
|
+(* *)
|
|
|
+(* En contrepartie de l'accessibilité au code source et des droits de copie, *)
|
|
|
+(* de modification et de redistribution accordés par cette licence, il n'est *)
|
|
|
+(* offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons, *)
|
|
|
+(* seule une responsabilité restreinte pèse sur l'auteur du programme, le *)
|
|
|
+(* titulaire des droits patrimoniaux et les concédants successifs. *)
|
|
|
+(* *)
|
|
|
+(* A cet égard l'attention de l'utilisateur est attirée sur les risques *)
|
|
|
+(* associés au chargement, à l'utilisation, à la modification et/ou au *)
|
|
|
+(* développement et à la reproduction du logiciel par l'utilisateur étant *)
|
|
|
+(* donné sa spécificité de logiciel libre, qui peut le rendre complexe à *)
|
|
|
+(* manipuler et qui le réserve donc à des développeurs et des professionnels *)
|
|
|
+(* avertis possédant des connaissances informatiques approfondies. Les *)
|
|
|
+(* utilisateurs sont donc invités à charger et tester l'adéquation du *)
|
|
|
+(* logiciel à leurs besoins dans des conditions permettant d'assurer la *)
|
|
|
+(* sécurité de leurs systèmes et ou de leurs données et, plus généralement, *)
|
|
|
+(* à l'utiliser et l'exploiter dans les mêmes conditions de sécurité. *)
|
|
|
+(* *)
|
|
|
+(* Le fait que vous puissiez accéder à cet en-tête signifie que vous avez *)
|
|
|
+(* pris connaissance de la licence CeCILL, et que vous en avez accepté les *)
|
|
|
+(* termes. *)
|
|
|
+(******************************************************************************)
|
|
|
+
|
|
|
+open Core.Std;;
|
|
|
+
|
|
|
+(* Module to add command without editing the rc file directly *)
|
|
|
+
|
|
|
+(* Function to create a new list augmented by some commands *)
|
|
|
+let new_list current_list position new_items =
|
|
|
+ match position with
|
|
|
+ | None -> List.append current_list new_items
|
|
|
+ | Some n -> (* If a number is given, add commands after position n by
|
|
|
+ splitting the list and concatenating all. List.split_n works like this :
|
|
|
+ * #let l1 = [1;2;3;4;5;6] in
|
|
|
+ * # List.split_n l1 2;;
|
|
|
+ * - : int list * int list = ([1; 2], [3; 4; 5; 6]) *)
|
|
|
+ let l_begin,l_end = List.split_n current_list n in
|
|
|
+ List.concat [ l_begin ; new_items ; l_end ]
|
|
|
+;;
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+(* Function which add the commands (one per line) ridden on stdin to the rc
|
|
|
+ * file, and then display th new configuration *)
|
|
|
+let run ~(rc:File_com.t) position =
|
|
|
+ (* Read command from stdin, as a list. fix_win_eol removes \r\n *)
|
|
|
+ let cmd_list = In_channel.input_lines ~fix_win_eol:true In_channel.stdin in
|
|
|
+ (* Create an updated rc file *)
|
|
|
+ let updated_rc = { rc with progs = (new_list rc.progs position cmd_list)} in
|
|
|
+ File_com.write updated_rc;
|
|
|
+ (* Display the result *)
|
|
|
+ let reread_rc = File_com.init_rc () in
|
|
|
+ List_rc.run ~rc:reread_rc
|
|
|
+;;
|
|
|
+
|