mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 10:40:57 +00:00 
			
		
		
		
	| This is one of the few POSIX APIs that was missing. It lets you choose a monotonic clock for your condition variables. This might improve perf on some platforms. It might also grant more flexibility with NTP configs. I know Qt is one project that believes it needs this. To introduce this, I needed to change some the *NSYNC APIs, to support passing a clock param. There's also new benchmarks, demonstrating Cosmopolitan's supremacy over many libc implementations when it comes to mutex performance. Cygwin has an alarmingly bad pthread_mutex_t implementation. It is so bad that they would have been significantly better off if they'd used naive spinlocks. | ||
|---|---|---|
| .. | ||
| test | ||
| BUILD.mk | ||
| cosmo.h | ||
| lapi.c | ||
| lapi.h | ||
| lauxlib.c | ||
| lauxlib.h | ||
| lbaselib.c | ||
| lcode.c | ||
| lcode.h | ||
| lcorolib.c | ||
| lctype.h | ||
| ldblib.c | ||
| ldebug.c | ||
| ldebug.h | ||
| ldo.c | ||
| ldo.h | ||
| ldump.c | ||
| lfunc.c | ||
| lfunc.h | ||
| lgc.c | ||
| lgc.h | ||
| linit.c | ||
| liolib.c | ||
| ljumptab.inc | ||
| llex.c | ||
| llex.h | ||
| llimits.h | ||
| llock.c | ||
| lmathlib.c | ||
| lmem.c | ||
| lmem.h | ||
| lnotice.c | ||
| loadlib.c | ||
| lobject.c | ||
| lobject.h | ||
| lopcodes.c | ||
| lopcodes.h | ||
| lopnames.inc | ||
| loslib.c | ||
| lparser.c | ||
| lparser.h | ||
| lprefix.h | ||
| lrepl.c | ||
| lrepl.h | ||
| lstate.c | ||
| lstate.h | ||
| lstring.c | ||
| lstring.h | ||
| lstrlib.c | ||
| ltable.c | ||
| ltable.h | ||
| ltablib.c | ||
| ltests.c | ||
| ltests.h | ||
| ltm.c | ||
| ltm.h | ||
| lua.h | ||
| lua.main.c | ||
| luac.main.c | ||
| luacallwithtrace.c | ||
| luaconf.h | ||
| luaencodejsondata.c | ||
| luaencodeluadata.c | ||
| luaencodeurl.c | ||
| luaformatstack.c | ||
| lualib.h | ||
| luaparseurl.c | ||
| luaprintstack.c | ||
| luapushheader.c | ||
| luapushheaders.c | ||
| luapushlatin1.c | ||
| luapushurlparams.c | ||
| lundump.c | ||
| lundump.h | ||
| lunix.c | ||
| lunix.h | ||
| lutf8lib.c | ||
| lvm.c | ||
| lvm.h | ||
| lzio.c | ||
| lzio.h | ||
| README.cosmo | ||
| serialize.c | ||
| tms.h | ||
| visitor.c | ||
| visitor.h | ||
DESCRIPTION
  Lua is a language designed for embedded use in native applications. It
  has an impossibly elegant C API and the Lua language itself feels more
  like Python compared to alternatives like Tcl except it's a great deal
  faster and doesn't have strong opinions about character encoding.
PROVENANCE
  https://github.com/lua/lua/
  commit 6443185167c77adcc8552a3fee7edab7895db1a9
  Author: Roberto Ierusalimschy <roberto@inf.puc-rio.br>
  Date:   May 2, 2023 at 3:44 PM EDT
      New release number (5.4.6)
  luac.c needed to be sourced from:
  https://www.lua.org/ftp/lua-5.4.6.tar.gz
LOCAL MODIFICATIONS
  Lua now uses a bestline REPL with bash-style code completion.
  Integer literals such as `033` will now be interpreted as octal.
  Integer literals such as `0b10` will now be interpreted as binary.
  The `\e` string literal escape sequence has been added, which is
  equivalent to `\27` (the Lua version of `\033`) or the ASCII ESC
  character. It may be used for teletypewriter control like having
  bold text, which can be encoded elegantly as `\e[1mHELLO\e[0m`.
  Added Python-like printf modulus operator for strings, e.g.:
  `"Hello, %s!" % {"world"}`.
  Added Python-like printf multiply operator for strings, e.g.:
  `"Hello, world! " * 3`.
  Added `unix` module that exposes the low-level System Five system
  call interface, e.g.: `require("unix"); print(unix.getcwd())`.
  Added luaL_traceback2() for function parameters in traceback.
  Fixed a buffer overflow in os.tmpname
NOTES
  If you'd like to update Cosmo's Lua to the latest version, here
  are some things that might be helpful to know.
  Cosmo's Lua adds ~20 or so files (e.g., `luacallwithtrace.c`, 
  `luaencodejsondata.c`, `luaencodeluadata.c`, etc.) to the 
  directory. In other words, a bunch of Cosmo's files don't
  have any Lua counterpart.
  Some of those files (e.g., `lunix.c`, `lunix.h`) implement 
  functionality that's available within the `lua` that Cosmo builds;
  most, though, implement functionality that's (currently?) only 
  available within `redbean`. In other words, not everything can be
  tested using `lua`; some things need to be tested using `redbean`.
  Some of Lua's files were renamed. For example, `lua.c` was renamed
  to `lua.main.c`, and `luac.c` (which is only available in Lua's
  distributions, and not in Lua's Github repo) was renamed to 
  `luac.main.c`. `ljumptab.h` was renamed to `ljumptab.inc`, and 
  `lopnames.h` was renamed to `lopnames.inc`. In other words, you'll
  need to take some kind of action in order to properly diff all of 
  Lua's files.
  Lua's `.h` files had the comment headers that look like this 
  removed:
    /*
    ** $Id: lua.h $
    ** Lua - A Scripting Language
    ** Lua.org, PUC-Rio, Brazil (http://www.lua.org)
    ** See Copyright Notice at the end of this file
    */
  Lua's `.c` files *replaced* those comment headers with a Cosmo
  emacs/vim header followed by a Lua copyright declaration.
  The `.c` files also added a `__static_yoink("lua_notice");`
  right after the `#include`s.
  Some of Lua's tests have been modified to accommodate Cosmo's
  changes. (And some of Lua's tests have been commented out
  due to Cosmo's changes.)
  Five of Lua's test files intentionally contain ISO-8859-1 (rather
  than  UTF-8) characters:
  * test/db.lua
  * test/files.lua
  * test/pm.lua
  * test/sort.lua
  * test/strings.lua
  If you edit those files as if they were UTF-8-encoded you'll
  corrupt the ISO-8859-1 characters and cause certain tests to fail.
  (Some of the tests count bytes, so you can't just fix the problem
  by converting the files — you also have to change various expected 
  results.)
  The modifications listed way up above are really only the 
  *user-visible* modifications. There are many that aren't 
  user-visible. For example, `_longjmp` was replaced with 
  `gclongjmp`, and `abort` was replaced, ultimately, with a 
  call to `_Exit`.
  To update Cosmo's Lua, you'll need to diff the latest Lua against
  the previous Lua, and Cosmo's Lua against the latest Lua. As you
  do that, you'll be trying to figure out both what Lua changed 
  *and* what Cosmo changed; you'll be trying to add Lua's changes 
  without accidentally removing Cosmo's changes. 
  
  It's tricky!
  We've started to try to make that process a bit easier by tagging
  Cosmo's changes with `[jart]`. For example, one side of the diff
  might (now) show:
    #define LUAI_THROW(L,c)		_longjmp((c)->b, 1)
  while the other side might (now) show:
    #define LUAI_THROW(L,c)		gclongjmp((c)->b, 1)  // [jart]
  The presence of the `[jart]` tag makes it easy to see that the
  Cosmo change was intentional.
  Be aware that not all changes have been tagged!
  There are *other* things we've done that are *also* meant to make
  diffing easier — though the intention is less obvious.
  For example, Cosmo moved the `enum` of opcodes from `ltm.h` to
  `tms.h`. Originally nothing at all was left behind in `ltm.h`.
  Because of that, you'd see an `enum` in Lua that seemed to be
  missing in Cosmo's Lua — as though the `enum` had recently been 
  added to Lua, and now needed to be added to Cosmo! To make the
  intention of Cosmo's change more obvious, we added a tombstone 
  of sorts to `ltm.h`:
    /*
    * WARNING: if you change the order of this enumeration,
    * grep "ORDER TM" and "ORDER OP"
    */
    // [jart] moved to tms.h
  The comment just above the tag comes from Lua; it's the comment
  above Lua's original `enum`.  *The presence of the comment in both
  Lua and Cosmo helps diff tools "resync" at that point.* That in
  turn makes it easier to see Cosmo's change, and to see that it was 
  intentional.
  The more things like that we do — the easier we can make it to
  quickly and correctly read diffs — the easier we'll make it to 
  keep Cosmo's Lua in sync with the latest Lua.