summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--debian/changelog14
-rw-r--r--debian/libwiretap14t64.symbols2
-rw-r--r--debian/patches/0001-wslua-Fix-support-for-Lua-5.1-and-5.2-on-32bit.patch699
-rw-r--r--debian/patches/series1
4 files changed, 16 insertions, 700 deletions
diff --git a/debian/changelog b/debian/changelog
index 12894d9f..596a0d50 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,17 @@
+wireshark (4.2.5-1) unstable; urgency=medium
+
+ * New upstream version:
+ - security fixes:
+ - MONGO and ZigBee TLV dissector infinite loops (CVE-2024-4854)
+ - The editcap command line utility could crash when chopping bytes
+ from the beginning of a packet. (CVE-2024-4853)
+ - The editcap command line utility could crash when injecting secrets
+ while writing multiple files (CVE-2024-4855)
+ * debian/patches: Drop cherry picked patch already integrated upstream
+ * Update symbols files
+
+ -- Balint Reczey <balint@balintreczey.hu> Thu, 16 May 2024 21:07:29 +0200
+
wireshark (4.2.4-1) unstable; urgency=medium
[ Martin Bagge ]
diff --git a/debian/libwiretap14t64.symbols b/debian/libwiretap14t64.symbols
index a280d013..4d25d71b 100644
--- a/debian/libwiretap14t64.symbols
+++ b/debian/libwiretap14t64.symbols
@@ -49,6 +49,8 @@ libwiretap.so.14 libwiretap14t64 #MINVER#
wtap_block_add_uint64_option@Base 2.1.2
wtap_block_add_uint8_option@Base 2.1.2
wtap_block_array_free@Base 2.1.2
+ wtap_block_array_ref@Base 4.2.5
+ wtap_block_array_unref@Base 4.2.5
wtap_block_copy@Base 2.1.2
wtap_block_count_option@Base 3.5.0
wtap_block_create@Base 2.1.2
diff --git a/debian/patches/0001-wslua-Fix-support-for-Lua-5.1-and-5.2-on-32bit.patch b/debian/patches/0001-wslua-Fix-support-for-Lua-5.1-and-5.2-on-32bit.patch
deleted file mode 100644
index 3bb35ff8..00000000
--- a/debian/patches/0001-wslua-Fix-support-for-Lua-5.1-and-5.2-on-32bit.patch
+++ /dev/null
@@ -1,699 +0,0 @@
-From f8fd960cb8f5378c8ab6b20b4bc7f0b73498d057 Mon Sep 17 00:00:00 2001
-From: Balint Reczey <balint@balintreczey.hu>
-Date: Sat, 20 Apr 2024 18:57:17 +0200
-Subject: [PATCH] wslua: Fix support for Lua 5.1 and 5.2 on 32bit
-MIME-Version: 1.0
-Content-Type: text/plain; charset=UTF-8
-Content-Transfer-Encoding: 8bit
-
-Add macros to use lua_pushnumber for Lua 5.1/5.2 and lua_pushinteger for Lua 5.3/5.4
-based on change proposal by Stig Bjørlykke.
-
-Ping #10881
-
-Follow up for commit 8cac5932f79b87deda26480769a266ff344036e6.
-
-Co-authored-by: Stig Bjørlykke <stig@bjorlykke.org>
----
- epan/wslua/init_wslua.c | 10 +++---
- epan/wslua/lrexlib/pcre2/lpcre2.c | 2 +-
- epan/wslua/make-taps.py | 24 +++++++-------
- epan/wslua/wslua.h | 7 +++++
- epan/wslua/wslua_byte_array.c | 12 +++----
- epan/wslua/wslua_dissector.c | 4 +--
- epan/wslua/wslua_field.c | 12 +++----
- epan/wslua/wslua_file.c | 6 ++--
- epan/wslua/wslua_file_handler.c | 8 ++---
- epan/wslua/wslua_frame_info.c | 8 ++---
- epan/wslua/wslua_pinfo.c | 2 +-
- epan/wslua/wslua_pref.c | 4 +--
- epan/wslua/wslua_struct.c | 10 +++---
- epan/wslua/wslua_tree.c | 6 ++--
- epan/wslua/wslua_tvb.c | 52 +++++++++++++++----------------
- epan/wslua/wslua_wtap.c | 10 +++---
- 16 files changed, 92 insertions(+), 85 deletions(-)
-
---- a/epan/wslua/init_wslua.c
-+++ b/epan/wslua/init_wslua.c
-@@ -969,7 +969,7 @@
- lua_getglobal(L, table);
- /* Set symbol in table. */
- lua_pushstring(L, name);
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
- lua_settable(L, -3);
- /* Pop table from stack. */
- lua_pop(L, 1);
-@@ -979,7 +979,7 @@
- add_global_symbol(const char *name, int value)
- {
- /* Set symbol in global environment. */
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
- lua_setglobal(L, name);
- }
-
-@@ -988,7 +988,7 @@
- {
- lua_getglobal(L, WSLUA_EXPERT_TABLE);
- lua_getfield(L, -1, WSLUA_EXPERT_SEVERITY_TABLE);
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
- lua_setfield(L, -2, name);
- lua_pop(L, 2);
- }
-@@ -998,7 +998,7 @@
- {
- lua_getglobal(L, WSLUA_EXPERT_TABLE);
- lua_getfield(L, -1, WSLUA_EXPERT_GROUP_TABLE);
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
- lua_setfield(L, -2, name);
- lua_pop(L, 2);
- }
-@@ -1007,7 +1007,7 @@
- add_menu_group_symbol(const char *name, int value)
- {
- /* Set symbol in global environment. */
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
- char *str = g_strdup(name);
- char *s = strstr(str, "_GROUP_");
- if (s == NULL)
---- a/epan/wslua/lrexlib/pcre2/lpcre2.c
-+++ b/epan/wslua/lrexlib/pcre2/lpcre2.c
-@@ -432,7 +432,7 @@
- #define SET_INFO_FIELD(L,ud,what,name,valtype) { \
- valtype val; \
- if (0 == pcre2_pattern_info (ud->pr, what, &val)) { \
-- lua_pushinteger (L, val); \
-+ WSLUA_PUSHINTEGER (L, val); \
- lua_setfield (L, -2, name); \
- } \
- }
---- a/epan/wslua/make-taps.py
-+++ b/epan/wslua/make-taps.py
-@@ -34,18 +34,18 @@
- types = {
- 'gchar[]': 'lua_pushstring(L,(const char*)v->STR);',
- 'gchar*': 'lua_pushstring(L,(const char*)v->STR);',
-- 'guint': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'guint8': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'guint16': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'guint32': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'gint': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'gint8': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'gint16': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-- 'gint32': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-+ 'guint': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'guint8': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'guint16': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'guint32': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'gint': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'gint8': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'gint16': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
-+ 'gint32': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
- 'gboolean': 'lua_pushboolean(L,(int)v->STR);',
- 'address': '{ Address a = (Address)g_malloc(sizeof(address)); copy_address(a, &(v->STR)); pushAddress(L,a); }',
- 'address*': '{ Address a = (Address)g_malloc(sizeof(address)); copy_address(a, v->STR); pushAddress(L,a); }',
-- 'int': 'lua_pushinteger(L,(lua_Integer)v->STR);',
-+ 'int': 'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR);',
- 'nstime_t': 'lua_pushnumber(L,(lua_Number)nstime_to_sec(&(v->STR)));',
- 'nstime_t*': 'lua_pushnumber(L,(lua_Number)nstime_to_sec(v->STR));',
- }
-@@ -79,7 +79,7 @@
- for enum in enum_types:
- m = re.search(fr'typedef\s+enum[^{{]*{{([^}}]*)}}[\s\n]*{enum}[\s\n]*;', buf, flags=re.DOTALL)
- if m:
-- types[enum] = f'lua_pushinteger(L,(lua_Integer)v->STR); /* {enum} */'
-+ types[enum] = f'WSLUA_PUSHINTEGER_WITH_CAST(L,v->STR); /* {enum} */'
- econsts = m.group(1).splitlines()
- econsts = [re.sub(r'\s+', '', item) for item in econsts]
- econsts = [re.sub(',', '', item) for item in econsts]
-@@ -183,9 +183,9 @@
- c_body += f'\n\t/*\n\t * {enum}\n\t */\n\tlua_newtable(L);\n'
- for econst in enums[enum]:
- c_body += f'''\
-- lua_pushinteger(L,(lua_Integer){econst});
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,{econst});
- lua_setglobal(L,"{econst}");
-- lua_pushinteger(L,(lua_Integer){econst});
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,{econst});
- lua_pushstring(L,"{econst}");
- lua_settable(L,-3);
- '''
---- a/epan/wslua/wslua.h
-+++ b/epan/wslua/wslua.h
-@@ -81,6 +81,13 @@
- #define wslua_optguint32(L,i,d) (guint32) ( luaL_optnumber(L,i,d) )
- #define wslua_optguint64(L,i,d) (guint64) ( luaL_optnumber(L,i,d) )
-
-+#if LUA_VERSION_NUM < 503
-+#define WSLUA_PUSHINTEGER(L, i) lua_pushnumber(L, i)
-+#define WSLUA_PUSHINTEGER_WITH_CAST(L, i) lua_pushnumber(L, (lua_Number)i)
-+#else
-+#define WSLUA_PUSHINTEGER(L, i) lua_pushinteger(L, i)
-+#define WSLUA_PUSHINTEGER_WITH_CAST(L, i) lua_pushinteger(L, (lua_Integer)i)
-+#endif
-
- struct _wslua_tvb {
- tvbuff_t* ws_tvb;
---- a/epan/wslua/wslua_byte_array.c
-+++ b/epan/wslua/wslua_byte_array.c
-@@ -214,7 +214,7 @@
- luaL_argerror(L,2,"index out of range");
- return 0;
- }
-- lua_pushinteger(L,ba->data[idx]);
-+ WSLUA_PUSHINTEGER(L,ba->data[idx]);
-
- WSLUA_RETURN(1); /* The value [0-255] of the byte. */
- }
-@@ -255,7 +255,7 @@
- value |= (guint8)ba->data[offset + i];
- }
-
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
-
- WSLUA_RETURN(1); /* The value of the little endian encoded signed integer beginning at given offset with given length. */
- }
-@@ -337,7 +337,7 @@
- value |= (guint8)ba->data[offset + i];
- }
-
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
-
- WSLUA_RETURN(1); /* The value of the little endian encoded unsigned integer beginning at given offset with given length. */
- }
-@@ -419,7 +419,7 @@
- value |= (guint8)ba->data[offset + i];
- }
-
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
-
- WSLUA_RETURN(1); /* The value of the big endian encoded 32 bit signed integer beginning at given offset with given length. */
- }
-@@ -501,7 +501,7 @@
- value |= (guint8)ba->data[offset + i];
- }
-
-- lua_pushinteger(L, value);
-+ WSLUA_PUSHINTEGER(L, value);
-
- WSLUA_RETURN(1); /* The value of the big endian encoded 32 bit unsigned integer beginning at given offset with given length. */
- }
-@@ -551,7 +551,7 @@
- /* Obtain the length of a <<lua_class_ByteArray,`ByteArray`>>. */
- ByteArray ba = checkByteArray(L,1);
-
-- lua_pushinteger(L,(lua_Integer)ba->len);
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,ba->len);
-
- WSLUA_RETURN(1); /* The length of the <<lua_class_ByteArray,`ByteArray`>>. */
- }
---- a/epan/wslua/wslua_dissector.c
-+++ b/epan/wslua/wslua_dissector.c
-@@ -107,7 +107,7 @@
- are normal conditions and possibly don't need the Lua traceback. */
- if (error) { WSLUA_ERROR(Dissector_call,error); }
-
-- lua_pushinteger(L,(lua_Integer)len);
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,len);
- WSLUA_RETURN(1); /* Number of bytes dissected. Note that some dissectors always return number of bytes in incoming buffer, so be aware. */
- }
-
-@@ -618,7 +618,7 @@
-
- if (error) { WSLUA_ERROR(DissectorTable_try,error); }
-
-- lua_pushinteger(L,(lua_Integer)len);
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,len);
- WSLUA_RETURN(1); /* Number of bytes dissected. Note that some dissectors always return number of bytes in incoming buffer, so be aware. */
- }
-
---- a/epan/wslua/wslua_field.c
-+++ b/epan/wslua/wslua_field.c
-@@ -50,7 +50,7 @@
- */
- FieldInfo fi = checkFieldInfo(L,1);
-
-- lua_pushinteger(L,fi->ws_fi->length);
-+ WSLUA_PUSHINTEGER(L,fi->ws_fi->length);
- return 1;
- }
-
-@@ -61,7 +61,7 @@
- */
- FieldInfo fi = checkFieldInfo(L,1);
-
-- lua_pushinteger(L,fi->ws_fi->start);
-+ WSLUA_PUSHINTEGER(L,fi->ws_fi->start);
- return 1;
- }
-
-@@ -91,13 +91,13 @@
- case FT_UINT24:
- case FT_UINT32:
- case FT_FRAMENUM:
-- lua_pushinteger(L,(lua_Integer)(fvalue_get_uinteger(fi->ws_fi->value)));
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,(fvalue_get_uinteger(fi->ws_fi->value)));
- return 1;
- case FT_INT8:
- case FT_INT16:
- case FT_INT24:
- case FT_INT32:
-- lua_pushinteger(L,(lua_Integer)(fvalue_get_sinteger(fi->ws_fi->value)));
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,(fvalue_get_sinteger(fi->ws_fi->value)));
- return 1;
- case FT_FLOAT:
- case FT_DOUBLE:
-@@ -268,7 +268,7 @@
- FieldInfo fi = checkFieldInfo(L,1);
-
- if (fi->ws_fi->hfinfo) {
-- lua_pushinteger(L, fi->ws_fi->hfinfo->type);
-+ WSLUA_PUSHINTEGER(L, fi->ws_fi->hfinfo->type);
- }
- else {
- lua_pushnil(L);
-@@ -710,7 +710,7 @@
- Field f = checkField(L,1);
- header_field_info* hfinfo = NULL;
-
-- GET_HFINFO_MEMBER(lua_pushinteger, type);
-+ GET_HFINFO_MEMBER(WSLUA_PUSHINTEGER, type);
-
- return 1;
- }
---- a/epan/wslua/wslua_file.c
-+++ b/epan/wslua/wslua_file.c
-@@ -152,7 +152,7 @@
- buff[buff_end] = '\0';
-
- if (buff_end > 0 && num_digits > 0 && sscanf(buff, "%lf", &d) == 1) {
-- lua_pushinteger(L, d);
-+ WSLUA_PUSHINTEGER(L, d);
- return 1;
- }
- else {
-@@ -355,7 +355,7 @@
- return 2;
- }
-
-- lua_pushinteger(L, (lua_Integer)(file_tell(f->file)));
-+ lua_pushnumber(L, (lua_Number)(file_tell(f->file)));
- }
- else {
- offset = wtap_dump_file_seek(f->wdh, offset, mode[op], &err);
-@@ -374,7 +374,7 @@
- return 2;
- }
-
-- lua_pushinteger(L, (lua_Integer)(offset));
-+ lua_pushnumber(L, (lua_Number)(offset));
- }
-
- WSLUA_RETURN(1); /* The current file cursor position as a number. */
---- a/epan/wslua/wslua_file_handler.c
-+++ b/epan/wslua/wslua_file_handler.c
-@@ -326,7 +326,7 @@
- fp = push_File(L, wth->random_fh);
- fc = push_CaptureInfo(L, wth, FALSE);
- fi = push_FrameInfo(L, rec, buf);
-- lua_pushinteger(L, (lua_Integer)seek_off);
-+ lua_pushnumber(L, (lua_Number)seek_off);
-
- switch ( lua_pcall(L,4,1,1) ) {
- case 0:
-@@ -474,7 +474,7 @@
-
- INIT_FILEHANDLER_ROUTINE(can_write_encap,WTAP_ERR_UNWRITABLE_ENCAP,NULL,NULL);
-
-- lua_pushinteger(L, encap);
-+ WSLUA_PUSHINTEGER(L, encap);
-
- switch ( lua_pcall(L,1,1,1) ) {
- case 0:
-@@ -842,7 +842,7 @@
- fh->registered = TRUE;
- registered_file_handlers = g_slist_prepend(registered_file_handlers, fh);
-
-- lua_pushinteger(L, fh->file_type);
-+ WSLUA_PUSHINTEGER(L, fh->file_type);
-
- WSLUA_RETURN(1); /* the new type number for this file reader/write */
- }
-@@ -1207,7 +1207,7 @@
- break;\
- } \
- } \
-- lua_pushinteger(L, (lua_Integer)supported_comment_types); \
-+ lua_pushnumber(L, (lua_Number)supported_comment_types); \
- });
- WSLUA_ATTRIBUTE_SET(FileHandler,supported_comment_types, { \
- guint supported_comment_types; \
---- a/epan/wslua/wslua_frame_info.c
-+++ b/epan/wslua/wslua_frame_info.c
-@@ -89,7 +89,7 @@
- g_free(err_info); /* is this right? */
- }
- else lua_pushnil(L);
-- lua_pushinteger(L, err);
-+ WSLUA_PUSHINTEGER(L, err);
- return 3;
- }
-
-@@ -120,7 +120,7 @@
- lua_createtable(L, n_comments, 0);
- for (i = 0; i < n_comments; i++) {
- comment = NULL;
-- lua_pushinteger(L, i+1);
-+ WSLUA_PUSHINTEGER(L, i+1);
- if (WTAP_OPTTYPE_SUCCESS ==
- wtap_block_get_nth_string_option_value(block, OPT_COMMENT, i, &comment)) {
- lua_pushstring(L, comment);
-@@ -371,7 +371,7 @@
- if (!wtap_dump_file_write(fh->wdh, fi->pd, (size_t)(len), &err)) {
- lua_pushboolean(L, FALSE);
- lua_pushfstring(L, "FrameInfoConst write_data() error: %s", g_strerror(err));
-- lua_pushinteger(L, err);
-+ WSLUA_PUSHINTEGER(L, err);
- return 3;
- }
-
-@@ -403,7 +403,7 @@
- lua_createtable(L, n_comments, 0);
- for (i = 0; i < n_comments; i++) {
- comment = NULL;
-- lua_pushinteger(L, i+1);
-+ WSLUA_PUSHINTEGER(L, i+1);
- if (WTAP_OPTTYPE_SUCCESS ==
- wtap_block_get_nth_string_option_value(block, OPT_COMMENT, i, &comment)) {
- lua_pushstring(L, comment);
---- a/epan/wslua/wslua_pinfo.c
-+++ b/epan/wslua/wslua_pinfo.c
-@@ -308,7 +308,7 @@
- if (pinfo->ws_pinfo->match_string) {
- lua_pushstring(L,pinfo->ws_pinfo->match_string);
- } else {
-- lua_pushinteger(L,(lua_Integer)(pinfo->ws_pinfo->match_uint));
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,(pinfo->ws_pinfo->match_uint));
- }
-
- return 1;
---- a/epan/wslua/wslua_pref.c
-+++ b/epan/wslua/wslua_pref.c
-@@ -515,9 +515,9 @@
- if ( g_str_equal(prefs_p->name,name) ) {
- switch (prefs_p->type) {
- case PREF_BOOL: lua_pushboolean(L, prefs_p->value.b); break;
-- case PREF_UINT: lua_pushinteger(L,(lua_Integer)prefs_p->value.u); break;
-+ case PREF_UINT: WSLUA_PUSHINTEGER_WITH_CAST(L,prefs_p->value.u); break;
- case PREF_STRING: lua_pushstring(L,prefs_p->value.s); break;
-- case PREF_ENUM: lua_pushinteger(L,(lua_Integer)prefs_p->value.e); break;
-+ case PREF_ENUM: WSLUA_PUSHINTEGER_WITH_CAST(L,prefs_p->value.e); break;
- case PREF_RANGE:
- {
- char *push_str = range_convert_range(NULL, prefs_p->value.r);
---- a/epan/wslua/wslua_struct.c
-+++ b/epan/wslua/wslua_struct.c
-@@ -410,7 +410,7 @@
- * given endianness and size. If the integer type is signed, this makes
- * the Lua number be +/- correctly as well.
- */
--static lua_Integer getinteger (const gchar *buff, int endian,
-+static lua_Number getinteger (const gchar *buff, int endian,
- int issigned, int size) {
- Uinttype l = 0;
- int i;
-@@ -427,12 +427,12 @@
- }
- }
- if (!issigned)
-- return (lua_Integer)l;
-+ return (lua_Number)l;
- else { /* signed format */
- Uinttype mask = (Uinttype)(~((Uinttype)0)) << (size*8 - 1);
- if (l & mask) /* negative value? */
- l |= mask; /* signal extension */
-- return (lua_Integer)(Inttype)l;
-+ return (lua_Number)(Inttype)l;
- }
- }
-
-@@ -470,8 +470,8 @@
- case 'b': case 'B': case 'h': case 'H':
- case 'l': case 'L': case 'T': case 'i': case 'I': { /* integer types */
- int issigned = g_ascii_islower(opt);
-- lua_Integer res = getinteger(data+pos, h.endian, issigned, (int)size);
-- lua_pushinteger(L, res);
-+ lua_Number res = getinteger(data+pos, h.endian, issigned, (int)size);
-+ WSLUA_PUSHINTEGER(L, res);
- break;
- }
- case 'e': {
---- a/epan/wslua/wslua_tree.c
-+++ b/epan/wslua/wslua_tree.c
-@@ -123,7 +123,7 @@
- item = proto_tree_add_item_ret_int(tree_item->tree, hfid, tvbr->tvb->ws_tvb,
- tvbr->offset, tvbr->len, encoding,
- &ret);
-- lua_pushinteger(L, (lua_Integer)ret);
-+ lua_pushnumber(L, (lua_Number)ret);
- lua_pushinteger(L, tvbr->offset + tvbr->len);
- }
- break;
-@@ -152,7 +152,7 @@
- item = proto_tree_add_item_ret_uint(tree_item-> tree, hfid, tvbr->tvb->ws_tvb,
- tvbr->offset, tvbr->len, encoding,
- &ret);
-- lua_pushinteger(L, (lua_Integer)ret);
-+ lua_pushnumber(L, (lua_Number)ret);
- lua_pushinteger(L, tvbr->offset + tvbr->len);
- }
- break;
-@@ -502,7 +502,7 @@
- switch(type) {
- case FT_PROTOCOL:
- item = proto_tree_add_item(tree_item->tree,hfid,tvbr->tvb->ws_tvb,tvbr->offset,tvbr->len,ENC_NA);
-- lua_pushinteger(L,0);
-+ WSLUA_PUSHINTEGER(L,0);
- lua_insert(L,1);
- break;
- case FT_BOOLEAN:
---- a/epan/wslua/wslua_tvb.c
-+++ b/epan/wslua/wslua_tvb.c
-@@ -135,7 +135,7 @@
- /* Obtain the reported length (length on the network) of a <<lua_class_Tvb,`Tvb`>>. */
- Tvb tvb = checkTvb(L,1);
-
-- lua_pushinteger(L,tvb_reported_length(tvb->ws_tvb));
-+ WSLUA_PUSHINTEGER(L,tvb_reported_length(tvb->ws_tvb));
- WSLUA_RETURN(1); /* The reported length of the <<lua_class_Tvb,`Tvb`>>. */
- }
-
-@@ -143,7 +143,7 @@
- /* Obtain the captured length (amount saved in the capture process) of a <<lua_class_Tvb,`Tvb`>>. */
- Tvb tvb = checkTvb(L,1);
-
-- lua_pushinteger(L,tvb_captured_length(tvb->ws_tvb));
-+ WSLUA_PUSHINTEGER(L,tvb_captured_length(tvb->ws_tvb));
- WSLUA_RETURN(1); /* The captured length of the <<lua_class_Tvb,`Tvb`>>. */
- }
-
-@@ -152,7 +152,7 @@
- Same as captured_len; kept only for backwards compatibility */
- Tvb tvb = checkTvb(L,1);
-
-- lua_pushinteger(L,tvb_captured_length(tvb->ws_tvb));
-+ WSLUA_PUSHINTEGER(L,tvb_captured_length(tvb->ws_tvb));
- WSLUA_RETURN(1); /* The captured length of the <<lua_class_Tvb,`Tvb`>>. */
- }
-
-@@ -163,7 +163,7 @@
- Tvb tvb = checkTvb(L,1);
- int offset = (int) luaL_optinteger(L, Tvb_reported_length_remaining_OFFSET, 0);
-
-- lua_pushinteger(L,tvb_reported_length_remaining(tvb->ws_tvb, offset));
-+ WSLUA_PUSHINTEGER(L,tvb_reported_length_remaining(tvb->ws_tvb, offset));
- WSLUA_RETURN(1); /* The captured length of the <<lua_class_Tvb,`Tvb`>>. */
- }
-
-@@ -210,7 +210,7 @@
- /* Returns the raw offset (from the beginning of the source <<lua_class_Tvb,`Tvb`>>) of a sub <<lua_class_Tvb,`Tvb`>>. */
- Tvb tvb = checkTvb(L,1);
-
-- lua_pushinteger(L,tvb_raw_offset(tvb->ws_tvb));
-+ WSLUA_PUSHINTEGER(L,tvb_raw_offset(tvb->ws_tvb));
- WSLUA_RETURN(1); /* The raw offset of the <<lua_class_Tvb,`Tvb`>>. */
- }
-
-@@ -441,16 +441,16 @@
-
- switch (tvbr->len) {
- case 1:
-- lua_pushinteger(L,tvb_get_guint8(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_guint8(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 2:
-- lua_pushinteger(L,tvb_get_ntohs(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_ntohs(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 3:
-- lua_pushinteger(L,tvb_get_ntoh24(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_ntoh24(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 4:
-- lua_pushinteger(L,tvb_get_ntohl(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_ntohl(tvbr->tvb->ws_tvb,tvbr->offset));
- WSLUA_RETURN(1); /* The unsigned integer value. */
- default:
- luaL_error(L,"TvbRange:uint() does not handle %d byte integers",tvbr->len);
-@@ -474,16 +474,16 @@
- switch (tvbr->len) {
- case 1:
- /* XXX unsigned anyway */
-- lua_pushinteger(L,(lua_Integer)(guint)tvb_get_guint8(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,(guint)tvb_get_guint8(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 2:
-- lua_pushinteger(L,tvb_get_letohs(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_letohs(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 3:
-- lua_pushinteger(L,tvb_get_letoh24(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_letoh24(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 4:
-- lua_pushinteger(L,tvb_get_letohl(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_letohl(tvbr->tvb->ws_tvb,tvbr->offset));
- WSLUA_RETURN(1); /* The unsigned integer value */
- default:
- luaL_error(L,"TvbRange:le_uint() does not handle %d byte integers",tvbr->len);
-@@ -594,16 +594,16 @@
-
- switch (tvbr->len) {
- case 1:
-- lua_pushinteger(L,tvb_get_gint8(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_gint8(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 2:
-- lua_pushinteger(L,tvb_get_ntohis(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_ntohis(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 3:
-- lua_pushinteger(L,tvb_get_ntohi24(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_ntohi24(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 4:
-- lua_pushinteger(L,tvb_get_ntohil(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_ntohil(tvbr->tvb->ws_tvb,tvbr->offset));
- WSLUA_RETURN(1); /* The signed integer value. */
- /*
- * XXX:
-@@ -633,16 +633,16 @@
-
- switch (tvbr->len) {
- case 1:
-- lua_pushinteger(L,tvb_get_gint8(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_gint8(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 2:
-- lua_pushinteger(L,tvb_get_letohis(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_letohis(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 3:
-- lua_pushinteger(L,tvb_get_letohi24(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_letohi24(tvbr->tvb->ws_tvb,tvbr->offset));
- return 1;
- case 4:
-- lua_pushinteger(L,tvb_get_letohil(tvbr->tvb->ws_tvb,tvbr->offset));
-+ WSLUA_PUSHINTEGER(L,tvb_get_letohil(tvbr->tvb->ws_tvb,tvbr->offset));
- WSLUA_RETURN(1); /* The signed integer value. */
- default:
- luaL_error(L,"TvbRange:le_int() does not handle %d byte integers",tvbr->len);
-@@ -1237,13 +1237,13 @@
- }
-
- if (len <= 8) {
-- lua_pushinteger(L,(lua_Integer)(guint)tvb_get_bits8(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len));
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,(guint)tvb_get_bits8(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len));
- return 1;
- } else if (len <= 16) {
-- lua_pushinteger(L,tvb_get_bits16(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len, FALSE));
-+ WSLUA_PUSHINTEGER(L,tvb_get_bits16(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len, FALSE));
- return 1;
- } else if (len <= 32) {
-- lua_pushinteger(L,tvb_get_bits32(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len, FALSE));
-+ WSLUA_PUSHINTEGER(L,tvb_get_bits32(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len, FALSE));
- return 1;
- } else if (len <= 64) {
- pushUInt64(L,tvb_get_bits64(tvbr->tvb->ws_tvb,tvbr->offset*8 + pos, len, FALSE));
-@@ -1334,7 +1334,7 @@
- luaL_error(L,"expired tvb");
- return 0;
- }
-- lua_pushinteger(L,(lua_Integer)tvbr->len);
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,tvbr->len);
- return 1;
- }
-
-@@ -1347,7 +1347,7 @@
- luaL_error(L,"expired tvb");
- return 0;
- }
-- lua_pushinteger(L,(lua_Integer)tvbr->offset);
-+ WSLUA_PUSHINTEGER_WITH_CAST(L,tvbr->offset);
- return 1;
- }
-
---- a/epan/wslua/wslua_wtap.c
-+++ b/epan/wslua/wslua_wtap.c
-@@ -85,7 +85,7 @@
- if (filetype == -1)
- lua_pushnil(LS);
- else
-- lua_pushinteger(LS,filetype);
-+ WSLUA_PUSHINTEGER(LS,filetype);
- WSLUA_RETURN(1); /* The filetype value for the file type with that name, or nil if there is no such file type. */
- }
-
-@@ -96,7 +96,7 @@
- @since 3.2.12, 3.4.4
- */
- lua_Number filetype = wtap_pcap_file_type_subtype();
-- lua_pushinteger(LS,filetype);
-+ WSLUA_PUSHINTEGER(LS,filetype);
- WSLUA_RETURN(1); /* The filetype value for pcap files. */
- }
-
-@@ -107,7 +107,7 @@
- @since 3.2.12, 3.4.4
- */
- lua_Number filetype = wtap_pcap_nsec_file_type_subtype();
-- lua_pushinteger(LS,filetype);
-+ WSLUA_PUSHINTEGER(LS,filetype);
- WSLUA_RETURN(1); /* The filetype value for nanosecond-resolution pcap files. */
- }
-
-@@ -118,7 +118,7 @@
- @since 3.2.12, 3.4.4
- */
- lua_Number filetype = wtap_pcapng_file_type_subtype();
-- lua_pushinteger(LS,filetype);
-+ WSLUA_PUSHINTEGER(LS,filetype);
- WSLUA_RETURN(1); /* The filetype value for pcapng files. */
- }
-
-@@ -148,7 +148,7 @@
- * it.
- */
- lua_pushstring(LS, entry->name);
-- lua_pushinteger(LS, entry->ft);
-+ WSLUA_PUSHINTEGER(LS, entry->ft);
- /*
- * The -3 is the index, relative to the top of the stack, of
- * the table; the two elements on top of it are the ft and
diff --git a/debian/patches/series b/debian/patches/series
index 1a5dfc85..162876e7 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -1,3 +1,2 @@
-0001-wslua-Fix-support-for-Lua-5.1-and-5.2-on-32bit.patch
09_idl2wrs.patch
0004-Use-packaged-JS-and-CSS-resources-instead-of-pulling.patch