1
1
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
4
4
@@ -29,6 +29,8 @@
5
5
* apprentice - make one pass through /etc/magic, learning its secrets.
6
6
*/
@@ -830,8 +830,8 @@ diff -u libmagic.orig/apprentice.c libmagic/apprentice.c
830
830
m->str_flags = swap4(m->str_flags);
831
831
}
832
832
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
835
835
@@ -139,7 +139,7 @@
836
836
/* malloc size is a conservative overestimate; could be
837
837
improved, or at least realloced after conversion. */
@@ -841,6 +841,15 @@ diff -u libmagic.orig/ascmagic.c libmagic/ascmagic.c
841
841
file_oomem(ms, mlen);
842
842
goto done;
843
843
}
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
+
844
853
@@ -211,6 +211,7 @@
845
854
case 0:
846
855
if (file_printf(ms, ", ") == -1)
@@ -860,8 +869,8 @@ diff -u libmagic.orig/ascmagic.c libmagic/ascmagic.c
860
869
return rv;
861
870
}
862
871
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
865
874
@@ -43,7 +43,17 @@
866
875
#include <err.h>
867
876
#endif
@@ -923,8 +932,8 @@ diff -u libmagic.orig/cdf.c libmagic/cdf.c
923
932
(void)fprintf(stderr, "timestamp %s\n", buf);
924
933
} else {
925
934
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
928
937
@@ -35,10 +35,12 @@
929
938
#ifndef _H_CDF_
930
939
#define _H_CDF_
@@ -966,8 +975,8 @@ diff -u libmagic.orig/cdf.h libmagic/cdf.h
966
975
void cdf_swap_header(cdf_header_t *);
967
976
void cdf_unpack_header(cdf_header_t *, char *);
968
977
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
971
980
@@ -96,7 +96,7 @@
972
981
}
973
982
@@ -1026,8 +1035,8 @@ diff -u libmagic.orig/cdf_time.c libmagic/cdf_time.c
1026
1035
static const cdf_timestamp_t tst = 0x01A5E403C2D59C00ULL;
1027
1036
static const char *ref = "Sat Apr 23 01:30:00 1977";
1028
1037
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
1031
1040
@@ -32,6 +32,7 @@
1032
1041
* uncompress(method, old, n, newch) - uncompress old into new,
1033
1042
* using method, return sizeof new
@@ -1189,8 +1198,8 @@ diff -u libmagic.orig/compress.c libmagic/compress.c
1189
1198
- #endif
1190
1199
+ #endif /* if PHP_FILEINFO_UNCOMPRESS */
1191
1200
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
1194
1203
@@ -33,11 +33,9 @@
1195
1204
#ifndef __file_h__
1196
1205
#define __file_h__
@@ -1303,7 +1312,13 @@ diff -u libmagic.orig/file.h libmagic/file.h
1303
1312
protected int file_zmagic(struct magic_set *, int, const char *,
1304
1313
const unsigned char *, size_t);
1305
1314
#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);
1307
1322
protected int file_magicfind(struct magic_set *, const char *, struct mlist *);
1308
1323
protected uint64_t file_signextend(struct magic_set *, struct magic *,
1309
1324
uint64_t);
@@ -1377,22 +1392,24 @@ diff -u libmagic.orig/file.h libmagic/file.h
1377
1392
1378
1393
#if defined(HAVE_MMAP) && defined(HAVE_SYS_MMAN_H) && !defined(QUICK)
1379
1394
#define QUICK
1380
- @@ -533,4 +511,12 @@
1381
- #define FILE_RCSID(id)
1395
+ @@ -531,6 +509,14 @@
1382
1396
#endif
1383
-
1397
+ #else
1398
+ #define FILE_RCSID(id)
1399
+ + #endif
1400
+ +
1384
1401
+ #ifdef PHP_WIN32
1385
1402
+ #define FINFO_LSEEK_FUNC _lseek
1386
1403
+ #define FINFO_READ_FUNC _read
1387
1404
+ #else
1388
1405
+ #define FINFO_LSEEK_FUNC lseek
1389
1406
+ #define FINFO_READ_FUNC read
1390
- + #endif
1391
- +
1407
+ #endif
1408
+
1392
1409
#endif /* __file_h__ */
1393
1410
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
1396
1413
@@ -59,27 +59,21 @@
1397
1414
# define minor(dev) ((dev) & 0xff)
1398
1415
#endif
@@ -1758,8 +1775,8 @@ diff -u libmagic.orig/fsmagic.c libmagic/fsmagic.c
1758
1775
return ret;
1759
1776
}
1760
1777
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
1763
1780
@@ -41,52 +41,42 @@
1764
1781
#if defined(HAVE_WCTYPE_H)
1765
1782
#include <wctype.h>
@@ -1896,7 +1913,7 @@ diff -u libmagic.orig/funcs.c libmagic/funcs.c
1896
1913
if ((ms->flags & MAGIC_DEBUG) != 0)
1897
1914
(void)fprintf(stderr, "zmagic %d\n", m);
1898
1915
goto done;
1899
- @@ -219,12 +221,17 @@
1916
+ @@ -219,16 +221,21 @@
1900
1917
}
1901
1918
1902
1919
/* Check if we have a CDF file */
@@ -1919,6 +1936,11 @@ diff -u libmagic.orig/funcs.c libmagic/funcs.c
1919
1936
1920
1937
/* try soft magic tests */
1921
1938
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);
1922
1944
@@ -296,7 +303,6 @@
1923
1945
1924
1946
return m;
@@ -2047,8 +2069,8 @@ diff -u libmagic.orig/funcs.c libmagic/funcs.c
2047
2069
}
2048
2070
+
2049
2071
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
2052
2074
@@ -25,11 +25,6 @@
2053
2075
* SUCH DAMAGE.
2054
2076
*/
@@ -2391,8 +2413,8 @@ diff -u libmagic.orig/magic.c libmagic/magic.c
2391
2413
public const char *
2392
2414
magic_error(struct magic_set *ms)
2393
2415
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
2396
2418
@@ -87,6 +87,7 @@
2397
2419
2398
2420
const char *magic_getpath(const char *, int);
@@ -2410,15 +2432,15 @@ diff -u libmagic.orig/magic.h libmagic/magic.h
2410
2432
int magic_errno(magic_t);
2411
2433
2412
2434
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 @@
2417
2438
* print.c - debugging printout routines
2418
2439
*/
2440
+
2419
2441
+ #define _GNU_SOURCE
2420
2442
+ #include "php.h"
2421
-
2443
+ +
2422
2444
#include "file.h"
2423
2445
+ #include "cdf.h"
2424
2446
@@ -2430,7 +2452,7 @@ diff -u libmagic.orig/print.c libmagic/print.c
2430
2452
#include <string.h>
2431
2453
#include <stdarg.h>
2432
2454
#include <stdlib.h>
2433
- @@ -43,188 +47 ,28 @@
2455
+ @@ -43,188 +48 ,28 @@
2434
2456
#endif
2435
2457
#include <time.h>
2436
2458
@@ -2631,7 +2653,7 @@ diff -u libmagic.orig/print.c libmagic/print.c
2631
2653
}
2632
2654
2633
2655
protected const char *
2634
- @@ -235,7 +79 ,7 @@
2656
+ @@ -235,7 +80 ,7 @@
2635
2657
struct tm *tm;
2636
2658
2637
2659
if (flags & FILE_T_WINDOWS) {
@@ -2641,8 +2663,8 @@ diff -u libmagic.orig/print.c libmagic/print.c
2641
2663
t = ts.tv_sec;
2642
2664
}
2643
2665
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
2646
2668
@@ -30,7 +30,11 @@
2647
2669
#endif
2648
2670
@@ -2704,8 +2726,8 @@ diff -u libmagic.orig/readcdf.c libmagic/readcdf.c
2704
2726
if (file_printf(ms, "application/CDFV2-corrupt") == -1)
2705
2727
return -1;
2706
2728
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
2709
2731
@@ -48,8 +48,8 @@
2710
2732
private int dophn_exec(struct magic_set *, int, int, int, off_t, int, size_t,
2711
2733
off_t, int *, int);
@@ -2956,8 +2978,8 @@ diff -u libmagic.orig/readelf.c libmagic/readelf.c
2956
2978
2957
2979
if (fstat(fd, &st) == -1) {
2958
2980
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
2961
2983
@@ -44,9 +44,17 @@
2962
2984
typedef uint32_t Elf32_Word;
2963
2985
typedef uint8_t Elf32_Char;
@@ -2977,8 +2999,8 @@ diff -u libmagic.orig/readelf.h libmagic/readelf.h
2977
2999
typedef uint32_t Elf64_Word;
2978
3000
typedef uint8_t Elf64_Char;
2979
3001
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
2982
3004
@@ -41,6 +41,11 @@
2983
3005
#include <stdlib.h>
2984
3006
#include <time.h>
@@ -2991,6 +3013,22 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
2991
3013
2992
3014
private int match(struct magic_set *, struct magic *, uint32_t,
2993
3015
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
+
2994
3032
@@ -132,7 +137,7 @@
2995
3033
struct magic *m = &magic[magindex];
2996
3034
@@ -3113,7 +3151,7 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
3113
3151
}
3114
3152
3115
3153
if (m->flag & INDIR) {
3116
- @@ -1644,9 +1624,6 @@
3154
+ @@ -1644,16 +1624,13 @@
3117
3155
if ((ms->flags & MAGIC_DEBUG) != 0) {
3118
3156
mdebug(offset, (char *)(void *)p,
3119
3157
sizeof(union VALUETYPE));
@@ -3123,7 +3161,32 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
3123
3161
}
3124
3162
}
3125
3163
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;
3127
3190
ms->o.buf = sbuf;
3128
3191
ms->offset = soffset;
3129
3192
if (rv == 1) {
@@ -3139,7 +3202,7 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
3139
3202
}
3140
3203
return rv;
3141
3204
3142
- @@ -1837,6 +1814 ,42 @@
3205
+ @@ -1837,6 +1816 ,42 @@
3143
3206
return file_strncmp(a, b, len, flags);
3144
3207
}
3145
3208
@@ -3182,7 +3245,7 @@ diff -u libmagic.orig/softmagic.c libmagic/softmagic.c
3182
3245
private int
3183
3246
magiccheck(struct magic_set *ms, struct magic *m)
3184
3247
{
3185
- @@ -1996,69 +2009 ,157 @@
3248
+ @@ -1996,69 +2011 ,157 @@
3186
3249
break;
3187
3250
}
3188
3251
case FILE_REGEX: {
0 commit comments