aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStig Bjørlykke <stig@bjorlykke.org>2008-02-08 09:45:36 +0000
committerStig Bjørlykke <stig@bjorlykke.org>2008-02-08 09:45:36 +0000
commit42fe2398b9b51ab73b5815726730e8febe99f82d (patch)
tree42ea4354ef344b6fcd3129bf2d6d021342589357
parent4284906aba309f7b481b7dc54623b593a2186f60 (diff)
Added missing "svn:keywords Id" and "svn:eol-style native" for some
c and h files. svn path=/trunk/; revision=24290
-rw-r--r--asn1/s1ap/packet-s1ap-template.c2
-rw-r--r--epan/dfilter/sttype-function.h2
-rw-r--r--epan/dissectors/packet-bctp.c242
-rw-r--r--epan/dissectors/packet-cigi.c2
-rw-r--r--epan/dissectors/packet-dcp.h2
-rw-r--r--epan/dissectors/packet-drda.c2
-rw-r--r--epan/dissectors/packet-erf.c2
-rw-r--r--epan/dissectors/packet-ncp-sss.c2
-rw-r--r--epan/dissectors/packet-ncp-sss.h2
-rw-r--r--epan/dissectors/packet-telkonet.c2
-rw-r--r--gtk/conversations_ncp.c2
-rw-r--r--gtk/conversations_rsvp.c2
-rw-r--r--gtk/hostlist_rsvp.c2
-rw-r--r--gtk/ncp_stat.c2
-rw-r--r--gtk/scsi_stat.c2
-rw-r--r--update.c704
16 files changed, 490 insertions, 484 deletions
diff --git a/asn1/s1ap/packet-s1ap-template.c b/asn1/s1ap/packet-s1ap-template.c
index 9191dc4f44..703632900f 100644
--- a/asn1/s1ap/packet-s1ap-template.c
+++ b/asn1/s1ap/packet-s1ap-template.c
@@ -2,7 +2,7 @@
* Routines for E-UTRAN S1 Application Protocol (S1AP) packet dissection
* Copyright 2007, Anders Broman <anders.broman@ericsson.com>
*
- * $Id: packet-s1ap-template.c 22778 2007-09-03 16:40:51Z etxrab $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/epan/dfilter/sttype-function.h b/epan/dfilter/sttype-function.h
index 7324e97a9b..d8cfa38b11 100644
--- a/epan/dfilter/sttype-function.h
+++ b/epan/dfilter/sttype-function.h
@@ -1,5 +1,5 @@
/*
- * $Id: sttype-test.h 11400 2004-07-18 00:24:25Z guy $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/epan/dissectors/packet-bctp.c b/epan/dissectors/packet-bctp.c
index 06ef184899..b76082d69d 100644
--- a/epan/dissectors/packet-bctp.c
+++ b/epan/dissectors/packet-bctp.c
@@ -1,121 +1,121 @@
-/*
- * packet-bctp.c
- * Q.1990 BICC bearer control tunnelling protocol
- *
- * (c) 2007, Luis E. Garcia Ontanon <luis.ontanon@gmail.com>
- *
- * $Id: $
- *
- * Wireshark - Network traffic analyzer
- * By Gerald Combs <gerald@wireshark.org>
- * Copyright 1998 Gerald Combs
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- *
- * Ref ITU-T Rec. Q.1990 (07/2001)
- */
-
-#ifdef HAVE_CONFIG_H
-#include "config.h"
-#endif
-
-#include <glib.h>
-#include <epan/packet.h>
-
-#define PNAME "BCTP Q.1990"
-#define PSNAME "BCTP"
-#define PFNAME "bctp"
-
-static int proto_bctp = -1;
-static int hf_bctp_bvei = -1;
-static int hf_bctp_bvi = -1;
-static int hf_bctp_tpei = -1;
-static int hf_bctp_tpi = -1;
-
-static gint ett_bctp = -1;
-static dissector_table_t bctp_dissector_table;
-static dissector_handle_t data_handle;
-static dissector_handle_t text_handle;
-
-/*
-static const range_string tpi_vals[] = {
- {0x00,0x17,"spare (binary encoded protocols)"},
- {0x18,0x1f,"reserved for national use (binary encoded protocols)"},
- {0x20,0x20,"IPBCP (text encoded)"},
- {0x21,0x21,"spare (text encoded protocol)"},
- {0x22,0x22,"not used"},
- {0x23,0x37,"spare (text encoded protocols)"},
- {0x38,0x3f,"reserved for national use (text encoded protocols)"},
- {0,0,NULL}
-};
-*/
-
-static const value_string bvei_vals[] = {
- {0,"No indication"},
- {0,"Version Error Indication, BCTP version not supported"},
- {0,NULL}
-};
-
-
-static void dissect_bctp(tvbuff_t* tvb, packet_info* pinfo, proto_tree* tree) {
- proto_item* pi = proto_tree_add_item(tree, proto_bctp, tvb,0,2, FALSE);
- proto_tree* pt = proto_item_add_subtree(pi,ett_bctp);
- tvbuff_t* sub_tvb = tvb_new_subset(tvb, 2, -1, -1);
- guint8 tpi = tvb_get_guint8(tvb,1) & 0x3f;
-
- proto_tree_add_item(pt, hf_bctp_bvei, tvb,0,2, FALSE);
- proto_tree_add_item(pt, hf_bctp_bvi, tvb,0,2, FALSE);
- proto_tree_add_item(pt, hf_bctp_tpei, tvb,0,2, FALSE);
- proto_tree_add_item(pt, hf_bctp_tpi, tvb,0,2, FALSE);
-
- if ( dissector_try_port(bctp_dissector_table, tpi, sub_tvb, pinfo, tree) ) {
- return;
- } else if (tpi <= 0x22) {
- call_dissector(data_handle,sub_tvb, pinfo, tree);
- } else {
- /* tpi > 0x22 */
- call_dissector(text_handle,sub_tvb, pinfo, tree);
- }
-}
-
-void
-proto_register_bctp (void)
-{
- static hf_register_info hf[] = {
- {&hf_bctp_bvei, {"BVEI", "bctp.bvei", FT_UINT16, BASE_HEX, VALS(bvei_vals), 0x4000, "BCTP Version Error Indicator", HFILL }},
- {&hf_bctp_bvi, {"BVI", "bctp.bvi", FT_UINT16, BASE_HEX, NULL, 0x1F00, "BCTP Version Indicator", HFILL }},
- {&hf_bctp_tpei, {"TPEI", "bctp.tpei", FT_UINT16, BASE_HEX, NULL, 0x0040, "Tunnelled Protocol Error Indicator", HFILL }},
- {&hf_bctp_tpi, {"TPI", "bctp.tpi", FT_UINT16, BASE_HEX, NULL, 0x003F, "Tunnelled Protocol Indicator", HFILL }},
- };
- static gint *ett[] = {
- &ett_bctp
- };
-
- proto_bctp = proto_register_protocol(PNAME, PSNAME, PFNAME);
- proto_register_field_array(proto_bctp, hf, array_length(hf));
- proto_register_subtree_array(ett, array_length(ett));
-
- register_dissector("bctp", dissect_bctp, proto_bctp);
-
- bctp_dissector_table = register_dissector_table("bctp.tpi", "BCTP Tunnelled Protocol Indicator", FT_UINT32, BASE_DEC);
-}
-
-void
-proto_reg_handoff_bctp(void)
-{
- data_handle = find_dissector("data");
- text_handle = find_dissector("data-text-lines");
-}
-
+/*
+ * packet-bctp.c
+ * Q.1990 BICC bearer control tunnelling protocol
+ *
+ * (c) 2007, Luis E. Garcia Ontanon <luis.ontanon@gmail.com>
+ *
+ * $Id$
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * Copyright 1998 Gerald Combs
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ *
+ * Ref ITU-T Rec. Q.1990 (07/2001)
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include <glib.h>
+#include <epan/packet.h>
+
+#define PNAME "BCTP Q.1990"
+#define PSNAME "BCTP"
+#define PFNAME "bctp"
+
+static int proto_bctp = -1;
+static int hf_bctp_bvei = -1;
+static int hf_bctp_bvi = -1;
+static int hf_bctp_tpei = -1;
+static int hf_bctp_tpi = -1;
+
+static gint ett_bctp = -1;
+static dissector_table_t bctp_dissector_table;
+static dissector_handle_t data_handle;
+static dissector_handle_t text_handle;
+
+/*
+static const range_string tpi_vals[] = {
+ {0x00,0x17,"spare (binary encoded protocols)"},
+ {0x18,0x1f,"reserved for national use (binary encoded protocols)"},
+ {0x20,0x20,"IPBCP (text encoded)"},
+ {0x21,0x21,"spare (text encoded protocol)"},
+ {0x22,0x22,"not used"},
+ {0x23,0x37,"spare (text encoded protocols)"},
+ {0x38,0x3f,"reserved for national use (text encoded protocols)"},
+ {0,0,NULL}
+};
+*/
+
+static const value_string bvei_vals[] = {
+ {0,"No indication"},
+ {0,"Version Error Indication, BCTP version not supported"},
+ {0,NULL}
+};
+
+
+static void dissect_bctp(tvbuff_t* tvb, packet_info* pinfo, proto_tree* tree) {
+ proto_item* pi = proto_tree_add_item(tree, proto_bctp, tvb,0,2, FALSE);
+ proto_tree* pt = proto_item_add_subtree(pi,ett_bctp);
+ tvbuff_t* sub_tvb = tvb_new_subset(tvb, 2, -1, -1);
+ guint8 tpi = tvb_get_guint8(tvb,1) & 0x3f;
+
+ proto_tree_add_item(pt, hf_bctp_bvei, tvb,0,2, FALSE);
+ proto_tree_add_item(pt, hf_bctp_bvi, tvb,0,2, FALSE);
+ proto_tree_add_item(pt, hf_bctp_tpei, tvb,0,2, FALSE);
+ proto_tree_add_item(pt, hf_bctp_tpi, tvb,0,2, FALSE);
+
+ if ( dissector_try_port(bctp_dissector_table, tpi, sub_tvb, pinfo, tree) ) {
+ return;
+ } else if (tpi <= 0x22) {
+ call_dissector(data_handle,sub_tvb, pinfo, tree);
+ } else {
+ /* tpi > 0x22 */
+ call_dissector(text_handle,sub_tvb, pinfo, tree);
+ }
+}
+
+void
+proto_register_bctp (void)
+{
+ static hf_register_info hf[] = {
+ {&hf_bctp_bvei, {"BVEI", "bctp.bvei", FT_UINT16, BASE_HEX, VALS(bvei_vals), 0x4000, "BCTP Version Error Indicator", HFILL }},
+ {&hf_bctp_bvi, {"BVI", "bctp.bvi", FT_UINT16, BASE_HEX, NULL, 0x1F00, "BCTP Version Indicator", HFILL }},
+ {&hf_bctp_tpei, {"TPEI", "bctp.tpei", FT_UINT16, BASE_HEX, NULL, 0x0040, "Tunnelled Protocol Error Indicator", HFILL }},
+ {&hf_bctp_tpi, {"TPI", "bctp.tpi", FT_UINT16, BASE_HEX, NULL, 0x003F, "Tunnelled Protocol Indicator", HFILL }},
+ };
+ static gint *ett[] = {
+ &ett_bctp
+ };
+
+ proto_bctp = proto_register_protocol(PNAME, PSNAME, PFNAME);
+ proto_register_field_array(proto_bctp, hf, array_length(hf));
+ proto_register_subtree_array(ett, array_length(ett));
+
+ register_dissector("bctp", dissect_bctp, proto_bctp);
+
+ bctp_dissector_table = register_dissector_table("bctp.tpi", "BCTP Tunnelled Protocol Indicator", FT_UINT32, BASE_DEC);
+}
+
+void
+proto_reg_handoff_bctp(void)
+{
+ data_handle = find_dissector("data");
+ text_handle = find_dissector("data-text-lines");
+}
+
diff --git a/epan/dissectors/packet-cigi.c b/epan/dissectors/packet-cigi.c
index dc062c827a..d08914073f 100644
--- a/epan/dissectors/packet-cigi.c
+++ b/epan/dissectors/packet-cigi.c
@@ -4,7 +4,7 @@
* CIGI - http://cigi.sourceforge.net/
* Copyright (c) 2005 The Boeing Company
*
- * $Id: README.developer 15753 2005-09-10 19:43:41Z guy $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/epan/dissectors/packet-dcp.h b/epan/dissectors/packet-dcp.h
index 77010a00b9..2f66bf3bc6 100644
--- a/epan/dissectors/packet-dcp.h
+++ b/epan/dissectors/packet-dcp.h
@@ -6,7 +6,7 @@
*
* Francesco Fondelli <francesco dot fondelli, gmail dot com>
*
- * $Id: README.developer 11973 2004-09-11 23:10:14Z guy $
+ * $Id$
*
* template taken from packet-udp.c
*
diff --git a/epan/dissectors/packet-drda.c b/epan/dissectors/packet-drda.c
index 52b8de0793..daeee6b105 100644
--- a/epan/dissectors/packet-drda.c
+++ b/epan/dissectors/packet-drda.c
@@ -3,7 +3,7 @@
*
* metatech <metatech@flashmail.com>
*
- * $Id: packet-drda.c 18196 2006-05-21 04:49:01Z sahlberg $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/epan/dissectors/packet-erf.c b/epan/dissectors/packet-erf.c
index 085e89b70c..69a01b9202 100644
--- a/epan/dissectors/packet-erf.c
+++ b/epan/dissectors/packet-erf.c
@@ -1,6 +1,8 @@
/* packet-erf.c
* Routines for ERF encapsulation dissection
*
+ * $Id$
+ *
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
* Copyright 1998 Gerald Combs
diff --git a/epan/dissectors/packet-ncp-sss.c b/epan/dissectors/packet-ncp-sss.c
index 72e3d44bce..0eb319b747 100644
--- a/epan/dissectors/packet-ncp-sss.c
+++ b/epan/dissectors/packet-ncp-sss.c
@@ -4,7 +4,7 @@
* Greg Morris <gmorris@novell.com>
* Copyright (c) Novell, Inc. 2002-2003
*
- * $Id: packet-ncp-sss.c,v 1.00 2003/06/26 11:36:14 guy Exp $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/epan/dissectors/packet-ncp-sss.h b/epan/dissectors/packet-ncp-sss.h
index a88edd8506..b0f261791e 100644
--- a/epan/dissectors/packet-ncp-sss.h
+++ b/epan/dissectors/packet-ncp-sss.h
@@ -3,7 +3,7 @@
* Greg Morris <gmorris@novell.com>
* Copyright (c) Novell, Inc. 2002-2004
*
- * $Id: packet-ncp-sss.h,v 1.0 2004/02/29 08:01:22 guy Exp $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/epan/dissectors/packet-telkonet.c b/epan/dissectors/packet-telkonet.c
index 309c29e7ee..653660e5f0 100644
--- a/epan/dissectors/packet-telkonet.c
+++ b/epan/dissectors/packet-telkonet.c
@@ -1,7 +1,7 @@
/* packet-telkonet.c
* Routines for ethertype 0x88A1 tunneling dissection
*
- * $Id: packet-telkonet.c 18196 2006-05-21 04:49:01Z sahlberg $
+ * $Id$
*
* Copyright 2006 Joerg Mayer (see AUTHORS file)
*
diff --git a/gtk/conversations_ncp.c b/gtk/conversations_ncp.c
index 5479f57f13..d0bd37ea73 100644
--- a/gtk/conversations_ncp.c
+++ b/gtk/conversations_ncp.c
@@ -1,7 +1,7 @@
/* conversations_ncp.c 2005 Greg Morris
* modified from conversations_eth.c 2003 Ronnie Sahlberg
*
- * $Id: conversations_wlan.c 15501 2005-08-21 19:24:11Z guy $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/gtk/conversations_rsvp.c b/gtk/conversations_rsvp.c
index 8e8772c621..70503b50c0 100644
--- a/gtk/conversations_rsvp.c
+++ b/gtk/conversations_rsvp.c
@@ -1,6 +1,8 @@
/* conversations_rsvp.c
* conversations_rsvp.c August 2005, Manu Pathak <mapathak@cisco.com>
*
+ * $Id$
+ *
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
* Copyright 1998 Gerald Combs
diff --git a/gtk/hostlist_rsvp.c b/gtk/hostlist_rsvp.c
index 1a3ceb0def..9168ccf31f 100644
--- a/gtk/hostlist_rsvp.c
+++ b/gtk/hostlist_rsvp.c
@@ -1,6 +1,8 @@
/* hostlist_rsvp.c
* hostlist_rsvp.c August 2005, Manu Pathak <mapathak@cisco.com>
*
+ * $Id$
+ *
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
* Copyright 1998 Gerald Combs
diff --git a/gtk/ncp_stat.c b/gtk/ncp_stat.c
index f3eed24eca..4459f05058 100644
--- a/gtk/ncp_stat.c
+++ b/gtk/ncp_stat.c
@@ -1,7 +1,7 @@
/* ncp_stat.c
* ncp_stat 2005 Greg Morris
*
- * $Id: ncp_stat.c 00000 2005-09-22 11:09:36Z xxx $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/gtk/scsi_stat.c b/gtk/scsi_stat.c
index 53c5104a7b..bc640311f8 100644
--- a/gtk/scsi_stat.c
+++ b/gtk/scsi_stat.c
@@ -1,7 +1,7 @@
/* scsi_stat.c
* scsi_stat 2006 Ronnie Sahlberg
*
- * $Id: scsi_stat.c 17252 2006-02-11 13:05:24Z lego $
+ * $Id$
*
* Wireshark - Network traffic analyzer
* By Gerald Combs <gerald@wireshark.org>
diff --git a/update.c b/update.c
index 05f8dbefee..223ef11b44 100644
--- a/update.c
+++ b/update.c
@@ -1,352 +1,352 @@
-/* update.c
- *
- * $Id: update.c 19935 2006-11-19 23:23:53Z gerald $
- *
- * Wireshark - Network traffic analyzer
- * By Gerald Combs <gerald@wireshark.org>
- * Copyright 1998 Gerald Combs
- *
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2
- * of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
- */
-
-#ifdef HAVE_CONFIG_H
-# include "config.h"
-#endif
-
-#include <glib.h>
-#include <string.h>
-#include <stdio.h>
-
-#include <epan/prefs.h>
-#include <epan/prefs-int.h>
-#include <epan/filesystem.h>
-
-#include "simple_dialog.h"
-#include "version_info.h"
-
-#ifdef HAVE_LIBPCAP
-#include "capture-pcap-util.h"
-#endif
-
-#include "file_util.h"
-
-#include <wininet.h>
-#include "nio-ie5.h"
-
-
-/* update information about a single component */
-typedef struct update_info_s {
- char *prefix; /* prefix of the update file keys */
- gboolean needs_update; /* does this component need an update */
- char *version_installed; /* the version currently installed */
-
- char *title; /* the component title (name) */
- char *description; /* description of the component */
- char *version_recommended; /* the version recommended */
- char *url; /* the URL for an update */
- char *md5; /* md5 checksum for that update */
- char *size; /* size of that update */
-} update_info_t;
-
-
-/* download a complete file from the internet */
-int
-download_file(const char *url, const char *filename) {
- netio_ie5_t * conn;
- char buf[100];
- int chunk_len;
- int fd;
- int stream_len;
- int ret = 0;
-
-
- /* open output file */
- fd = eth_open(filename, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, 0644);
- if(fd == -1) {
- g_warning("Couldn't open output file %s!", filename);
- return -1;
- }
-
- /* connect to url */
- conn = netio_ie5_connect (url);
- if (conn == NULL) {
- g_warning("Couldn't connect to %s!", url);
- return -1;
- }
-
- do {
- /* XXX - maybe add a progress bar here */
-
- /* read some bytes from the url */
- chunk_len = netio_ie5_read (conn, buf, sizeof(buf));
-
- /* write bytes to the output file */
- stream_len = eth_write( fd, buf, chunk_len);
- if(stream_len != chunk_len) {
- g_warning("output failed: stream_len %u != chunk_len %u", stream_len, chunk_len);
- ret = -1;
- break;
- }
- } while(chunk_len > 0);
-
- netio_ie5_disconnect(conn);
-
- eth_close(fd);
-
- return ret;
-}
-
-update_info_t *
-update_info_new(void)
-{
- return g_malloc0(sizeof(update_info_t));
-}
-
-void
-update_info_delete(update_info_t *update_info)
-{
- if(update_info->prefix)
- g_free(update_info->prefix);
- if(update_info->version_installed)
- g_free(update_info->version_installed);
-
- if(update_info->title)
- g_free(update_info->title);
- if(update_info->description)
- g_free(update_info->description);
- if(update_info->version_recommended)
- g_free(update_info->version_recommended);
- if(update_info->url)
- g_free(update_info->url);
- if(update_info->md5)
- g_free(update_info->md5);
- if(update_info->size)
- g_free(update_info->size);
-
- g_free(update_info);
-}
-
-/* check a single key value pair */
-static void
-update_pref_check(gchar *pref_name, gchar *value, char *check_prefix, char *check_name, char **check_value)
-{
- GString *check = g_string_new(check_prefix);
-
- g_string_append(check, check_name);
-
- if(strcmp(pref_name, check->str) == 0) {
- if(*check_value)
- /* there shouldn't be a duplicate entry in the update file */
- g_warning("Duplicate of %s: current %s former %s", pref_name, value, *check_value);
- else
- *check_value = g_strdup(value);
- }
-
- g_string_free(check, TRUE);
-}
-
-/* a new key value pair from the update file */
-static prefs_set_pref_e
-update_pref(gchar *pref_name, gchar *value, void *private_data)
-{
- update_info_t *update_info = private_data;
-
- update_pref_check(pref_name, value, update_info->prefix, "title", &update_info->title);
- update_pref_check(pref_name, value, update_info->prefix, "description", &update_info->description);
- update_pref_check(pref_name, value, update_info->prefix, "version", &update_info->version_recommended);
- update_pref_check(pref_name, value, update_info->prefix, "update.url", &update_info->url);
- update_pref_check(pref_name, value, update_info->prefix, "update.md5", &update_info->md5);
- update_pref_check(pref_name, value, update_info->prefix, "update.size", &update_info->size);
-
- return PREFS_SET_OK;
-}
-
-/* display an update_info */
-static void
-update_info_display(update_info_t *update_info)
-{
- GString *overview;
-
-
- overview = g_string_new("");
-
- if(update_info->title) {
- g_string_append_printf(overview, "%s%s%s",
- simple_dialog_primary_start(), update_info->title, simple_dialog_primary_end());
- } else {
- g_string_append_printf(overview, "%sComponent%s",
- simple_dialog_primary_start(), simple_dialog_primary_end());
- }
-
- g_string_append(overview, "\n\n");
-
- if(update_info->description)
- g_string_append_printf(overview, "%s\n\n", update_info->description);
-
- g_string_append_printf(overview, "Installed: %s\n", update_info->version_installed);
-
- if(update_info->version_recommended)
- g_string_append_printf(overview, "Recommended: %s\n", update_info->version_recommended);
- else
- g_string_append(overview, "Recommenced: unknown\n");
-
- if(update_info->version_recommended && update_info->url)
- g_string_append_printf(overview, "From: %s\n", update_info->url);
-
- if(update_info->size)
- g_string_append_printf(overview, "Size: %s", update_info->size);
-
- simple_dialog(ESD_TYPE_INFO, ESD_BTN_OK, overview->str);
-
- g_string_free(overview, TRUE);
-
-}
-
-/* check the version of the wireshark program */
-static update_info_t *
-update_check_wireshark(const char *local_file)
-{
- FILE *pf;
- update_info_t *update_info = update_info_new();
-
-
- update_info->version_installed = g_strdup(VERSION);
- update_info->prefix = "wireshark.setup.";
-
- pf = eth_fopen(local_file, "r");
- if(pf != NULL) {
- /* read in update_info of Wireshark */
- read_prefs_file(local_file, pf, update_pref, update_info);
- fclose(pf);
-
- /* check if Wireshark needs an update */
- if(update_info->version_installed && update_info->version_recommended &&
- strcmp(update_info->version_installed, update_info->version_recommended) != 0)
- {
- update_info->needs_update = TRUE;
- }
- } else {
- g_warning("Could not open %s", local_file);
- }
-
- return update_info;
-}
-
-/* check the version of winpcap */
-static update_info_t *
-update_check_winpcap(const char *local_file)
-{
- FILE *pf;
- update_info_t * update_info = update_info_new();
- GString *pcap_version_tmp;
- char *pcap_version = NULL;
- char *pcap_vstart;
- char *pcap_vend;
-
-
- update_info->prefix = "winpcap.";
-
- pf = eth_fopen(local_file, "r");
- if(pf != NULL) {
- /* read in update_info of WinPcap */
- read_prefs_file(local_file, pf, update_pref, update_info);
- fclose(pf);
-
- /* get WinPcap version */
- /* XXX - what's the "approved" method to get the WinPcap version? */
- pcap_version_tmp = g_string_new("");
- get_runtime_pcap_version(pcap_version_tmp);
-
- /* cut out real version from "combined" version string */
- pcap_vstart = strstr(pcap_version_tmp->str, "with WinPcap version ");
- if(pcap_vstart != NULL) {
- pcap_vstart += sizeof("with WinPcap version");
- pcap_vend = strstr(pcap_vstart, " ");
- if(pcap_vend != NULL) {
- pcap_vend[0] = 0;
- pcap_version = g_strdup(pcap_vstart);
- }
- }
-
- update_info->version_installed = g_strdup(pcap_version);
-
- if(pcap_version && update_info->version_recommended &&
- strcmp(pcap_version, update_info->version_recommended) != 0)
- {
- update_info->needs_update = TRUE;
- }
- } else {
- g_warning("Could not open %s", local_file);
- }
-
- g_string_free(pcap_version_tmp, TRUE);
- if(pcap_version)
- g_free(pcap_version);
-
- return update_info;
-}
-
-
-/* check for all updates */
-void
-update_check(gboolean interactive)
-{
- char *local_file;
- const char *url_file = "http://127.0.0.1/wsupdate"; /* XXX - build the URL depending on platform, versions, ... */
- update_info_t *update_info_wireshark;
- update_info_t *update_info_winpcap;
-
-
- /* build update file name */
- /* XXX - using the personal path, use temp dir instead? */
- local_file = get_persconffile_path("wsupdate", FALSE, TRUE /*for_writing*/);
- if(local_file == NULL) {
- g_warning("Couldn't create output path!");
- return;
- }
-
- /* download update file */
- if(download_file(url_file, local_file) == -1) {
- g_warning("Couldn't download update file: %s", local_file);
- g_free(local_file);
- return;
- }
-
- /* check wireshark */
- update_info_wireshark = update_check_wireshark(local_file);
-
- /* check winpcap */
- update_info_winpcap = update_check_winpcap(local_file);
-
- /* display results */
- if(update_info_wireshark->needs_update || update_info_winpcap->needs_update) {
- if(update_info_wireshark->needs_update)
- update_info_display(update_info_wireshark);
- if(update_info_winpcap->needs_update)
- update_info_display(update_info_winpcap);
- } else {
- if(interactive) {
- simple_dialog(ESD_TYPE_INFO, ESD_BTN_OK, "No updates available");
- }
- }
-
- /* cleanup */
- update_info_delete(update_info_wireshark);
- update_info_delete(update_info_winpcap);
-
- g_free(local_file);
-}
-
+/* update.c
+ *
+ * $Id$
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * Copyright 1998 Gerald Combs
+ *
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <glib.h>
+#include <string.h>
+#include <stdio.h>
+
+#include <epan/prefs.h>
+#include <epan/prefs-int.h>
+#include <epan/filesystem.h>
+
+#include "simple_dialog.h"
+#include "version_info.h"
+
+#ifdef HAVE_LIBPCAP
+#include "capture-pcap-util.h"
+#endif
+
+#include "file_util.h"
+
+#include <wininet.h>
+#include "nio-ie5.h"
+
+
+/* update information about a single component */
+typedef struct update_info_s {
+ char *prefix; /* prefix of the update file keys */
+ gboolean needs_update; /* does this component need an update */
+ char *version_installed; /* the version currently installed */
+
+ char *title; /* the component title (name) */
+ char *description; /* description of the component */
+ char *version_recommended; /* the version recommended */
+ char *url; /* the URL for an update */
+ char *md5; /* md5 checksum for that update */
+ char *size; /* size of that update */
+} update_info_t;
+
+
+/* download a complete file from the internet */
+int
+download_file(const char *url, const char *filename) {
+ netio_ie5_t * conn;
+ char buf[100];
+ int chunk_len;
+ int fd;
+ int stream_len;
+ int ret = 0;
+
+
+ /* open output file */
+ fd = eth_open(filename, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, 0644);
+ if(fd == -1) {
+ g_warning("Couldn't open output file %s!", filename);
+ return -1;
+ }
+
+ /* connect to url */
+ conn = netio_ie5_connect (url);
+ if (conn == NULL) {
+ g_warning("Couldn't connect to %s!", url);
+ return -1;
+ }
+
+ do {
+ /* XXX - maybe add a progress bar here */
+
+ /* read some bytes from the url */
+ chunk_len = netio_ie5_read (conn, buf, sizeof(buf));
+
+ /* write bytes to the output file */
+ stream_len = eth_write( fd, buf, chunk_len);
+ if(stream_len != chunk_len) {
+ g_warning("output failed: stream_len %u != chunk_len %u", stream_len, chunk_len);
+ ret = -1;
+ break;
+ }
+ } while(chunk_len > 0);
+
+ netio_ie5_disconnect(conn);
+
+ eth_close(fd);
+
+ return ret;
+}
+
+update_info_t *
+update_info_new(void)
+{
+ return g_malloc0(sizeof(update_info_t));
+}
+
+void
+update_info_delete(update_info_t *update_info)
+{
+ if(update_info->prefix)
+ g_free(update_info->prefix);
+ if(update_info->version_installed)
+ g_free(update_info->version_installed);
+
+ if(update_info->title)
+ g_free(update_info->title);
+ if(update_info->description)
+ g_free(update_info->description);
+ if(update_info->version_recommended)
+ g_free(update_info->version_recommended);
+ if(update_info->url)
+ g_free(update_info->url);
+ if(update_info->md5)
+ g_free(update_info->md5);
+ if(update_info->size)
+ g_free(update_info->size);
+
+ g_free(update_info);
+}
+
+/* check a single key value pair */
+static void
+update_pref_check(gchar *pref_name, gchar *value, char *check_prefix, char *check_name, char **check_value)
+{
+ GString *check = g_string_new(check_prefix);
+
+ g_string_append(check, check_name);
+
+ if(strcmp(pref_name, check->str) == 0) {
+ if(*check_value)
+ /* there shouldn't be a duplicate entry in the update file */
+ g_warning("Duplicate of %s: current %s former %s", pref_name, value, *check_value);
+ else
+ *check_value = g_strdup(value);
+ }
+
+ g_string_free(check, TRUE);
+}
+
+/* a new key value pair from the update file */
+static prefs_set_pref_e
+update_pref(gchar *pref_name, gchar *value, void *private_data)
+{
+ update_info_t *update_info = private_data;
+
+ update_pref_check(pref_name, value, update_info->prefix, "title", &update_info->title);
+ update_pref_check(pref_name, value, update_info->prefix, "description", &update_info->description);
+ update_pref_check(pref_name, value, update_info->prefix, "version", &update_info->version_recommended);
+ update_pref_check(pref_name, value, update_info->prefix, "update.url", &update_info->url);
+ update_pref_check(pref_name, value, update_info->prefix, "update.md5", &update_info->md5);
+ update_pref_check(pref_name, value, update_info->prefix, "update.size", &update_info->size);
+
+ return PREFS_SET_OK;
+}
+
+/* display an update_info */
+static void
+update_info_display(update_info_t *update_info)
+{
+ GString *overview;
+
+
+ overview = g_string_new("");
+
+ if(update_info->title) {
+ g_string_append_printf(overview, "%s%s%s",
+ simple_dialog_primary_start(), update_info->title, simple_dialog_primary_end());
+ } else {
+ g_string_append_printf(overview, "%sComponent%s",
+ simple_dialog_primary_start(), simple_dialog_primary_end());
+ }
+
+ g_string_append(overview, "\n\n");
+
+ if(update_info->description)
+ g_string_append_printf(overview, "%s\n\n", update_info->description);
+
+ g_string_append_printf(overview, "Installed: %s\n", update_info->version_installed);
+
+ if(update_info->version_recommended)
+ g_string_append_printf(overview, "Recommended: %s\n", update_info->version_recommended);
+ else
+ g_string_append(overview, "Recommenced: unknown\n");
+
+ if(update_info->version_recommended && update_info->url)
+ g_string_append_printf(overview, "From: %s\n", update_info->url);
+
+ if(update_info->size)
+ g_string_append_printf(overview, "Size: %s", update_info->size);
+
+ simple_dialog(ESD_TYPE_INFO, ESD_BTN_OK, overview->str);
+
+ g_string_free(overview, TRUE);
+
+}
+
+/* check the version of the wireshark program */
+static update_info_t *
+update_check_wireshark(const char *local_file)
+{
+ FILE *pf;
+ update_info_t *update_info = update_info_new();
+
+
+ update_info->version_installed = g_strdup(VERSION);
+ update_info->prefix = "wireshark.setup.";
+
+ pf = eth_fopen(local_file, "r");
+ if(pf != NULL) {
+ /* read in update_info of Wireshark */
+ read_prefs_file(local_file, pf, update_pref, update_info);
+ fclose(pf);
+
+ /* check if Wireshark needs an update */
+ if(update_info->version_installed && update_info->version_recommended &&
+ strcmp(update_info->version_installed, update_info->version_recommended) != 0)
+ {
+ update_info->needs_update = TRUE;
+ }
+ } else {
+ g_warning("Could not open %s", local_file);
+ }
+
+ return update_info;
+}
+
+/* check the version of winpcap */
+static update_info_t *
+update_check_winpcap(const char *local_file)
+{
+ FILE *pf;
+ update_info_t * update_info = update_info_new();
+ GString *pcap_version_tmp;
+ char *pcap_version = NULL;
+ char *pcap_vstart;
+ char *pcap_vend;
+
+
+ update_info->prefix = "winpcap.";
+
+ pf = eth_fopen(local_file, "r");
+ if(pf != NULL) {
+ /* read in update_info of WinPcap */
+ read_prefs_file(local_file, pf, update_pref, update_info);
+ fclose(pf);
+
+ /* get WinPcap version */
+ /* XXX - what's the "approved" method to get the WinPcap version? */
+ pcap_version_tmp = g_string_new("");
+ get_runtime_pcap_version(pcap_version_tmp);
+
+ /* cut out real version from "combined" version string */
+ pcap_vstart = strstr(pcap_version_tmp->str, "with WinPcap version ");
+ if(pcap_vstart != NULL) {
+ pcap_vstart += sizeof("with WinPcap version");
+ pcap_vend = strstr(pcap_vstart, " ");
+ if(pcap_vend != NULL) {
+ pcap_vend[0] = 0;
+ pcap_version = g_strdup(pcap_vstart);
+ }
+ }
+
+ update_info->version_installed = g_strdup(pcap_version);
+
+ if(pcap_version && update_info->version_recommended &&
+ strcmp(pcap_version, update_info->version_recommended) != 0)
+ {
+ update_info->needs_update = TRUE;
+ }
+ } else {
+ g_warning("Could not open %s", local_file);
+ }
+
+ g_string_free(pcap_version_tmp, TRUE);
+ if(pcap_version)
+ g_free(pcap_version);
+
+ return update_info;
+}
+
+
+/* check for all updates */
+void
+update_check(gboolean interactive)
+{
+ char *local_file;
+ const char *url_file = "http://127.0.0.1/wsupdate"; /* XXX - build the URL depending on platform, versions, ... */
+ update_info_t *update_info_wireshark;
+ update_info_t *update_info_winpcap;
+
+
+ /* build update file name */
+ /* XXX - using the personal path, use temp dir instead? */
+ local_file = get_persconffile_path("wsupdate", FALSE, TRUE /*for_writing*/);
+ if(local_file == NULL) {
+ g_warning("Couldn't create output path!");
+ return;
+ }
+
+ /* download update file */
+ if(download_file(url_file, local_file) == -1) {
+ g_warning("Couldn't download update file: %s", local_file);
+ g_free(local_file);
+ return;
+ }
+
+ /* check wireshark */
+ update_info_wireshark = update_check_wireshark(local_file);
+
+ /* check winpcap */
+ update_info_winpcap = update_check_winpcap(local_file);
+
+ /* display results */
+ if(update_info_wireshark->needs_update || update_info_winpcap->needs_update) {
+ if(update_info_wireshark->needs_update)
+ update_info_display(update_info_wireshark);
+ if(update_info_winpcap->needs_update)
+ update_info_display(update_info_winpcap);
+ } else {
+ if(interactive) {
+ simple_dialog(ESD_TYPE_INFO, ESD_BTN_OK, "No updates available");
+ }
+ }
+
+ /* cleanup */
+ update_info_delete(update_info_wireshark);
+ update_info_delete(update_info_winpcap);
+
+ g_free(local_file);
+}
+