aboutsummaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-lpd.c
diff options
context:
space:
mode:
authorMichael Mann <mmann78@netscape.net>2014-08-13 08:56:22 -0400
committerAnders Broman <a.broman58@gmail.com>2014-08-14 04:21:05 +0000
commitd68d0e88b4924a610b5cd2fd3a748b00c9bbab1a (patch)
treef46c04238502faa689c173f1b8420c8d19d3c51e /epan/dissectors/packet-lpd.c
parentf64421df3f230e89e0d83e327926f4c46fbd70dc (diff)
Eliminate proto_tree_add_text from some dissectors.
Other minor cleanup while in the neighborhood. Change-Id: If73a029f564219782c313d4154c24c7ce7458b52 Reviewed-on: https://code.wireshark.org/review/3574 Reviewed-by: Michael Mann <mmann78@netscape.net> Petri-Dish: Michael Mann <mmann78@netscape.net> Tested-by: Petri Dish Buildbot <buildbot-no-reply@wireshark.org> Reviewed-by: Anders Broman <a.broman58@gmail.com>
Diffstat (limited to 'epan/dissectors/packet-lpd.c')
-rw-r--r--epan/dissectors/packet-lpd.c83
1 files changed, 48 insertions, 35 deletions
diff --git a/epan/dissectors/packet-lpd.c b/epan/dissectors/packet-lpd.c
index f9a5c4e1a4..ea338667e9 100644
--- a/epan/dissectors/packet-lpd.c
+++ b/epan/dissectors/packet-lpd.c
@@ -34,6 +34,9 @@ void proto_reg_handoff_lpd(void);
static int proto_lpd = -1;
static int hf_lpd_response = -1;
static int hf_lpd_request = -1;
+static int hf_lpd_client_code = -1;
+static int hf_lpd_printer_option = -1;
+static int hf_lpd_response_code = -1;
static gint ett_lpd = -1;
@@ -43,6 +46,28 @@ static gint find_printer_string(tvbuff_t *tvb, int offset);
static dissector_handle_t data_handle;
+/* This information comes from the LPRng HOWTO, which also describes
+ RFC 1179. http://www.astart.com/lprng/LPRng-HOWTO.html */
+static const value_string lpd_client_code[] = {
+ { 1, "LPC: start print / jobcmd: abort" },
+ { 2, "LPR: transfer a printer job / jobcmd: receive control file" },
+ { 3, "LPQ: print short form of queue status / jobcmd: receive data file" },
+ { 4, "LPQ: print long form of queue status" },
+ { 5, "LPRM: remove jobs" },
+ { 6, "LPRng lpc: do control operation" },
+ { 7, "LPRng lpr: transfer a block format print job" },
+ { 8, "LPRng lpc: secure command transfer" },
+ { 9, "LPRng lpq: verbose status information" },
+ { 0, NULL }
+};
+static const value_string lpd_server_code[] = {
+ { 0, "Success: accepted, proceed" },
+ { 1, "Queue not accepting jobs" },
+ { 2, "Queue temporarily full, retry later" },
+ { 3, "Bad job format, do not retry" },
+ { 0, NULL }
+};
+
static void
dissect_lpd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
{
@@ -52,28 +77,6 @@ dissect_lpd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
guint8 code;
gint printer_len;
- /* This information comes from the LPRng HOWTO, which also describes
- RFC 1179. http://www.astart.com/lprng/LPRng-HOWTO.html */
- static const value_string lpd_client_code[] = {
- { 1, "LPC: start print / jobcmd: abort" },
- { 2, "LPR: transfer a printer job / jobcmd: receive control file" },
- { 3, "LPQ: print short form of queue status / jobcmd: receive data file" },
- { 4, "LPQ: print long form of queue status" },
- { 5, "LPRM: remove jobs" },
- { 6, "LPRng lpc: do control operation" },
- { 7, "LPRng lpr: transfer a block format print job" },
- { 8, "LPRng lpc: secure command transfer" },
- { 9, "LPRng lpq: verbose status information" },
- { 0, NULL }
- };
- static const value_string lpd_server_code[] = {
- { 0, "Success: accepted, proceed" },
- { 1, "Queue not accepting jobs" },
- { 2, "Queue temporarily full, retry later" },
- { 3, "Bad job format, do not retry" },
- { 0, NULL }
- };
-
col_set_str(pinfo->cinfo, COL_PROTOCOL, "LPD");
col_clear(pinfo->cinfo, COL_INFO);
@@ -99,7 +102,6 @@ dissect_lpd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
col_set_str(pinfo->cinfo, COL_INFO, "LPD continuation");
}
- if (tree) {
ti = proto_tree_add_item(tree, proto_lpd, tvb, 0, -1, ENC_NA);
lpd_tree = proto_item_add_subtree(ti, ett_lpd);
@@ -116,11 +118,9 @@ dissect_lpd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
printer_len = find_printer_string(tvb, 1);
if (code <= 9 && printer_len != -1) {
- proto_tree_add_text(lpd_tree, tvb, 0, 1, "%s",
- val_to_str(code, lpd_client_code, "Unknown client code: %u"));
- proto_tree_add_text(lpd_tree, tvb, 1, printer_len,
- "Printer/options: %s",
- tvb_format_text(tvb, 1, printer_len));
+ proto_tree_add_uint_format(lpd_tree, hf_lpd_client_code, tvb, 0, 1, code,
+ "%s", val_to_str(code, lpd_client_code, "Unknown client code: %u"));
+ proto_tree_add_item(lpd_tree, hf_lpd_printer_option, tvb, 1, printer_len, ENC_ASCII|ENC_NA);
}
else {
call_dissector(data_handle,tvb, pinfo, lpd_tree);
@@ -128,8 +128,7 @@ dissect_lpd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
}
else if (lpr_packet_type == response) {
if (code <= 3) {
- proto_tree_add_text(lpd_tree, tvb, 0, 1,
- "Response: %s", val_to_str(code, lpd_server_code, "Unknown server code: %u"));
+ proto_tree_add_item(lpd_tree, hf_lpd_response_code, tvb, 0, 1, ENC_NA);
}
else {
call_dissector(data_handle,tvb, pinfo, lpd_tree);
@@ -138,7 +137,6 @@ dissect_lpd(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree)
else {
call_dissector(data_handle,tvb, pinfo, lpd_tree);
}
- }
}
@@ -163,13 +161,28 @@ proto_register_lpd(void)
static hf_register_info hf[] = {
{ &hf_lpd_response,
{ "Response", "lpd.response",
- FT_BOOLEAN, BASE_NONE, NULL, 0x0,
- "TRUE if LPD response", HFILL }},
+ FT_BOOLEAN, BASE_NONE, NULL, 0x0,
+ "TRUE if LPD response", HFILL }},
{ &hf_lpd_request,
{ "Request", "lpd.request",
- FT_BOOLEAN, BASE_NONE, NULL, 0x0,
- "TRUE if LPD request", HFILL }}
+ FT_BOOLEAN, BASE_NONE, NULL, 0x0,
+ "TRUE if LPD request", HFILL }},
+
+ { &hf_lpd_client_code,
+ { "Client code", "lpd.client_code",
+ FT_UINT8, BASE_DEC, VALS(lpd_client_code), 0x0,
+ NULL, HFILL }},
+
+ { &hf_lpd_printer_option,
+ { "Printer/options", "lpd.printer_option",
+ FT_STRING, BASE_NONE, NULL, 0x0,
+ NULL, HFILL }},
+
+ { &hf_lpd_response_code,
+ { "Response", "lpd.response_code",
+ FT_UINT8, BASE_DEC, VALS(lpd_server_code), 0x0,
+ NULL, HFILL }},
};
static gint *ett[] = {
&ett_lpd,