Changes in / [182fe1e:08061589]


Ignore:
Location:
doc
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • doc/LaTeXmacros/common.tex

    r182fe1e r08061589  
    1010%% Author           : Peter A. Buhr
    1111%% Created On       : Sat Apr  9 10:06:17 2016
    12 <<<<<<< HEAD
    13 %% Last Modified By : Peter A. Buhr
    14 %% Last Modified On : Mon Aug  1 08:57:17 2016
    15 %% Update Count     : 223
    16 =======
    1712%% Last Modified By :
    1813%% Last Modified On : Sun Jul 31 07:22:50 2016
    1914%% Update Count     : 207
    20 >>>>>>> 080615890f586cb9954c252b55cab47f52c25758
    2115%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    2216
     
    2519\setlength{\textheight}{9in}
    2620%\oddsidemargin 0.0in
    27 \renewcommand{\topfraction}{0.8}                % float must be greater than X of the page before it is forced onto its own page
    28 \renewcommand{\bottomfraction}{0.8}             % float must be greater than X of the page before it is forced onto its own page
     21\renewcommand{\topfraction}{0.8}        % float must be greater than X of the page before it is forced onto its own page
     22\renewcommand{\bottomfraction}{0.8}     % float must be greater than X of the page before it is forced onto its own page
    2923\renewcommand{\floatpagefraction}{0.8}  % float must be greater than X of the page before it is forced onto its own page
    30 \renewcommand{\textfraction}{0.0}               % the entire page maybe devoted to floats with no text on the page at all
    31 
    32 \lefthyphenmin=4                                                % hyphen only after 4 characters
     24\renewcommand{\textfraction}{0.0}       % the entire page maybe devoted to floats with no text on the page at all
     25
     26\lefthyphenmin=4
    3327\righthyphenmin=4
    3428
     
    4438% Names used in the document.
    4539
    46 \newcommand{\CFA}{C$\mathbf\forall$\xspace} % set language symbolic name
    47 \newcommand{\CFL}{Cforall\xspace}               % set language text name
     40\newcommand{\CFA}{C$\mathbf\forall$\xspace}              % set language symbolic name
     41\newcommand{\CFL}{Cforall\xspace}                        % set language text name
    4842\newcommand{\CC}{\rm C\kern-.1em\hbox{+\kern-.25em+}\xspace} % CC symbolic name
    4943\newcommand{\CCeleven}{\rm C\kern-.1em\hbox{+\kern-.25em+}11\xspace} % C++11 symbolic name
    50 \def\c11{ISO/IEC C}                                             % C11 name (cannot have numbers in latex command name)
     44\def\c11{ISO/IEC C} % C11 name (cannot have numbers in latex command name)
    5145
    5246%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
     
    5852\setlength{\parindentlnth}{\parindent}
    5953
    60 \newlength{\gcolumnposn}                                % temporary hack because lstlisting does handle tabs correctly
     54\newlength{\gcolumnposn}
    6155\newlength{\columnposn}
    6256\setlength{\gcolumnposn}{2.5in}
     
    6963%\patchcmd{\lsthk@TextStyle}{\let\lst@DefEsc\@empty}{}{}{\errmessage{failed to patch}}
    7064
    71 \usepackage{pslatex}                                    % reduce size of san serif font
    72 \usepackage{relsize}                                    % must be after change to small or selects old size
     65\usepackage{pslatex}                                                                    % reduce size of san serif font
     66\usepackage{relsize}                                    % must be after change to small or selects old size
    7367
    7468% reduce size of chapter/section titles
     
    126120
    127121% inline text and lowercase index: \Index{inline and lowercase index text}
     122% inline text and as-in index: \Index[as-is index text]{inline text}
     123% inline text but index with different as-is text: \Index[index text]{inline text}
    128124\newcommand{\Index}{\@ifstar\@sIndex\@Index}
    129 % inline text and as-in index: \Index[as-is index text]{inline text}
    130125\newcommand{\@Index}[2][\@empty]{\lowercase{\def\temp{#2}}#2\ifx#1\@empty\index{\temp}\else\index{#1@{\protect#2}}\fi}
    131 % inline text but index with different as-is text: \Index[index text]{inline text}
    132126\newcommand{\@sIndex}[2][\@empty]{#2\ifx#1\@empty\index{#2}\else\index{#1@{\protect#2}}\fi}
    133127
    134 % inline text and code index (cannot use ©)
     128% cannot use ©
    135129\newcommand{\Indexc}[1]{\lstinline$#1$\index{#1@\lstinline$#1$}}
    136 % code index (cannot use ©)
    137130\newcommand{\indexc}[1]{\index{#1@\lstinline$#1$}}
    138131
     
    144137\newcommand{\@newterm}[2][\@empty]{\lowercase{\def\temp{#2}}{\newtermFontInline{#2}}\ifx#1\@empty\index{\temp}\else\index{#1@{\protect#2}}\fi}
    145138\newcommand{\@snewterm}[2][\@empty]{{\newtermFontInline{#2}}\ifx#1\@empty\index{#2}\else\index{#1@{\protect#2}}\fi}
    146 
    147 % Latin abbreviation
    148 \newcommand{\abbrevFont}{\textit}       % set empty for no italics
    149 \newcommand*{\eg}{%
    150         \@ifnextchar{,}{\abbrevFont{e}.\abbrevFont{g}.}%
    151                 {\@ifnextchar{:}{\abbrevFont{e}.\abbrevFont{g}.}%
    152                         {\abbrevFont{e}.\abbrevFont{g}.,\xspace}}%
    153 }%
    154 \newcommand*{\ie}{%
    155         \@ifnextchar{,}{\abbrevFont{i}.\abbrevFont{e}.}%
    156                 {\@ifnextchar{:}{\abbrevFont{i}.\abbrevFont{e}.}%
    157                         {\abbrevFont{i}.\abbrevFont{e}.,\xspace}}%
    158 }%
    159 \newcommand*{\etc}{%
    160         \@ifnextchar{.}{\abbrevFont{etc}}%
    161         {\abbrevFont{etc}.\xspace}%
    162 }%
    163139\makeatother
    164140
     
    169145        \endlist
    170146}% quote2
    171 
    172147\newenvironment{rationale}{%
    173148  \begin{quote2}\noindent$\Box$\enspace
     
    213188\newcommand{\VPageref}[2][page]{\ifx#1\@empty\else{#1}\nobreakspace\fi\pageref{#2}}
    214189
    215 % Go programming language: https://github.com/julienc91/listings-golang/blob/master/listings-golang.sty
     190% Go programming language
    216191\lstdefinelanguage{Golang}{
    217192        morekeywords=[1]{package,import,func,type,struct,return,defer,panic, recover,select,var,const,iota,},%
     
    229204}
    230205
    231 % CFA programming language, based on ANSI C (with some gcc additions)
     206% CFA programming language, based on ANSI C
    232207\lstdefinelanguage{CFA}[ANSI]{C}{
    233208        morekeywords={_Alignas,_Alignof,__alignof,__alignof__,asm,__asm,__asm__,_At,_Atomic,__attribute,__attribute__,auto,
     
    240215language=CFA,
    241216columns=fullflexible,
    242 basicstyle=\linespread{0.9}\sf,                 % reduce line spacing and use sanserif font
    243 stringstyle=\tt,                                                % use typewriter font
    244 tabsize=4,                                                              % 4 space tabbing
    245 xleftmargin=\parindentlnth,                             % indent code to paragraph indentation
    246 extendedchars=true,                                             % allow ASCII characters in the range 128-255
    247 escapechar=§,                                                   % escape to latex in CFA code
    248 mathescape=true,                                                % allow $...$ LaTeX math escapes in code
    249 %keepspaces=true,                                               %
    250 showstringspaces=false,                                 % do not show spaces with cup
    251 showlines=true,                                                 % show blank lines at end of code
    252 aboveskip=4pt,                                                  % spacing above/below code block
     217basicstyle=\linespread{0.9}\sf,
     218stringstyle=\tt,
     219tabsize=4,
     220xleftmargin=\parindentlnth,
     221extendedchars=true,
     222escapechar=§,
     223mathescape=true,
     224keepspaces=true,
     225showstringspaces=false,
     226showlines=true,
     227aboveskip=4pt,
    253228belowskip=3pt,
    254 moredelim=**[is][\color{red}]{®}{®},    % red highlighting
    255 moredelim=**[is][\color{blue}]{ß}{ß},   % blue highlighting
     229moredelim=**[is][\color{red}]{®}{®}, % red highlighting
     230moredelim=**[is][\color{blue}]{ß}{ß}, % blue highlighting
    256231moredelim=**[is][\color{OliveGreen}]{¢}{¢}, % green highlighting
    257232moredelim=[is][\lstset{keywords={}}]{¶}{¶}, % temporarily turn off keywords
     
    267242\renewcommand\thebibliography[1]{
    268243  \Oldthebibliography{#1}
    269   \setlength{\parskip}{0pt}                             % reduce vertical spacing between references
     244  \setlength{\parskip}{0pt}                     % reduce vertical spacing between references
    270245  \setlength{\itemsep}{5pt plus 0.3ex}
    271246}%
     247
     248\newcommand*{\eg}{\textit{e.g}.\@\xspace}
     249\newcommand*{\ie}{\textit{i.e}.\@\xspace}
     250
     251\makeatletter
     252\newcommand*{\etc}{%
     253    \@ifnextchar{.}%
     254        {\textit{etc}}%
     255        {\textit{etc}.\@\xspace}%
     256}
     257\makeatother
    272258
    273259% Local Variables: %
  • doc/user/user.tex

    r182fe1e r08061589  
    1010%% Author           : Peter A. Buhr
    1111%% Created On       : Wed Apr  6 14:53:29 2016
    12 <<<<<<< HEAD
    13 %% Last Modified By : Peter A. Buhr
    14 %% Last Modified On : Mon Aug  1 08:43:49 2016
    15 %% Update Count     : 1270
    16 =======
    1712%% Last Modified By :
    1813%% Last Modified On : Sun Jul 31 07:27:55 2016
    1914%% Update Count     : 1254
    20 >>>>>>> 080615890f586cb9954c252b55cab47f52c25758
    2115%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
    2216
     
    217211however, it largely extended the language, and did not address many existing problems.\footnote{%
    218212Two important existing problems addressed were changing the type of character literals from ©int© to ©char© and enumerator from ©int© to the type of its enumerators.}
    219 \Index*{Fortran}~\cite{Fortran08}, \Index*{Ada}~\cite{Ada12}, and \Index*{Cobol}~\cite{Cobol14} are examples of programming languages that took an evolutionary approach, where modern language features (\eg objects, concurrency) are added and problems fixed within the framework of the existing language.
     213\Index*{Fortran}~\cite{Fortran08}, \Index*{Ada}~\cite{Ada12}, and \Index*{Cobol}~\cite{Cobol14} are examples of programming languages that took an evolutionary approach, where modern language features (e.g., objects, concurrency) are added and problems fixed within the framework of the existing language.
    220214\Index*{Java}~\cite{Java8}, \Index*{Go}~\cite{Go}, \Index*{Rust}~\cite{Rust} and \Index*{D}~\cite{D} are examples of the revolutionary approach for modernizing C/\CC, resulting in a new language rather than an extension of the descendent.
    221215These languages have different syntax and semantics from C, and do not interoperate directly with C, largely because of garbage collection.
     
    271265\section[Compiling CFA Program]{Compiling \CFA Program}
    272266
    273 The command ©cfa© is used to compile \CFA program(s), and is based on the GNU \Indexc{gcc} command, \eg:
     267The command ©cfa© is used to compile \CFA program(s), and is based on the GNU \Indexc{gcc} command, e.g.:
    274268\begin{lstlisting}
    275269cfa§\indexc{cfa}\index{compilation!cfa@©cfa©}§ [ gcc-options ] C/§\CFA§-files [ assembler/loader-files ]
     
    356350\section{Underscores in Constants}
    357351
    358 Numeric constants are extended to allow \Index{underscore}s within constants\index{constant!underscore}, \eg:
     352Numeric constants are extended to allow \Index{underscore}s within constants\index{constant!underscore}, e.g.:
    359353\begin{lstlisting}
    3603542®_®147®_®483®_®648;                    §\C{// decimal constant}§
     
    372366\begin{enumerate}
    373367\item
    374 A sequence of underscores is disallowed, \eg ©12__34© is invalid.
     368A sequence of underscores is disallowed, e.g., ©12__34© is invalid.
    375369\item
    376370Underscores may only appear within a sequence of digits (regardless of the digit radix).
    377 In other words, an underscore cannot start or end a sequence of digits, \eg ©_1©, ©1_© and ©_1_© are invalid (actually, the 1st and 3rd examples are identifier names).
     371In other words, an underscore cannot start or end a sequence of digits, e.g., ©_1©, ©1_© and ©_1_© are invalid (actually, the 1st and 3rd examples are identifier names).
    378372\item
    379373A numeric prefix may end with an underscore;
     
    504498\end{quote2}
    505499
    506 All type qualifiers, \eg ©const©, ©volatile©, etc., are used in the normal way with the new declarations and also appear left to right, \eg:
     500All type qualifiers, e.g., ©const©, ©volatile©, etc., are used in the normal way with the new declarations and also appear left to right, e.g.:
    507501\begin{quote2}
    508502\begin{tabular}{@{}l@{\hspace{1em}}l@{\hspace{1em}}l@{}}
     
    524518\end{tabular}
    525519\end{quote2}
    526 All declaration qualifiers, \eg ©extern©, ©static©, etc., are used in the normal way with the new declarations but can only appear at the start of a \CFA routine declaration,\footnote{\label{StorageClassSpecifier}
    527 The placement of a storage-class specifier other than at the beginning of the declaration specifiers in a declaration is an obsolescent feature.~\cite[\S~6.11.5(1)]{C11}} \eg:
     520All declaration qualifiers, e.g., ©extern©, ©static©, etc., are used in the normal way with the new declarations but can only appear at the start of a \CFA routine declaration,\footnote{\label{StorageClassSpecifier}
     521The placement of a storage-class specifier other than at the beginning of the declaration specifiers in a declaration is an obsolescent feature.~\cite[\S~6.11.5(1)]{C11}} e.g.:
    528522\begin{quote2}
    529523\begin{tabular}{@{}l@{\hspace{3em}}l@{\hspace{2em}}l@{}}
     
    548542Unsupported are K\&R C declarations where the base type defaults to ©int©, if no type is specified,\footnote{
    549543At least one type specifier shall be given in the declaration specifiers in each declaration, and in the specifier-qualifier list in each structure declaration and type name~\cite[\S~6.7.2(2)]{C11}}
    550 \eg:
     544e.g.:
    551545\begin{lstlisting}
    552546x;                                                              §\C{// int x}§
     
    618612A \Index{pointer}/\Index{reference} is a generalization of a variable name, i.e., a mutable address that can point to more than one memory location during its lifetime.
    619613(Similarly, an integer variable can contain multiple integer literals during its lifetime versus an integer constant representing a single literal during its lifetime and may not occupy storage as the literal is embedded directly into instructions.)
    620 Hence, a pointer occupies memory to store its current address, and the pointer's value is loaded by dereferencing, \eg:
     614Hence, a pointer occupies memory to store its current address, and the pointer's value is loaded by dereferencing, e.g.:
    621615\begin{quote2}
    622616\begin{tabular}{@{}ll@{}}
     
    675669Except for auto-dereferencing by the compiler, this reference example is the same as the previous pointer example.
    676670Hence, a reference behaves like the variable name for the current variable it is pointing-to.
    677 The simplest way to understand a reference is to imagine the compiler inserting a dereference operator before the reference variable for each reference qualifier in a declaration, \eg:
     671The simplest way to understand a reference is to imagine the compiler inserting a dereference operator before the reference variable for each reference qualifier in a declaration, e.g.:
    678672\begin{lstlisting}
    679673r2 = ((r1 + r2) * (r3 - r1)) / (r3 - 15);
     
    683677®*®r2 = ((®*®r1 + ®*®r2) ®*® (®**®r3 - ®*®r1)) / (®**®r3 - 15);
    684678\end{lstlisting}
    685 When a reference operation appears beside a dereference operation, \eg ©&*©, they cancel out.\footnote{
     679When a reference operation appears beside a dereference operation, e.g., ©&*©, they cancel out.\footnote{
    686680The unary ©&© operator yields the address of its operand.
    687681If the operand has type ``type'', the result has type ``pointer to type''.
     
    727721®&®crc = &cx;                                   §\C{// error, cannot change crc}§
    728722\end{lstlisting}
    729 Hence, for type ©& const©, there is no pointer assignment, so ©&rc = &x© is disallowed, and \emph{the address value cannot be ©0© unless an arbitrary pointer is assigned to the reference}, \eg:
     723Hence, for type ©& const©, there is no pointer assignment, so ©&rc = &x© is disallowed, and \emph{the address value cannot be ©0© unless an arbitrary pointer is assigned to the reference}, e.g.:
    730724\begin{lstlisting}
    731725int & const r = *0;                             §\C{// where 0 is the int * zero}§
    732726\end{lstlisting}
    733727Otherwise, the compiler is managing the addresses for type ©& const© not the programmer, and by a programming discipline of only using references with references, address errors can be prevented.
    734 Finally, the position of the ©const© qualifier \emph{after} the pointer/reference qualifier causes confuse for C programmers.
    735 The ©const© qualifier cannot be moved before the pointer/reference qualifier for C style-declarations;
    736 \CFA-style declarations attempt to address this issue:
    737 \begin{quote2}
    738 \begin{tabular}{@{}l@{\hspace{3em}}l@{}}
    739 \multicolumn{1}{c@{\hspace{3em}}}{\textbf{\CFA}}        & \multicolumn{1}{c}{\textbf{C}}        \\
    740 \begin{lstlisting}
    741 ®const® * ®const® * const int ccp;
    742 ®const® & ®const® & const int ccr;
    743 \end{lstlisting}
    744 &
    745 \begin{lstlisting}
    746 const int * ®const® * ®const® ccp;
    747 
    748 \end{lstlisting}
    749 \end{tabular}
    750 \end{quote2}
    751 where the \CFA declaration is read left-to-right (see \VRef{s:Declarations}).
    752728
    753729\Index{Initialization} is different than \Index{assignment} because initialization occurs on the empty (uninitialized) storage on an object, while assignment occurs on possibly initialized storage of an object.
     
    809785\section{Type Operators}
    810786
    811 The new declaration syntax can be used in other contexts where types are required, \eg casts and the pseudo-routine ©sizeof©:
     787The new declaration syntax can be used in other contexts where types are required, e.g., casts and the pseudo-routine ©sizeof©:
    812788\begin{quote2}
    813789\begin{tabular}{@{}l@{\hspace{3em}}l@{}}
     
    829805
    830806\CFA also supports a new syntax for routine definition, as well as ISO C and K\&R routine syntax.
    831 The point of the new syntax is to allow returning multiple values from a routine~\cite{Galletly96,CLU}, \eg:
     807The point of the new syntax is to allow returning multiple values from a routine~\cite{Galletly96,CLU}, e.g.:
    832808\begin{lstlisting}
    833809®[ int o1, int o2, char o3 ]® f( int i1, char i2, char i3 ) {
     
    841817\Index*{Michael Tiemann}, with help from \Index*{Doug Lea}, provided named return values in g++, circa 1989.}
    842818The value of each local return variable is automatically returned at routine termination.
    843 Declaration qualifiers can only appear at the start of a routine definition, \eg:
     819Declaration qualifiers can only appear at the start of a routine definition, e.g.:
    844820\begin{lstlisting}
    845821®extern® [ int x ] g( int y ) {§\,§}
     
    873849The inability to use \CFA declarations in these two contexts is probably a blessing because it precludes programmers from arbitrarily switching between declarations forms within a declaration contexts.
    874850
    875 C-style declarations can be used to declare parameters for \CFA style routine definitions, \eg:
     851C-style declarations can be used to declare parameters for \CFA style routine definitions, e.g.:
    876852\begin{lstlisting}
    877853[ int ] f( * int, int * );              §\C{// returns an integer, accepts 2 pointers to integers}§
     
    922898
    923899The syntax of the new routine prototype declaration follows directly from the new routine definition syntax;
    924 as well, parameter names are optional, \eg:
     900as well, parameter names are optional, e.g.:
    925901\begin{lstlisting}
    926902[ int x ] f ();                                 §\C{// returning int with no parameters}§
     
    930906\end{lstlisting}
    931907This syntax allows a prototype declaration to be created by cutting and pasting source text from the routine definition header (or vice versa).
    932 It is possible to declare multiple routine-prototypes in a single declaration, but the entire type specification is distributed across \emph{all} routine names in the declaration list (see~\VRef{s:Declarations}), \eg:
     908It is possible to declare multiple routine-prototypes in a single declaration, but the entire type specification is distributed across \emph{all} routine names in the declaration list (see~\VRef{s:Declarations}), e.g.:
    933909\begin{quote2}
    934910\begin{tabular}{@{}l@{\hspace{3em}}l@{}}
     
    943919\end{tabular}
    944920\end{quote2}
    945 Declaration qualifiers can only appear at the start of a \CFA routine declaration,\footref{StorageClassSpecifier} \eg:
     921Declaration qualifiers can only appear at the start of a \CFA routine declaration,\footref{StorageClassSpecifier} e.g.:
    946922\begin{lstlisting}
    947923extern [ int ] f (int);
     
    952928\section{Routine Pointers}
    953929
    954 The syntax for pointers to \CFA routines specifies the pointer name on the right, \eg:
     930The syntax for pointers to \CFA routines specifies the pointer name on the right, e.g.:
    955931\begin{lstlisting}
    956932* [ int x ] () fp;                      §\C{// pointer to routine returning int with no parameters}§
     
    10701046p( /* positional */, /* named */, . . . );
    10711047\end{lstlisting}
    1072 While it is possible to implement both approaches, the first possibly is more complex than the second, \eg:
     1048While it is possible to implement both approaches, the first possibly is more complex than the second, e.g.:
    10731049\begin{lstlisting}
    10741050p( int x, int y, int z, . . . );
     
    10801056In the second call, the named arguments separate the positional and ellipse arguments, making it trivial to read the call.
    10811057
    1082 The problem is exacerbated with default arguments, \eg:
     1058The problem is exacerbated with default arguments, e.g.:
    10831059\begin{lstlisting}
    10841060void p( int x, int y = 2, int z = 3. . . );
     
    12881264
    12891265As mentioned, tuples can appear in contexts requiring a list of value, such as an argument list of a routine call.
    1290 In unambiguous situations, the tuple brackets may be omitted, \eg a tuple that appears as an argument may have its
     1266In unambiguous situations, the tuple brackets may be omitted, e.g., a tuple that appears as an argument may have its
    12911267square brackets omitted for convenience; therefore, the following routine invocations are equivalent:
    12921268\begin{lstlisting}
     
    13271303
    13281304Type qualifiers, i.e., const and volatile, may modify a tuple type.
    1329 The meaning is the same as for a type qualifier modifying an aggregate type [Int99, x 6.5.2.3(7),x 6.7.3(11)], i.e., the qualifier is distributed across all of the types in the tuple, \eg:
     1305The meaning is the same as for a type qualifier modifying an aggregate type [Int99, x 6.5.2.3(7),x 6.7.3(11)], i.e., the qualifier is distributed across all of the types in the tuple, e.g.:
    13301306\begin{lstlisting}
    13311307const volatile [ int, float, const int ] x;
     
    13351311[ const volatile int, const volatile float, const volatile int ] x;
    13361312\end{lstlisting}
    1337 Declaration qualifiers can only appear at the start of a \CFA tuple declaration4, \eg:
     1313Declaration qualifiers can only appear at the start of a \CFA tuple declaration4, e.g.:
    13381314\begin{lstlisting}
    13391315extern [ int, int ] w1;
     
    13431319Unfortunately, C's syntax for subscripts precluded treating them as tuples.
    13441320The C subscript list has the form ©[i][j]...© and not ©[i, j, ...]©.
    1345 Therefore, there is no syntactic way for a routine returning multiple values to specify the different subscript values, \eg ©f[g()]© always means a single subscript value because there is only one set of brackets.
     1321Therefore, there is no syntactic way for a routine returning multiple values to specify the different subscript values, e.g., ©f[g()]© always means a single subscript value because there is only one set of brackets.
    13461322Fixing this requires a major change to C because the syntactic form ©M[i, j, k]© already has a particular meaning: ©i, j, k© is a comma expression.
    13471323\end{rationale}
     
    14041380Clearly, the types of the entities being assigned must be type compatible with the value of the expression.
    14051381
    1406 Mass assignment has parallel semantics, \eg the statement:
     1382Mass assignment has parallel semantics, e.g., the statement:
    14071383\begin{lstlisting}
    14081384[ x, y, z ] = 1.5;
     
    14931469\section{Unnamed Structure Fields}
    14941470
    1495 C requires each field of a structure to have a name, except for a bit field associated with a basic type, \eg:
     1471C requires each field of a structure to have a name, except for a bit field associated with a basic type, e.g.:
    14961472\begin{lstlisting}
    14971473struct {
    1498         int f1;                                 §\C{// named field}§
    1499         int f2 : 4;                             §\C{// named field with bit field size}§
    1500         int : 3;                                §\C{// unnamed field for basic type with bit field size}§
    1501         int ;                                   §\C{// disallowed, unnamed field}§
    1502         int *;                                  §\C{// disallowed, unnamed field}§
    1503         int (*)(int);                   §\C{// disallowed, unnamed field}§
     1474        int f1;                 // named field
     1475        int f2 : 4;             // named field with bit field size
     1476        int : 3;                // unnamed field for basic type with bit field size
     1477        int ;                   // disallowed, unnamed field
     1478        int *;                  // disallowed, unnamed field
     1479        int (*)(int);   // disallowed, unnamed field
    15041480};
    15051481\end{lstlisting}
    15061482This requirement is relaxed by making the field name optional for all field declarations; therefore, all the field declarations in the example are allowed.
    15071483As for unnamed bit fields, an unnamed field is used for padding a structure to a particular size.
    1508 A list of unnamed fields is also supported, \eg:
     1484A list of unnamed fields is also supported, e.g.:
    15091485\begin{lstlisting}
    15101486struct {
    1511         int , , ;                               §\C{// 3 unnamed fields}§
     1487        int , , ;               // 3 unnamed fields
    15121488}
    15131489\end{lstlisting}
     
    15221498§\emph{expr}§ -> [ §\emph{fieldlist}§ ]
    15231499\end{lstlisting}
    1524 \emph{expr} is any expression yielding a value of type record, \eg ©struct©, ©union©.
     1500\emph{expr} is any expression yielding a value of type record, e.g., ©struct©, ©union©.
    15251501Each element of \emph{ fieldlist} is an element of the record specified by \emph{expr}.
    15261502A record-field tuple may be used anywhere a tuple can be used. An example of the use of a record-field tuple is
     
    17841760}
    17851761\end{lstlisting}
    1786 While the declaration of the local variable ©y© is useful with a scope across all ©case© clauses, the initialization for such a variable is defined to never be executed because control always transfers over it.
    1787 Furthermore, any statements before the first ©case© clause can only be executed if labelled and transferred to using a ©goto©, either from outside or inside of the ©switch©, both of which are problematic.
    1788 As well, the declaration of ©z© cannot occur after the ©case© because a label can only be attached to a statement, and without a fall through to case 3, ©z© is uninitialized.
    1789 The key observation is that the ©switch© statement branches into control structure, i.e., there are multiple entry points into its statement body.
     1762While the declaration of the local variable ©y© is useful and its scope is across all ©case© clauses, the initialization for such a variable is defined to never be executed because control always transfers over it.
     1763Furthermore, any statements before the first ©case© clause can only be executed if labelled and transferred to using a ©goto©, either from outside or inside of the ©switch©.
     1764As mentioned, transfer into control structures should be forbidden;
     1765transfers from within the ©switch© body using a ©goto© are equally unpalatable.
     1766As well, the declaration of ©z© is cannot occur after the ©case© because a label can only be attached to a statement, and without a fall through to case 3, ©z© is uninitialized.
    17901767\end{enumerate}
    17911768
     
    18051782\item
    18061783Eliminating default fall-through has the greatest potential for affecting existing code.
    1807 However, even if fall-through is removed, most ©switch© statements would continue to work because of the explicit transfers already present at the end of each ©case© clause, the common placement of the ©default© clause at the end of the case list, and the most common use of fall-through, i.e., a list of ©case© clauses executing common code, \eg:
    1808  \begin{lstlisting}
     1784However, even if fall-through is removed, most ©switch© statements would continue to work because of the explicit transfers already present at the end of each ©case© clause, the common placement of the ©default© clause at the end of the case list, and the most common use of fall-through, i.e., a list of ©case© clauses executing common code, e.g.:
     1785\begin{lstlisting}
    18091786case 1:  case 2:  case 3: ...
    18101787\end{lstlisting}
    18111788still work.
    18121789Nevertheless, reversing the default action would have a non-trivial effect on case actions that compound, such as the above example of processing shell arguments.
    1813 <<<<<<< HEAD
    1814 Therefore, to preserve backwards compatibility, it is necessary to introduce a new kind of ©switch© statement, called ©choose©, with no implicit fall-through semantics and an explicit fall-through if the last statement of a case-clause ends with the new keyword ©fallthru©, \eg:
    1815 =======
    18161790Therefore, to preserve backwards compatibility, it is necessary to introduce a new kind of ©switch© statement, called ©choose©, with no implicit fall-through semantics and an explicit fall-through if the last statement of a case-clause ends with the new keyword ©fallthrough©/©fallthru©, e.g.:
    1817 >>>>>>> 080615890f586cb9954c252b55cab47f52c25758
    18181791\begin{lstlisting}
    18191792®choose® ( i ) {
     
    18421815Therefore, no change is made for this issue.
    18431816\item
    1844 Dealing with unreachable code in a ©switch©/©choose© body is solved by restricting declarations and associated initialization to the start of statement body, which is executed \emph{before} the transfer to the appropriate ©case© clause\footnote{
    1845 Essentially, these declarations are hoisted before the ©switch©/©choose© statement and both declarations and statement are surrounded by a compound statement.} and precluding statements before the first ©case© clause.
    1846 Further declarations at the same nesting level as the statement body are disallowed to ensure every transfer into the body is sound.
     1817Dealing with unreachable code in a ©switch©/©choose© body is solved by restricting declarations and associated initialization to the start of statement body, which is executed \emph{before} the transfer to the appropriate ©case© clause.\footnote{
     1818Essentially, these declarations are hoisted before the statement and both declarations and statement are surrounded by a compound statement.} and precluding statements before the first ©case© clause.
     1819Further declaration in the statement body are disallowed.
    18471820\begin{lstlisting}
    18481821switch ( x ) {
    1849         ®int i = 0;®                            §\C{// allowed only at start
     1822        ®int i = 0;®                            §\C{// allowed
    18501823  case 0:
    18511824        ...
    1852         ®int j = 0;®                            §\C{// disallowed}§
     1825        ®int i = 0;®                            §\C{// disallowed}§
    18531826  case 1:
    18541827    {
    1855                 ®int k = 0;®                    §\C{// allowed at different nesting levels
     1828                ®int i = 0;®                    §\C{// allowed in any compound statement
    18561829                ...
    18571830        }
     
    27342707Like the \Index*[C++]{\CC} lexical problem with closing template-syntax, e.g, ©Foo<Bar<int®>>®©, this issue can be solved with a more powerful lexer/parser.
    27352708
    2736 There are several ambiguous cases with operator identifiers, \eg ©int *?*?()©, where the string ©*?*?© can be lexed as ©*©/©?*?© or ©*?©/©*?©.
    2737 Since it is common practise to put a unary operator juxtaposed to an identifier, \eg ©*i©, users will be annoyed if they cannot do this with respect to operator identifiers.
     2709There are several ambiguous cases with operator identifiers, e.g., ©int *?*?()©, where the string ©*?*?© can be lexed as ©*©/©?*?© or ©*?©/©*?©.
     2710Since it is common practise to put a unary operator juxtaposed to an identifier, e.g., ©*i©, users will be annoyed if they cannot do this with respect to operator identifiers.
    27382711Even with this special hack, there are 5 general cases that cannot be handled.
    27392712The first case is for the function-call identifier ©?()©:
     
    28002773This means that a function requiring mutual exclusion could block if the lock is already held by another thread.
    28012774Blocking on a monitor lock does not block the kernel thread, it simply blocks the user thread, which yields its kernel thread while waiting to obtain the lock.
    2802 If multiple mutex parameters are specified, they will be locked in parameter order (\ie first parameter is locked first) and unlocked in the
     2775If multiple mutex parameters are specified, they will be locked in parameter order (i.e. first parameter is locked first) and unlocked in the
    28032776reverse order.
    28042777\begin{lstlisting}
     
    45034476\CFA is C \emph{incompatible} on this issue, and provides semantics similar to \Index*[C++]{\CC}.
    45044477Nested types are not hoisted and can be referenced using the field selection operator ``©.©'', unlike the \CC scope-resolution operator ``©::©''.
    4505 Given that nested types in C are equivalent to not using them, \ie they are essentially useless, it is unlikely there are any realistic usages that break because of this incompatibility.
     4478Given that nested types in C are equivalent to not using them, i.e., they are essentially useless, it is unlikely there are any realistic usages that break because of this incompatibility.
    45064479\end{description}
    45074480
     
    51945167\label{s:RationalNumbers}
    51955168
    5196 Rational numbers are numbers written as a ratio, \ie as a fraction, where the numerator (top number) and the denominator (bottom number) are whole numbers.
     5169Rational numbers are numbers written as a ratio, i.e., as a fraction, where the numerator (top number) and the denominator (bottom number) are whole numbers.
    51975170When creating and computing with rational numbers, results are constantly reduced to keep the numerator and denominator as small as possible.
    51985171
Note: See TracChangeset for help on using the changeset viewer.