rufus-lua-win 5.1.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +17 -0
- data/Gemfile +4 -0
- data/LICENSE.txt +22 -0
- data/README.md +69 -0
- data/Rakefile +1 -0
- data/lib/rufus/lua/win.rb +18 -0
- data/lib/rufus/lua/win/version.rb +7 -0
- data/rufus-lua-win.gemspec +23 -0
- data/vendor/lua/bin/liblua.dll +0 -0
- data/vendor/lua/lib/lua/LuaXml.lua +119 -0
- data/vendor/lua/lib/lua/alien.lua +250 -0
- data/vendor/lua/lib/lua/alien/core.dll +0 -0
- data/vendor/lua/lib/lua/alien/struct.dll +0 -0
- data/vendor/lua/lib/lua/base.lua +536 -0
- data/vendor/lua/lib/lua/bin.lua +20 -0
- data/vendor/lua/lib/lua/bit.dll +0 -0
- data/vendor/lua/lib/lua/cdlua.dll +0 -0
- data/vendor/lua/lib/lua/cdluacontextplus.dll +0 -0
- data/vendor/lua/lib/lua/cdluagl.dll +0 -0
- data/vendor/lua/lib/lua/cdluaim.dll +0 -0
- data/vendor/lua/lib/lua/cdluapdf.dll +0 -0
- data/vendor/lua/lib/lua/copas.lua +543 -0
- data/vendor/lua/lib/lua/coxpcall.lua +57 -0
- data/vendor/lua/lib/lua/date.lua +745 -0
- data/vendor/lua/lib/lua/debug_ext.lua +84 -0
- data/vendor/lua/lib/lua/debug_init.lua +2 -0
- data/vendor/lua/lib/lua/des56.dll +0 -0
- data/vendor/lua/lib/lua/dist/config.lua +109 -0
- data/vendor/lua/lib/lua/dist/constraints.lua +271 -0
- data/vendor/lua/lib/lua/dist/depends.lua +601 -0
- data/vendor/lua/lib/lua/dist/git.lua +307 -0
- data/vendor/lua/lib/lua/dist/init.lua +278 -0
- data/vendor/lua/lib/lua/dist/manifest.lua +225 -0
- data/vendor/lua/lib/lua/dist/package.lua +583 -0
- data/vendor/lua/lib/lua/dist/sys.lua +367 -0
- data/vendor/lua/lib/lua/dist/utils.lua +130 -0
- data/vendor/lua/lib/lua/ex.dll +0 -0
- data/vendor/lua/lib/lua/fstable.lua +116 -0
- data/vendor/lua/lib/lua/getopt.lua +273 -0
- data/vendor/lua/lib/lua/git.lua +5 -0
- data/vendor/lua/lib/lua/git/core.dll +0 -0
- data/vendor/lua/lib/lua/git/objects.lua +121 -0
- data/vendor/lua/lib/lua/git/pack.lua +316 -0
- data/vendor/lua/lib/lua/git/protocol.lua +188 -0
- data/vendor/lua/lib/lua/git/repo.lua +283 -0
- data/vendor/lua/lib/lua/git/util.lua +233 -0
- data/vendor/lua/lib/lua/gzio.dll +0 -0
- data/vendor/lua/lib/lua/gzip.lua +81 -0
- data/vendor/lua/lib/lua/iconv.dll +0 -0
- data/vendor/lua/lib/lua/imlua.dll +0 -0
- data/vendor/lua/lib/lua/imlua_fftw.dll +0 -0
- data/vendor/lua/lib/lua/imlua_jp2.dll +0 -0
- data/vendor/lua/lib/lua/imlua_process.dll +0 -0
- data/vendor/lua/lib/lua/imlua_process_omp.dll +0 -0
- data/vendor/lua/lib/lua/io_ext.lua +115 -0
- data/vendor/lua/lib/lua/iuplua.dll +0 -0
- data/vendor/lua/lib/lua/iuplua_mglplot.dll +0 -0
- data/vendor/lua/lib/lua/iuplua_pplot.dll +0 -0
- data/vendor/lua/lib/lua/iupluacd.dll +0 -0
- data/vendor/lua/lib/lua/iupluacontrols.dll +0 -0
- data/vendor/lua/lib/lua/iupluagl.dll +0 -0
- data/vendor/lua/lib/lua/iupluaim.dll +0 -0
- data/vendor/lua/lib/lua/iupluaimglib.dll +0 -0
- data/vendor/lua/lib/lua/iupluatuio.dll +0 -0
- data/vendor/lua/lib/lua/lanes-keeper.lua +302 -0
- data/vendor/lua/lib/lua/lanes.lua +591 -0
- data/vendor/lua/lib/lua/lanes/core.dll +0 -0
- data/vendor/lua/lib/lua/lcs.lua +55 -0
- data/vendor/lua/lib/lua/lemock.lua +659 -0
- data/vendor/lua/lib/lua/lfs.dll +0 -0
- data/vendor/lua/lib/lua/list.lua +375 -0
- data/vendor/lua/lib/lua/logging.lua +189 -0
- data/vendor/lua/lib/lua/logging/console.lua +22 -0
- data/vendor/lua/lib/lua/logging/email.lua +44 -0
- data/vendor/lua/lib/lua/logging/file.lua +55 -0
- data/vendor/lua/lib/lua/logging/rolling_file.lua +81 -0
- data/vendor/lua/lib/lua/logging/socket.lua +35 -0
- data/vendor/lua/lib/lua/logging/sql.lua +64 -0
- data/vendor/lua/lib/lua/loop/base.lua +68 -0
- data/vendor/lua/lib/lua/loop/cached.lua +312 -0
- data/vendor/lua/lib/lua/loop/collection/MapWithArrayOfKeys.lua +64 -0
- data/vendor/lua/lib/lua/loop/collection/ObjectCache.lua +39 -0
- data/vendor/lua/lib/lua/loop/collection/OrderedSet.lua +164 -0
- data/vendor/lua/lib/lua/loop/collection/PriorityQueue.lua +86 -0
- data/vendor/lua/lib/lua/loop/collection/UnorderedArray.lua +32 -0
- data/vendor/lua/lib/lua/loop/collection/UnorderedArraySet.lua +56 -0
- data/vendor/lua/lib/lua/loop/compiler/Arguments.lua +108 -0
- data/vendor/lua/lib/lua/loop/compiler/Conditional.lua +50 -0
- data/vendor/lua/lib/lua/loop/compiler/Expression.lua +215 -0
- data/vendor/lua/lib/lua/loop/component/base.lua +221 -0
- data/vendor/lua/lib/lua/loop/component/contained.lua +71 -0
- data/vendor/lua/lib/lua/loop/component/dynamic.lua +223 -0
- data/vendor/lua/lib/lua/loop/component/intercepted.lua +354 -0
- data/vendor/lua/lib/lua/loop/component/wrapped.lua +195 -0
- data/vendor/lua/lib/lua/loop/debug/Inspector.lua +521 -0
- data/vendor/lua/lib/lua/loop/debug/Matcher.lua +192 -0
- data/vendor/lua/lib/lua/loop/debug/Verbose.lua +266 -0
- data/vendor/lua/lib/lua/loop/debug/Viewer.lua +200 -0
- data/vendor/lua/lib/lua/loop/multiple.lua +105 -0
- data/vendor/lua/lib/lua/loop/object/Exception.lua +57 -0
- data/vendor/lua/lib/lua/loop/object/Publisher.lua +43 -0
- data/vendor/lua/lib/lua/loop/object/Wrapper.lua +39 -0
- data/vendor/lua/lib/lua/loop/scoped.lua +585 -0
- data/vendor/lua/lib/lua/loop/serial/FileStream.lua +48 -0
- data/vendor/lua/lib/lua/loop/serial/Serializer.lua +291 -0
- data/vendor/lua/lib/lua/loop/serial/SocketStream.lua +51 -0
- data/vendor/lua/lib/lua/loop/serial/StringStream.lua +47 -0
- data/vendor/lua/lib/lua/loop/simple.lua +75 -0
- data/vendor/lua/lib/lua/loop/table.lua +71 -0
- data/vendor/lua/lib/lua/loop/thread/CoSocket.lua +416 -0
- data/vendor/lua/lib/lua/loop/thread/IOScheduler.lua +170 -0
- data/vendor/lua/lib/lua/loop/thread/Scheduler.lua +327 -0
- data/vendor/lua/lib/lua/loop/thread/SocketScheduler.lua +88 -0
- data/vendor/lua/lib/lua/loop/thread/Timer.lua +54 -0
- data/vendor/lua/lib/lua/lpeg.dll +0 -0
- data/vendor/lua/lib/lua/ltn12.lua +292 -0
- data/vendor/lua/lib/lua/luaXML_lib.dll +0 -0
- data/vendor/lua/lib/lua/luacurl.dll +0 -0
- data/vendor/lua/lib/lua/luadoc/config.lua +34 -0
- data/vendor/lua/lib/lua/luadoc/doclet/debug.lua +46 -0
- data/vendor/lua/lib/lua/luadoc/doclet/formatter.lua +84 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html.lua +289 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/file.lp +113 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/function.lp +64 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/index.lp +70 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/luadoc.css +286 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/menu.lp +55 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/module.lp +109 -0
- data/vendor/lua/lib/lua/luadoc/doclet/html/table.lp +15 -0
- data/vendor/lua/lib/lua/luadoc/doclet/raw.lua +12 -0
- data/vendor/lua/lib/lua/luadoc/init.lua +58 -0
- data/vendor/lua/lib/lua/luadoc/lp.lua +130 -0
- data/vendor/lua/lib/lua/luadoc/taglet/standard.lua +495 -0
- data/vendor/lua/lib/lua/luadoc/taglet/standard/tags.lua +171 -0
- data/vendor/lua/lib/lua/luadoc/util.lua +233 -0
- data/vendor/lua/lib/lua/luagl.dll +0 -0
- data/vendor/lua/lib/lua/luaglu.dll +0 -0
- data/vendor/lua/lib/lua/luaidl.lua +113 -0
- data/vendor/lua/lib/lua/luaidl/lex.lua +793 -0
- data/vendor/lua/lib/lua/luaidl/pre.lua +149 -0
- data/vendor/lua/lib/lua/luaidl/sin.lua +3631 -0
- data/vendor/lua/lib/lua/luarocks/add.lua +108 -0
- data/vendor/lua/lib/lua/luarocks/admin_remove.lua +87 -0
- data/vendor/lua/lib/lua/luarocks/build.lua +330 -0
- data/vendor/lua/lib/lua/luarocks/build/builtin.lua +253 -0
- data/vendor/lua/lib/lua/luarocks/build/cmake.lua +54 -0
- data/vendor/lua/lib/lua/luarocks/build/command.lua +32 -0
- data/vendor/lua/lib/lua/luarocks/build/make.lua +92 -0
- data/vendor/lua/lib/lua/luarocks/cache.lua +85 -0
- data/vendor/lua/lib/lua/luarocks/cfg.lua +449 -0
- data/vendor/lua/lib/lua/luarocks/command_line.lua +163 -0
- data/vendor/lua/lib/lua/luarocks/deps.lua +654 -0
- data/vendor/lua/lib/lua/luarocks/dir.lua +69 -0
- data/vendor/lua/lib/lua/luarocks/download.lua +90 -0
- data/vendor/lua/lib/lua/luarocks/fetch.lua +321 -0
- data/vendor/lua/lib/lua/luarocks/fetch/cvs.lua +44 -0
- data/vendor/lua/lib/lua/luarocks/fetch/git.lua +81 -0
- data/vendor/lua/lib/lua/luarocks/fetch/git_file.lua +17 -0
- data/vendor/lua/lib/lua/luarocks/fetch/hg.lua +54 -0
- data/vendor/lua/lib/lua/luarocks/fetch/sscm.lua +42 -0
- data/vendor/lua/lib/lua/luarocks/fetch/svn.lua +53 -0
- data/vendor/lua/lib/lua/luarocks/fs.lua +40 -0
- data/vendor/lua/lib/lua/luarocks/fs/lua.lua +676 -0
- data/vendor/lua/lib/lua/luarocks/fs/unix.lua +88 -0
- data/vendor/lua/lib/lua/luarocks/fs/unix/tools.lua +325 -0
- data/vendor/lua/lib/lua/luarocks/fs/win32.lua +107 -0
- data/vendor/lua/lib/lua/luarocks/fs/win32/tools.lua +334 -0
- data/vendor/lua/lib/lua/luarocks/help.lua +101 -0
- data/vendor/lua/lib/lua/luarocks/index.lua +172 -0
- data/vendor/lua/lib/lua/luarocks/install.lua +151 -0
- data/vendor/lua/lib/lua/luarocks/list.lua +35 -0
- data/vendor/lua/lib/lua/luarocks/loader.lua +228 -0
- data/vendor/lua/lib/lua/luarocks/make.lua +71 -0
- data/vendor/lua/lib/lua/luarocks/make_manifest.lua +34 -0
- data/vendor/lua/lib/lua/luarocks/manif.lua +360 -0
- data/vendor/lua/lib/lua/luarocks/manif_core.lua +75 -0
- data/vendor/lua/lib/lua/luarocks/new_version.lua +141 -0
- data/vendor/lua/lib/lua/luarocks/pack.lua +205 -0
- data/vendor/lua/lib/lua/luarocks/path.lua +315 -0
- data/vendor/lua/lib/lua/luarocks/persist.lua +173 -0
- data/vendor/lua/lib/lua/luarocks/refresh_cache.lua +30 -0
- data/vendor/lua/lib/lua/luarocks/remove.lua +135 -0
- data/vendor/lua/lib/lua/luarocks/rep.lua +313 -0
- data/vendor/lua/lib/lua/luarocks/require.lua +6 -0
- data/vendor/lua/lib/lua/luarocks/search.lua +399 -0
- data/vendor/lua/lib/lua/luarocks/show.lua +138 -0
- data/vendor/lua/lib/lua/luarocks/site_config.lua +23 -0
- data/vendor/lua/lib/lua/luarocks/tools/patch.lua +712 -0
- data/vendor/lua/lib/lua/luarocks/tools/tar.lua +144 -0
- data/vendor/lua/lib/lua/luarocks/tools/zip.lua +245 -0
- data/vendor/lua/lib/lua/luarocks/type_check.lua +267 -0
- data/vendor/lua/lib/lua/luarocks/unpack.lua +151 -0
- data/vendor/lua/lib/lua/luarocks/util.lua +420 -0
- data/vendor/lua/lib/lua/luarocks/validate.lua +164 -0
- data/vendor/lua/lib/lua/luars232.dll +0 -0
- data/vendor/lua/lib/lua/luasql/mysql.dll +0 -0
- data/vendor/lua/lib/lua/luasql/postgres.dll +0 -0
- data/vendor/lua/lib/lua/luasql/sqlite3.dll +0 -0
- data/vendor/lua/lib/lua/luaunit.lua +601 -0
- data/vendor/lua/lib/lua/lxp.dll +0 -0
- data/vendor/lua/lib/lua/lxp/lom.lua +60 -0
- data/vendor/lua/lib/lua/math_ext.lua +27 -0
- data/vendor/lua/lib/lua/mbox.lua +53 -0
- data/vendor/lua/lib/lua/md5.lua +19 -0
- data/vendor/lua/lib/lua/md5/core.dll +0 -0
- data/vendor/lua/lib/lua/metalua.lua +0 -0
- data/vendor/lua/lib/lua/metalua/ast_to_string.mlua +553 -0
- data/vendor/lua/lib/lua/metalua/base.lua +104 -0
- data/vendor/lua/lib/lua/metalua/bytecode.lua +0 -0
- data/vendor/lua/lib/lua/metalua/clopts.mlua +204 -0
- data/vendor/lua/lib/lua/metalua/compiler.lua +3 -0
- data/vendor/lua/lib/lua/metalua/dollar.mlua +24 -0
- data/vendor/lua/lib/lua/metalua/extension/H-runtime.mlua +216 -0
- data/vendor/lua/lib/lua/metalua/extension/H.mlua +22 -0
- data/vendor/lua/lib/lua/metalua/extension/anaphoric.mlua +54 -0
- data/vendor/lua/lib/lua/metalua/extension/clist.mlua +149 -0
- data/vendor/lua/lib/lua/metalua/extension/continue.mlua +53 -0
- data/vendor/lua/lib/lua/metalua/extension/localin.mlua +2 -0
- data/vendor/lua/lib/lua/metalua/extension/log.mlua +39 -0
- data/vendor/lua/lib/lua/metalua/extension/match.mlua +374 -0
- data/vendor/lua/lib/lua/metalua/extension/ternary.mlua +10 -0
- data/vendor/lua/lib/lua/metalua/extension/trycatch.mlua +189 -0
- data/vendor/lua/lib/lua/metalua/extension/types-runtime.mlua +159 -0
- data/vendor/lua/lib/lua/metalua/extension/types.mlua +352 -0
- data/vendor/lua/lib/lua/metalua/extension/withdo.mlua +30 -0
- data/vendor/lua/lib/lua/metalua/extension/xglobal-runtime.lua +41 -0
- data/vendor/lua/lib/lua/metalua/extension/xglobal.mlua +20 -0
- data/vendor/lua/lib/lua/metalua/extension/xloop.mlua +100 -0
- data/vendor/lua/lib/lua/metalua/extension/xmatch.mlua +216 -0
- data/vendor/lua/lib/lua/metalua/metaloop.mlua +76 -0
- data/vendor/lua/lib/lua/metalua/mlc.lua +0 -0
- data/vendor/lua/lib/lua/metalua/mlc_xcall.lua +119 -0
- data/vendor/lua/lib/lua/metalua/mlp.lua +0 -0
- data/vendor/lua/lib/lua/metalua/package2.lua +101 -0
- data/vendor/lua/lib/lua/metalua/runtime.lua +3 -0
- data/vendor/lua/lib/lua/metalua/string2.lua +44 -0
- data/vendor/lua/lib/lua/metalua/table2.lua +372 -0
- data/vendor/lua/lib/lua/metalua/walk.mlua +304 -0
- data/vendor/lua/lib/lua/metalua/walk/bindings.mlua +41 -0
- data/vendor/lua/lib/lua/metalua/walk/id.mlua +186 -0
- data/vendor/lua/lib/lua/metalua/walk/scope.lua +54 -0
- data/vendor/lua/lib/lua/mime.lua +87 -0
- data/vendor/lua/lib/lua/mime/core.dll +0 -0
- data/vendor/lua/lib/lua/mobdebug.lua +1484 -0
- data/vendor/lua/lib/lua/modules.lua +16 -0
- data/vendor/lua/lib/lua/object.lua +56 -0
- data/vendor/lua/lib/lua/oil/Exception.lua +26 -0
- data/vendor/lua/lib/lua/oil/arch.lua +27 -0
- data/vendor/lua/lib/lua/oil/arch/basic/client.lua +29 -0
- data/vendor/lua/lib/lua/oil/arch/basic/common.lua +13 -0
- data/vendor/lua/lib/lua/oil/arch/basic/server.lua +27 -0
- data/vendor/lua/lib/lua/oil/arch/cooperative/common.lua +10 -0
- data/vendor/lua/lib/lua/oil/arch/cooperative/server.lua +16 -0
- data/vendor/lua/lib/lua/oil/arch/corba/client.lua +39 -0
- data/vendor/lua/lib/lua/oil/arch/corba/common.lua +58 -0
- data/vendor/lua/lib/lua/oil/arch/corba/intercepted/client.lua +9 -0
- data/vendor/lua/lib/lua/oil/arch/corba/intercepted/server.lua +9 -0
- data/vendor/lua/lib/lua/oil/arch/corba/server.lua +35 -0
- data/vendor/lua/lib/lua/oil/arch/ludo/byref.lua +18 -0
- data/vendor/lua/lib/lua/oil/arch/ludo/client.lua +19 -0
- data/vendor/lua/lib/lua/oil/arch/ludo/common.lua +18 -0
- data/vendor/lua/lib/lua/oil/arch/ludo/server.lua +19 -0
- data/vendor/lua/lib/lua/oil/arch/typed/client.lua +27 -0
- data/vendor/lua/lib/lua/oil/arch/typed/common.lua +9 -0
- data/vendor/lua/lib/lua/oil/arch/typed/server.lua +18 -0
- data/vendor/lua/lib/lua/oil/assert.lua +87 -0
- data/vendor/lua/lib/lua/oil/builder.lua +45 -0
- data/vendor/lua/lib/lua/oil/builder/basic/client.lua +31 -0
- data/vendor/lua/lib/lua/oil/builder/basic/common.lua +11 -0
- data/vendor/lua/lib/lua/oil/builder/basic/server.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/cooperative/common.lua +11 -0
- data/vendor/lua/lib/lua/oil/builder/cooperative/server.lua +11 -0
- data/vendor/lua/lib/lua/oil/builder/corba/client.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/corba/common.lua +24 -0
- data/vendor/lua/lib/lua/oil/builder/corba/gencode.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/corba/intercepted/client.lua +11 -0
- data/vendor/lua/lib/lua/oil/builder/corba/intercepted/server.lua +11 -0
- data/vendor/lua/lib/lua/oil/builder/corba/server.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/lua/client.lua +11 -0
- data/vendor/lua/lib/lua/oil/builder/lua/server.lua +12 -0
- data/vendor/lua/lib/lua/oil/builder/ludo/byref.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/ludo/client.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/ludo/common.lua +14 -0
- data/vendor/lua/lib/lua/oil/builder/ludo/server.lua +13 -0
- data/vendor/lua/lib/lua/oil/builder/typed/client.lua +16 -0
- data/vendor/lua/lib/lua/oil/builder/typed/server.lua +12 -0
- data/vendor/lua/lib/lua/oil/compat.lua +846 -0
- data/vendor/lua/lib/lua/oil/component.lua +1 -0
- data/vendor/lua/lib/lua/oil/corba/giop.lua +301 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Codec.lua +1568 -0
- data/vendor/lua/lib/lua/oil/corba/giop/CodecGen.lua +589 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Exception.lua +25 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Indexer.lua +63 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Listener.lua +343 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Messenger.lua +228 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Referrer.lua +180 -0
- data/vendor/lua/lib/lua/oil/corba/giop/Requester.lua +462 -0
- data/vendor/lua/lib/lua/oil/corba/idl.lua +597 -0
- data/vendor/lua/lib/lua/oil/corba/idl/Compiler.lua +133 -0
- data/vendor/lua/lib/lua/oil/corba/idl/Importer.lua +235 -0
- data/vendor/lua/lib/lua/oil/corba/idl/Indexer.lua +95 -0
- data/vendor/lua/lib/lua/oil/corba/idl/Registry.lua +1821 -0
- data/vendor/lua/lib/lua/oil/corba/idl/ir.lua +847 -0
- data/vendor/lua/lib/lua/oil/corba/idl/sysex.lua +21 -0
- data/vendor/lua/lib/lua/oil/corba/iiop/Profiler.lua +200 -0
- data/vendor/lua/lib/lua/oil/corba/intercepted/Listener.lua +158 -0
- data/vendor/lua/lib/lua/oil/corba/intercepted/Requester.lua +181 -0
- data/vendor/lua/lib/lua/oil/corba/services/event.lua +126 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/ConsumerAdmin.lua +50 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/EventFactory.lua +15 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/EventQueue.lua +37 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/ProxyPushConsumer.lua +75 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/ProxyPushSupplier.lua +62 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/SingleDeferredDispatcher.lua +60 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/SingleSynchronousDispatcher.lua +39 -0
- data/vendor/lua/lib/lua/oil/corba/services/event/SupplierAdmin.lua +50 -0
- data/vendor/lua/lib/lua/oil/corba/services/naming.lua +436 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Acceptor.lua +268 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Channels.lua +121 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Connector.lua +147 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Dispatcher.lua +99 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Proxies.lua +86 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Proxies/asynchronous.lua +56 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Proxies/protected.lua +17 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Proxies/synchronous.lua +17 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Proxies/utils.lua +29 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Receiver.lua +110 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Servants.lua +207 -0
- data/vendor/lua/lib/lua/oil/kernel/base/Sockets.lua +44 -0
- data/vendor/lua/lib/lua/oil/kernel/cooperative/Receiver.lua +139 -0
- data/vendor/lua/lib/lua/oil/kernel/intercepted/Listener.lua +47 -0
- data/vendor/lua/lib/lua/oil/kernel/intercepted/Requester.lua +58 -0
- data/vendor/lua/lib/lua/oil/kernel/lua/Dispatcher.lua +76 -0
- data/vendor/lua/lib/lua/oil/kernel/lua/Proxies.lua +69 -0
- data/vendor/lua/lib/lua/oil/kernel/typed/Dispatcher.lua +91 -0
- data/vendor/lua/lib/lua/oil/kernel/typed/Proxies.lua +153 -0
- data/vendor/lua/lib/lua/oil/kernel/typed/Servants.lua +137 -0
- data/vendor/lua/lib/lua/oil/ludo/Codec.lua +66 -0
- data/vendor/lua/lib/lua/oil/ludo/CodecByRef.lua +103 -0
- data/vendor/lua/lib/lua/oil/ludo/Listener.lua +151 -0
- data/vendor/lua/lib/lua/oil/ludo/Referrer.lua +72 -0
- data/vendor/lua/lib/lua/oil/ludo/Requester.lua +107 -0
- data/vendor/lua/lib/lua/oil/oo.lua +1 -0
- data/vendor/lua/lib/lua/oil/port.lua +1 -0
- data/vendor/lua/lib/lua/oil/properties.lua +57 -0
- data/vendor/lua/lib/lua/oil/verbose.lua +133 -0
- data/vendor/lua/lib/lua/package_ext.lua +15 -0
- data/vendor/lua/lib/lua/parser.lua +268 -0
- data/vendor/lua/lib/lua/pl/Date.lua +555 -0
- data/vendor/lua/lib/lua/pl/List.lua +613 -0
- data/vendor/lua/lib/lua/pl/Map.lua +113 -0
- data/vendor/lua/lib/lua/pl/MultiMap.lua +62 -0
- data/vendor/lua/lib/lua/pl/OrderedMap.lua +151 -0
- data/vendor/lua/lib/lua/pl/Set.lua +153 -0
- data/vendor/lua/lib/lua/pl/app.lua +165 -0
- data/vendor/lua/lib/lua/pl/array2d.lua +501 -0
- data/vendor/lua/lib/lua/pl/class.lua +180 -0
- data/vendor/lua/lib/lua/pl/comprehension.lua +286 -0
- data/vendor/lua/lib/lua/pl/config.lua +176 -0
- data/vendor/lua/lib/lua/pl/data.lua +606 -0
- data/vendor/lua/lib/lua/pl/dir.lua +475 -0
- data/vendor/lua/lib/lua/pl/file.lua +70 -0
- data/vendor/lua/lib/lua/pl/func.lua +376 -0
- data/vendor/lua/lib/lua/pl/init.lua +68 -0
- data/vendor/lua/lib/lua/pl/input.lua +173 -0
- data/vendor/lua/lib/lua/pl/lapp.lua +407 -0
- data/vendor/lua/lib/lua/pl/lexer.lua +456 -0
- data/vendor/lua/lib/lua/pl/luabalanced.lua +264 -0
- data/vendor/lua/lib/lua/pl/operator.lua +201 -0
- data/vendor/lua/lib/lua/pl/path.lua +398 -0
- data/vendor/lua/lib/lua/pl/permute.lua +63 -0
- data/vendor/lua/lib/lua/pl/platf/luajava.lua +101 -0
- data/vendor/lua/lib/lua/pl/pretty.lua +285 -0
- data/vendor/lua/lib/lua/pl/seq.lua +551 -0
- data/vendor/lua/lib/lua/pl/sip.lua +344 -0
- data/vendor/lua/lib/lua/pl/strict.lua +70 -0
- data/vendor/lua/lib/lua/pl/stringio.lua +158 -0
- data/vendor/lua/lib/lua/pl/stringx.lua +440 -0
- data/vendor/lua/lib/lua/pl/tablex.lua +817 -0
- data/vendor/lua/lib/lua/pl/template.lua +103 -0
- data/vendor/lua/lib/lua/pl/test.lua +135 -0
- data/vendor/lua/lib/lua/pl/text.lua +243 -0
- data/vendor/lua/lib/lua/pl/utils.lua +550 -0
- data/vendor/lua/lib/lua/pl/xml.lua +689 -0
- data/vendor/lua/lib/lua/profiler.dll +0 -0
- data/vendor/lua/lib/lua/re.lua +248 -0
- data/vendor/lua/lib/lua/rex_onig.dll +0 -0
- data/vendor/lua/lib/lua/rex_pcre.dll +0 -0
- data/vendor/lua/lib/lua/rex_posix.dll +0 -0
- data/vendor/lua/lib/lua/rings.dll +0 -0
- data/vendor/lua/lib/lua/serialize.lua +193 -0
- data/vendor/lua/lib/lua/set.lua +149 -0
- data/vendor/lua/lib/lua/socket.lua +133 -0
- data/vendor/lua/lib/lua/socket/core.dll +0 -0
- data/vendor/lua/lib/lua/socket/ftp.lua +281 -0
- data/vendor/lua/lib/lua/socket/http.lua +350 -0
- data/vendor/lua/lib/lua/socket/smtp.lua +251 -0
- data/vendor/lua/lib/lua/socket/tp.lua +123 -0
- data/vendor/lua/lib/lua/socket/url.lua +297 -0
- data/vendor/lua/lib/lua/ssl.dll +0 -0
- data/vendor/lua/lib/lua/ssl.lua +93 -0
- data/vendor/lua/lib/lua/ssl/https.lua +138 -0
- data/vendor/lua/lib/lua/stable.lua +28 -0
- data/vendor/lua/lib/lua/std.lua +16 -0
- data/vendor/lua/lib/lua/strbuf.lua +32 -0
- data/vendor/lua/lib/lua/strict.lua +45 -0
- data/vendor/lua/lib/lua/string_ext.lua +274 -0
- data/vendor/lua/lib/lua/table_ext.lua +117 -0
- data/vendor/lua/lib/lua/tar.lua +262 -0
- data/vendor/lua/lib/lua/task.dll +0 -0
- data/vendor/lua/lib/lua/tree.lua +81 -0
- data/vendor/lua/lib/lua/unicode.dll +0 -0
- data/vendor/lua/lib/lua/verbose_require.lua +11 -0
- data/vendor/lua/lib/lua/vstruct.lua +86 -0
- data/vendor/lua/lib/lua/vstruct/ast.lua +192 -0
- data/vendor/lua/lib/lua/vstruct/ast/Bitpack.lua +33 -0
- data/vendor/lua/lib/lua/vstruct/ast/Generator.lua +174 -0
- data/vendor/lua/lib/lua/vstruct/ast/IO.lua +45 -0
- data/vendor/lua/lib/lua/vstruct/ast/List.lua +56 -0
- data/vendor/lua/lib/lua/vstruct/ast/Name.lua +20 -0
- data/vendor/lua/lib/lua/vstruct/ast/Repeat.lua +23 -0
- data/vendor/lua/lib/lua/vstruct/ast/Root.lua +19 -0
- data/vendor/lua/lib/lua/vstruct/ast/Table.lua +65 -0
- data/vendor/lua/lib/lua/vstruct/cursor.lua +81 -0
- data/vendor/lua/lib/lua/vstruct/io.lua +45 -0
- data/vendor/lua/lib/lua/vstruct/io/a.lua +24 -0
- data/vendor/lua/lib/lua/vstruct/io/b.lua +28 -0
- data/vendor/lua/lib/lua/vstruct/io/bigendian.lua +21 -0
- data/vendor/lua/lib/lua/vstruct/io/c.lua +25 -0
- data/vendor/lua/lib/lua/vstruct/io/defaults.lua +24 -0
- data/vendor/lua/lib/lua/vstruct/io/endianness.lua +41 -0
- data/vendor/lua/lib/lua/vstruct/io/f.lua +129 -0
- data/vendor/lua/lib/lua/vstruct/io/hostendian.lua +21 -0
- data/vendor/lua/lib/lua/vstruct/io/i.lua +42 -0
- data/vendor/lua/lib/lua/vstruct/io/littleendian.lua +21 -0
- data/vendor/lua/lib/lua/vstruct/io/m.lua +62 -0
- data/vendor/lua/lib/lua/vstruct/io/p.lua +23 -0
- data/vendor/lua/lib/lua/vstruct/io/s.lua +27 -0
- data/vendor/lua/lib/lua/vstruct/io/seekb.lua +18 -0
- data/vendor/lua/lib/lua/vstruct/io/seekf.lua +18 -0
- data/vendor/lua/lib/lua/vstruct/io/seekto.lua +18 -0
- data/vendor/lua/lib/lua/vstruct/io/u.lua +54 -0
- data/vendor/lua/lib/lua/vstruct/io/x.lua +34 -0
- data/vendor/lua/lib/lua/vstruct/io/z.lua +63 -0
- data/vendor/lua/lib/lua/vstruct/lexer.lua +100 -0
- data/vendor/lua/lib/lua/vstruct/pack.lua +142 -0
- data/vendor/lua/lib/lua/vstruct/test.lua +47 -0
- data/vendor/lua/lib/lua/vstruct/test/basic.lua +73 -0
- data/vendor/lua/lib/lua/vstruct/test/common.lua +100 -0
- data/vendor/lua/lib/lua/vstruct/test/fp-bigendian.lua +56 -0
- data/vendor/lua/lib/lua/vstruct/test/fp-littleendian.lua +56 -0
- data/vendor/lua/lib/lua/vstruct/test/struct-test-gen.lua +1230 -0
- data/vendor/lua/lib/lua/vstruct/unpack.lua +126 -0
- data/vendor/lua/lib/lua/wx.dll +0 -0
- data/vendor/lua/lib/lua/xml.lua +75 -0
- data/vendor/lua/lib/lua/zip.dll +0 -0
- data/vendor/lua/lib/lua/zlib.dll +0 -0
- metadata +529 -0
@@ -0,0 +1,30 @@
|
|
1
|
+
-- RAII in metalua.
|
2
|
+
--
|
3
|
+
-- Write:
|
4
|
+
-- with var_1, var_2... = val_1, val_2... do
|
5
|
+
-- ...
|
6
|
+
-- end
|
7
|
+
--
|
8
|
+
-- will assign val_n to var_n foreach n, and guaranty that var_n:close() will be called,
|
9
|
+
-- no matter what, even if the body causes an error, even if it returns, even
|
10
|
+
-- if another :close() call causes an error, etc. No. Matter. What.
|
11
|
+
|
12
|
+
require 'metalua.extension.trycatch'
|
13
|
+
|
14
|
+
function withdo_builder (x)
|
15
|
+
local names, vals, body = unpack(x)
|
16
|
+
for i = #names, 1, -1 do
|
17
|
+
local name, val = names[i], vals[i]
|
18
|
+
body = trycatch_builder{ { `Set{ {name}, {val} }, body }, -- try-block
|
19
|
+
{ }, -- catch-block
|
20
|
+
{ +{ print ("closing "..-{`String{name[1]}}) },
|
21
|
+
`Invoke{ name, `String "close" } } }
|
22
|
+
end
|
23
|
+
table.insert(body, 1, `Local{ names })
|
24
|
+
return body
|
25
|
+
end
|
26
|
+
|
27
|
+
mlp.lexer:add 'with'
|
28
|
+
mlp.stat:add{
|
29
|
+
'with', mlp.id_list, '=', mlp.expr_list, 'do', mlp.block, 'end',
|
30
|
+
builder = withdo_builder }
|
@@ -0,0 +1,41 @@
|
|
1
|
+
local _G = getfenv()
|
2
|
+
local _G_mt = getmetatable(_G)
|
3
|
+
|
4
|
+
|
5
|
+
-- Set the __globals metafield in the global environment's metatable,
|
6
|
+
-- if not already there.
|
7
|
+
if _G_mt then
|
8
|
+
if _G_mt.__globals then return else
|
9
|
+
print( "Warning: _G already has a metatable,"..
|
10
|
+
" which might interfere with xglobals")
|
11
|
+
_G_mt.__globals = { }
|
12
|
+
end
|
13
|
+
else
|
14
|
+
_G_mt = { __globals = { } }
|
15
|
+
setmetatable(_G, _G_mt)
|
16
|
+
end
|
17
|
+
|
18
|
+
-- add a series of variable names to the list of declared globals
|
19
|
+
function _G_mt.__newglobal(...)
|
20
|
+
local g = _G_mt.__globals
|
21
|
+
for v in ivalues{...} do g[v]=true end
|
22
|
+
end
|
23
|
+
|
24
|
+
-- Try to set a global that's not in _G:
|
25
|
+
-- if it isn't declared, fail
|
26
|
+
function _G_mt.__newindex(_G, var, val)
|
27
|
+
if not _G_mt.__globals[var] then
|
28
|
+
error ("Setting undeclared global variable "..var)
|
29
|
+
end
|
30
|
+
rawset(_G, var, val)
|
31
|
+
end
|
32
|
+
|
33
|
+
-- Try to read a global that's not in _G:
|
34
|
+
-- if it isn't declared, fail
|
35
|
+
function _G_mt.__index(_G, var)
|
36
|
+
if not _G_mt.__globals[var] then
|
37
|
+
error ("Reading undeclared global variable "..var)
|
38
|
+
end
|
39
|
+
return nil
|
40
|
+
end
|
41
|
+
|
@@ -0,0 +1,20 @@
|
|
1
|
+
-- WARNING, this is undertested, especially in cases where mutliple
|
2
|
+
-- modules have their own fenvs. Use at your own risks.
|
3
|
+
|
4
|
+
require 'strict'
|
5
|
+
|
6
|
+
local function decl_builder(x)
|
7
|
+
local ids, vals = unpack(x)
|
8
|
+
local ids_as_strings = table.imap(|x| `String{x[1]}, ids)
|
9
|
+
local decl = `Call{ +{getmetatable(getfenv()).__newglobal},
|
10
|
+
unpack(ids_as_strings) }
|
11
|
+
if vals then return { decl, `Set{ ids, vals } }
|
12
|
+
else return decl end
|
13
|
+
end
|
14
|
+
|
15
|
+
mlp.lexer:add 'global'
|
16
|
+
mlp.stat:add{
|
17
|
+
'global', mlp.id_list, gg.onkeyword{ '=', mlp.expr_list },
|
18
|
+
builder = decl_builder }
|
19
|
+
|
20
|
+
return +{ require (-{ `String{ package.metalua_extension_prefix .. 'xglobal-runtime' } }) }
|
@@ -0,0 +1,100 @@
|
|
1
|
+
-{ extension 'match' }
|
2
|
+
-{ extension 'log' }
|
3
|
+
|
4
|
+
require 'metalua.walk'
|
5
|
+
|
6
|
+
----------------------------------------------------------------------
|
7
|
+
-- Back-end:
|
8
|
+
----------------------------------------------------------------------
|
9
|
+
|
10
|
+
-- Parse additional elements in a loop
|
11
|
+
loop_element = gg.multisequence{
|
12
|
+
{ 'while', mlp.expr, builder = |x| `Until{ `Op{ 'not', x[1] } } },
|
13
|
+
{ 'until', mlp.expr, builder = |x| `Until{ x[1] } },
|
14
|
+
{ 'if', mlp.expr, builder = |x| `If{ x[1] } },
|
15
|
+
{ 'unless', mlp.expr, builder = |x| `If{ `Op{ 'not', x[1] } } },
|
16
|
+
{ 'for', mlp.for_header, builder = |x| x[1] } }
|
17
|
+
|
18
|
+
-- Recompose the loop
|
19
|
+
function xloop_builder(x)
|
20
|
+
local first, elements, body = unpack(x)
|
21
|
+
|
22
|
+
-------------------------------------------------------------------
|
23
|
+
-- If it's a regular loop, don't bloat the code
|
24
|
+
-------------------------------------------------------------------
|
25
|
+
if not next(elements) then
|
26
|
+
table.insert(first, body)
|
27
|
+
return first
|
28
|
+
end
|
29
|
+
|
30
|
+
-------------------------------------------------------------------
|
31
|
+
-- There's no reason to treat the first element in a special way
|
32
|
+
-------------------------------------------------------------------
|
33
|
+
table.insert(elements, 1, first)
|
34
|
+
|
35
|
+
-------------------------------------------------------------------
|
36
|
+
-- if a header or a break must be able to exit the loops, ti will
|
37
|
+
-- set exit_label and use it (a regular break wouldn't be enough,
|
38
|
+
-- as it couldn't escape several nested loops.)
|
39
|
+
-------------------------------------------------------------------
|
40
|
+
local exit_label
|
41
|
+
local function exit()
|
42
|
+
if not exit_label then exit_label = mlp.gensym 'break' [1] end
|
43
|
+
return `Goto{ exit_label }
|
44
|
+
end
|
45
|
+
|
46
|
+
-------------------------------------------------------------------
|
47
|
+
-- Compile all headers elements, from last to first
|
48
|
+
-------------------------------------------------------------------
|
49
|
+
for i = #elements, 1, -1 do
|
50
|
+
local e = elements[i]
|
51
|
+
match e with
|
52
|
+
| `If{ cond } ->
|
53
|
+
body = `If{ cond, {body} }
|
54
|
+
| `Until{ cond } ->
|
55
|
+
body = +{stat: if -{cond} then -{exit()} else -{body} end }
|
56
|
+
| `Forin{ ... } | `Fornum{ ... } ->
|
57
|
+
table.insert (e, {body}); body=e
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
-------------------------------------------------------------------
|
62
|
+
-- Change breaks into gotos that escape all loops at once.
|
63
|
+
-------------------------------------------------------------------
|
64
|
+
local cfg = { stat = { }, expr = { } }
|
65
|
+
function cfg.stat.down(x)
|
66
|
+
match x with
|
67
|
+
| `Break -> x <- exit()
|
68
|
+
| `Forin{ ... } | `Fornum{ ... } | `While{ ... } | `Repeat{ ... } ->
|
69
|
+
return 'break'
|
70
|
+
| _ -> -- pass
|
71
|
+
end
|
72
|
+
end
|
73
|
+
function cfg.expr.down(x) if x.tag=='Function' then return 'break' end end
|
74
|
+
walk.stat(cfg, body)
|
75
|
+
|
76
|
+
if exit_label then body = { body, `Label{ exit_label } } end
|
77
|
+
return body
|
78
|
+
end
|
79
|
+
|
80
|
+
----------------------------------------------------------------------
|
81
|
+
-- Front-end:
|
82
|
+
----------------------------------------------------------------------
|
83
|
+
|
84
|
+
mlp.lexer:add 'unless'
|
85
|
+
mlp.stat:del 'for'
|
86
|
+
mlp.stat:del 'while'
|
87
|
+
|
88
|
+
loop_element_list = gg.list{ loop_element, terminators='do' }
|
89
|
+
|
90
|
+
mlp.stat:add{
|
91
|
+
'for', mlp.for_header, loop_element_list, 'do', mlp.block, 'end',
|
92
|
+
builder = xloop_builder }
|
93
|
+
|
94
|
+
mlp.stat:add{
|
95
|
+
'while', mlp.expr, loop_element_list, 'do', mlp.block, 'end',
|
96
|
+
builder = |x| xloop_builder{ `While{x[1]}, x[2], x[3] } }
|
97
|
+
|
98
|
+
mlp.stat:add{
|
99
|
+
'unless', mlp.expr, 'then', mlp.block, 'end',
|
100
|
+
builder = |x| +{stat: if not -{x[1]} then -{x[2]} end} }
|
@@ -0,0 +1,216 @@
|
|
1
|
+
|
2
|
+
require 'metalua.extension.match'
|
3
|
+
|
4
|
+
module ('spmatch', package.seeall)
|
5
|
+
|
6
|
+
require 'metalua.walk.id'
|
7
|
+
|
8
|
+
-{extension 'log'}
|
9
|
+
|
10
|
+
----------------------------------------------------------------------
|
11
|
+
-- Back-end for statements
|
12
|
+
-- "match function ..." and "local match function...".
|
13
|
+
-- Tag must be either "Localrec" or "Set".
|
14
|
+
----------------------------------------------------------------------
|
15
|
+
named_match_function_builder = |tag| function (x)
|
16
|
+
local func_name, _, cases = unpack(x)
|
17
|
+
local arity = #cases[1][1][1]
|
18
|
+
if arity==0 then
|
19
|
+
error "There must be at least 1 case in match function"
|
20
|
+
end
|
21
|
+
local args = { }
|
22
|
+
for i=1, arity do args[i] = mlp.gensym("arg."..i) end
|
23
|
+
local body = match_builder{args, cases}
|
24
|
+
return { tag=tag, {func_name}, { `Function{ args, {body} } } }
|
25
|
+
end
|
26
|
+
|
27
|
+
-- Get rid of the former parser, it will be blended in a multiseq:
|
28
|
+
mlp.stat:del 'match'
|
29
|
+
|
30
|
+
----------------------------------------------------------------------
|
31
|
+
-- "match function", "match ... with"
|
32
|
+
----------------------------------------------------------------------
|
33
|
+
mlp.stat:add{ 'match',
|
34
|
+
gg.multisequence{
|
35
|
+
|
36
|
+
----------------------------------------------------------------
|
37
|
+
-- Shortcut for declaration of functions containing only a match:
|
38
|
+
-- "function f($1) match $1 with $2 end end" can be written:
|
39
|
+
-- "match function f $2 end"
|
40
|
+
----------------------------------------------------------------
|
41
|
+
{ 'function', mlp.expr, gg.optkeyword '|',
|
42
|
+
match_cases_list_parser, 'end',
|
43
|
+
builder = named_match_function_builder 'Set' },
|
44
|
+
|
45
|
+
----------------------------------------------------------------
|
46
|
+
-- Reintroduce the original match statement:
|
47
|
+
----------------------------------------------------------------
|
48
|
+
default = gg.sequence{
|
49
|
+
mlp.expr_list, 'with', gg.optkeyword '|',
|
50
|
+
match_cases_list_parser, 'end',
|
51
|
+
builder = |x| match_builder{ x[1], x[3] } } } }
|
52
|
+
|
53
|
+
----------------------------------------------------------------------
|
54
|
+
-- Shortcut: "local match function f $cases end" translates to:
|
55
|
+
-- "local function f($args) match $args with $cases end end"
|
56
|
+
----------------------------------------------------------------------
|
57
|
+
mlp.stat:get'local'[2]:add{
|
58
|
+
'match', 'function', mlp.expr, gg.optkeyword '|',
|
59
|
+
match_cases_list_parser, 'end',
|
60
|
+
builder = named_match_function_builder 'Localrec' }
|
61
|
+
|
62
|
+
----------------------------------------------------------------------
|
63
|
+
-- "match...with" expressions and "match function..."
|
64
|
+
----------------------------------------------------------------------
|
65
|
+
mlp.expr:add{ 'match', builder = |x| x[1], gg.multisequence{
|
66
|
+
|
67
|
+
----------------------------------------------------------------
|
68
|
+
-- Anonymous match functions:
|
69
|
+
-- "function ($1) match $1 with $2 end end" can be written:
|
70
|
+
-- "match function $2 end"
|
71
|
+
----------------------------------------------------------------
|
72
|
+
{ 'function', gg.optkeyword '|',
|
73
|
+
match_cases_list_parser,
|
74
|
+
'end',
|
75
|
+
builder = function(x)
|
76
|
+
local _, cases = unpack(x)
|
77
|
+
local v = mlp.gensym()
|
78
|
+
local body = match_builder{v, cases}
|
79
|
+
return `Function{ {v}, {body} }
|
80
|
+
end },
|
81
|
+
|
82
|
+
----------------------------------------------------------------
|
83
|
+
-- match expressions: you can put a match where an expression
|
84
|
+
-- is expected. The case bodies are then expected to be
|
85
|
+
-- expressions, not blocks.
|
86
|
+
----------------------------------------------------------------
|
87
|
+
default = gg.sequence{
|
88
|
+
mlp.expr_list, 'with', gg.optkeyword '|',
|
89
|
+
gg.list{ name = "match cases list",
|
90
|
+
gg.sequence{ name = "match expr case",
|
91
|
+
gg.list{ name = "match expr case patterns list",
|
92
|
+
primary = mlp.expr_list,
|
93
|
+
separators = "|",
|
94
|
+
terminators = { "->", "if" } },
|
95
|
+
gg.onkeyword{ "if", mlp.expr, consume = true },
|
96
|
+
"->",
|
97
|
+
mlp.expr }, -- Notice: expression, not block!
|
98
|
+
separators = "|" },
|
99
|
+
-- Notice: no "end" keyword!
|
100
|
+
builder = function (x)
|
101
|
+
local tested_term_seq, _, cases = unpack(x)
|
102
|
+
local v = mlp.gensym 'match_expr'
|
103
|
+
-- Replace expressions with blocks
|
104
|
+
for case in ivalues (cases) do
|
105
|
+
local body = case[3]
|
106
|
+
case[3] = { `Set{ {v}, {body} } }
|
107
|
+
end
|
108
|
+
local m = match_builder { tested_term_seq, cases }
|
109
|
+
return `Stat{ { `Local{{v}}; m }, v }
|
110
|
+
end } } }
|
111
|
+
|
112
|
+
function bind (x)
|
113
|
+
local patterns, values = unpack(x)
|
114
|
+
|
115
|
+
-------------------------------------------------------------------
|
116
|
+
-- Generate pattern code: "bind vars = vals" translates to:
|
117
|
+
-- do
|
118
|
+
-- pattern matching code, goto 'fail' on mismatch
|
119
|
+
-- goto 'success'
|
120
|
+
-- label 'fail': error "..."
|
121
|
+
-- label success
|
122
|
+
-- end
|
123
|
+
-- vars is the set of variables used by the pattern
|
124
|
+
-------------------------------------------------------------------
|
125
|
+
local code, vars do
|
126
|
+
local match_cfg = {
|
127
|
+
on_failure = mlp.gensym 'mismatch' [1],
|
128
|
+
locals = { },
|
129
|
+
code = { } }
|
130
|
+
pattern_seq_builder(patterns, values, match_cfg)
|
131
|
+
local on_success = mlp.gensym 'on_success' [1]
|
132
|
+
code = {
|
133
|
+
match_cfg.code;
|
134
|
+
`Goto{ on_success };
|
135
|
+
`Label{ match_cfg.on_failure };
|
136
|
+
+{error "bind error"};
|
137
|
+
`Label{ on_success } }
|
138
|
+
vars = match_cfg.locals
|
139
|
+
end
|
140
|
+
|
141
|
+
-------------------------------------------------------------------
|
142
|
+
-- variables that actually appear in the pattern:
|
143
|
+
-------------------------------------------------------------------
|
144
|
+
local vars_in_pattern do
|
145
|
+
vars_in_pattern = { }
|
146
|
+
local walk_cfg = { id = { } }
|
147
|
+
function walk_cfg.id.free(v) vars_in_pattern[v[1]]=true end
|
148
|
+
walk_id.expr_list(walk_cfg, patterns)
|
149
|
+
end
|
150
|
+
|
151
|
+
-------------------------------------------------------------------
|
152
|
+
-- temp variables that are generated for destructuring,
|
153
|
+
-- but aren't explicitly typed by the user. These must be made
|
154
|
+
-- local.
|
155
|
+
-------------------------------------------------------------------
|
156
|
+
local vars_not_in_pattern do
|
157
|
+
vars_not_in_pattern = { }
|
158
|
+
for k in keys(vars) do
|
159
|
+
if not vars_in_pattern[k] then
|
160
|
+
vars_not_in_pattern[k] = true
|
161
|
+
end
|
162
|
+
end
|
163
|
+
end
|
164
|
+
|
165
|
+
-------------------------------------------------------------------
|
166
|
+
-- Declare the temp variables as local to the statement.
|
167
|
+
-------------------------------------------------------------------
|
168
|
+
if next(vars_not_in_pattern) then
|
169
|
+
local loc = { }
|
170
|
+
for k in keys (vars_not_in_pattern) do
|
171
|
+
table.insert (loc, `Id{k})
|
172
|
+
end
|
173
|
+
table.insert (code, 1, `Local{ loc, { } })
|
174
|
+
end
|
175
|
+
|
176
|
+
-------------------------------------------------------------------
|
177
|
+
-- Transform the set of pattern variable names into a list of `Id{}
|
178
|
+
-------------------------------------------------------------------
|
179
|
+
local decl_list do
|
180
|
+
decl_list = { }
|
181
|
+
for k in keys (vars_in_pattern) do
|
182
|
+
table.insert (decl_list, `Id{k})
|
183
|
+
end
|
184
|
+
end
|
185
|
+
|
186
|
+
return code, decl_list
|
187
|
+
end
|
188
|
+
|
189
|
+
function local_bind(x)
|
190
|
+
local code, vars = bind (x)
|
191
|
+
return { `Local{ vars, { } }; code }
|
192
|
+
end
|
193
|
+
|
194
|
+
function non_local_bind(x)
|
195
|
+
local code, _ = bind (x)
|
196
|
+
code.tag = 'Do'
|
197
|
+
return code
|
198
|
+
end
|
199
|
+
|
200
|
+
----------------------------------------------------------------------
|
201
|
+
-- Syntax front-end
|
202
|
+
----------------------------------------------------------------------
|
203
|
+
mlp.lexer:add 'bind'
|
204
|
+
|
205
|
+
----------------------------------------------------------------------
|
206
|
+
-- bind patterns = vars
|
207
|
+
----------------------------------------------------------------------
|
208
|
+
mlp.stat:add{ 'bind', mlp.expr_list, '=', mlp.expr_list,
|
209
|
+
builder = non_local_bind }
|
210
|
+
|
211
|
+
----------------------------------------------------------------------
|
212
|
+
-- local bind patterns = vars
|
213
|
+
-- Some monkey-patching of "local ..." must take place
|
214
|
+
----------------------------------------------------------------------
|
215
|
+
mlp.stat:get'local'[2]:add{ 'bind', mlp.expr_list, '=', mlp.expr_list,
|
216
|
+
builder = local_bind }
|
@@ -0,0 +1,76 @@
|
|
1
|
+
require 'metalua.compiler'
|
2
|
+
|
3
|
+
module ('metaloop', package.seeall)
|
4
|
+
|
5
|
+
PRINT_AST = true
|
6
|
+
LINE_WIDTH = 60
|
7
|
+
PROMPT = "M> "
|
8
|
+
PROMPT2 = ">> "
|
9
|
+
|
10
|
+
do -- set readline() to a line reader, either editline otr a default
|
11
|
+
local status, _ = pcall(require, 'editline')
|
12
|
+
if status then
|
13
|
+
local rl_handle = editline.init 'metalua'
|
14
|
+
readline = |p| rl_handle:read(p)
|
15
|
+
else
|
16
|
+
function readline (p)
|
17
|
+
io.write (p)
|
18
|
+
io.flush ()
|
19
|
+
return io.read '*l'
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
function reached_eof(lx, msg)
|
25
|
+
return lx:peek().tag=='Eof' or msg:find "token `Eof"
|
26
|
+
end
|
27
|
+
|
28
|
+
printf ("Metalua, interactive REPLoop.\n"..
|
29
|
+
"(c) 2006-2008 <metalua@gmail.com>")
|
30
|
+
|
31
|
+
function run()
|
32
|
+
local lines = { }
|
33
|
+
while true do
|
34
|
+
local src, lx, ast, f, results, success
|
35
|
+
repeat
|
36
|
+
local line = readline(next(lines) and PROMPT2 or PROMPT)
|
37
|
+
if not line then print(); os.exit(0) end -- line==nil iff eof on stdin
|
38
|
+
if not next(lines) then
|
39
|
+
line = line:gsub('^%s*=', 'return ')
|
40
|
+
end
|
41
|
+
table.insert(lines, line)
|
42
|
+
src = table.concat (lines, "\n")
|
43
|
+
until #line>0
|
44
|
+
|
45
|
+
lx = mlc.lexstream_of_luastring(src)
|
46
|
+
success, ast = pcall(mlc.ast_of_lexstream, lx)
|
47
|
+
if success then
|
48
|
+
success, f = pcall(mlc.function_of_ast, ast, '=stdin')
|
49
|
+
if success then
|
50
|
+
results = { pcall(f) }
|
51
|
+
success = table.remove (results, 1)
|
52
|
+
if success then
|
53
|
+
-- Success!
|
54
|
+
table.iforeach(|x| table.print(x, LINE_WIDTH), results)
|
55
|
+
lines = { }
|
56
|
+
else
|
57
|
+
print "Evaluation error:"
|
58
|
+
print (results[1])
|
59
|
+
lines = { }
|
60
|
+
end
|
61
|
+
else
|
62
|
+
print "Can't compile into bytecode:"
|
63
|
+
print (f)
|
64
|
+
lines = { }
|
65
|
+
end
|
66
|
+
else
|
67
|
+
-- If lx has been read entirely, try to read another
|
68
|
+
-- line before failing.
|
69
|
+
if not reached_eof(lx, ast) then
|
70
|
+
print "Can't compile source into AST:"
|
71
|
+
print (ast)
|
72
|
+
lines = { }
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
end
|