1 # Copyright (c) 2002-2004 Apple Computer, Inc. All rights reserved.
3 # @APPLE_LICENSE_HEADER_START@
5 # This file contains Original Code and/or Modifications of Original Code
6 # as defined in and that are subject to the Apple Public Source License
7 # Version 2.0 (the 'License'). You may not use this file except in
8 # compliance with the License. Please obtain a copy of the License at
9 # http://www.opensource.apple.com/apsl/ and read it before using this
12 # The Original Code and all software distributed under the License are
13 # distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 # EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 # INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 # FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
17 # Please see the License for the specific language governing rights and
18 # limitations under the License.
20 # @APPLE_LICENSE_HEADER_END@
23 # Revision 1.7 2005/10/19 17:19:56 herscher
24 # Change JDK to use JAVA_HOME environment variable
26 # Revision 1.6 2005/02/10 22:35:36 cheshire
27 # <rdar://problem/3727944> Update name
29 # Revision 1.5 2005/02/08 23:47:51 shersche
30 # Build into proper directories for installer
32 # Revision 1.4 2004/12/16 22:38:00 shersche
33 # Compile DNSSDException.java first to avoid build errors, copy output to appropriate "buildroot" folder
35 # Revision 1.3 2004/11/23 08:13:07 shersche
36 # Link to the iphlpapi.lib for GetAdaptersInfo
38 # Revision 1.2 2004/06/26 20:07:06 rpantos
39 # Update to use WinVersRes.h
41 # Revision 1.1 2004/06/18 04:12:05 rpantos
42 # Move up one level. Integration changes for Scott.
44 # Revision 1.2 2004/05/01 00:31:41 rpantos
45 # Change line endings for CVS.
47 # Revision 1.1 2004/04/30 16:32:34 rpantos
50 # This Makefile builds a .jar file and accompanying JNI support library
51 # containing the DNSSD implementation for Java and support classes.
53 # Prior to building Java support, you must build DNSSD.dll.
55 # nmake with no arguments builds all production targets.
56 # 'nmake DEBUG=1' to build debugging targets.
57 # 'nmake clean' or 'nmake clean DEBUG=1' to delete prod/debug objects & targets
59 # To run nmake, you may need to set up your PATH correctly, using a script
60 # such as: "\Program Files\Microsoft Visual Studio .NET\Vc7\bin\vcvars32.bat"
62 # The default location of the JDK is \javasdk. You can override this on the
63 # command line (e.g. 'nmake JDK=\j2dk1.4.2_03').
65 ############################################################################
67 COREDIR = ..\..\mDNSCore
68 SHAREDDIR = ..\..\mDNSShared
78 JAVAC = $(JDK)\bin\javac
79 JAVAH = $(JDK)\bin\javah
81 CFLAGS_COMMON = -LD -DAUTO_CALLBACKS=0 -I. -I..\.. \
82 -I$(COREDIR) -I$(SHAREDDIR) -I$(JDK)\include -I$(JDK)\include\win32
84 # Set up diverging paths for debug vs. prod builds
87 CFLAGS_DEBUG = -Zi -DMDNS_DEBUGMSGS=2
88 OBJDIR = objects\debug
89 BUILDDIR = build\debug
90 INSTALLDIR = root\"Program Files"\Bonjour
93 CFLAGS_DEBUG = -Os -DMDNS_DEBUGMSGS=0
96 INSTALLDIR = root\"Program Files"\Bonjour
97 LIBDIR = ..\DLL\Release
100 CFLAGS = $(CFLAGS_COMMON) $(CFLAGS_DEBUG)
101 JAVACFLAGS = $(CFLAGS) $(JAVACFLAGS_OS)
103 #############################################################################
105 all: setup Java postbuild
107 # 'setup' sets up the build directory structure the way we want
109 @if not exist objects mkdir objects
110 @if not exist build mkdir build
111 @if not exist $(OBJDIR) mkdir $(OBJDIR)
112 @if not exist $(BUILDDIR) mkdir $(BUILDDIR)
115 @if not exist root mkdir root
116 @if not exist root\"Program Files" mkdir root\"Program Files"
117 @if not exist $(INSTALLDIR) mkdir $(INSTALLDIR)
118 copy $(BUILDDIR)\dns_sd.jar $(INSTALLDIR)
119 copy $(BUILDDIR)\jdns_sd.dll $(INSTALLDIR)
121 # clean removes targets and objects
123 @if exist $(OBJDIR) $(RMDIR) $(OBJDIR)
124 @if exist $(BUILDDIR) $(RMDIR) $(BUILDDIR)
126 #############################################################################
128 # The following targets build Java wrappers for the dns-sd.h API.
130 Java: setup $(BUILDDIR)\dns_sd.jar $(BUILDDIR)\jdns_sd.dll postbuild
131 @echo "Java wrappers done"
133 JAVASRC = $(SHAREDDIR)\Java
134 JARCONTENTS = $(OBJDIR)\com\apple\dnssd\DNSSDService.class \
135 $(OBJDIR)\com\apple\dnssd\DNSSDException.class \
136 $(OBJDIR)\com\apple\dnssd\DNSRecord.class \
137 $(OBJDIR)\com\apple\dnssd\TXTRecord.class \
138 $(OBJDIR)\com\apple\dnssd\DNSSDRegistration.class \
139 $(OBJDIR)\com\apple\dnssd\BaseListener.class \
140 $(OBJDIR)\com\apple\dnssd\BrowseListener.class \
141 $(OBJDIR)\com\apple\dnssd\ResolveListener.class \
142 $(OBJDIR)\com\apple\dnssd\RegisterListener.class \
143 $(OBJDIR)\com\apple\dnssd\QueryListener.class \
144 $(OBJDIR)\com\apple\dnssd\DomainListener.class \
145 $(OBJDIR)\com\apple\dnssd\DNSSD.class
147 $(BUILDDIR)\dns_sd.jar: $(JARCONTENTS)
148 $(JAR) -cf $@ -C $(OBJDIR) com
150 $(BUILDDIR)\jdns_sd.dll: $(JAVASRC)\JNISupport.c $(OBJDIR)\DNSSD.java.h $(OBJDIR)\jdns_sd.RES
151 $(CC) -Fe$@ $(JAVASRC)\JNISupport.c $(CFLAGS) -I$(OBJDIR) \
152 $(LIBDIR)\DNSSD.lib $(JDK)\lib\jvm.lib ws2_32.lib iphlpapi.lib $(OBJDIR)\jdns_sd.RES
155 {$(JAVASRC)}.java{$(OBJDIR)\com\apple\dnssd}.class:
156 $(JAVAC) -d $(OBJDIR) -classpath $(OBJDIR) $<
158 $(OBJDIR)\DNSSD.java.h: $(OBJDIR)\com\apple\dnssd\DNSSD.class
159 $(JAVAH) -classpath $(OBJDIR) -o $@ \
160 com.apple.dnssd.AppleBrowser \
161 com.apple.dnssd.AppleResolver \
162 com.apple.dnssd.AppleRegistration \
163 com.apple.dnssd.AppleQuery \
164 com.apple.dnssd.AppleService
166 $(OBJDIR)\jdns_sd.RES: jdns_sd.rc