397 lines
18 KiB
OCaml
397 lines
18 KiB
OCaml
(**************************************************************************)
|
|
(* *)
|
|
(* OCaml *)
|
|
(* *)
|
|
(* Maxence Guesdon, projet Cristal, INRIA Rocquencourt *)
|
|
(* *)
|
|
(* Copyright 2001 Institut National de Recherche en Informatique et *)
|
|
(* en Automatique. *)
|
|
(* *)
|
|
(* All rights reserved. This file is distributed under the terms of *)
|
|
(* the GNU Lesser General Public License version 2.1, with the *)
|
|
(* special exception on linking described in the file LICENSE. *)
|
|
(* *)
|
|
(**************************************************************************)
|
|
|
|
(** The messages of the application. *)
|
|
|
|
let ok = "Ok"
|
|
let software = "OCamldoc"
|
|
let config_version = Config.version
|
|
let magic = config_version^""
|
|
|
|
(** Messages for command line *)
|
|
|
|
let usage = "Usage: "^(Sys.argv.(0))^" [options] <files>\n"
|
|
let options_are = "Options are:"
|
|
let latex_only = "(LaTeX only)"
|
|
let texi_only = "(TeXinfo only)"
|
|
let latex_texi_only = "(LaTeX and TeXinfo only)"
|
|
let html_only = "(HTML only)"
|
|
let html_latex_only = "(HTML and LaTeX only)"
|
|
let html_latex_texi_only = "(HTML, LaTeX and TeXinfo only)"
|
|
let man_only = "(man only)"
|
|
let option_impl ="<file> Consider <file> as a .ml file"
|
|
let option_intf ="<file> Consider <file> as a .mli file"
|
|
let option_text ="<file> Consider <file> as a .txt file"
|
|
let display_custom_generators_dir = "Display custom generators standard directory and exit"
|
|
let add_load_dir = "<dir> Add the given directory to the search path for custom\n"^
|
|
"\t\tgenerators"
|
|
let load_file = "<file.cm[o|a|xs]> Load file defining a new documentation generator"
|
|
let werr = " Treat ocamldoc warnings as errors"
|
|
let hide_warnings = " do not print ocamldoc warnings"
|
|
let target_dir = "<dir> Generate files in directory <dir>, rather than in current\n"^
|
|
"\t\tdirectory (for man and HTML generators)"
|
|
let dump = "<file> Dump collected information into <file>"
|
|
let load = "<file> Load information from <file> ; may be used several times"
|
|
let css_style = "<file> Use content of <file> as CSS style definition "^html_only
|
|
let index_only = " Generate index files only "^html_only
|
|
let colorize_code = " Colorize code even in documentation pages "^html_only
|
|
let html_short_functors = " Use short form to display functor types "^html_only
|
|
let charset c = Printf.sprintf
|
|
"<s> Add information about character encoding being s\n\t\t(default is %s)"
|
|
c
|
|
let generate_html = " Generate HTML documentation"
|
|
let generate_latex = " Generate LaTeX documentation"
|
|
let generate_texinfo = " Generate TeXinfo documentation"
|
|
let generate_man = " Generate man pages"
|
|
let generate_dot = " Generate dot code of top modules dependencies"
|
|
|
|
let option_not_in_native_code op = "Option "^op^" not available in native code version."
|
|
|
|
let default_out_file = "ocamldoc.out"
|
|
let out_file =
|
|
"<file> Set the output file name, used by texi, latex and dot generators\n"^
|
|
"\t\t(default is "^default_out_file^")\n"^
|
|
"\t\tor the prefix of index files for the HTML generator\n"^
|
|
"\t\t(default is index)"
|
|
|
|
let dot_include_all =
|
|
" Include all modules in the dot output, not only the\n"^
|
|
"\t\tmodules given on the command line"
|
|
let dot_types = " Generate dependency graph for types instead of modules"
|
|
let default_dot_colors =
|
|
[ [ "darkturquoise" ; "darkgoldenrod2" ; "cyan" ; "green" ; ] ;
|
|
[ "magenta" ; "yellow" ; "burlywood1" ; "aquamarine" ; "floralwhite" ; "lightpink" ] ;
|
|
[ "lightblue" ; "mediumturquoise" ; "salmon" ; "slategray3"] ;
|
|
]
|
|
|
|
let dot_colors =
|
|
" <c1,c2,...,cn>\n"^
|
|
"\t\tUse colors c1,c1,...,cn in the dot output\n"^
|
|
"\t\t(default list is "^
|
|
(String.concat ",\n\t\t" (List.map (String.concat ",") default_dot_colors))^")"
|
|
|
|
let dot_reduce =
|
|
" Perform a transitive reduction on the selected dependency graph\n"^
|
|
"\t\tbefore the dot output"
|
|
|
|
let man_mini = " Generate man pages only for modules, module types, classes\n"^
|
|
"\t\tand class types "^man_only
|
|
let default_man_section = "3"
|
|
let man_section = "<section> Use <section> in man page files "^
|
|
"(default is "^default_man_section^") "^man_only^"\n"
|
|
|
|
let default_man_suffix = default_man_section^"o"
|
|
let man_suffix = "<suffix> Use <suffix> for man page files "^
|
|
"(default is "^default_man_suffix^") "^man_only^"\n"
|
|
|
|
let option_title = "<title> Use <title> as title for the generated documentation"
|
|
let option_intro =
|
|
"<file> Use content of <file> as ocamldoc text to use as introduction\n"^
|
|
"\t\t"^(html_latex_texi_only)
|
|
let with_parameter_list = " Display the complete list of parameters for functions and\n"^
|
|
"\t\tmethods "^html_only
|
|
let hide_modules = "<M1,M2.M3,...> Hide the given complete module names in generated doc"
|
|
let no_header = " Suppress header in generated documentation\n\t\t"^latex_texi_only
|
|
let no_trailer = " Suppress trailer in generated documentation\n\t\t"^latex_texi_only
|
|
let separate_files = " Generate one file per toplevel module "^latex_only
|
|
let latex_title ref_titles =
|
|
"n,style Associate {n } to the given sectionning style\n"^
|
|
"\t\t(e.g. 'section') in the latex output "^latex_only^"\n"^
|
|
"\t\tDefault sectionning is:\n\t\t"^
|
|
(String.concat "\n\t\t"
|
|
(List.map (fun (n,t) -> Printf.sprintf " %d -> %s" n t) !ref_titles))
|
|
|
|
let default_latex_value_prefix = "val:"
|
|
let latex_value_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of values.\n"^
|
|
"\t\t(default is \""^default_latex_value_prefix^"\")"
|
|
|
|
let default_latex_type_prefix = "type:"
|
|
let latex_type_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of types.\n"^
|
|
"\t\t(default is \""^default_latex_type_prefix^"\")"
|
|
|
|
let default_latex_type_elt_prefix = "typeelt:"
|
|
let latex_type_elt_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of type elements.\n"^
|
|
"\t\t(default is \""^default_latex_type_elt_prefix^"\")"
|
|
|
|
let default_latex_extension_prefix = "extension:"
|
|
let latex_extension_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of extensions.\n"^
|
|
"\t\t(default is \""^default_latex_extension_prefix^"\")"
|
|
|
|
let default_latex_exception_prefix = "exception:"
|
|
let latex_exception_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of exceptions.\n"^
|
|
"\t\t(default is \""^default_latex_exception_prefix^"\")"
|
|
|
|
let default_latex_module_prefix = "module:"
|
|
let latex_module_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of modules.\n"^
|
|
"\t\t(default is \""^default_latex_module_prefix^"\")"
|
|
|
|
let default_latex_module_type_prefix = "moduletype:"
|
|
let latex_module_type_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of module types.\n"^
|
|
"\t\t(default is \""^default_latex_module_type_prefix^"\")"
|
|
|
|
let default_latex_class_prefix = "class:"
|
|
let latex_class_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of classes.\n"^
|
|
"\t\t(default is \""^default_latex_class_prefix^"\")"
|
|
|
|
let default_latex_class_type_prefix = "classtype:"
|
|
let latex_class_type_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of class types.\n"^
|
|
"\t\t(default is \""^default_latex_class_type_prefix^"\")"
|
|
|
|
let default_latex_attribute_prefix = "val:"
|
|
let latex_attribute_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of attributes.\n"^
|
|
"\t\t(default is \""^default_latex_attribute_prefix^"\")"
|
|
|
|
let default_latex_method_prefix = "method:"
|
|
let latex_method_prefix =
|
|
"<string>\n"^
|
|
"\t\tUse <string> as prefix for the LaTeX labels of methods.\n"^
|
|
"\t\t(default is \""^default_latex_method_prefix^"\")"
|
|
|
|
let no_toc = " Do not generate table of contents "^latex_only
|
|
let sort_modules = " Sort the list of top modules before generating the documentation"
|
|
let no_stop = " Do not stop at (**/**) comments"
|
|
let no_custom_tags = " Do not allow custom @-tags"
|
|
let remove_stars = " Remove beginning blanks of comment lines, until the first '*'"
|
|
let keep_code = " Always keep code when available"
|
|
let inverse_merge_ml_mli = " Inverse implementations and interfaces when merging"
|
|
let no_filter_with_module_constraints = "Do not filter module elements using module type constraints"
|
|
let merge_description = ('d', "merge description")
|
|
let merge_author = ('a', "merge @author")
|
|
let merge_version = ('v', "merge @version")
|
|
let merge_see = ('l', "merge @see")
|
|
let merge_since = ('s', "merge @since")
|
|
let merge_before = ('b', "merge @before")
|
|
let merge_deprecated = ('o', "merge @deprecated")
|
|
let merge_param = ('p', "merge @param")
|
|
let merge_raised_exception = ('e', "merge @raise")
|
|
let merge_return_value = ('r', "merge @return")
|
|
let merge_custom = ('c', "merge custom @-tags")
|
|
let merge_all = ('A', "merge all")
|
|
|
|
let no_index = " Do not build index for Info files "^texi_only
|
|
let esc_8bits = " Escape accentuated characters in Info files "^texi_only
|
|
let info_section = " Specify section of Info directory "^texi_only
|
|
let info_entry = " Specify Info directory entry "^texi_only
|
|
|
|
let options_can_be = "<options> can be one or more of the following characters:"
|
|
let string_of_options_list l =
|
|
List.fold_left (fun acc -> fun (c, m) -> acc^"\n\t\t"^(String.make 1 c)^" "^m)
|
|
""
|
|
l
|
|
|
|
let merge_options =
|
|
"<options> specify merge options between .mli and .ml\n\t\t"^
|
|
options_can_be^
|
|
(string_of_options_list
|
|
[ merge_description ;
|
|
merge_author ;
|
|
merge_version ;
|
|
merge_see ;
|
|
merge_since ;
|
|
merge_before ;
|
|
merge_deprecated ;
|
|
merge_param ;
|
|
merge_raised_exception ;
|
|
merge_return_value ;
|
|
merge_custom ;
|
|
merge_all ]
|
|
)
|
|
|
|
let help = " Display this list of options"
|
|
|
|
|
|
(** Error and warning messages *)
|
|
|
|
let warning = "Warning"
|
|
|
|
let error_location file l c =
|
|
Printf.sprintf "File \"%s\", line %d, character %d:\n" file l c
|
|
|
|
let bad_magic_number =
|
|
"Bad magic number for this ocamldoc dump!\n"^
|
|
"This dump was not created by this version of OCamldoc."
|
|
|
|
let not_a_module_name s = s^" is not a valid module name"
|
|
let load_file_error f e = "Error while loading file "^f^":\n"^e
|
|
let wrong_format s = "Wrong format for \""^s^"\""
|
|
let errors_occured n = (string_of_int n)^" error(s) encountered"
|
|
let parse_error = "Parse error"
|
|
let text_parse_error l c s =
|
|
let lines = Str.split (Str.regexp_string "\n") s in
|
|
(List.nth lines l) ^ "\n" ^ (String.make c ' ') ^ "^"
|
|
|
|
let file_not_found_in_paths paths name =
|
|
Printf.sprintf "No file %s found in the load paths: \n%s"
|
|
name
|
|
(String.concat "\n" paths)
|
|
|
|
let tag_not_handled tag = "Tag @"^tag^" not handled by this generator"
|
|
let should_escape_at_sign = "The character @ has a special meaning in ocamldoc comments, for commands such as @raise or @since. \
|
|
If you want to write a single @, you must escape it as \\@."
|
|
let bad_tree = "Incorrect tree structure."
|
|
let not_a_valid_tag s = s^" is not a valid tag."
|
|
let fun_without_param f = "Function "^f^" has no parameter.";;
|
|
let method_without_param f = "Method "^f^" has no parameter.";;
|
|
let anonymous_parameters f = "Function "^f^" has anonymous parameters."
|
|
let function_colon f = "Function "^f^": "
|
|
let implicit_match_in_parameter = "Parameters contain implicit pattern matching."
|
|
let unknown_extension f = "Unknown extension for file "^f^"."
|
|
let two_implementations name = "There are two implementations of module "^name^"."
|
|
let two_interfaces name = "There are two interfaces of module "^name^"."
|
|
let too_many_module_objects name = "There are too many interfaces/implementation of module "^name^"."
|
|
let extension_not_found_in_implementation ext m = "Extension "^ext^" was not found in implementation of module "^m^"."
|
|
let exception_not_found_in_implementation exc m = "Exception "^exc^" was not found in implementation of module "^m^"."
|
|
let type_not_found_in_implementation exc m = "Type "^exc^" was not found in implementation of module "^m^"."
|
|
let module_not_found_in_implementation m m2 = "Module "^m^" was not found in implementation of module "^m2^"."
|
|
let value_not_found_in_implementation v m = "Value "^v^" was not found in implementation of module "^m^"."
|
|
let class_not_found_in_implementation c m = "Class "^c^" was not found in implementation of module "^m^"."
|
|
let attribute_not_found_in_implementation a c = "Attribute "^a^" was not found in implementation of class "^c^"."
|
|
let method_not_found_in_implementation m c = "Method "^m^" was not found in implementation of class "^c^"."
|
|
let different_types t = "Definition of type "^t^" doesn't match from interface to implementation."
|
|
let attribute_type_not_found cl att = "The type of the attribute "^att^" could not be found in the signature of class "^cl^"."
|
|
let method_type_not_found cl met = "The type of the method "^met^" could not be found in the signature of class "^cl^"."
|
|
let module_not_found m m2 = "The module "^m2^" could not be found in the signature of module "^m^"."
|
|
let module_type_not_found m mt = "The module type "^mt^" could not be found in the signature of module "^m^"."
|
|
let value_not_found m v = "The value "^v^" could not be found in the signature of module "^m^"."
|
|
let extension_not_found m e = "The extension "^e^" could not be found in the signature of module "^m^"."
|
|
let exception_not_found m e = "The exception "^e^" could not be found in the signature of module "^m^"."
|
|
let type_not_found m t = "The type "^t^" could not be found in the signature of module "^m^"."
|
|
let class_not_found m c = "The class "^c^" could not be found in the signature of module "^m^"."
|
|
let class_type_not_found m c = "The class type "^c^" could not be found in the signature of module "^m^"."
|
|
let type_not_found_in_typedtree t = "Type "^t^" was not found in typed tree."
|
|
let extension_not_found_in_typedtree x = "Extension "^x^" was not found in typed tree."
|
|
let exception_not_found_in_typedtree e = "Exception "^e^" was not found in typed tree."
|
|
let module_type_not_found_in_typedtree mt = "Module type "^mt^" was not found in typed tree."
|
|
let module_not_found_in_typedtree m = "Module "^m^" was not found in typed tree."
|
|
let class_not_found_in_typedtree c = "Class "^c^" was not found in typed tree."
|
|
let class_type_not_found_in_typedtree ct = "Class type "^ct^" was not found in typed tree."
|
|
let inherit_classexp_not_found_in_typedtree n =
|
|
"Inheritance class expression number "^(string_of_int n)^" was not found in typed tree."
|
|
let attribute_not_found_in_typedtree att = "Class attribute "^att^" was not found in typed tree."
|
|
let method_not_found_in_typedtree met = "Class method "^met^" was not found in typed tree."
|
|
let misplaced_comment file pos =
|
|
Printf.sprintf "Misplaced special comment in file %s, character %d." file pos
|
|
|
|
let cross_module_not_found n = "Module "^n^" not found"
|
|
let cross_module_type_not_found n = "Module type "^n^" not found"
|
|
let cross_module_or_module_type_not_found n = "Module or module type "^n^" not found"
|
|
let cross_class_not_found n = "Class "^n^" not found"
|
|
let cross_class_type_not_found n = "class type "^n^" not found"
|
|
let cross_class_or_class_type_not_found n = "Class or class type "^n^" not found"
|
|
let cross_extension_not_found n = "Extension "^n^" not found"
|
|
let cross_exception_not_found n = "Exception "^n^" not found"
|
|
let cross_element_not_found n = "Element "^n^" not found"
|
|
let cross_method_not_found n = "Method "^n^" not found"
|
|
let cross_attribute_not_found n = "Attribute "^n^" not found"
|
|
let cross_section_not_found n = "Section "^n^" not found"
|
|
let cross_value_not_found n = "Value "^n^" not found"
|
|
let cross_type_not_found n = "Type "^n^" not found"
|
|
let cross_recfield_not_found n = Printf.sprintf "Record field %s not found" n
|
|
let cross_const_not_found n = Printf.sprintf "Constructor %s not found" n
|
|
|
|
let object_end = "object ... end"
|
|
let struct_end = "struct ... end"
|
|
let sig_end = "sig ... end"
|
|
|
|
let current_generator_is_not kind =
|
|
Printf.sprintf "Current generator is not a %s generator" kind
|
|
;;
|
|
|
|
(** Messages for verbose mode. *)
|
|
|
|
let analysing f = "Analysing file "^f^"..."
|
|
let merging = "Merging..."
|
|
let cross_referencing = "Cross referencing..."
|
|
let generating_doc = "Generating documentation..."
|
|
let loading f = "Loading "^f^"..."
|
|
let file_generated f = "File "^f^" generated."
|
|
let file_exists_dont_generate f =
|
|
"File "^f^" exists, we don't generate it."
|
|
|
|
(** Messages for documentation generation.*)
|
|
|
|
let modul = "Module"
|
|
let modules = "Modules"
|
|
let functors = "Functors"
|
|
let values = "Simple values"
|
|
let types = "Types"
|
|
let extensions = "Extensions"
|
|
let exceptions = "Exceptions"
|
|
let record = "Record"
|
|
let variant = "Variant"
|
|
let mutab = "mutable"
|
|
let functions = "Functions"
|
|
let parameters = "Parameters"
|
|
let abstract = "Abstract"
|
|
let functo = "Functor"
|
|
let clas = "Class"
|
|
let classes = "Classes"
|
|
let attributes = "Attributes"
|
|
let methods = "Methods"
|
|
let authors = "Author(s)"
|
|
let version = "Version"
|
|
let since = "Since"
|
|
let before = "Before"
|
|
let deprecated = "Deprecated."
|
|
let raises = "Raises"
|
|
let returns = "Returns"
|
|
let inherits = "Inherits"
|
|
let inheritance = "Inheritance"
|
|
let privat = "private"
|
|
let module_type = "Module type"
|
|
let class_type = "Class type"
|
|
let description = "Description"
|
|
let interface = "Interface"
|
|
let type_parameters = "Type parameters"
|
|
let class_types = "Class types"
|
|
let module_types = "Module types"
|
|
let see_also = "See also"
|
|
let documentation = "Documentation"
|
|
let index_of = "Index of"
|
|
let top = "Top"
|
|
let index_of_values = index_of^" values"
|
|
let index_of_extensions = index_of^" extensions"
|
|
let index_of_exceptions = index_of^" exceptions"
|
|
let index_of_types = index_of^" types"
|
|
let index_of_attributes = index_of^" class attributes"
|
|
let index_of_methods = index_of^" class methods"
|
|
let index_of_classes = index_of^" classes"
|
|
let index_of_class_types = index_of^" class types"
|
|
let index_of_modules = index_of^" modules"
|
|
let index_of_module_types = index_of^" module types"
|
|
let previous = "Previous"
|
|
let next = "Next"
|
|
let up = "Up"
|