|
|
092ea1 |
diff --git a/src/Makefile.am b/src/Makefile.am
|
|
|
092ea1 |
index a9b245d..c7f184d 100644
|
|
|
092ea1 |
--- a/src/Makefile.am
|
|
|
092ea1 |
+++ b/src/Makefile.am
|
|
|
092ea1 |
@@ -17,10 +17,10 @@ MINGWLIBS = -lgnurx -lshlwapi
|
|
|
092ea1 |
else
|
|
|
092ea1 |
MINGWLIBS =
|
|
|
092ea1 |
endif
|
|
|
092ea1 |
-libmagic_la_LIBADD = $(LTLIBOBJS) $(MINGWLIBS)
|
|
|
092ea1 |
+libmagic_la_LIBADD = -lm $(LTLIBOBJS) $(MINGWLIBS)
|
|
|
092ea1 |
|
|
|
092ea1 |
file_SOURCES = file.c seccomp.c
|
|
|
092ea1 |
-file_LDADD = libmagic.la
|
|
|
092ea1 |
+file_LDADD = libmagic.la -lm
|
|
|
092ea1 |
CLEANFILES = magic.h
|
|
|
092ea1 |
EXTRA_DIST = magic.h.in
|
|
|
092ea1 |
HDR= $(top_srcdir)/src/magic.h.in
|
|
|
092ea1 |
diff --git a/src/softmagic.c b/src/softmagic.c
|
|
|
092ea1 |
index 3e76517..57b4677 100644
|
|
|
092ea1 |
--- a/src/softmagic.c
|
|
|
092ea1 |
+++ b/src/softmagic.c
|
|
|
092ea1 |
@@ -37,6 +37,7 @@ FILE_RCSID("@(#)$File: softmagic.c,v 1.259 2018/03/11 01:23:52 christos Exp $")
|
|
|
092ea1 |
|
|
|
092ea1 |
#include "magic.h"
|
|
|
092ea1 |
#include <assert.h>
|
|
|
092ea1 |
+#include <math.h>
|
|
|
092ea1 |
#include <string.h>
|
|
|
092ea1 |
#include <ctype.h>
|
|
|
092ea1 |
#include <stdlib.h>
|
|
|
092ea1 |
@@ -1893,19 +1894,19 @@ magiccheck(struct magic_set *ms, struct magic *m)
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '!':
|
|
|
092ea1 |
- matched = fv != fl;
|
|
|
092ea1 |
+ matched = isunordered(fl, fv) ? 1 : fv != fl;
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '=':
|
|
|
092ea1 |
- matched = fv == fl;
|
|
|
092ea1 |
+ matched = isunordered(fl, fv) ? 0 : fv == fl;
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '>':
|
|
|
092ea1 |
- matched = fv > fl;
|
|
|
092ea1 |
+ matched = isgreater(fv, fl);
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '<':
|
|
|
092ea1 |
- matched = fv < fl;
|
|
|
092ea1 |
+ matched = isless(fv, fl);
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
default:
|
|
|
092ea1 |
@@ -1926,19 +1927,19 @@ magiccheck(struct magic_set *ms, struct magic *m)
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '!':
|
|
|
092ea1 |
- matched = dv != dl;
|
|
|
092ea1 |
+ matched = isunordered(dv, dl) ? 1 : dv != dl;
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '=':
|
|
|
092ea1 |
- matched = dv == dl;
|
|
|
092ea1 |
+ matched = isunordered(dv, dl) ? 0 : dv == dl;
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '>':
|
|
|
092ea1 |
- matched = dv > dl;
|
|
|
092ea1 |
+ matched = isgreater(dv, dl);
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
case '<':
|
|
|
092ea1 |
- matched = dv < dl;
|
|
|
092ea1 |
+ matched = isless(dv, dl);
|
|
|
092ea1 |
break;
|
|
|
092ea1 |
|
|
|
092ea1 |
default:
|