incompatibilities with 2.5 + restrictions on tag methods

This commit is contained in:
Roberto Ierusalimschy 1997-06-20 16:28:16 -03:00
parent f97307b548
commit 3e43275308
1 changed files with 51 additions and 23 deletions

View File

@ -1,4 +1,4 @@
% $Id: manual.tex,v 2.3 1997/06/19 18:03:04 roberto Exp roberto $ % $Id: manual.tex,v 2.4 1997/06/19 18:49:40 roberto Exp roberto $
\documentstyle[fullpage,11pt,bnf]{article} \documentstyle[fullpage,11pt,bnf]{article}
@ -38,7 +38,7 @@ Waldemar Celes
\tecgraf\ --- Computer Science Department --- PUC-Rio \tecgraf\ --- Computer Science Department --- PUC-Rio
} }
\date{\small \verb$Date: 1997/06/19 18:03:04 $} \date{\small \verb$Date: 1997/06/19 18:49:40 $}
\maketitle \maketitle
@ -973,6 +973,8 @@ See event \verb|"gettable"| for its semantics.
\item[``getglobal'':]\index{getglobal event} \item[``getglobal'':]\index{getglobal event}
called whenever Lua accesses a global variable. called whenever Lua accesses a global variable.
This method can only be set for \nil\ and for tags
created by \verb|newtag|.
\begin{verbatim} \begin{verbatim}
function getglobal (varname) function getglobal (varname)
local value = rawgetglobal(varname) local value = rawgetglobal(varname)
@ -988,6 +990,8 @@ Notice: the function \verb|getglobal| is pre-defined in Lua \see{predefined}.
\item[``setglobal'':]\index{setglobal event} \item[``setglobal'':]\index{setglobal event}
called whenever Lua assigns to a global variable. called whenever Lua assigns to a global variable.
This method cannot be set for numbers, strings, and tables and
userdata with default tags.
\begin{verbatim} \begin{verbatim}
function setglobal (varname, newvalue) function setglobal (varname, newvalue)
local oldvalue = rawgetglobal(varname) local oldvalue = rawgetglobal(varname)
@ -1003,6 +1007,7 @@ Notice: the function \verb|setglobal| is pre-defined in Lua \see{predefined}.
\item[``gettable'':]\index{gettable event} \item[``gettable'':]\index{gettable event}
called whenever Lua accesses an indexed variable. called whenever Lua accesses an indexed variable.
This method cannot be set for tables with default tag.
\begin{verbatim} \begin{verbatim}
function gettable_event (table, index) function gettable_event (table, index)
local tm = gettagmethod(tag(table), "gettable") local tm = gettagmethod(tag(table), "gettable")
@ -1024,6 +1029,7 @@ called whenever Lua accesses an indexed variable.
\item[``settable'':]\index{settable event} \item[``settable'':]\index{settable event}
called when Lua assigns to an indexed variable. called when Lua assigns to an indexed variable.
This method cannot be set for tables with default tag.
\begin{verbatim} \begin{verbatim}
function settable_event (table, index, value) function settable_event (table, index, value)
local tm = gettagmethod(tag(table), "settable") local tm = gettagmethod(tag(table), "settable")
@ -1063,6 +1069,8 @@ called when Lua tries to call a non function value.
\item[``gc'':]\index{gc event} \item[``gc'':]\index{gc event}
called when Lua is garbage collecting an object. called when Lua is garbage collecting an object.
This method cannot be set for strings, numbers, functions,
and userdata with default tag.
For each object to be collected, For each object to be collected,
Lua does the equivalent of the following function: Lua does the equivalent of the following function:
\begin{verbatim} \begin{verbatim}
@ -1092,20 +1100,22 @@ is terminated returning an error condition.
The only argument to the error method is a string The only argument to the error method is a string
describing the error. describing the error.
The standard I/O library redefines this method, The default method prints this message in \verb|stderr|.
using the debug facilities \see{debugI},
in order to print some extra information,
like the call stack.
To provide more information about errors,
Lua programs should include the compilation pragma \verb|$debug|.
\index{debug pragma}\label{pragma}
When an error occurs in a program compiled with this option,
the error routine is able to print the number of the lines where the calls
(and the error) were made.
If needed, it is possible to change the error method with the If needed, it is possible to change the error method with the
function \verb|seterrormethod|, function \verb|seterrormethod|,
which gets the new error handler as its only parameter which gets the new error handler as its only parameter
\see{pdf-seterrormethod}. \see{pdf-seterrormethod}.
The standard I/O library uses this facility to redefine the error method,
using the debug facilities \see{debugI},
in order to print some extra information,
like the call stack.
To provide more information about errors,
Lua programs should include the compilation pragma \verb|$debug|.
\index{debug pragma}\label{pragma}
When an error occurs in a program compiled with this option,
the I/O error routine is able to print the number of the
lines where the calls (and the error) were made.
Lua code can explicitly generate an error by calling the built-in Lua code can explicitly generate an error by calling the built-in
function \verb|error| \see{pdf-error}. function \verb|error| \see{pdf-error}.
@ -1430,13 +1440,14 @@ pops all elements from the C2lua stack.
The following example shows how a C program may do the The following example shows how a C program may do the
equivalent to the Lua code: equivalent to the Lua code:
\begin{verbatim} \begin{verbatim}
a = f(t.x, 4) a = f("how", t.x, 4)
\end{verbatim} \end{verbatim}
\begin{verbatim} \begin{verbatim}
lua_pushstring("how"); /* 1st argument */
lua_pushobject(lua_getglobal("t")); /* push value of global 't' */ lua_pushobject(lua_getglobal("t")); /* push value of global 't' */
lua_pushstring("x"); /* push the string 'x' */ lua_pushstring("x"); /* push the string 'x' */
lua_pushobject(lua_gettable()); /* push result of t.x (= t['x']) */ lua_pushobject(lua_gettable()); /* push result of t.x (= t['x']) */
lua_pushnumber(4); /* 2nd argument */ lua_pushnumber(4); /* 3th argument */
lua_callfunction(lua_getglobal("f")); /* call Lua function */ lua_callfunction(lua_getglobal("f")); /* call Lua function */
lua_pushobject(lua_getresult(1)); /* push first result of the call */ lua_pushobject(lua_getresult(1)); /* push first result of the call */
lua_setglobal("a"); /* sets global variable 'a' */ lua_setglobal("a"); /* sets global variable 'a' */
@ -1928,8 +1939,8 @@ See some examples below:
--> x="apple and orange and lime" --> x="apple and orange and lime"
t = {} t = {}
gsub("first second word", "(%w%w*)", rawsettable, t) dummy, t.n = gsub("first second word", "(%w%w*)", rawsettable, t)
--> t={"first", "second", "word"} --> t={"first", "second", "word"; n=3}
\end{verbatim} \end{verbatim}
@ -2443,13 +2454,34 @@ the previous public versions of Lua,
some differences had to be introduced. some differences had to be introduced.
Here is a list of all these incompatibilities. Here is a list of all these incompatibilities.
\subsection*{Incompatibilities with \Index{version 2.5}}
\begin{itemize}
\item
The whole fallback mechanism has been replaced by tag methods.
Nevertheless, the function \verb|setfallback| has been rewritten in
a way that uses tag methods to fully emulate the old behavior
of fallbacks.
\item
Tags now must be created with the function \verb|newtag|.
Nevertheless, old user defined tags are still accepted
(user defined tags must be positive;
\verb|newtag| uses negative numbers).
Tag methods cannot be set for such user defined tags,
and fallbacks do not affect tags created by \verb|newtag|.
\item
Lua 2.5 accepts mixed comparisons of strings and numbers,
like \verb|2<"12"|, giving weird results.
Now this is an error.
\item
Character \verb|"-"| (hyphen) now is ``magic'' in pattern matching.
\item
Some API functions have been rewritten as macros.
\end{itemize}
\subsection*{Incompatibilities with \Index{version 2.4}} \subsection*{Incompatibilities with \Index{version 2.4}}
The whole I/O facilities have been rewritten. The whole I/O facilities have been rewritten.
We strongly encourage programmers to adapt their code We strongly encourage programmers to adapt their code
to this new version. to this new version.
However, we are keeping the old version of the libraries
in the distribution,
to allow a smooth transition.
The incompatibilities between the new and the old libraries are: The incompatibilities between the new and the old libraries are:
\begin{itemize} \begin{itemize}
\item The format facility of function \verb|write| has been supersed by \item The format facility of function \verb|write| has been supersed by
@ -2550,7 +2582,3 @@ Special care should be taken with macros like
\end{document} \end{document}