Blame view

src/services/named.lua 1.15 KB
314bc5df   zhengshouren   提交服务器初始代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
  local skynet = require "skynet"
  require "skynet.manager"
  local crab = require "crab.c"
  
  local table_insert = table.insert
  local table_unpack = table.unpack
  local mode, id, dict = ...
  
  local function toutf8(name)
  	local t = {}
  	for _, v in utf8.codes(name) do
  		table_insert(t, v)
  	end
  	return t
  end
  
  if mode == "sub" then
  	local CMD = {}
  	dict = tonumber(dict)
  
  	function CMD.check(name)
  		if name:find("%c") then
  			return false
  		end
  		local utftb = toutf8(name)
  		if crab.filter(dict, utftb) then
  			return false, utf8.char(table_unpack(utftb))
  		end
  		return true
  	end
  
  	skynet.start(function()
  		skynet.dispatch("lua", function(_, _, command, ...)
  			local f = CMD[command]
  			skynet.ret(skynet.pack(f(...)))
  		end)
  
  		skynet.register(string.format("NAMED%d", id))
  	end)
  else
  	skynet.start(function()
c384626d   zhouhaihai   好友
42
  		local ok, forbidNames = pcall(require, "csvdata.forbid_name")
314bc5df   zhengshouren   提交服务器初始代码
43
44
45
46
47
48
49
50
51
52
53
54
55
56
  		if not ok then forbidNames = {} end
  
  		local words = {}
  		for _, data in ipairs(forbidNames) do
  			local ok, utftb = pcall(toutf8, data.name)
  			if ok then table.insert(words, utftb) end
  		end
  		local d = crab.open(words)
  
  		for i = 1, 5 do
  			skynet.newservice(SERVICE_NAME, "sub", i, d)
  		end
  	end)
  end