#==============================================================================# # # Centralized cross-platform build system # # see for instructions: http://puredata.org/docs/developer/build # # #==============================================================================# CWD := $(shell pwd) cvs_root_dir := $(shell cd $(CWD)/.. && pwd) DESTDIR = $(CWD)/build BUILDLAYOUT_DIR = $(CWD) ## default target all: pd abstractions doc gem externals @echo "Complete build succeeded!" include $(BUILDLAYOUT_DIR)/Makefile.buildlayout #==============================================================================# # # GET VERSIONS FOR RELEVANT SOFTWARE # #==============================================================================# CYCLONE_MAJOR_VERSION := $(shell grep CYCLONE_VERSION \ $(externals_src)/miXed/cyclone/build_counter | cut -d ' ' -f 3 | \ cut -d '"' -f 2) CYCLONE_RELEASE := $(shell grep CYCLONE_RELEASE \ $(externals_src)/miXed/cyclone/build_counter | cut -d ' ' -f 3 | \ cut -d '"' -f 2) CYCLONE_BUILD := $(shell grep CYCLONE_BUILD \ $(externals_src)/miXed/cyclone/build_counter | cut -d ' ' -f 3 | \ cut -d '"' -f 2) CYCLONE_VERSION := $(CYCLONE_MAJOR_VERSION) $(CYCLONE_RELEASE) $(CYCLONE_BUILD) GEM_VERSION := $(shell grep "GEM_VERSION" $(gem_src)/src/Base/GemVersion.h | \ sed -n 's|.*GEM_VERSION = "\(.*\)".*|\1|p') MAXLIB_VERSION := $(shell grep "define VERSION" \ $(externals_src)/maxlib/maxlib.c | cut -d '"' -f 2) OSC_VERSION := $(shell grep "define VERSION" $(externals_src)/OSCx/src/OSC.c | \ cut -d '"' -f 2) PDP_VERSION := $(shell grep PDP_VERSION= $(externals_src)/pdp/configure.ac | \ cut -d '=' -f 2) PIDIP_VERSION := $(shell grep _VERSION= $(externals_src)/pidip/configure.ac | \ cut -d '"' -f 2) PMPD_VERSION := $(shell grep "define VERSION" \ $(externals_src)/pmpd/pmpd.c | cut -d '"' -f 2) TOXY_MAJOR_VERSION := $(shell grep TOXY_VERSION \ $(externals_src)/miXed/toxy/build_counter | cut -d ' ' -f 3 | \ cut -d '"' -f 2) TOXY_RELEASE := $(shell grep TOXY_RELEASE \ $(externals_src)/miXed/toxy/build_counter | cut -d ' ' -f 3 | \ cut -d '"' -f 2) TOXY_BUILD := $(shell grep TOXY_BUILD \ $(externals_src)/miXed/toxy/build_counter | cut -d ' ' -f 3 | \ cut -d '"' -f 2) TOXY_VERSION := $(TOXY_MAJOR_VERSION) $(TOXY_RELEASE) $(TOXY_BUILD) ZEXY_VERSION := $(shell grep VERSION $(externals_src)/zexy/src/zexy.h | \ grep -v _VERSION | cut -d ' ' -f 3 | cut -d '"' -f 2) # these are sent to all of the various Makefiles so that they all copy their # output to the same directory tree DEST_PATHS = BUILDLAYOUT_DIR=$(BUILDLAYOUT_DIR) \ cvs_root_dir=$(cvs_root_dir) \ DESTDIR=$(DESTDIR) \ prefix=$(prefix) \ libpddir=$(libpddir) \ OPT_CFLAGS="$(OPT_CFLAGS)" \ UNAME=$(UNAME) #==============================================================================# # # BUILD TARGETS # #==============================================================================# #------------------------------------------------------------------------------ # abstractions abstractions: #------------------------------------------------------------------------------ # doc doc: #------------------------------------------------------------------------------ # externals externals: $(MAKE) -C $(externals_src) $(DEST_PATHS) #------------------------------------------------------------------------------ # pd ifeq ($(OS_NAME),darwin) PD_CONFIGURE_FLAGS = --enable-jack else ifeq ($(OS_NAME),linux) PD_CONFIGURE_FLAGS = --enable-jack --enable-alsa else PD_CONFIGURE_FLAGS = endif endif PD_BUILD_FLAGS = HAVE_AUTOGEN_SH := $(wildcard $(pd_src)/autogen.sh) # test for the new build system ifeq (autogen.sh, $(findstring autogen.sh,$(HAVE_AUTOGEN_SH))) #----------------------------------------------------------------------------# # new autotools build system pd: set_version cd $(pd_src) \ && ./autogen.sh \ && ./configure $(PD_CONFIGURE_FLAGS) \ && make $(DEST_PATHS) $(PD_BUILD_FLAGS) PD_NAME=Pd pd_install: pd $(MAKE) -C $(pd_src) $(DEST_PATHS) $(PD_BUILD_FLAGS) install install -d $(DESTDIR)$(manualsdir)/$(PD_NAME) install -p $(pd_src)/src/notes.txt $(DESTDIR)$(manualsdir)/$(PD_NAME) else #----------------------------------------------------------------------------# # old build system PD_AUTOCONF = autoconf $(pd_src)/src/configure: $(pd_src)/src/configure.in cd $(pd_src)/src/ && \ if [ -f acinclude.m4 ] ; then aclocal ; fi && \ $(PD_AUTOCONF) && \ if grep -q AC_CONFIG_HEADERS configure.in ; then autoheader ; fi # this is not used yet because MinGW doesn't use ./configure && make yet #$(pd_src)/src/makefile: $(pd_src)/src/makefile.in # cd $(pd_src)/src/ && ./configure $(PD_CONFIGURE_FLAGS) # this line has the "-" to support the current makefile.mingw hack pd: $(pd_src)/src/configure set_version -cd $(pd_src)/src && ./configure $(PD_CONFIGURE_FLAGS) && \ make OPT_CFLAGS="" depend && \ make $(DEST_PATHS) $(PD_BUILD_FLAGS) PD_NAME=Pd pd_install: pd $(MAKE) -C $(pd_src)/src $(DEST_PATHS) $(PD_BUILD_FLAGS) install install -d $(DESTDIR)$(manualsdir)/$(PD_NAME) install -p $(pd_src)/src/notes.txt $(DESTDIR)$(manualsdir)/$(PD_NAME) endif #==============================================================================# # # INSTALL TARGETS # #==============================================================================# # this is used for installing into a pre-build Pd binary extended_install: abstractions_install doc_install \ gem_install externals_install readme_install welcome_install \ license_install noncvs_install #------------------------------------------------------------------------------ # install install: pd_install extended_install @echo "Complete install succeeded!" #------------------------------------------------------------------------------ # install_devel devel_install: pd_devel_install @echo "Complete install succeeded!" #------------------------------------------------------------------------------ # abstractions_install abstractions_install: $(MAKE) -C $(abstractions_src) $(DEST_PATHS) install #------------------------------------------------------------------------------ # doc_install doc_install: $(MAKE) -C $(doc_src) $(DEST_PATHS) install #------------------------------------------------------------------------------ # extensions_install extensions_install: $(MAKE) -C $(extensions_src) $(DEST_PATHS) install #------------------------------------------------------------------------------ # externals_install externals_install: $(MAKE) -C $(externals_src) $(DEST_PATHS) install #------------------------------------------------------------------------------ # gem_install GEM_NAME = Gem $(gem_src)/src/configure: cd $(gem_src)/src && ./autogen.sh $(gem_src)/src/Gem.dll: $(gem_src)/src/configure $(gem_src)/src/Gem.pd_linux: $(gem_src)/src/configure cd $(gem_src)/src && ./configure \ --with-pd=$(pd_src) $(MAKE) -C $(gem_src)/src $(gem_src)/src/Gem.pd_darwin: $(gem_src)/src/configure cd $(gem_src)/src && ./configure \ PKG_FTGL_CFLAGS="-I/sw/include -I/sw/include/freetype2 -I/sw/include/FTGL" \ --without-ALL \ --with-ftgl --with-ftgl-libs=/sw/lib \ --with-artoolkit-includes=/sw/include --with-artoolkit-libs=/sw/lib \ --with-pd=$(pd_src) $(MAKE) -C $(gem_src)/src gem: $(gem_src)/src/Gem.$(EXTENSION) gem_install: gem install -d $(DESTDIR)$(objectsdir)/$(GEM_NAME) ifneq ($(OS_NAME),windows) install -p $(gem_src)/src/Gem.$(EXTENSION) $(DESTDIR)$(objectsdir)/$(GEM_NAME)/ endif (test -e $(gem_src)/src/plugins/filmAVI/.libs/gem_filmAVI.so && \ install -p $(gem_src)/src/plugins/*/.libs/gem_*.so $(DESTDIR)$(objectsdir)/$(GEM_NAME)/ ) || true (test -e $(gem_src)/src/plugins/filmAVI/.libs/gem_filmAVI.dll && \ install -p $(gem_src)/src/plugins/*/.libs/gem_*.dll $(DESTDIR)$(objectsdir)/$(GEM_NAME)/ ) || true install -p $(gem_src)/help/*.* $(DESTDIR)$(objectsdir)/$(GEM_NAME)/ install -p $(gem_src)/abstractions/*.* $(DESTDIR)$(objectsdir)/$(GEM_NAME) install -d $(DESTDIR)$(objectsdir)/$(GEM_NAME)/manual install -p $(gem_src)/doc/*.* $(DESTDIR)$(objectsdir)/$(GEM_NAME)/manual install -d $(DESTDIR)$(objectsdir)/$(GEM_NAME)/manual/html # in Gem 0.92, $(gem_src)/manual moved to $(gem_src)/doc/manual (test -d $(gem_src)/manual && \ install -p $(gem_src)/manual/*.* $(DESTDIR)$(objectsdir)/$(GEM_NAME)/manual/html ) || \ install -p $(gem_src)/doc/manual/*.* $(DESTDIR)$(objectsdir)/$(GEM_NAME)/manual/html for dir in $(shell ls -1 $(gem_src)/examples | grep -v CVS); do \ echo "installing $$dir"; \ install -d $(DESTDIR)$(objectsdir)/$(GEM_NAME)/examples/$$dir ; \ install -p $(gem_src)/examples/$$dir/*.* $(DESTDIR)$(objectsdir)/$(GEM_NAME)/examples/$$dir ;\ done # install Gem headers to make it easier to build standalone Gem objects install -d $(DESTDIR)$(includedir)/Base install -p $(gem_src)/src/Base/*.h $(DESTDIR)$(includedir)/Base/ # links to keep the old-style placement for Gem examples in the Help Browser ifneq ($(OS_NAME),windows) install -d $(DESTDIR)$(examplesdir) ln -s ../../extra/$(GEM_NAME)/examples $(DESTDIR)$(examplesdir)/$(GEM_NAME) install -d $(DESTDIR)$(manualsdir) ln -s ../../extra/$(GEM_NAME)/manual $(DESTDIR)$(manualsdir)/$(GEM_NAME) endif #------------------------------------------------------------------------------ # noncvs_install # this is for including pre-compiled binaries in a build noncvs_install: -install -p $(packages_src)/noncvs/$(OS_NAME)/bin/*.* $(DESTDIR)$(bindir) -install -p $(packages_src)/noncvs/$(OS_NAME)/doc/5.reference/*.* $(DESTDIR)$(helpdir) -install -p $(packages_src)/noncvs/$(OS_NAME)/extra/*.* $(DESTDIR)$(objectsdir) ifeq ($(OS_NAME),windows) -install -p $(packages_src)/noncvs/windows/extra/Gem/*.* \ $(DESTDIR)$(objectsdir)/$(GEM_NAME)/ endif -test -d $(packages_src)/noncvs/$(OS_NAME)/gripd && \ install -d $(DESTDIR)$(prefix)/gripd -install -p $(packages_src)/noncvs/$(OS_NAME)/gripd/*.* \ $(DESTDIR)$(prefix)/gripd #==============================================================================# # # GENERATE TEXT FILES FOR PACKAGE # #==============================================================================# LICENSE_FILE = $(DESTDIR)$(manualsdir)/$(PD_NAME)/License.html license_install: # generate HTML version of License install -d $(DESTDIR)$(manualsdir)/$(PD_NAME) -rm $(LICENSE_FILE) touch $(LICENSE_FILE) echo "" >> "$(LICENSE_FILE)" echo "

(Parts of this package can be used under " >> "$(LICENSE_FILE)" echo "Pd’s BSD license)

" >> "$(LICENSE_FILE)" echo "" >> "$(LICENSE_FILE)" cat "$(packages_src)/gpl-3.0.txt" | sed -e 's/^$$/\/g' >> "$(LICENSE_FILE)" echo "" >> $(LICENSE_FILE) # Pd's license file install -p "$(pd_src)/LICENSE.txt" "$(DESTDIR)$(manualsdir)/$(PD_NAME)/Pd-LICENSE.txt" WELCOME_FILE = $(DESTDIR)$(manualsdir)/$(PD_NAME)/Welcome.html welcome_install: install -d $(DESTDIR)$(manualsdir)/$(PD_NAME) -rm $(WELCOME_FILE) touch $(WELCOME_FILE) echo "" >> $(WELCOME_FILE) echo "" >> $(WELCOME_FILE) echo "" >> $(WELCOME_FILE) echo "

" >> $(WELCOME_FILE) echo "

" >> $(WELCOME_FILE) echo "

Version $(PD_VERSION)

" >> $(WELCOME_FILE) echo "

written by Miller S. Puckette

" >> $(WELCOME_FILE) echo "" >> $(WELCOME_FILE) echo "

`grep -A9 ACKNOWLEDG $(pd_src)/README.txt`

" >> $(WELCOME_FILE) echo "
" >> $(WELCOME_FILE) echo "" >> $(WELCOME_FILE) README_FILE = $(DESTDIR)$(manualsdir)/$(PD_NAME)/ReadMe.html readme_install: install -d $(DESTDIR)$(manualsdir)/$(PD_NAME) echo $(CYCLONE_RELEASE) -rm $(README_FILE) touch $(README_FILE) echo "" >> $(README_FILE) echo "" >> $(README_FILE) echo "" >> $(README_FILE) echo "" >> $(README_FILE) echo "" >> $(README_FILE) echo "" >> $(README_FILE) echo "

Pure Data $(PD_VERSION)

" >> $(README_FILE) echo "

Pd is a real-time, graphical programming language for media processing. It provides an environment for audio analysis, synthesis, and processing, with a rich set of multimedia capabilities. You can get Pd for Linux, Windows, MacOS X, BSD, or IRIX.

" >> $(README_FILE) echo "

For more information, go to: http://puredata.org

" >> $(README_FILE) echo "

Installation

" >> $(README_FILE) ifeq ($(OS_NAME),linux) echo "

" >> $(README_FILE) echo "

" >> $(README_FILE) endif ifeq ($(OS_NAME),darwin) echo "

To install Pd, drag the $(PD_APP_NAME).app into your /Applications folder or to the shortcut in the disk image. (You might need to put the old one in the trash before copying this one to /Applications)

" >> $(README_FILE) echo "

By default, most of the included libraries are loaded at startup. To change this, set your own preferences in the Startup... Preferences pane usings the Save all settings button. If you want to start with the default preferences, throw away the Pd preferences file ~/Library/Preferences/org.puredata.pdextended.plist (~ means your home folder), or run this command in the Terminal.app:

rm ~/Library/Preferences/org.puredata.pdextended.plist

The Preferences panels in Pd are currently buggy, so you might have better luck with the Apple utilities: defaults read org.puredata.pdextended, or, Property List Editor, which is freely available as part of XCode or the Server Tools.

" >> $(README_FILE) echo "If you want to use PDP on Mac OS X 10.4/Tiger or 10.3/Panther, you will need to install X11 (X11 comes installed with 10.5/Leopard). It comes on the install CD/DVD that your computer came with. For more detail, see How to install X11 in OS X or How do I install Pd on MacOS X?." >> $(README_FILE) endif ifeq ($(OS_NAME),windows) echo "

To make sure that all of the included libraries are loaded when Pd runs, " >> $(README_FILE) echo "double-click C:\Program Files\pd\pd-settings.reg to import the settings to the registry. WARNING: this will overwrite any existing Pd preferences!

" >> $(README_FILE) echo "

ASIO4ALL

" >> $(README_FILE) echo "

ASIO4ALL is a cost-free ASIO audio driver. Is it highly recommended for use with Pd. Download and install it, then when you launch Pd, choose the ASIO option from the Media menu. Using ASIO4ALL should mean less crashes and troubles, as well as better audio performance." >> $(README_FILE) echo "

" >> $(README_FILE) endif echo "

Installing Externals, Objects, and Help files

" >> $(README_FILE) echo "

" >> $(README_FILE) echo "If you would like to install other externals, objects, help files, etc. there are special folders that Pd-extended uses, which are listed below. If the folder does not exist, you should create it. You can find out more details about this by reading that FAQ: How do I install externals and help files?." >> $(README_FILE) echo "

" >> $(README_FILE) ifeq ($(OS_NAME),darwin) echo "
Only for the current user account
" >> $(README_FILE) echo "
~/Library/Pd
" >> $(README_FILE) echo "
For all user accounts on the computer
" >> $(README_FILE) echo "
/Library/Pd
" >> $(README_FILE) endif ifeq ($(OS_NAME),linux) echo "
Only for the current user account
" >> $(README_FILE) echo "
~/pd-externals/
" >> $(README_FILE) echo "
For all user accounts on the computer
" >> $(README_FILE) echo "
/usr/local/lib/pd-externals
" >> $(README_FILE) endif ifeq ($(OS_NAME),windows) echo "
Only for the current user account
" >> $(README_FILE) echo "
%UserProfile%\Application Data\Pd
" >> $(README_FILE) echo "
For all user accounts on the computer
" >> $(README_FILE) echo "
%ProgramFiles%\Common Files\Pd
" >> $(README_FILE) endif echo "
" >> $(README_FILE) echo "

" >> $(README_FILE) echo "

Flext Binaries have been removed from Pd-extended

" >> $(README_FILE) echo "

As of release 0.41.4 of Pd-extended, the whole package is built from source every night. That means that some objects have been removed from the package because they were not being built from source (objects like [pool], [msd], [flashserver], etc.). You can download these objects from the original authors or get the files from the 0.40.3 Pd-extended release." >> $(README_FILE) echo "

" >> $(README_FILE) echo "

License

" >> $(README_FILE) echo "

" >> $(README_FILE) echo 'This package is released under the GNU GPL. The Pd core and some other included code is originally available with a BSD license from the Pd CVS on SourceForge.' >> $(README_FILE) echo "

" >> $(README_FILE) echo "

Patented Algorithms

" >> $(README_FILE) echo "

" >> $(README_FILE) echo "This package may contain software that is covered by patents in certain countries, like the U.S. and Germany. In order to use this software you must have the proper license. Below is a list of the known software packages that are covered by patents in some countries:" >> $(README_FILE) echo "

" >> $(README_FILE) echo "" >> $(README_FILE) echo '

Please consider trying to get rid of software patents in your country: http://www.nosoftwarepatents.com

' >> $(README_FILE) echo "

Pure Data CVS Developers

" >> $(README_FILE) # this may seem whack, but it generates the list of developers from the SourceForge site: curl 'http://sourceforge.net/project/memberlist.php?group_id=55736' | grep -A2 -e '' | sed 's|\(href="\)|target="w" \1http://sourceforge.net|' >> $(README_FILE) echo "

" >> $(README_FILE) echo "

" >> $(README_FILE) echo "Many others not listed have contributed their time and effort, this is just a list of the current developers in the SourceForge project. But really, every Pd user is a developer and is encouraged to contribute to the CVS repository." >> $(README_FILE) echo "

" >> $(README_FILE) echo "

Included Versions

" >> $(README_FILE) echo "

These externals are all included from the Pd CVS repository:

" >> $(README_FILE) echo "" >> $(README_FILE) echo "(this package was built on `date`)
" >> $(README_FILE) echo "" >> $(README_FILE) #==============================================================================# # ## FINAL ASSEMBLY # #==============================================================================# #---------------------------------------------------------------------------- # clean up the documentation before packaging doc_format: # clean out cruft files -find $(DESTDIR) -name .DS_Store -delete -find $(DESTDIR) -name '*.*.bak' -delete -find $(DESTDIR) -name .svn -print0 | xargs -0 rm -rf #==============================================================================# # # DEVELOPER TARGETS # #==============================================================================# set_version: # change Pd's version number to reflect the extended build # this needs the complete_version_defines patch to work cd $(pd_src)/src/ && \ sed 's|^\(#define PD_TEST_VERSION "\).*"|\1$(PD-EXTENDED_VERSION)"|' m_pd.h > \ m_pd.h.tmp && mv m_pd.h.tmp m_pd.h unset_version: # change the version number back to the original # this needs the complete_version_defines patch to work cd $(pd_src)/src && \ sed 's|^\(#define PD_TEST_VERSION ".*\)$(PD-EXTENDED_VERSION_PREFIX).*"|\1"|' \ m_pd.h > m_pd.h.tmp && \ mv m_pd.h.tmp m_pd.h #==============================================================================# # # CLEAN TARGETS # #==============================================================================# abstractions_clean: -$(MAKE) -C $(abstractions_src) $(DEST_PATHS) clean doc_clean: externals_clean: -$(MAKE) -C $(externals_src) $(DEST_PATHS) clean gem_clean: -$(MAKE) -C $(gem_src)/src clean pd_clean: -$(MAKE) -C $(pd_src)/src $(DEST_PATHS) clean # these targets are all from Makefile.buildlayout: install_clean cruft_clean clean: abstractions_clean doc_clean externals_clean gem_clean pd_clean echo "Complete clean finished." distclean: cruft_clean $(MAKE) -C $(abstractions_src) distclean $(MAKE) -C $(doc_src) distclean $(MAKE) -C $(extensions_src) distclean $(MAKE) -C $(externals_src) distclean -$(MAKE) -C $(pd_src) distclean test_locations: @echo "PD_VERSION: $(PD_VERSION)" @echo "PD-EXTENDED_VERSION: $(PD-EXTENDED_VERSION)" @echo "CWD $(CWD)" @echo "DESTDIR $(DESTDIR)" @echo "PREFIX $(prefix)" @echo "BINDIR $(bindir)" @echo "LIBDIR $(libdir)" @echo "OBJECTSDIR $(objectsdir)" @echo "PDDOCDIR $(pddocdir)" @echo "LIBPDDIR $(libpddir)" @echo "LIBPDBINDIR $(libpdbindir)" @echo "HELPDIR $(helpdir)" @echo "MANUALSDIR $(manualsdir)" @echo "EXAMPLESDIR $(examplesdir)" @echo "HAVE_AUTOGEN_SH --$(HAVE_AUTOGEN_SH)--"