1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147
|
document {
Key => Program,
Headline => "external program object",
PARA {"A hash table returned by ", TO "findProgram",
" with the following strings as keys:"},
UL {
{TT "\"name\"", ", the name of the loaded program. ",
"This comes from the first argument passed to ",
TO "findProgram", ". It is also what is displayed when ",
"printing a Program."},
{TT "\"path\"", ", the path to the program as determined by ",
TO "findProgram", "."},
{TT "\"prefix\"", ", a sequence of two strings identifying the ",
"prefix prepended to the binary executables. See ",
TO "findProgram", ", specifically the description of the ",
TT "Prefix", " option, for more."},
{TT "\"version\"", ", a string containing the version number ",
"of the program. Only present if ", TO "findProgram",
" was called with the ", TT "MinimumVersion", " option."}},
SeeAlso => {"programPaths", "findProgram"}
}
document {
Key => symbol programPaths,
Headline => "user-defined external program paths",
PARA {"A mutable hash table containing user-defined paths to external ",
"programs used by Macaulay2. Its keys are strings containing the ",
"names of programs and must coincide with the first argument of ",
TO "findProgram", "."},
PARA {"It is only necessary to define a path in this way if a program ",
"is installed in a non-standard location. In particular, ",
TO "findProgram", " already checks ",
TT "prefixDirectory | currentLayout#\"programs\"",
" (where the programs shipped with Macaulay2 are installed) ",
"and all of the directories in the user's ", TT "PATH",
" environment variable."},
PARA {"If you use a particular program frequently and it is installed ",
"in a non-standard location, then it may be useful to add a line to ",
"your ", TO "initialization file", " defining its path in this way."},
SeeAlso => {"Program", "findProgram"}
}
document {
Key => RaiseError,
Headline => "whether to raise an error"
}
document {
Key => AdditionalPaths,
Headline => "list of non-standard paths to search for a program"
}
document{
Key => MinimumVersion,
Headline => "the minimum required version of a program"
}
document {
Key => {findProgram,
(findProgram, String, String),
(findProgram, String, List),
[findProgram, AdditionalPaths],
[findProgram, MinimumVersion],
[findProgram, Prefix],
[findProgram, RaiseError],
[findProgram, Verbose]},
Headline => "load external program",
Usage => "findProgram(name, cmd)\nfindProgram(name, cmds)",
Inputs => {
"name" => String => {"the name of the program to load. ",
"This should match the corresponding key in ",
TO "programPaths", "."},
"cmd" => String =>
"a command to run that should return 0 if the program is present.",
"cmds" => List => {"a list of commands to run that should all return ",
"0 if the program is present."},
RaiseError => Boolean =>
"whether to raise an error if the program is not found.",
Verbose => Boolean =>
"whether to inform the user of each path that is checked.",
Prefix => List => {
"a list of sequences containing two strings identifying a ",
"prefix that is added to the executable binaries belonging to the ",
"program by some distributions. These sequences should be of the ",
"form ", TT "(regex, prefix)", " where ", TT "regex", " is a ",
TO2("regular expressions", "regular expression"), " that should ",
"match all binary executables that need the prefix and ",
TT "prefix", " is the prefix itself."},
AdditionalPaths => List => {
"a list of strings containing any paths to check for the program ",
"in addition to the default ones."},
MinimumVersion => Sequence => {
"containing two strings the form ",
TT "(minVersion, versionCommand)", ", where ", TT "minVersion",
" is the minimum required version of the program and ",
TT "versionCommand", " is a shell command to obtain the version ",
"number of an installed program."}
},
Outputs => {Program => { "the program that was loaded. ",
"If the program is not found and ", TT "RaiseError", " is set to ",
TO "false", " then ", TO "null", " is returned."}},
PARA {"This function checks for the existence of an external program by ",
"running ", TT "cmd", " (or every element of ", TT "cmds", ") ",
"prepended with various paths in the following order:"},
UL {
{"The user-defined path specified by ", TT "programPaths#name",
", if it exists.",},
{"The path specified by ",
TT "prefixDirectory | currentLayout#\"programs\"",
", where the programs shipped with Macaulay2 are installed."},
{"Each path specified by the ", TT "AdditionalPaths", " option."},
{"Each path specified by the user's ", TT "PATH",
" environment variable."},
{"The path to ", TT "M2-binary", "."}
},
PARA {"For each path, any prefixes specified by the ", TT "Prefix",
" option are checked."},
PARA {"Once this is successful (i.e., ", TT "cmd", " or each element of ",
TT "cmds", " returns a value of 0), then a ", TO "Program",
" object is returned. If it is unsuccessful, then either an error is ",
"raised or ", TO "null", " is returned, depending on the value of ",
TT "RaiseError", "."},
PARA {"Note that if a program consists of a single executable binary ",
"file, then ", TT "name", " should coincide with the name of this ",
"file."},
EXAMPLE lines ///
programPaths#"gfan" = "/path/to/gfan/" -* no-capture-flag *-
gfan = findProgram("gfan", "gfan _version --help", Verbose => true)///,
PARA {"One program that is shipped with a variety of prefixes in ",
"different distributions and for which the ", TT "Prefix",
" option is useful is TOPCOM:"},
EXAMPLE {///findProgram("topcom", "cube 3", Verbose => true, Prefix => {
(".*", "topcom-"),
("^(cross|cube|cyclic|hypersimplex|lattice)$", "TOPCOM-"),
("^cube$", "topcom_")})///},
PARA {"Note that when using the ", TT "MinimumVersion", " option, the ",
"command used to obtain the current version number must remove ",
"everything except the version number itself and any leading or ",
"trailing whitespace. Piping with standard UNIX utilities such as ",
TT "sed", ", ", TT "head", ", ", TT "tail", ", ", TT "cut", ", and ",
TT "tr", " may be useful."},
EXAMPLE {///findProgram("gfan", "gfan _version --help", Verbose => true,
MinimumVersion => ("0.5",
"gfan _version | head -2 | tail -1 | sed 's/gfan//'"))
///},
SeeAlso => {"Program", "programPaths", "runProgram"}
}
|