Skip to content

Commit a289b37

Browse files
committed
updated libmagic.patch
1 parent ee4b389 commit a289b37

File tree

1 file changed

+111
-48
lines changed

1 file changed

+111
-48
lines changed

ext/fileinfo/libmagic.patch

+111-48
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
diff -u libmagic.orig/apprentice.c libmagic/apprentice.c
2-
--- libmagic.orig/apprentice.c 2013-03-21 18:45:14.000000000 +0100
3-
+++ libmagic/apprentice.c 2013-04-27 13:53:32.175250261 +0200
2+
--- libmagic.orig/apprentice.c Thu Mar 21 18:45:14 2013
3+
+++ libmagic/apprentice.c Fri May 3 15:19:35 2013
44
@@ -29,6 +29,8 @@
55
* apprentice - make one pass through /etc/magic, learning its secrets.
66
*/
@@ -830,8 +830,8 @@ diff -u libmagic.orig/apprentice.c libmagic/apprentice.c
830830
m->str_flags = swap4(m->str_flags);
831831
}
832832
diff -u libmagic.orig/ascmagic.c libmagic/ascmagic.c
833-
--- libmagic.orig/ascmagic.c 2012-10-31 18:03:01.000000000 +0100
834-
+++ libmagic/ascmagic.c 2013-04-08 15:42:57.328298809 +0200
833+
--- libmagic.orig/ascmagic.c Wed Oct 31 18:03:01 2012
834+
+++ libmagic/ascmagic.c Tue Feb 18 18:44:17 2014
835835
@@ -139,7 +139,7 @@
836836
/* malloc size is a conservative overestimate; could be
837837
improved, or at least realloced after conversion. */
@@ -841,6 +841,15 @@ diff -u libmagic.orig/ascmagic.c libmagic/ascmagic.c
841841
file_oomem(ms, mlen);
842842
goto done;
843843
}
844+
@@ -147,7 +147,7 @@
845+
== NULL)
846+
goto done;
847+
if ((rv = file_softmagic(ms, utf8_buf,
848+
- (size_t)(utf8_end - utf8_buf), TEXTTEST, text)) == 0)
849+
+ (size_t)(utf8_end - utf8_buf), 0, TEXTTEST, text)) == 0)
850+
rv = -1;
851+
}
852+
844853
@@ -211,6 +211,7 @@
845854
case 0:
846855
if (file_printf(ms, ", ") == -1)
@@ -860,8 +869,8 @@ diff -u libmagic.orig/ascmagic.c libmagic/ascmagic.c
860869
return rv;
861870
}
862871
diff -u libmagic.orig/cdf.c libmagic/cdf.c
863-
--- libmagic.orig/cdf.c 2013-03-21 18:45:14.000000000 +0100
864-
+++ libmagic/cdf.c 2013-04-08 15:42:57.328298809 +0200
872+
--- libmagic.orig/cdf.c Thu Mar 21 18:45:14 2013
873+
+++ libmagic/cdf.c Sun Apr 7 22:30:22 2013
865874
@@ -43,7 +43,17 @@
866875
#include <err.h>
867876
#endif
@@ -923,8 +932,8 @@ diff -u libmagic.orig/cdf.c libmagic/cdf.c
923932
(void)fprintf(stderr, "timestamp %s\n", buf);
924933
} else {
925934
diff -u libmagic.orig/cdf.h libmagic/cdf.h
926-
--- libmagic.orig/cdf.h 2012-10-31 18:03:01.000000000 +0100
927-
+++ libmagic/cdf.h 2013-04-08 15:42:57.328298809 +0200
935+
--- libmagic.orig/cdf.h Wed Oct 31 18:03:01 2012
936+
+++ libmagic/cdf.h Sun Apr 7 22:30:22 2013
928937
@@ -35,10 +35,12 @@
929938
#ifndef _H_CDF_
930939
#define _H_CDF_
@@ -966,8 +975,8 @@ diff -u libmagic.orig/cdf.h libmagic/cdf.h
966975
void cdf_swap_header(cdf_header_t *);
967976
void cdf_unpack_header(cdf_header_t *, char *);
968977
diff -u libmagic.orig/cdf_time.c libmagic/cdf_time.c
969-
--- libmagic.orig/cdf_time.c 2012-10-31 18:03:01.000000000 +0100
970-
+++ libmagic/cdf_time.c 2013-04-08 15:42:57.328298809 +0200
978+
--- libmagic.orig/cdf_time.c Wed Oct 31 18:03:01 2012
979+
+++ libmagic/cdf_time.c Sun Apr 7 22:30:22 2013
971980
@@ -96,7 +96,7 @@
972981
}
973982

@@ -1026,8 +1035,8 @@ diff -u libmagic.orig/cdf_time.c libmagic/cdf_time.c
10261035
static const cdf_timestamp_t tst = 0x01A5E403C2D59C00ULL;
10271036
static const char *ref = "Sat Apr 23 01:30:00 1977";
10281037
diff -u libmagic.orig/compress.c libmagic/compress.c
1029-
--- libmagic.orig/compress.c 2013-01-06 21:35:43.000000000 +0100
1030-
+++ libmagic/compress.c 2013-04-08 15:42:57.328298809 +0200
1038+
--- libmagic.orig/compress.c Sun Jan 6 21:35:43 2013
1039+
+++ libmagic/compress.c Sun Apr 7 22:30:22 2013
10311040
@@ -32,6 +32,7 @@
10321041
* uncompress(method, old, n, newch) - uncompress old into new,
10331042
* using method, return sizeof new
@@ -1189,8 +1198,8 @@ diff -u libmagic.orig/compress.c libmagic/compress.c
11891198
-#endif
11901199
+#endif /* if PHP_FILEINFO_UNCOMPRESS */
11911200
diff -u libmagic.orig/file.h libmagic/file.h
1192-
--- libmagic.orig/file.h 2013-02-18 16:40:59.000000000 +0100
1193-
+++ libmagic/file.h 2013-04-08 15:42:57.328298809 +0200
1201+
--- libmagic.orig/file.h Mon Feb 18 16:40:59 2013
1202+
+++ libmagic/file.h Tue Feb 18 18:44:17 2014
11941203
@@ -33,11 +33,9 @@
11951204
#ifndef __file_h__
11961205
#define __file_h__
@@ -1303,7 +1312,13 @@ diff -u libmagic.orig/file.h libmagic/file.h
13031312
protected int file_zmagic(struct magic_set *, int, const char *,
13041313
const unsigned char *, size_t);
13051314
#endif
1306-
@@ -443,16 +442,13 @@
1315+
@@ -438,21 +437,18 @@
1316+
unichar **, size_t *, const char **, const char **, const char **);
1317+
protected int file_is_tar(struct magic_set *, const unsigned char *, size_t);
1318+
protected int file_softmagic(struct magic_set *, const unsigned char *, size_t,
1319+
- int, int);
1320+
+ size_t, int, int);
1321+
protected int file_apprentice(struct magic_set *, const char *, int);
13071322
protected int file_magicfind(struct magic_set *, const char *, struct mlist *);
13081323
protected uint64_t file_signextend(struct magic_set *, struct magic *,
13091324
uint64_t);
@@ -1377,22 +1392,24 @@ diff -u libmagic.orig/file.h libmagic/file.h
13771392

13781393
#if defined(HAVE_MMAP) && defined(HAVE_SYS_MMAN_H) && !defined(QUICK)
13791394
#define QUICK
1380-
@@ -533,4 +511,12 @@
1381-
#define FILE_RCSID(id)
1395+
@@ -531,6 +509,14 @@
13821396
#endif
1383-
1397+
#else
1398+
#define FILE_RCSID(id)
1399+
+#endif
1400+
+
13841401
+#ifdef PHP_WIN32
13851402
+#define FINFO_LSEEK_FUNC _lseek
13861403
+#define FINFO_READ_FUNC _read
13871404
+#else
13881405
+#define FINFO_LSEEK_FUNC lseek
13891406
+#define FINFO_READ_FUNC read
1390-
+#endif
1391-
+
1407+
#endif
1408+
13921409
#endif /* __file_h__ */
13931410
diff -u libmagic.orig/fsmagic.c libmagic/fsmagic.c
1394-
--- libmagic.orig/fsmagic.c 2013-03-21 18:45:14.000000000 +0100
1395-
+++ libmagic/fsmagic.c 2013-04-08 15:42:57.328298809 +0200
1411+
--- libmagic.orig/fsmagic.c Thu Mar 21 18:45:14 2013
1412+
+++ libmagic/fsmagic.c Sun Apr 7 22:30:22 2013
13961413
@@ -59,27 +59,21 @@
13971414
# define minor(dev) ((dev) & 0xff)
13981415
#endif
@@ -1758,8 +1775,8 @@ diff -u libmagic.orig/fsmagic.c libmagic/fsmagic.c
17581775
return ret;
17591776
}
17601777
diff -u libmagic.orig/funcs.c libmagic/funcs.c
1761-
--- libmagic.orig/funcs.c 2012-10-31 18:03:01.000000000 +0100
1762-
+++ libmagic/funcs.c 2013-04-08 15:42:57.328298809 +0200
1778+
--- libmagic.orig/funcs.c Wed Oct 31 18:03:01 2012
1779+
+++ libmagic/funcs.c Tue Feb 18 18:44:17 2014
17631780
@@ -41,52 +41,42 @@
17641781
#if defined(HAVE_WCTYPE_H)
17651782
#include <wctype.h>
@@ -1896,7 +1913,7 @@ diff -u libmagic.orig/funcs.c libmagic/funcs.c
18961913
if ((ms->flags & MAGIC_DEBUG) != 0)
18971914
(void)fprintf(stderr, "zmagic %d\n", m);
18981915
goto done;
1899-
@@ -219,12 +221,17 @@
1916+
@@ -219,16 +221,21 @@
19001917
}
19011918

19021919
/* Check if we have a CDF file */
@@ -1919,6 +1936,11 @@ diff -u libmagic.orig/funcs.c libmagic/funcs.c
19191936

19201937
/* try soft magic tests */
19211938
if ((ms->flags & MAGIC_NO_CHECK_SOFT) == 0)
1939+
- if ((m = file_softmagic(ms, ubuf, nb, BINTEST,
1940+
+ if ((m = file_softmagic(ms, ubuf, nb, 0, BINTEST,
1941+
looks_text)) != 0) {
1942+
if ((ms->flags & MAGIC_DEBUG) != 0)
1943+
(void)fprintf(stderr, "softmagic %d\n", m);
19221944
@@ -296,7 +303,6 @@
19231945

19241946
return m;
@@ -2047,8 +2069,8 @@ diff -u libmagic.orig/funcs.c libmagic/funcs.c
20472069
}
20482070
+
20492071
diff -u libmagic.orig/magic.c libmagic/magic.c
2050-
--- libmagic.orig/magic.c 2013-01-11 17:43:09.000000000 +0100
2051-
+++ libmagic/magic.c 2013-04-27 13:53:32.175250261 +0200
2072+
--- libmagic.orig/magic.c Fri Jan 11 17:43:09 2013
2073+
+++ libmagic/magic.c Fri May 3 15:19:35 2013
20522074
@@ -25,11 +25,6 @@
20532075
* SUCH DAMAGE.
20542076
*/
@@ -2391,8 +2413,8 @@ diff -u libmagic.orig/magic.c libmagic/magic.c
23912413
public const char *
23922414
magic_error(struct magic_set *ms)
23932415
diff -u libmagic.orig/magic.h libmagic/magic.h
2394-
--- libmagic.orig/magic.h 2013-03-21 18:52:42.000000000 +0100
2395-
+++ libmagic/magic.h 2013-04-08 15:42:57.328298809 +0200
2416+
--- libmagic.orig/magic.h Thu Mar 21 18:52:42 2013
2417+
+++ libmagic/magic.h Sun Apr 7 22:30:22 2013
23962418
@@ -87,6 +87,7 @@
23972419

23982420
const char *magic_getpath(const char *, int);
@@ -2410,15 +2432,15 @@ diff -u libmagic.orig/magic.h libmagic/magic.h
24102432
int magic_errno(magic_t);
24112433

24122434
diff -u libmagic.orig/print.c libmagic/print.c
2413-
--- libmagic.orig/print.c 2013-03-21 18:45:14.000000000 +0100
2414-
+++ libmagic/print.c 2013-04-27 13:53:32.175250261 +0200
2415-
@@ -28,13 +28,17 @@
2416-
/*
2435+
--- libmagic.orig/print.c Thu Mar 21 18:45:14 2013
2436+
+++ libmagic/print.c Mon Dec 16 23:09:24 2013
2437+
@@ -29,12 +29,17 @@
24172438
* print.c - debugging printout routines
24182439
*/
2440+
24192441
+#define _GNU_SOURCE
24202442
+#include "php.h"
2421-
2443+
+
24222444
#include "file.h"
24232445
+#include "cdf.h"
24242446

@@ -2430,7 +2452,7 @@ diff -u libmagic.orig/print.c libmagic/print.c
24302452
#include <string.h>
24312453
#include <stdarg.h>
24322454
#include <stdlib.h>
2433-
@@ -43,188 +47,28 @@
2455+
@@ -43,188 +48,28 @@
24342456
#endif
24352457
#include <time.h>
24362458

@@ -2631,7 +2653,7 @@ diff -u libmagic.orig/print.c libmagic/print.c
26312653
}
26322654

26332655
protected const char *
2634-
@@ -235,7 +79,7 @@
2656+
@@ -235,7 +80,7 @@
26352657
struct tm *tm;
26362658

26372659
if (flags & FILE_T_WINDOWS) {
@@ -2641,8 +2663,8 @@ diff -u libmagic.orig/print.c libmagic/print.c
26412663
t = ts.tv_sec;
26422664
}
26432665
diff -u libmagic.orig/readcdf.c libmagic/readcdf.c
2644-
--- libmagic.orig/readcdf.c 2012-10-31 18:03:01.000000000 +0100
2645-
+++ libmagic/readcdf.c 2013-04-08 15:42:57.328298809 +0200
2666+
--- libmagic.orig/readcdf.c Wed Oct 31 18:03:01 2012
2667+
+++ libmagic/readcdf.c Sun Apr 7 22:30:22 2013
26462668
@@ -30,7 +30,11 @@
26472669
#endif
26482670

@@ -2704,8 +2726,8 @@ diff -u libmagic.orig/readcdf.c libmagic/readcdf.c
27042726
if (file_printf(ms, "application/CDFV2-corrupt") == -1)
27052727
return -1;
27062728
diff -u libmagic.orig/readelf.c libmagic/readelf.c
2707-
--- libmagic.orig/readelf.c 2013-03-21 18:45:14.000000000 +0100
2708-
+++ libmagic/readelf.c 2013-04-08 15:42:57.328298809 +0200
2729+
--- libmagic.orig/readelf.c Thu Mar 21 18:45:14 2013
2730+
+++ libmagic/readelf.c Sun Apr 7 22:30:22 2013
27092731
@@ -48,8 +48,8 @@
27102732
private int dophn_exec(struct magic_set *, int, int, int, off_t, int, size_t,
27112733
off_t, int *, int);
@@ -2956,8 +2978,8 @@ diff -u libmagic.orig/readelf.c libmagic/readelf.c
29562978

29572979
if (fstat(fd, &st) == -1) {
29582980
diff -u libmagic.orig/readelf.h libmagic/readelf.h
2959-
--- libmagic.orig/readelf.h 2013-03-21 18:45:14.000000000 +0100
2960-
+++ libmagic/readelf.h 2013-03-31 16:57:18.499744030 +0200
2981+
--- libmagic.orig/readelf.h Thu Mar 21 18:45:14 2013
2982+
+++ libmagic/readelf.h Wed Mar 28 15:35:26 2012
29612983
@@ -44,9 +44,17 @@
29622984
typedef uint32_t Elf32_Word;
29632985
typedef uint8_t Elf32_Char;
@@ -2977,8 +2999,8 @@ diff -u libmagic.orig/readelf.h libmagic/readelf.h
29772999
typedef uint32_t Elf64_Word;
29783000
typedef uint8_t Elf64_Char;
29793001
diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
2980-
--- libmagic.orig/softmagic.c 2013-03-21 18:45:14.000000000 +0100
2981-
+++ libmagic/softmagic.c 2013-05-14 11:00:07.044745939 +0200
3002+
--- libmagic.orig/softmagic.c Thu Mar 21 18:45:14 2013
3003+
+++ libmagic/softmagic.c Tue Feb 18 18:44:17 2014
29823004
@@ -41,6 +41,11 @@
29833005
#include <stdlib.h>
29843006
#include <time.h>
@@ -2991,6 +3013,22 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
29913013

29923014
private int match(struct magic_set *, struct magic *, uint32_t,
29933015
const unsigned char *, size_t, size_t, int, int, int, int, int *, int *,
3016+
@@ -69,13 +74,13 @@
3017+
/*ARGSUSED1*/ /* nbytes passed for regularity, maybe need later */
3018+
protected int
3019+
file_softmagic(struct magic_set *ms, const unsigned char *buf, size_t nbytes,
3020+
- int mode, int text)
3021+
+ size_t level, int mode, int text)
3022+
{
3023+
struct mlist *ml;
3024+
int rv, printed_something = 0, need_separator = 0;
3025+
for (ml = ms->mlist[0]->next; ml != ms->mlist[0]; ml = ml->next)
3026+
if ((rv = match(ms, ml->magic, ml->nmagic, buf, nbytes, 0, mode,
3027+
- text, 0, 0, &printed_something, &need_separator,
3028+
+ text, 0, level, &printed_something, &need_separator,
3029+
NULL)) != 0)
3030+
return rv;
3031+
29943032
@@ -132,7 +137,7 @@
29953033
struct magic *m = &magic[magindex];
29963034

@@ -3113,7 +3151,7 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
31133151
}
31143152

31153153
if (m->flag & INDIR) {
3116-
@@ -1644,9 +1624,6 @@
3154+
@@ -1644,16 +1624,13 @@
31173155
if ((ms->flags & MAGIC_DEBUG) != 0) {
31183156
mdebug(offset, (char *)(void *)p,
31193157
sizeof(union VALUETYPE));
@@ -3123,7 +3161,32 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
31233161
}
31243162
}
31253163

3126-
@@ -1717,12 +1694,12 @@
3164+
/* Verify we have enough data to match magic type */
3165+
switch (m->type) {
3166+
case FILE_BYTE:
3167+
- if (nbytes < (offset + 1)) /* should alway be true */
3168+
+ if (nbytes < (offset + 1)) /* should always be true */
3169+
return 0;
3170+
break;
3171+
3172+
@@ -1703,6 +1680,8 @@
3173+
break;
3174+
3175+
case FILE_INDIRECT:
3176+
+ if (offset == 0)
3177+
+ return 0;
3178+
if (nbytes < offset)
3179+
return 0;
3180+
sbuf = ms->o.buf;
3181+
@@ -1710,19 +1689,19 @@
3182+
ms->o.buf = NULL;
3183+
ms->offset = 0;
3184+
rv = file_softmagic(ms, s + offset, nbytes - offset,
3185+
- BINTEST, text);
3186+
+ recursion_level, BINTEST, text);
3187+
if ((ms->flags & MAGIC_DEBUG) != 0)
3188+
fprintf(stderr, "indirect @offs=%u[%d]\n", offset, rv);
3189+
rbuf = ms->o.buf;
31273190
ms->o.buf = sbuf;
31283191
ms->offset = soffset;
31293192
if (rv == 1) {
@@ -3139,7 +3202,7 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
31393202
}
31403203
return rv;
31413204

3142-
@@ -1837,6 +1814,42 @@
3205+
@@ -1837,6 +1816,42 @@
31433206
return file_strncmp(a, b, len, flags);
31443207
}
31453208

@@ -3182,7 +3245,7 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
31823245
private int
31833246
magiccheck(struct magic_set *ms, struct magic *m)
31843247
{
3185-
@@ -1996,69 +2009,157 @@
3248+
@@ -1996,69 +2011,157 @@
31863249
break;
31873250
}
31883251
case FILE_REGEX: {

0 commit comments

Comments
 (0)