c7415180d0b1a29ab77f411d9696dd5740a3eb9c
[ghc.git] / distrib / Makefile-bin.in
1 #
2 # @configure_input@
3 #
4 # Instructions for configuring an fptools package.
5 #
6 # There are two ways you can get started with an fptools package, either
7 # by using the unpacked distribution tree in-situ or by installing the
8 # package.
9 #
10 # Using the package directly is easy, just do `make config'. (The
11 # distribution will *not* work straight out of the box, you'll have to do
12 # this first)
13 #
14 # To install the package, you'll have to set one or more of the
15 # following variables:
16 #
17 #  * bindir 
18 #     path to directory of where you want the executables
19 #     to be installed.
20 #  * libdir
21 #     where you want the library archives to go.
22 #     Note, if you specify /usr/foo/lib for libdir,
23 #     the library files for your fptools package will be
24 #     installed in  /usr/foo/lib/<package>-<version>, e.g.,
25 #     /usr/foo/lib/ghc-2.02. If you don't want the package/version
26 #     directory appended, you'll have to modify $(real_libdir)
27 #     below.
28 #
29 #  * datadir
30 #     path to where the platform-independent files will go.
31 #     As for libdir, the effective path for the platform-indep
32 #     stuff is $(datadir)/<package>-<version>. If you want
33 #     complete control, see $(real_datadir)
34 #
35 #  * platform 
36 #     the platform you're installing for. The configure script
37 #     makes an educated guess, so you'll only have to set this
38 #     if it clashes with your reality, I guess.
39 #
40 #  * htmldir
41 #     where to install the documentation HTML files.
42 #  * dvidir
43 #     where to install the DVI files.
44 #  * infodir
45 #     where to install the Emacs info files
46 #
47 # Installing the documentation is not done as part of the `install' rule, but
48 # via `install-docs' (or if you want to be selective: `install-html', `install-dvi'
49 # and `install-info').
50 #
51 # For more complete instructions, consult the INSTALL file
52 # that came with the bundle, and/or consult the installation
53 # documentation in one of the document directories.
54 #
55 # Please report any bugs, problems etc. with installing and using this bundle
56 # Makefile setup to glasgow-haskell-bugs@dcs.gla.ac.uk
57
58
59 # Where the different pieces of the bundle should go:
60 bindir      = @bindir@
61 libdir      = @libdir@
62 datadir     = @datadir@
63
64 platform    = @TargetPlatform@
65 prefix      = @prefix@
66 exec_prefix = @exec_prefix@
67
68 # default
69 infodir   = $(datadir)
70 htmldir   = $(datadir)
71 dvidir    = $(datadir)
72
73 #
74 # Putting the package stuff in package-specific
75 # directories:
76 #
77 real_libdir      = $(libdir)/$(package)-$(version)
78 real_datadir     = $(datadir)/$(package)-$(version)
79
80 package     = ghc
81 version     = 2.02
82 PERL        = @PerlCmd@
83 RM          = rm -f
84 MV          = mv
85 LN_S        = @LN_S@
86 CHMOD       = chmod
87 INSTALL     = @INSTALL@
88 # sigh
89 INSTALL_DIR  = ./mkdirhier
90
91 #
92 # Set of package scripts for which you'd like a name-<version> symlink
93 # to be created, i.e., create a symlink, ghc-2.02, pointing to ghc to
94 # avoid version vertigo.
95 #
96 VERSION_SYMLINKS_FOR=ghc
97
98 #
99 # List of files in bin directory that need to have
100 # local setup/install information prepended.
101 #
102 PACKAGE_SCRIPTS=ghc stat2resid hstags mkdependHS
103
104 # Binaries to install
105 PACKAGE_BINS=$(PACKAGE_SCRIPTS) hp2ps
106
107 #----------end of user-serviceable parts------------
108 #
109 #
110 # How to install the different pieces
111
112 INSTALL_BIN  = $(INSTALL) $(INSTALL_BIN_OPTS)
113 INSTALL_LIB  = $(INSTALL) $(INSTALL_LIB_OPTS)
114 INSTALL_DATA = $(INSTALL) $(INSTALL_DATA_OPTS)
115
116 # What's common to all installs
117 INSTALL_OPTS= $(EXTRA_INSTALL_OPTS)
118
119 BIN_PERMS = 755
120 LIB_PERMS = 644
121
122 INSTALL_BIN_OPTS  = -m $(BIN_PERMS) $(INSTALL_OPTS) $(EXTRA_INSTALL_BIN_OPTS)
123 INSTALL_LIB_OPTS  = -m $(LIB_PERMS) $(INSTALL_OPTS) $(EXTRA_INSTALL_LIB_OPTS)
124 INSTALL_DATA_OPTS = -m $(LIB_PERMS) $(INSTALL_OPTS) $(EXTRA_INSTALL_DATA_OPTS)
125
126 .PHONY: in-place config-pkgs mk-version-symlinks install-dirs install
127
128 config-pkgs ::
129         @echo "Configuring $(package), version $(version), on $(platform) ..."
130         $(RM) bin/$(platform)/$(package)-$(version)/$(package)-$(version)
131         @for i in $(PACKAGE_SCRIPTS); do \
132            echo "Creating a configured version of $$i .."; \
133            $(RM) bin/$(platform)/$(package)-$(version)/$$i.bak; \
134            test -f bin/$(platform)/$(package)-$(version)/$$i && $(MV) bin/$(platform)/$(package)-$(version)/$$i bin/$(platform)/$(package)-$(version)/$$i.bak; \
135            echo "eval 'exec $(PERL) -S $$$""0 $$""{1+\"$$$""@\"}'"         > bin/$(platform)/$(package)-$(version)/$$i; \
136            echo "      if $$""running_under_some_shell;"                  >> bin/$(platform)/$(package)-$(version)/$$i; \
137            echo $$"bindir='$(bindir)';"                                   >> bin/$(platform)/$(package)-$(version)/$$i; \
138            echo $$"libdir='$(real_libdir)';"                              >> bin/$(platform)/$(package)-$(version)/$$i; \
139            echo $$"datadir='$(real_datadir)';"                            >> bin/$(platform)/$(package)-$(version)/$$i; \
140            cat bin/$(platform)/$(package)-$(version)/$(package).prl       >> bin/$(platform)/$(package)-$(version)/$$i; \
141            $(CHMOD) $(BIN_PERMS) bin/$(platform)/$(package)-$(version)/$$i; \
142            echo "Done."; \
143         done
144
145 #
146 # The vaguely funky eval 'exec ...' echo line above *might* be
147 # a tad too much for some `make's - here's what it should return
148 # if all is well:
149 #
150 #   eval 'exec /installed/path/for/perl -S $0 ${1+"$@"}'
151 #         if $running_under_some_shell;
152 #
153
154 mk-version-symlinks ::
155         @for i in $(VERSION_SYMLINKS_FOR) ""; do \
156           if [ "x$$i" != "x" ]; then \
157              echo "Symlinking $$i to $$i-$(version)"; \
158              (cd bin/$(platform)/$(package)-$(version); $(RM) $$i-$(version); $(LN_S) $$i $$i-$(version) ); \
159           fi;\
160         done
161
162 in-place ::
163         $(MAKE) $(MFLAGS) config-pkgs bindir=`pwd`/bin/$(platform)/$(package)-$(version) libdir=`pwd`/lib/$(platform) datadir=`pwd`/share/$(package)-$(version)
164         $(MAKE) $(MFLAGS) mk-version-symlinks
165         @echo "Finished configuring..to use, add `pwd`/bin/$(platform)/$(package)-$(version) to your PATH."
166
167 install-dirs ::
168         $(INSTALL_DIR) $(bindir)
169         (cd lib/$(platform)/$(package)-$(version); find . -type d -exec sh -c '$(INSTALL_DIR) $0 $(real_libdir)/$0' {} \; )
170         (cd share/$(package)-$(version); find . -type d -exec sh -c '$(INSTALL_DIR) $0 $(real_datadir)/$0' {} \; )
171
172 install :: config-pkgs mk-version-symlinks install-dirs install-bin install-libs install-data
173
174 .PHONY: install-bin install-libs install-datas
175
176 install-bin:
177         for i in $(PACKAGE_BINS); do \
178            $(INSTALL_BIN) bin/$(platform)/$(package)-$(version)/$$i $(bindir); \
179         done;
180         for in in $(VERSION_SYMLINKS_FOR) ""; do \
181            if [ "x$$i" != "x"]; then \
182                 $(INSTALL_BIN) bin/$(platform)/$(package)-$(version)/$$i $(bindir); \
183            fi; \
184         done
185
186
187 install-libs:
188         (cd lib/$(platform)/$(package)-$(version); find . -type f -exec sh -c '$(INSTALL_LIB) $0 $(real_libdir)/$0' {} \; )
189
190 install-datas:
191         (cd share/$(package)-$(version); find . -type f -exec sh -c '$(INSTALL_DATA) $0 $(real_datadir)/$0' {} \; )
192
193 show-install-setup:
194         @echo "Install setup..."
195         @echo "bindir  = $(bindir)"
196         @echo "libdir  = $(libdir) (real_libdir  = $(real_libdir))"
197         @echo "datadir = $(datadir) (real_datadir = $(real_datadir))"
198
199 #
200 # Documentation targets, install-docs for the whole lot, or
201 # install-{dvi,html,info}
202 #
203
204 .PHONY: show-install-setup install-docs install-html install-info install-dirs-dvi install-dirs-html install-dirs-info
205
206 install-docs : install-html install-dvi install-info
207
208 install-dvi: install-dirs-dvi
209         $(INSTALL_DATA) dvi/$(package)-$(version)/* $(dvidir)
210
211 install-info: install-dirs-info
212         $(INSTALL_DATA) info/$(package)-$(version)/* $(infodir)
213
214 install-html: install-dirs-html
215         $(INSTALL_DATA) html/$(package)-$(version)/* $(htmldir)
216
217 install-dirs-html:
218         $(INSTALL_DIR) $(htmldir) 
219
220 install-dirs-info:
221         $(INSTALL_DIR) $(infodir) 
222
223 install-dirs-dvi:
224         $(INSTALL_DIR) $(dvidir) 
225