Added 'simplesect' sections to the manual

'simplesect' encloses the introductory text of sections with
subsections, so that each section either is all text or is all
subsections. (This commit also corrects a small brace error in the
manual and extra spaces/tabs in some other files.)
This commit is contained in:
Roberto Ierusalimschy 2020-04-13 13:42:40 -03:00
parent 7ccc6d8290
commit 9e0a8475cd
5 changed files with 56 additions and 6 deletions

View File

@ -16,7 +16,7 @@
/* global table */ /* global table */
#define LUA_GNAME "_G" #define LUA_GNAME "_G"
typedef struct luaL_Buffer luaL_Buffer; typedef struct luaL_Buffer luaL_Buffer;

2
lgc.c
View File

@ -152,7 +152,7 @@ static GCObject **getgclist (GCObject *o) {
** and its key is not marked, mark its entry as dead. This allows the ** and its key is not marked, mark its entry as dead. This allows the
** collection of the key, but keeps its entry in the table (its removal ** collection of the key, but keeps its entry in the table (its removal
** could break a chain). The main feature of a dead key is that it must ** could break a chain). The main feature of a dead key is that it must
** be different from any other value, to do not disturb searches. ** be different from any other value, to do not disturb searches.
** Other places never manipulate dead keys, because its associated empty ** Other places never manipulate dead keys, because its associated empty
** value is enough to signal that the entry is logically empty. ** value is enough to signal that the entry is logically empty.
*/ */

View File

@ -195,7 +195,7 @@ enum OpMode {iABC, iABx, iAsBx, iAx, isJ}; /* basic instruction formats */
typedef enum { typedef enum {
/*---------------------------------------------------------------------- /*----------------------------------------------------------------------
name args description name args description
------------------------------------------------------------------------*/ ------------------------------------------------------------------------*/
OP_MOVE,/* A B R[A] := R[B] */ OP_MOVE,/* A B R[A] := R[B] */
OP_LOADI,/* A sBx R[A] := sBx */ OP_LOADI,/* A sBx R[A] := sBx */

View File

@ -29,7 +29,7 @@
** Integer type for decoded UTF-8 values; MAXUTF needs 31 bits. ** Integer type for decoded UTF-8 values; MAXUTF needs 31 bits.
*/ */
#if (UINT_MAX >> 30) >= 1 #if (UINT_MAX >> 30) >= 1
typedef unsigned int utfint; typedef unsigned int utfint;
#else #else
typedef unsigned long utfint; typedef unsigned long utfint;
#endif #endif

View File

@ -59,8 +59,12 @@ see Roberto's book, @emphx{Programming in Lua}.
@C{-------------------------------------------------------------------------} @C{-------------------------------------------------------------------------}
@sect1{basic| @title{Basic Concepts} @sect1{basic| @title{Basic Concepts}
@simplesect{
This section describes the basic concepts of the language. This section describes the basic concepts of the language.
}
@sect2{TypesSec| @title{Values and Types} @sect2{TypesSec| @title{Values and Types}
Lua is a dynamically typed language. Lua is a dynamically typed language.
@ -570,6 +574,8 @@ right after its creation.
@sect2{GC| @title{Garbage Collection} @sect2{GC| @title{Garbage Collection}
@simplesect{
Lua performs automatic memory management. Lua performs automatic memory management.
This means that This means that
you do not have to worry about allocating memory for new objects you do not have to worry about allocating memory for new objects
@ -597,6 +603,8 @@ or @Lid{collectgarbage} in Lua.
You can also use these functions to control You can also use these functions to control
the collector directly (e.g., to stop and restart it). the collector directly (e.g., to stop and restart it).
}
@sect3{incmode| @title{Incremental Garbage Collection} @sect3{incmode| @title{Incremental Garbage Collection}
In incremental mode, In incremental mode,
@ -934,6 +942,8 @@ and @Lid{lua_yield}.
@C{-------------------------------------------------------------------------} @C{-------------------------------------------------------------------------}
@sect1{language| @title{The Language} @sect1{language| @title{The Language}
@simplesect{
This section describes the lexis, the syntax, and the semantics of Lua. This section describes the lexis, the syntax, and the semantics of Lua.
In other words, In other words,
this section describes this section describes
@ -951,6 +961,8 @@ and other terminal symbols are shown like @bnfter{=}.
The complete syntax of Lua can be found in @refsec{BNF} The complete syntax of Lua can be found in @refsec{BNF}
at the end of this manual. at the end of this manual.
}
@sect2{lexical| @title{Lexical Conventions} @sect2{lexical| @title{Lexical Conventions}
Lua is a @x{free-form} language. Lua is a @x{free-form} language.
@ -1175,12 +1187,16 @@ the variable @id{_ENV} itself is never global @see{globalenv}.
@sect2{stats| @title{Statements} @sect2{stats| @title{Statements}
@simplesect{
Lua supports an almost conventional set of @x{statements}, Lua supports an almost conventional set of @x{statements},
similar to those in other conventional languages. similar to those in other conventional languages.
This set includes This set includes
blocks, assignments, control structures, function calls, blocks, assignments, control structures, function calls,
and variable declarations. and variable declarations.
}
@sect3{@title{Blocks} @sect3{@title{Blocks}
A @x{block} is a list of statements, A @x{block} is a list of statements,
@ -1607,6 +1623,8 @@ in case of errors.
@sect2{expressions| @title{Expressions} @sect2{expressions| @title{Expressions}
@simplesect{
The basic expressions in Lua are the following: The basic expressions in Lua are the following:
@Produc{ @Produc{
@producname{exp}@producbody{prefixexp} @producname{exp}@producbody{prefixexp}
@ -1681,6 +1699,7 @@ even if @id{f} returns several values.
(The value of @T{(f(x,y,z))} is the first value returned by @id{f} (The value of @T{(f(x,y,z))} is the first value returned by @id{f}
or @nil if @id{f} does not return any values.) or @nil if @id{f} does not return any values.)
}
@sect3{arith| @title{Arithmetic Operators} @sect3{arith| @title{Arithmetic Operators}
@ -2301,6 +2320,8 @@ while all of them share the same @id{x}.
@C{-------------------------------------------------------------------------} @C{-------------------------------------------------------------------------}
@sect1{API| @title{The Application Program Interface} @sect1{API| @title{The Application Program Interface}
@simplesect{
@index{C API} @index{C API}
This section describes the @N{C API} for Lua, that is, This section describes the @N{C API} for Lua, that is,
the set of @N{C functions} available to the host program to communicate the set of @N{C functions} available to the host program to communicate
@ -2337,9 +2358,13 @@ every function in the library, except to @Lid{lua_newstate},
which creates a Lua state from scratch and returns a pointer which creates a Lua state from scratch and returns a pointer
to the @emph{main thread} in the new state. to the @emph{main thread} in the new state.
}
@sect2{@title{The Stack} @sect2{@title{The Stack}
@simplesect{
Lua uses a @emph{virtual stack} to pass values to and from C. Lua uses a @emph{virtual stack} to pass values to and from C.
Each element in this stack represents a Lua value Each element in this stack represents a Lua value
(@nil, number, string, etc.). (@nil, number, string, etc.).
@ -2370,6 +2395,7 @@ and
(that is, the element at @N{the top}) (that is, the element at @N{the top})
and index @M{-n} represents the first element. and index @M{-n} represents the first element.
}
@sect3{stacksize| @title{Stack Size} @sect3{stacksize| @title{Stack Size}
@ -2511,6 +2537,8 @@ the @x{global environment}.
@sect2{C-error|@title{Error Handling in C} @sect2{C-error|@title{Error Handling in C}
@simplesect{
Internally, Lua uses the C @id{longjmp} facility to handle errors. Internally, Lua uses the C @id{longjmp} facility to handle errors.
(Lua will use exceptions if you compile it as C++; (Lua will use exceptions if you compile it as C++;
search for @id{LUAI_THROW} in the source code for details.) search for @id{LUAI_THROW} in the source code for details.)
@ -2559,6 +2587,8 @@ However, there is no guarantee about stack space.
To push anything on the stack, To push anything on the stack,
the panic function must first check the available space @see{stacksize}. the panic function must first check the available space @see{stacksize}.
}
@sect3{statuscodes|@title{Status Codes} @sect3{statuscodes|@title{Status Codes}
@ -3621,8 +3651,6 @@ The @Lid{lua_pcall} function returns one of the following status codes:
} }
}
@APIEntry{ @APIEntry{
int lua_pcallk (lua_State *L, int lua_pcallk (lua_State *L,
int nargs, int nargs,
@ -4975,6 +5003,8 @@ refer to the @id{n2}-th upvalue of the Lua closure at index @id{funcindex2}.
@C{-------------------------------------------------------------------------} @C{-------------------------------------------------------------------------}
@sect1{@title{The Auxiliary Library} @sect1{@title{The Auxiliary Library}
@simplesect{
@index{lauxlib.h} @index{lauxlib.h}
The @def{auxiliary library} provides several convenient functions The @def{auxiliary library} provides several convenient functions
to interface C with Lua. to interface C with Lua.
@ -5009,6 +5039,9 @@ you should not use these functions for other stack values.
Functions called @id{luaL_check*} Functions called @id{luaL_check*}
always raise an error if the check is not satisfied. always raise an error if the check is not satisfied.
}
@sect2{@title{Functions and Types} @sect2{@title{Functions and Types}
Here we list all functions and types from the auxiliary library Here we list all functions and types from the auxiliary library
@ -5933,6 +5966,8 @@ This function is used to build a prefix for error messages.
@C{-------------------------------------------------------------------------} @C{-------------------------------------------------------------------------}
@sect1{libraries| @title{The Standard Libraries} @sect1{libraries| @title{The Standard Libraries}
@simplesect{
The standard Lua libraries provide useful functions The standard Lua libraries provide useful functions
that are implemented @N{in C} through the @N{C API}. that are implemented @N{in C} through the @N{C API}.
Some of these functions provide essential services to the language Some of these functions provide essential services to the language
@ -6004,6 +6039,9 @@ the host program can open them individually by using
and @defid{luaopen_debug} (for the debug library). and @defid{luaopen_debug} (for the debug library).
These functions are declared in @defid{lualib.h}. These functions are declared in @defid{lualib.h}.
}
@sect2{predefined| @title{Basic Functions} @sect2{predefined| @title{Basic Functions}
The basic library provides core functions to Lua. The basic library provides core functions to Lua.
@ -6834,6 +6872,8 @@ or @fail plus an error message if none succeeds.
@sect2{strlib| @title{String Manipulation} @sect2{strlib| @title{String Manipulation}
@simplesect{
This library provides generic functions for string manipulation, This library provides generic functions for string manipulation,
such as finding and extracting substrings, and pattern matching. such as finding and extracting substrings, and pattern matching.
When indexing a string in Lua, the first character is at @N{position 1} When indexing a string in Lua, the first character is at @N{position 1}
@ -7187,9 +7227,13 @@ The definition of what a lowercase letter is depends on the current locale.
} }
}
@sect3{pm| @title{Patterns} @sect3{pm| @title{Patterns}
@simplesect{
Patterns in Lua are described by regular strings, Patterns in Lua are described by regular strings,
which are interpreted as patterns by the pattern-matching functions which are interpreted as patterns by the pattern-matching functions
@Lid{string.find}, @Lid{string.find},
@ -7199,6 +7243,8 @@ and @Lid{string.match}.
This section describes the syntax and the meaning This section describes the syntax and the meaning
(that is, what they match) of these strings. (that is, what they match) of these strings.
}
@sect4{@title{Character Class:} @sect4{@title{Character Class:}
A @def{character class} is used to represent a set of characters. A @def{character class} is used to represent a set of characters.
The following combinations are allowed in describing a character class: The following combinations are allowed in describing a character class:
@ -8910,6 +8956,8 @@ is a more portable solution.
@sect1{incompat| @title{Incompatibilities with the Previous Version} @sect1{incompat| @title{Incompatibilities with the Previous Version}
@simplesect{
Here we list the incompatibilities that you may find when moving a program Here we list the incompatibilities that you may find when moving a program
from @N{Lua 5.3} to @N{Lua 5.4}. from @N{Lua 5.3} to @N{Lua 5.4}.
@ -8942,6 +8990,8 @@ precompiled chunks are not compatible between different Lua versions.
The standard paths in the official distribution may The standard paths in the official distribution may
change between versions. change between versions.
}
@sect2{@title{Incompatibilities in the Language} @sect2{@title{Incompatibilities in the Language}
@itemize{ @itemize{