summaryrefslogtreecommitdiff
path: root/app-arch/p7zip/files/p7zip-16.02-darwin.patch
blob: 1c3899f30a5326099a8efff699e193b1d8bc80a5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
--- a/CPP/myWindows/StdAfx.h
+++ b/CPP/myWindows/StdAfx.h
@@ -32,7 +32,7 @@
 #include <errno.h>
 #include <math.h>
 
-#ifdef __NETWARE__
+#if defined(__NETWARE__) || defined(__MACH__)
 #include <sys/types.h>
 #endif
 

https://svnweb.freebsd.org/ports/head/archivers/p7zip/files/patch-CPP_Windows_ErrorMsg.cpp?view=markup&pathrev=458172
This fixes the build with Clang 6.0:

 ../../../../CPP/Windows/ErrorMsg.cpp:24:10: error: case value evaluates to -2147024809, which cannot be narrowed to type 'DWORD' (aka  'unsigned int') [-Wc++11-narrowing]
     case E_INVALIDARG          : txt = "E_INVALIDARG"; break ;
          ^
 ../../../../CPP/Common/MyWindows.h:89:22: note: expanded from macro 'E_INVALIDARG'
 #define E_INVALIDARG ((HRESULT)0x80070057L)
                      ^

The HRESULT cast in the macro causes the value to be read as signed int.
--- a/CPP/Windows/ErrorMsg.cpp
+++ b/CPP/Windows/ErrorMsg.cpp
@@ -15,13 +15,13 @@ UString MyFormatMessage(DWORD errorCode)
 
   switch(errorCode) {
     case ERROR_NO_MORE_FILES   : txt = "No more files"; break ;
-    case E_NOTIMPL             : txt = "E_NOTIMPL"; break ;
-    case E_NOINTERFACE         : txt = "E_NOINTERFACE"; break ;
-    case E_ABORT               : txt = "E_ABORT"; break ;
-    case E_FAIL                : txt = "E_FAIL"; break ;
-    case STG_E_INVALIDFUNCTION : txt = "STG_E_INVALIDFUNCTION"; break ;
-    case E_OUTOFMEMORY         : txt = "E_OUTOFMEMORY"; break ;
-    case E_INVALIDARG          : txt = "E_INVALIDARG"; break ;
+    case (DWORD)(E_NOTIMPL)             : txt = "E_NOTIMPL"; break ;
+    case (DWORD)(E_NOINTERFACE)         : txt = "E_NOINTERFACE"; break ;
+    case (DWORD)(E_ABORT)               : txt = "E_ABORT"; break ;
+    case (DWORD)(E_FAIL)                : txt = "E_FAIL"; break ;
+    case (DWORD)(STG_E_INVALIDFUNCTION) : txt = "STG_E_INVALIDFUNCTION"; break ;
+    case (DWORD)(E_OUTOFMEMORY)         : txt = "E_OUTOFMEMORY"; break ;
+    case (DWORD)(E_INVALIDARG)          : txt = "E_INVALIDARG"; break ;
     case ERROR_DIRECTORY          : txt = "Error Directory"; break ;
     default:
       txt = strerror(errorCode);