123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- (******************************************************************************)
- (* 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;;
- (* Function allowing to set the title of the current terminal windows
- * XXX Maybe better in some lib *)
- let set_title new_title =
- (* Use echo command to set term title *)
- Sys.command (sprintf "echo -en \"\\033]0;%s\\a\"" new_title)
- |> function | 0 -> () | _ -> sprintf "Error while setting terminal title"
- |> Messages.warning
- ;;
- (* Function to return the less launched command, at least the first one *)
- (* TODO Test it *)
- (* Log is a list of entry (commands) asociated with numbers *)
- let less_launched (log : (string * int) list) =
- let max = Const.default_launch in (* Number of launch, maximum *)
- (* Return smallest, n is the smaller key *)
- let entries_by_number = List.Assoc.inverse log in
- List.min_elt ~cmp:(fun (n,_) (n',_) -> Int.compare n n') entries_by_number
- |> (function Some (min,cmd) ->
- if min <= max
- then Some cmd
- else None
- | None -> assert false) (* XXX Use exception here? *)
- ;;
- (* Get the command corresponding to a number *)
- let num_cmd_to_cmd ~rc n =
- List.nth rc.Settings_t.progs n
- ;;
- (* Function to determinate what is the next command to
- * execute. It takes the current number from tmp file. *)
- let what_next ~rc ~tmp =
- Tmp_file.get_accurate_log ~rc ~tmp
- (* Find the less launched, with order *)
- |> less_launched
- |> function
- (* If in range of the list, return the corresponding command else return
- * an empty string after displaying error. *)
- | Some x -> set_title x; x
- | None ->
- Messages.ok "All has been launched!";
- Messages.tips "You can reset with '-r'";
- (* Return empty string *)
- ""
- ;;
- (* Display an error message if command can't run
- * if 0 status, do nothing
- * else display status number *)
- let display_result command status =
- match status with
- | 0 -> (* No problem, do nothing *) ()
- | _ -> (* Problem occur, display it *)
- sprintf "Problem while running: '%s'\nExited with code: %i\n"
- command status
- |> Messages.warning
- ;;
- (* Execute some command and log it *)
- let execute ?(display=true) cmd =
- Tmp_file.log ~cmd ~func:((+) 1) ();
- if display then
- Messages.ok cmd;
- (* We can remove lock file since number in tmp_file has been incremented *)
- Lock.remove ();
- Sys.command cmd
- |> display_result cmd (* Make it settable in rc file *)
- ;;
|