1#
2# Make sure all needed macro's are defined
3#
4
5#
6# Get the 'head' of the build environment if necessary.  This includes default
7# targets and paths to tools
8#
9
10ifndef EnvironmentDefined
11include $(AP_WORK)/build/NWGNUhead.inc
12endif
13
14#
15# These directories will be at the beginning of the include list, followed by
16# INCDIRS
17#
18XINCDIRS	+= \
19			$(APR)/include \
20			$(APRUTIL)/include \
21			$(AP_WORK)/include \
22			$(AP_WORK)/modules/http \
23			$(NWOS) \
24			$(EOLIST)
25
26#
27# These flags will come after CFLAGS
28#
29XCFLAGS		+= \
30			$(EOLIST)
31
32#
33# These defines will come after DEFINES
34#
35XDEFINES	+= \
36			$(EOLIST)
37
38#
39# These flags will be added to the link.opt file
40#
41XLFLAGS		+= \
42			$(EOLIST)
43
44#
45# These values will be appended to the correct variables based on the value of
46# RELEASE
47#
48ifeq "$(RELEASE)" "debug"
49XINCDIRS	+= \
50			$(EOLIST)
51
52XCFLAGS		+= \
53			$(EOLIST)
54
55XDEFINES	+= \
56			$(EOLIST)
57
58XLFLAGS		+= \
59			$(EOLIST)
60endif
61
62ifeq "$(RELEASE)" "noopt"
63XINCDIRS	+= \
64			$(EOLIST)
65
66XCFLAGS		+= \
67			$(EOLIST)
68
69XDEFINES	+= \
70			$(EOLIST)
71
72XLFLAGS		+= \
73			$(EOLIST)
74endif
75
76ifeq "$(RELEASE)" "release"
77XINCDIRS	+= \
78			$(EOLIST)
79
80XCFLAGS		+= \
81			$(EOLIST)
82
83XDEFINES	+= \
84			$(EOLIST)
85
86XLFLAGS		+= \
87			$(EOLIST)
88endif
89
90#
91# These are used by the link target if an NLM is being generated
92# This is used by the link 'name' directive to name the nlm.  If left blank
93# TARGET_nlm (see below) will be used.
94#
95NLM_NAME	= proxyhtp
96
97#
98# This is used by the link '-desc ' directive.
99# If left blank, NLM_NAME will be used.
100#
101NLM_DESCRIPTION	= Apache $(VERSION_STR) Proxy HTTP Sub-Module
102
103#
104# This is used by the '-threadname' directive.  If left blank,
105# NLM_NAME Thread will be used.
106#
107NLM_THREAD_NAME	= Proxy HTTP Module
108
109#
110# If this is specified, it will override VERSION value in
111# $(AP_WORK)/build/NWGNUenvironment.inc
112#
113NLM_VERSION	=
114
115#
116# If this is specified, it will override the default of 64K
117#
118NLM_STACK_SIZE	= 8192
119
120
121#
122# If this is specified it will be used by the link '-entry' directive
123#
124NLM_ENTRY_SYM	=
125
126#
127# If this is specified it will be used by the link '-exit' directive
128#
129NLM_EXIT_SYM	=
130
131#
132# If this is specified it will be used by the link '-check' directive
133#
134NLM_CHECK_SYM	=
135
136#
137# If these are specified it will be used by the link '-flags' directive
138#
139NLM_FLAGS	=
140
141#
142# If this is specified it will be linked in with the XDCData option in the def
143# file instead of the default of $(NWOS)/apache.xdc.  XDCData can be disabled
144# by setting APACHE_UNIPROC in the environment
145#
146XDCDATA		=
147
148#
149# If there is an NLM target, put it here
150#
151TARGET_nlm = \
152	$(OBJDIR)/proxyhtp.nlm \
153	$(EOLIST)
154
155#
156# If there is an LIB target, put it here
157#
158TARGET_lib = \
159	$(EOLIST)
160
161#
162# These are the OBJ files needed to create the NLM target above.
163# Paths must all use the '/' character
164#
165FILES_nlm_objs = \
166	$(OBJDIR)/mod_proxy_http.o \
167	$(OBJDIR)/libprews.o \
168	$(EOLIST)
169
170#
171# These are the LIB files needed to create the NLM target above.
172# These will be added as a library command in the link.opt file.
173#
174FILES_nlm_libs = \
175	$(PRELUDE) \
176	$(EOLIST)
177
178#
179# These are the modules that the above NLM target depends on to load.
180# These will be added as a module command in the link.opt file.
181#
182FILES_nlm_modules = \
183	aprlib \
184	libc \
185	proxy \
186	$(EOLIST)
187
188#
189# If the nlm has a msg file, put it's path here
190#
191FILE_nlm_msg =
192
193#
194# If the nlm has a hlp file put it's path here
195#
196FILE_nlm_hlp =
197
198#
199# If this is specified, it will override $(NWOS)\copyright.txt.
200#
201FILE_nlm_copyright =
202
203#
204# Any additional imports go here
205#
206FILES_nlm_Ximports = \
207	@aprlib.imp \
208	@httpd.imp \
209	@$(OBJDIR)/mod_proxy.imp \
210	@libc.imp \
211	$(EOLIST)
212
213# Don't link with Winsock if standard sockets are being used
214ifndef USE_STDSOCKETS
215FILES_nlm_Ximports += @ws2nlm.imp \
216	$(EOLIST)
217endif
218
219#
220# Any symbols exported to here
221#
222FILES_nlm_exports = \
223	proxy_http_module \
224	$(EOLIST)
225
226#
227# These are the OBJ files needed to create the LIB target above.
228# Paths must all use the '/' character
229#
230FILES_lib_objs = \
231	$(EOLIST)
232
233#
234# implement targets and dependancies (leave this section alone)
235#
236
237libs :: $(OBJDIR) $(TARGET_lib)
238
239nlms :: libs $(TARGET_nlm)
240
241#
242# Updated this target to create necessary directories and copy files to the
243# correct place.  (See $(AP_WORK)/build/NWGNUhead.inc for examples)
244#
245install :: nlms FORCE
246
247#
248# Any specialized rules here
249#
250
251vpath %.c ../arch/netware
252
253#
254# Include the 'tail' makefile that has targets that depend on variables defined
255# in this makefile
256#
257
258include $(APBUILD)/NWGNUtail.inc
259
260
261