diff options
author | Kahrl <kahrl@gmx.net> | 2011-10-25 02:00:32 +0200 |
---|---|---|
committer | Perttu Ahola <celeron55@gmail.com> | 2011-12-01 11:38:06 +0200 |
commit | 7f7fe444d39a3280f45b8c4f12192cd420d9a904 (patch) | |
tree | c9620b63fee9789c5f18702e6b4767d284ba54ea | |
parent | f4272ccf8f0b0bbd76b28bbc715dd8534507a9bf (diff) | |
download | minetest-7f7fe444d39a3280f45b8c4f12192cd420d9a904.tar.gz minetest-7f7fe444d39a3280f45b8c4f12192cd420d9a904.tar.bz2 minetest-7f7fe444d39a3280f45b8c4f12192cd420d9a904.zip |
Wireshark dissector: Add TOSERVER_RESPAWN and TOCLIENT_DEATHSCREEN, plus some failed assertion fix (well, hack).
-rw-r--r-- | util/wireshark/minetest.lua | 46 |
1 files changed, 45 insertions, 1 deletions
diff --git a/util/wireshark/minetest.lua b/util/wireshark/minetest.lua index a7cd0c77c..6d5fa412d 100644 --- a/util/wireshark/minetest.lua +++ b/util/wireshark/minetest.lua @@ -427,6 +427,10 @@ do } end +-- TOSERVER_RESPAWN + +minetest_client_commands[0x38] = { "RESPAWN", 2 } + @@ -936,6 +940,40 @@ do } end +-- TOCLIENT_DEATHSCREEN + +do + local vs_set_camera_point_target = { + [0] = "False", + [1] = "True" + } + + local f_set_camera_point_target = ProtoField.uint8( + "minetest.server.deathscreen_set_camera_point_target", + "Set camera point target", base.DEC, vs_set_camera_point_target) + local f_camera_point_target_x = ProtoField.int32( + "minetest.client.deathscreen_camera_point_target_x", + "Camera point target X", base.DEC) + local f_camera_point_target_y = ProtoField.int32( + "minetest.client.deathscreen_camera_point_target_y", + "Camera point target Y", base.DEC) + local f_camera_point_target_z = ProtoField.int32( + "minetest.client.deathscreen_camera_point_target_z", + "Camera point target Z", base.DEC) + + minetest_server_commands[0x37] = { + "DEATHSCREEN", 15, + { f_set_camera_point_target, f_camera_point_target_x, + f_camera_point_target_y, f_camera_point_target_z}, + function(buffer, pinfo, tree, t) + t:add(f_set_camera_point_target, buffer(2,1)) + t:add(f_camera_point_target_x, buffer(3,4)) + t:add(f_camera_point_target_y, buffer(7,4)) + t:add(f_camera_point_target_z, buffer(11,4)) + end + } +end + @@ -1280,6 +1318,12 @@ function minetest_convert_utf16(tvb, name) hex = hex .. " 3F" end end - return ByteArray.new(hex):tvb(name):range() + if hex == "" then + -- This is a hack to avoid a failed assertion in tvbuff.c + -- (function: ensure_contiguous_no_exception) + return ByteArray.new("00"):tvb(name):range(0,0) + else + return ByteArray.new(hex):tvb(name):range() + end end |