Changelog for hslua-1.0.1
Changelog
1.0.1
-
Exposed more functions from Lua's
lauxlib
library:getmetafield
,getmetatable'
,getsubtable
, andtraceback
.
The function
getsubtable
is a reimplementation instead of a wrapper to the C function for simplicity (thereby avoiding additional C wrappers). -
Fixed tests for GHC 8.6 by no longer depending on failable pattern matching.
1.0.0
New features
-
Error handling at language borders has been vastly improved and is now mostly automatic. Haskell's
Foreign.Lua.Exception
s are transformed into Lua errors and vice versa. Lua-side wrappers are no longer necessary. -
Haskell functions are no longer pushed as userdata by
pushHaskellFunction
, but as C functions. This simplifies tasks where Lua expects true function objects object (for example when looking for module loaders). -
Added stack instance for
- Data.Set.Set,
- Integer,
- Int,
- Float, and
- Double.
Instances for numbers fall back to strings when the representation as a Lua number would cause a loss of precision.
-
Haskell functions pushed with
pushHaskellFunction
can now be garbage collected by Lua without having to call back into Haskell. The callback into Haskell by the GC had previously caused programs to hang in some situations. -
Bindings to more Lua C API functions and macros:
isinteger
,load
,loadbuffer
, andpushglobaltable
. -
Any Haskell value can be pushed to the Lua stack as userdata via
pushAny
and retrieved viapeekAny
. Additional functions are provided to setup the userdata metatable. -
The C preprocessor constants
LUA_LOADED_TABLE
andLUA_PRELOAD_TABLE
are made available asloadedTableRegistryField
andpreloadTableRegistryField
, respectively. -
Additional small helper functions:
peekRead
-- read value from a string.popValue
-- peek value at the top of the Lua stack, then remove it from the stack regardless of whether peeking was successful or not.
Naming
-
The Lua prefix was removed from types (
State
,Integer
,Number
,Exception
) and the respective infix from functions (try
,run
,runWith
,runEither
). HsLua should be imported qualified to avoid name collisions. -
Terminology now consistently uses exception to refer to Haskell exceptions, and error for Lua errors; function names changed accordingly (
throwException
,catchException
,withExceptionMessage
). -
Module Foreign.Lua.Api was renamed to Foreign.Lua.Core.
-
Foreign.Lua.lerror was renamed to Foreign.Lua.error.
-
Typeclass ToLuaStack was renamed to Pushable.
-
Typeclass FromLuaStack was renamed to Peekable.
-
Cabal flag use-pkgconfig was renamed to pkg-config (which is the flag name used by other projects such a zlib).
Type signatures
-
The return value of
lua_newuserdata
is CSize (was CInt). -
Table index parameter in
rawgeti
andrawseti
must be of type LuaInteger, but were of type Int. -
The number of upvalues passed to
pushcclosure
must be of type NumArgs. -
Lua.error
has type Lua NumResults, simplifying its use in HaskellFunctions. -
Retrieval functions which can fail, i.e.
tocfunction
,tointeger
,tonumber
,tostring
,tothread
, andtouserdata
, use the Maybe type to indicate success or failure, avoiding the need to perform additional checks.
Removed Features
-
Support for Lua versions before 5.3 has been dropped.
-
Support for GHC 7.8 has been dropped.
-
wrapHaskellFunction
has been made internal and is no longer exported.
Changed behavior
-
Peekable instances for numbers and strings became more forgiving. Peeking of basic types now follows Lua's default conversion rules:
- numbers can be given as strings, and vice versa;
- any value can be converted into a boolean -- only
nil
andfalse
are peeked asFalse
, all other asTrue
.
Other
- Many internal improvements and additions such as a benchmarking suite, code cleanups, better tests, etc.
0.9.5.{1,2}
- Relaxed upper bound on exceptions.
0.9.5
- Provide Optional as a replacement for OrNil. Exports of the latter have been fixed.
- Provide utility function
raiseError
: Its argument will be thrown as an error in Lua. - Add
modifyLuaError
: The function lives in Foreign.Lua.Error and allows to alter error messages. This is most useful for amending errors with additional information. - Fixed a bug in
toList
which left a element on the stack if deserializing that element lead to an error. This also affected the FromLuaStack instance for lists. - Fixed a bug in
pairsFromTable
which left a key-value pair on the stack if either of them could not be read into the expected type. This also affected the FromLuaStack instance for Map.
0.9.4
- Make Lua an instance of MonadMask: MonadMask from Control.Monad.Catch allows to mask asynchronous exceptions. This allows to define a finalizer for Lua operations.
- Add functions and constants to refer to stack indices: The functions
nthFromBottom
,nthFromTop
as well as the constantsstackTop
andstackBottom
have been introduced. Numeric constants are less clear, and named constants can aid readability. - Add type OrNil: This type can be used when dealing with optional arguments to Lua functions.
- Add function absindex: it converts the acceptable index
idx
into an equivalent absolute index (that is, one that does not depend on the stack top). The function callslua_absindex
when compiled with Lua 5.2 or later; for Lua 5.1, it is reimplemented in Haskell. - Functions in
tasty
which have been deprecated have been replaced with non-deprecated alternatives.
0.9.3
- Re-export more FunctionCalling helpers in
Foreign.Lua
: The typeclassToHaskellFunction
and the helper functiontoHaskellFunction
are useful when working with functions. Importing them separately fromForeign.Lua.FunctionCalling
was an unnecessary burden; they are therefor now re-exported by the main module. - Export registry-relatd constants
refnil
andnoref
: The constants are related to Lua's registry functions (ref
andunref
). - Add helper to convert functions into CFunction: A new helper
wrapHaskellFunction
is provided. It expects a HaskellImportedFunction userdata (as produced bypushHaskellFunction
) on top of the stack and replaces it with a C function. The new function converts error values generated withlerror
into Lua errors, i.e. it callslua_error
. - Add utility function
setglobal'
: It works likesetglobal
, but works with packages and nested tables (dot-notation only).
0.9.2
- Add cabal flag 'export-dynamic': Default behavior is to include all symbols in the dynamic symbol table, as this enables users to load dynamic lua libraries. However, it is sometimes desirable to disable, e.g., when compiling a fully static binary. See jgm/pandoc#3986.
0.9.1
- Increase user-friendlyness of error messages: The error message returned by
toHaskellFunction
hinted at the fact that the failing function is a Haskell function. This is mostly unnecessary information and might have confused users.
0.9.0
- Added cabal flag to allow fully safe garbage collection: Lua garbage
collection can occur in most of the API functions, even in those usually not
calling back into haskell and hence marked as optimizable. The effect of this
is that finalizers which call Haskell functions will cause the program to
hang. A new flag
allow-unsafe-gc
is introduced and enabled by default. Disabling this flag will mark more C API functions as potentially calling back into Haskell. This has a serious performance impact. FromLuaStack
andToLuaStack
instances for lazy ByteStrings are added.- None-string error messages are handled properly: Lua allows error messages to be of any type, but the haskell error handlers expected string values. Tables, booleans, and other non-string values are now handled as well and converted to strings.
0.8.0
- Use newtype definitions instead of type aliases for LuaNumber and LuaInteger. This makes it easier to ensure the correct numeric instances in situations where Lua might have been compiled with 32-bit numbers.
- Instances of
FromLuaStack
andToLuaStack
forInt
are removed. The correctness of these instances cannot be guaranteed if Lua was compiled with a non-standard integer type.
0.7.1
- The flag
lua_32bits
was added to allow users to compile Lua for 32-bit systems. - When reading a list, throw an error if the lua value isn't a table instead of silently returning an empty list.
0.7.0
- Tuples from pairs to octuples have been made instances of
FromLuaStack
andToLuaStack
. - New functions
dostring
anddofile
are provided to load and run strings and files in a single step. LuaStatus
was renamed toStatus
, the Lua prefix was removed from its type constructors.- The constructor
ErrFile
was added toStatus
. It is returned byloadfile
if the file cannot be read. - Remove unused FFI bindings and unused types, including all functions unsafe to use from within Haskell and the library functions added with 0.5.0. Users with special requirements should define their own wrappers and raw bindings.
- The module Foreign.Lua.Api.SafeBindings was merge into Foreign.Lua.Api.RawBindings.
- FFI bindings are changed to use newtypes where sensible, most notably
StackIndex
,NumArgs
, andNumResults
, but also the newly introduced newtypesStatusCode
,TypeCode
, andLuaBool
. - Add functions
tointegerx
andtonumberx
which can be used to get and check values from the stack in a single step. - The signature of
concat
was changed fromInt -> Lua ()
toNumArgs -> Lua ()
. - The signature of
loadfile
was changed fromString -> Lua Int
toString -> Lua Status
. - The type
LTYPE
was renamed toType
, its constructors were renamed to follow the patternType<Typename>
.LuaRelation
was renamed toRelationalOperator
, the Lua prefix was removed from its constructors. - Add function
tolist
to allow getting a generic list from the stack without having to worry about the overlapping instance with[Char]
.
0.6.0
- Supported Lua Versions now include Lua 5.2 and Lua 5.3. LuaJIT and Lua 5.1 remain supported as well.
- Flag
use-pkgconfig
was added to allow discovery of library and include paths via pkg-config. Setting a specific Lua version flag now impliessystem-lua
. (Sean Proctor) - The module was renamed from
Scripting.Lua
toForeign.Lua
. The code is now split over multiple sub-modules. Files processed with hsc2hs are restricted to Foreign.Lua.Api. - A
Lua
monad (reader monad over LuaState) is introduced. Functions which took a LuaState as their first argument are changed into monadic functions within that monad. - Error handling has been redesigned completely. A new LuaException was
introduced and is thrown in unexpected situations. Errors in lua which are
leading to a
longjmp
are now caught with the help of additional C wrapper functions. Those no longer lead to uncontrolled program termination but are converted into a LuaException. peek
no longer returnsMaybe a
but justa
. A LuaException is thrown if an error occurs (i.e. in situtations where Nothing would have been returned previously).- The
StackValue
typeclass has been split intoFromLuaStack
andToLuaStack
. Instances not satisfying the lawx == push x *> peek (-1)
have been dropped. - Documentation of API functions was improved. Most docstrings have been copied from the official Lua manual, enriched with proper markup and links, and changed to properly describe hslua specifics when necessary.
- Example programs have been moved to a separate repository.
- Unused files were removed. (Sean Proctor)
0.5.0
- New raw functions for
luaopen_base
,luaopen_package
,luaopen_string
,luaopen_table
,luaopen_math
,luaopen_io
,luaopen_os
,luaopen_debug
and their high-level wrappers (with namesopenbase
,opentable
etc.) implemented. - Remove custom versions of
loadfile
andloadstring
. - Drop support for GHC versions < 7.8, avoid compiler warnings.
- Ensure no symbols are stripped when linking the bundled lua interpreter.
- Simplify
tostring
function definition. (Sean Proctor) - Explicitly deprecate
strlen
. (Sean Proctor) - Add links to lua documentation for functions wrapping the official lua C API. (Sean Proctor).
0.4.1
- Bugfix(#30):
tolist
wasn't popping elements of the list from stack.
0.4.0
pushstring
andtostring
now usesByteString
instead of[Char]
.StackValue [Char]
instance is removed,StackValue ByteString
is added.StackValue a => StackValue [a]
instance is added. It pushes a Lua array to the stack.pushlist
,islist
andtolist
functions are added.- Type errors in Haskell functions now propagated differently. See the
Scripting.Lua
documentation for detailed explanation. This should fix segfaults reported several times. lua_error
function is removed, it's never safe to call in Haskell.
Related issues and pull requests: #12, #26, #24, #23, #18.
0.3.14
- Pkgconf-based setup removed. Cabal is now using
extra-libraries
to link with Lua. luajit
flag is added to link hslua with LuaJIT.
0.3.13
- Small bugfix related with GHCi running under Windows.
0.3.12
pushrawhsfunction
andregisterrawhsfunction
functions are added.apicheck
flag is added to Cabal package to enable Lua API checking. (useful for debugging)
0.3.11
luaL_ref
andluaL_unref
functions are added.