mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2025-01-19 07:20:50 +00:00
2550 lines
45 KiB
Text
2550 lines
45 KiB
Text
#LyX 1.2 created this file. For more info see http://www.lyx.org/
|
|
\lyxformat 220
|
|
\textclass scrbook
|
|
\language american
|
|
\inputencoding latin1
|
|
\fontscheme pslatex
|
|
\graphics dvips
|
|
\float_placement htb
|
|
\paperfontsize 12
|
|
\spacing single
|
|
\papersize letterpaper
|
|
\paperpackage a4
|
|
\use_geometry 0
|
|
\use_amsmath 0
|
|
\use_natbib 0
|
|
\use_numerical_citations 0
|
|
\paperorientation portrait
|
|
\secnumdepth 2
|
|
\tocdepth 2
|
|
\paragraph_separation skip
|
|
\defskip medskip
|
|
\quotes_language english
|
|
\quotes_times 2
|
|
\papercolumns 1
|
|
\papersides 2
|
|
\paperpagestyle headings
|
|
|
|
\layout Title
|
|
|
|
The Ruamoko Programming Language
|
|
\layout Author
|
|
|
|
Bill Currie
|
|
\begin_inset Formula $\bullet $
|
|
\end_inset
|
|
|
|
Jeff Teunissen
|
|
\layout Publishers
|
|
|
|
QuakeForge Press
|
|
\layout Uppertitleback
|
|
|
|
This manual is free; you can redistribute it and/or modify it under the
|
|
terms of the GNU General Public License as published by the Free Software
|
|
Foundation; either version 2 of the License, or (at your option) any later
|
|
version.
|
|
\newline
|
|
|
|
\newline
|
|
This manual is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
FOR A PARTICULAR PURPOSE.
|
|
See the GNU General Public License for more details.
|
|
\newline
|
|
|
|
\newline
|
|
You should have received a copy of the GNU General Public License along
|
|
with this manual: if not, write to:
|
|
\newline
|
|
|
|
\newline
|
|
Free Software Foundation, Inc.
|
|
\newline
|
|
59 Temple Place - Suite 330
|
|
\newline
|
|
Boston MA 02111-1307
|
|
\newline
|
|
USA
|
|
\layout Lowertitleback
|
|
|
|
Copyright © 2002-2003 Bill Currie and Jeff Teunissen
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset LatexCommand \tableofcontents{}
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Addchap
|
|
|
|
Preface
|
|
\layout Standard
|
|
|
|
In December 1996, Id Software released
|
|
\emph on
|
|
Quake
|
|
\emph default
|
|
to the world.
|
|
It's doubtful that they knew at the time that it would spark a revolution
|
|
-- but such a revolution happened.
|
|
To the game industry's surprise, people were getting the game not just
|
|
to play it, but to
|
|
\emph on
|
|
change
|
|
\emph default
|
|
it\SpecialChar \@.
|
|
For the first time, people could make whole new games based on the Quake
|
|
engine without having to rewrite the whole game -- and in fact you couldn't
|
|
rewrite the whole game, because the main source code wasn't available to
|
|
the general public.
|
|
What
|
|
\series bold
|
|
was
|
|
\series default
|
|
available was something new -- the game wasn't just a game, it was a virtual
|
|
machine that had a byte-code instruction set -- and it had a compiler that
|
|
you could use to make new games to run inside that engine.
|
|
The language (called
|
|
\emph on
|
|
QuakeC
|
|
\emph default
|
|
) was kind of crude, and the compiler was even more crude -- but it was
|
|
a revolutionary development.
|
|
\layout Standard
|
|
|
|
Now, let's fast-forward to another December -- this time, three years later.
|
|
In another revolutionary move, Id Software released the source code to
|
|
the complete Quake engine.
|
|
This gave many people the opportunity to do a lot more than just make
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
mods
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
for Quake.
|
|
Instead, people could make all-new games without using Quake itself.
|
|
Many projects started up around this source code, with many aims\SpecialChar \ldots{}
|
|
but one
|
|
project grew to be the most dominant: That project is
|
|
\emph on
|
|
QuakeForge
|
|
\emph default
|
|
.
|
|
\layout Standard
|
|
|
|
QuakeForge has developed a number of interesting things involving the Quake
|
|
engine, but most of them are beyond the scope of this manual.
|
|
This manual documents the
|
|
\emph on
|
|
Ruamoko
|
|
\begin_inset Foot
|
|
collapsed true
|
|
|
|
\layout Standard
|
|
|
|
The name Ruamoko comes from the Maori name for their god of volcanoes and
|
|
earthquakes.
|
|
According to myth, Ruamoko is not yet born, and when he shakes inside the
|
|
Earth-mother, the world trembles.
|
|
\end_inset
|
|
|
|
|
|
\emph default
|
|
language, a language based on Id Software's QuakeC, but which has been
|
|
expanded in ways far beyond the original language.
|
|
\layout Standard
|
|
|
|
The idea behind this book is to give new programmers a solid foundation
|
|
in both of the programming models (procedural and object-oriented) supported
|
|
by the Ruamoko language, while giving experienced Ruamoko programmers a
|
|
complete reference for development of game code.
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset FloatList figure
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Part
|
|
|
|
Classical Programming in Ruamoko
|
|
\layout Chapter
|
|
|
|
|
|
\begin_inset LatexCommand \label{cha:A-Tutorial-Introduction}
|
|
|
|
\end_inset
|
|
|
|
Introduction: Foot, Meet Mister Rocket Launcher
|
|
\layout Standard
|
|
|
|
Let us begin with a quick introduction to Ruamoko.
|
|
Our aim here is to show the basic elements of the language in real programs,
|
|
but without getting bogged down in details or rules.
|
|
At this point, we're not even trying to be complete, or even precise (except
|
|
that the examples are meant to be correct).
|
|
We want to get you as quickly as possible to the point where you can write
|
|
useful programs, and to do that we have to concentrate on the basics: variables
|
|
and constants, arithmetic, flow control, functions, and the rudiments of
|
|
input and output.
|
|
We are intentionally leaving out of this chapter features of Ruamoko that
|
|
are important for writing bigger programs, or programs to run in an actual
|
|
Quake engine.
|
|
These include entities, structures, pointers, most of the operators, objects,
|
|
and the standard builtin library.
|
|
\layout Standard
|
|
|
|
This approach has its drawbacks.
|
|
Most notable is that the complete story on any particular language feature
|
|
is not found here, and the brief tutorial, just by being brief, may be
|
|
misleading.
|
|
And because the examples don't use the full power of Ruamoko, they may
|
|
not be as elegant or concise as they could be; we
|
|
\series bold
|
|
have
|
|
\series default
|
|
tried to minimize these effects, but be warned.
|
|
Another drawback is that later chapters will repeat some of what's presented
|
|
here.
|
|
We hope that the repetition will help more than it annoys.
|
|
\layout Standard
|
|
|
|
In any case, experienced programmers should be able to get an idea, from
|
|
this chapter, of some of the things that can be done in Ruamoko, for their
|
|
own needs.
|
|
Beginners should supplement it by writing small, similar programs of their
|
|
own.
|
|
Both groups can use it as a framework on which to hang the more detailed
|
|
descriptions that begin in later chapters.
|
|
\layout Section
|
|
|
|
Getting Started
|
|
\layout Standard
|
|
|
|
The best way to learn a new programming language is by writing programs
|
|
in it.
|
|
The first program one writes is almost always the same for all new languages:
|
|
print the phrase
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
Hello, world!
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
on the screen.
|
|
\layout Standard
|
|
|
|
This is the big hurdle.
|
|
To get past it, you have to be able to create the program text somewhere,
|
|
compile it, load it successfully, load it, run it, and find out where the
|
|
output went.
|
|
With these mechanical details mastered, everything else is relatively easy.
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset Float figure
|
|
wide false
|
|
collapsed true
|
|
|
|
\layout LyX-Code
|
|
\line_top \line_bottom
|
|
|
|
\begin_inset Include \verbatiminput{hello.r}
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Caption
|
|
|
|
|
|
\begin_inset LatexCommand \label{cap:Hello-World}
|
|
|
|
\end_inset
|
|
|
|
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
Hello World
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
|
|
\end_inset
|
|
|
|
A Ruamoko program that does this simple task is found in Figure
|
|
\begin_inset LatexCommand \vref{cap:Hello-World}
|
|
|
|
\end_inset
|
|
|
|
.
|
|
To run this program, you first have to compile it.
|
|
To compile it, you need to save the source code into a file (for example,
|
|
|
|
\family typewriter
|
|
hello.r
|
|
\family default
|
|
), then compile it with the command
|
|
\family typewriter
|
|
\series bold
|
|
qfcc -o qwaq.dat hello.r
|
|
\family default
|
|
\series default
|
|
.
|
|
\layout Standard
|
|
|
|
If you haven't screwed anything up, such as omitting a character or misspelling
|
|
something, the compilation will proceed.
|
|
You should be rewarded with something that looks something like Figure
|
|
|
|
\begin_inset LatexCommand \vref{cap:qfcc-output}
|
|
|
|
\end_inset
|
|
|
|
.
|
|
\begin_inset Float figure
|
|
wide false
|
|
collapsed true
|
|
|
|
\layout LyX-Code
|
|
|
|
|
|
\begin_inset Include \verbatiminput{qfcc-output.txt}
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Caption
|
|
|
|
|
|
\family typewriter
|
|
|
|
\begin_inset LatexCommand \label{cap:qfcc-output}
|
|
|
|
\end_inset
|
|
|
|
|
|
\series bold
|
|
qfcc
|
|
\family default
|
|
\series default
|
|
output
|
|
\end_inset
|
|
|
|
|
|
\layout Standard
|
|
|
|
You run
|
|
\family typewriter
|
|
qwaq.dat
|
|
\family default
|
|
by issuing the command
|
|
\family typewriter
|
|
\series bold
|
|
qwaq
|
|
\family default
|
|
\series default
|
|
.
|
|
The program should print
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
|
|
\family typewriter
|
|
Hello, world!
|
|
\family default
|
|
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
to your screen.
|
|
\layout Standard
|
|
|
|
Now, for some explanations regarding the program itself.
|
|
All Ruamoko programs, regardless of size, consist mainly of
|
|
\emph on
|
|
functions
|
|
\emph default
|
|
and
|
|
\emph on
|
|
variables
|
|
\emph default
|
|
.
|
|
A function contains statements that tell the compiler what computing operations
|
|
you want to do, and variables store values used during the operation of
|
|
the program.
|
|
Ruamoko functions are roughly equivalent to C's functions, or Pascal's
|
|
procedures and functions.
|
|
Our example is a function called
|
|
\family typewriter
|
|
main
|
|
\family default
|
|
.
|
|
You can create functions with just about any name you like, but
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
|
|
\family typewriter
|
|
main
|
|
\family default
|
|
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
is special -- program execution begins there
|
|
\begin_inset Foot
|
|
collapsed true
|
|
|
|
\layout Standard
|
|
|
|
This is not precisely true.
|
|
When used in a game engine, there are certain other functions that are
|
|
called by the engine during the course of a game.
|
|
\end_inset
|
|
|
|
.
|
|
This means that every program must have a
|
|
\family typewriter
|
|
main
|
|
\family default
|
|
function somewhere.
|
|
\layout Standard
|
|
|
|
The main function will usually call other functions to do its job -- some
|
|
of them you write, and some of them are provided by the virtual machine
|
|
your program runs inside.
|
|
The first lines of the program (the ones beginning with
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
|
|
\family typewriter
|
|
#include
|
|
\family default
|
|
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
) tell the compiler to include information about the standard variables,
|
|
constants,
|
|
\emph on
|
|
fields
|
|
\emph default
|
|
|
|
\begin_inset LatexCommand \index{fields}
|
|
|
|
\end_inset
|
|
|
|
, and
|
|
\emph on
|
|
engine functions
|
|
\begin_inset Foot
|
|
collapsed true
|
|
|
|
\layout Standard
|
|
|
|
also known as
|
|
\emph on
|
|
builtins
|
|
\emph default
|
|
.
|
|
\end_inset
|
|
|
|
|
|
\emph default
|
|
|
|
\begin_inset LatexCommand \index{functions, engine}
|
|
|
|
\end_inset
|
|
|
|
provided by the environment
|
|
\begin_inset Foot
|
|
collapsed true
|
|
|
|
\layout Standard
|
|
|
|
The environment will be described later.
|
|
\end_inset
|
|
|
|
.
|
|
\layout Standard
|
|
|
|
One way of communicating data between functions is for the calling function
|
|
to provide a list of values, called
|
|
\emph on
|
|
arguments
|
|
\emph default
|
|
|
|
\begin_inset LatexCommand \index{arguments}
|
|
|
|
\end_inset
|
|
|
|
, to the function it calls.
|
|
The parentheses after the function's name surround the
|
|
\emph on
|
|
argument list
|
|
\emph default
|
|
|
|
\begin_inset LatexCommand \index{argument list}
|
|
|
|
\end_inset
|
|
|
|
.
|
|
In this example, main is defined to be a function that expects no arguments,
|
|
which is indicated by an empty list:\SpecialChar ~
|
|
|
|
\family typewriter
|
|
()
|
|
\family default
|
|
.
|
|
\layout Standard
|
|
|
|
The statements of a function are enclosed in curly braces,\SpecialChar ~
|
|
|
|
\family typewriter
|
|
{}
|
|
\family default
|
|
.
|
|
The function
|
|
\family typewriter
|
|
main
|
|
\family default
|
|
contains only one statement,
|
|
\family typewriter
|
|
printf ("Hello, world!
|
|
\backslash
|
|
n")
|
|
\family default
|
|
.
|
|
This is a
|
|
\emph on
|
|
function call
|
|
\emph default
|
|
, which transfers control from one function to another.
|
|
A function is called by giving its name, followed by a list of arguments
|
|
enclosed by parentheses, so this calls the function
|
|
\family typewriter
|
|
printf
|
|
\family default
|
|
with the argument
|
|
\family typewriter
|
|
"Hello, world!
|
|
\backslash
|
|
n"
|
|
\family default
|
|
.
|
|
|
|
\family typewriter
|
|
printf
|
|
\family default
|
|
is an engine function that prints output, in this case the string of characters
|
|
between the quotes.
|
|
\layout Standard
|
|
|
|
A sequence of characters between double quotes, like
|
|
\family typewriter
|
|
"Hello, world!
|
|
\backslash
|
|
n"
|
|
\family default
|
|
, is called a
|
|
\emph on
|
|
string constant
|
|
\emph default
|
|
or simply a
|
|
\emph on
|
|
string
|
|
\emph default
|
|
.
|
|
For the moment, our only use of strings will be as arguments for
|
|
\family typewriter
|
|
printf
|
|
\family default
|
|
and other functions.
|
|
\layout Standard
|
|
|
|
The sequence
|
|
\family typewriter
|
|
|
|
\backslash
|
|
n
|
|
\family default
|
|
in the string is Ruamoko notation for the
|
|
\emph on
|
|
newline character
|
|
\emph default
|
|
, which when printed tells the terminal (or a game client) to advance to
|
|
the next line in the output.
|
|
If you leave out the
|
|
\family typewriter
|
|
|
|
\backslash
|
|
n
|
|
\family default
|
|
, you will find that there is no advance after the character string is printed.
|
|
You must use
|
|
\family typewriter
|
|
|
|
\backslash
|
|
n
|
|
\family default
|
|
to include a newline character in the printf argument; if you try to insert
|
|
a newline yourself into the string, the Ruamoko compiler will give you
|
|
an error message when you compile the program.
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset Float figure
|
|
wide false
|
|
collapsed true
|
|
|
|
\layout LyX-Code
|
|
\line_top \line_bottom
|
|
|
|
\begin_inset Include \verbatiminput{hello2.r}
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Caption
|
|
|
|
|
|
\begin_inset LatexCommand \label{cap:A-different-Hello}
|
|
|
|
\end_inset
|
|
|
|
A different
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
Hello World
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
|
|
\end_inset
|
|
|
|
The
|
|
\family typewriter
|
|
printf()
|
|
\family default
|
|
function never supplies a newline automatically, so several calls may be
|
|
used to build up an output line in stages.
|
|
Our first program could just as easily been written as it is in figure
|
|
|
|
\begin_inset LatexCommand \vref{cap:A-different-Hello}
|
|
|
|
\end_inset
|
|
|
|
, and it would have produced identical output.
|
|
\layout Standard
|
|
|
|
Note that
|
|
\family typewriter
|
|
|
|
\backslash
|
|
n
|
|
\family default
|
|
represents only a single character.
|
|
An
|
|
\emph on
|
|
escape character
|
|
\emph default
|
|
like
|
|
\family typewriter
|
|
|
|
\backslash
|
|
n
|
|
\family default
|
|
gives you a general way to express hard-to-type or invisible characters.
|
|
Among the others are
|
|
\family typewriter
|
|
|
|
\backslash
|
|
t
|
|
\family default
|
|
for a tab,
|
|
\family typewriter
|
|
|
|
\backslash
|
|
b
|
|
\family default
|
|
for a backspace,
|
|
\family typewriter
|
|
|
|
\backslash
|
|
"
|
|
\family default
|
|
for a double-quote, and
|
|
\family typewriter
|
|
|
|
\backslash
|
|
|
|
\backslash
|
|
|
|
\family default
|
|
for the backslash character itself.
|
|
There is a complete list in [section]
|
|
\layout Section
|
|
|
|
Variables and Mathematical Expressions
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset Float figure
|
|
wide false
|
|
collapsed true
|
|
|
|
\layout LyX-Code
|
|
\line_top \line_bottom
|
|
|
|
\begin_inset Include \verbatiminput{radians.r}
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Caption
|
|
|
|
|
|
\begin_inset LatexCommand \label{cap:Degrees-to-radians}
|
|
|
|
\end_inset
|
|
|
|
Degrees to radians
|
|
\end_inset
|
|
|
|
In figure
|
|
\begin_inset LatexCommand \vref{cap:Degrees-to-radians}
|
|
|
|
\end_inset
|
|
|
|
, we find a simple program uses the formula
|
|
\begin_inset Formula $R=D\, \times \, (\frac{\pi }{180})$
|
|
\end_inset
|
|
|
|
to print a table of various angles in both their degrees and radian equivalents.
|
|
\layout Standard
|
|
|
|
The line
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
|
|
\family typewriter
|
|
/* Print a silly conversion table between degrees and radians */
|
|
\family default
|
|
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
and the three parts that say things like
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
|
|
\family typewriter
|
|
// lower limit
|
|
\family default
|
|
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
are
|
|
\emph on
|
|
comments
|
|
\emph default
|
|
|
|
\begin_inset LatexCommand \index{comments}
|
|
|
|
\end_inset
|
|
|
|
.
|
|
Characters between
|
|
\family typewriter
|
|
/*
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
*/
|
|
\family default
|
|
, and anything between
|
|
\family typewriter
|
|
//
|
|
\family default
|
|
and the next line, are ignored by the compiler; they may be used freely
|
|
to make a program easier for humans to understand.
|
|
Comments may appear anywhere a blank space, or a tab, or a newline can.
|
|
\layout Standard
|
|
|
|
In Ruamoko, all variables must be declared before they are used., usually
|
|
at the beginning of the function before any statements.
|
|
A declaration
|
|
\begin_inset LatexCommand \index{declaration, variable}
|
|
|
|
\end_inset
|
|
|
|
announces the properties of variables to the compiler; it consists of a
|
|
type name and a list of one or more variables, such as
|
|
\layout LyX-Code
|
|
|
|
float degrees, radians;
|
|
\newline
|
|
integer lower, upper, step;
|
|
\layout Standard
|
|
|
|
The type
|
|
\family typewriter
|
|
float
|
|
\family default
|
|
means that the
|
|
\family typewriter
|
|
degrees
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
radians
|
|
\family default
|
|
variables are floating-point numbers (numbers that can have a fractional
|
|
part), and the type
|
|
\family typewriter
|
|
integer
|
|
\family default
|
|
means that the
|
|
\family typewriter
|
|
lower
|
|
\family default
|
|
,
|
|
\family typewriter
|
|
upper
|
|
\family default
|
|
, and
|
|
\family typewriter
|
|
step
|
|
\family default
|
|
variables are integers -- that is, they are whole numbers.
|
|
\layout Standard
|
|
|
|
Unlike C, in which
|
|
\family typewriter
|
|
int
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
float
|
|
\family default
|
|
can have different sizes depending on the machine, Ruamoko variables always
|
|
have a size that is a multiple of 4 bytes (32 bits).
|
|
\layout Standard
|
|
|
|
Ruamoko provides four basic data types
|
|
\begin_inset LatexCommand \index{types, basic}
|
|
|
|
\end_inset
|
|
|
|
:
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset Tabular
|
|
<lyxtabular version="3" rows="4" columns="2">
|
|
<features>
|
|
<column alignment="left" valignment="top" width="0pt">
|
|
<column alignment="left" valignment="top" width="0pt">
|
|
<row>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family typewriter
|
|
float
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
floating-point numbers
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family typewriter
|
|
integer
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family roman
|
|
\series medium
|
|
\shape up
|
|
\size normal
|
|
\emph off
|
|
\bar no
|
|
\noun off
|
|
\color none
|
|
whole numbers, with a range between -2147483648 and 2147483647.
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family typewriter
|
|
string
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family roman
|
|
\series medium
|
|
\shape up
|
|
\size normal
|
|
\emph off
|
|
\bar no
|
|
\noun off
|
|
\color none
|
|
text strings
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family typewriter
|
|
vector
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\family roman
|
|
\series medium
|
|
\shape up
|
|
\size normal
|
|
\emph off
|
|
\bar no
|
|
\noun off
|
|
\color none
|
|
three-dimensional floating-point vectors
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
</lyxtabular>
|
|
|
|
\end_inset
|
|
|
|
|
|
\layout Standard
|
|
|
|
There are more types than just these four, but this is the list of
|
|
\emph on
|
|
basic types
|
|
\emph default
|
|
.
|
|
There are also
|
|
\emph on
|
|
arrays
|
|
\emph default
|
|
,
|
|
\emph on
|
|
structures
|
|
\emph default
|
|
, and
|
|
\emph on
|
|
unions
|
|
\emph default
|
|
of these basic types,
|
|
\emph on
|
|
pointers
|
|
\emph default
|
|
to them, and functions that return them, all of which we'll meet later.
|
|
\layout Standard
|
|
|
|
The computation in the conversion program begins with the assignment statements
|
|
\layout LyX-Code
|
|
|
|
lower = 0;
|
|
\newline
|
|
upper = 360;
|
|
\newline
|
|
step = 45;
|
|
\layout Standard
|
|
|
|
which set the variables to their initial values.
|
|
In Ruamoko, as in C, a statement is terminated by the semicolon character.
|
|
\layout Standard
|
|
|
|
Each line of the table is computed in the same manner, so we use a loop
|
|
that repeats once per output line; this is the purpose of the
|
|
\family typewriter
|
|
while
|
|
\family default
|
|
loop
|
|
\layout LyX-Code
|
|
|
|
while (degrees <= upper) {
|
|
\newline
|
|
|
|
\begin_inset Formula $\vdots $
|
|
\end_inset
|
|
|
|
|
|
\newline
|
|
}
|
|
\layout Standard
|
|
|
|
The
|
|
\family typewriter
|
|
while
|
|
\family default
|
|
loop works like this: The condition in parentheses is tested.
|
|
If it is true (if
|
|
\family typewriter
|
|
degrees
|
|
\family default
|
|
is less than or equal to
|
|
\family typewriter
|
|
upper
|
|
\family default
|
|
), the body of the loop (the three statements enclosed in the block delimited
|
|
by the curly braces) is executed.
|
|
Then the condition is tested again, and if it's true again, the body is
|
|
executed again.
|
|
If and when the condition becomes false (
|
|
\family typewriter
|
|
degrees
|
|
\family default
|
|
exceeds
|
|
\family typewriter
|
|
upper
|
|
\family default
|
|
), the loop ends and execution continues at the statement following the
|
|
loop's end.
|
|
Since there are no more statements in the program, the end of the loop
|
|
terminates the program.
|
|
\layout Standard
|
|
|
|
The body of a while loop can be one or more statements enclosed in braces
|
|
(called a block, or compound statement), or a single statement without
|
|
braces, as in
|
|
\layout LyX-Code
|
|
|
|
while (i < n)
|
|
\newline
|
|
i = i * 2;
|
|
\layout Standard
|
|
|
|
In either case, we will always indent the statements controlled by the while
|
|
by one tab stop (which we will show as four spaces), so you can see at
|
|
a glance which statements are inside the loop.
|
|
The indentation emphasizes the logical structure of the program.
|
|
The compiler does not care how your program looks, but proper indentation
|
|
and spacing are critical in making programs easy for people (including
|
|
you) to read.
|
|
We recommend writing only one statement per line, and using blanks around
|
|
operators to make groupings clear.
|
|
The positions of braces is less important, though you should be warned
|
|
that many programmers have passionate beliefs about how braces should be
|
|
used.
|
|
We have chosen the so-called
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
One True Brace Style
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
, which is the style that Brian Kernighan and Dennis Ritchie used in their
|
|
book
|
|
\bar under
|
|
The C Programming Language
|
|
\bar default
|
|
, for consistency.
|
|
Pick a style that suits you, and use it consistently in your own work,
|
|
but be prepared to adapt to the styles of other programmers when writing
|
|
as a group.
|
|
\layout Standard
|
|
|
|
Most of the work gets done inside the loop.
|
|
The radians for the angle are computed and assigned to the
|
|
\family typewriter
|
|
radians
|
|
\family default
|
|
variable using the statement
|
|
\layout LyX-Code
|
|
|
|
radians = degrees * (PI / 180);
|
|
\layout Standard
|
|
|
|
This example also shows a bit more of how
|
|
\family typewriter
|
|
printf()
|
|
\family default
|
|
works.
|
|
|
|
\family typewriter
|
|
printf()
|
|
\family default
|
|
is a general-purpose output formatting function, which we will describe
|
|
in detail in [chapter].
|
|
Its first argument is a string to be printed, with each
|
|
\family typewriter
|
|
%
|
|
\family default
|
|
indicating where one of the other (second, third, and so on) arguments
|
|
is to be substituted, and in what form it is to be output.
|
|
For instance,
|
|
\family typewriter
|
|
%f
|
|
\family default
|
|
specifies a
|
|
\family typewriter
|
|
float
|
|
\family default
|
|
argument, so the statement
|
|
\layout LyX-Code
|
|
|
|
printf("%f
|
|
\backslash
|
|
t%f
|
|
\backslash
|
|
n", degrees, radians);
|
|
\layout Standard
|
|
|
|
causes the values of the two
|
|
\family typewriter
|
|
float
|
|
\family default
|
|
variables
|
|
\family typewriter
|
|
degrees
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
radians
|
|
\family default
|
|
to be printed, with a tab (
|
|
\family typewriter
|
|
|
|
\backslash
|
|
t
|
|
\family default
|
|
) between them.
|
|
\layout Chapter
|
|
|
|
Types, Operators, and Expressions
|
|
\layout Standard
|
|
|
|
Variables and constants are the basic data units manipulated in a program.
|
|
Declarations list the variables to be used, and state what type they have
|
|
and perhaps what the initial values for them are.
|
|
Operators specify what is to be done to them.
|
|
Expressions combine variables and constants to produce new values.
|
|
The type of a unit determines the set of values it can have and what operations
|
|
are permissible for it.
|
|
These building blocks are the subject of this chapter.
|
|
\layout Section
|
|
|
|
Variable Names
|
|
\layout Standard
|
|
|
|
Though we didn't say it in Chapter
|
|
\begin_inset LatexCommand \ref{cha:A-Tutorial-Introduction}
|
|
|
|
\end_inset
|
|
|
|
, there are some restrictions on variable names and symbolic constants.
|
|
Names are composed of letters and digits; the first character must be a
|
|
letter (the underscore,
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
_
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
, counts as a letter -- it's often useful for improving the readability
|
|
of long names).
|
|
Don't begin variable names with an underscore, however, since functions
|
|
beginning with _ are reserved for library and engine functions.
|
|
Upper-case and lower-case are distinct, so x and X are two different names.
|
|
Traditional practice is to use lower-case or mixed case for variable names,
|
|
and all upper-case for
|
|
\emph on
|
|
symbolic constants
|
|
\emph default
|
|
, also known as
|
|
\emph on
|
|
defines
|
|
\emph default
|
|
.
|
|
Keywords like if, else, integer, float, etc.
|
|
are reserved -- you can't use them as variable names.
|
|
\layout Section
|
|
|
|
Constants
|
|
\layout Standard
|
|
|
|
An integer constant like
|
|
\family typewriter
|
|
5678
|
|
\family default
|
|
is an integer.
|
|
Floating-point constants contain a decimal point (
|
|
\family typewriter
|
|
123.4
|
|
\family default
|
|
) or an exponent (
|
|
\family typewriter
|
|
1e-2
|
|
\family default
|
|
) or both (
|
|
\family typewriter
|
|
1.2e3
|
|
\family default
|
|
).
|
|
\layout Standard
|
|
|
|
The value of an integer can be specified in octal (base 8, 0
|
|
\begin_inset Formula $\ldots $
|
|
\end_inset
|
|
|
|
7) or hexadecimal (base 16, 0
|
|
\begin_inset Formula $\ldots $
|
|
\end_inset
|
|
|
|
F, hereafter called
|
|
\begin_inset Quotes eld
|
|
\end_inset
|
|
|
|
hex
|
|
\begin_inset Quotes erd
|
|
\end_inset
|
|
|
|
) instead of decimal.
|
|
A leading
|
|
\family typewriter
|
|
0
|
|
\family default
|
|
(zero) on an integer constant means octal; a leading
|
|
\family typewriter
|
|
0x
|
|
\family default
|
|
or
|
|
\family typewriter
|
|
0X
|
|
\family default
|
|
means hex.
|
|
For example, decimal 31 can be written as
|
|
\family typewriter
|
|
037
|
|
\family default
|
|
in octal, or
|
|
\family typewriter
|
|
0x1f
|
|
\family default
|
|
or
|
|
\family typewriter
|
|
0X1F
|
|
\family default
|
|
in hex.
|
|
\layout Standard
|
|
|
|
Certain characters can be represented in string constants by escape sequences
|
|
like
|
|
\family typewriter
|
|
|
|
\backslash
|
|
n
|
|
\family default
|
|
(newline); these sequences look like two characters, but represent only
|
|
one.
|
|
In addition, an arbitrary byte value can be represented by
|
|
\layout LyX-Code
|
|
|
|
|
|
\backslash
|
|
o
|
|
\layout Standard
|
|
|
|
where
|
|
\family typewriter
|
|
o
|
|
\family default
|
|
is one to three octal digits or by
|
|
\layout LyX-Code
|
|
|
|
|
|
\backslash
|
|
xh
|
|
\layout Standard
|
|
|
|
where
|
|
\family typewriter
|
|
h
|
|
\family default
|
|
is one or more hex digits.
|
|
So we might write
|
|
\layout LyX-Code
|
|
|
|
"vtab =
|
|
\backslash
|
|
013"
|
|
\layout Standard
|
|
|
|
or, in hex,
|
|
\layout LyX-Code
|
|
|
|
"vtab =
|
|
\backslash
|
|
x0b"
|
|
\layout Standard
|
|
|
|
The complete set of escape sequences is found in Table
|
|
\begin_inset LatexCommand \ref{cap:Escape-sequences}
|
|
|
|
\end_inset
|
|
|
|
.
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset Float table
|
|
wide false
|
|
collapsed true
|
|
|
|
\layout Standard
|
|
|
|
|
|
\hfill
|
|
|
|
\begin_inset Tabular
|
|
<lyxtabular version="3" rows="14" columns="2">
|
|
<features>
|
|
<column alignment="left" valignment="top" leftline="true" width="0pt">
|
|
<column alignment="left" valignment="top" leftline="true" rightline="true" width="0pt">
|
|
<row topline="true" bottomline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
Sequence
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
Description
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
a
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
Alert (bell) character
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
b
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
backspace
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
f
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
form feed
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
n
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
newline
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
r
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
carriage return
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
t
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
tab character
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
|
|
\backslash
|
|
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
backslash
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
?
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
question mark
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
'
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
single quote
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
"
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
double quote
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
ooo
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
octal number
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
xhh
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
hex number
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
<row topline="true" bottomline="true">
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
|
|
\backslash
|
|
^
|
|
\end_inset
|
|
</cell>
|
|
<cell alignment="center" valignment="top" topline="true" leftline="true" rightline="true" usebox="none">
|
|
\begin_inset Text
|
|
|
|
\layout Standard
|
|
|
|
alternate character set (toggles)
|
|
\end_inset
|
|
</cell>
|
|
</row>
|
|
</lyxtabular>
|
|
|
|
\end_inset
|
|
|
|
|
|
\hfill
|
|
|
|
\layout Caption
|
|
|
|
|
|
\begin_inset LatexCommand \label{cap:Escape-sequences}
|
|
|
|
\end_inset
|
|
|
|
Escape sequences
|
|
\end_inset
|
|
|
|
|
|
\layout Chapter
|
|
|
|
Control Constructs: Kneel Before Zod
|
|
\layout Chapter
|
|
|
|
Arrays and Pointers: Pull Pin, Then Throw
|
|
\bar under
|
|
GRENADE
|
|
\layout Chapter
|
|
|
|
Breaking Up The Program: Now Where Did I Put That?
|
|
\layout Part
|
|
|
|
Object-Oriented Programming in Ruamoko
|
|
\layout Part
|
|
|
|
Language Reference
|
|
\layout Chapter
|
|
|
|
Types
|
|
\layout Standard
|
|
|
|
This is currently just new stuff in
|
|
\family typewriter
|
|
\series bold
|
|
qfcc
|
|
\family default
|
|
\series default
|
|
.
|
|
\layout Section
|
|
|
|
New Type Features
|
|
\layout Subsection
|
|
|
|
New Types
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
integer
|
|
\family default
|
|
32 bit signed integer
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
id
|
|
\family default
|
|
generic object pointer
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
Class
|
|
\family default
|
|
class object pointer
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
Protocol
|
|
\family default
|
|
protocol object pointer
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
Method
|
|
\family default
|
|
method pointer
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
SEL
|
|
\family default
|
|
selector
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
IMP
|
|
\family default
|
|
message implementation
|
|
\layout Standard
|
|
|
|
|
|
\family typewriter
|
|
id
|
|
\family default
|
|
,
|
|
\family typewriter
|
|
Class
|
|
\family default
|
|
,
|
|
\family typewriter
|
|
Protocol
|
|
\family default
|
|
,
|
|
\family typewriter
|
|
Method
|
|
\family default
|
|
,
|
|
\family typewriter
|
|
SEL
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
IMP
|
|
\family default
|
|
are part of
|
|
\family typewriter
|
|
\series bold
|
|
qfcc
|
|
\family default
|
|
\series default
|
|
's Objective-QC extensions.
|
|
\layout Subsection
|
|
|
|
Enumerators
|
|
\layout Standard
|
|
|
|
as per C
|
|
\layout Subsection
|
|
|
|
Structures
|
|
\layout LyX-Code
|
|
|
|
struct foo {
|
|
\newline
|
|
integer bar;
|
|
\newline
|
|
float baz;
|
|
\newline
|
|
void () func;
|
|
\newline
|
|
};
|
|
\layout Standard
|
|
|
|
Structures with no elements can be declared for making opaque types (particularl
|
|
y useful for engine interface functions).
|
|
\layout Subsection
|
|
|
|
Arrays
|
|
\layout LyX-Code
|
|
|
|
integer [13] array;
|
|
\layout Subsection
|
|
|
|
Pointers
|
|
\layout Standard
|
|
|
|
Pointers are declared the same way as arrays, but with no number in the
|
|
|
|
\family typewriter
|
|
[]
|
|
\family default
|
|
s.
|
|
In fact, arrays are just pointers with limited (compile-time) bounds checking
|
|
(constant indices).
|
|
\layout Subsection
|
|
|
|
Complex types
|
|
\layout Standard
|
|
|
|
Complex types can be created by nesting type declarations within
|
|
\family typewriter
|
|
()
|
|
\family default
|
|
s.
|
|
e.g.:
|
|
\layout LyX-Code
|
|
|
|
(.float) (string name) find_field;
|
|
\layout Standard
|
|
|
|
declares a function (
|
|
\family typewriter
|
|
find_field
|
|
\family default
|
|
) taking a string parameter and returning a float field `offset'.
|
|
Without the
|
|
\family typewriter
|
|
()
|
|
\family default
|
|
s around the
|
|
\family typewriter
|
|
.float
|
|
\family default
|
|
, the declaration would be a function field.
|
|
\layout Subsection
|
|
|
|
|
|
\family typewriter
|
|
typedef
|
|
\layout Standard
|
|
|
|
By using
|
|
\family typewriter
|
|
typedef
|
|
\family default
|
|
complex types can be given symbolic names.
|
|
e.g.:
|
|
\layout LyX-Code
|
|
|
|
struct foo_s {};
|
|
\newline
|
|
typedef foo_s [] foo_t;
|
|
\layout Standard
|
|
|
|
creates type
|
|
\family typewriter
|
|
foo_t
|
|
\family default
|
|
which is a pointer to the structure
|
|
\family typewriter
|
|
foo_s
|
|
\family default
|
|
(which happens to be opaque).
|
|
\layout Subsection
|
|
|
|
Variable-argument functions
|
|
\layout Standard
|
|
|
|
Typed parameters preceding the ellipsis are allowed, e.g.:
|
|
\family typewriter
|
|
void (string fmt, ...) printf;
|
|
\layout Standard
|
|
|
|
More importantly, it is now possible to write vararg functions in QC.
|
|
|
|
\family typewriter
|
|
@argc
|
|
\family default
|
|
gives the number of parameters passed through the ellipsis and
|
|
\family typewriter
|
|
@argv
|
|
\family default
|
|
is an array of vectors representing the parameters passed through
|
|
\family typewriter
|
|
...
|
|
\family default
|
|
.
|
|
\layout Standard
|
|
|
|
|
|
\series bold
|
|
\emph on
|
|
Warning: attempting to pass
|
|
\family typewriter
|
|
@argv
|
|
\family default
|
|
to a non-engine function will not work.
|
|
This is because of changes in how local variables are handled by the compiler.
|
|
\layout Subsection
|
|
|
|
Improved type checking
|
|
\layout Standard
|
|
|
|
Function parameters and return types are are fully checked, including the
|
|
number of parameters passed to a function.
|
|
Functions with different return types and/or different parameter types
|
|
or counts are distinct types and mixing them up will cause a type mismatch
|
|
error.
|
|
Similar for pointers to various types.
|
|
\layout Section
|
|
|
|
Variables
|
|
\layout Subsection
|
|
|
|
Local variables
|
|
\layout Subsubsection
|
|
|
|
Initialization
|
|
\layout Standard
|
|
|
|
Local variables of basic types can now be initialized when declared.
|
|
e,g,
|
|
\layout Verse
|
|
|
|
|
|
\family typewriter
|
|
local integer elite = 31337;
|
|
\layout Subsubsection
|
|
|
|
Unused variables
|
|
\layout Standard
|
|
|
|
Local variables that are declared but not used produce a warning.
|
|
\layout Subsubsection
|
|
|
|
Uninitialized variables
|
|
\layout Standard
|
|
|
|
Checks are done to ensure that local variables have been initialized before
|
|
being used.
|
|
However, these checks are not perfect and false positives are very likely
|
|
in complex code.
|
|
Occurrences of false negatives are not known, but the possibility of their
|
|
existence remains and any examples of false negatives should be reported
|
|
as bugs.
|
|
\layout Subsection
|
|
|
|
Complex global variables
|
|
\layout Standard
|
|
|
|
Global array variables can be initialized using
|
|
\family typewriter
|
|
= {
|
|
\emph on
|
|
element-list
|
|
\emph default
|
|
};
|
|
\family default
|
|
.
|
|
Element lists may be nested using
|
|
\family typewriter
|
|
{}
|
|
\family default
|
|
.
|
|
Structures cannot currently be initialized, but this is a FIXME :)
|
|
\layout Subsection
|
|
|
|
Magic variables
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@self
|
|
\family default
|
|
Automagically-declared entity variable the engine will use for
|
|
\family typewriter
|
|
touch
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
think
|
|
\family default
|
|
functions.
|
|
This allows
|
|
\family typewriter
|
|
self
|
|
\family default
|
|
to be used as the object hidden parameter in methods.
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@this
|
|
\family default
|
|
Automagically-declared
|
|
\family typewriter
|
|
id
|
|
\family default
|
|
field that the engine expects to point to the object associated with the
|
|
entity.
|
|
The engine will use this field, if it exists, to set the
|
|
\family typewriter
|
|
self
|
|
\family default
|
|
parameter to
|
|
\family typewriter
|
|
touch
|
|
\family default
|
|
and
|
|
\family typewriter
|
|
think
|
|
\family default
|
|
methods (the engine assumes it's calling a method rather than a function
|
|
if the @this field is used.
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@argc
|
|
\family default
|
|
Number of parameters passed through
|
|
\family typewriter
|
|
...
|
|
|
|
\family default
|
|
in vararg functions.
|
|
Not valid elsewhere.
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@argv
|
|
\family default
|
|
Array of vectors representing the parameters passed through
|
|
\family typewriter
|
|
...
|
|
|
|
\family default
|
|
in vararg functions.
|
|
Not valid elsewhere.
|
|
\layout Section
|
|
|
|
Code constructs
|
|
\layout Subsection
|
|
|
|
|
|
\family typewriter
|
|
break
|
|
\layout Standard
|
|
|
|
The
|
|
\family typewriter
|
|
break
|
|
\family default
|
|
statement can be used to leave a loop (
|
|
\family typewriter
|
|
while
|
|
\family default
|
|
,
|
|
\family typewriter
|
|
do
|
|
\family default
|
|
...
|
|
|
|
\family typewriter
|
|
while
|
|
\family default
|
|
, or
|
|
\family typewriter
|
|
for
|
|
\family default
|
|
) prematurely.
|
|
The
|
|
\family typewriter
|
|
break
|
|
\family default
|
|
statement is also used to leave a
|
|
\family typewriter
|
|
switch
|
|
\family default
|
|
statement.
|
|
\layout Subsection
|
|
|
|
|
|
\family typewriter
|
|
continue
|
|
\layout Standard
|
|
|
|
The
|
|
\family typewriter
|
|
continue
|
|
\family default
|
|
statement is used to jump to the beginning of a loop.
|
|
In
|
|
\family typewriter
|
|
for
|
|
\family default
|
|
loops, the test and post expressions are evaluated before continuing with
|
|
the loop.
|
|
\layout Subsection
|
|
|
|
|
|
\family typewriter
|
|
for
|
|
\layout Standard
|
|
|
|
The
|
|
\family typewriter
|
|
for
|
|
\family default
|
|
loop is:
|
|
\layout LyX-Code
|
|
|
|
for (
|
|
\emph on
|
|
initialization-expression
|
|
\emph default
|
|
;
|
|
\emph on
|
|
test-expression
|
|
\emph default
|
|
;
|
|
\emph on
|
|
post-expression
|
|
\emph default
|
|
)
|
|
\layout LyX-Code
|
|
|
|
|
|
\emph on
|
|
statement
|
|
\layout Standard
|
|
|
|
and is equivalent to
|
|
\layout LyX-Code
|
|
|
|
|
|
\emph on
|
|
initialization expression
|
|
\layout LyX-Code
|
|
|
|
while (
|
|
\emph on
|
|
test expression
|
|
\emph default
|
|
) {
|
|
\layout LyX-Code
|
|
|
|
|
|
\emph on
|
|
statement
|
|
\layout LyX-Code
|
|
|
|
|
|
\emph on
|
|
post expression
|
|
\layout LyX-Code
|
|
|
|
}
|
|
\layout Subsection
|
|
|
|
|
|
\family typewriter
|
|
switch
|
|
\layout Standard
|
|
|
|
The
|
|
\family typewriter
|
|
switch
|
|
\family default
|
|
statement is used to select between multiple code blocks based on the value
|
|
of an expression.
|
|
\layout LyX-Code
|
|
|
|
switch (
|
|
\emph on
|
|
test expression
|
|
\emph default
|
|
) {
|
|
\newline
|
|
case
|
|
\emph on
|
|
value
|
|
\emph default
|
|
:
|
|
\newline
|
|
|
|
\emph on
|
|
optional statements
|
|
\newline
|
|
|
|
\emph default
|
|
case
|
|
\emph on
|
|
value
|
|
\emph default
|
|
:
|
|
\newline
|
|
|
|
\emph on
|
|
optional statements
|
|
\emph default
|
|
|
|
\newline
|
|
default:
|
|
\newline
|
|
|
|
\emph on
|
|
optional statements
|
|
\emph default
|
|
|
|
\newline
|
|
}
|
|
\layout Standard
|
|
|
|
Code execution starts at the selected
|
|
\family typewriter
|
|
case
|
|
\family default
|
|
and continues on to the end of the switch block.
|
|
Following
|
|
\family typewriter
|
|
case
|
|
\family default
|
|
s do
|
|
\emph on
|
|
not
|
|
\emph default
|
|
affect code execution.
|
|
If this behavior is not desired, as is usual, then a
|
|
\family typewriter
|
|
break
|
|
\family default
|
|
statement is required to cause the code to jump to the end of the
|
|
\family typewriter
|
|
switch
|
|
\family default
|
|
, skipping any intervening code.
|
|
That is, just like C.
|
|
\layout Subsubsection
|
|
|
|
|
|
\family typewriter
|
|
\emph on
|
|
test expression
|
|
\layout Standard
|
|
|
|
The test expression may result in a float, string or integer value.
|
|
\layout Subsubsection
|
|
|
|
|
|
\family typewriter
|
|
case
|
|
\emph on
|
|
value
|
|
\layout Verse
|
|
|
|
|
|
\family typewriter
|
|
case
|
|
\emph on
|
|
value
|
|
\emph default
|
|
:
|
|
\layout Standard
|
|
|
|
The case value may be of any constant type consistent with the test expression
|
|
of the
|
|
\family typewriter
|
|
switch
|
|
\family default
|
|
.
|
|
\layout Subsubsection
|
|
|
|
|
|
\family typewriter
|
|
default
|
|
\layout Standard
|
|
|
|
If specified, this is where execution will go when no
|
|
\family typewriter
|
|
case
|
|
\family default
|
|
has been selected by the test expression.
|
|
If not specified, and no
|
|
\family typewriter
|
|
case
|
|
\family default
|
|
has been selected by the test expression, the
|
|
\family typewriter
|
|
switch
|
|
\family default
|
|
does not execute any code within the block.
|
|
\layout Section
|
|
|
|
Expressions
|
|
\layout Subsection
|
|
|
|
Binary
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
<<\SpecialChar ~
|
|
>>
|
|
\family default
|
|
bit shift left and right
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
^
|
|
\family default
|
|
bitwise exclusive or
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
%
|
|
\family default
|
|
modulus
|
|
\layout Subsubsection
|
|
|
|
Assignment
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
\emph on
|
|
op
|
|
\emph default
|
|
=
|
|
\family default
|
|
equivalent to
|
|
\family typewriter
|
|
a = a
|
|
\emph on
|
|
op
|
|
\emph default
|
|
b
|
|
\family default
|
|
.
|
|
\layout Subsection
|
|
|
|
Unary
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
~
|
|
\family default
|
|
bitwise not
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
&
|
|
\family default
|
|
address
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
++
|
|
\emph on
|
|
e
|
|
\emph default
|
|
\SpecialChar ~
|
|
--
|
|
\emph on
|
|
e
|
|
\family default
|
|
\emph default
|
|
pre-increment and decrement
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
\emph on
|
|
e
|
|
\emph default
|
|
++\SpecialChar ~
|
|
|
|
\emph on
|
|
e
|
|
\emph default
|
|
--
|
|
\family default
|
|
post-increment and decrement
|
|
\layout Subsection
|
|
|
|
Other
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
\emph on
|
|
type\SpecialChar ~
|
|
|
|
\emph default
|
|
(
|
|
\emph on
|
|
expr
|
|
\emph default
|
|
)
|
|
\family default
|
|
cast expression.
|
|
Only works for converting between integer and float types and between pointer
|
|
types.
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
\emph on
|
|
expr
|
|
\emph default
|
|
[
|
|
\emph on
|
|
expr
|
|
\emph default
|
|
]
|
|
\family default
|
|
array indexing.
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
\emph on
|
|
expr
|
|
\emph default
|
|
?
|
|
\emph on
|
|
expr
|
|
\emph default
|
|
:
|
|
\emph on
|
|
expr
|
|
\family default
|
|
\emph default
|
|
C's trinary expression
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
[
|
|
\emph on
|
|
expr
|
|
\emph default
|
|
\SpecialChar ~
|
|
|
|
\emph on
|
|
exprs
|
|
\emph default
|
|
]
|
|
\family default
|
|
Objective-QC message
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@selector(
|
|
\emph on
|
|
exprs
|
|
\emph default
|
|
)
|
|
\family default
|
|
Objective-QC selector expression
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@protocol(
|
|
\emph on
|
|
name
|
|
\emph default
|
|
)
|
|
\family default
|
|
Objective-QC protocol expression
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@encode(
|
|
\emph on
|
|
type
|
|
\emph default
|
|
)
|
|
\family default
|
|
Objective-QC type encoding expression
|
|
\layout Labeling
|
|
\labelwidthstring 00.00.0000
|
|
|
|
|
|
\family typewriter
|
|
@
|
|
\emph on
|
|
string
|
|
\family default
|
|
\emph default
|
|
Objective-QC string object.
|
|
Currently identical to a normal QC string.
|
|
\layout Standard
|
|
|
|
|
|
\begin_inset LatexCommand \printindex{}
|
|
|
|
\end_inset
|
|
|
|
|
|
\the_end
|