const.ml 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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. (* File to store configuration variables *)
  37. open Core.Std;;
  38. (* We need to be as lazy as possible, since sometimes, some varible are not
  39. * needed and thus, it's useless the raise an exception. *)
  40. (* General function to get environment variables
  41. * default: default value for the variable, if not set *)
  42. let get_var: ?default:(string lazy_t) -> string lazy_t -> string lazy_t =
  43. fun ?default name ->
  44. let open Lazy in
  45. let msg =
  46. name >>| fun name ->
  47. sprintf "ERROR: Could not get $%s. Please consider setting it." name
  48. in
  49. (* Get the var *)
  50. name >>= fun name ->
  51. Sys.getenv name
  52. |> (function
  53. | Some x -> lazy x
  54. | None -> Option.value_exn ~message:(Lazy.force msg) default)
  55. ;;
  56. (* Get current home *)
  57. let home =
  58. get_var (lazy "HOME")
  59. ;;
  60. (* Get default editor *)
  61. let editor = (* If editor is not set, it gets "", but an exception is raised *)
  62. get_var (lazy "EDITOR")
  63. ;;
  64. (* Level of verbosity, used by Messages module *)
  65. let verbosity =
  66. ref (get_var ~default:(lazy "4") (lazy "OC_VERB")
  67. |> Lazy.force
  68. |> Int.of_string);;
  69. (* Whether we ask for confirmation, used by Messages module *)
  70. (* None -> ask, no preference defined,
  71. * Some true -> assume Yes
  72. * Some false -> assume No *)
  73. let ask_unset = -1;; (* Constant to leave preference unset *)
  74. let ask =
  75. ref (get_var ~default:(lazy (Int.to_string ask_unset)) (lazy "OC_YES")
  76. |> Lazy.force
  77. |> Int.of_string
  78. (* XXX Hacking with get_var, using
  79. * -1 for None, 0 for Some false and 1 for Some true *)
  80. |> function
  81. | unset when unset = ask_unset -> None | 0 -> Some false | 1 -> Some true
  82. | _ -> None
  83. )
  84. ;;
  85. (* Use do not use colors, 0 -> false, anything -> true *)
  86. let no_color =
  87. ref (get_var ~default:(lazy "0") (lazy "OC_NOCOLOR")
  88. |> Lazy.force
  89. |> (function "0" -> false | _ -> true)
  90. )
  91. ;;
  92. (* Default place to read settings *)
  93. let rc_file_default =
  94. let internal_default : string lazy_t =
  95. (* Default value, if no value is given (for instance as
  96. command line argument), or no environnement variable is set *)
  97. Lazy.(home >>| fun home -> home ^ "/" ^ ".oclaunch_rc.json")
  98. in
  99. get_var ~default:internal_default (lazy "OC_RC")
  100. ;;
  101. (* Current place to read settings, maybe modified from command line argument *)
  102. let rc_file = ref rc_file_default;;
  103. (* Set tmp file, in witch stock launches, in biniou format *)
  104. let tmp_file =
  105. get_var ~default:(lazy ("/tmp/.oclaunch_trace.dat")) (lazy "OC_TMP")
  106. |> Lazy.force
  107. ;;
  108. (* Default max number for launch *)
  109. let default_launch = 1;; (* TODO set it in rc file *)