2019-03-17 14:40:57 +02:00
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
< html >
< head >
2020-04-14 19:56:54 +03:00
< title > Problems, Level 0< / title >
2020-05-03 03:20:55 +03:00
< link href = "../docs-assets/Breadcrumbs.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
2020-03-19 02:11:25 +02:00
< meta name = "viewport" content = "width=device-width initial-scale=1" >
2019-03-17 14:40:57 +02:00
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" >
< meta http-equiv = "Content-Language" content = "en-gb" >
2020-05-03 03:01:21 +03:00
2020-05-03 03:20:55 +03:00
< link href = "../docs-assets/Contents.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
< link href = "../docs-assets/Progress.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
< link href = "../docs-assets/Navigation.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
< link href = "../docs-assets/Fonts.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
< link href = "../docs-assets/Base.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
2020-05-03 03:01:21 +03:00
< script >
function togglePopup(material_id) {
var popup = document.getElementById(material_id);
popup.classList.toggle("show");
}
< / script >
2020-05-03 03:20:55 +03:00
< link href = "../docs-assets/Popups.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
< link href = "../docs-assets/Colours.css" rel = "stylesheet" rev = "stylesheet" type = "text/css" >
2020-04-14 19:56:54 +03:00
2019-03-17 14:40:57 +02:00
< / head >
2020-05-03 03:01:21 +03:00
< body class = "commentary-font" >
2020-03-19 02:11:25 +02:00
< nav role = "navigation" >
2020-04-14 19:56:54 +03:00
< h1 > < a href = "../index.html" >
2020-05-03 18:34:53 +03:00
< img src = "../docs-assets/Inform.png" height = 72" >
2020-04-14 19:56:54 +03:00
< / a > < / h1 >
< ul > < li > < a href = "../compiler.html" > compiler tools< / a > < / li >
2020-03-19 02:11:25 +02:00
< li > < a href = "../other.html" > other tools< / a > < / li >
< li > < a href = "../extensions.html" > extensions and kits< / a > < / li >
< li > < a href = "../units.html" > unit test tools< / a > < / li >
2020-04-14 19:56:54 +03:00
< / ul > < h2 > Compiler Webs< / h2 > < ul >
2020-03-19 02:11:25 +02:00
< li > < a href = "../inbuild/index.html" > inbuild< / a > < / li >
< li > < a href = "../inform7/index.html" > inform7< / a > < / li >
< li > < a href = "../inter/index.html" > inter< / a > < / li >
2020-04-14 19:56:54 +03:00
< / ul > < h2 > Inbuild Modules< / h2 > < ul >
< li > < a href = "../supervisor-module/index.html" > supervisor< / a > < / li >
< / ul > < h2 > Inform7 Modules< / h2 > < ul >
2020-03-19 02:11:25 +02:00
< li > < a href = "../core-module/index.html" > core< / a > < / li >
2020-08-27 17:50:24 +03:00
< li > < a href = "../assertions-module/index.html" > assertions< / a > < / li >
< li > < a href = "../values-module/index.html" > values< / a > < / li >
< li > < a href = "../knowledge-module/index.html" > knowledge< / a > < / li >
< li > < a href = "../imperative-module/index.html" > imperative< / a > < / li >
< li > < a href = "../runtime-module/index.html" > runtime< / a > < / li >
2020-03-19 02:11:25 +02:00
< li > < a href = "../if-module/index.html" > if< / a > < / li >
< li > < a href = "../multimedia-module/index.html" > multimedia< / a > < / li >
< li > < a href = "../index-module/index.html" > index< / a > < / li >
2020-04-14 19:56:54 +03:00
< / ul > < h2 > Inter Modules< / h2 > < ul >
< li > < a href = "../bytecode-module/index.html" > bytecode< / a > < / li >
2020-03-19 02:11:25 +02:00
< li > < a href = "../building-module/index.html" > building< / a > < / li >
< li > < a href = "../codegen-module/index.html" > codegen< / a > < / li >
2020-05-20 02:02:28 +03:00
< / ul > < h2 > Services< / h2 > < ul >
2020-04-14 19:56:54 +03:00
< li > < a href = "../arch-module/index.html" > arch< / a > < / li >
2020-08-27 17:50:24 +03:00
< li > < a href = "../calculus-module/index.html" > calculus< / a > < / li >
2020-04-14 19:56:54 +03:00
< li > < a href = "../html-module/index.html" > html< / a > < / li >
2020-05-20 02:02:28 +03:00
< li > < a href = "../inflections-module/index.html" > inflections< / a > < / li >
2020-08-27 17:50:24 +03:00
< li > < a href = "../kinds-module/index.html" > kinds< / a > < / li >
2020-05-20 02:02:28 +03:00
< li > < a href = "../linguistics-module/index.html" > linguistics< / a > < / li >
< li > < a href = "index.html" > < span class = "selectedlink" > problems< / span > < / a > < / li >
2020-08-27 17:50:24 +03:00
< li > < a href = "../syntax-module/index.html" > syntax< / a > < / li >
< li > < a href = "../words-module/index.html" > words< / a > < / li >
2020-03-19 02:11:25 +02:00
< li > < a href = "../../../inweb/docs/foundation-module/index.html" > foundation< / a > < / li >
2020-04-14 19:56:54 +03:00
< / ul >
2020-03-19 02:11:25 +02:00
< / nav >
< main role = "main" >
2020-05-03 03:01:21 +03:00
<!-- Weave of 'Problems, Level 0' generated by Inweb -->
< div class = "breadcrumbs" >
2020-05-20 13:36:42 +03:00
< ul class = "crumbs" > < li > < a href = "../index.html" > Home< / a > < / li > < li > < a href = "../compiler.html" > Services< / a > < / li > < li > < a href = "index.html" > problems< / a > < / li > < li > < a href = "index.html#2" > Chapter 2: Problems< / a > < / li > < li > < b > Problems, Level 0< / b > < / li > < / ul > < / div >
< p class = "purpose" > To handle fatal errors and establish how problem sigils work.< / p >
2019-03-17 14:40:57 +02:00
2020-05-21 02:11:29 +03:00
< ul class = "toc" > < li > < a href = "2-pl0.html#SP1" > § 1. Sudden exits< / a > < / li > < li > < a href = "2-pl0.html#SP3" > § 3. Configuration< / a > < / li > < li > < a href = "2-pl0.html#SP6" > § 6. Sigils< / a > < / li > < / ul > < hr class = "tocbar" >
2020-05-03 03:01:21 +03:00
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP1" class = "paragraph-anchor" > < / a > < b > § 1. Sudden exits. < / b > In my beginning is my end: this lowest level of the error-handling system
2020-05-20 13:36:42 +03:00
deals with systemic collapses, and it begins with the exit itself. Note that
the exit code depends on whether the parent tool, perversely perhaps, actually
wants to have issued a given problem — this is used when testing Inform.
< / p >
2020-05-03 03:01:21 +03:00
2020-05-20 13:36:42 +03:00
< p class = "commentary" > By convention our exit codes are 0 for success, 1 for failure, and 2 for a
filing-system-related failure.
< / p >
2020-05-03 03:01:21 +03:00
2020-05-20 13:36:42 +03:00
< pre class = "displayed-code all-displayed-code code-font" >
2020-05-03 03:01:21 +03:00
< span class = "identifier-syntax" > text_stream< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > sigil_of_required_problem< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > NULL< / span > < span class = "plain-syntax" > ;< / span >
2020-05-20 13:36:42 +03:00
2020-05-03 03:01:21 +03:00
< span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > sigil_of_required_problem_found< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > FALSE< / span > < span class = "plain-syntax" > ;< / span >
2020-05-20 13:36:42 +03:00
< span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > echo_problem_message_sigils< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > FALSE< / span > < span class = "plain-syntax" > ;< / span >
< span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > crash_on_all_problems< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > FALSE< / span > < span class = "plain-syntax" > ;< / span >
2020-05-03 03:01:21 +03:00
2020-05-21 02:11:29 +03:00
< span class = "reserved-syntax" > void< / span > < span class = "plain-syntax" > < / span > < span class = "function-syntax" > ProblemSigils::exit< / span > < button class = "popup" onclick = "togglePopup('usagePopup1')" > < span class = "comment-syntax" > ?< / span > < span class = "popuptext" id = "usagePopup1" > Usage of < span class = "code-font" > < span class = "function-syntax" > ProblemSigils::exit< / span > < / span > :< br / > < a href = "2-pl0.html#SP2" > § 2< / a > < br / > Problems, Level 2 - < a href = "2-pl2.html#SP14" > § 14< / a > < br / > Problems, Level 3 - < a href = "2-pl3.html#SP3" > § 3< / a > , < a href = "2-pl3.html#SP11" > § 11< / a > < / span > < / button > < span class = "plain-syntax" > (< / span > < span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > code< / span > < span class = "plain-syntax" > ) {< / span >
2020-05-20 13:36:42 +03:00
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > if< / span > < span class = "plain-syntax" > ((< / span > < span class = "identifier-syntax" > sigil_of_required_problem< / span > < span class = "plain-syntax" > ) & & (< / span > < span class = "identifier-syntax" > sigil_of_required_problem_found< / span > < span class = "plain-syntax" > == < / span > < span class = "identifier-syntax" > FALSE< / span > < span class = "plain-syntax" > ))< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > exit< / span > < span class = "plain-syntax" > (0); < / span > < span class = "comment-syntax" > so that the problem test case will fail in < / span > < span class = "extract" > < span class = "extract-syntax" > intest< / span > < / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > exit< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > code< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > }< / span >
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP2" class = "paragraph-anchor" > < / a > < b > § 2. < / b > The following function has had an amusing evolution over the years. It does
2020-05-21 02:11:29 +03:00
something nobody is ever supposed to do: deliberately crashes the process.
At one time it executed < span class = "extract" > < span class = "extract-syntax" > int x = 1/0;< / span > < / span > , but compilers got wise to that, or
else would detect that such an expression had no side effects and was not used.
What we now do is to dereference a null pointer, while apparently trying to make
use of the result.
< / p >
< pre class = "displayed-code all-displayed-code code-font" >
< span class = "reserved-syntax" > void< / span > < span class = "plain-syntax" > < / span > < span class = "function-syntax" > ProblemSigils::force_crash< / span > < button class = "popup" onclick = "togglePopup('usagePopup2')" > < span class = "comment-syntax" > ?< / span > < span class = "popuptext" id = "usagePopup2" > Usage of < span class = "code-font" > < span class = "function-syntax" > ProblemSigils::force_crash< / span > < / span > :< br / > Problems, Level 2 - < a href = "2-pl2.html#SP9" > § 9< / a > , < a href = "2-pl2.html#SP14" > § 14< / a > < br / > Problems, Level 3 - < a href = "2-pl3.html#SP3" > § 3< / a > < / span > < / button > < span class = "plain-syntax" > (< / span > < span class = "reserved-syntax" > void< / span > < span class = "plain-syntax" > ) {< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > STREAM_FLUSH< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > STDOUT< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > STREAM_FLUSH< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > DL< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > WRITE_TO< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > STDERR< / span > < span class = "plain-syntax" > ,< / span >
< span class = "plain-syntax" > < / span > < span class = "string-syntax" > "*** Intentionally crashing to force stack backtrace to console logs ***\n"< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > STREAM_FLUSH< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > STDERR< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > parse_node< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > PN< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > NULL< / span > < span class = "plain-syntax" > ; < / span > < span class = "identifier-syntax" > LOG< / span > < span class = "plain-syntax" > (< / span > < span class = "string-syntax" > "$T"< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > PN< / span > < span class = "plain-syntax" > -> < / span > < span class = "identifier-syntax" > next< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < a href = "2-pl0.html#SP1" class = "function-link" > < span class = "function-syntax" > ProblemSigils::exit< / span > < / a > < span class = "plain-syntax" > (1); < / span > < span class = "comment-syntax" > should never in fact be reached< / span >
< span class = "plain-syntax" > }< / span >
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP3" class = "paragraph-anchor" > < / a > < b > § 3. Configuration. < / b > Inform calls this in response to its < span class = "extract" > < span class = "extract-syntax" > -require-problem< / span > < / span > command line switch:
2020-05-20 13:36:42 +03:00
< / p >
< pre class = "displayed-code all-displayed-code code-font" >
2020-05-21 02:11:29 +03:00
< span class = "reserved-syntax" > void< / span > < span class = "plain-syntax" > < / span > < span class = "function-syntax" > ProblemSigils::require< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > text_stream< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > ) {< / span >
2020-05-03 03:01:21 +03:00
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > sigil_of_required_problem< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > Str::duplicate< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > }< / span >
2020-05-20 13:36:42 +03:00
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP4" class = "paragraph-anchor" > < / a > < b > § 4. < / b > And this in response to < span class = "extract" > < span class = "extract-syntax" > -sigils< / span > < / span > , which causes the sigil of any problem to
2020-05-20 13:36:42 +03:00
be echoed to standard output (i.e., printed). Again, this is useful in testing.
< / p >
2020-05-03 03:01:21 +03:00
2020-05-20 13:36:42 +03:00
< pre class = "displayed-code all-displayed-code code-font" >
2020-05-21 02:11:29 +03:00
< span class = "reserved-syntax" > void< / span > < span class = "plain-syntax" > < / span > < span class = "function-syntax" > ProblemSigils::echo_sigils< / span > < span class = "plain-syntax" > (< / span > < span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > state< / span > < span class = "plain-syntax" > ) {< / span >
2020-05-20 13:36:42 +03:00
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > echo_problem_message_sigils< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > state< / span > < span class = "plain-syntax" > ;< / span >
2020-05-03 03:01:21 +03:00
< span class = "plain-syntax" > }< / span >
2020-05-20 13:36:42 +03:00
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP5" class = "paragraph-anchor" > < / a > < b > § 5. < / b > And this in response to < span class = "extract" > < span class = "extract-syntax" > -crash-all< / span > < / span > , an ugly expedient for working with
2020-05-20 13:36:42 +03:00
Inform in the debugger.
< / p >
2020-05-03 03:01:21 +03:00
2020-05-20 13:36:42 +03:00
< pre class = "displayed-code all-displayed-code code-font" >
2020-05-21 02:11:29 +03:00
< span class = "reserved-syntax" > void< / span > < span class = "plain-syntax" > < / span > < span class = "function-syntax" > ProblemSigils::crash_on_problems< / span > < span class = "plain-syntax" > (< / span > < span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > state< / span > < span class = "plain-syntax" > ) {< / span >
2020-05-20 13:36:42 +03:00
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > crash_on_all_problems< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > state< / span > < span class = "plain-syntax" > ;< / span >
2020-05-03 03:01:21 +03:00
< span class = "plain-syntax" > }< / span >
2020-05-20 13:36:42 +03:00
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP6" class = "paragraph-anchor" > < / a > < b > § 6. Sigils. < / b > Every problem message in Inform is identified by a sigil, a short alphanumeric
2020-05-20 13:36:42 +03:00
symbol. The < span class = "extract" > < span class = "extract-syntax" > _p_< / span > < / span > notation is used to write these; this expands to the name in
double quotes followed by the source section and line number at which it is
generated.
< / p >
< pre class = "definitions code-font" > < span class = "definition-keyword" > define< / span > < span class = "identifier-syntax" > _p_< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > ) #< / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > __FILE__< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > __LINE__< / span >
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP7" class = "paragraph-anchor" > < / a > < b > § 7. < / b > That means that when a < span class = "extract" > < span class = "extract-syntax" > _p_< / span > < / span > argument is given to a function, it is actually
2020-05-20 13:36:42 +03:00
a list of three arguments, matching the < span class = "extract" > < span class = "extract-syntax" > SIGIL_ARGUMENTS< / span > < / span > prototype. < span class = "extract" > < span class = "extract-syntax" > SIGIL_ARGUMENTS< / span > < / span >
appears as a pseudo-argument in the function prototypes of the many of the
functions in this module as a result.
< / p >
< p class = "commentary" > Each such function should either < span class = "extract" > < span class = "extract-syntax" > ACT_ON_SIGIL< / span > < / span > itself or else pass over to
another problem function, using < span class = "extract" > < span class = "extract-syntax" > PASS_SIGIL< / span > < / span > as the pseudo-argument.
< / p >
2020-05-03 03:01:21 +03:00
2020-05-20 13:36:42 +03:00
< pre class = "definitions code-font" > < span class = "definition-keyword" > define< / span > < span class = "constant-syntax" > SIGIL_ARGUMENTS< / span > < span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > char< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > , < / span > < span class = "reserved-syntax" > char< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > file< / span > < span class = "plain-syntax" > , < / span > < span class = "reserved-syntax" > int< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > line< / span >
< span class = "definition-keyword" > define< / span > < span class = "constant-syntax" > PASS_SIGIL< / span > < span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > file< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > line< / span >
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP8" class = "paragraph-anchor" > < / a > < b > § 8. < / b > We will maintain the following variables. The distinction is that the
2020-05-20 13:36:42 +03:00
"unlinked" one holds the sigil of a message which is next up to be hyperlinked
to documentation; < span class = "extract" > < span class = "extract-syntax" > sigil_of_latest_unlinked_problem< / span > < / span > is then emptied when this
is done, whereas < span class = "extract" > < span class = "extract-syntax" > sigil_of_latest_problem< / span > < / span > keeps its value until the next
problem is issued.
< / p >
< pre class = "displayed-code all-displayed-code code-font" >
< span class = "identifier-syntax" > text_stream< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > NULL< / span > < span class = "plain-syntax" > ;< / span >
< span class = "identifier-syntax" > text_stream< / span > < span class = "plain-syntax" > *< / span > < span class = "identifier-syntax" > sigil_of_latest_unlinked_problem< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > NULL< / span > < span class = "plain-syntax" > ;< / span >
< / pre >
2020-08-27 17:50:24 +03:00
< p class = "commentary firstcommentary" > < a id = "SP9" class = "paragraph-anchor" > < / a > < b > § 9. < / b > So, then, the following long macro is how a function "acts" on a sigil:
2020-05-20 13:36:42 +03:00
< / p >
< pre class = "definitions code-font" > < span class = "definition-keyword" > define< / span > < span class = "constant-syntax" > ACT_ON_SIGIL< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > LOG< / span > < span class = "plain-syntax" > (< / span > < span class = "string-syntax" > "Problem %s issued from %s, line %d\n"< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > file< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > line< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > if< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > telemetry_recording< / span > < span class = "plain-syntax" > ) {< / span >
< span class = "plain-syntax" > < / span > < a href = "1-tlm.html#SP2" class = "function-link" > < span class = "function-syntax" > Telemetry::ensure_telemetry_file< / span > < / a > < span class = "plain-syntax" > ();< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > WRITE_TO< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > telmy< / span > < span class = "plain-syntax" > , < / span > < span class = "string-syntax" > "Problem %s issued from %s, line %d\n"< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > file< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > line< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > }< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > if< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_latest_unlinked_problem< / span > < span class = "plain-syntax" > == < / span > < span class = "identifier-syntax" > NULL< / span > < span class = "plain-syntax" > )< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > sigil_of_latest_unlinked_problem< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > Str::new< / span > < span class = "plain-syntax" > ();< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > else< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > Str::clear< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_latest_unlinked_problem< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > WRITE_TO< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_latest_unlinked_problem< / span > < span class = "plain-syntax" > , < / span > < span class = "string-syntax" > "%s"< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > if< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > == < / span > < span class = "identifier-syntax" > NULL< / span > < span class = "plain-syntax" > )< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > Str::new< / span > < span class = "plain-syntax" > ();< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > else< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > Str::clear< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > WRITE_TO< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > , < / span > < span class = "string-syntax" > "%s"< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > sigil< / span > < span class = "plain-syntax" > );< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > if< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > Str::eq< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > sigil_of_required_problem< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > ))< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > sigil_of_required_problem_found< / span > < span class = "plain-syntax" > = < / span > < span class = "identifier-syntax" > TRUE< / span > < span class = "plain-syntax" > ;< / span >
< span class = "plain-syntax" > < / span > < span class = "reserved-syntax" > if< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > echo_problem_message_sigils< / span > < span class = "plain-syntax" > )< / span >
< span class = "plain-syntax" > < / span > < span class = "identifier-syntax" > WRITE_TO< / span > < span class = "plain-syntax" > (< / span > < span class = "identifier-syntax" > STDERR< / span > < span class = "plain-syntax" > , < / span > < span class = "string-syntax" > "Problem__ %S\n"< / span > < span class = "plain-syntax" > , < / span > < span class = "identifier-syntax" > sigil_of_latest_problem< / span > < span class = "plain-syntax" > );< / span >
< / pre >
2020-05-03 03:01:21 +03:00
< nav role = "progress" > < div class = "progresscontainer" >
2020-05-20 13:36:42 +03:00
< ul class = "progressbar" > < li class = "progressprev" > < a href = "1-tlm.html" > ❮ < / a > < / li > < li class = "progresschapter" > < a href = "P-wtmd.html" > P< / a > < / li > < li class = "progresschapter" > < a href = "1-pm.html" > 1< / a > < / li > < li class = "progresscurrentchapter" > 2< / li > < li class = "progresscurrent" > pl0< / li > < li class = "progresssection" > < a href = "2-pl1.html" > pl1< / a > < / li > < li class = "progresssection" > < a href = "2-pl2.html" > pl2< / a > < / li > < li class = "progresssection" > < a href = "2-pl3.html" > pl3< / a > < / li > < li class = "progressnext" > < a href = "2-pl1.html" > ❯ < / a > < / li > < / ul > < / div >
2020-05-03 03:01:21 +03:00
< / nav > <!-- End of weave -->
2019-03-17 14:40:57 +02:00
2020-03-19 02:11:25 +02:00
< / main >
2019-03-17 14:40:57 +02:00
< / body >
< / html >