Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Memory dev: changed args or LuaMemory::LuaMemory and LuaMemory::memorize() #199

Open
wants to merge 33 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
dbe83b0
add ConfigListReg
shewer Mar 30, 2021
cb90c91
add ConfigItemReg ConfigValue
shewer Mar 31, 2021
a1c75a7
add ProjectionReg
shewer Mar 31, 2021
a4842ab
add sample projection.lua
shewer Mar 31, 2021
e0450e2
add ConfigMapReg
shewer Apr 1, 2021
d5767e5
modify ConfigReg
shewer Apr 1, 2021
36e30b6
ConfigList(append , insert) ConfigMap (set ) 改用 自身 參考(ConfigItem)
shewer Apr 1, 2021
c1e9e56
move Config ..REG code to config.h
shewer Apr 4, 2021
15040ce
update
shewer Apr 12, 2021
7bf6c2c
update sample
shewer Apr 12, 2021
951912f
update types.cc
shewer Apr 12, 2021
c193fd8
add engine:apply_schema() (#98)
shewer Apr 1, 2021
aa0c118
Export KeyEvent (#100)
shewer Apr 1, 2021
ec95adc
remove config.h modules.cc projection.lua
shewer Apr 14, 2021
d1cefd9
restore moduless.cc from fork/master
shewer Jul 28, 2021
9268d3f
rebase from fork/master
shewer Jul 28, 2021
bbdd4b7
Merge branch 'hchunhui:master' into master
shewer Sep 17, 2021
f4638ba
merge fork/master #139
shewer Oct 22, 2021
ee227e8
Merge branch 'hchunhui:master' into master
shewer Oct 30, 2021
590d3d5
Merge remote-tracking branch 'fork/master'
shewer Feb 15, 2022
c219707
Merge branch 'hchunhui:master' into master
shewer Jun 6, 2022
667ff2b
Merge branch 'hchunhui:master' into master
shewer Jul 6, 2022
42618fd
Merge branch 'hchunhui:master' into master
shewer Jul 11, 2022
3298ce7
Merge branch 'hchunhui:master' into master
shewer Jul 11, 2022
311e1e9
Merge branch 'hchunhui:master' into master
shewer Jul 12, 2022
f0c80e3
Merge branch 'hchunhui:master' into master
shewer Jul 12, 2022
052f028
Merge branch 'hchunhui:master' into master
shewer Jul 13, 2022
a13205d
Merge branch 'hchunhui:master' into master
shewer Jul 24, 2022
9d6b14a
Merge remote-tracking branch 'fork/master'
shewer Sep 4, 2022
63cc6b6
add distribution infomation
shewer Sep 7, 2022
ed0346a
Merge branch 'hchunhui:master' into master
shewer Sep 11, 2022
fb1b3bd
Merge branch 'hchunhui:master' into master
shewer Sep 24, 2022
962a64f
changed args or LuaMemory::LuaMemory and LuaMemory::memorize()
shewer Sep 24, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion sample/lua/expand_translator.lua
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,9 @@ local function init(env)
env.mem = Memory(env.engine,env.engine.schema) -- ns= "translator"
-- env.mem = Memory(env.engine,env.engine.schema, env.name_space )
-- env.mem = Memory(env.engine,Schema("cangjie5") ) -- ns= "translator-
env.mem:memorize(function(commit) memoryCallback(env.mem, commit) end)
env.mem:memorize(memoryCallback)
-- env.mem = Memory(env.engine,Schema("cangjie5"),'translator', memoryCallback) --

-- or use
-- schema = Schema("cangjie5") -- schema_id
-- env.mem = Memory(env.engine, schema, "translator")
Expand Down
65 changes: 65 additions & 0 deletions sample/lua/expand_translator1.lua
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@


--[[
in cangjie5.schema.yaml

schema:
schema_id: cangjie5
engine:
translators:
- lua_translator@expand_translator
]]

local function memoryCallback(memory, commit)
for i,dictentry in ipairs(commit:get())
do
log.info(dictentry.text .. " " .. dictentry.weight .. " " .. dictentry.comment .. "")
memory:update_userdict(dictentry,0,"") -- do nothing to userdict
-- memory:update_userdict(dictentry,1,"") -- update entry to userdict
-- memory:update_userdict(dictentry,1,"") -- delete entry to userdict
end
return true
end

local function init(env)
env.mem = Memory(env.engine,Schema("luna_pinyin"),'translator', memoryCallback) --
config = env.engine.schema.config
env.tag = config:get_string(env.name_space .. '/tag') or 'abc'
namespace = 'expand_translator'
log.info("expand_translator Initilized!")
end

-- translation function
-- 使用 Translation( func, argvs....)
local function transltion_func(inp,seg,mem)
if mem:dict_lookup(inp, true, 100) then
for entry in mem:iter_dict() do
local code = mem:decode(entry.code)
local codeComment = table.concat(code, ',')
local ph = Phrase(mem, 'expand_translator', seg.start, seg._end, entry)
ph.comment = codeComment
yield(ph:toCandidate())
end
end
end
local function translation_func1(translation,str)
for cand in translation:iter() do
local gcand=cand:get_genuine()
gcand.comment = gcand.comment .. ":" .. str
yield(cand)
end
end

local function translate(inp,seg,env)
if not seg:has_tag(env.tag) then return end
-- t1 memory 請調出 cand
local active_inp= inp:sub(seg.start+1, seg._end)
local t1 = Translator( translation_func, active_inp, seg, mem)
-- t2 修改 candidate comment
local t2 = Translator( translation_func1, t1,'--test--')
for cand in t2:iter() do
yield(cand)
end
end

return {init = init, func = translate}
7 changes: 5 additions & 2 deletions src/types.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1340,7 +1340,7 @@ namespace MemoryReg {
if (!memorize_callback)
return false;

auto r = lua_->call<bool, an<LuaObj>, const CommitEntry &>(memorize_callback, commit_entry);
auto r = lua_->call<bool, an<LuaObj>, T &, const CommitEntry &>(memorize_callback, *this, commit_entry);
if (!r.ok()) {
auto e = r.get_err();
LOG(ERROR) << "LuaMemory::Memorize error(" << e.status << "): " << e.e;
Expand All @@ -1363,10 +1363,13 @@ namespace MemoryReg {
Ticket translatorTicket(engine,"translator");
translatorTicket.schema = & (LuaType<Schema &>::todata(L, 2) );

if (3 <= n)
if (3 == n)
translatorTicket.name_space = LuaType<string>::todata(L, 3, &C);

an<T> memoli = New<T>(lua, translatorTicket);
if (4 <= n)
memoli->memorize(LuaObj::todata(L, 4));

LuaType<an<T>>::pushdata(L, memoli);
return 1;
}
Expand Down