File: findProgram-doc.m2

package info (click to toggle)
macaulay2 1.21%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 133,096 kB
  • sloc: cpp: 110,377; ansic: 16,306; javascript: 4,193; makefile: 3,821; sh: 3,580; lisp: 764; yacc: 590; xml: 177; python: 140; perl: 114; lex: 65; awk: 3
file content (147 lines) | stat: -rw-r--r-- 6,598 bytes parent folder | download
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"}
}