Only add extra symbols if they are not already exported by this dll.

diff --git a/tools/winebuild/import.c b/tools/winebuild/import.c
index 19cbe2d..b9795ed 100644
--- a/tools/winebuild/import.c
+++ b/tools/winebuild/import.c
@@ -237,15 +237,37 @@
     return off;
 }
 
+/* add a symbol to the extra list, but only if needed */
+static int add_extra_symbol( const char **extras, int *count, const char *name )
+{
+    int i;
+
+    if (!find_symbol( name, undef_symbols, nb_undef_symbols ))
+    {
+        /* check if the symbol is being exported by this dll */
+        for (i = 0; i < nb_entry_points; i++)
+        {
+            ORDDEF *odp = EntryPoints[i];
+            if (odp->type == TYPE_STDCALL ||
+                odp->type == TYPE_CDECL ||
+                odp->type == TYPE_VARARGS ||
+                odp->type == TYPE_EXTERN)
+            {
+                if (!strcmp( odp->name, name )) return 0;
+            }
+        }
+        extras[*count] = name;
+        (*count)++;
+    }
+    return 1;
+}
+
 /* add the extra undefined symbols that will be contained in the generated spec file itself */
 static void add_extra_undef_symbols(void)
 {
     const char *extras[10];
     int i, count = 0, nb_stubs = 0, nb_regs = 0;
-
-#define ADD_SYM(name) \
-    do { if (!find_symbol( extras[count] = (name), undef_symbols, \
-                           nb_undef_symbols )) count++; } while(0)
+    int kernel_imports = 0, ntdll_imports = 0;
 
     sort_symbols( undef_symbols, nb_undef_symbols );
 
@@ -262,33 +284,35 @@
     case SPEC_MODE_DLL:
         break;
     case SPEC_MODE_GUIEXE:
-        ADD_SYM( "GetCommandLineA" );
-        ADD_SYM( "GetStartupInfoA" );
-        ADD_SYM( "GetModuleHandleA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetCommandLineA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetStartupInfoA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetModuleHandleA" );
         /* fall through */
     case SPEC_MODE_CUIEXE:
-        ADD_SYM( "ExitProcess" );
+        kernel_imports += add_extra_symbol( extras, &count, "ExitProcess" );
         break;
     case SPEC_MODE_GUIEXE_UNICODE:
-        ADD_SYM( "GetCommandLineA" );
-        ADD_SYM( "GetStartupInfoA" );
-        ADD_SYM( "GetModuleHandleA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetCommandLineA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetStartupInfoA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetModuleHandleA" );
         /* fall through */
     case SPEC_MODE_CUIEXE_UNICODE:
-        ADD_SYM( "ExitProcess" );
+        kernel_imports += add_extra_symbol( extras, &count, "ExitProcess" );
         break;
     }
     if (nb_delayed)
     {
-       ADD_SYM( "LoadLibraryA" );
-       ADD_SYM( "GetProcAddress" );
+        kernel_imports += add_extra_symbol( extras, &count, "LoadLibraryA" );
+        kernel_imports += add_extra_symbol( extras, &count, "GetProcAddress" );
     }
-    if (nb_regs) ADD_SYM( "__wine_call_from_32_regs" );
-    if (nb_delayed || nb_stubs) ADD_SYM( "RtlRaiseException" );
+    if (nb_regs)
+        ntdll_imports += add_extra_symbol( extras, &count, "__wine_call_from_32_regs" );
+    if (nb_delayed || nb_stubs)
+        ntdll_imports += add_extra_symbol( extras, &count, "RtlRaiseException" );
 
     /* make sure we import the dlls that contain these functions */
-    if (SpecMode != SPEC_MODE_DLL || nb_delayed) add_import_dll( "kernel32", 0 );
-    if (nb_delayed || nb_stubs || nb_regs) add_import_dll( "ntdll", 0 );
+    if (kernel_imports) add_import_dll( "kernel32", 0 );
+    if (ntdll_imports) add_import_dll( "ntdll", 0 );
 
     if (count)
     {