I am writing a dissector in Lua for a custom binary protocol. I have defined three field types:
f.field1 = ProtoField.bytes("myproto.field1","Field 1",base.HEX)
f.field2 = ProtoField.uint16("myproto.field2","Field 2",base.HEX)
f.field3 = ProtoField.bytes("myproto.field3","Field 3",base.HEX)
These fields are added to the tree like this:
subtree:add(f.field1,buf(offset,4))
offset = offset + 4
val2 = buf(offset,2):uint()
– some logic around populating f2_description omitted
offset = offset + 2
subtree:add(f.field2, val2):append_text(" (" ..f2_description ..")")
subtree:add(f.field3, buf(offset,2))
Now, when I open Wireshark and click on “Field 1” or “Field 3” in the dissected packet’s tree, I see that the selected data is highlighted in the raw packet hex view (bottom most panel):
data:image/s3,"s3://crabby-images/ddde5/ddde584a948dd9a020557bf35c7c27d20e03ccf5" alt="packet contents highlighted"
but it is not the case for Field2.
data:image/s3,"s3://crabby-images/30a7d/30a7d50743ed7a2456c11c36246b7fc1ed8988af" alt="alt text"
What am I doing wrong?
asked 13 Feb ‘12, 13:02
data:image/s3,"s3://crabby-images/ab4c0/ab4c09413129b94df3cb15755f84e9951a075d4a" alt="Konrads's gravatar image"
Konrads
21●1●1●4
accept rate: 0%
edited 13 Feb ‘12, 17:33
data:image/s3,"s3://crabby-images/04170/04170fbfd93c8c63b00ba1618a2a6e0022cd7955" alt="helloworld's gravatar image"
helloworld
3.1k●4●20●41
Thanks! it works!