summaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorJesse Chappell <jesse@essej.net>2006-12-27 03:59:19 +0000
committerJesse Chappell <jesse@essej.net>2006-12-27 03:59:19 +0000
commit7d95ab884a3529978e36f72471c1afa1938b074a (patch)
treec63fba6f650eed9a6f6e7f7f54d6641211ef5efb /tools
parent2491eec0fd218f3aa95698461956a9a74f067721 (diff)
updated app_build.rb script to completely package a universal binary in two steps. added various files needed in the app bundle, some of which will need updating as the gtk version used increases.
git-svn-id: svn://localhost/ardour2/trunk@1248 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'tools')
-rw-r--r--tools/osx_packaging/COPYING340
-rwxr-xr-xtools/osx_packaging/app_build.rb247
-rw-r--r--tools/osx_packaging/ardour2_mac_ui.rc9
-rwxr-xr-xtools/osx_packaging/bin/exporter3
-rw-r--r--tools/osx_packaging/etc/gtk-2.0/gdk-pixbuf.loaders113
-rw-r--r--tools/osx_packaging/etc/gtk-2.0/gtk.immodules35
-rw-r--r--tools/osx_packaging/etc/pango/pango.modules24
-rw-r--r--tools/osx_packaging/etc/pango/pangorc5
-rw-r--r--tools/osx_packaging/etc/pango/pangox.aliases220
-rw-r--r--tools/osx_packaging/etc/profile.d/gtk+2-shlibs.csh1
-rw-r--r--tools/osx_packaging/etc/profile.d/gtk+2-shlibs.sh1
-rw-r--r--tools/osx_packaging/etc/profile.d/libxml2-bin.csh2
-rw-r--r--tools/osx_packaging/etc/profile.d/libxml2-bin.sh2
-rwxr-xr-xtools/osx_packaging/script3
14 files changed, 989 insertions, 16 deletions
diff --git a/tools/osx_packaging/COPYING b/tools/osx_packaging/COPYING
new file mode 100644
index 0000000000..d60c31a97a
--- /dev/null
+++ b/tools/osx_packaging/COPYING
@@ -0,0 +1,340 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.
+ 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Library General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+ 2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) Accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of Sections
+ 1 and 2 above on a medium customarily used for software interchange; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable. However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+ 5. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+ 7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded. In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Library General
+Public License instead of this License.
diff --git a/tools/osx_packaging/app_build.rb b/tools/osx_packaging/app_build.rb
index 965d87003d..443b287c28 100755
--- a/tools/osx_packaging/app_build.rb
+++ b/tools/osx_packaging/app_build.rb
@@ -1,22 +1,253 @@
-#!/usr/bin/ruby
+#!/usr/bin/env ruby
# Ruby script for pulling together a MacOSX app bundle.
-if File.exist?("lib") then
- Dir.foreach("lib") {|x| unless x[0] == 46 then File.delete("lib/"+x) end}
+# it will be either powerpc or i386
+version = "beta9"
+arch = `uname -p`.strip()
+libdir = "lib_" + arch
+bindir = "bin_" + arch
+
+ppc_libdir = "lib_powerpc"
+i386_libdir = "lib_i386"
+ppc_bindir = "bin_powerpc"
+i386_bindir = "bin_i386"
+ppc_binlib = "binlib_powerpc.zip"
+i386_binlib = "binlib_i386.zip"
+
+#$stdout.print("libdir is '" + libdir + "'\n")
+
+# check for the other arch's libbin.zip
+if arch == "i386" then
+ zipfile = ppc_binlib
+ `rm -rf #{ppc_libdir} #{ppc_bindir}`
+else
+ zipfile = i386_binlib
+ `rm -rf #{i386_libdir} #{i386_bindir}`
+end
+
+if File.exist?(zipfile) then
+ $stdout.print("Found #{zipfile} : unpacking...\n")
+ `unzip -aq #{zipfile}`
+end
+
+
+if File.exist?(libdir) then
+ # remove it
+ `rm -rf #{libdir}/*`
+ #Dir.foreach(libdir) {|x| unless ( x[0] == 46 or File.stat(libdir+"/"+x).directory?) then File.delete(libdir + "/" +x) end}
else
- Dir.mkdir "lib"
+ Dir.mkdir libdir
end
-result = `otool -L ../../gtk2_ardour/ardour.bin`
+if File.exist?(bindir) then
+ Dir.foreach(bindir) {|x| unless x[0] == 46 then File.delete(bindir + "/" +x) end}
+else
+ Dir.mkdir bindir
+end
+
+if not File.exist?(libdir+"/surfaces") then
+ Dir.mkdir(libdir + "/surfaces")
+end
+
+
+odir = Dir.getwd
+Dir.chdir("../..")
+
+result = `otool -L gtk2_ardour/ardour.bin`
results = result.split("\n")
results.delete_at(0)
+
+result = `otool -L libs/ardour/libardour.dylib`
+results = results + result.split("\n").slice(1,result.size-1)
+
+result = `otool -L libs/surfaces/*/*.dylib`
+results = results + result.split("\n").slice(1,result.size-1)
+
+results.uniq!
+
+$stdout.print("Copying libs to #{libdir} ...\n");
+
+results.each do |s|
+ s = s.split[0]
+ # exclude frameworks, system libraries, X11 libraries, and libjack.
+ unless s =~ /System|\/usr\/lib|\/usr\/X11R6|libjack|:$/ then
+ #$stdout.print("Copying #{s}\n")
+ `cp #{s} #{odir}/#{libdir}/`
+ end
+end
+
+# now do it again
+result = `otool -L #{odir}/#{libdir}/*.dylib`
+results = result.split("\n")
+results.uniq!
results.each do |s|
s = s.split[0]
# exclude frameworks, system libraries, X11 libraries, and libjack.
- unless s =~ /System|\/usr\/lib|\/usr\/X11R6|libjack/ then
- `cp #{s} lib`
+ unless s =~ /System|\/usr\/lib|\/usr\/X11R6|libjack|:$/ then
+ sbase = File.basename(s)
+ targfile = "#{odir}/#{libdir}/#{sbase}"
+ #$stdout.print("Targ is : " + targfile + "\n")
+ if not File.exist?(targfile) then
+ #$stdout.print("2nd stage Copying #{s}\n")
+ `cp #{s} #{odir}/#{libdir}/`
+ end
+ end
+end
+
+
+Dir.chdir(odir)
+
+# copy ardour.bin to bindir/ardour
+$stdout.print("Copying bin to #{bindir} ...\n");
+
+if File.exist?("../../gtk2_ardour/ardour.bin") then
+ `cp ../../gtk2_ardour/ardour.bin #{bindir}/ardour`
+end
+
+`cp ../../libs/surfaces/*/*.dylib #{libdir}/surfaces`
+# remove the basenames from libdir that are in surfaces (copied earlier)
+begin
+ Dir.foreach(libdir+"/surfaces") {|x| unless ( x[0] == 46 or x.include?("libardour_cp")) then File.delete(libdir + "/" +x) end}
+rescue
+end
+
+
+# copy gtk and pango lib stuff
+`cp -R /opt/local/lib/pango #{libdir}/`
+`cp -R /opt/local/lib/gtk-2.0 #{libdir}/`
+
+# use our clearlooks
+`rm -f #{libdir}/gtk-2.0/2.*/engines/libclearlooks.*`
+# must use .so for it to be found :/
+`cp ../../libs/clearlooks/libclearlooks.dylib #{libdir}/gtk-2.0/2.10.0/engines/libclearlooks.so`
+
+
+def lipo_platforms_recurse(src1, src2, target)
+
+ if not File.stat(src1).directory? then
+ # normal file, lets lipo them if it doesn't already exist there
+ isbin = `file #{src1}`.include?("Mach-O")
+ if (! File.exist?(target)) and isbin then
+ if File.exist?(src2) then
+ $stdout.print("Lipo'ing " + target + "\n")
+ `lipo -create -output #{target} #{src1} #{src2}`
+ else
+ # just copy it
+ $stdout.print("Copying " + src1 + "\n")
+ `cp #{src1} #{target}`
+ end
+ else
+ #$stdout.print("Skipping " + target + "\n")
+ end
+ else
+ # directory, recurse if necessary
+ if File.exist?(src2) then
+ # other dir exists, recurse
+
+ # make targetdir if necessary
+ if not File.exist?(target) then
+ Dir.mkdir(target)
+ end
+
+ Dir.foreach(src1) do |file|
+ if file[0] != 46 then
+ src1file = src1 + '/' + file
+ src2file = src2 + '/' + file
+ targfile = target + '/' + file
+ lipo_platforms_recurse(src1file, src2file, targfile)
+ end
+ end
+ else
+ # just copy it recursively to target
+ $stdout.print("Copying dir " + src1 + "\n")
+ `cp -R #{src1} #{target}`
end
+ end
end
-`/usr/local/bin/platypus -a 'Ardour2' -t 'Shell' -o 'None' -u 'Paul Davis' -i '/bin/sh' -V '1.0' -s 'ArDr' -I 'org.ardour.Ardour2' -f 'bin' -f 'lib' -f 'Ardour2.icns' -f 'MenuBar.nib' -f 'ProgressWindow.nib' -f 'init' -f 'openDoc' 'script' 'Ardour2.app'` \ No newline at end of file
+# lipo stuff together if both platforms libs and bins are here
+
+if File.exist?(ppc_libdir) and File.exist?(i386_libdir) then
+ $stdout.print("\nBoth platforms in place, lipo'ing...\n");
+ `rm -rf lib/*`
+ lipo_platforms_recurse(ppc_libdir, i386_libdir, "lib")
+ lipo_platforms_recurse(i386_libdir, ppc_libdir, "lib")
+ lipo_platforms_recurse(i386_bindir+'/ardour', ppc_bindir+'/ardour', "bin/ardour")
+
+ # remove existing Ardour2.app
+ `rm -rf Ardour2.app`
+
+ $stdout.print("\nRunning Playtpus to create Ardour2.app ...\n");
+
+ `/usr/local/bin/platypus -D -X 'ardour' -a 'Ardour2' -t 'shell' -o 'None' -u 'Paul Davis' -i '/bin/sh' -V '2.0' -s 'ArDr' -I 'org.ardour.Ardour2' -f 'bin' -f 'lib' -i 'Ardour2.icns' -f 'MenuBar.nib' -f 'ProgressWindow.nib' -f 'init' -f 'openDoc' 'script' 'Ardour2.app'`
+
+ $stdout.print("\nCopying other stuff to Ardour2.app ...\n");
+
+ if not File.exist?("Ardour2.app/Contents/Resources/etc") then
+ Dir.mkdir "Ardour2.app/Contents/Resources/etc"
+ end
+
+ if not File.exist?("Ardour2.app/Contents/Resources/etc/ardour2") then
+ Dir.mkdir "Ardour2.app/Contents/Resources/etc/ardour2"
+ end
+ `cp ../../gtk2_ardour/ardour.bindings ../../gtk2_ardour/ardour.colors ../../gtk2_ardour/ardour.menus Ardour2.app/Contents/Resources/etc/ardour2/`
+ `cp ../../ardour.rc ../../ardour_system.rc Ardour2.app/Contents/Resources/etc/ardour2/`
+ `cp ardour2_mac_ui.rc Ardour2.app/Contents/Resources/etc/ardour2/ardour2_ui.rc`
+
+ # copy other etc stuff
+ if not File.exist?("Ardour2.app/Contents/Resources/etc/gtk-2.0") then
+ `cp -R etc/gtk-2.0 Ardour2.app/Contents/Resources/etc/`
+ end
+ if not File.exist?("Ardour2.app/Contents/Resources/etc/pango") then
+ `cp -R etc/pango Ardour2.app/Contents/Resources/etc/`
+ end
+ if not File.exist?("Ardour2.app/Contents/Resources/etc/fonts") then
+ `cp -R /opt/local/etc/fonts Ardour2.app/Contents/Resources/etc/`
+ end
+
+ if not File.exist?("Ardour2.app/Contents/Resources/etc/profile.d") then
+ `cp -R etc/profile.d Ardour2.app/Contents/Resources/etc/`
+ end
+
+ # share stuff
+
+ if not File.exist?("Ardour2.app/Contents/Resources/share") then
+ Dir.mkdir "Ardour2.app/Contents/Resources/share"
+ end
+
+ if not File.exist?("Ardour2.app/Contents/Resources/share/ardour2") then
+ Dir.mkdir "Ardour2.app/Contents/Resources/share/ardour2"
+ Dir.mkdir "Ardour2.app/Contents/Resources/share/ardour2/templates"
+ `cp -R ../../gtk2_ardour/icons ../../gtk2_ardour/pixmaps ../../gtk2_ardour/splash.png Ardour2.app/Contents/Resources/share/ardour2/`
+ `cp ../../templates/*.template Ardour2.app/Contents/Resources/share/ardour2/templates/`
+ end
+
+ # go through and recursively remove any .svn dirs in the bundle
+ svndirs = `find Ardour2.app -name .svn -type dir`.split("\n")
+ svndirs.each do |svndir|
+ `rm -rf #{svndir}`
+ end
+
+ # make DMG
+ `rm -rf macdist`
+ Dir.mkdir("macdist")
+ `cp -r README.rtf COPYING Ardour2.app macdist/`
+ dmgname = "Ardour2-#{version}"
+ `rm -f #{dmgname}.dmg`
+ $stdout.print("\nCreating DMG\n")
+ `hdiutil create -fs HFS+ -volname #{dmgname} -srcfolder macdist #{dmgname}.dmg`
+
+
+ $stdout.print("\nDone\n")
+
+else
+ # zip up libdir and bindir
+ zipfile = "binlib_"+`uname -p`.strip() + ".zip"
+ $stdout.print("\nZipping up #{libdir} and #{bindir} into #{zipfile}\n")
+ $stdout.print("Copy #{zipfile} to other platform's osx_packaging dir and run app_build.rb\nthere to complete universal build.\n")
+ `zip -rq #{zipfile} #{libdir} #{bindir}`
+
+end
+
+
diff --git a/tools/osx_packaging/ardour2_mac_ui.rc b/tools/osx_packaging/ardour2_mac_ui.rc
index 17952d6a44..775a1247bf 100644
--- a/tools/osx_packaging/ardour2_mac_ui.rc
+++ b/tools/osx_packaging/ardour2_mac_ui.rc
@@ -138,7 +138,7 @@ style "transport_base" = "medium_bold_text"
style "black_mackie_menu_bar" = "medium_bold_text"
{
- font_name = "sans bold 12"
+ font_name = "sans bold 11"
fg[NORMAL] = { 1.0, 1.0, 1.0 }
bg[NORMAL] = { 0, 0, 0 }
}
@@ -283,11 +283,6 @@ style "time_button" = "default_buttons_menus"
font_name = "sans 10"
}
-style "default_menus" = "default_buttons_menus"
-{
- font_name = "sans 11"
-}
-
style "transport_button"
{
font_name = "sans 9"
@@ -999,7 +994,7 @@ widget "*EditModeSelector" style "medium_bold_entry"
widget "*SnapTypeSelector" style "medium_bold_entry"
widget "*SnapModeSelector" style "medium_bold_entry"
widget "*ZoomFocusSelector" style "medium_bold_entry"
-widget "*ArdourContextMenu*" style "default_menus"
+widget "*ArdourContextMenu*" style "default_buttons_menus"
widget "*EditGroupTitleButton*" style "default_buttons_menus"
widget "*MixerGroupTitleButton*" style "default_buttons_menus"
widget "*ErrorLogCloseButton" style "default_buttons_menus"
diff --git a/tools/osx_packaging/bin/exporter b/tools/osx_packaging/bin/exporter
index 5a2ce0d307..cf77284796 100755
--- a/tools/osx_packaging/bin/exporter
+++ b/tools/osx_packaging/bin/exporter
@@ -36,4 +36,7 @@ sed 's|${CWD}|'"$TOP|g" "$TOP/etc/gtk-2.0/gtk.immodules" > "$ETC/gtk.immodules"
sed 's|${CWD}|'"$TOP|g" "$TOP/etc/gtk-2.0/gdk-pixbuf.loaders" \
> "$ETC/gdk-pixbuf.loaders"
+# to prevent complaining
+mkdir -p "$HOME/.ardour2/templates"
+
exec "$CWD/ardour" "$@"
diff --git a/tools/osx_packaging/etc/gtk-2.0/gdk-pixbuf.loaders b/tools/osx_packaging/etc/gtk-2.0/gdk-pixbuf.loaders
new file mode 100644
index 0000000000..00c931d069
--- /dev/null
+++ b/tools/osx_packaging/etc/gtk-2.0/gdk-pixbuf.loaders
@@ -0,0 +1,113 @@
+# GdkPixbuf Image Loader Modules file
+# Automatically generated file, do not edit
+#
+# LoaderDir = ${CWD}/lib/gtk-2.0/2.10.0/loaders
+#
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/io-wmf.so"
+"wmf" 0 "gtk20" "Windows Metafile"
+"image/x-wmf" ""
+"wmf" ""
+"\327\315\306\232" "" 100
+"\001" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-ani.so"
+"ani" 0 "gtk20" "The ANI image format"
+"application/x-navi-animation" ""
+"ani" ""
+"RIFF ACON" " xxxx " 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-bmp.so"
+"bmp" 0 "gtk20" "The BMP image format"
+"image/bmp" "image/x-bmp" "image/x-MS-bmp" ""
+"bmp" ""
+"BM" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-gif.so"
+"gif" 0 "gtk20" "The GIF image format"
+"image/gif" ""
+"gif" ""
+"GIF8" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-ico.so"
+"ico" 1 "gtk20" "The ICO image format"
+"image/x-icon" ""
+"ico" "cur" ""
+" \001 " "zz znz" 100
+" \002 " "zz znz" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-jpeg.so"
+"jpeg" 1 "gtk20" "The JPEG image format"
+"image/jpeg" ""
+"jpeg" "jpe" "jpg" ""
+"\377\330" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-pcx.so"
+"pcx" 0 "gtk20" "The PCX image format"
+"image/x-pcx" ""
+"pcx" ""
+"\n \001" "" 100
+"\n\002\001" "" 100
+"\n\003\001" "" 100
+"\n\004\001" "" 100
+"\n\005\001" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-png.so"
+"png" 1 "gtk20" "The PNG image format"
+"image/png" ""
+"png" ""
+"\211PNG\r\n\032\n" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-pnm.so"
+"pnm" 0 "gtk20" "The PNM/PBM/PGM/PPM image format family"
+"image/x-portable-anymap" "image/x-portable-bitmap" "image/x-portable-graymap" "image/x-portable-pixmap" ""
+"pnm" "pbm" "pgm" "ppm" ""
+"P1" "" 100
+"P2" "" 100
+"P3" "" 100
+"P4" "" 100
+"P5" "" 100
+"P6" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-ras.so"
+"ras" 0 "gtk20" "The Sun raster image format"
+"image/x-cmu-raster" "image/x-sun-raster" ""
+"ras" ""
+"Y\246j\225" "" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-tga.so"
+"tga" 0 "gtk20" "The Targa image format"
+"image/x-tga" ""
+"tga" "targa" ""
+" \001\001" "x " 100
+" \001\t" "x " 100
+" \002" "xz " 99
+" \003" "xz " 100
+" \n" "xz " 100
+" \013" "xz " 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-tiff.so"
+"tiff" 0 "gtk20" "The TIFF image format"
+"image/tiff" ""
+"tiff" "tif" ""
+"MM *" " z " 100
+"II* " " z" 100
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-wbmp.so"
+"wbmp" 0 "gtk20" "The WBMP image format"
+"image/vnd.wap.wbmp" ""
+"wbmp" ""
+" " "z" 1
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-xbm.so"
+"xbm" 0 "gtk20" "The XBM image format"
+"image/x-xbitmap" ""
+"xbm" ""
+"#define " "" 100
+"/*" "" 50
+
+"${CWD}/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-xpm.so"
+"xpm" 0 "gtk20" "The XPM image format"
+"image/x-xpixmap" ""
+"xpm" ""
+"/* XPM */" "" 100
+
diff --git a/tools/osx_packaging/etc/gtk-2.0/gtk.immodules b/tools/osx_packaging/etc/gtk-2.0/gtk.immodules
new file mode 100644
index 0000000000..e8a9900917
--- /dev/null
+++ b/tools/osx_packaging/etc/gtk-2.0/gtk.immodules
@@ -0,0 +1,35 @@
+# GTK+ Input Method Modules file
+# Automatically generated file, do not edit
+#
+# ModulesPath = /var/root/.gtk-2.0/2.4.0/powerpc-apple-darwin7.6.0/immodules:/var/root/.gtk-2.0/2.4.0/immodules:/var/root/.gtk-2.0/powerpc-apple-darwin7.6.0/immodules:/var/root/.gtk-2.0/immodules:${CWD}/lib/gtk-2.0/2.4.0/powerpc-apple-darwin7.6.0/immodules:${CWD}/lib/gtk-2.0/2.4.0/immodules:${CWD}/lib/gtk-2.0/powerpc-apple-darwin7.6.0/immodules:${CWD}/lib/gtk-2.0/immodules
+#
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-am-et.so"
+"am_et" "Amharic (EZ+)" "gtk20" "${CWD}/share/locale" "am"
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-cedilla.so"
+"cedilla" "Cedilla" "gtk+" "${CWD}/share/locale" "az:ca:co:fr:gv:oc:pt:sq:tr:wa"
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-cyrillic-translit.so"
+"cyrillic_translit" "Cyrillic (Transliterated)" "gtk20" "${CWD}/share/locale" ""
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-inuktitut.so"
+"inuktitut" "Inukitut (Transliterated)" "gtk20" "${CWD}/share/locale" "iu"
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-ipa.so"
+"ipa" "IPA" "gtk20" "${CWD}/share/locale" ""
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-thai-broken.so"
+"thai_broken" "Thai (Broken)" "gtk20" "${CWD}/share/locale" ""
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-ti-er.so"
+"ti_er" "Tigrigna-Eritrean (EZ+)" "gtk20" "${CWD}/share/locale" "ti"
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-ti-et.so"
+"ti_et" "Tigrigna-Ethiopian (EZ+)" "gtk20" "${CWD}/share/locale" "ti"
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-viqr.so"
+"viqr" "Vietnamese (VIQR)" "gtk20" "${CWD}/share/locale" "vi"
+
+"${CWD}/lib/gtk-2.0/2.10.0/immodules/im-xim.so"
+"xim" "X Input Method" "gtk20" "${CWD}/share/locale" "ko:ja:th:zh"
+
diff --git a/tools/osx_packaging/etc/pango/pango.modules b/tools/osx_packaging/etc/pango/pango.modules
new file mode 100644
index 0000000000..c635b8b6a6
--- /dev/null
+++ b/tools/osx_packaging/etc/pango/pango.modules
@@ -0,0 +1,24 @@
+# Pango Modules file
+# Automatically generated file, do not edit
+#
+# ModulesPath = "${CWD}/lib/pango/1.5.0/modules"
+#
+${CWD}/lib/pango/1.5.0/modules/pango-arabic-fc.so ArabicScriptEngineFc PangoEngineShape PangoRenderFc arabic:*
+${CWD}/lib/pango/1.5.0/modules/pango-basic-fc.so BasicScriptEngineFc PangoEngineShape PangoRenderFc armenian:* bopomofo:* cherokee:* coptic:* cyrillic:* deseret:* ethiopic:* georgian:* gothic:* greek:* han:* hiragana:* katakana:* latin:* ogham:* old-italic:* runic:* canadian-aboriginal:* yi:* braille:* cypriot:* limbu:* osmanya:* shavian:* linear-b:* ugaritic:* glagolitic:* common:
+${CWD}/lib/pango/1.5.0/modules/pango-basic-x.so BasicScriptEngineX PangoEngineShape PangoRenderX common:
+${CWD}/lib/pango/1.5.0/modules/pango-hangul-fc.so HangulScriptEngineFc PangoEngineShape PangoRenderFc hangul:*
+${CWD}/lib/pango/1.5.0/modules/pango-hebrew-fc.so HebrewScriptEngineFc PangoEngineShape PangoRenderFc hebrew:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so devaScriptEngineFc PangoEngineShape PangoRenderFc devanagari:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so bengScriptEngineFc PangoEngineShape PangoRenderFc bengali:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so guruScriptEngineFc PangoEngineShape PangoRenderFc gurmukhi:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so gujrScriptEngineFc PangoEngineShape PangoRenderFc gujarati:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so oryaScriptEngineFc PangoEngineShape PangoRenderFc oriya:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so tamlScriptEngineFc PangoEngineShape PangoRenderFc tamil:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so teluScriptEngineFc PangoEngineShape PangoRenderFc telugu:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so kndaScriptEngineFc PangoEngineShape PangoRenderFc kannada:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so mlymScriptEngineFc PangoEngineShape PangoRenderFc malayalam:*
+${CWD}/lib/pango/1.5.0/modules/pango-indic-fc.so sinhScriptEngineFc PangoEngineShape PangoRenderFc sinhala:*
+${CWD}/lib/pango/1.5.0/modules/pango-khmer-fc.so KhmerScriptEngineFc PangoEngineShape PangoRenderFc khmer:*
+${CWD}/lib/pango/1.5.0/modules/pango-syriac-fc.so SyriacScriptEngineFc PangoEngineShape PangoRenderFc syriac:*
+${CWD}/lib/pango/1.5.0/modules/pango-thai-fc.so ThaiScriptEngineFc PangoEngineShape PangoRenderFc thai:* lao:*
+${CWD}/lib/pango/1.5.0/modules/pango-tibetan-fc.so TibetanScriptEngineFc PangoEngineShape PangoRenderFc tibetan:*
diff --git a/tools/osx_packaging/etc/pango/pangorc b/tools/osx_packaging/etc/pango/pangorc
new file mode 100644
index 0000000000..a4152dd731
--- /dev/null
+++ b/tools/osx_packaging/etc/pango/pangorc
@@ -0,0 +1,5 @@
+[Pango]
+ModuleFiles = ${HOME}/Library/Application Support/Ardour/pango.modules
+
+[PangoX]
+AliasFiles = ${HOME}/Library/Application Support/Ardour/pangox.aliases
diff --git a/tools/osx_packaging/etc/pango/pangox.aliases b/tools/osx_packaging/etc/pango/pangox.aliases
new file mode 100644
index 0000000000..9b41aa7521
--- /dev/null
+++ b/tools/osx_packaging/etc/pango/pangox.aliases
@@ -0,0 +1,220 @@
+# File defining aliases of PangoFontDescription to X font set
+#
+# family style variant weight stretch XLFD
+
+sans normal normal normal normal \
+ "-*-helvetica-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -*-gulim-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+sans italic normal normal normal \
+ "-*-helvetica-medium-o-normal--*-*-*-*-*-*-*-*,\
+ -*-gulim-medium-o-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+sans normal normal bold normal \
+ "-*-helvetica-bold-r-normal--*-*-*-*-*-*-*-*,\
+ -*-gulim-bold-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+sans italic normal bold normal \
+ "-*-helvetica-bold-o-normal--*-*-*-*-*-*-*-*,\
+ -*-gulim-bold-o-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+
+serif normal normal normal normal \
+ "-*-times-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -*-batang-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+serif italic normal normal normal \
+ "-*-times-medium-i-normal--*-*-*-*-*-*-*-*,\
+ -*-batang-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+serif normal normal bold normal \
+ "-*-times-bold-r-normal--*-*-*-*-*-*-*-*,\
+ -*-batang-bold-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+serif italic normal bold normal \
+ "-*-times-bold-i-normal--*-*-*-*-*-*-*-*,\
+ -*-batang-bold-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+monospace normal normal normal normal \
+ "-*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -*-dotum-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+monospace italic normal normal normal \
+ "-*-fixed-medium-i-normal--*-*-*-*-*-*-*-*,\
+ -*-dotum-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+monospace normal normal bold normal \
+ "-*-fixed-bold-r-normal--*-*-*-*-*-*-*-*,\
+ -*-dotum-bold-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
+
+monospace italic normal bold normal \
+ "-*-fixed-bold-i-normal--*-*-*-*-*-*-*-*,\
+ -*-dotum-bold-r-normal--*-*-*-*-*-*-ksc5601.1987-0,\
+ -*-clearlyu-medium-r-normal--*-*-*-*-*-*-iso10646-1,\
+ -*-fixed-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -kaist-iyagi-bold-r-normal--*-*-*-*-*-*-johab-1,\
+ -*-song ti-medium-r-normal--*-*-*-*-*-*-*-*,\
+ -freetype-unitamil-medium-r-normal--*-*-*-*-*-*-iso10646-tam,\
+ -*-devanagari-medium-r-normal--*-*-*-*-*-*-iso10646-dev,\
+ -*-gujarati-medium-r-normal--*-*-*-*-*-*-iso10646-guj,\
+ -*-gurmukhi-medium-r-normal--*-*-*-*-*-*-iso10646-gur,\
+ -*-bengali-medium-r-normal--*-*-*-*-*-*-iso10646-bng,\
+ -*-kannada-medium-r-normal--*-*-*-*-*-*-iso10646-kan,\
+ -*-burmese-medium-r-normal--*-*-*-*-*-*-iso10646-brm,\
+ -*-buginese-medium-r-normal--*-*-*-*-*-*-iso10646-bgn,\
+ -*-oriya-medium-r-normal--*-*-*-*-*-*-iso10646-ori,\
+ -daewoo-mincho-medium-r-normal--*-*-*-*-*-*-ksc5601.1987-0"
diff --git a/tools/osx_packaging/etc/profile.d/gtk+2-shlibs.csh b/tools/osx_packaging/etc/profile.d/gtk+2-shlibs.csh
new file mode 100644
index 0000000000..8dcc7a5865
--- /dev/null
+++ b/tools/osx_packaging/etc/profile.d/gtk+2-shlibs.csh
@@ -0,0 +1 @@
+setenv GDK_USE_XFT '1'
diff --git a/tools/osx_packaging/etc/profile.d/gtk+2-shlibs.sh b/tools/osx_packaging/etc/profile.d/gtk+2-shlibs.sh
new file mode 100644
index 0000000000..9aeffa2d87
--- /dev/null
+++ b/tools/osx_packaging/etc/profile.d/gtk+2-shlibs.sh
@@ -0,0 +1 @@
+export GDK_USE_XFT='1'
diff --git a/tools/osx_packaging/etc/profile.d/libxml2-bin.csh b/tools/osx_packaging/etc/profile.d/libxml2-bin.csh
new file mode 100644
index 0000000000..b27efb89f4
--- /dev/null
+++ b/tools/osx_packaging/etc/profile.d/libxml2-bin.csh
@@ -0,0 +1,2 @@
+setenv XML_CATALOG_FILES '/sw/etc/xml/catalog'
+setenv SGML_CATALOG_FILES '/sw/etc/sgml/catalog'
diff --git a/tools/osx_packaging/etc/profile.d/libxml2-bin.sh b/tools/osx_packaging/etc/profile.d/libxml2-bin.sh
new file mode 100644
index 0000000000..29ca69f842
--- /dev/null
+++ b/tools/osx_packaging/etc/profile.d/libxml2-bin.sh
@@ -0,0 +1,2 @@
+export XML_CATALOG_FILES='/sw/etc/xml/catalog'
+export SGML_CATALOG_FILES='/sw/etc/sgml/catalog'
diff --git a/tools/osx_packaging/script b/tools/osx_packaging/script
index d689320d20..ec6ad4feec 100755
--- a/tools/osx_packaging/script
+++ b/tools/osx_packaging/script
@@ -24,4 +24,5 @@ export "DISPLAY=`cat $TMP/display`"
ps -wx -ocommand | grep -e '[X]11' > /dev/null || exit 11
cd ~/
-exec "$CWD/bin/exporter" "$@"
+shift
+exec "$CWD/bin/exporter" "$*"