[CMAKE]
[reactos.git] / gcc.cmake
index 1dc23f2..14e10d6 100644 (file)
--- a/gcc.cmake
+++ b/gcc.cmake
@@ -11,15 +11,18 @@ else()
 link_directories("${REACTOS_SOURCE_DIR}/importlibs" ${REACTOS_BINARY_DIR}/lib/3rdparty/mingw)\r
 set(CMAKE_C_LINK_EXECUTABLE "<CMAKE_C_COMPILER> <FLAGS> <CMAKE_C_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>")\r
 set(CMAKE_CXX_LINK_EXECUTABLE "<CMAKE_CXX_COMPILER> <FLAGS> <CMAKE_CXX_LINK_FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> -lstdc++ -lsupc++ -lgcc -lmingwex -lmingw32 <LINK_LIBRARIES>")\r
-set(CMAKE_EXE_LINKER_FLAGS "-nodefaultlibs -nostdlib -Wl,--enable-auto-image-base -Wl,--kill-at -Wl,-T,${REACTOS_SOURCE_DIR}/global.lds")\r
+set(CMAKE_EXE_LINKER_FLAGS "-nodefaultlibs -nostdlib -Wl,--enable-auto-image-base -Wl,--kill-at")\r
+# -Wl,-T,${REACTOS_SOURCE_DIR}/global.lds\r
 \r
 # Compiler Core\r
 add_definitions(-pipe -fms-extensions)\r
 \r
 set(CMAKE_C_CREATE_SHARED_LIBRARY "<CMAKE_C_COMPILER> <CMAKE_SHARED_LIBRARY_C_FLAGS> <LINK_FLAGS> <CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS> -o <TARGET> <OBJECTS> <LINK_LIBRARIES>")\r
 \r
+set(CMAKE_RC_CREATE_SHARED_LIBRARY "<CMAKE_C_COMPILER> <CMAKE_SHARED_LIBRARY_C_FLAGS> <LINK_FLAGS> <CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS> -o <TARGET> <OBJECTS> <LINK_LIBRARIES>")\r
+\r
 # Debugging (Note: DWARF-4 on 4.5.1 when we ship)\r
-add_definitions(-gdwarf-2 -g2 -femit-struct-debug-detailed=none -feliminate-unused-debug-types)\r
+#add_definitions(-gdwarf-2 -g2 -femit-struct-debug-detailed=none -feliminate-unused-debug-types)\r
 \r
 # Tuning\r
 add_definitions(-march=pentium -mtune=i686)\r
@@ -30,12 +33,13 @@ add_definitions(-Wall -Wno-char-subscripts -Wpointer-arith -Wno-multichar -Wno-e
 # Optimizations\r
 add_definitions(-Os -fno-strict-aliasing -ftracer -momit-leaf-frame-pointer -mpreferred-stack-boundary=2 -fno-set-stack-executable -fno-optimize-sibling-calls)\r
 \r
-# C++ Flags\r
-#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-exceptions -fno-rtti")\r
-\r
 # Macros\r
 macro(set_entrypoint MODULE ENTRYPOINT)\r
-    set(NEW_LINKER_FLAGS "-Wl,-entry,_${ENTRYPOINT}")\r
+    if(${ENTRYPOINT} STREQUAL "0")\r
+        set(NEW_LINKER_FLAGS "-Wl,-entry,0")\r
+    else()\r
+        set(NEW_LINKER_FLAGS "-Wl,-entry,_${ENTRYPOINT}")\r
+    endif()\r
     get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
     if(LINKER_FLAGS)\r
         set(NEW_LINKER_FLAGS "${LINKER_FLAGS} ${NEW_LINKER_FLAGS}")\r
@@ -53,44 +57,49 @@ macro(set_subsystem MODULE SUBSYSTEM)
 endmacro()\r
 \r
 macro(add_importlibs MODULE)\r
-  FOREACH(LIB ${ARGN})\r
+  foreach(LIB ${ARGN})\r
     target_link_libraries(${MODULE} ${LIB}.a)\r
-  ENDFOREACH()\r
+  endforeach()\r
 endmacro()\r
 \r
 macro(set_module_type MODULE TYPE)\r
 \r
-  add_dependencies(${MODULE} builno_header psdk)\r
+    add_dependencies(${MODULE} psdk buildno_header)\r
   \r
-  if(${TYPE} MATCHES nativecui)\r
-    set_subsystem(${MODULE} native)\r
-    set_entrypoint(${MODULE} NtProcessStartup@4)\r
-  endif()\r
-  if(${TYPE} MATCHES win32gui)\r
-    set_subsystem(${MODULE} windows)\r
-    set_entrypoint(${MODULE} WinMainCRTStartup)\r
-  endif()\r
-  if(${TYPE} MATCHES win32cui)\r
-    set_subsystem(${MODULE} console)\r
-    set_entrypoint(${MODULE} mainCRTStartup)\r
-  endif()\r
-  if(${TYPE} MATCHES win32dll)\r
-    target_link_libraries(${MODULE} mingw_dllmain mingw_common)\r
-    set_entrypoint(${MODULE} DllMain@12)\r
-  endif()\r
+    if(${TYPE} MATCHES nativecui)\r
+        set_subsystem(${MODULE} native)\r
+        set_entrypoint(${MODULE} NtProcessStartup@4)\r
+    endif()\r
+    if(${TYPE} MATCHES win32gui)\r
+        set_subsystem(${MODULE} windows)\r
+        set_entrypoint(${MODULE} WinMainCRTStartup)\r
+        if(NOT IS_UNICODE)\r
+            target_link_libraries(${MODULE} mingw_main)\r
+        else()\r
+            target_link_libraries(${MODULE} mingw_wmain)\r
+        endif(NOT IS_UNICODE)\r
+        target_link_libraries(${MODULE} mingw_common)\r
+    endif()\r
+    if(${TYPE} MATCHES win32cui)\r
+        set_subsystem(${MODULE} console)\r
+        set_entrypoint(${MODULE} mainCRTStartup)\r
+        if(NOT IS_UNICODE)\r
+            target_link_libraries(${MODULE} mingw_main)\r
+        else()\r
+            target_link_libraries(${MODULE} mingw_wmain)\r
+        endif(NOT IS_UNICODE)\r
+        target_link_libraries(${MODULE} mingw_common)\r
+    endif()\r
+    if(${TYPE} MATCHES win32dll)\r
+        set_entrypoint(${MODULE} DllMain@12)\r
+    endif()\r
 endmacro()\r
 \r
 endif()\r
 \r
-macro(set_unicode MODULE STATE)\r
-   if(${STATE} MATCHES yes)\r
-       add_definitions(-DUNICODE -D_UNICODE)\r
-       target_link_libraries(${MODULE} mingw_wmain)\r
-   else()\r
-       target_link_libraries(${MODULE} mingw_main)\r
-   endif()\r
-   \r
-  target_link_libraries(${MODULE} mingw_common)\r
+macro(set_unicode)\r
+   add_definitions(-DUNICODE -D_UNICODE)\r
+   set(IS_UNICODE 1)\r
 endmacro()\r
 \r
 # Workaround lack of mingw RC support in cmake\r
@@ -106,20 +115,18 @@ macro(set_rc_compiler)
         set(result_incs "-I${arg} ${result_incs}")\r
     endforeach(arg ${includes})\r
 \r
-    SET(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> ${result_defs} ${result_incs} -i <SOURCE> -O coff -o <OBJECT>")\r
+    set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> ${result_defs} ${result_incs} -i <SOURCE> -O coff -o <OBJECT>")\r
 endmacro()\r
 \r
 #typelib support\r
 macro(ADD_TYPELIB TARGET)\r
-  FOREACH(SOURCE ${ARGN})\r
-    GET_FILENAME_COMPONENT(FILE ${SOURCE} NAME_WE)\r
-    SET(OBJECT ${CMAKE_CURRENT_BINARY_DIR}/${FILE}.tlb)\r
-    ADD_CUSTOM_COMMAND(\r
-      OUTPUT ${OBJECT}\r
-      COMMAND native-widl -I${REACTOS_SOURCE_DIR}/include/dxsdk -I. -I${REACTOS_SOURCE_DIR}/include -I${REACTOS_SOURCE_DIR}/include/psdk -m32 --win32 -t -T ${OBJECT} ${CMAKE_CURRENT_SOURCE_DIR}/${SOURCE}\r
-      DEPENDS native-widl\r
-    )\r
-    LIST(APPEND OBJECTS ${OBJECT})\r
-  ENDFOREACH()\r
-  ADD_CUSTOM_TARGET(${TARGET} ALL DEPENDS ${OBJECTS})\r
-ENDMACRO()\r
+  foreach(SOURCE ${ARGN})\r
+    get_filename_component(FILE ${SOURCE} NAME_WE)\r
+    set(OBJECT ${CMAKE_CURRENT_BINARY_DIR}/${FILE}.tlb)\r
+    add_custom_command(OUTPUT ${OBJECT}\r
+                       COMMAND native-widl -I${REACTOS_SOURCE_DIR}/include/dxsdk -I. -I${REACTOS_SOURCE_DIR}/include -I${REACTOS_SOURCE_DIR}/include/psdk -m32 --win32 -t -T ${OBJECT} ${CMAKE_CURRENT_SOURCE_DIR}/${SOURCE}\r
+                       DEPENDS native-widl)\r
+    list(APPEND OBJECTS ${OBJECT})\r
+  endforeach()\r
+  add_custom_target(${TARGET} ALL DEPENDS ${OBJECTS})\r
+endmacro()\r