winegcc: C++ support

Dimitrie O. Paun dpaun at rogers.com
Tue Dec 31 00:14:44 CST 2002


Relative to the previous winegcc patch.

ChangeLog
  Add C++ support & small cleanups.

--- tools/winegcc.c.A0	2002-12-29 02:26:55.000000000 -0500
+++ tools/winegcc.c	2002-12-31 00:55:52.000000000 -0500
@@ -30,14 +30,6 @@
 # include <unistd.h>
 #endif
 
-#ifndef GCC_BIN
-#define GCC_BIN "gcc"
-#endif
-
-#ifndef INCLUDEDIR
-#define INCLUDEDIR "/usr/local/include/wine"
-#endif
-
 void error(const char *s, ...)
 {
     va_list ap;
@@ -54,7 +46,7 @@
 {
     char **gcc_argv;
     int i, j;
-    int linking = 1, verbose = 0, use_static_linking = 0;
+    int linking = 1, verbose = 0, cpp = 0, use_static_linking = 0;
     int use_stdinc = 1, use_stdlib = 1, use_msvcrt = 0, gui_app = 0;
 
     for ( i = 1 ; i < argc ; i++ ) 
@@ -69,13 +61,6 @@
                 case 'M':        /* map file generation */
                     if (argv[i][2] == 0) linking = 0;
                     break;
-                case 'v':        /* verbose */
-                    if (argv[i][2] == 0) verbose = 1;
-                    break;
-		case 'V':
-		    printf("winegcc v0.3\n");
-		    exit(0);
-		    break;
 		case 'm':
 		    if (strcmp("-mno-cygwin", argv[i]) == 0)
 			use_msvcrt = 1;
@@ -93,6 +78,13 @@
                 case 's':
                     if (strcmp("-static", argv[i]) == 0) use_static_linking = 1;
                     break;
+                case 'v':        /* verbose */
+                    if (argv[i][2] == 0) verbose = 1;
+                    break;
+		case 'V':
+		    printf("winegcc v0.3\n");
+		    exit(0);
+		    break;
                 case 'W':
                     if (strncmp("-Wl,", argv[i], 4) == 0)
 		    {
@@ -100,6 +92,9 @@
                             use_static_linking = 1;
                     }
                     break;
+		case 'x':
+		    if (strcmp("-xc++", argv[i]) == 0) cpp = 1;
+		    break;
                 case '-':
                     if (strcmp("-static", argv[i]+1) == 0)
                         use_static_linking = 1;
@@ -117,7 +112,8 @@
     {
 	gcc_argv[i++] = BINDIR "/winewrap";
 	if (gui_app) gcc_argv[i++] = "-mgui";
-	
+
+	if (cpp) gcc_argv[i++] = "-C";	
     	for ( j = 1 ; j < argc ; j++ ) 
     	{
 	    if ( argv[j][0] == '-' )
@@ -140,7 +136,7 @@
     }
     else
     {
-	gcc_argv[i++] = GCC_BIN;
+	gcc_argv[i++] = cpp ? "g++" : "gcc";
 
 	gcc_argv[i++] = "-fshort-wchar";
 	gcc_argv[i++] = "-fPIC";


-- 
Dimi.




More information about the wine-patches mailing list