X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2f51a9ecc5b9ebd406b6fa8d919793c1d661ec15..a44bfc97ab99de6505d48d8ed52302fee45473ab:/src/makeprog.env.in

diff --git a/src/makeprog.env.in b/src/makeprog.env.in
index d3b1905a34..01b798ca0d 100644
--- a/src/makeprog.env.in
+++ b/src/makeprog.env.in
@@ -1,26 +1,26 @@
 # Make environment for making samples on Unix
 
-# Clears all default suffixes
-.SUFFIXES:	.o .cpp .c .cxx
-
 # The binary program extension, if any, including dots (e.g. '.exe')
 PROGRAM_EXT = @PROGRAM_EXT@
 BIN_PROGRAM = $(PROGRAM)$(PROGRAM_EXT)
-RES_PROGRAM = $(PROGRAM)_resources.o
-RES_PROGRAM_OPT = @RESPROGRAM@
+RES_PROGRAM_OBJ = @RESPROGRAMOBJ@
+BUNDLE = $(BIN_PROGRAM).app/Contents
+
+# NB: see remark in Makefile.in as to why we don't use %.foo: %.bar rules
+.SUFFIXES: .o .c .cpp .cxx .rc _resources.o
+
+.c.o:
+	$(CC) -c $(CFLAGS) $(APPEXTRADEFS) -o $@ $<
 
-# To add resources to the Mac OS X applications
-LIBWX_MACRES = $(top_builddir)/lib/lib@WX_LIBRARY@-$(WX_MAJOR_VERSION_NUMBER).$(WX_MINOR_VERSION_NUMBER).$(WX_RELEASE_NUMBER).r
-LIBWX_MACRESCOMP = $(RESCOMP) $(RESFLAGS) $(LIBWX_MACRES) -o $(BIN_PROGRAM)
+.cpp.o:
+	$(CXX) -c $(CXXFLAGS) $(APPEXTRADEFS) -o $@ $<
 
-.c.o :
-	$(CCC) -c $(CFLAGS) $(APPEXTRADEFS) -o $@ $<
+.cxx.o:
+	$(CXX) -c $(CXXFLAGS) $(APPEXTRADEFS) -o $@ $<
 
-.cpp.o :
-	$(CC) -c $(CPPFLAGS) $(APPEXTRADEFS) -o $@ $<
+.rc_resources.o:
+	$(RESCOMP) -i $< -o $@ $(RESFLAGS)
 
-.cxx.o :
-	$(CC) -c $(CPPFLAGS) $(APPEXTRADEFS) -o $@ $<
 
 # the comment at the end of the next line is needed because otherwise autoconf
 # would remove this line completely - it contains a built-in hack to remove
@@ -30,20 +30,17 @@ VPATH = @PATH_IFS@$(top_srcdir)/$(program_dir) # ':' for autoconf
 # Set defaults from configure
 include $(top_builddir)/src/make.env
 
-all:    $(BIN_PROGRAM) install_dirs install_data
+all:    $(BIN_PROGRAM) @MACOSX_BUNDLE@ install_dirs install_data
 
-$(BIN_PROGRAM):	$(OBJECTS) $(top_builddir)/lib/@WX_TARGET_LIBRARY@ $(RES_PROGRAM_OPT) @LIBWXMACRES@
-	$(CC) $(LDFLAGS) -o $(BIN_PROGRAM) $(OBJECTS) $(LDLIBS) $(LIBRARIES) $(RES_PROGRAM_OPT)
+$(BIN_PROGRAM):	$(OBJECTS) $(top_builddir)/lib/@WX_TARGET_LIBRARY@ $(RES_PROGRAM_OBJ) @LIBWXMACRES@
+	$(CXX) $(LDFLAGS_EXE) -o $@ $(OBJECTS) $(LDLIBS) $(LIBRARIES) $(RES_PROGRAM_OBJ)
 	@LIBWXMACRESCOMP@
 
-$(RES_PROGRAM):  $(PROGRAM).rc
-	$(RESCOMP) $(RCINPUTSWITCH) $(top_srcdir)/$(program_dir)/$(PROGRAM).rc $(RCOUTPUTSWITCH) $(PROGRAM)_resources.o $(RESFLAGS)
-
 install_dirs:
 	@list='$(DATADIRS)'; for p in $$list; do \
 	  mkdir -p $(top_builddir)/$(program_dir)/$$p; \
 	done
-	
+
 install_data:
 	@list='$(DATAFILES)'; for p in $$list; do \
 	  if test ! -s $(top_builddir)/$(program_dir)/$$p; then \
@@ -52,4 +49,31 @@ install_data:
 	done
 
 clean:
-	rm -f $(OBJECTS) $(BIN_PROGRAM)  $(RES_PROGRAM) core
+	rm -f $(OBJECTS) $(DEPFILES) $(BIN_PROGRAM) $(RES_PROGRAM_OBJ) core
+
+#
+# Targets to build a Mac OS X application bundle
+#
+bundle: $(BUNDLE)/MacOS/$(PROGRAM) $(BUNDLE)/Info.plist $(BUNDLE)/PkgInfo $(BUNDLE)/Resources/$(PROGRAM).rsrc $(BUNDLE)/Resources/wxmac.icns
+
+$(BUNDLE)/Info.plist: $(top_srcdir)/src/$(TOOLKITDIR)/Info.plist.in $(top_builddir)/lib/@WX_TARGET_LIBRARY@
+	@$(INSTALL) -d `dirname $@`
+	sed -e "s/IDENTIFIER/`echo $(program_dir) | sed 's,/,.,g'`/" \
+	    -e "s/EXECUTABLE/$(PROGRAM)/" \
+	    -e "s/VERSION/$(WX_MAJOR_VERSION_NUMBER).$(WX_MINOR_VERSION_NUMBER).$(WX_RELEASE_NUMBER)/" $< > $@
+
+$(BUNDLE)/PkgInfo:
+	@$(INSTALL) -d `dirname $@`
+	echo -n "APPL????" > $@
+
+$(BUNDLE)/MacOS/$(PROGRAM): $(OBJECTS) $(top_builddir)/lib/@WX_TARGET_LIBRARY@
+	@$(INSTALL) -d `dirname $@`
+	$(CXX) $(LDFLAGS_EXE) -o $@ $(OBJECTS) $(LDLIBS) $(LIBRARIES)
+
+$(BUNDLE)/Resources/$(PROGRAM).rsrc: $(top_builddir)/lib/@WX_RESOURCES_MACOSX_DATA@
+	@$(INSTALL) -d `dirname $@`
+	cp $< $@
+
+$(BUNDLE)/Resources/wxmac.icns: $(top_srcdir)/src/$(TOOLKITDIR)/wxmac.icns
+	@$(INSTALL) -d `dirname $@`
+	cp $< $@