mirror of
https://gitlab.com/Syping/luaengineapp.git
synced 2024-12-22 20:05:30 +01:00
add LuaEngine compiler
This commit is contained in:
parent
adb091dfbb
commit
eec5071578
9 changed files with 225 additions and 20 deletions
|
@ -10,18 +10,20 @@ LuaEngine Windows:
|
||||||
script:
|
script:
|
||||||
- mkdir -p build
|
- mkdir -p build
|
||||||
- cd build
|
- cd build
|
||||||
- qmake CONFIG+=WITH_LUAENGINERUN ../luaengine.pro
|
- qmake CONFIG+=WITH_LUAENGINECOM CONFIG+=WITH_LUAENGINERUN ../luaengine.pro
|
||||||
- make -j4
|
- make -j4
|
||||||
- cp -Rf src/luaenginecore/release/LuaEngine.dll ../
|
- cp -Rf src/luaenginecore/release/LuaEngine.dll ../
|
||||||
- cp -Rf src/luaenginegui/release/LuaEngineGui.dll ../
|
- cp -Rf src/luaenginegui/release/LuaEngineGui.dll ../
|
||||||
- cp -Rf src/luaengineio/release/LuaEngineIO.dll ../
|
- cp -Rf src/luaengineio/release/LuaEngineIO.dll ../
|
||||||
- cp -Rf src/luaengineos/release/LuaEngineOS.dll ../
|
- cp -Rf src/luaengineos/release/LuaEngineOS.dll ../
|
||||||
- cp -Rf src/luaengine/release/LuaEngine.exe ../
|
- cp -Rf src/luaengine/release/LuaEngine.exe ../
|
||||||
|
- cp -Rf src/luaenginec/release/luaenginec.exe ../
|
||||||
- cd ..
|
- cd ..
|
||||||
artifacts:
|
artifacts:
|
||||||
paths:
|
paths:
|
||||||
- "LuaEngine.dll"
|
- "LuaEngine.dll"
|
||||||
- "LuaEngine.exe"
|
- "LuaEngine.exe"
|
||||||
|
- "luaenginec.exe"
|
||||||
- "LuaEngineGui.dll"
|
- "LuaEngineGui.dll"
|
||||||
- "LuaEngineIO.dll"
|
- "LuaEngineIO.dll"
|
||||||
- "LuaEngineOS.dll"
|
- "LuaEngineOS.dll"
|
||||||
|
@ -34,13 +36,13 @@ LuaEngineApp:
|
||||||
script:
|
script:
|
||||||
- mkdir -p build
|
- mkdir -p build
|
||||||
- cd build
|
- cd build
|
||||||
- qmake-static CONFIG+=WITH_LUAENGINEAPP ../luaengine.pro
|
- qmake-static CONFIG+=WITH_LUAENGINEAPP DEFINES+=LUAENGINE_FOOTER_SCRIPT ../luaengine.pro
|
||||||
- make -j4
|
- make -j4
|
||||||
- cp -Rf src/luaengineapp/release/LuaEngineApp.exe ../
|
- cp -Rf src/luaengineapp/release/LuaEngineApp.exe ../windows.le
|
||||||
- cd ..
|
- cd ..
|
||||||
artifacts:
|
artifacts:
|
||||||
paths:
|
paths:
|
||||||
- "LuaEngineApp.exe"
|
- "windows.le"
|
||||||
|
|
||||||
LuaEngine Setup:
|
LuaEngine Setup:
|
||||||
stage: deploy
|
stage: deploy
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QFont>
|
#include <QFont>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QDebug>
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
|
|
|
@ -36,11 +36,12 @@ INCLUDEPATH += \
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
main.cpp
|
main.cpp
|
||||||
|
|
||||||
win32: HEADERS += \
|
|
||||||
resource.h
|
|
||||||
|
|
||||||
OTHER_FILES += \
|
OTHER_FILES += \
|
||||||
app.lua \
|
app.lua \
|
||||||
app.rc
|
app.rc
|
||||||
|
|
||||||
win32: RC_FILE = app.rc
|
|
||||||
|
!defined(LUAENGINE_FOOTER_SCRIPT) {
|
||||||
|
win32: HEADERS += resource.h
|
||||||
|
win32: RC_FILE = app.rc
|
||||||
|
}
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include "LuaEngineIO.h"
|
#include "LuaEngineIO.h"
|
||||||
#include "LuaEngineOS.h"
|
#include "LuaEngineOS.h"
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
|
#include <QMessageBox>
|
||||||
#include <QFont>
|
#include <QFont>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
|
@ -30,7 +31,6 @@ int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
QApplication::setAttribute(Qt::AA_EnableHighDpiScaling, true);
|
QApplication::setAttribute(Qt::AA_EnableHighDpiScaling, true);
|
||||||
QApplication a(argc, argv);
|
QApplication a(argc, argv);
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 4, 0)
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 4, 0)
|
||||||
if (QSysInfo::windowsVersion() >= 0x0080)
|
if (QSysInfo::windowsVersion() >= 0x0080)
|
||||||
|
@ -42,14 +42,37 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
QByteArray luaScript;
|
QByteArray luaScript;
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
|
#ifdef LUAENGINE_FOOTER_SCRIPT
|
||||||
{
|
{
|
||||||
HMODULE handle = GetModuleHandleW(NULL);
|
QFile executable(a.arguments().at(0));
|
||||||
HRSRC resource = FindResourceW(handle, MAKEINTRESOURCE(IDR_SCRIPT1), L"SCRIPT");
|
if (executable.open(QIODevice::ReadOnly)) {
|
||||||
HGLOBAL resourceData = LoadResource(handle, resource);
|
qint64 executableSize = executable.size();
|
||||||
DWORD size = SizeofResource(handle, resource);
|
executable.seek(executableSize - 6);
|
||||||
const char *data = static_cast<const char*>(LockResource(resourceData));
|
QByteArray footer = executable.read(6);
|
||||||
luaScript = QByteArray(data, size);
|
if (footer.right(2) == QByteArray("\xb4\x00", 2)) {
|
||||||
|
bool sizeOk;
|
||||||
|
qint64 scriptSize = footer.left(4).toHex().toLongLong(&sizeOk, 16);
|
||||||
|
if (sizeOk) {
|
||||||
|
executable.seek(executableSize - scriptSize - 6);
|
||||||
|
luaScript = executable.read(scriptSize);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
QMessageBox::information(NULL, "Lua Engine", "Lua Engine Script footer not found!");
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
{
|
||||||
|
HMODULE handle = GetModuleHandleW(NULL);
|
||||||
|
HRSRC resource = FindResourceW(handle, MAKEINTRESOURCE(IDR_SCRIPT1), L"SCRIPT");
|
||||||
|
HGLOBAL resourceData = LoadResource(handle, resource);
|
||||||
|
DWORD size = SizeofResource(handle, resource);
|
||||||
|
const char *data = static_cast<const char*>(LockResource(resourceData));
|
||||||
|
luaScript = QByteArray(data, size);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
LuaEngineGui luaEngineGui;
|
LuaEngineGui luaEngineGui;
|
||||||
|
@ -63,7 +86,7 @@ int main(int argc, char *argv[])
|
||||||
}
|
}
|
||||||
|
|
||||||
if (luaEngineGui.executeLuaFunction("main", arguments, true)) {
|
if (luaEngineGui.executeLuaFunction("main", arguments, true)) {
|
||||||
QVariant variant = luaEngineGui.returnVariant();
|
const QVariant variant = luaEngineGui.returnVariant();
|
||||||
if (variant.type() == QVariant::Int || variant.type() == QVariant::LongLong) {
|
if (variant.type() == QVariant::Int || variant.type() == QVariant::LongLong) {
|
||||||
return variant.toInt();
|
return variant.toInt();
|
||||||
}
|
}
|
||||||
|
|
34
src/luaenginec/luaenginec.pro
Normal file
34
src/luaenginec/luaenginec.pro
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
#/*****************************************************************************
|
||||||
|
#* luaEngine Lua Engine for Qt
|
||||||
|
#* Copyright (C) 2019 Syping
|
||||||
|
#*
|
||||||
|
#* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
#* you may not use this file except in compliance with the License.
|
||||||
|
#* You may obtain a copy of the License at
|
||||||
|
#*
|
||||||
|
#* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#*
|
||||||
|
#* Unless required by applicable law or agreed to in writing, software
|
||||||
|
#* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
#* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
#* See the License for the specific language governing permissions and
|
||||||
|
#* limitations under the License.
|
||||||
|
#*****************************************************************************/
|
||||||
|
|
||||||
|
QT += core
|
||||||
|
QT -= gui widgets
|
||||||
|
TARGET = luaenginec
|
||||||
|
CONFIG += c++11
|
||||||
|
|
||||||
|
static: DEFINES += LUAENGINE_STATIC
|
||||||
|
|
||||||
|
CONFIG(debug, debug|release): win32: LIBS += -L$$OUT_PWD/../luaenginecore/debug -lLuaEngine
|
||||||
|
CONFIG(release, debug|release): win32: LIBS += -L$$OUT_PWD/../luaenginecore/release -lLuaEngine
|
||||||
|
unix: LIBS += -L$$OUT_PWD/../luaenginecore -lLuaEngine
|
||||||
|
|
||||||
|
INCLUDEPATH += \
|
||||||
|
../luaenginecore/lua \
|
||||||
|
../luaenginecore/luaengine \
|
||||||
|
|
||||||
|
SOURCES += \
|
||||||
|
main.cpp
|
100
src/luaenginec/main.cpp
Normal file
100
src/luaenginec/main.cpp
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
/*****************************************************************************
|
||||||
|
* luaEngine Lua Engine for Qt
|
||||||
|
* Copyright (C) 2018-2019 Syping
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*****************************************************************************/
|
||||||
|
|
||||||
|
#include "LuaEngine.h"
|
||||||
|
#include <QCommandLineParser>
|
||||||
|
#include <QCommandLineOption>
|
||||||
|
#include <QCoreApplication>
|
||||||
|
#include <QTextStream>
|
||||||
|
#include <QSaveFile>
|
||||||
|
#include <QFile>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
QCoreApplication a(argc, argv);
|
||||||
|
a.setApplicationName("luaenginec");
|
||||||
|
a.setApplicationVersion("0.1");
|
||||||
|
|
||||||
|
QCommandLineParser parser;
|
||||||
|
|
||||||
|
QCommandLineOption pLuaEngineOption(QStringList() << "le" << "luaengine", "Location of portable Lua Engine executor.", "luaengine");
|
||||||
|
parser.addOption(pLuaEngineOption);
|
||||||
|
|
||||||
|
parser.addPositionalArgument("source", "Source file to build.");
|
||||||
|
parser.addPositionalArgument("output", "Output file.");
|
||||||
|
|
||||||
|
parser.addHelpOption();
|
||||||
|
parser.addVersionOption();
|
||||||
|
|
||||||
|
parser.process(a);
|
||||||
|
|
||||||
|
const QStringList args = parser.positionalArguments();
|
||||||
|
|
||||||
|
QFile luaScript(args.at(0));
|
||||||
|
|
||||||
|
LuaEngine luaEngine;
|
||||||
|
if (!luaEngine.loadLuaScript(&luaScript)) {
|
||||||
|
QTextStream(stderr) << "Failed to load \"" << args.at(0) << "\"." << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
QSaveFile outputFile(args.at(1));
|
||||||
|
if (!outputFile.open(QIODevice::WriteOnly)) {
|
||||||
|
QTextStream(stderr) << "Failed to open \"" << args.at(1) << "\"." << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString pLuaEngine = parser.value(pLuaEngineOption);
|
||||||
|
if (!pLuaEngine.isEmpty()) {
|
||||||
|
QFile portableLuaEngine(pLuaEngine);
|
||||||
|
if (!portableLuaEngine.open(QIODevice::ReadOnly)) {
|
||||||
|
outputFile.cancelWriting();
|
||||||
|
outputFile.commit();
|
||||||
|
QTextStream(stderr) << "Failed to open \"" << pLuaEngine << "\"." << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
outputFile.write(portableLuaEngine.readAll());
|
||||||
|
}
|
||||||
|
|
||||||
|
const QByteArray luaDump = luaEngine.dumpLuaScript();
|
||||||
|
int dumpSize = luaDump.size();
|
||||||
|
outputFile.write(luaDump);
|
||||||
|
|
||||||
|
if (!pLuaEngine.isEmpty()) {
|
||||||
|
QByteArray lengthArray = QByteArray::number(dumpSize, 16);
|
||||||
|
if (lengthArray.size() > 8) {
|
||||||
|
outputFile.cancelWriting();
|
||||||
|
outputFile.commit();
|
||||||
|
QTextStream(stderr) << "Lua Engine script is too large." << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
while (lengthArray.size() != 8) {
|
||||||
|
lengthArray.insert(0, "0");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
outputFile.write(QByteArray::fromHex(lengthArray));
|
||||||
|
outputFile.write("\xb4\x00", 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!outputFile.commit()) {
|
||||||
|
QTextStream(stderr) << "Failed to write \"" << args.at(1) << "\"." << endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -20,7 +20,6 @@
|
||||||
#include <QTextStream>
|
#include <QTextStream>
|
||||||
#include <QMetaMethod>
|
#include <QMetaMethod>
|
||||||
#include <QtGlobal>
|
#include <QtGlobal>
|
||||||
#include <QDebug>
|
|
||||||
|
|
||||||
LuaEngine::LuaEngine(QObject *parent, bool loadBaseLibraries) : QObject(parent)
|
LuaEngine::LuaEngine(QObject *parent, bool loadBaseLibraries) : QObject(parent)
|
||||||
{
|
{
|
||||||
|
@ -53,6 +52,13 @@ void LuaEngine::loadBaseLibraries()
|
||||||
luaL_openlibs(L);
|
luaL_openlibs(L);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int LuaEngine::luaEngineWriter_p(lua_State *L_p, const void *buffer, size_t size, void *array)
|
||||||
|
{
|
||||||
|
Q_UNUSED(L_p)
|
||||||
|
((QByteArray*)array)->append(QByteArray(static_cast<const char*>(buffer), (int)size));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int LuaEngine::luaEngineVersion_p(lua_State *L_p)
|
int LuaEngine::luaEngineVersion_p(lua_State *L_p)
|
||||||
{
|
{
|
||||||
pushVariant(L_p, "0.1");
|
pushVariant(L_p, "0.1");
|
||||||
|
@ -83,10 +89,44 @@ int LuaEngine::luaEnginePlatform_p(lua_State *L_p)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LuaEngine::executeLuaScript(const QByteArray &data)
|
QByteArray LuaEngine::dumpLuaScript()
|
||||||
|
{
|
||||||
|
QByteArray array;
|
||||||
|
lua_lock(L);
|
||||||
|
lua_dump(L, luaEngineWriter_p, (void*)&array, 1);
|
||||||
|
lua_unlock(L);
|
||||||
|
return array;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LuaEngine::loadLuaScript(const QByteArray &data)
|
||||||
{
|
{
|
||||||
int result = luaL_loadbuffer(L, data.data(), data.size(), "script");
|
int result = luaL_loadbuffer(L, data.data(), data.size(), "script");
|
||||||
if (result == 0)
|
return (result == 0) ? true : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LuaEngine::loadLuaScript(QIODevice *device, bool closeDevice)
|
||||||
|
{
|
||||||
|
QByteArray data;
|
||||||
|
if (!device->isOpen()) {
|
||||||
|
if (device->open(QIODevice::ReadOnly)) {
|
||||||
|
data = device->readAll();
|
||||||
|
if (closeDevice)
|
||||||
|
device->close();
|
||||||
|
return loadLuaScript(data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
data = device->readAll();
|
||||||
|
if (closeDevice)
|
||||||
|
device->close();
|
||||||
|
return loadLuaScript(data);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LuaEngine::executeLuaScript(const QByteArray &data)
|
||||||
|
{
|
||||||
|
if (loadLuaScript(data))
|
||||||
return (lua_pcall(L, 0, LUA_MULTRET, 0) == 0) ? true : false;
|
return (lua_pcall(L, 0, LUA_MULTRET, 0) == 0) ? true : false;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,7 @@ extern "C" {
|
||||||
#include "../lua/lua.h"
|
#include "../lua/lua.h"
|
||||||
#include "../lua/lualib.h"
|
#include "../lua/lualib.h"
|
||||||
#include "../lua/lauxlib.h"
|
#include "../lua/lauxlib.h"
|
||||||
|
#include "../lua/llimits.h"
|
||||||
}
|
}
|
||||||
|
|
||||||
class LUAENGINESHARED_EXPORT LuaEngine : public QObject
|
class LUAENGINESHARED_EXPORT LuaEngine : public QObject
|
||||||
|
@ -39,6 +40,9 @@ public:
|
||||||
~LuaEngine();
|
~LuaEngine();
|
||||||
lua_State* luaState();
|
lua_State* luaState();
|
||||||
void loadBaseLibraries();
|
void loadBaseLibraries();
|
||||||
|
QByteArray dumpLuaScript();
|
||||||
|
bool loadLuaScript(const QByteArray &data);
|
||||||
|
bool loadLuaScript(QIODevice *device, bool closeDevice = true);
|
||||||
bool executeLuaScript(const QByteArray &data);
|
bool executeLuaScript(const QByteArray &data);
|
||||||
bool executeLuaScript(QIODevice *device, bool closeDevice = true);
|
bool executeLuaScript(QIODevice *device, bool closeDevice = true);
|
||||||
bool executeLuaFunction(const char *name, bool requireReturn = false);
|
bool executeLuaFunction(const char *name, bool requireReturn = false);
|
||||||
|
@ -74,6 +78,7 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
lua_State *L;
|
lua_State *L;
|
||||||
|
static int luaEngineWriter_p(lua_State *L_p, const void *buffer, size_t size, void *array);
|
||||||
static int luaEngineVersion_p(lua_State *L_p);
|
static int luaEngineVersion_p(lua_State *L_p);
|
||||||
static int luaEnginePlatform_p(lua_State *L_p);
|
static int luaEnginePlatform_p(lua_State *L_p);
|
||||||
static int luaObjectDelete_p(lua_State *L_p);
|
static int luaObjectDelete_p(lua_State *L_p);
|
||||||
|
|
|
@ -25,3 +25,4 @@ SUBDIRS += luaenginecore \
|
||||||
|
|
||||||
CONFIG(WITH_LUAENGINEAPP): SUBDIRS += luaengineapp
|
CONFIG(WITH_LUAENGINEAPP): SUBDIRS += luaengineapp
|
||||||
CONFIG(WITH_LUAENGINERUN): SUBDIRS += luaengine
|
CONFIG(WITH_LUAENGINERUN): SUBDIRS += luaengine
|
||||||
|
CONFIG(WITH_LUAENGINECOM): SUBDIRS += luaenginec
|
||||||
|
|
Loading…
Reference in a new issue