<section xml:id="section-programs" label="section-programs">
<title>Program Listings (with <c>code</c> in the title)</title>
<p>
Sage cells can be used for Python examples,
but Sage uses a mild amount of pre-parsing,
so that might not be a wise decision,
especially in instructional settings.
We might implement Skulpt or Brython (in-browser Python) or the Python language argument to the Sage Cell Server.
To see examples of authoring Sage cells,
have a look at Section<nbsp/><xref ref="section-sage-cells"/>.
</p>
<p>
In the meantime, program listings,
<idx><h>listing</h></idx>
<idx><h>program listing</h></idx>
especially with syntax highlighting, is useful all by itself.
The
<q>R</q>
language might not be a bad stand-in for pseudo-code,
as it supports assignment with a left arrow and has fairly generic procedural syntax for control structures and data structures.
Or maybe Pascal would be a good choice?
Here is an example of R. Note in the source that the entire block of code is wrapped in a CDATA section due to the four left angle brackets.
We do not recommend this technique for isolated problem characters,
but it is a life-saver for situations like the <init>XSLT</init> code just following.
</p>
<!-- Output in knowls?? -->
<!-- Comments edited for length -->
<!-- http://connectmv.com/tutorials/r-tutorial/programming-in-r-loops-and-flow-control/ -->
<program language="r">
<code>
n_loops <- 10
x.means <- numeric(n_loops) # create a vector of zeros for results
for (i in 1:n_loops){
x <- as.integer(runif(100, 1, 7)) # 1 to 6, uniformly
x.means[i] <- mean(x)
}
x.means
</code>
</program>
<p>
And some self-referential XSL:
</p>
<!-- input element intentionally ommited here. Pretext processor should correct. -->
<program language="xslt" margins="15%">
<xsl:template match="biblio" mode="number">
<xsl:apply-templates select="." mode="structural-number"/>
<xsl:text>.</xsl:text>
<xsl:number from="references" level="any" count="biblio"/>
</xsl:template>
</program>
<p>
Matlab is a commercial language for mathematics,
while Octave in an open source version.
The <attr>language</attr> values of <c>matlab</c> and <c>octave</c> are somewhat interchangeable.
Following is a very slighlty edited version of an example from
<url href="http://www.public.asu.edu/~hhuang38/hph_matlab_basic2013_1.pdf" visual="www.public.asu.edu/~hhuang38/hph_matlab_basic2013_1.pdf"><articletitle>50 Basic Examples for Matlab</articletitle></url>.
</p>
<!-- Example 45: 50 Basic Examples for Matlab -->
<program language="matlab">
<code>
a = [0:0.5:5]; % A Matlab comment here
b = 2*a.^2 + 3*a -5;
c = 1.2*a.^2+4*a-3;
subplot(1,2,1)
plot(a,b,'-or','MarkerFaceColor','g','LineWidth',2)
xlabel('X'); ylabel('Y'); legend('Curve ','Location','NorthWest')
subplot(1,2,2)
plot(a,c,'--ok','MarkerFaceColor','c','LineWidth',2)
xlabel('X'); ylabel('Y'); legend('Curve 2','Location','NorthWest')
</code>
</program>
<p>
You can write made-up pseudo-code,
but you might explain to a reader what your symbols all mean.
This routine takes the <m>m\times n</m> marix <m>A</m> to reduced row-echelon form.
Note that with no language specified,
there is no special formatting or use of color.
Note in the source the use of escaped characters for the three less-than symbols.
</p>
<program margins="5%">
<code>
input m, n and A
r := 0
for j := 1 to n
i := r+1
while i <= m and A[i,j] == 0
i := i+1
if i < m+1
r := r+1
swap rows i and r of A (row op 1)
scale A[r,j] to a leading 1 (row op 2)
for k := 1 to m, k <> r
make A[k,j] zero (row op 3, employing row r)
output r and A
</code>
</program>
<p>
Look in the <c>pretext-common.xsl</c> file to see the strings to use to identify languages.
Always all-lowercase, no symbols, no punctuation.
</p>
<p>
Note that the above examples all have slightly different widths
(theser are very evident in print with the frames).
As 2-D atomic objects,
to place them in the narrative requires the layout features of a <c>sidebyside</c> element.
Then <c>width</c> and/or <c>margin</c> attributes will influence the width of the panel.
</p>
<p>
A <c>program</c> may also be nested inside a <c>listing</c>,
which behaves similar to a <c>figure</c>.
You can provide a <c>title</c>,
and the listing will be numbered along with tables and figures.
This then makes it possible to cross-reference the listing,
such as <xref ref="listing-c-hello" text="type-global"/>.
It also removes the requirement of wrapping the <c>program</c> in a <c>sidebyside</c>.
For technical reasons,
the three examples above will not split across a page break in PDF output,
but the placement inside a <c>listing</c> will allow splits,
as you should see in at least one example following.
</p>
<listing xml:id="listing-c-hello">
<title>C Version of <q>Hello, World!</q></title>
<program language="c">
<code>
/* Hello World program */
#include<stdio.h>
main()
{
printf("Hello, World!");
}
</code>
</program>
</listing>
<p>
A <tag>program</tag> may include line numbers.
</p>
<listing xml:id="program-line-numbers">
<title>A static Java program with line numbers</title>
<program interactive="no" language="java" line-numbers="yes">
<code>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
</code>
</program>
</listing>
<p>
A <tag>program</tag> may also include highlighted lines.
</p>
<listing xml:id="program-highlight-lines">
<title>A static Java program with line numbers</title>
<program interactive="no" language="java" line-numbers="yes" highlight-lines="1,3-5">
<code>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
</code>
</program>
</listing>
<p>
Although a program should have a <tag>code</tag> element surrounding its code,
we attempt to provide one when it is missing.
This next sample tests that and intentionally has no leading or trailing newline inside the program.
</p>
<program languge="python">print("Hello world")</program>
<p>
Sometimes it is nice to author an inline fragment of a program and have the styling of its text match that of a <tag>program</tag>.
To do this we can use the <tag>pf</tag> tag (
<q>program fragment</q>).
It is similar to a <tag>c</tag> element,
but will be syntax highlighted according to either a <attr>language</attr> or the default language for <tag>programs</tag>.
Here is an example in C: <pf language="c">printf("The cost is $%f.2", money);</pf>.
And another that is in Python and tests problematic characters:
<pf language="python">print("& % $ # _ { } ~ ^ \")</pf>.
</p>
<p>
If you are discussing algorithms in the abstract
(or even concretely),
you can set them off like a theorem,
with a number, a title and a target for cross-references.
Sometimes you claim an algorithm produces something in particular,
or has certain properties,
such as a theoretical run time,
so a proof may be included.
See the discussion just preceding about (limited) options for pseudo-code.
</p>
<algorithm xml:id="algorithm-sieve-eratosthenes">
<title>Sieve of Eratosthenes</title>
<statement>
<p>
On input of a positive integer <c>n</c> this algorithm will compute all the prime numbers up to,
and including, <c>n</c>.
It was named for Eratosthenes of Cyrene (<ca/> 276 BC<ndash/><ca/> 195/194 BC) by Nicomachus (<ca/> 60<ndash/><ca/> 120 CE) in
<pubtitle>Introduction to Arithmetic</pubtitle>.
(
<url href="http://en.wikipedia.org/wiki/Sieve_of_Eratosthenes" visual="en.wikipedia.org/wiki/Sieve_of_Eratosthenes">Wikipedia</url>,
2015)
<ol>
<li>Input: <c>n</c></li>
<li>
Form the list of all integers from <c>2</c> to <c>n</c>
</li>
<li>Set <c>p = 2</c></li>
<li>
<p>
While <c>p < sqrt(n)</c>
<ol marker="1.">
<li>
If present, remove from the list multiples <c>2p, 3p, ...</c>
</li>
<li>
If <c>p</c> is now the last element of the list, stop
</li>
<li>
Otherwise, set <c>p</c> to the element of the list immediately after current <c>p</c>
</li>
</ol>
</p>
</li>
<li>Output: the remaining elements of the list</li>
</ol>
</p>
</statement>
<proof>
<p>
Any element removed is a non-trivial product of two integers and hence composite.
So no prime is is ever removed from the list.
</p>
<p>
Each composite number is a multiple of some prime,
and since no prime is ever removed,
each composite will be removed.
Hence the removed elements are precisely the set of composite numbers in the list and thus the remainder are precisely the primes on the list.
</p>
</proof>
</algorithm>
<p>
If you are writing about system-level software,
you may need to write numbers in hexadecimal or binary.
Here we use a numbered,
displayed equation (mathematics) and <latex/> macros such as <c>\texttt</c> for a monospace text font,
and <c>\;</c> for spacing/grouping the bits of the binary number.
<men>
\texttt{6C2A}_{16} = \texttt{0110}\;\texttt{1100}\;\texttt{0010}\;\texttt{1010}_{2}
</men>
If you use these constructions repeatedly,
then some <latex/> macros might be useful.
It might also be beneficial for us to add some <pretext/> markup for such numbers used in a paragraph<mdash/>send us a feature request.
</p>
<theorem xml:id="theorem-detached">
<statement>
<p>
This is a spurious theorem to break up the run of consecutive <c>listing</c> so we might test the effect.
</p>
</statement>
</theorem>
<p>
And this is a spurious paragraph to prove that the theorem beforehand,
and the proof following, are distinct from one another.
</p>
<proof ref="theorem-detached" text="type-global">
<p>
This is a proof that is authored
<q>detached.</q>
It is not associated with the theorem above in a way other than simply following it.<fn>
Footnotes once behaved badly in a detached <tag>proof</tag>.
</fn>
</p>
<p>
Notice that this proof has a <attr>ref</attr> attribute that points to the theorem being proved.
In this way,
the <tag>proof</tag> element doubles as an <tag>xref</tag>.
So the <attr>text</attr> attribute is also available to fashion how the cross-reference appears.
Options are basically the same as for <tag>xref</tag>,
though some things are not possible, such as custom text.
</p>
</proof>
<p>
A specialized version of a program listing is an interactive command/response session at a command-line,
where differing fonts are used to differentiate the system prompt,
the user's commands, and the system's reaction.
A <c>console</c> session may be used by itself inside a <c>sidebyside</c>,
or it can be wrapped in a listing to get a number and a caption.
As elsewhere,
you will need to escape ampersands and angle brackets
(such as if you have a command using redirection),
using <c>&amp;</c>,
<c>&lt;</c>,
and <c>&gt;</c> in your source.
</p>
<listing xml:id="console-raspberry-pi">
<title>Console Session: <c>int</c> and <c>float</c></title>
<console prompt="pi@raspberrypi ~/progs/chap02 $ ">
<input>gcc -Wall -o intAndFloat intAndFloat.c</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
</listing>
<p>
Here is the plain version, some layout control.
We simply place a small margin on the left
(at 4% width).
</p>
<console prompt="pi@raspberrypi ~/progs/chap02 $ " margins="4%">
<input>gcc -Wall -o intAndFloat intAndFloat.c</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
<p>
If your console input exceeds more than one line,
you can author it across several lines and your choice of line breaks will be reflected in the rendering.
You can decide to indent lines after the first one for clarity,
if desired.
You can also decide if your audience needs line-continuation characters or not.
</p>
<listing xml:id="console-raspberry-pi-multi">
<title>Console Session: <c>int</c> and <c>float</c> (multi-line input)</title>
<console prompt="pi@raspberrypi ~/progs/chap02 $ ">
<input>
gcc -Wall
-o intAndFloat intAndFloat.c
</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
</listing>
<p>
A <tag>console</tag> may specify a continuation symbol,
as a prefix on every line but the first.
</p>
<console>
<input prompt=">>> ">
for x in range(0:20):
print(x)
print("Excellent!")
</input>
<input prompt=">>> " continuation="... ">
for x in range(0:20):
print(x)
print("Excellent!")
</input>
<!-- Test for empty input. Should create an empty entry. -->
<input/>
<!-- Test for only whitespace input. Should create an empty entry. -->
<input> </input>
<!-- Test for only whitespace input with newlines. Should create an empty entry. -->
<input>
</input>
</console>
<p>
Notice in the HTML version of the above example that when you highlight all,
or a portion,
of the listing for a cut-and-paste that the prompts are not included.
</p>
<p>
Now a test of some listings
(and pre-formatted text)
in a block that likely has a background color in an HTML version.
</p>
<exercise>
<title>Code in a colored(?) container</title>
<statement>
<p>
Not really much of an exercise,
but it should force a colored box.
</p>
<p>
Running a program in a console:
</p>
<console>
<input>
./program
</input>
</console>
<pre>
A pre
</pre>
</statement>
</exercise>
<p>
The next listing is just absurdity,
to check various characters from <latex/> that are otherwise employed by the code supporting consoles,
and some Latin-1 characters.
We test each in a prompt, input, and output.
We use <c>(*</c> and <c>*)</c> as sequences used to escape embedded <latex/> commands,
so we test those also.
</p>
<listing>
<title>Console Session: problematic <latex/> characters</title>
<console>
<input prompt="A backslash \ here ">A backslash \ here</input>
<output>A backslash \ here</output>
<input prompt="A begin group { here ">A begin group { here</input>
<output>A begin group { here</output>
<input prompt="An end group { here ">An end group } here</input>
<output>An end group } here</output>
<input prompt="An open escape sequence (* here ">An open escape sequence (* here</input>
<output>An open escape sequence (* here</output>
<input prompt="An end escape sequence *) here ">An end escape sequence *) here</input>
<output>An end escape sequence *) here</output>
<input prompt="Some quotation marks ` ' " here ">Some quotation marks ` ' " here</input>
<output>Some quotation marks ` ' " here</output>
<input prompt="The rest & % $ # _ ~ ^ of LaTeX ">The rest & % $ # _ ~ ^ of LaTeX</input>
<output>The rest & % $ # _ ~ ^ of LaTeX</output>
<input prompt="Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ ">Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ</input>
<output>Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ</output>
</console>
</listing>
<p>
A program can also have <tag>preamble</tag> and <tag>postamble</tag>.
They are tested here mostly just for their handling of leading/trailing whitespace.
Note that the indentation of the start/end tags for the subelements is intentionally chaotic.
There is even trailing whitespace after some of the start tags.
That should not affect the indentation of the output.
(However, the actual contents of the various parts of the program must all be indented to a similar degree in the source.)
</p>
<program language="python" line-numbers="yes">
<preamble>
# meta: text in preamble with one trailing authored blank line
def foo():
return 42
</preamble>
<code>
# meta: text in code with one authored blank line before and after
# meta: in the output there should be two blank lines above and three below
# Your code for bar()
</code>
<postamble>
# meta: text in postamble with two authored blank lines preceding
print(bar())</postamble>
</program>
<p>
An interactive rendering of the same program should produce the same visible code.
Both samples should end in a newline.
There will be a visible difference between how this the empty line created by that newline rendered in plain HTML
(the empty line is not included)
and Runestone
(the empty line is visible).
</p>
<program language="python" line-numbers="yes" interactive="activecode">
<preamble>
# meta: text in preamble with one trailing authored blank line
def foo():
return 42
</preamble>
<code>
# meta: text in code with one authored blank line before and after
# meta: in the output there should be two blank lines above and three below
# Your code for bar()
</code>
<postamble>
# meta: text in postamble with two authored blank lines preceding
print(bar())</postamble>
</program>
<p>
We conclude this section with a longer example of a program listing,
an assembly language program from Bob Plantz,
included to test a <c>listing</c> breaking across pages in PDF output.
</p>
<listing>
<title>A longer program listing</title>
<program>
<code>
@ structPass2.s
@ Allocates two structs and assigns a value to each field
@ in each struct, then displays the values.
@ Bob Plantz - 6 July 2016
@ Constants for assembler
.include "theTag_struct.s" @ theTag struct defs.
.equ y,-28 @ y struct
.equ x,-16 @ x struct
.equ locals,28 @ space for the structs
@ Constant program data
.section .rodata
.align 2
displayX:
.asciz "x fields:\n"
displayY:
.asciz "y fields:\n"
dispAChar:
.asciz " aChar = "
dispAnInt:
.asciz " anInt = "
dispOtherChar:
.asciz " anotherChar = "
@ The program
.text
.align 2
.global main
.type main, %function
main:
stmfd sp!, {r4, fp, lr} @ save caller's info
add fp, sp, #8 @ our frame pointer
sub sp, sp, #locals @ for the structs
@ fill the x struct
add r0, fp, #x @ address of x struct
mov r1, #'1
mov r2, #456
mov r3, #'2
bl loadStruct
@ fill the y struct
add r0, fp, #y @ address of y struct
mov r1, #'a
mov r2, #123
mov r3, #'b
bl loadStruct
@ display x struct
add r4, fp, #x @ address of x struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
@ display y struct
add r4, fp, #y @ address of y struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
mov r0, #0 @ return 0;
sub sp, fp, #8 @ restore sp
ldmfd sp!, {r4, fp, pc} @ restore and return
.align 2
@ addresses of messages
displayXaddr:
.word displayX
displayYaddr:
.word displayY
dispACharAddr:
.word dispAChar
dispAnIntAddr:
.word dispAnInt
dispOtherCharAddr:
.word dispOtherChar
</code>
</program>
</listing>
</section>
Section 24 Program Listings (with code
in the title)
View Source for section
Sage cells can be used for Python examples, but Sage uses a mild amount of pre-parsing, so that might not be a wise decision, especially in instructional settings. We might implement Skulpt or Brython (in-browser Python) or the Python language argument to the Sage Cell Server. To see examples of authoring Sage cells, have a look at SectionΒ 3.
In the meantime, program listings, especially with syntax highlighting, is useful all by itself. The βRβ language might not be a bad stand-in for pseudo-code, as it supports assignment with a left arrow and has fairly generic procedural syntax for control structures and data structures. Or maybe Pascal would be a good choice? Here is an example of R. Note in the source that the entire block of code is wrapped in a CDATA section due to the four left angle brackets. We do not recommend this technique for isolated problem characters, but it is a life-saver for situations like the XSLT code just following.
View Source for program
<program language="r">
<code>
n_loops <- 10
x.means <- numeric(n_loops) # create a vector of zeros for results
for (i in 1:n_loops){
x <- as.integer(runif(100, 1, 7)) # 1 to 6, uniformly
x.means[i] <- mean(x)
}
x.means
</code>
</program>
n_loops <- 10
x.means <- numeric(n_loops) # create a vector of zeros for results
for (i in 1:n_loops){
x <- as.integer(runif(100, 1, 7)) # 1 to 6, uniformly
x.means[i] <- mean(x)
}
x.means
And some self-referential XSL:
View Source for program
<program language="xslt" margins="15%">
<xsl:template match="biblio" mode="number">
<xsl:apply-templates select="." mode="structural-number"/>
<xsl:text>.</xsl:text>
<xsl:number from="references" level="any" count="biblio"/>
</xsl:template>
</program>
<xsl:template match="biblio" mode="number">
<xsl:apply-templates select="." mode="structural-number"/>
<xsl:text>.</xsl:text>
<xsl:number from="references" level="any" count="biblio"/>
</xsl:template>
Matlab is a commercial language for mathematics, while Octave in an open source version. The
@language
values of matlab
and octave
are somewhat interchangeable. Following is a very slighlty edited version of an example from β50 Basic Examples for Matlabβ.
View Source for program
<program language="matlab">
<code>
a = [0:0.5:5]; % A Matlab comment here
b = 2*a.^2 + 3*a -5;
c = 1.2*a.^2+4*a-3;
subplot(1,2,1)
plot(a,b,'-or','MarkerFaceColor','g','LineWidth',2)
xlabel('X'); ylabel('Y'); legend('Curve ','Location','NorthWest')
subplot(1,2,2)
plot(a,c,'--ok','MarkerFaceColor','c','LineWidth',2)
xlabel('X'); ylabel('Y'); legend('Curve 2','Location','NorthWest')
</code>
</program>
a = [0:0.5:5]; % A Matlab comment here
b = 2*a.^2 + 3*a -5;
c = 1.2*a.^2+4*a-3;
subplot(1,2,1)
plot(a,b,'-or','MarkerFaceColor','g','LineWidth',2)
xlabel('X'); ylabel('Y'); legend('Curve ','Location','NorthWest')
subplot(1,2,2)
plot(a,c,'--ok','MarkerFaceColor','c','LineWidth',2)
xlabel('X'); ylabel('Y'); legend('Curve 2','Location','NorthWest')
You can write made-up pseudo-code, but you might explain to a reader what your symbols all mean. This routine takes the \(m\times n\) marix \(A\) to reduced row-echelon form. Note that with no language specified, there is no special formatting or use of color. Note in the source the use of escaped characters for the three less-than symbols.
View Source for program
<program margins="5%">
<code>
input m, n and A
r := 0
for j := 1 to n
i := r+1
while i <= m and A[i,j] == 0
i := i+1
if i < m+1
r := r+1
swap rows i and r of A (row op 1)
scale A[r,j] to a leading 1 (row op 2)
for k := 1 to m, k <> r
make A[k,j] zero (row op 3, employing row r)
output r and A
</code>
</program>
input m, n and A
r := 0
for j := 1 to n
i := r+1
while i <= m and A[i,j] == 0
i := i+1
if i < m+1
r := r+1
swap rows i and r of A (row op 1)
scale A[r,j] to a leading 1 (row op 2)
for k := 1 to m, k <> r
make A[k,j] zero (row op 3, employing row r)
output r and A
Look in the
pretext-common.xsl
file to see the strings to use to identify languages. Always all-lowercase, no symbols, no punctuation.
Note that the above examples all have slightly different widths (theser are very evident in print with the frames). As 2-D atomic objects, to place them in the narrative requires the layout features of a
sidebyside
element. Then width
and/or margin
attributes will influence the width of the panel.
A
program
may also be nested inside a listing
, which behaves similar to a figure
. You can provide a title
, and the listing will be numbered along with tables and figures. This then makes it possible to cross-reference the listing, such as ListingΒ 24.1. It also removes the requirement of wrapping the program
in a sidebyside
. For technical reasons, the three examples above will not split across a page break in PDF output, but the placement inside a listing
will allow splits, as you should see in at least one example following.
View Source for listing
<listing xml:id="listing-c-hello">
<title>C Version of <q>Hello, World!</q></title>
<program language="c">
<code>
/* Hello World program */
#include<stdio.h>
main()
{
printf("Hello, World!");
}
</code>
</program>
</listing>
View Source for program
<program language="c">
<code>
/* Hello World program */
#include<stdio.h>
main()
{
printf("Hello, World!");
}
</code>
</program>
/* Hello World program */
#include<stdio.h>
main()
{
printf("Hello, World!");
}
A
<program>
may include line numbers.
View Source for listing
<listing xml:id="program-line-numbers">
<title>A static Java program with line numbers</title>
<program interactive="no" language="java" line-numbers="yes">
<code>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
</code>
</program>
</listing>
View Source for program
<program interactive="no" language="java" line-numbers="yes">
<code>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
</code>
</program>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
A
<program>
may also include highlighted lines.
View Source for listing
<listing xml:id="program-highlight-lines">
<title>A static Java program with line numbers</title>
<program interactive="no" language="java" line-numbers="yes" highlight-lines="1,3-5">
<code>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
</code>
</program>
</listing>
View Source for program
<program interactive="no" language="java" line-numbers="yes" highlight-lines="1,3-5">
<code>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
</code>
</program>
import javax.swing.JFrame; //Importing class JFrame
import javax.swing.JLabel; //Importing class JLabel
public class HelloWorld {
public static void main(String[] args) {
JFrame frame = new JFrame(); //Creating frame
frame.setTitle("Hi!"); //Setting title frame
frame.add(new JLabel("Hello, world!"));//Adding text to frame
frame.pack(); //Setting size to smallest
frame.setLocationRelativeTo(null); //Centering frame
frame.setVisible(true); //Showing frame
}
}
Although a program should have a
<code>
element surrounding its code, we attempt to provide one when it is missing. This next sample tests that and intentionally has no leading or trailing newline inside the program.
View Source for program
<program languge="python">print("Hello world")</program>
print("Hello world")
Sometimes it is nice to author an inline fragment of a program and have the styling of its text match that of a
<program>
. To do this we can use the <pf>
tag ( βprogram fragmentβ). It is similar to a <c>
element, but will be syntax highlighted according to either a @language
or the default language for <programs>
. Here is an example in C: printf("The cost is $%f.2", money);
. And another that is in Python and tests problematic characters: print("& % $ # _ { } ~ ^ \")
.
If you are discussing algorithms in the abstract (or even concretely), you can set them off like a theorem, with a number, a title and a target for cross-references. Sometimes you claim an algorithm produces something in particular, or has certain properties, such as a theoretical run time, so a proof may be included. See the discussion just preceding about (limited) options for pseudo-code.
Algorithm 24.4. Sieve of Eratosthenes.
View Source for algorithm
<algorithm xml:id="algorithm-sieve-eratosthenes">
<title>Sieve of Eratosthenes</title>
<statement>
<p>
On input of a positive integer <c>n</c> this algorithm will compute all the prime numbers up to,
and including, <c>n</c>.
It was named for Eratosthenes of Cyrene (<ca/> 276 BC<ndash/><ca/> 195/194 BC) by Nicomachus (<ca/> 60<ndash/><ca/> 120 CE) in
<pubtitle>Introduction to Arithmetic</pubtitle>.
(
<url href="http://en.wikipedia.org/wiki/Sieve_of_Eratosthenes" visual="en.wikipedia.org/wiki/Sieve_of_Eratosthenes">Wikipedia</url>,
2015)
<ol>
<li>Input: <c>n</c></li>
<li>
Form the list of all integers from <c>2</c> to <c>n</c>
</li>
<li>Set <c>p = 2</c></li>
<li>
<p>
While <c>p < sqrt(n)</c>
<ol marker="1.">
<li>
If present, remove from the list multiples <c>2p, 3p, ...</c>
</li>
<li>
If <c>p</c> is now the last element of the list, stop
</li>
<li>
Otherwise, set <c>p</c> to the element of the list immediately after current <c>p</c>
</li>
</ol>
</p>
</li>
<li>Output: the remaining elements of the list</li>
</ol>
</p>
</statement>
<proof>
<p>
Any element removed is a non-trivial product of two integers and hence composite.
So no prime is is ever removed from the list.
</p>
<p>
Each composite number is a multiple of some prime,
and since no prime is ever removed,
each composite will be removed.
Hence the removed elements are precisely the set of composite numbers in the list and thus the remainder are precisely the primes on the list.
</p>
</proof>
</algorithm>
On input of a positive integer
n
this algorithm will compute all the prime numbers up to, and including, n
. It was named for Eratosthenes of Cyrene (ca. 276 BCβca. 195/194 BC) by Nicomachus (ca. 60βca. 120 CE) in Introduction to Arithmetic. ( Wikipedia, 2015)-
Input:
n
-
Form the list of all integers from
2
ton
-
Set
p = 2
-
While
p < sqrt(n)
-
If present, remove from the list multiples
2p, 3p, ...
-
If
p
is now the last element of the list, stop -
Otherwise, set
p
to the element of the list immediately after currentp
-
-
Output: the remaining elements of the list
Proof.
View Source for proof
<proof>
<p>
Any element removed is a non-trivial product of two integers and hence composite.
So no prime is is ever removed from the list.
</p>
<p>
Each composite number is a multiple of some prime,
and since no prime is ever removed,
each composite will be removed.
Hence the removed elements are precisely the set of composite numbers in the list and thus the remainder are precisely the primes on the list.
</p>
</proof>
Any element removed is a non-trivial product of two integers and hence composite. So no prime is is ever removed from the list.
Each composite number is a multiple of some prime, and since no prime is ever removed, each composite will be removed. Hence the removed elements are precisely the set of composite numbers in the list and thus the remainder are precisely the primes on the list.
If you are writing about system-level software, you may need to write numbers in hexadecimal or binary. Here we use a numbered, displayed equation (mathematics) and LaTeX macros such as
\texttt
for a monospace text font, and \;
for spacing/grouping the bits of the binary number.
\begin{equation}
\texttt{6C2A}_{16} = \texttt{0110}\;\texttt{1100}\;\texttt{0010}\;\texttt{1010}_{2}\tag{24.1}
\end{equation}
If you use these constructions repeatedly, then some LaTeX macros might be useful. It might also be beneficial for us to add some PreTeXt markup for such numbers used in a paragraphβsend us a feature request.
Theorem 24.5.
View Source for theorem
<theorem xml:id="theorem-detached">
<statement>
<p>
This is a spurious theorem to break up the run of consecutive <c>listing</c> so we might test the effect.
</p>
</statement>
</theorem>
This is a spurious theorem to break up the run of consecutive
listing
so we might test the effect.
And this is a spurious paragraph to prove that the theorem beforehand, and the proof following, are distinct from one another.
Proof.Β (TheoremΒ 24.5)
View Source for proof
<proof ref="theorem-detached" text="type-global">
<p>
This is a proof that is authored
<q>detached.</q>
It is not associated with the theorem above in a way other than simply following it.<fn>
Footnotes once behaved badly in a detached <tag>proof</tag>.
</fn>
</p>
<p>
Notice that this proof has a <attr>ref</attr> attribute that points to the theorem being proved.
In this way,
the <tag>proof</tag> element doubles as an <tag>xref</tag>.
So the <attr>text</attr> attribute is also available to fashion how the cross-reference appears.
Options are basically the same as for <tag>xref</tag>,
though some things are not possible, such as custom text.
</p>
</proof>
This is a proof that is authored βdetached.β It is not associated with the theorem above in a way other than simply following it.
β1β
Footnotes once behaved badly in a detached
<proof>
.Notice that this proof has a
@ref
attribute that points to the theorem being proved. In this way, the <proof>
element doubles as an <xref>
. So the @text
attribute is also available to fashion how the cross-reference appears. Options are basically the same as for <xref>
, though some things are not possible, such as custom text.
A specialized version of a program listing is an interactive command/response session at a command-line, where differing fonts are used to differentiate the system prompt, the userβs commands, and the systemβs reaction. A
console
session may be used by itself inside a sidebyside
, or it can be wrapped in a listing to get a number and a caption. As elsewhere, you will need to escape ampersands and angle brackets (such as if you have a command using redirection), using &
, <
, and >
in your source.
View Source for listing
<listing xml:id="console-raspberry-pi">
<title>Console Session: <c>int</c> and <c>float</c></title>
<console prompt="pi@raspberrypi ~/progs/chap02 $ ">
<input>gcc -Wall -o intAndFloat intAndFloat.c</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
</listing>
int
and float
View Source for console
<console prompt="pi@raspberrypi ~/progs/chap02 $ ">
<input>gcc -Wall -o intAndFloat intAndFloat.c</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
pi@raspberrypi ~/progs/chap02 $ gcc -Wall -o intAndFloat intAndFloat.c pi@raspberrypi ~/progs/chap02 $ ./intAndFloat The integer is 19088743 and the float is 19088.742188 pi@raspberrypi ~/progs/chap02 $
Here is the plain version, some layout control. We simply place a small margin on the left (at 4% width).
View Source for console
<console prompt="pi@raspberrypi ~/progs/chap02 $ " margins="4%">
<input>gcc -Wall -o intAndFloat intAndFloat.c</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
pi@raspberrypi ~/progs/chap02 $ gcc -Wall -o intAndFloat intAndFloat.c pi@raspberrypi ~/progs/chap02 $ ./intAndFloat The integer is 19088743 and the float is 19088.742188 pi@raspberrypi ~/progs/chap02 $
If your console input exceeds more than one line, you can author it across several lines and your choice of line breaks will be reflected in the rendering. You can decide to indent lines after the first one for clarity, if desired. You can also decide if your audience needs line-continuation characters or not.
View Source for listing
<listing xml:id="console-raspberry-pi-multi">
<title>Console Session: <c>int</c> and <c>float</c> (multi-line input)</title>
<console prompt="pi@raspberrypi ~/progs/chap02 $ ">
<input>
gcc -Wall
-o intAndFloat intAndFloat.c
</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
</listing>
int
and float
(multi-line input)View Source for console
<console prompt="pi@raspberrypi ~/progs/chap02 $ ">
<input>
gcc -Wall
-o intAndFloat intAndFloat.c
</input>
<input>./intAndFloat</input>
<output>
The integer is 19088743 and the float is 19088.742188
</output>
<input/>
</console>
pi@raspberrypi ~/progs/chap02 $ gcc -Wall -o intAndFloat intAndFloat.c pi@raspberrypi ~/progs/chap02 $ ./intAndFloat The integer is 19088743 and the float is 19088.742188 pi@raspberrypi ~/progs/chap02 $
A
<console>
may specify a continuation symbol, as a prefix on every line but the first.
View Source for console
<console>
<input prompt=">>> ">
for x in range(0:20):
print(x)
print("Excellent!")
</input>
<input prompt=">>> " continuation="... ">
for x in range(0:20):
print(x)
print("Excellent!")
</input>
<!-- Test for empty input. Should create an empty entry. -->
<input/>
<!-- Test for only whitespace input. Should create an empty entry. -->
<input> </input>
<!-- Test for only whitespace input with newlines. Should create an empty entry. -->
<input>
</input>
</console>
>>> for x in range(0:20): print(x) print("Excellent!") >>> for x in range(0:20): ... print(x) ... print("Excellent!") $ $ $
Notice in the HTML version of the above example that when you highlight all, or a portion, of the listing for a cut-and-paste that the prompts are not included.
Now a test of some listings (and pre-formatted text) in a block that likely has a background color in an HTML version.
Checkpoint 24.8. Code in a colored(?) container.
View Source for exercise
<exercise>
<title>Code in a colored(?) container</title>
<statement>
<p>
Not really much of an exercise,
but it should force a colored box.
</p>
<p>
Running a program in a console:
</p>
<console>
<input>
./program
</input>
</console>
<pre>
A pre
</pre>
</statement>
</exercise>
Not really much of an exercise, but it should force a colored box.
Running a program in a console:
View Source for console
<console>
<input>
./program
</input>
</console>
$ ./program
A pre
The next listing is just absurdity, to check various characters from LaTeX that are otherwise employed by the code supporting consoles, and some Latin-1 characters. We test each in a prompt, input, and output. We use
(*
and *)
as sequences used to escape embedded LaTeX commands, so we test those also.
View Source for listing
<listing>
<title>Console Session: problematic <latex/> characters</title>
<console>
<input prompt="A backslash \ here ">A backslash \ here</input>
<output>A backslash \ here</output>
<input prompt="A begin group { here ">A begin group { here</input>
<output>A begin group { here</output>
<input prompt="An end group { here ">An end group } here</input>
<output>An end group } here</output>
<input prompt="An open escape sequence (* here ">An open escape sequence (* here</input>
<output>An open escape sequence (* here</output>
<input prompt="An end escape sequence *) here ">An end escape sequence *) here</input>
<output>An end escape sequence *) here</output>
<input prompt="Some quotation marks ` ' " here ">Some quotation marks ` ' " here</input>
<output>Some quotation marks ` ' " here</output>
<input prompt="The rest & % $ # _ ~ ^ of LaTeX ">The rest & % $ # _ ~ ^ of LaTeX</input>
<output>The rest & % $ # _ ~ ^ of LaTeX</output>
<input prompt="Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ ">Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ</input>
<output>Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ</output>
</console>
</listing>
View Source for console
<console>
<input prompt="A backslash \ here ">A backslash \ here</input>
<output>A backslash \ here</output>
<input prompt="A begin group { here ">A begin group { here</input>
<output>A begin group { here</output>
<input prompt="An end group { here ">An end group } here</input>
<output>An end group } here</output>
<input prompt="An open escape sequence (* here ">An open escape sequence (* here</input>
<output>An open escape sequence (* here</output>
<input prompt="An end escape sequence *) here ">An end escape sequence *) here</input>
<output>An end escape sequence *) here</output>
<input prompt="Some quotation marks ` ' " here ">Some quotation marks ` ' " here</input>
<output>Some quotation marks ` ' " here</output>
<input prompt="The rest & % $ # _ ~ ^ of LaTeX ">The rest & % $ # _ ~ ^ of LaTeX</input>
<output>The rest & % $ # _ ~ ^ of LaTeX</output>
<input prompt="Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ ">Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ</input>
<output>Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ</output>
</console>
A backslash \ here A backslash \ here A backslash \ here A begin group { here A begin group { here A begin group { here An end group { here An end group } here An end group } here An open escape sequence (* here An open escape sequence (* here An open escape sequence (* here An end escape sequence *) here An end escape sequence *) here An end escape sequence *) here Some quotation marks ` ' " here Some quotation marks ` ' " here Some quotation marks ` ' " here The rest & % $ # _ ~ ^ of LaTeX The rest & % $ # _ ~ ^ of LaTeX The rest & % $ # _ ~ ^ of LaTeX Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ Latin-1: ΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓΓ
A program can also have
<preamble>
and <postamble>
. They are tested here mostly just for their handling of leading/trailing whitespace. Note that the indentation of the start/end tags for the subelements is intentionally chaotic. There is even trailing whitespace after some of the start tags. That should not affect the indentation of the output. (However, the actual contents of the various parts of the program must all be indented to a similar degree in the source.)
View Source for program
<program language="python" line-numbers="yes">
<preamble>
# meta: text in preamble with one trailing authored blank line
def foo():
return 42
</preamble>
<code>
# meta: text in code with one authored blank line before and after
# meta: in the output there should be two blank lines above and three below
# Your code for bar()
</code>
<postamble>
# meta: text in postamble with two authored blank lines preceding
print(bar())</postamble>
</program>
# meta: text in preamble with one trailing authored blank line
def foo():
return 42
# meta: text in code with one authored blank line before and after
# meta: in the output there should be two blank lines above and three below
# Your code for bar()
# meta: text in postamble with two authored blank lines preceding
print(bar())
An interactive rendering of the same program should produce the same visible code. Both samples should end in a newline. There will be a visible difference between how this the empty line created by that newline rendered in plain HTML (the empty line is not included) and Runestone (the empty line is visible).
View Source for program
<program language="python" line-numbers="yes" interactive="activecode">
<preamble>
# meta: text in preamble with one trailing authored blank line
def foo():
return 42
</preamble>
<code>
# meta: text in code with one authored blank line before and after
# meta: in the output there should be two blank lines above and three below
# Your code for bar()
</code>
<postamble>
# meta: text in postamble with two authored blank lines preceding
print(bar())</postamble>
</program>
We conclude this section with a longer example of a program listing, an assembly language program from Bob Plantz, included to test a
listing
breaking across pages in PDF output.
View Source for listing
<listing>
<title>A longer program listing</title>
<program>
<code>
@ structPass2.s
@ Allocates two structs and assigns a value to each field
@ in each struct, then displays the values.
@ Bob Plantz - 6 July 2016
@ Constants for assembler
.include "theTag_struct.s" @ theTag struct defs.
.equ y,-28 @ y struct
.equ x,-16 @ x struct
.equ locals,28 @ space for the structs
@ Constant program data
.section .rodata
.align 2
displayX:
.asciz "x fields:\n"
displayY:
.asciz "y fields:\n"
dispAChar:
.asciz " aChar = "
dispAnInt:
.asciz " anInt = "
dispOtherChar:
.asciz " anotherChar = "
@ The program
.text
.align 2
.global main
.type main, %function
main:
stmfd sp!, {r4, fp, lr} @ save caller's info
add fp, sp, #8 @ our frame pointer
sub sp, sp, #locals @ for the structs
@ fill the x struct
add r0, fp, #x @ address of x struct
mov r1, #'1
mov r2, #456
mov r3, #'2
bl loadStruct
@ fill the y struct
add r0, fp, #y @ address of y struct
mov r1, #'a
mov r2, #123
mov r3, #'b
bl loadStruct
@ display x struct
add r4, fp, #x @ address of x struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
@ display y struct
add r4, fp, #y @ address of y struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
mov r0, #0 @ return 0;
sub sp, fp, #8 @ restore sp
ldmfd sp!, {r4, fp, pc} @ restore and return
.align 2
@ addresses of messages
displayXaddr:
.word displayX
displayYaddr:
.word displayY
dispACharAddr:
.word dispAChar
dispAnIntAddr:
.word dispAnInt
dispOtherCharAddr:
.word dispOtherChar
</code>
</program>
</listing>
View Source for program
<program>
<code>
@ structPass2.s
@ Allocates two structs and assigns a value to each field
@ in each struct, then displays the values.
@ Bob Plantz - 6 July 2016
@ Constants for assembler
.include "theTag_struct.s" @ theTag struct defs.
.equ y,-28 @ y struct
.equ x,-16 @ x struct
.equ locals,28 @ space for the structs
@ Constant program data
.section .rodata
.align 2
displayX:
.asciz "x fields:\n"
displayY:
.asciz "y fields:\n"
dispAChar:
.asciz " aChar = "
dispAnInt:
.asciz " anInt = "
dispOtherChar:
.asciz " anotherChar = "
@ The program
.text
.align 2
.global main
.type main, %function
main:
stmfd sp!, {r4, fp, lr} @ save caller's info
add fp, sp, #8 @ our frame pointer
sub sp, sp, #locals @ for the structs
@ fill the x struct
add r0, fp, #x @ address of x struct
mov r1, #'1
mov r2, #456
mov r3, #'2
bl loadStruct
@ fill the y struct
add r0, fp, #y @ address of y struct
mov r1, #'a
mov r2, #123
mov r3, #'b
bl loadStruct
@ display x struct
add r4, fp, #x @ address of x struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
@ display y struct
add r4, fp, #y @ address of y struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
mov r0, #0 @ return 0;
sub sp, fp, #8 @ restore sp
ldmfd sp!, {r4, fp, pc} @ restore and return
.align 2
@ addresses of messages
displayXaddr:
.word displayX
displayYaddr:
.word displayY
dispACharAddr:
.word dispAChar
dispAnIntAddr:
.word dispAnInt
dispOtherCharAddr:
.word dispOtherChar
</code>
</program>
@ structPass2.s
@ Allocates two structs and assigns a value to each field
@ in each struct, then displays the values.
@ Bob Plantz - 6 July 2016
@ Constants for assembler
.include "theTag_struct.s" @ theTag struct defs.
.equ y,-28 @ y struct
.equ x,-16 @ x struct
.equ locals,28 @ space for the structs
@ Constant program data
.section .rodata
.align 2
displayX:
.asciz "x fields:\n"
displayY:
.asciz "y fields:\n"
dispAChar:
.asciz " aChar = "
dispAnInt:
.asciz " anInt = "
dispOtherChar:
.asciz " anotherChar = "
@ The program
.text
.align 2
.global main
.type main, %function
main:
stmfd sp!, {r4, fp, lr} @ save caller's info
add fp, sp, #8 @ our frame pointer
sub sp, sp, #locals @ for the structs
@ fill the x struct
add r0, fp, #x @ address of x struct
mov r1, #'1
mov r2, #456
mov r3, #'2
bl loadStruct
@ fill the y struct
add r0, fp, #y @ address of y struct
mov r1, #'a
mov r2, #123
mov r3, #'b
bl loadStruct
@ display x struct
add r4, fp, #x @ address of x struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
@ display y struct
add r4, fp, #y @ address of y struct
ldr r0, displayXaddr
bl writeStr
ldr r0, dispACharAddr @ display aChar
bl writeStr
ldrb r0, [r4, #aChar]
bl putChar
bl newLine
ldr r0, dispAnIntAddr @ display anInt
bl writeStr
ldr r0, [r4, #anInt]
bl putDecInt
bl newLine
ldr r0, dispOtherCharAddr @ display anotherChar
bl writeStr
ldrb r0, [r4, #anotherChar]
bl putChar
bl newLine
mov r0, #0 @ return 0;
sub sp, fp, #8 @ restore sp
ldmfd sp!, {r4, fp, pc} @ restore and return
.align 2
@ addresses of messages
displayXaddr:
.word displayX
displayYaddr:
.word displayY
dispACharAddr:
.word dispAChar
dispAnIntAddr:
.word dispAnInt
dispOtherCharAddr:
.word dispOtherChar