summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bin/process.dllbin0 -> 15872 bytes
-rw-r--r--build/extension/.gitignore4
-rw-r--r--main.lua14
-rw-r--r--src/ffi/sleep.lua8
-rw-r--r--src/ffi/unicode.lua49
-rw-r--r--src/global_protect.lua (renamed from test/global_protect.lua)0
-rw-r--r--src/service/init.lua36
-rw-r--r--test/main.lua10
8 files changed, 110 insertions, 11 deletions
diff --git a/bin/process.dll b/bin/process.dll
new file mode 100644
index 00000000..ff0fc1d3
--- /dev/null
+++ b/bin/process.dll
Binary files differ
diff --git a/build/extension/.gitignore b/build/extension/.gitignore
new file mode 100644
index 00000000..bf962da1
--- /dev/null
+++ b/build/extension/.gitignore
@@ -0,0 +1,4 @@
+out
+node_modules
+client/server
+.vscode-test \ No newline at end of file
diff --git a/main.lua b/main.lua
index 269566af..3f2f251c 100644
--- a/main.lua
+++ b/main.lua
@@ -1,7 +1,15 @@
-require 'filelist'
+require 'filesystem'
ROOT = fs.current_path()
-package.path = package.path .. ';' .. (ROOT / 'src' / '?.lua'):string()
- .. ';' .. (ROOT / 'src' / '?' / 'init.lua'):string()
+package.path = (ROOT / 'src' / '?.lua'):string()
+ .. ';' .. (ROOT / 'src' / '?' / 'init.lua'):string()
local log = require 'log'
log.init(ROOT, ROOT / 'log' / 'test.log')
+log.info('Lua 语言服务启动,路径为:', ROOT)
+
+require 'utility'
+require 'global_protect'
+local service = require 'service'
+local session = service()
+
+session:listen()
diff --git a/src/ffi/sleep.lua b/src/ffi/sleep.lua
new file mode 100644
index 00000000..5c4be639
--- /dev/null
+++ b/src/ffi/sleep.lua
@@ -0,0 +1,8 @@
+local ffi = require 'ffi'
+ffi.cdef[[
+ void Sleep(unsigned long dwMilliseconds);
+]]
+
+return function (time)
+ ffi.C.Sleep(time)
+end
diff --git a/src/ffi/unicode.lua b/src/ffi/unicode.lua
new file mode 100644
index 00000000..734b4679
--- /dev/null
+++ b/src/ffi/unicode.lua
@@ -0,0 +1,49 @@
+local ffi = require 'ffi'
+ffi.cdef[[
+ int MultiByteToWideChar(unsigned int CodePage, unsigned long dwFlags, const char* lpMultiByteStr, int cbMultiByte, wchar_t* lpWideCharStr, int cchWideChar);
+ int WideCharToMultiByte(unsigned int CodePage, unsigned long dwFlags, const wchar_t* lpWideCharStr, int cchWideChar, char* lpMultiByteStr, int cchMultiByte, const char* lpDefaultChar, int* pfUsedDefaultChar);
+]]
+
+local CP_UTF8 = 65001
+local CP_ACP = 0
+
+local function u2w(input)
+ local wlen = ffi.C.MultiByteToWideChar(CP_UTF8, 0, input, #input, nil, 0)
+ local wstr = ffi.new('wchar_t[?]', wlen+1)
+ ffi.C.MultiByteToWideChar(CP_UTF8, 0, input, #input, wstr, wlen)
+ return wstr, wlen
+end
+
+local function a2w(input)
+ local wlen = ffi.C.MultiByteToWideChar(CP_ACP, 0, input, #input, nil, 0)
+ local wstr = ffi.new('wchar_t[?]', wlen+1)
+ ffi.C.MultiByteToWideChar(CP_ACP, 0, input, #input, wstr, wlen)
+ return wstr, wlen
+end
+
+local function w2u(wstr, wlen)
+ local len = ffi.C.WideCharToMultiByte(CP_UTF8, 0, wstr, wlen, nil, 0, nil, nil)
+ local str = ffi.new('char[?]', len+1)
+ ffi.C.WideCharToMultiByte(CP_UTF8, 0, wstr, wlen, str, len, nil, nil)
+ return ffi.string(str)
+end
+
+local function w2a(wstr, wlen)
+ local len = ffi.C.WideCharToMultiByte(CP_ACP, 0, wstr, wlen, nil, 0, nil, nil)
+ local str = ffi.new('char[?]', len)
+ ffi.C.WideCharToMultiByte(CP_ACP, 0, wstr, wlen, str, len, nil, nil)
+ return ffi.string(str)
+end
+
+return {
+ u2w = u2w,
+ a2w = a2w,
+ w2u = w2u,
+ w2a = w2a,
+ u2a = function (input)
+ return w2a(u2w(input))
+ end,
+ a2u = function (input)
+ return w2u(a2w(input))
+ end,
+}
diff --git a/test/global_protect.lua b/src/global_protect.lua
index 6c736ea6..6c736ea6 100644
--- a/test/global_protect.lua
+++ b/src/global_protect.lua
diff --git a/src/service/init.lua b/src/service/init.lua
index 91e0a4d4..53e6e4b3 100644
--- a/src/service/init.lua
+++ b/src/service/init.lua
@@ -1,5 +1,35 @@
-local api = {
- definition = require 'service.definition'
+local sleep = require 'ffi.sleep'
+local ext = require 'process.ext'
+
+local function listen(self, input, output)
+ if input then
+ log.info('指定输入文件,路径为:', input)
+ fs.create_directories(input:parent_path())
+ io.input(io.open(input:string(), 'rb'))
+ else
+ ext.set_filemode(io.stdin, 'b')
+ end
+ if output then
+ log.info('指定输出文件,路径为:', output)
+ fs.create_directories(output:parent_path())
+ io.output(io.open(output:string(), 'wb'))
+ else
+ ext.set_filemode(io.stdout, 'b')
+ io.stdout:setvbuf 'no'
+ end
+
+ for line in io.input():lines 'L' do
+ log.debug('标准输入:\n', line)
+ end
+end
+
+local mt = {
+ definition = require 'service.definition',
+ listen = listen,
}
+mt.__index = mt
-return api
+return function ()
+ local session = setmetatable({}, mt)
+ return session
+end
diff --git a/test/main.lua b/test/main.lua
index 34cd003a..972a1068 100644
--- a/test/main.lua
+++ b/test/main.lua
@@ -1,11 +1,11 @@
require 'filesystem'
ROOT = fs.current_path()
-package.path = package.path .. ';' .. (ROOT / 'src' / '?.lua'):string()
- .. ';' .. (ROOT / 'src' / '?' / 'init.lua'):string()
- .. ';' .. (ROOT / 'test' / '?.lua'):string()
- .. ';' .. (ROOT / 'test' / '?' / 'init.lua'):string()
+package.path = (ROOT / 'src' / '?.lua'):string()
+ .. ';' .. (ROOT / 'src' / '?' / 'init.lua'):string()
+ .. ';' .. (ROOT / 'test' / '?.lua'):string()
+ .. ';' .. (ROOT / 'test' / '?' / 'init.lua'):string()
-local log = require 'log'
+log = require 'log'
log.init(ROOT, ROOT / 'log' / 'test.log')
log.debug('测试开始')