aboutsummaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-msn-messenger.c
diff options
context:
space:
mode:
Diffstat (limited to 'epan/dissectors/packet-msn-messenger.c')
-rw-r--r--epan/dissectors/packet-msn-messenger.c151
1 files changed, 82 insertions, 69 deletions
diff --git a/epan/dissectors/packet-msn-messenger.c b/epan/dissectors/packet-msn-messenger.c
index b9cd203990..d0057fbcc0 100644
--- a/epan/dissectors/packet-msn-messenger.c
+++ b/epan/dissectors/packet-msn-messenger.c
@@ -36,13 +36,13 @@ void proto_reg_handoff_msnms(void);
* The now-expired Internet-Draft for the MSN Messenger 1.0 protocol
* can, as of the time of the writing of this comment, be found at:
*
- * http://praya.sourceforge.net/draft-movva-msn-messenger-protocol-00.txt
+ * http://praya.sourceforge.net/draft-movva-msn-messenger-protocol-00.txt
*
- * http://mono.es.gnome.org/imsharp/tutoriales/msn/appendixa.html
+ * http://mono.es.gnome.org/imsharp/tutoriales/msn/appendixa.html
*
- * http://www.hypothetic.org/docs/msn/ietf_draft.php
+ * http://www.hypothetic.org/docs/msn/ietf_draft.php
*
- * http://babble.wundsam.net/docs/protocol-msn-im.txt
+ * http://babble.wundsam.net/docs/protocol-msn-im.txt
*
* Note that it's Yet Another FTP-Like Command/Response Protocol,
* so it arguably should be dissected as such, although you do have
@@ -58,84 +58,97 @@ static int proto_msnms = -1;
static gint ett_msnms = -1;
-#define TCP_PORT_MSNMS 1863
+#define TCP_PORT_MSNMS 1863
static void
dissect_msnms(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
{
- proto_tree *msnms_tree;
- proto_item *ti;
- gint offset = 0;
- const guchar *line;
- gint next_offset;
- int linelen;
- /* int tokenlen; */
- /* const guchar *next_token; */
-
- col_set_str(pinfo->cinfo, COL_PROTOCOL, "MSNMS");
-
- /*
- * Find the end of the first line.
- *
- * Note that "tvb_find_line_end()" will return a value that is
- * not longer than what's in the buffer, so the "tvb_get_ptr()"
- * call won't throw an exception.
- */
- linelen = tvb_find_line_end(tvb, offset, -1, &next_offset, FALSE);
- line = tvb_get_ptr(tvb, offset, linelen);
-
-
- /*
- * Put the first line from the buffer into the summary.
- */
- col_add_str(pinfo->cinfo, COL_INFO,
- format_text(line, linelen));
-
- if (tree) {
- ti = proto_tree_add_item(tree, proto_msnms, tvb, offset, -1,
- ENC_NA);
- msnms_tree = proto_item_add_subtree(ti, ett_msnms);
-
- /*
- * Show the rest of the packet as text,
- * a line at a time.
- */
- while (tvb_offset_exists(tvb, offset)) {
- /*
- * Find the end of the line.
- */
- tvb_find_line_end(tvb, offset, -1,
- &next_offset, FALSE);
-
- /*
- * Put this line.
- */
- proto_tree_add_format_text(msnms_tree, tvb, offset, next_offset - offset);
- offset = next_offset;
- }
- }
+ proto_tree *msnms_tree;
+ proto_item *ti;
+ gint offset = 0;
+ const guchar *line;
+ gint next_offset;
+ int linelen;
+ /* int tokenlen; */
+ /* const guchar *next_token; */
+
+ col_set_str(pinfo->cinfo, COL_PROTOCOL, "MSNMS");
+
+ /*
+ * Find the end of the first line.
+ *
+ * Note that "tvb_find_line_end()" will return a value that is
+ * not longer than what's in the buffer, so the "tvb_get_ptr()"
+ * call won't throw an exception.
+ */
+ linelen = tvb_find_line_end(tvb, offset, -1, &next_offset, FALSE);
+ line = tvb_get_ptr(tvb, offset, linelen);
+
+
+ /*
+ * Put the first line from the buffer into the summary.
+ */
+ col_add_str(pinfo->cinfo, COL_INFO,
+ format_text(line, linelen));
+
+ if (tree) {
+ ti = proto_tree_add_item(tree, proto_msnms, tvb, offset, -1,
+ ENC_NA);
+ msnms_tree = proto_item_add_subtree(ti, ett_msnms);
+
+ /*
+ * Show the rest of the packet as text,
+ * a line at a time.
+ */
+ while (tvb_offset_exists(tvb, offset)) {
+ /*
+ * Find the end of the line.
+ */
+ tvb_find_line_end(tvb, offset, -1,
+ &next_offset, FALSE);
+
+ /*
+ * Put this line.
+ */
+ proto_tree_add_format_text(msnms_tree, tvb, offset, next_offset - offset);
+ offset = next_offset;
+ }
+ }
}
void
proto_register_msnms(void)
{
- static gint *ett[] = {
- &ett_msnms,
- };
+ static gint *ett[] = {
+ &ett_msnms,
+ };
- proto_msnms = proto_register_protocol("MSN Messenger Service", "MSNMS", "msnms");
- proto_register_subtree_array(ett, array_length(ett));
+ proto_msnms = proto_register_protocol("MSN Messenger Service", "MSNMS", "msnms");
+ proto_register_subtree_array(ett, array_length(ett));
}
void
proto_reg_handoff_msnms(void)
{
- dissector_handle_t msnms_handle;
-
- msnms_handle = create_dissector_handle(dissect_msnms, proto_msnms);
- dissector_add_uint("tcp.port", TCP_PORT_MSNMS, msnms_handle);
- /*
- * For MSN Messenger Protocol over HTTP
- */
- dissector_add_string("media_type", "application/x-msn-messenger", msnms_handle);
+ dissector_handle_t msnms_handle;
+
+ msnms_handle = create_dissector_handle(dissect_msnms, proto_msnms);
+ dissector_add_uint("tcp.port", TCP_PORT_MSNMS, msnms_handle);
+ /*
+ * For MSN Messenger Protocol over HTTP
+ */
+ dissector_add_string("media_type", "application/x-msn-messenger", msnms_handle);
}
+
+/*
+ * Editor modelines - http://www.wireshark.org/tools/modelines.html
+ *
+ * Local variables:
+ * c-basic-offset: 4
+ * tab-width: 8
+ * indent-tabs-mode: nil
+ * End:
+ *
+ * vi: set shiftwidth=4 tabstop=8 expandtab:
+ * :indentSize=4:tabSize=8:noTabs=true:
+ */