1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- (******************************************************************************)
- (* Copyright © Joly Clément, 2014-2015 *)
- (* *)
- (* 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
- Settings_t.progs = (new_list rc.Settings_t.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 ()
- ;;
|