summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2021-11-02 12:04:04 +0800
committer最萌小汐 <sumneko@hotmail.com>2021-11-15 16:08:33 +0800
commit9d2be68b46194a18132c57c26034823b1752a300 (patch)
tree1b344bd994fd6bc946c2d4b5deebac6370ff0c7e
parent47c0a57dc43f698f0152616fccd183516ad769d0 (diff)
downloadlua-language-server-9d2be68b46194a18132c57c26034823b1752a300.zip
resolve utf16 bom
-rw-r--r--script/encoder/init.lua22
-rw-r--r--script/library.lua2
2 files changed, 20 insertions, 4 deletions
diff --git a/script/encoder/init.lua b/script/encoder/init.lua
index f33f5a1d..d7753c1f 100644
--- a/script/encoder/init.lua
+++ b/script/encoder/init.lua
@@ -4,6 +4,8 @@ local utf16be = require 'encoder.utf16be'
---@alias encoder.encoding '"utf8"'|'"utf16"'|'"utf16le"'|'"utf16be"'
+---@alias encoder.bom '"no"'|'"yes"'|'"auto"'
+
local m = {}
---@param encoding encoder.encoding
@@ -63,9 +65,13 @@ end
---@param encoding encoder.encoding
---@param text string
+---@param bom encoder.bom
---@return string
-function m.encode(encoding, text)
+function m.encode(encoding, text, bom)
if encoding == 'utf8' then
+ if bom == 'yes' then
+ text = '\xEF\xBB\xBF' .. text
+ end
return text
end
if encoding == 'ansi' then
@@ -73,10 +79,20 @@ function m.encode(encoding, text)
end
if encoding == 'utf16'
or encoding == 'utf16le' then
- return utf16le.encode(text)
+ text = utf16le.encode(text)
+ if bom == 'yes'
+ or bom == 'auto' then
+ text = '\xFF\xFE' .. text
+ end
+ return text
end
if encoding == 'utf16be' then
- return utf16be.encode(text)
+ text = utf16be.encode(text)
+ if bom == 'yes'
+ or bom == 'auto' then
+ text = '\xFE\xFF' .. text
+ end
+ return text
end
log.error('Unsupport encode encoding:', encoding)
return text
diff --git a/script/library.lua b/script/library.lua
index 0911750e..943e6d2d 100644
--- a/script/library.lua
+++ b/script/library.lua
@@ -236,7 +236,7 @@ local function initBuiltIn()
local metaDoc = compileSingleMetaDoc(fsu.loadFile(libPath), metaLang, status)
if metaDoc then
local outPath = metaPath / libName
- encoder.encode(encoding, metaDoc)
+ metaDoc = encoder.encode(encoding, metaDoc, 'auto')
out:saveFile(libName, metaDoc)
m.metaPaths[#m.metaPaths+1] = outPath:string()
end