作者hmml (hmml)
看板mud_sanc
标题[心得] Mushclient 处理移位码的plugin...
时间Wed Sep 11 00:59:43 2013
一样还是试作,不过大部份都能显示的很好。
利用的函数是 OnPluginPacketReceived ,抓封包用的。这个函数是无差别
抓封包,在 MushClient 开始处理封包前,它会先抓过来,使用者可以先
MushClient 处理内容,弄成自己需要的再给 MushClient 处理。所以才有
可能处理移位码。这个一定要用 plugin 去挂。
不过处理封包的跟处理画面中的行不太一样,封包不是只有一行内容,它的
上限是 999 个字元,所以资料量大的指令,如:skill、list、score...
很容易超过 999 上限,这时就会切成好几个封包送过来,切的地方往往不
太好,可以说...蛮糟的...
当它切在一行的正中央,後半行的移位码会得不到前半行的长度,因而算错
该推移的长度。切在移位码的正中央,这个判断就会丢失。资料量要分好几
个封包的时候,也不保证它中间的封包一定就是 999 字元塞满(根本它随
意),只能无差别处理。
所以这个试作有很多时间都在处理这个问题。
目前没处理的,就是移位码指定的位置,是有字元占位的,圣殿有很多这类
作法:sc的3P视图,就是用这种方法写的,目前只完成堆叠,并没有写截掉
和取代的部份,所以3P永远不会动。compare 的红字绝对会在最左...等等。
party 的 3p 视图,写法跟 sc 是不同的。之前有wiz说写法一样,是他看错
。party 的移位码是用来截断角色名字的,後方3P视图里一个移位码也没有
。显示的写法根本是不一样的。
大概还是要重弄...因为截掉和取代非常难...这部份可能也是程式作者不愿
支援移位码的原因吧...基於他显示内容的方法,处理这两种很烦人。
下面这个就将就着用,反正 zMUD 也只有5.55可以将移位码显示得很完美而
已...
--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--
<?xml version="1.0" encoding="iso-8859-1"?>
<!DOCTYPE muclient>
<!-- Saved on 星期二, 六月 11, 2013, 10:42 下午 -->
<!-- MuClient version 4.84 -->
<!-- Plugin "newtest" generated by Plugin Wizard -->
<muclient>
<plugin
name="newtest_trial"
id="69400abd9629952d36fbc92e"
language="Lua"
purpose="重写中"
date_written="2013-06-11 22:41:55"
requires="4.84"
version="1.0"
>
<description trim="y">
重写中...
</description>
</plugin>
<!-- Get our standard constants -->
<include name="constants.lua"/>
<!-- Script -->
<script>
<![CDATA[
-- 在被分析前,就抓到封包的函数
function OnPluginPacketReceived (sText)
--tend :前封包中无换行字元的行。
--sText:伺服器送来的封包。
if string.match(sText,'%*trigger%d+') == nil then --不到一行的略过
if tend ~= nil then --如果tend有内容
sText = tend..sText
--把它接到目前封包的前头
tend = nil
--接着清空
end --tend nil?
end --不到一行的略过END
i,j =string.gsub(sText,'\n',"█")
--检查换行
if j >= 2 then --两行以上
if string.find(sText,"[^\n]+$") then --找封包的末行
--将末行存入tend。
tend = string.sub
(sText
,string.find
(sText
,"[^\n]+$"
))
end
--将封包的末行移除
sText = string.sub(sText,1,string.find(sText,"[^\n]+$"))
--将封包尾端一些奇怪的字元移除。
sText = string.sub(sText,1,-2)
--如果误删了换行,另行补上。
if string.find(sText,"[\n]",-1) == nil then
sText = sText..'\n'
end
end --两行以上END
--到此为止是整顿封包,让被腰斩的行恢复原状。
--以下是移位码处理。
if string.match(sText,'(%c%[24;)(%d+)H') ~= nil then --如果有移位码
--把移位码标记出来。
sText = string.gsub(sText,'(%c%[24;)(%d+)H',"∴%2∴")
--删除所有色码,存到sText准备对照用。
sText2 = string.gsub(sText,'(%c%[%d*m)',"")
sText2 = string.gsub(sText2,'(%c%[%d+;)(%d+)[m]',"")
sText2 = string.gsub(sText2,'(%c%[%d+;)(%d+;%d+)[m]',"")
--把sText2的内容一行一行读出
for i in string.gmatch(sText2, "[^\n]+" ) do
--从行首开始一个个找出改过的移位码
for di,di2 in string.gmatch(i, "(∴(%d+)∴)" ) do
--di = 移位码全部格式
--di2 = 移位码数值
i2,i3 = string.find(i,di)
--移位码位置
--移位码的数值减去移位码的位置,就是空格该补上的数量
al_len = di2-i2
--把移位码置换成应该补上的空格字段(sText2)
i = string.gsub(i,'∴(%d+)∴',string.rep(" ",al_len),1)
--同时也将sText的移位码同sText2般置换
sText = string.gsub(sText,'∴(%d+)∴',string.rep(" ",al_len),1)
end --for match ∴(%d+)∴
end --for match \n
end
--不管封包尾端有没有*[0m,无差别补上
sText = sText..string.char(0x1b)..'[0m'
--送到MushClient 接手处理
return sText
end
]]>
</script>
</muclient>
--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--==-==--
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 106.1.194.58
1F:推 elvrael :看不懂....不过还是要来推一下 XD 09/11 08:52
2F:→ laechan :你可以试试抓断行码(\n),将一段讯息先用断行码切成 n 09/11 09:54
3F:→ laechan :断讯息,再各别处理其移位码 09/11 09:55
4F:→ laechan :这样要超过 999 应该很困难 09/11 09:55
5F:→ laechan :唔你好像就是这样处理的, 呵呵 09/11 09:57