IncludeTemplate("filelist.t");
#! now transform these hashes into $project tags
- foreach $file (sort keys %wxGeneric) {
- my $tag = "";
- next if $wxGeneric{$file} =~ /\b(PS|G|16|U)\b/;
+ foreach $file (sort keys %wxUNIV) {
+ next if $wxUNIV{$file} =~ /\T\b/;
$file =~ s/cp?p?$/obj/;
- $project{"WXGENERICOBJS"} .= "\$(MSWDIR)\\" . $file . " "
+ $obj = "\$(UNIVDIR)\\" . $file . " ";
+ $project{"WXUNIVOBJS"} .= "\$(MSWDIR)\\" . $file . " "
+ }
+
+ foreach $file (sort keys %wxUNIV) {
+ next unless $wxUNIV{$file} =~ /\T\b/;
+
+ $file =~ s/cp?p?$/obj/;
+ $obj = "\$(UNIVTHEMEDIR)\\" . $file . " ";
+ $project{"WXUNIVTHEMEOBJS"} .= "\$(MSWDIR)\\" . $file . " "
}
foreach $file (sort keys %wxHTML) {
$project{"WXCOBJS"} .= $obj if $isCFile;
}
+#! MSW dir for native port
foreach $file (sort keys %wxMSW) {
next if $wxMSW{$file} =~ /\b16\b/;
}
$project{"WXCOBJS"} .= $obj if $isCFile;
}
+
+#! Now do MSW dir for UNIV
+ foreach $file (sort keys %wxMSW) {
+ next unless $wxMSW{$file} =~ /\b(L|B)\b/;
+
+#! if ( $file =~ /^automtn/ ) {
+#! #! comment in old makefile.b32 seems to imply that this file can not
+#! #! be compiled with Borland (leads to crash in oleauto sample)
+#! No longer true, at least for BC++ 5.2
+#! next;
+#! }
+
+ $isCFile = $file =~ /\.c$/;
+
+ my $isOleObj = $wxMSW{$file} =~ /\bO\b/;
+ $file =~ s/cp?p?$/obj/;
+ my $obj = "\$(MSWDIR)\\" . $file . " ";
+
+ $project{"WXMSWUNIVOBJS"} .= $obj;
+ if ( $isOleObj ) {
+ #! remember that this file is in ole subdir
+ $project{"WXOLEUNIVOBJS"} .= $obj;
+ }
+ $project{"WXCUNIVOBJS"} .= $obj if $isCFile;
+ }
+
+#! Generic Dir for Native Port
+ foreach $file (sort keys %wxGeneric) {
+ my $tag = "";
+ next if $wxGeneric{$file} =~ /\b(PS|G|16|U)\b/;
+
+ $file =~ s/cp?p?$/obj/;
+ $project{"WXGENERICOBJS"} .= "\$(MSWDIR)\\" . $file . " "
+ }
+
+#! Generic Dir for UNIV Port
+ foreach $file (sort keys %wxGeneric) {
+ my $filereal = $file;
+ if ( $file =~ /^([^.]+)g.cpp$/ ) {
+ $filereal = "$1.cpp";
+ }
+ $file =~ s/cp?p?$/obj/;
+ $filereal =~ s/cp?p?$/obj/;
+
+ next if $project{"WXMSWUNIVOBJS"} =~ /\b$filereal\b/ ||
+ $project{"WXUNIVOBJS"} =~ /\b$filereal\b/;
+
+
+ $project{"WXGENERICUNIVOBJS"} .= "\$(MSWDIR)\\" . $file . " "
+ }
+
#$}
-# This file was automatically generated by tmake
+# This file was automatically generated by tmake
# DO NOT CHANGE THIS FILE, YOUR CHANGES WILL BE LOST! CHANGE B32.T!
#
WXDIR = $(WXWIN)
THISDIR = $(WXDIR)\src\msw
+
# Set all these to 1 if you want to build a dynamic library
!if "$(DLL)" == "1"
WXMAKINGDLL=1
COMMDIR=..\common
HTMLDIR=..\html
OLEDIR=.\ole
+UNIVDIR=..\univ
+UNIVTHEMEDIR=..\univ\themes
MSWDIR=.
DOCDIR = $(WXDIR)\docs
GENERICOBJS= #$ ExpandList("WXGENERICOBJS");
-# Not needed:
-# $(MSWDIR)\colrdlgg.obj \
-# $(MSWDIR)\fontdlgg.obj \
-# $(MSWDIR)\msgdlgg.obj \
-# $(MSWDIR)\printps.obj \
-# $(MSWDIR)\prntdlgg.obj \
-# $(MSWDIR)\listctrl.obj \
-# $(MSWDIR)\notebook.obj \
-# $(MSWDIR)\treectrl.obj
+MSWOBJS = #$ ExpandList("WXMSWOBJS");
-COMMONOBJS = \
- $(MSWDIR)\y_tab.obj \
- #$ ExpandList("WXCOMMONOBJS");
+GENERICUNIVOBJS= #$ ExpandList("WXGENERICUNIVOBJS");
-MSWOBJS = #$ ExpandList("WXMSWOBJS");
+MSWUNIVOBJS = #$ ExpandList("WXMSWUNIVOBJS");
+
+UNIVOBJS = #$ ExpandList("WXUNIVOBJS");
+
+UNIVTHEMEOBJS = #$ ExpandList("WXUNIVTHEMEOBJS");
HTMLOBJS = #$ ExpandList("WXHTMLOBJS");
+COMMONOBJS = \
+ $(MSWDIR)\y_tab.obj \
+ #$ ExpandList("WXCOMMONOBJS");
+
+!if "$(WXUSINGUNIV)" == "1"
+OBJECTS = $(COMMONOBJS) $(GENERICUNIVOBJS) $(MSWUNIVOBJS) $(HTMLOBJS) $(UNIVOBJS) $(UNIVTHEMEOBJS)
+!else
OBJECTS = $(COMMONOBJS) $(GENERICOBJS) $(MSWOBJS) $(HTMLOBJS)
+!endif
-default: wx
+default: wx
wx: $(ARCHINCDIR)\wx makesetuph makearchsetuph $(CFG) $(DUMMY).obj $(OBJECTS) $(PERIPH_TARGET) $(LIBTARGET)
-all: wx
+all: wx
# Copy the in-CVS setup0.h to setup.h if necessary
makesetuph:
# Copy include\wx\msw\setup.h to the architecture-specific location
makearchsetuph:
- copy $(WXDIR)\include\wx\msw\setup.h $(ARCHSETUPH)
+ copy $(SETUPSRCDIR)\setup.h $(ARCHSETUPH)
cd $(WXDIR)\src\msw
$(ARCHINCDIR)\wx:
-mkdir $(ARCHINCDIR)
-mkdir $(ARCHINCDIR)\wx
+ -erase $(CFG)
!if "$(DLL)" == "0"
$(LIBTARGET): $(DUMMY).obj $(OBJECTS)
-erase $(LIBTARGET)
- tlib "$(LIBTARGET)" /P1024 @&&!
+ tlib "$(LIBTARGET)" /P1024 $(LINKDEBUGFLAGS) @&&!
+$(OBJECTS:.obj =.obj +) +$(PERIPH_LIBS:.lib =.lib +)
!
!else
$(LIBTARGET): $(DUMMY).obj $(OBJECTS)
- -erase $(LIBTARGET)
- -erase $(WXLIBDIR)\wx.dll
- $(LINK) $(LINK_FLAGS) /L$(WXLIBDIR);$(BCCDIR)\lib;$(BCCDIR)\lib\psdk /v @&&!
+ -erase $(LIBTARGET)
+ -erase $(WXDLL)
+ $(LINK) $(LINK_FLAGS) $(LINKDEBUGFLAGS) /L$(WXLIBDIR);$(BCCDIR)\lib;$(BCCDIR)\lib\psdk @&&!
c0d32.obj $(OBJECTS)
-$(WXLIBDIR)\wx
+$(WXDLL)
nul
$(PERIPH_LIBS) $(LIBS)
wxb32
!
- implib -c $(LIBTARGET) $(WXLIBDIR)\wx.dll
+ implib -c $(LIBTARGET) $(WXDLL)
!endif
dummy.obj: dummy.$(SRCSUFF) $(LOCALHEADERS) $(BASEHEADERS) $(WXDIR)\include\wx\wx.h
dummydll.obj: dummydll.$(SRCSUFF) $(LOCALHEADERS) $(BASEHEADERS) $(WXDIR)\include\wx\wx.h version.res
-version.res:
- brc32 -r -i$(WXDIR)\include\ $(MSWDIR)\version.rc
+version.res:
+ brc32 -r -i$(WXDIR)\include\ $(MSWDIR)\version.rc
$(MSWDIR)\y_tab.obj: $(COMMDIR)\y_tab.c $(COMMDIR)\lex_yy.c
$(COMMDIR)\lex_yy.c: $(COMMDIR)\doslex.c
copy $(COMMDIR)\doslex.c $(COMMDIR)\lex_yy.c
-# $(OBJECTS): $(WXDIR)\include\wx\setup.h
+# $(OBJECTS): $(WXDIR)\include\wx\setup.h
+
+!if "$(WXUSINGUNIV)" == "1"
+########################################################
+# MSW objects (compile Native or UNIV) - UNIV
+
+#${
+ $_ = $project{"WXMSWUNIVOBJS"};
+ my @objs = split;
+ foreach (@objs) {
+ $text .= $_ . ": ";
+ if ( $project{"WXOLEOBJS"} =~ /\Q$_/ ) { s/MSWDIR/OLEDIR/; }
+ $suffix = $project{"WXCUNIVOBJS"} =~ /\Q$_/ ? "c" : '$(SRCSUFF)';
+ s/obj$/$suffix/;
+ $text .= $_ . "\n\n";
+ }
+#$}
+
+
+!else
+########################################################
+# MSW objects (compile Native or UNIV) - Native
#${
$_ = $project{"WXMSWOBJS"};
$text .= $_ . "\n\n";
}
#$}
+!endif
+
+!if "$(WXUSINGUNIV)" == "1"
+########################################################
+# UNIV objects
+#${
+ $_ = $project{"WXUNIVOBJS"};
+ my @objs = split;
+ foreach (@objs) {
+ $text .= $_ . ": ";
+ s/MSWDIR/UNIVDIR/;
+ s/obj$/\$(SRCSUFF)/;
+ $text .= $_ . "\n\n";
+ }
+#$}
+
+
+########################################################
+# UNIV THEME objects
+
+#${
+ $_ = $project{"WXUNIVTHEMEOBJS"};
+ my @objs = split;
+ foreach (@objs) {
+ $text .= $_ . ": ";
+ s/MSWDIR/UNIVTHEMEDIR/;
+ s/obj$/\$(SRCSUFF)/;
+ $text .= $_ . "\n\n";
+ }
+#$}
+
+!endif
########################################################
# Common objects (always compiled)
}
#$}
+!if "$(WXUSINGUNIV)" == "1"
+########################################################
+# Generic objects (not always compiled, depending on
+# whether platforms have native implementations)
+# Native
+
+
+#${
+ $_ = $project{"WXGENERICUNIVOBJS"};
+ my @objs = split;
+ foreach (@objs) {
+ $text .= $_ . ": ";
+ s/MSWDIR/GENDIR/;
+ s/obj$/\$(SRCSUFF)/;
+ $text .= $_ . "\n\n";
+ }
+#$}
+
+!else
########################################################
# Generic objects (not always compiled, depending on
# whether platforms have native implementations)
+# Native
#${
$_ = $project{"WXGENERICOBJS"};
$text .= $_ . "\n\n";
}
#$}
+!endif
########################################################
# HTML objects (always compiled)
all_utils:
cd $(WXDIR)\utils
- make -f makefile.b32
+ ${MAKE} -f makefile.b32
cd $(WXDIR)\src\msw
all_samples:
cd $(WXDIR)\samples
- make -f makefile.b32
+ ${MAKE} -f makefile.b32
cd $(WXDIR)\src\msw
all_execs:
cd $(WXDIR)\utils
- make -f makefile.b32 all_execs
+ ${MAKE} -f makefile.b32 all_execs
cd $(WXDIR)\src\msw
png: $(CFG)
cd $(WXDIR)\src\png
- make -f makefile.b32
+ ${MAKE} -f makefile.b32 FINAL=$(FINAL)
cd $(WXDIR)\src\msw
clean_png:
cd $(WXDIR)\src\png
- make -f makefile.b32 clean
+ ${MAKE} -f makefile.b32 clean
cd $(WXDIR)\src\msw
zlib: $(CFG)
cd $(WXDIR)\src\zlib
- make -f makefile.b32 lib
+ ${MAKE} -f makefile.b32 FINAL=$(FINAL) lib
cd $(WXDIR)\src\msw
clean_zlib:
cd $(WXDIR)\src\zlib
- make -f makefile.b32 clean
+ ${MAKE} -f makefile.b32 clean
cd $(WXDIR)\src\msw
jpeg: $(CFG)
cd $(WXDIR)\src\jpeg
- make -f makefile.b32
+ ${MAKE} -f makefile.b32 FINAL=$(FINAL)
cd $(WXDIR)\src\msw
clean_jpeg:
cd $(WXDIR)\src\jpeg
- make -f makefile.b32 clean
+ ${MAKE} -f makefile.b32 clean
cd $(WXDIR)\src\msw
regex: $(CFG)
cd $(WXDIR)\src\regex
- make -f makefile.b32 lib
+ ${MAKE} -f makefile.b32 FINAL=$(FINAL) lib
cd $(WXDIR)\src\msw
clean_regex:
cd $(WXDIR)\src\regex
- make -f makefile.b32 clean
+ ${MAKE} -f makefile.b32 clean
cd $(WXDIR)\src\msw
tiff: $(CFG)
cd $(WXDIR)\src\tiff
- make -f makefile.b32 lib
+ ${MAKE} -f makefile.b32 FINAL=$(FINAL) lib
cd $(WXDIR)\src\msw
clean_tiff:
cd $(WXDIR)\src\tiff
- make -f makefile.b32 clean
+ ${MAKE} -f makefile.b32 clean
cd $(WXDIR)\src\msw
$(CFG): makefile.b32
- copy &&!
+ copy &&!
-Hc
-H=$(WXDIR)\src\msw\wx32.csm
-3
-L$(BCCDIR)\lib;$(BCCDIR)\lib\psdk
-D__WXWIN__
--D__WXMSW__
+-D$(PORT)
-D__WINDOWS__
-DWIN32
$(OPT)
! $(CFG)
clean: $(PERIPH_CLEAN_TARGET)
- -erase $(LIBTARGET)
- -erase $(WXLIBDIR)\wx.dll
-erase $(WXLIBDIR)\wx.tds
-erase $(WXLIBDIR)\wx.il?
-erase *.obj
-erase *.pch
-erase *.csm
- -erase *.cfg
-erase "wx32.#??"
-erase ..\common\y_tab.c
-erase ..\common\lex_yy.c
pdfrtf: $(DOCDIR)/pdf/wx.rtf
proppdfrtf: $(DOCDIR)/pdf/prop.rtf
refpdfrtf: $(DOCDIR)/pdf/techref.rtf
-html: wxhtml portinghtml
-wxhtml: $(DOCDIR)\html\wx\wx.htm
+html: wxhtml portinghtml
+wxhtml: $(DOCDIR)\html\wx\wx.htm
htmlhelp: $(DOCDIR)\html\wx\wx.chm
prophtml: $(DOCDIR)\html\proplist\prop.htm
ps: wxps referencps
-wxps: $(WXDIR)\docs\ps\wx.ps
-propps: $(WXDIR)\docs\ps\prop.ps
-referencps: $(WXDIR)\docs\ps\referenc.ps
+wxps: $(WXDIR)\docs\ps\wx.ps
+propps: $(WXDIR)\docs\ps\prop.ps
+referencps: $(WXDIR)\docs\ps\referenc.ps
portinghtml: $(DOCDIR)\html\porting\port.htm
portingrtf: $(DOCDIR)/winhelp/porting.rtf
portinghlp: $(DOCDIR)/winhelp/porting.hlp
portingpdfrtf: $(DOCDIR)/pdf/porting.rtf
-portingps: $(WXDIR)\docs\ps\porting.ps
+portingps: $(WXDIR)\docs\ps\porting.ps
allhlp: wxhlp portinghlp prophlp
cd $(WXDIR)\utils\dialoged\src
- make -f makefile.b32 hlp
+ ${MAKE} -f makefile.b32 hlp
cd $(THISDIR)
# cd $(WXDIR)\utils\wxhelp\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
# cd $(WXDIR)\utils\tex2rtf\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
# cd $(WXDIR)\utils\wxgraph\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
# cd $(WXDIR)\utils\wxchart\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
# cd $(WXDIR)\utils\wxtree\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
# cd $(WXDIR)\utils\wxbuild\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
# cd $(WXDIR)\utils\wxgrid\src
-# make -f makefile.b32 hlp
+# ${MAKE} -f makefile.b32 hlp
allhtml: wxhtml portinghtml prophtml
cd $(WXDIR)\utils\dialoged\src
- make -f makefile.b32 html
+ ${MAKE} -f makefile.b32 html
cd $(THISDIR)
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\dialoged\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\hytext\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\wxhelp\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\tex2rtf\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\wxgraph\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\wxchart\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
# cd $(WXDIR)\utils\wxtree\src
-# make -f makefile.b32 html
+# ${MAKE} -f makefile.b32 html
allps: wxps referencps portingps propps
cd $(WXDIR)\utils\dialoged\src
- make -f makefile.b32 ps
+ ${MAKE} -f makefile.b32 ps
cd $(THISDIR)
allpdfrtf: pdfrtf portingpdfrtf proppdfrtf
cd $(WXDIR)\utils\dialoged\src
- make -f makefile.b32 pdfrtf
+ ${MAKE} -f makefile.b32 pdfrtf
cd $(THISDIR)
# cd $(WXDIR)\utils\wxhelp\src
-# make -f makefile.b32 ps
+# ${MAKE} -f makefile.b32 ps
# cd $(WXDIR)\utils\tex2rtf\src
-# make -f makefile.b32 ps
+# ${MAKE} -f makefile.b32 ps
# cd $(WXDIR)\utils\wxgraph\src
-# make -f makefile.b32 ps
+# ${MAKE} -f makefile.b32 ps
# cd $(WXDIR)\utils\wxchart\src
-# make -f makefile.b32 ps
+# ${MAKE} -f makefile.b32 ps
# cd $(WXDIR)\utils\wxtree\src
-# make -f makefile.b32 ps
+# ${MAKE} -f makefile.b32 ps
# cd $(THISDIR)
$(DOCDIR)/winhelp/wx.hlp: $(DOCDIR)/latex/wx/wx.rtf $(DOCDIR)/latex/wx/wx.hpj
cd $(THISDIR)
$(DOCDIR)\html\wx\wx.chm : $(DOCDIR)\html\wx\wx.htm $(DOCDIR)\html\wx\wx.hhp
- cd $(DOCDIR)\html\wx
- -hhc wx.hhp
- cd $(THISDIR)
+ cd $(DOCDIR)\html\wx
+ -hhc wx.hhp
+ cd $(THISDIR)
$(DOCDIR)\html\porting\port.htm: $(DOCDIR)\latex\porting\porting.tex
-erase $(DOCDIR)\latex\proplist\*.ref
cd $(THISDIR)
-$(WXDIR)\docs\latex\wx\manual.dvi: $(DOCDIR)/latex/wx/body.tex $(DOCDIR)/latex/wx/manual.tex
- cd $(WXDIR)\docs\latex\wx
+$(WXDIR)\docs\latex\wx\manual.dvi: $(DOCDIR)/latex/wx/body.tex $(DOCDIR)/latex/wx/manual.tex
+ cd $(WXDIR)\docs\latex\wx
-latex manual
-latex manual
-makeindx manual
-latex manual
cd $(THISDIR)
-$(WXDIR)\docs\latex\porting\porting.dvi: $(DOCDIR)/latex/porting/porting.tex
- cd $(WXDIR)\docs\latex\porting
+$(WXDIR)\docs\latex\porting\porting.dvi: $(DOCDIR)/latex/porting/porting.tex
+ cd $(WXDIR)\docs\latex\porting
-latex porting
-latex porting
-makeindx porting
-latex porting
cd $(THISDIR)
-$(WXDIR)\docs\ps\wx.ps: $(WXDIR)\docs\latex\wx\manual.dvi
- cd $(WXDIR)\docs\latex\wx
+$(WXDIR)\docs\ps\wx.ps: $(WXDIR)\docs\latex\wx\manual.dvi
+ cd $(WXDIR)\docs\latex\wx
-dvips32 -o wx.ps manual
move wx.ps $(WXDIR)\docs\ps\wx.ps
cd $(THISDIR)
-$(WXDIR)\docs\ps\porting.ps: $(WXDIR)\docs\latex\porting\porting.dvi
- cd $(WXDIR)\docs\latex\porting
+$(WXDIR)\docs\ps\porting.ps: $(WXDIR)\docs\latex\porting\porting.dvi
+ cd $(WXDIR)\docs\latex\porting
-dvips32 -o porting.ps porting
move porting.ps $(WXDIR)\docs\ps\porting.ps
cd $(THISDIR)
-$(WXDIR)\docs\latex\wx\referenc.dvi: $(DOCDIR)/latex/wx/classes.tex $(DOCDIR)/latex/wx/topics.tex $(DOCDIR)/latex/wx/referenc.tex
- cd $(WXDIR)\docs\latex\wx
+$(WXDIR)\docs\latex\wx\referenc.dvi: $(DOCDIR)/latex/wx/classes.tex $(DOCDIR)/latex/wx/topics.tex $(DOCDIR)/latex/wx/referenc.tex
+ cd $(WXDIR)\docs\latex\wx
-latex referenc
-latex referenc
-makeindx referenc
-latex referenc
cd $(THISDIR)
-$(WXDIR)\docs\ps\referenc.ps: $(WXDIR)\docs\latex\wx\referenc.dvi
- cd $(WXDIR)\docs\latex\wx
+$(WXDIR)\docs\ps\referenc.ps: $(WXDIR)\docs\latex\wx\referenc.dvi
+ cd $(WXDIR)\docs\latex\wx
-dvips32 -o referenc.ps referenc
move referenc.ps $(WXDIR)\docs\ps\referenc.ps
cd $(THISDIR)
# makefile.$(MFTYPE) : $(WXWIN)\distrib\msw\tmake\filelist.txt $(WXWIN)\distrib\msw\tmake\$(MFTYPE).t
self:
- cd $(WXWIN)\distrib\msw\tmake
- tmake -t $(MFTYPE) wxwin.pro -o makefile.$(MFTYPE)
- copy makefile.$(MFTYPE) $(WXWIN)\src\msw
-
+ cd $(WXWIN)\distrib\msw\tmake
+ tmake -t $(MFTYPE) wxwin.pro -o makefile.$(MFTYPE)
+ copy makefile.$(MFTYPE) $(WXWIN)\src\msw