added wxDebugReport
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32744 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
62
Makefile.in
62
Makefile.in
@@ -236,6 +236,7 @@ ALL_BASE_HEADERS = \
|
|||||||
wx/datstrm.h \
|
wx/datstrm.h \
|
||||||
wx/dde.h \
|
wx/dde.h \
|
||||||
wx/debug.h \
|
wx/debug.h \
|
||||||
|
wx/debugrpt.h \
|
||||||
wx/defs.h \
|
wx/defs.h \
|
||||||
wx/dir.h \
|
wx/dir.h \
|
||||||
wx/dlimpexp.h \
|
wx/dlimpexp.h \
|
||||||
@@ -350,6 +351,7 @@ ALL_BASE_SOURCES = \
|
|||||||
src/common/config.cpp \
|
src/common/config.cpp \
|
||||||
src/common/datetime.cpp \
|
src/common/datetime.cpp \
|
||||||
src/common/datstrm.cpp \
|
src/common/datstrm.cpp \
|
||||||
|
src/common/debugrpt.cpp \
|
||||||
src/common/dircmn.cpp \
|
src/common/dircmn.cpp \
|
||||||
src/common/dynarray.cpp \
|
src/common/dynarray.cpp \
|
||||||
src/common/dynlib.cpp \
|
src/common/dynlib.cpp \
|
||||||
@@ -482,6 +484,7 @@ MONODLL_OBJECTS = \
|
|||||||
monodll_config.o \
|
monodll_config.o \
|
||||||
monodll_datetime.o \
|
monodll_datetime.o \
|
||||||
monodll_datstrm.o \
|
monodll_datstrm.o \
|
||||||
|
monodll_debugrpt.o \
|
||||||
monodll_dircmn.o \
|
monodll_dircmn.o \
|
||||||
monodll_dynarray.o \
|
monodll_dynarray.o \
|
||||||
monodll_dynlib.o \
|
monodll_dynlib.o \
|
||||||
@@ -569,6 +572,7 @@ MONOLIB_OBJECTS = \
|
|||||||
monolib_config.o \
|
monolib_config.o \
|
||||||
monolib_datetime.o \
|
monolib_datetime.o \
|
||||||
monolib_datstrm.o \
|
monolib_datstrm.o \
|
||||||
|
monolib_debugrpt.o \
|
||||||
monolib_dircmn.o \
|
monolib_dircmn.o \
|
||||||
monolib_dynarray.o \
|
monolib_dynarray.o \
|
||||||
monolib_dynlib.o \
|
monolib_dynlib.o \
|
||||||
@@ -658,6 +662,7 @@ BASEDLL_OBJECTS = \
|
|||||||
basedll_config.o \
|
basedll_config.o \
|
||||||
basedll_datetime.o \
|
basedll_datetime.o \
|
||||||
basedll_datstrm.o \
|
basedll_datstrm.o \
|
||||||
|
basedll_debugrpt.o \
|
||||||
basedll_dircmn.o \
|
basedll_dircmn.o \
|
||||||
basedll_dynarray.o \
|
basedll_dynarray.o \
|
||||||
basedll_dynlib.o \
|
basedll_dynlib.o \
|
||||||
@@ -730,6 +735,7 @@ BASELIB_OBJECTS = \
|
|||||||
baselib_config.o \
|
baselib_config.o \
|
||||||
baselib_datetime.o \
|
baselib_datetime.o \
|
||||||
baselib_datstrm.o \
|
baselib_datstrm.o \
|
||||||
|
baselib_debugrpt.o \
|
||||||
baselib_dircmn.o \
|
baselib_dircmn.o \
|
||||||
baselib_dynarray.o \
|
baselib_dynarray.o \
|
||||||
baselib_dynlib.o \
|
baselib_dynlib.o \
|
||||||
@@ -2784,6 +2790,7 @@ COND_USE_GUI_1_WXUNIV_0___CORE_SRC_OBJECTS = \
|
|||||||
monodll_choicdgg.o \
|
monodll_choicdgg.o \
|
||||||
monodll_choicbkg.o \
|
monodll_choicbkg.o \
|
||||||
monodll_dcpsg.o \
|
monodll_dcpsg.o \
|
||||||
|
monodll_dbgrptg.o \
|
||||||
monodll_dirctrlg.o \
|
monodll_dirctrlg.o \
|
||||||
monodll_dragimgg.o \
|
monodll_dragimgg.o \
|
||||||
monodll_listbkg.o \
|
monodll_listbkg.o \
|
||||||
@@ -2932,6 +2939,7 @@ COND_USE_GUI_1_WXUNIV_1___CORE_SRC_OBJECTS = \
|
|||||||
monodll_choicdgg.o \
|
monodll_choicdgg.o \
|
||||||
monodll_choicbkg.o \
|
monodll_choicbkg.o \
|
||||||
monodll_dcpsg.o \
|
monodll_dcpsg.o \
|
||||||
|
monodll_dbgrptg.o \
|
||||||
monodll_dirctrlg.o \
|
monodll_dirctrlg.o \
|
||||||
monodll_dragimgg.o \
|
monodll_dragimgg.o \
|
||||||
monodll_listbkg.o \
|
monodll_listbkg.o \
|
||||||
@@ -4236,6 +4244,7 @@ COND_USE_GUI_1_WXUNIV_0___CORE_SRC_OBJECTS_1 = \
|
|||||||
monolib_choicdgg.o \
|
monolib_choicdgg.o \
|
||||||
monolib_choicbkg.o \
|
monolib_choicbkg.o \
|
||||||
monolib_dcpsg.o \
|
monolib_dcpsg.o \
|
||||||
|
monolib_dbgrptg.o \
|
||||||
monolib_dirctrlg.o \
|
monolib_dirctrlg.o \
|
||||||
monolib_dragimgg.o \
|
monolib_dragimgg.o \
|
||||||
monolib_listbkg.o \
|
monolib_listbkg.o \
|
||||||
@@ -4384,6 +4393,7 @@ COND_USE_GUI_1_WXUNIV_1___CORE_SRC_OBJECTS_1 = \
|
|||||||
monolib_choicdgg.o \
|
monolib_choicdgg.o \
|
||||||
monolib_choicbkg.o \
|
monolib_choicbkg.o \
|
||||||
monolib_dcpsg.o \
|
monolib_dcpsg.o \
|
||||||
|
monolib_dbgrptg.o \
|
||||||
monolib_dirctrlg.o \
|
monolib_dirctrlg.o \
|
||||||
monolib_dragimgg.o \
|
monolib_dragimgg.o \
|
||||||
monolib_listbkg.o \
|
monolib_listbkg.o \
|
||||||
@@ -5916,6 +5926,7 @@ COND_USE_GUI_1_WXUNIV_0___CORE_SRC_OBJECTS_2 = \
|
|||||||
coredll_choicdgg.o \
|
coredll_choicdgg.o \
|
||||||
coredll_choicbkg.o \
|
coredll_choicbkg.o \
|
||||||
coredll_dcpsg.o \
|
coredll_dcpsg.o \
|
||||||
|
coredll_dbgrptg.o \
|
||||||
coredll_dirctrlg.o \
|
coredll_dirctrlg.o \
|
||||||
coredll_dragimgg.o \
|
coredll_dragimgg.o \
|
||||||
coredll_listbkg.o \
|
coredll_listbkg.o \
|
||||||
@@ -6064,6 +6075,7 @@ COND_USE_GUI_1_WXUNIV_1___CORE_SRC_OBJECTS_2 = \
|
|||||||
coredll_choicdgg.o \
|
coredll_choicdgg.o \
|
||||||
coredll_choicbkg.o \
|
coredll_choicbkg.o \
|
||||||
coredll_dcpsg.o \
|
coredll_dcpsg.o \
|
||||||
|
coredll_dbgrptg.o \
|
||||||
coredll_dirctrlg.o \
|
coredll_dirctrlg.o \
|
||||||
coredll_dragimgg.o \
|
coredll_dragimgg.o \
|
||||||
coredll_listbkg.o \
|
coredll_listbkg.o \
|
||||||
@@ -7108,6 +7120,7 @@ COND_USE_GUI_1_WXUNIV_0___CORE_SRC_OBJECTS_3 = \
|
|||||||
corelib_choicdgg.o \
|
corelib_choicdgg.o \
|
||||||
corelib_choicbkg.o \
|
corelib_choicbkg.o \
|
||||||
corelib_dcpsg.o \
|
corelib_dcpsg.o \
|
||||||
|
corelib_dbgrptg.o \
|
||||||
corelib_dirctrlg.o \
|
corelib_dirctrlg.o \
|
||||||
corelib_dragimgg.o \
|
corelib_dragimgg.o \
|
||||||
corelib_listbkg.o \
|
corelib_listbkg.o \
|
||||||
@@ -7256,6 +7269,7 @@ COND_USE_GUI_1_WXUNIV_1___CORE_SRC_OBJECTS_3 = \
|
|||||||
corelib_choicdgg.o \
|
corelib_choicdgg.o \
|
||||||
corelib_choicbkg.o \
|
corelib_choicbkg.o \
|
||||||
corelib_dcpsg.o \
|
corelib_dcpsg.o \
|
||||||
|
corelib_dbgrptg.o \
|
||||||
corelib_dirctrlg.o \
|
corelib_dirctrlg.o \
|
||||||
corelib_dragimgg.o \
|
corelib_dragimgg.o \
|
||||||
corelib_listbkg.o \
|
corelib_listbkg.o \
|
||||||
@@ -9896,6 +9910,9 @@ monodll_datetime.o: $(srcdir)/src/common/datetime.cpp $(MONODLL_ODEP)
|
|||||||
monodll_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(MONODLL_ODEP)
|
monodll_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(MONODLL_ODEP)
|
||||||
$(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
$(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
||||||
|
|
||||||
|
monodll_debugrpt.o: $(srcdir)/src/common/debugrpt.cpp $(MONODLL_ODEP)
|
||||||
|
$(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/common/debugrpt.cpp
|
||||||
|
|
||||||
monodll_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(MONODLL_ODEP)
|
monodll_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(MONODLL_ODEP)
|
||||||
$(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
$(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
||||||
|
|
||||||
@@ -13118,6 +13135,9 @@ monodll_sound_sdl.o: $(srcdir)/src/unix/sound_sdl.cpp $(MONODLL_ODEP)
|
|||||||
@COND_USE_GUI_1@monodll_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(MONODLL_ODEP)
|
@COND_USE_GUI_1@monodll_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(MONODLL_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
||||||
|
|
||||||
|
@COND_USE_GUI_1@monodll_dbgrptg.o: $(srcdir)/src/generic/dbgrptg.cpp $(MONODLL_ODEP)
|
||||||
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/generic/dbgrptg.cpp
|
||||||
|
|
||||||
@COND_USE_GUI_1@monodll_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(MONODLL_ODEP)
|
@COND_USE_GUI_1@monodll_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(MONODLL_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
||||||
|
|
||||||
@@ -13322,6 +13342,9 @@ monolib_datetime.o: $(srcdir)/src/common/datetime.cpp $(MONOLIB_ODEP)
|
|||||||
monolib_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(MONOLIB_ODEP)
|
monolib_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(MONOLIB_ODEP)
|
||||||
$(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
$(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
||||||
|
|
||||||
|
monolib_debugrpt.o: $(srcdir)/src/common/debugrpt.cpp $(MONOLIB_ODEP)
|
||||||
|
$(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/common/debugrpt.cpp
|
||||||
|
|
||||||
monolib_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(MONOLIB_ODEP)
|
monolib_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(MONOLIB_ODEP)
|
||||||
$(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
$(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
||||||
|
|
||||||
@@ -16544,6 +16567,9 @@ monolib_sound_sdl.o: $(srcdir)/src/unix/sound_sdl.cpp $(MONOLIB_ODEP)
|
|||||||
@COND_USE_GUI_1@monolib_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(MONOLIB_ODEP)
|
@COND_USE_GUI_1@monolib_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(MONOLIB_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
||||||
|
|
||||||
|
@COND_USE_GUI_1@monolib_dbgrptg.o: $(srcdir)/src/generic/dbgrptg.cpp $(MONOLIB_ODEP)
|
||||||
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/generic/dbgrptg.cpp
|
||||||
|
|
||||||
@COND_USE_GUI_1@monolib_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(MONOLIB_ODEP)
|
@COND_USE_GUI_1@monolib_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(MONOLIB_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
||||||
|
|
||||||
@@ -16751,6 +16777,9 @@ basedll_datetime.o: $(srcdir)/src/common/datetime.cpp $(BASEDLL_ODEP)
|
|||||||
basedll_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(BASEDLL_ODEP)
|
basedll_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(BASEDLL_ODEP)
|
||||||
$(CXXC) -c -o $@ $(BASEDLL_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
$(CXXC) -c -o $@ $(BASEDLL_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
||||||
|
|
||||||
|
basedll_debugrpt.o: $(srcdir)/src/common/debugrpt.cpp $(BASEDLL_ODEP)
|
||||||
|
$(CXXC) -c -o $@ $(BASEDLL_CXXFLAGS) $(srcdir)/src/common/debugrpt.cpp
|
||||||
|
|
||||||
basedll_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(BASEDLL_ODEP)
|
basedll_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(BASEDLL_ODEP)
|
||||||
$(CXXC) -c -o $@ $(BASEDLL_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
$(CXXC) -c -o $@ $(BASEDLL_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
||||||
|
|
||||||
@@ -17294,6 +17323,9 @@ baselib_datetime.o: $(srcdir)/src/common/datetime.cpp $(BASELIB_ODEP)
|
|||||||
baselib_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(BASELIB_ODEP)
|
baselib_datstrm.o: $(srcdir)/src/common/datstrm.cpp $(BASELIB_ODEP)
|
||||||
$(CXXC) -c -o $@ $(BASELIB_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
$(CXXC) -c -o $@ $(BASELIB_CXXFLAGS) $(srcdir)/src/common/datstrm.cpp
|
||||||
|
|
||||||
|
baselib_debugrpt.o: $(srcdir)/src/common/debugrpt.cpp $(BASELIB_ODEP)
|
||||||
|
$(CXXC) -c -o $@ $(BASELIB_CXXFLAGS) $(srcdir)/src/common/debugrpt.cpp
|
||||||
|
|
||||||
baselib_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(BASELIB_ODEP)
|
baselib_dircmn.o: $(srcdir)/src/common/dircmn.cpp $(BASELIB_ODEP)
|
||||||
$(CXXC) -c -o $@ $(BASELIB_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
$(CXXC) -c -o $@ $(BASELIB_CXXFLAGS) $(srcdir)/src/common/dircmn.cpp
|
||||||
|
|
||||||
@@ -20366,6 +20398,9 @@ coredll_win32.o: $(srcdir)/src/univ/themes/win32.cpp $(COREDLL_ODEP)
|
|||||||
@COND_USE_GUI_1@coredll_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(COREDLL_ODEP)
|
@COND_USE_GUI_1@coredll_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(COREDLL_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(COREDLL_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(COREDLL_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
||||||
|
|
||||||
|
@COND_USE_GUI_1@coredll_dbgrptg.o: $(srcdir)/src/generic/dbgrptg.cpp $(COREDLL_ODEP)
|
||||||
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(COREDLL_CXXFLAGS) $(srcdir)/src/generic/dbgrptg.cpp
|
||||||
|
|
||||||
@COND_USE_GUI_1@coredll_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(COREDLL_ODEP)
|
@COND_USE_GUI_1@coredll_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(COREDLL_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(COREDLL_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(COREDLL_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
||||||
|
|
||||||
@@ -22862,6 +22897,9 @@ corelib_win32.o: $(srcdir)/src/univ/themes/win32.cpp $(CORELIB_ODEP)
|
|||||||
@COND_USE_GUI_1@corelib_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(CORELIB_ODEP)
|
@COND_USE_GUI_1@corelib_dcpsg.o: $(srcdir)/src/generic/dcpsg.cpp $(CORELIB_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(CORELIB_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(CORELIB_CXXFLAGS) $(srcdir)/src/generic/dcpsg.cpp
|
||||||
|
|
||||||
|
@COND_USE_GUI_1@corelib_dbgrptg.o: $(srcdir)/src/generic/dbgrptg.cpp $(CORELIB_ODEP)
|
||||||
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(CORELIB_CXXFLAGS) $(srcdir)/src/generic/dbgrptg.cpp
|
||||||
|
|
||||||
@COND_USE_GUI_1@corelib_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(CORELIB_ODEP)
|
@COND_USE_GUI_1@corelib_dirctrlg.o: $(srcdir)/src/generic/dirctrlg.cpp $(CORELIB_ODEP)
|
||||||
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(CORELIB_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
@COND_USE_GUI_1@ $(CXXC) -c -o $@ $(CORELIB_CXXFLAGS) $(srcdir)/src/generic/dirctrlg.cpp
|
||||||
|
|
||||||
@@ -24408,6 +24446,10 @@ SAMPLES_DIST: ALL_GUI_DIST
|
|||||||
cp $(SAMPDIR)/listctrl/*.xpm $(DISTDIR)/samples/listctrl
|
cp $(SAMPDIR)/listctrl/*.xpm $(DISTDIR)/samples/listctrl
|
||||||
cp $(SAMPDIR)/listctrl/bitmaps/*.xpm $(DISTDIR)/samples/listctrl/bitmaps
|
cp $(SAMPDIR)/listctrl/bitmaps/*.xpm $(DISTDIR)/samples/listctrl/bitmaps
|
||||||
|
|
||||||
|
mkdir $(DISTDIR)/samples/mediaplayer
|
||||||
|
cp $(SAMPDIR)/mediaplayer/Makefile.in $(DISTDIR)/samples/mediaplayer
|
||||||
|
cp $(SAMPDIR)/mediaplayer/*.cpp $(DISTDIR)/samples/mediaplayer
|
||||||
|
|
||||||
mkdir $(DISTDIR)/samples/mdi
|
mkdir $(DISTDIR)/samples/mdi
|
||||||
mkdir $(DISTDIR)/samples/mdi/bitmaps
|
mkdir $(DISTDIR)/samples/mdi/bitmaps
|
||||||
cp $(SAMPDIR)/mdi/Makefile.in $(DISTDIR)/samples/mdi
|
cp $(SAMPDIR)/mdi/Makefile.in $(DISTDIR)/samples/mdi
|
||||||
@@ -24495,6 +24537,11 @@ SAMPLES_DIST: ALL_GUI_DIST
|
|||||||
cp $(SAMPDIR)/png/*.h $(DISTDIR)/samples/png
|
cp $(SAMPDIR)/png/*.h $(DISTDIR)/samples/png
|
||||||
cp $(SAMPDIR)/png/*.png $(DISTDIR)/samples/png
|
cp $(SAMPDIR)/png/*.png $(DISTDIR)/samples/png
|
||||||
|
|
||||||
|
mkdir $(DISTDIR)/samples/popup
|
||||||
|
cp $(SAMPDIR)/popup/Makefile.in $(DISTDIR)/samples/popup
|
||||||
|
cp $(SAMPDIR)/popup/makefile.unx $(DISTDIR)/samples/popup
|
||||||
|
cp $(SAMPDIR)/popup/*.cpp $(DISTDIR)/samples/popup
|
||||||
|
|
||||||
mkdir $(DISTDIR)/samples/printing
|
mkdir $(DISTDIR)/samples/printing
|
||||||
cp $(SAMPDIR)/printing/Makefile.in $(DISTDIR)/samples/printing
|
cp $(SAMPDIR)/printing/Makefile.in $(DISTDIR)/samples/printing
|
||||||
cp $(SAMPDIR)/printing/makefile.unx $(DISTDIR)/samples/printing
|
cp $(SAMPDIR)/printing/makefile.unx $(DISTDIR)/samples/printing
|
||||||
@@ -24638,6 +24685,10 @@ SAMPLES_DIST: ALL_GUI_DIST
|
|||||||
cp $(SAMPDIR)/validate/*.h $(DISTDIR)/samples/validate
|
cp $(SAMPDIR)/validate/*.h $(DISTDIR)/samples/validate
|
||||||
cp $(SAMPDIR)/validate/*.xpm $(DISTDIR)/samples/validate
|
cp $(SAMPDIR)/validate/*.xpm $(DISTDIR)/samples/validate
|
||||||
|
|
||||||
|
mkdir $(DISTDIR)/samples/vscroll
|
||||||
|
cp $(SAMPDIR)/vscroll/Makefile.in $(DISTDIR)/samples/vscroll
|
||||||
|
cp $(SAMPDIR)/vscroll/*.cpp $(DISTDIR)/samples/vscroll
|
||||||
|
|
||||||
mkdir $(DISTDIR)/samples/wizard
|
mkdir $(DISTDIR)/samples/wizard
|
||||||
cp $(SAMPDIR)/wizard/Makefile.in $(DISTDIR)/samples/wizard
|
cp $(SAMPDIR)/wizard/Makefile.in $(DISTDIR)/samples/wizard
|
||||||
cp $(SAMPDIR)/wizard/makefile.unx $(DISTDIR)/samples/wizard
|
cp $(SAMPDIR)/wizard/makefile.unx $(DISTDIR)/samples/wizard
|
||||||
@@ -24652,6 +24703,17 @@ SAMPLES_DIST: ALL_GUI_DIST
|
|||||||
cp $(SAMPDIR)/widgets/*.rc $(DISTDIR)/samples/widgets
|
cp $(SAMPDIR)/widgets/*.rc $(DISTDIR)/samples/widgets
|
||||||
cp $(SAMPDIR)/widgets/icons/*.xpm $(DISTDIR)/samples/widgets/icons
|
cp $(SAMPDIR)/widgets/icons/*.xpm $(DISTDIR)/samples/widgets/icons
|
||||||
|
|
||||||
|
mkdir $(DISTDIR)/samples/xrc
|
||||||
|
mkdir $(DISTDIR)/samples/xrc/rc
|
||||||
|
cp $(SAMPDIR)/xrc/Makefile.in $(DISTDIR)/samples/xrc
|
||||||
|
cp $(SAMPDIR)/xrc/*.cpp $(DISTDIR)/samples/xrc
|
||||||
|
cp $(SAMPDIR)/xrc/*.h $(DISTDIR)/samples/xrc
|
||||||
|
cp $(SAMPDIR)/xrc/*.rc $(DISTDIR)/samples/xrc
|
||||||
|
cp $(SAMPDIR)/xrc/rc/*.xpm $(DISTDIR)/samples/widgets/rc
|
||||||
|
cp $(SAMPDIR)/xrc/rc/*.xrc $(DISTDIR)/samples/widgets/rc
|
||||||
|
cp $(SAMPDIR)/xrc/rc/*.gif $(DISTDIR)/samples/widgets/rc
|
||||||
|
cp $(SAMPDIR)/xrc/rc/*.ico $(DISTDIR)/samples/widgets/rc
|
||||||
|
|
||||||
UTILS_DIST: ALL_GUI_DIST
|
UTILS_DIST: ALL_GUI_DIST
|
||||||
mkdir $(DISTDIR)/utils
|
mkdir $(DISTDIR)/utils
|
||||||
cp $(UTILSDIR)/Makefile.in $(DISTDIR)/utils
|
cp $(UTILSDIR)/Makefile.in $(DISTDIR)/utils
|
||||||
|
@@ -260,6 +260,7 @@ IMPORTANT: please read docs/tech/tn0016.txt before modifying this file!
|
|||||||
src/common/config.cpp
|
src/common/config.cpp
|
||||||
src/common/datetime.cpp
|
src/common/datetime.cpp
|
||||||
src/common/datstrm.cpp
|
src/common/datstrm.cpp
|
||||||
|
src/common/debugrpt.cpp
|
||||||
src/common/dircmn.cpp
|
src/common/dircmn.cpp
|
||||||
src/common/dynarray.cpp
|
src/common/dynarray.cpp
|
||||||
src/common/dynlib.cpp
|
src/common/dynlib.cpp
|
||||||
@@ -336,6 +337,7 @@ IMPORTANT: please read docs/tech/tn0016.txt before modifying this file!
|
|||||||
wx/datstrm.h
|
wx/datstrm.h
|
||||||
wx/dde.h
|
wx/dde.h
|
||||||
wx/debug.h
|
wx/debug.h
|
||||||
|
wx/debugrpt.h
|
||||||
wx/defs.h
|
wx/defs.h
|
||||||
wx/dir.h
|
wx/dir.h
|
||||||
wx/dlimpexp.h
|
wx/dlimpexp.h
|
||||||
@@ -575,6 +577,7 @@ IMPORTANT: please read docs/tech/tn0016.txt before modifying this file!
|
|||||||
src/generic/choicdgg.cpp
|
src/generic/choicdgg.cpp
|
||||||
src/generic/choicbkg.cpp
|
src/generic/choicbkg.cpp
|
||||||
src/generic/dcpsg.cpp
|
src/generic/dcpsg.cpp
|
||||||
|
src/generic/dbgrptg.cpp
|
||||||
src/generic/dirctrlg.cpp
|
src/generic/dirctrlg.cpp
|
||||||
src/generic/dragimgg.cpp
|
src/generic/dragimgg.cpp
|
||||||
src/generic/listbkg.cpp
|
src/generic/listbkg.cpp
|
||||||
|
@@ -203,6 +203,7 @@ MONODLL_OBJECTS = \
|
|||||||
$(OBJS)\monodll_config.obj \
|
$(OBJS)\monodll_config.obj \
|
||||||
$(OBJS)\monodll_datetime.obj \
|
$(OBJS)\monodll_datetime.obj \
|
||||||
$(OBJS)\monodll_datstrm.obj \
|
$(OBJS)\monodll_datstrm.obj \
|
||||||
|
$(OBJS)\monodll_debugrpt.obj \
|
||||||
$(OBJS)\monodll_dircmn.obj \
|
$(OBJS)\monodll_dircmn.obj \
|
||||||
$(OBJS)\monodll_dynarray.obj \
|
$(OBJS)\monodll_dynarray.obj \
|
||||||
$(OBJS)\monodll_dynlib.obj \
|
$(OBJS)\monodll_dynlib.obj \
|
||||||
@@ -308,6 +309,7 @@ MONOLIB_OBJECTS = \
|
|||||||
$(OBJS)\monolib_config.obj \
|
$(OBJS)\monolib_config.obj \
|
||||||
$(OBJS)\monolib_datetime.obj \
|
$(OBJS)\monolib_datetime.obj \
|
||||||
$(OBJS)\monolib_datstrm.obj \
|
$(OBJS)\monolib_datstrm.obj \
|
||||||
|
$(OBJS)\monolib_debugrpt.obj \
|
||||||
$(OBJS)\monolib_dircmn.obj \
|
$(OBJS)\monolib_dircmn.obj \
|
||||||
$(OBJS)\monolib_dynarray.obj \
|
$(OBJS)\monolib_dynarray.obj \
|
||||||
$(OBJS)\monolib_dynlib.obj \
|
$(OBJS)\monolib_dynlib.obj \
|
||||||
@@ -414,6 +416,7 @@ BASEDLL_OBJECTS = \
|
|||||||
$(OBJS)\basedll_config.obj \
|
$(OBJS)\basedll_config.obj \
|
||||||
$(OBJS)\basedll_datetime.obj \
|
$(OBJS)\basedll_datetime.obj \
|
||||||
$(OBJS)\basedll_datstrm.obj \
|
$(OBJS)\basedll_datstrm.obj \
|
||||||
|
$(OBJS)\basedll_debugrpt.obj \
|
||||||
$(OBJS)\basedll_dircmn.obj \
|
$(OBJS)\basedll_dircmn.obj \
|
||||||
$(OBJS)\basedll_dynarray.obj \
|
$(OBJS)\basedll_dynarray.obj \
|
||||||
$(OBJS)\basedll_dynlib.obj \
|
$(OBJS)\basedll_dynlib.obj \
|
||||||
@@ -505,6 +508,7 @@ BASELIB_OBJECTS = \
|
|||||||
$(OBJS)\baselib_config.obj \
|
$(OBJS)\baselib_config.obj \
|
||||||
$(OBJS)\baselib_datetime.obj \
|
$(OBJS)\baselib_datetime.obj \
|
||||||
$(OBJS)\baselib_datstrm.obj \
|
$(OBJS)\baselib_datstrm.obj \
|
||||||
|
$(OBJS)\baselib_debugrpt.obj \
|
||||||
$(OBJS)\baselib_dircmn.obj \
|
$(OBJS)\baselib_dircmn.obj \
|
||||||
$(OBJS)\baselib_dynarray.obj \
|
$(OBJS)\baselib_dynarray.obj \
|
||||||
$(OBJS)\baselib_dynlib.obj \
|
$(OBJS)\baselib_dynlib.obj \
|
||||||
@@ -1227,6 +1231,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = \
|
|||||||
$(OBJS)\monodll_choicdgg.obj \
|
$(OBJS)\monodll_choicdgg.obj \
|
||||||
$(OBJS)\monodll_choicbkg.obj \
|
$(OBJS)\monodll_choicbkg.obj \
|
||||||
$(OBJS)\monodll_dcpsg.obj \
|
$(OBJS)\monodll_dcpsg.obj \
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj \
|
||||||
$(OBJS)\monodll_dirctrlg.obj \
|
$(OBJS)\monodll_dirctrlg.obj \
|
||||||
$(OBJS)\monodll_dragimgg.obj \
|
$(OBJS)\monodll_dragimgg.obj \
|
||||||
$(OBJS)\monodll_listbkg.obj \
|
$(OBJS)\monodll_listbkg.obj \
|
||||||
@@ -1423,6 +1428,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = \
|
|||||||
$(OBJS)\monodll_choicdgg.obj \
|
$(OBJS)\monodll_choicdgg.obj \
|
||||||
$(OBJS)\monodll_choicbkg.obj \
|
$(OBJS)\monodll_choicbkg.obj \
|
||||||
$(OBJS)\monodll_dcpsg.obj \
|
$(OBJS)\monodll_dcpsg.obj \
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj \
|
||||||
$(OBJS)\monodll_dirctrlg.obj \
|
$(OBJS)\monodll_dirctrlg.obj \
|
||||||
$(OBJS)\monodll_dragimgg.obj \
|
$(OBJS)\monodll_dragimgg.obj \
|
||||||
$(OBJS)\monodll_listbkg.obj \
|
$(OBJS)\monodll_listbkg.obj \
|
||||||
@@ -1733,6 +1739,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = \
|
|||||||
$(OBJS)\monolib_choicdgg.obj \
|
$(OBJS)\monolib_choicdgg.obj \
|
||||||
$(OBJS)\monolib_choicbkg.obj \
|
$(OBJS)\monolib_choicbkg.obj \
|
||||||
$(OBJS)\monolib_dcpsg.obj \
|
$(OBJS)\monolib_dcpsg.obj \
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj \
|
||||||
$(OBJS)\monolib_dirctrlg.obj \
|
$(OBJS)\monolib_dirctrlg.obj \
|
||||||
$(OBJS)\monolib_dragimgg.obj \
|
$(OBJS)\monolib_dragimgg.obj \
|
||||||
$(OBJS)\monolib_listbkg.obj \
|
$(OBJS)\monolib_listbkg.obj \
|
||||||
@@ -1929,6 +1936,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = \
|
|||||||
$(OBJS)\monolib_choicdgg.obj \
|
$(OBJS)\monolib_choicdgg.obj \
|
||||||
$(OBJS)\monolib_choicbkg.obj \
|
$(OBJS)\monolib_choicbkg.obj \
|
||||||
$(OBJS)\monolib_dcpsg.obj \
|
$(OBJS)\monolib_dcpsg.obj \
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj \
|
||||||
$(OBJS)\monolib_dirctrlg.obj \
|
$(OBJS)\monolib_dirctrlg.obj \
|
||||||
$(OBJS)\monolib_dragimgg.obj \
|
$(OBJS)\monolib_dragimgg.obj \
|
||||||
$(OBJS)\monolib_listbkg.obj \
|
$(OBJS)\monolib_listbkg.obj \
|
||||||
@@ -2181,6 +2189,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = \
|
|||||||
$(OBJS)\coredll_choicdgg.obj \
|
$(OBJS)\coredll_choicdgg.obj \
|
||||||
$(OBJS)\coredll_choicbkg.obj \
|
$(OBJS)\coredll_choicbkg.obj \
|
||||||
$(OBJS)\coredll_dcpsg.obj \
|
$(OBJS)\coredll_dcpsg.obj \
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj \
|
||||||
$(OBJS)\coredll_dirctrlg.obj \
|
$(OBJS)\coredll_dirctrlg.obj \
|
||||||
$(OBJS)\coredll_dragimgg.obj \
|
$(OBJS)\coredll_dragimgg.obj \
|
||||||
$(OBJS)\coredll_listbkg.obj \
|
$(OBJS)\coredll_listbkg.obj \
|
||||||
@@ -2377,6 +2386,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = \
|
|||||||
$(OBJS)\coredll_choicdgg.obj \
|
$(OBJS)\coredll_choicdgg.obj \
|
||||||
$(OBJS)\coredll_choicbkg.obj \
|
$(OBJS)\coredll_choicbkg.obj \
|
||||||
$(OBJS)\coredll_dcpsg.obj \
|
$(OBJS)\coredll_dcpsg.obj \
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj \
|
||||||
$(OBJS)\coredll_dirctrlg.obj \
|
$(OBJS)\coredll_dirctrlg.obj \
|
||||||
$(OBJS)\coredll_dragimgg.obj \
|
$(OBJS)\coredll_dragimgg.obj \
|
||||||
$(OBJS)\coredll_listbkg.obj \
|
$(OBJS)\coredll_listbkg.obj \
|
||||||
@@ -2576,6 +2586,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = \
|
|||||||
$(OBJS)\corelib_choicdgg.obj \
|
$(OBJS)\corelib_choicdgg.obj \
|
||||||
$(OBJS)\corelib_choicbkg.obj \
|
$(OBJS)\corelib_choicbkg.obj \
|
||||||
$(OBJS)\corelib_dcpsg.obj \
|
$(OBJS)\corelib_dcpsg.obj \
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj \
|
||||||
$(OBJS)\corelib_dirctrlg.obj \
|
$(OBJS)\corelib_dirctrlg.obj \
|
||||||
$(OBJS)\corelib_dragimgg.obj \
|
$(OBJS)\corelib_dragimgg.obj \
|
||||||
$(OBJS)\corelib_listbkg.obj \
|
$(OBJS)\corelib_listbkg.obj \
|
||||||
@@ -2772,6 +2783,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = \
|
|||||||
$(OBJS)\corelib_choicdgg.obj \
|
$(OBJS)\corelib_choicdgg.obj \
|
||||||
$(OBJS)\corelib_choicbkg.obj \
|
$(OBJS)\corelib_choicbkg.obj \
|
||||||
$(OBJS)\corelib_dcpsg.obj \
|
$(OBJS)\corelib_dcpsg.obj \
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj \
|
||||||
$(OBJS)\corelib_dirctrlg.obj \
|
$(OBJS)\corelib_dirctrlg.obj \
|
||||||
$(OBJS)\corelib_dragimgg.obj \
|
$(OBJS)\corelib_dragimgg.obj \
|
||||||
$(OBJS)\corelib_listbkg.obj \
|
$(OBJS)\corelib_listbkg.obj \
|
||||||
@@ -3808,6 +3820,9 @@ $(OBJS)\monodll_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\monodll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\monodll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\monodll_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\monodll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\monodll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -5290,6 +5305,11 @@ $(OBJS)\monodll_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\monodll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\monodll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONODLL_CXXFLAGS) $**
|
||||||
@@ -5479,6 +5499,9 @@ $(OBJS)\monolib_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\monolib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\monolib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\monolib_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\monolib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\monolib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -6961,6 +6984,11 @@ $(OBJS)\monolib_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\monolib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\monolib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
@@ -7153,6 +7181,9 @@ $(OBJS)\basedll_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\basedll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\basedll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(BASEDLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(BASEDLL_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\basedll_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(BASEDLL_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\basedll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\basedll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(BASEDLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(BASEDLL_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -7387,6 +7418,9 @@ $(OBJS)\baselib_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\baselib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\baselib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(BASELIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(BASELIB_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\baselib_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(BASELIB_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\baselib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\baselib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(BASELIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(BASELIB_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -8725,6 +8759,11 @@ $(OBJS)\coredll_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -q -c -P -o$@ $(COREDLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(COREDLL_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(COREDLL_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\coredll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\coredll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(COREDLL_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(COREDLL_CXXFLAGS) $**
|
||||||
@@ -9859,6 +9898,11 @@ $(OBJS)\corelib_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -q -c -P -o$@ $(CORELIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(CORELIB_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(CORELIB_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\corelib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\corelib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(CORELIB_CXXFLAGS) $**
|
$(CXX) -q -c -P -o$@ $(CORELIB_CXXFLAGS) $**
|
||||||
|
@@ -187,6 +187,7 @@ MONODLL_OBJECTS = \
|
|||||||
$(OBJS)\monodll_config.o \
|
$(OBJS)\monodll_config.o \
|
||||||
$(OBJS)\monodll_datetime.o \
|
$(OBJS)\monodll_datetime.o \
|
||||||
$(OBJS)\monodll_datstrm.o \
|
$(OBJS)\monodll_datstrm.o \
|
||||||
|
$(OBJS)\monodll_debugrpt.o \
|
||||||
$(OBJS)\monodll_dircmn.o \
|
$(OBJS)\monodll_dircmn.o \
|
||||||
$(OBJS)\monodll_dynarray.o \
|
$(OBJS)\monodll_dynarray.o \
|
||||||
$(OBJS)\monodll_dynlib.o \
|
$(OBJS)\monodll_dynlib.o \
|
||||||
@@ -292,6 +293,7 @@ MONOLIB_OBJECTS = \
|
|||||||
$(OBJS)\monolib_config.o \
|
$(OBJS)\monolib_config.o \
|
||||||
$(OBJS)\monolib_datetime.o \
|
$(OBJS)\monolib_datetime.o \
|
||||||
$(OBJS)\monolib_datstrm.o \
|
$(OBJS)\monolib_datstrm.o \
|
||||||
|
$(OBJS)\monolib_debugrpt.o \
|
||||||
$(OBJS)\monolib_dircmn.o \
|
$(OBJS)\monolib_dircmn.o \
|
||||||
$(OBJS)\monolib_dynarray.o \
|
$(OBJS)\monolib_dynarray.o \
|
||||||
$(OBJS)\monolib_dynlib.o \
|
$(OBJS)\monolib_dynlib.o \
|
||||||
@@ -398,6 +400,7 @@ BASEDLL_OBJECTS = \
|
|||||||
$(OBJS)\basedll_config.o \
|
$(OBJS)\basedll_config.o \
|
||||||
$(OBJS)\basedll_datetime.o \
|
$(OBJS)\basedll_datetime.o \
|
||||||
$(OBJS)\basedll_datstrm.o \
|
$(OBJS)\basedll_datstrm.o \
|
||||||
|
$(OBJS)\basedll_debugrpt.o \
|
||||||
$(OBJS)\basedll_dircmn.o \
|
$(OBJS)\basedll_dircmn.o \
|
||||||
$(OBJS)\basedll_dynarray.o \
|
$(OBJS)\basedll_dynarray.o \
|
||||||
$(OBJS)\basedll_dynlib.o \
|
$(OBJS)\basedll_dynlib.o \
|
||||||
@@ -488,6 +491,7 @@ BASELIB_OBJECTS = \
|
|||||||
$(OBJS)\baselib_config.o \
|
$(OBJS)\baselib_config.o \
|
||||||
$(OBJS)\baselib_datetime.o \
|
$(OBJS)\baselib_datetime.o \
|
||||||
$(OBJS)\baselib_datstrm.o \
|
$(OBJS)\baselib_datstrm.o \
|
||||||
|
$(OBJS)\baselib_debugrpt.o \
|
||||||
$(OBJS)\baselib_dircmn.o \
|
$(OBJS)\baselib_dircmn.o \
|
||||||
$(OBJS)\baselib_dynarray.o \
|
$(OBJS)\baselib_dynarray.o \
|
||||||
$(OBJS)\baselib_dynlib.o \
|
$(OBJS)\baselib_dynlib.o \
|
||||||
@@ -1230,6 +1234,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = \
|
|||||||
$(OBJS)\monodll_choicdgg.o \
|
$(OBJS)\monodll_choicdgg.o \
|
||||||
$(OBJS)\monodll_choicbkg.o \
|
$(OBJS)\monodll_choicbkg.o \
|
||||||
$(OBJS)\monodll_dcpsg.o \
|
$(OBJS)\monodll_dcpsg.o \
|
||||||
|
$(OBJS)\monodll_dbgrptg.o \
|
||||||
$(OBJS)\monodll_dirctrlg.o \
|
$(OBJS)\monodll_dirctrlg.o \
|
||||||
$(OBJS)\monodll_dragimgg.o \
|
$(OBJS)\monodll_dragimgg.o \
|
||||||
$(OBJS)\monodll_listbkg.o \
|
$(OBJS)\monodll_listbkg.o \
|
||||||
@@ -1428,6 +1433,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = \
|
|||||||
$(OBJS)\monodll_choicdgg.o \
|
$(OBJS)\monodll_choicdgg.o \
|
||||||
$(OBJS)\monodll_choicbkg.o \
|
$(OBJS)\monodll_choicbkg.o \
|
||||||
$(OBJS)\monodll_dcpsg.o \
|
$(OBJS)\monodll_dcpsg.o \
|
||||||
|
$(OBJS)\monodll_dbgrptg.o \
|
||||||
$(OBJS)\monodll_dirctrlg.o \
|
$(OBJS)\monodll_dirctrlg.o \
|
||||||
$(OBJS)\monodll_dragimgg.o \
|
$(OBJS)\monodll_dragimgg.o \
|
||||||
$(OBJS)\monodll_listbkg.o \
|
$(OBJS)\monodll_listbkg.o \
|
||||||
@@ -1742,6 +1748,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = \
|
|||||||
$(OBJS)\monolib_choicdgg.o \
|
$(OBJS)\monolib_choicdgg.o \
|
||||||
$(OBJS)\monolib_choicbkg.o \
|
$(OBJS)\monolib_choicbkg.o \
|
||||||
$(OBJS)\monolib_dcpsg.o \
|
$(OBJS)\monolib_dcpsg.o \
|
||||||
|
$(OBJS)\monolib_dbgrptg.o \
|
||||||
$(OBJS)\monolib_dirctrlg.o \
|
$(OBJS)\monolib_dirctrlg.o \
|
||||||
$(OBJS)\monolib_dragimgg.o \
|
$(OBJS)\monolib_dragimgg.o \
|
||||||
$(OBJS)\monolib_listbkg.o \
|
$(OBJS)\monolib_listbkg.o \
|
||||||
@@ -1940,6 +1947,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = \
|
|||||||
$(OBJS)\monolib_choicdgg.o \
|
$(OBJS)\monolib_choicdgg.o \
|
||||||
$(OBJS)\monolib_choicbkg.o \
|
$(OBJS)\monolib_choicbkg.o \
|
||||||
$(OBJS)\monolib_dcpsg.o \
|
$(OBJS)\monolib_dcpsg.o \
|
||||||
|
$(OBJS)\monolib_dbgrptg.o \
|
||||||
$(OBJS)\monolib_dirctrlg.o \
|
$(OBJS)\monolib_dirctrlg.o \
|
||||||
$(OBJS)\monolib_dragimgg.o \
|
$(OBJS)\monolib_dragimgg.o \
|
||||||
$(OBJS)\monolib_listbkg.o \
|
$(OBJS)\monolib_listbkg.o \
|
||||||
@@ -2206,6 +2214,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = \
|
|||||||
$(OBJS)\coredll_choicdgg.o \
|
$(OBJS)\coredll_choicdgg.o \
|
||||||
$(OBJS)\coredll_choicbkg.o \
|
$(OBJS)\coredll_choicbkg.o \
|
||||||
$(OBJS)\coredll_dcpsg.o \
|
$(OBJS)\coredll_dcpsg.o \
|
||||||
|
$(OBJS)\coredll_dbgrptg.o \
|
||||||
$(OBJS)\coredll_dirctrlg.o \
|
$(OBJS)\coredll_dirctrlg.o \
|
||||||
$(OBJS)\coredll_dragimgg.o \
|
$(OBJS)\coredll_dragimgg.o \
|
||||||
$(OBJS)\coredll_listbkg.o \
|
$(OBJS)\coredll_listbkg.o \
|
||||||
@@ -2404,6 +2413,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = \
|
|||||||
$(OBJS)\coredll_choicdgg.o \
|
$(OBJS)\coredll_choicdgg.o \
|
||||||
$(OBJS)\coredll_choicbkg.o \
|
$(OBJS)\coredll_choicbkg.o \
|
||||||
$(OBJS)\coredll_dcpsg.o \
|
$(OBJS)\coredll_dcpsg.o \
|
||||||
|
$(OBJS)\coredll_dbgrptg.o \
|
||||||
$(OBJS)\coredll_dirctrlg.o \
|
$(OBJS)\coredll_dirctrlg.o \
|
||||||
$(OBJS)\coredll_dragimgg.o \
|
$(OBJS)\coredll_dragimgg.o \
|
||||||
$(OBJS)\coredll_listbkg.o \
|
$(OBJS)\coredll_listbkg.o \
|
||||||
@@ -2609,6 +2619,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = \
|
|||||||
$(OBJS)\corelib_choicdgg.o \
|
$(OBJS)\corelib_choicdgg.o \
|
||||||
$(OBJS)\corelib_choicbkg.o \
|
$(OBJS)\corelib_choicbkg.o \
|
||||||
$(OBJS)\corelib_dcpsg.o \
|
$(OBJS)\corelib_dcpsg.o \
|
||||||
|
$(OBJS)\corelib_dbgrptg.o \
|
||||||
$(OBJS)\corelib_dirctrlg.o \
|
$(OBJS)\corelib_dirctrlg.o \
|
||||||
$(OBJS)\corelib_dragimgg.o \
|
$(OBJS)\corelib_dragimgg.o \
|
||||||
$(OBJS)\corelib_listbkg.o \
|
$(OBJS)\corelib_listbkg.o \
|
||||||
@@ -2807,6 +2818,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = \
|
|||||||
$(OBJS)\corelib_choicdgg.o \
|
$(OBJS)\corelib_choicdgg.o \
|
||||||
$(OBJS)\corelib_choicbkg.o \
|
$(OBJS)\corelib_choicbkg.o \
|
||||||
$(OBJS)\corelib_dcpsg.o \
|
$(OBJS)\corelib_dcpsg.o \
|
||||||
|
$(OBJS)\corelib_dbgrptg.o \
|
||||||
$(OBJS)\corelib_dirctrlg.o \
|
$(OBJS)\corelib_dirctrlg.o \
|
||||||
$(OBJS)\corelib_dragimgg.o \
|
$(OBJS)\corelib_dragimgg.o \
|
||||||
$(OBJS)\corelib_listbkg.o \
|
$(OBJS)\corelib_listbkg.o \
|
||||||
@@ -3880,6 +3892,9 @@ $(OBJS)\monodll_datetime.o: ../../src/common/datetime.cpp
|
|||||||
$(OBJS)\monodll_datstrm.o: ../../src/common/datstrm.cpp
|
$(OBJS)\monodll_datstrm.o: ../../src/common/datstrm.cpp
|
||||||
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\monodll_debugrpt.o: ../../src/common/debugrpt.cpp
|
||||||
|
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\monodll_dircmn.o: ../../src/common/dircmn.cpp
|
$(OBJS)\monodll_dircmn.o: ../../src/common/dircmn.cpp
|
||||||
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -5462,6 +5477,11 @@ $(OBJS)\monodll_dcpsg.o: ../../src/generic/dcpsg.cpp
|
|||||||
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(USE_GUI),1)
|
||||||
|
$(OBJS)\monodll_dbgrptg.o: ../../src/generic/dbgrptg.cpp
|
||||||
|
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(USE_GUI),1)
|
ifeq ($(USE_GUI),1)
|
||||||
$(OBJS)\monodll_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
$(OBJS)\monodll_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
||||||
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONODLL_CXXFLAGS) $<
|
||||||
@@ -5651,6 +5671,9 @@ $(OBJS)\monolib_datetime.o: ../../src/common/datetime.cpp
|
|||||||
$(OBJS)\monolib_datstrm.o: ../../src/common/datstrm.cpp
|
$(OBJS)\monolib_datstrm.o: ../../src/common/datstrm.cpp
|
||||||
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\monolib_debugrpt.o: ../../src/common/debugrpt.cpp
|
||||||
|
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\monolib_dircmn.o: ../../src/common/dircmn.cpp
|
$(OBJS)\monolib_dircmn.o: ../../src/common/dircmn.cpp
|
||||||
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -7233,6 +7256,11 @@ $(OBJS)\monolib_dcpsg.o: ../../src/generic/dcpsg.cpp
|
|||||||
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(USE_GUI),1)
|
||||||
|
$(OBJS)\monolib_dbgrptg.o: ../../src/generic/dbgrptg.cpp
|
||||||
|
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(USE_GUI),1)
|
ifeq ($(USE_GUI),1)
|
||||||
$(OBJS)\monolib_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
$(OBJS)\monolib_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
||||||
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(MONOLIB_CXXFLAGS) $<
|
||||||
@@ -7425,6 +7453,9 @@ $(OBJS)\basedll_datetime.o: ../../src/common/datetime.cpp
|
|||||||
$(OBJS)\basedll_datstrm.o: ../../src/common/datstrm.cpp
|
$(OBJS)\basedll_datstrm.o: ../../src/common/datstrm.cpp
|
||||||
$(CXX) -c -o $@ $(BASEDLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(BASEDLL_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\basedll_debugrpt.o: ../../src/common/debugrpt.cpp
|
||||||
|
$(CXX) -c -o $@ $(BASEDLL_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\basedll_dircmn.o: ../../src/common/dircmn.cpp
|
$(OBJS)\basedll_dircmn.o: ../../src/common/dircmn.cpp
|
||||||
$(CXX) -c -o $@ $(BASEDLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(BASEDLL_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -7659,6 +7690,9 @@ $(OBJS)\baselib_datetime.o: ../../src/common/datetime.cpp
|
|||||||
$(OBJS)\baselib_datstrm.o: ../../src/common/datstrm.cpp
|
$(OBJS)\baselib_datstrm.o: ../../src/common/datstrm.cpp
|
||||||
$(CXX) -c -o $@ $(BASELIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(BASELIB_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\baselib_debugrpt.o: ../../src/common/debugrpt.cpp
|
||||||
|
$(CXX) -c -o $@ $(BASELIB_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\baselib_dircmn.o: ../../src/common/dircmn.cpp
|
$(OBJS)\baselib_dircmn.o: ../../src/common/dircmn.cpp
|
||||||
$(CXX) -c -o $@ $(BASELIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(BASELIB_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -9097,6 +9131,11 @@ $(OBJS)\coredll_dcpsg.o: ../../src/generic/dcpsg.cpp
|
|||||||
$(CXX) -c -o $@ $(COREDLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(COREDLL_CXXFLAGS) $<
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(USE_GUI),1)
|
||||||
|
$(OBJS)\coredll_dbgrptg.o: ../../src/generic/dbgrptg.cpp
|
||||||
|
$(CXX) -c -o $@ $(COREDLL_CXXFLAGS) $<
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(USE_GUI),1)
|
ifeq ($(USE_GUI),1)
|
||||||
$(OBJS)\coredll_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
$(OBJS)\coredll_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
||||||
$(CXX) -c -o $@ $(COREDLL_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(COREDLL_CXXFLAGS) $<
|
||||||
@@ -10331,6 +10370,11 @@ $(OBJS)\corelib_dcpsg.o: ../../src/generic/dcpsg.cpp
|
|||||||
$(CXX) -c -o $@ $(CORELIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CORELIB_CXXFLAGS) $<
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(USE_GUI),1)
|
||||||
|
$(OBJS)\corelib_dbgrptg.o: ../../src/generic/dbgrptg.cpp
|
||||||
|
$(CXX) -c -o $@ $(CORELIB_CXXFLAGS) $<
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(USE_GUI),1)
|
ifeq ($(USE_GUI),1)
|
||||||
$(OBJS)\corelib_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
$(OBJS)\corelib_dirctrlg.o: ../../src/generic/dirctrlg.cpp
|
||||||
$(CXX) -c -o $@ $(CORELIB_CXXFLAGS) $<
|
$(CXX) -c -o $@ $(CORELIB_CXXFLAGS) $<
|
||||||
@@ -11023,3 +11067,4 @@ $(OBJS)\gllib_glcanvas.o: ../../src/msw/glcanvas.cpp
|
|||||||
|
|
||||||
.PHONY: all clean setup_h samples build_cfg_file
|
.PHONY: all clean setup_h samples build_cfg_file
|
||||||
|
|
||||||
|
|
||||||
|
@@ -206,6 +206,7 @@ MONODLL_OBJECTS = \
|
|||||||
$(OBJS)\monodll_config.obj \
|
$(OBJS)\monodll_config.obj \
|
||||||
$(OBJS)\monodll_datetime.obj \
|
$(OBJS)\monodll_datetime.obj \
|
||||||
$(OBJS)\monodll_datstrm.obj \
|
$(OBJS)\monodll_datstrm.obj \
|
||||||
|
$(OBJS)\monodll_debugrpt.obj \
|
||||||
$(OBJS)\monodll_dircmn.obj \
|
$(OBJS)\monodll_dircmn.obj \
|
||||||
$(OBJS)\monodll_dynarray.obj \
|
$(OBJS)\monodll_dynarray.obj \
|
||||||
$(OBJS)\monodll_dynlib.obj \
|
$(OBJS)\monodll_dynlib.obj \
|
||||||
@@ -317,6 +318,7 @@ MONOLIB_OBJECTS = \
|
|||||||
$(OBJS)\monolib_config.obj \
|
$(OBJS)\monolib_config.obj \
|
||||||
$(OBJS)\monolib_datetime.obj \
|
$(OBJS)\monolib_datetime.obj \
|
||||||
$(OBJS)\monolib_datstrm.obj \
|
$(OBJS)\monolib_datstrm.obj \
|
||||||
|
$(OBJS)\monolib_debugrpt.obj \
|
||||||
$(OBJS)\monolib_dircmn.obj \
|
$(OBJS)\monolib_dircmn.obj \
|
||||||
$(OBJS)\monolib_dynarray.obj \
|
$(OBJS)\monolib_dynarray.obj \
|
||||||
$(OBJS)\monolib_dynlib.obj \
|
$(OBJS)\monolib_dynlib.obj \
|
||||||
@@ -430,6 +432,7 @@ BASEDLL_OBJECTS = \
|
|||||||
$(OBJS)\basedll_config.obj \
|
$(OBJS)\basedll_config.obj \
|
||||||
$(OBJS)\basedll_datetime.obj \
|
$(OBJS)\basedll_datetime.obj \
|
||||||
$(OBJS)\basedll_datstrm.obj \
|
$(OBJS)\basedll_datstrm.obj \
|
||||||
|
$(OBJS)\basedll_debugrpt.obj \
|
||||||
$(OBJS)\basedll_dircmn.obj \
|
$(OBJS)\basedll_dircmn.obj \
|
||||||
$(OBJS)\basedll_dynarray.obj \
|
$(OBJS)\basedll_dynarray.obj \
|
||||||
$(OBJS)\basedll_dynlib.obj \
|
$(OBJS)\basedll_dynlib.obj \
|
||||||
@@ -526,6 +529,7 @@ BASELIB_OBJECTS = \
|
|||||||
$(OBJS)\baselib_config.obj \
|
$(OBJS)\baselib_config.obj \
|
||||||
$(OBJS)\baselib_datetime.obj \
|
$(OBJS)\baselib_datetime.obj \
|
||||||
$(OBJS)\baselib_datstrm.obj \
|
$(OBJS)\baselib_datstrm.obj \
|
||||||
|
$(OBJS)\baselib_debugrpt.obj \
|
||||||
$(OBJS)\baselib_dircmn.obj \
|
$(OBJS)\baselib_dircmn.obj \
|
||||||
$(OBJS)\baselib_dynarray.obj \
|
$(OBJS)\baselib_dynarray.obj \
|
||||||
$(OBJS)\baselib_dynlib.obj \
|
$(OBJS)\baselib_dynlib.obj \
|
||||||
@@ -1499,6 +1503,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = \
|
|||||||
$(OBJS)\monodll_choicdgg.obj \
|
$(OBJS)\monodll_choicdgg.obj \
|
||||||
$(OBJS)\monodll_choicbkg.obj \
|
$(OBJS)\monodll_choicbkg.obj \
|
||||||
$(OBJS)\monodll_dcpsg.obj \
|
$(OBJS)\monodll_dcpsg.obj \
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj \
|
||||||
$(OBJS)\monodll_dirctrlg.obj \
|
$(OBJS)\monodll_dirctrlg.obj \
|
||||||
$(OBJS)\monodll_dragimgg.obj \
|
$(OBJS)\monodll_dragimgg.obj \
|
||||||
$(OBJS)\monodll_listbkg.obj \
|
$(OBJS)\monodll_listbkg.obj \
|
||||||
@@ -1695,6 +1700,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = \
|
|||||||
$(OBJS)\monodll_choicdgg.obj \
|
$(OBJS)\monodll_choicdgg.obj \
|
||||||
$(OBJS)\monodll_choicbkg.obj \
|
$(OBJS)\monodll_choicbkg.obj \
|
||||||
$(OBJS)\monodll_dcpsg.obj \
|
$(OBJS)\monodll_dcpsg.obj \
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj \
|
||||||
$(OBJS)\monodll_dirctrlg.obj \
|
$(OBJS)\monodll_dirctrlg.obj \
|
||||||
$(OBJS)\monodll_dragimgg.obj \
|
$(OBJS)\monodll_dragimgg.obj \
|
||||||
$(OBJS)\monodll_listbkg.obj \
|
$(OBJS)\monodll_listbkg.obj \
|
||||||
@@ -2029,6 +2035,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = \
|
|||||||
$(OBJS)\monolib_choicdgg.obj \
|
$(OBJS)\monolib_choicdgg.obj \
|
||||||
$(OBJS)\monolib_choicbkg.obj \
|
$(OBJS)\monolib_choicbkg.obj \
|
||||||
$(OBJS)\monolib_dcpsg.obj \
|
$(OBJS)\monolib_dcpsg.obj \
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj \
|
||||||
$(OBJS)\monolib_dirctrlg.obj \
|
$(OBJS)\monolib_dirctrlg.obj \
|
||||||
$(OBJS)\monolib_dragimgg.obj \
|
$(OBJS)\monolib_dragimgg.obj \
|
||||||
$(OBJS)\monolib_listbkg.obj \
|
$(OBJS)\monolib_listbkg.obj \
|
||||||
@@ -2225,6 +2232,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = \
|
|||||||
$(OBJS)\monolib_choicdgg.obj \
|
$(OBJS)\monolib_choicdgg.obj \
|
||||||
$(OBJS)\monolib_choicbkg.obj \
|
$(OBJS)\monolib_choicbkg.obj \
|
||||||
$(OBJS)\monolib_dcpsg.obj \
|
$(OBJS)\monolib_dcpsg.obj \
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj \
|
||||||
$(OBJS)\monolib_dirctrlg.obj \
|
$(OBJS)\monolib_dirctrlg.obj \
|
||||||
$(OBJS)\monolib_dragimgg.obj \
|
$(OBJS)\monolib_dragimgg.obj \
|
||||||
$(OBJS)\monolib_listbkg.obj \
|
$(OBJS)\monolib_listbkg.obj \
|
||||||
@@ -2624,6 +2632,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = \
|
|||||||
$(OBJS)\coredll_choicdgg.obj \
|
$(OBJS)\coredll_choicdgg.obj \
|
||||||
$(OBJS)\coredll_choicbkg.obj \
|
$(OBJS)\coredll_choicbkg.obj \
|
||||||
$(OBJS)\coredll_dcpsg.obj \
|
$(OBJS)\coredll_dcpsg.obj \
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj \
|
||||||
$(OBJS)\coredll_dirctrlg.obj \
|
$(OBJS)\coredll_dirctrlg.obj \
|
||||||
$(OBJS)\coredll_dragimgg.obj \
|
$(OBJS)\coredll_dragimgg.obj \
|
||||||
$(OBJS)\coredll_listbkg.obj \
|
$(OBJS)\coredll_listbkg.obj \
|
||||||
@@ -2820,6 +2829,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = \
|
|||||||
$(OBJS)\coredll_choicdgg.obj \
|
$(OBJS)\coredll_choicdgg.obj \
|
||||||
$(OBJS)\coredll_choicbkg.obj \
|
$(OBJS)\coredll_choicbkg.obj \
|
||||||
$(OBJS)\coredll_dcpsg.obj \
|
$(OBJS)\coredll_dcpsg.obj \
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj \
|
||||||
$(OBJS)\coredll_dirctrlg.obj \
|
$(OBJS)\coredll_dirctrlg.obj \
|
||||||
$(OBJS)\coredll_dragimgg.obj \
|
$(OBJS)\coredll_dragimgg.obj \
|
||||||
$(OBJS)\coredll_listbkg.obj \
|
$(OBJS)\coredll_listbkg.obj \
|
||||||
@@ -3043,6 +3053,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = \
|
|||||||
$(OBJS)\corelib_choicdgg.obj \
|
$(OBJS)\corelib_choicdgg.obj \
|
||||||
$(OBJS)\corelib_choicbkg.obj \
|
$(OBJS)\corelib_choicbkg.obj \
|
||||||
$(OBJS)\corelib_dcpsg.obj \
|
$(OBJS)\corelib_dcpsg.obj \
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj \
|
||||||
$(OBJS)\corelib_dirctrlg.obj \
|
$(OBJS)\corelib_dirctrlg.obj \
|
||||||
$(OBJS)\corelib_dragimgg.obj \
|
$(OBJS)\corelib_dragimgg.obj \
|
||||||
$(OBJS)\corelib_listbkg.obj \
|
$(OBJS)\corelib_listbkg.obj \
|
||||||
@@ -3239,6 +3250,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = \
|
|||||||
$(OBJS)\corelib_choicdgg.obj \
|
$(OBJS)\corelib_choicdgg.obj \
|
||||||
$(OBJS)\corelib_choicbkg.obj \
|
$(OBJS)\corelib_choicbkg.obj \
|
||||||
$(OBJS)\corelib_dcpsg.obj \
|
$(OBJS)\corelib_dcpsg.obj \
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj \
|
||||||
$(OBJS)\corelib_dirctrlg.obj \
|
$(OBJS)\corelib_dirctrlg.obj \
|
||||||
$(OBJS)\corelib_dragimgg.obj \
|
$(OBJS)\corelib_dragimgg.obj \
|
||||||
$(OBJS)\corelib_listbkg.obj \
|
$(OBJS)\corelib_listbkg.obj \
|
||||||
@@ -3976,7 +3988,7 @@ __RTTIFLAG = /GR
|
|||||||
__EXCEPTIONSFLAG =
|
__EXCEPTIONSFLAG =
|
||||||
!endif
|
!endif
|
||||||
!if "$(USE_EXCEPTIONS)" == "1"
|
!if "$(USE_EXCEPTIONS)" == "1"
|
||||||
__EXCEPTIONSFLAG = /GX
|
__EXCEPTIONSFLAG = /EHsc
|
||||||
!endif
|
!endif
|
||||||
!if "$(BUILD)" == "debug" && "$(DEBUG_RUNTIME_LIBS)" == "0"
|
!if "$(BUILD)" == "debug" && "$(DEBUG_RUNTIME_LIBS)" == "0"
|
||||||
__NO_VC_CRTDBG_p = /D__NO_VC_CRTDBG__
|
__NO_VC_CRTDBG_p = /D__NO_VC_CRTDBG__
|
||||||
@@ -4735,6 +4747,9 @@ $(OBJS)\monodll_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\monodll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\monodll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\monodll_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\monodll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\monodll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -6217,6 +6232,11 @@ $(OBJS)\monodll_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\monodll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\monodll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONODLL_CXXFLAGS) $**
|
||||||
@@ -6406,6 +6426,9 @@ $(OBJS)\monolib_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\monolib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\monolib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\monolib_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\monolib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\monolib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -7888,6 +7911,11 @@ $(OBJS)\monolib_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\monolib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\monolib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(MONOLIB_CXXFLAGS) $**
|
||||||
@@ -8080,6 +8108,9 @@ $(OBJS)\basedll_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\basedll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\basedll_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(BASEDLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(BASEDLL_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\basedll_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(BASEDLL_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\basedll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\basedll_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(BASEDLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(BASEDLL_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -8314,6 +8345,9 @@ $(OBJS)\baselib_datetime.obj: ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\baselib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
$(OBJS)\baselib_datstrm.obj: ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(BASELIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(BASELIB_CXXFLAGS) $**
|
||||||
|
|
||||||
|
$(OBJS)\baselib_debugrpt.obj: ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(BASELIB_CXXFLAGS) $**
|
||||||
|
|
||||||
$(OBJS)\baselib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
$(OBJS)\baselib_dircmn.obj: ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(BASELIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(BASELIB_CXXFLAGS) $**
|
||||||
|
|
||||||
@@ -9652,6 +9686,11 @@ $(OBJS)\coredll_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) /c /nologo /TP /Fo$@ $(COREDLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(COREDLL_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(COREDLL_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\coredll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\coredll_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(COREDLL_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(COREDLL_CXXFLAGS) $**
|
||||||
@@ -10786,6 +10825,11 @@ $(OBJS)\corelib_dcpsg.obj: ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) /c /nologo /TP /Fo$@ $(CORELIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(CORELIB_CXXFLAGS) $**
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!if "$(USE_GUI)" == "1"
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj: ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(CORELIB_CXXFLAGS) $**
|
||||||
|
!endif
|
||||||
|
|
||||||
!if "$(USE_GUI)" == "1"
|
!if "$(USE_GUI)" == "1"
|
||||||
$(OBJS)\corelib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\corelib_dirctrlg.obj: ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(CORELIB_CXXFLAGS) $**
|
$(CXX) /c /nologo /TP /Fo$@ $(CORELIB_CXXFLAGS) $**
|
||||||
|
@@ -348,6 +348,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = &
|
|||||||
$(OBJS)\monodll_choicdgg.obj &
|
$(OBJS)\monodll_choicdgg.obj &
|
||||||
$(OBJS)\monodll_choicbkg.obj &
|
$(OBJS)\monodll_choicbkg.obj &
|
||||||
$(OBJS)\monodll_dcpsg.obj &
|
$(OBJS)\monodll_dcpsg.obj &
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj &
|
||||||
$(OBJS)\monodll_dirctrlg.obj &
|
$(OBJS)\monodll_dirctrlg.obj &
|
||||||
$(OBJS)\monodll_dragimgg.obj &
|
$(OBJS)\monodll_dragimgg.obj &
|
||||||
$(OBJS)\monodll_listbkg.obj &
|
$(OBJS)\monodll_listbkg.obj &
|
||||||
@@ -546,6 +547,7 @@ ____CORE_SRC_FILENAMES_OBJECTS = &
|
|||||||
$(OBJS)\monodll_choicdgg.obj &
|
$(OBJS)\monodll_choicdgg.obj &
|
||||||
$(OBJS)\monodll_choicbkg.obj &
|
$(OBJS)\monodll_choicbkg.obj &
|
||||||
$(OBJS)\monodll_dcpsg.obj &
|
$(OBJS)\monodll_dcpsg.obj &
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj &
|
||||||
$(OBJS)\monodll_dirctrlg.obj &
|
$(OBJS)\monodll_dirctrlg.obj &
|
||||||
$(OBJS)\monodll_dragimgg.obj &
|
$(OBJS)\monodll_dragimgg.obj &
|
||||||
$(OBJS)\monodll_listbkg.obj &
|
$(OBJS)\monodll_listbkg.obj &
|
||||||
@@ -864,6 +866,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = &
|
|||||||
$(OBJS)\monolib_choicdgg.obj &
|
$(OBJS)\monolib_choicdgg.obj &
|
||||||
$(OBJS)\monolib_choicbkg.obj &
|
$(OBJS)\monolib_choicbkg.obj &
|
||||||
$(OBJS)\monolib_dcpsg.obj &
|
$(OBJS)\monolib_dcpsg.obj &
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj &
|
||||||
$(OBJS)\monolib_dirctrlg.obj &
|
$(OBJS)\monolib_dirctrlg.obj &
|
||||||
$(OBJS)\monolib_dragimgg.obj &
|
$(OBJS)\monolib_dragimgg.obj &
|
||||||
$(OBJS)\monolib_listbkg.obj &
|
$(OBJS)\monolib_listbkg.obj &
|
||||||
@@ -1062,6 +1065,7 @@ ____CORE_SRC_FILENAMES_1_OBJECTS = &
|
|||||||
$(OBJS)\monolib_choicdgg.obj &
|
$(OBJS)\monolib_choicdgg.obj &
|
||||||
$(OBJS)\monolib_choicbkg.obj &
|
$(OBJS)\monolib_choicbkg.obj &
|
||||||
$(OBJS)\monolib_dcpsg.obj &
|
$(OBJS)\monolib_dcpsg.obj &
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj &
|
||||||
$(OBJS)\monolib_dirctrlg.obj &
|
$(OBJS)\monolib_dirctrlg.obj &
|
||||||
$(OBJS)\monolib_dragimgg.obj &
|
$(OBJS)\monolib_dragimgg.obj &
|
||||||
$(OBJS)\monolib_listbkg.obj &
|
$(OBJS)\monolib_listbkg.obj &
|
||||||
@@ -1335,6 +1339,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = &
|
|||||||
$(OBJS)\coredll_choicdgg.obj &
|
$(OBJS)\coredll_choicdgg.obj &
|
||||||
$(OBJS)\coredll_choicbkg.obj &
|
$(OBJS)\coredll_choicbkg.obj &
|
||||||
$(OBJS)\coredll_dcpsg.obj &
|
$(OBJS)\coredll_dcpsg.obj &
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj &
|
||||||
$(OBJS)\coredll_dirctrlg.obj &
|
$(OBJS)\coredll_dirctrlg.obj &
|
||||||
$(OBJS)\coredll_dragimgg.obj &
|
$(OBJS)\coredll_dragimgg.obj &
|
||||||
$(OBJS)\coredll_listbkg.obj &
|
$(OBJS)\coredll_listbkg.obj &
|
||||||
@@ -1533,6 +1538,7 @@ ____CORE_SRC_FILENAMES_2_OBJECTS = &
|
|||||||
$(OBJS)\coredll_choicdgg.obj &
|
$(OBJS)\coredll_choicdgg.obj &
|
||||||
$(OBJS)\coredll_choicbkg.obj &
|
$(OBJS)\coredll_choicbkg.obj &
|
||||||
$(OBJS)\coredll_dcpsg.obj &
|
$(OBJS)\coredll_dcpsg.obj &
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj &
|
||||||
$(OBJS)\coredll_dirctrlg.obj &
|
$(OBJS)\coredll_dirctrlg.obj &
|
||||||
$(OBJS)\coredll_dragimgg.obj &
|
$(OBJS)\coredll_dragimgg.obj &
|
||||||
$(OBJS)\coredll_listbkg.obj &
|
$(OBJS)\coredll_listbkg.obj &
|
||||||
@@ -1740,6 +1746,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = &
|
|||||||
$(OBJS)\corelib_choicdgg.obj &
|
$(OBJS)\corelib_choicdgg.obj &
|
||||||
$(OBJS)\corelib_choicbkg.obj &
|
$(OBJS)\corelib_choicbkg.obj &
|
||||||
$(OBJS)\corelib_dcpsg.obj &
|
$(OBJS)\corelib_dcpsg.obj &
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj &
|
||||||
$(OBJS)\corelib_dirctrlg.obj &
|
$(OBJS)\corelib_dirctrlg.obj &
|
||||||
$(OBJS)\corelib_dragimgg.obj &
|
$(OBJS)\corelib_dragimgg.obj &
|
||||||
$(OBJS)\corelib_listbkg.obj &
|
$(OBJS)\corelib_listbkg.obj &
|
||||||
@@ -1938,6 +1945,7 @@ ____CORE_SRC_FILENAMES_3_OBJECTS = &
|
|||||||
$(OBJS)\corelib_choicdgg.obj &
|
$(OBJS)\corelib_choicdgg.obj &
|
||||||
$(OBJS)\corelib_choicbkg.obj &
|
$(OBJS)\corelib_choicbkg.obj &
|
||||||
$(OBJS)\corelib_dcpsg.obj &
|
$(OBJS)\corelib_dcpsg.obj &
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj &
|
||||||
$(OBJS)\corelib_dirctrlg.obj &
|
$(OBJS)\corelib_dirctrlg.obj &
|
||||||
$(OBJS)\corelib_dragimgg.obj &
|
$(OBJS)\corelib_dragimgg.obj &
|
||||||
$(OBJS)\corelib_listbkg.obj &
|
$(OBJS)\corelib_listbkg.obj &
|
||||||
@@ -2481,6 +2489,7 @@ MONODLL_OBJECTS = &
|
|||||||
$(OBJS)\monodll_config.obj &
|
$(OBJS)\monodll_config.obj &
|
||||||
$(OBJS)\monodll_datetime.obj &
|
$(OBJS)\monodll_datetime.obj &
|
||||||
$(OBJS)\monodll_datstrm.obj &
|
$(OBJS)\monodll_datstrm.obj &
|
||||||
|
$(OBJS)\monodll_debugrpt.obj &
|
||||||
$(OBJS)\monodll_dircmn.obj &
|
$(OBJS)\monodll_dircmn.obj &
|
||||||
$(OBJS)\monodll_dynarray.obj &
|
$(OBJS)\monodll_dynarray.obj &
|
||||||
$(OBJS)\monodll_dynlib.obj &
|
$(OBJS)\monodll_dynlib.obj &
|
||||||
@@ -2588,6 +2597,7 @@ MONOLIB_OBJECTS = &
|
|||||||
$(OBJS)\monolib_config.obj &
|
$(OBJS)\monolib_config.obj &
|
||||||
$(OBJS)\monolib_datetime.obj &
|
$(OBJS)\monolib_datetime.obj &
|
||||||
$(OBJS)\monolib_datstrm.obj &
|
$(OBJS)\monolib_datstrm.obj &
|
||||||
|
$(OBJS)\monolib_debugrpt.obj &
|
||||||
$(OBJS)\monolib_dircmn.obj &
|
$(OBJS)\monolib_dircmn.obj &
|
||||||
$(OBJS)\monolib_dynarray.obj &
|
$(OBJS)\monolib_dynarray.obj &
|
||||||
$(OBJS)\monolib_dynlib.obj &
|
$(OBJS)\monolib_dynlib.obj &
|
||||||
@@ -2695,6 +2705,7 @@ BASEDLL_OBJECTS = &
|
|||||||
$(OBJS)\basedll_config.obj &
|
$(OBJS)\basedll_config.obj &
|
||||||
$(OBJS)\basedll_datetime.obj &
|
$(OBJS)\basedll_datetime.obj &
|
||||||
$(OBJS)\basedll_datstrm.obj &
|
$(OBJS)\basedll_datstrm.obj &
|
||||||
|
$(OBJS)\basedll_debugrpt.obj &
|
||||||
$(OBJS)\basedll_dircmn.obj &
|
$(OBJS)\basedll_dircmn.obj &
|
||||||
$(OBJS)\basedll_dynarray.obj &
|
$(OBJS)\basedll_dynarray.obj &
|
||||||
$(OBJS)\basedll_dynlib.obj &
|
$(OBJS)\basedll_dynlib.obj &
|
||||||
@@ -2787,6 +2798,7 @@ BASELIB_OBJECTS = &
|
|||||||
$(OBJS)\baselib_config.obj &
|
$(OBJS)\baselib_config.obj &
|
||||||
$(OBJS)\baselib_datetime.obj &
|
$(OBJS)\baselib_datetime.obj &
|
||||||
$(OBJS)\baselib_datstrm.obj &
|
$(OBJS)\baselib_datstrm.obj &
|
||||||
|
$(OBJS)\baselib_debugrpt.obj &
|
||||||
$(OBJS)\baselib_dircmn.obj &
|
$(OBJS)\baselib_dircmn.obj &
|
||||||
$(OBJS)\baselib_dynarray.obj &
|
$(OBJS)\baselib_dynarray.obj &
|
||||||
$(OBJS)\baselib_dynlib.obj &
|
$(OBJS)\baselib_dynlib.obj &
|
||||||
@@ -4101,6 +4113,9 @@ $(OBJS)\monodll_datetime.obj : .AUTODEPEND ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\monodll_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
$(OBJS)\monodll_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\monodll_debugrpt.obj : .AUTODEPEND ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\monodll_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
$(OBJS)\monodll_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -5683,6 +5698,11 @@ $(OBJS)\monodll_dcpsg.obj : .AUTODEPEND ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!ifeq USE_GUI 1
|
||||||
|
$(OBJS)\monodll_dbgrptg.obj : .AUTODEPEND ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
||||||
|
!endif
|
||||||
|
|
||||||
!ifeq USE_GUI 1
|
!ifeq USE_GUI 1
|
||||||
$(OBJS)\monodll_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\monodll_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONODLL_CXXFLAGS) $<
|
||||||
@@ -5872,6 +5892,9 @@ $(OBJS)\monolib_datetime.obj : .AUTODEPEND ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\monolib_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
$(OBJS)\monolib_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\monolib_debugrpt.obj : .AUTODEPEND ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\monolib_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
$(OBJS)\monolib_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -7454,6 +7477,11 @@ $(OBJS)\monolib_dcpsg.obj : .AUTODEPEND ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!ifeq USE_GUI 1
|
||||||
|
$(OBJS)\monolib_dbgrptg.obj : .AUTODEPEND ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
||||||
|
!endif
|
||||||
|
|
||||||
!ifeq USE_GUI 1
|
!ifeq USE_GUI 1
|
||||||
$(OBJS)\monolib_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\monolib_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(MONOLIB_CXXFLAGS) $<
|
||||||
@@ -7646,6 +7674,9 @@ $(OBJS)\basedll_datetime.obj : .AUTODEPEND ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\basedll_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
$(OBJS)\basedll_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(BASEDLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(BASEDLL_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\basedll_debugrpt.obj : .AUTODEPEND ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(BASEDLL_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\basedll_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
$(OBJS)\basedll_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(BASEDLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(BASEDLL_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -7880,6 +7911,9 @@ $(OBJS)\baselib_datetime.obj : .AUTODEPEND ..\..\src\common\datetime.cpp
|
|||||||
$(OBJS)\baselib_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
$(OBJS)\baselib_datstrm.obj : .AUTODEPEND ..\..\src\common\datstrm.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(BASELIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(BASELIB_CXXFLAGS) $<
|
||||||
|
|
||||||
|
$(OBJS)\baselib_debugrpt.obj : .AUTODEPEND ..\..\src\common\debugrpt.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(BASELIB_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\baselib_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
$(OBJS)\baselib_dircmn.obj : .AUTODEPEND ..\..\src\common\dircmn.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(BASELIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(BASELIB_CXXFLAGS) $<
|
||||||
|
|
||||||
@@ -9318,6 +9352,11 @@ $(OBJS)\coredll_dcpsg.obj : .AUTODEPEND ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -zq -fo=$^@ $(COREDLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(COREDLL_CXXFLAGS) $<
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!ifeq USE_GUI 1
|
||||||
|
$(OBJS)\coredll_dbgrptg.obj : .AUTODEPEND ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(COREDLL_CXXFLAGS) $<
|
||||||
|
!endif
|
||||||
|
|
||||||
!ifeq USE_GUI 1
|
!ifeq USE_GUI 1
|
||||||
$(OBJS)\coredll_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\coredll_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(COREDLL_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(COREDLL_CXXFLAGS) $<
|
||||||
@@ -10552,6 +10591,11 @@ $(OBJS)\corelib_dcpsg.obj : .AUTODEPEND ..\..\src\generic\dcpsg.cpp
|
|||||||
$(CXX) -zq -fo=$^@ $(CORELIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(CORELIB_CXXFLAGS) $<
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
|
!ifeq USE_GUI 1
|
||||||
|
$(OBJS)\corelib_dbgrptg.obj : .AUTODEPEND ..\..\src\generic\dbgrptg.cpp
|
||||||
|
$(CXX) -zq -fo=$^@ $(CORELIB_CXXFLAGS) $<
|
||||||
|
!endif
|
||||||
|
|
||||||
!ifeq USE_GUI 1
|
!ifeq USE_GUI 1
|
||||||
$(OBJS)\corelib_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
$(OBJS)\corelib_dirctrlg.obj : .AUTODEPEND ..\..\src\generic\dirctrlg.cpp
|
||||||
$(CXX) -zq -fo=$^@ $(CORELIB_CXXFLAGS) $<
|
$(CXX) -zq -fo=$^@ $(CORELIB_CXXFLAGS) $<
|
||||||
|
@@ -480,6 +480,10 @@ SOURCE=..\..\src\common\datstrm.cpp
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\common\debugrpt.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=..\..\src\common\dircmn.cpp
|
SOURCE=..\..\src\common\dircmn.cpp
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -1141,6 +1145,10 @@ SOURCE=..\..\include\wx\debug.h
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\include\wx\debugrpt.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=..\..\include\wx\defs.h
|
SOURCE=..\..\include\wx\defs.h
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
@@ -4081,6 +4081,10 @@ SOURCE=..\..\src\generic\colrdlgg.cpp
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\src\generic\dbgrptg.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=..\..\src\generic\dcpsg.cpp
|
SOURCE=..\..\src\generic\dcpsg.cpp
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
@@ -9,7 +9,7 @@ All:
|
|||||||
|
|
||||||
- wxURI::GetUser() only returns the user name now, use GetUserInfo() to get
|
- wxURI::GetUser() only returns the user name now, use GetUserInfo() to get
|
||||||
user and password as in 2.5.4; wxURI::GetPassword() added
|
user and password as in 2.5.4; wxURI::GetPassword() added
|
||||||
- added wx_dynamic_cast() macro
|
- added wxDebugReport class
|
||||||
|
|
||||||
All (GUI):
|
All (GUI):
|
||||||
|
|
||||||
|
221
include/wx/debugrpt.h
Normal file
221
include/wx/debugrpt.h
Normal file
@@ -0,0 +1,221 @@
|
|||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Name: wx/debugrpt.h
|
||||||
|
// Purpose: declaration of wxDebugReport class
|
||||||
|
// Author: Vadim Zeitlin
|
||||||
|
// Created: 2005-01-17
|
||||||
|
// RCS-ID: $Id$
|
||||||
|
// Copyright: (c) 2005 Vadim Zeitlin <vadim@wxwindows.org>
|
||||||
|
// Licence: wxWindows licence
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
#ifndef _WX_DEBUGRPT_H_
|
||||||
|
#define _WX_DEBUGRPT_H_
|
||||||
|
|
||||||
|
#include "wx/defs.h"
|
||||||
|
|
||||||
|
#if wxUSE_DEBUGREPORT
|
||||||
|
|
||||||
|
class WXDLLIMPEXP_XML wxXmlNode;
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReport: generate a debug report, processing is done in derived class
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDebugReport
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
// this is used for the functions which may report either the current state
|
||||||
|
// or the state during the last (fatal) exception
|
||||||
|
enum Context { Context_Curent, Context_Exception };
|
||||||
|
|
||||||
|
|
||||||
|
// ctor creates a temporary directory where we create the files which will
|
||||||
|
// be included in the report, use IsOk() to check for errors
|
||||||
|
wxDebugReport();
|
||||||
|
|
||||||
|
// dtor normally destroys the temporary directory created in the ctor (with
|
||||||
|
// all the files it contains), call Reset() to prevent this from happening
|
||||||
|
virtual ~wxDebugReport();
|
||||||
|
|
||||||
|
// return the name of the directory used for this report
|
||||||
|
const wxString& GetDirectory() const { return m_dir; }
|
||||||
|
|
||||||
|
// return true if the object was successfully initialized
|
||||||
|
bool IsOk() const { return !GetDirectory().empty(); }
|
||||||
|
|
||||||
|
// reset the directory name we use, the object can't be used any more after
|
||||||
|
// this as it becomes invalid/uninitialized
|
||||||
|
void Reset() { m_dir.clear(); }
|
||||||
|
|
||||||
|
|
||||||
|
// add another file to the report: the file must already exist, its name is
|
||||||
|
// relative to GetDirectory()
|
||||||
|
//
|
||||||
|
// description is shown to the user in the report summary
|
||||||
|
virtual void AddFile(const wxString& name, const wxString& description);
|
||||||
|
|
||||||
|
// add an XML file containing the current or exception context and the
|
||||||
|
// stack trace
|
||||||
|
bool AddCurrentContext() { return AddContext(Context_Curent); }
|
||||||
|
bool AddExceptionContext() { return AddContext(Context_Exception); }
|
||||||
|
virtual bool AddContext(Context ctx);
|
||||||
|
|
||||||
|
#if wxUSE_CRASHREPORT
|
||||||
|
// add a file with crash report
|
||||||
|
bool AddCurrentDump() { return AddDump(Context_Curent); }
|
||||||
|
bool AddExceptionDump() { return AddDump(Context_Exception); }
|
||||||
|
virtual bool AddDump(Context ctx);
|
||||||
|
#endif // wxUSE_CRASHREPORT
|
||||||
|
|
||||||
|
// add all available information to the report
|
||||||
|
void AddAll(Context context = Context_Exception);
|
||||||
|
|
||||||
|
|
||||||
|
// process this report: the base class simply notifies the user that the
|
||||||
|
// report has been generated, this is usually not enough -- instead you
|
||||||
|
// should override this method to do something more useful to you
|
||||||
|
bool Process();
|
||||||
|
|
||||||
|
// get the name used as base name for various files, by default
|
||||||
|
// wxApp::GetName()
|
||||||
|
virtual wxString GetReportName() const;
|
||||||
|
|
||||||
|
// get the files in this report
|
||||||
|
size_t GetFilesCount() const { return m_files.GetCount(); }
|
||||||
|
bool GetFile(size_t n, wxString *name, wxString *desc) const;
|
||||||
|
|
||||||
|
// remove the file from report: this is used by wxDebugReportPreview to
|
||||||
|
// allow the user to remove files potentially containing private
|
||||||
|
// information from the report
|
||||||
|
void RemoveFile(const wxString& name);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
// used by AddContext()
|
||||||
|
virtual bool DoAddSystemInfo(wxXmlNode *nodeSystemInfo);
|
||||||
|
virtual bool DoAddLoadedModules(wxXmlNode *nodeModules);
|
||||||
|
virtual bool DoAddExceptionInfo(wxXmlNode *nodeContext);
|
||||||
|
virtual void DoAddCustomContext(wxXmlNode * WXUNUSED(nodeRoot)) { }
|
||||||
|
|
||||||
|
// used by Process()
|
||||||
|
virtual bool DoProcess();
|
||||||
|
|
||||||
|
private:
|
||||||
|
// name of the report directory
|
||||||
|
wxString m_dir;
|
||||||
|
|
||||||
|
// the arrays of files in this report and their descriptions
|
||||||
|
wxArrayString m_files,
|
||||||
|
m_descriptions;
|
||||||
|
};
|
||||||
|
|
||||||
|
#if wxUSE_ZIPSTREAM
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportCompress: compress all files of this debug report in a .ZIP
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDebugReportCompress : public wxDebugReport
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxDebugReportCompress() { }
|
||||||
|
|
||||||
|
// returns the full path of the compressed file (empty if creation failed)
|
||||||
|
const wxString& GetCompressedFileName() const { return m_zipfile; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual bool DoProcess();
|
||||||
|
|
||||||
|
private:
|
||||||
|
// full path to the ZIP file we created
|
||||||
|
wxString m_zipfile;
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportUploader: uploads compressed file using HTTP POST request
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDebugReportUpload : public wxDebugReportCompress
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
// this class will upload the compressed file created by its base class to
|
||||||
|
// an HTML multipart/form-data form at the specified address
|
||||||
|
//
|
||||||
|
// the URL is the base address, input is the name of the "type=file"
|
||||||
|
// control on the form used for the file name and action is the value of
|
||||||
|
// the form action field
|
||||||
|
wxDebugReportUpload(const wxString& url,
|
||||||
|
const wxString& input,
|
||||||
|
const wxString& action,
|
||||||
|
const wxString& curl = _T("curl"));
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual bool DoProcess();
|
||||||
|
|
||||||
|
// this function may be overridden in a derived class to show the output
|
||||||
|
// from curl: this may be an HTML page or anything else that the server
|
||||||
|
// returned
|
||||||
|
//
|
||||||
|
// return value becomes the return value of Process()
|
||||||
|
virtual bool OnServerReply(const wxArrayString& WXUNUSED(reply))
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
// the full URL to use with HTTP POST request
|
||||||
|
wxString m_uploadURL;
|
||||||
|
|
||||||
|
// the name of the input field containing the file name in the form at
|
||||||
|
// above URL
|
||||||
|
wxString m_inputField;
|
||||||
|
|
||||||
|
// the curl command (by default it is just "curl" but could be full path to
|
||||||
|
// curl or a wrapper script with curl-compatible syntax)
|
||||||
|
wxString m_curlCmd;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // wxUSE_ZIPSTREAM
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportPreview: presents the debug report to the user and allows him
|
||||||
|
// to veto report entirely or remove some parts of it
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDebugReportPreview
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
// ctor is trivial
|
||||||
|
wxDebugReportPreview() { }
|
||||||
|
|
||||||
|
// present the report to the user and allow him to modify it by removing
|
||||||
|
// some or all of the files and, potentially, adding some notes
|
||||||
|
//
|
||||||
|
// return true if the report should be processed or false if the user chose
|
||||||
|
// to cancel report generation or removed all files from it
|
||||||
|
virtual bool Show(wxDebugReport& dbgrpt) const = 0;
|
||||||
|
|
||||||
|
// dtor is trivial as well but should be virtual for a base class
|
||||||
|
virtual ~wxDebugReportPreview() { }
|
||||||
|
};
|
||||||
|
|
||||||
|
#if wxUSE_GUI
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportPreviewStd: standard debug report preview window
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDebugReportPreviewStd : public wxDebugReportPreview
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxDebugReportPreviewStd() { }
|
||||||
|
|
||||||
|
virtual bool Show(wxDebugReport& dbgrpt) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // wxUSE_GUI
|
||||||
|
|
||||||
|
#endif // wxUSE_DEBUGREPORT
|
||||||
|
|
||||||
|
#endif // _WX_DEBUGRPT_H_
|
||||||
|
|
13
samples/debugrpt/debugrpt.bkl
Normal file
13
samples/debugrpt/debugrpt.bkl
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<?xml version="1.0" ?>
|
||||||
|
<!-- $Id$ -->
|
||||||
|
|
||||||
|
<makefile>
|
||||||
|
<include file="../../build/bakefiles/common_samples.bkl"/>
|
||||||
|
|
||||||
|
<exe id="debugrpt" template="wx_sample" template_append="wx_append">
|
||||||
|
<sources>debugrpt.cpp</sources>
|
||||||
|
<wx-lib>core</wx-lib>
|
||||||
|
<wx-lib>base</wx-lib>
|
||||||
|
<wx-lib>xml</wx-lib>
|
||||||
|
</exe>
|
||||||
|
</makefile>
|
187
samples/debugrpt/debugrpt.cpp
Normal file
187
samples/debugrpt/debugrpt.cpp
Normal file
@@ -0,0 +1,187 @@
|
|||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Name: debugrpt.cpp
|
||||||
|
// Purpose: minimal sample showing wxDebugReport and related classes
|
||||||
|
// Author: Vadim Zeitlin
|
||||||
|
// Modified by:
|
||||||
|
// Created: 2005-01-20
|
||||||
|
// RCS-ID: $Id$
|
||||||
|
// Copyright: (c) 2005 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
|
||||||
|
// License: wxWindows licence
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// headers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#include "wx/app.h"
|
||||||
|
#include "wx/datetime.h"
|
||||||
|
#include "wx/ffile.h"
|
||||||
|
#include "wx/filename.h"
|
||||||
|
#include "wx/dynlib.h"
|
||||||
|
#include "wx/debugrpt.h"
|
||||||
|
|
||||||
|
#include "wx/msgdlg.h"
|
||||||
|
|
||||||
|
#if !wxUSE_DEBUGREPORT
|
||||||
|
#error "This sample can't be built without wxUSE_DEBUGREPORT"
|
||||||
|
#endif // wxUSE_DEBUGREPORT
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// custom debug reporting class
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// this is your custom debug reporter, you will probably want to parse the XML
|
||||||
|
// document in OnServerReply() instead of just dumping it as I do
|
||||||
|
class MyDebugReport : public wxDebugReportUpload
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MyDebugReport() : wxDebugReportUpload
|
||||||
|
(
|
||||||
|
_T("http://iml2.hitchcock.org/intranet/crashes/wxtest"),
|
||||||
|
_T("report:file"),
|
||||||
|
_T("action")
|
||||||
|
)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual bool OnServerReply(const wxArrayString& reply)
|
||||||
|
{
|
||||||
|
if ( reply.IsEmpty() )
|
||||||
|
{
|
||||||
|
wxLogError(_T("Didn't receive the expected server reply."));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxString s(_T("Server replied:\n"));
|
||||||
|
|
||||||
|
const size_t count = reply.GetCount();
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
s << _T('\t') << reply[n] << _T('\n');
|
||||||
|
}
|
||||||
|
|
||||||
|
wxLogMessage(_T("%s"), s.c_str());
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// helper functions
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// just some functions to get a slightly deeper stack trace
|
||||||
|
static void bar(const wxChar *p)
|
||||||
|
{
|
||||||
|
char *pc = 0;
|
||||||
|
*pc = *p;
|
||||||
|
|
||||||
|
printf("bar: %s\n", p);
|
||||||
|
}
|
||||||
|
|
||||||
|
void baz(const wxString& s)
|
||||||
|
{
|
||||||
|
printf("baz: %s\n", s.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
void foo(int n)
|
||||||
|
{
|
||||||
|
if ( n % 2 )
|
||||||
|
baz(wxT("odd"));
|
||||||
|
else
|
||||||
|
bar(wxT("even"));
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// application class
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// this is a usual application class modified to work with debug reporter
|
||||||
|
//
|
||||||
|
// basically just 2 things are necessary: call wxHandleFatalExceptions() as
|
||||||
|
// early as possible and override OnFatalException() to create the report there
|
||||||
|
class MyApp : public wxApp
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual bool OnInit()
|
||||||
|
{
|
||||||
|
wxHandleFatalExceptions();
|
||||||
|
|
||||||
|
if ( !wxApp::OnInit() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual int OnRun()
|
||||||
|
{
|
||||||
|
// a real program would be presumably be a bit harder to crash than
|
||||||
|
// just pressing "yes" in a dialog... but this is just an example
|
||||||
|
switch ( wxMessageBox
|
||||||
|
(
|
||||||
|
_T("Generate report for crash (or just current context)?"),
|
||||||
|
_T("wxDebugReport Test"),
|
||||||
|
wxYES_NO | wxCANCEL
|
||||||
|
) )
|
||||||
|
{
|
||||||
|
case wxYES:
|
||||||
|
// this call is going to crash
|
||||||
|
foo(32);
|
||||||
|
foo(17);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxNO:
|
||||||
|
// example of manually generated report, this could be also
|
||||||
|
// used in wxApp::OnAssert()
|
||||||
|
GenerateReport(wxDebugReport::Context_Curent);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wxCANCEL:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void OnFatalException()
|
||||||
|
{
|
||||||
|
GenerateReport(wxDebugReport::Context_Exception);
|
||||||
|
}
|
||||||
|
|
||||||
|
void GenerateReport(wxDebugReport::Context ctx)
|
||||||
|
{
|
||||||
|
MyDebugReport report;
|
||||||
|
|
||||||
|
// add all standard files: currently this means just a minidump and an
|
||||||
|
// XML file with system info and stack trace
|
||||||
|
report.AddAll(ctx);
|
||||||
|
|
||||||
|
// you can also call report.AddFile(...) with your own log files, files
|
||||||
|
// created using wxRegKey::Export() and so on, here we just add a test
|
||||||
|
// file containing the date of the crash
|
||||||
|
wxFileName fn(report.GetDirectory(), _T("timestamp.my"));
|
||||||
|
wxFFile file(fn.GetFullPath(), _T("w"));
|
||||||
|
if ( file.IsOpened() )
|
||||||
|
{
|
||||||
|
wxDateTime dt = wxDateTime::Now();
|
||||||
|
file.Write(dt.FormatISODate() + _T(' ') + dt.FormatISOTime());
|
||||||
|
file.Close();
|
||||||
|
}
|
||||||
|
|
||||||
|
report.AddFile(fn.GetFullName(), _T("timestamp of this report"));
|
||||||
|
|
||||||
|
// calling Show() is not mandatory, but is more polite
|
||||||
|
if ( wxDebugReportPreviewStd().Show(report) )
|
||||||
|
{
|
||||||
|
if ( report.Process() )
|
||||||
|
{
|
||||||
|
// report successfully uploaded
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//else: user cancelled the report
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
IMPLEMENT_APP(MyApp)
|
||||||
|
|
639
src/common/debugrpt.cpp
Normal file
639
src/common/debugrpt.cpp
Normal file
@@ -0,0 +1,639 @@
|
|||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Name: src/common/debugrpt.cpp
|
||||||
|
// Purpose: wxDebugReport and related classes implementation
|
||||||
|
// Author: Vadim Zeitlin
|
||||||
|
// Modified by:
|
||||||
|
// Created: 2005-01-17
|
||||||
|
// RCS-ID: $Id$
|
||||||
|
// Copyright: (c) 2005 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
|
||||||
|
// License: wxWindows licence
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// declarations
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// headers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
|
#ifdef __BORLANDC__
|
||||||
|
#pragma hdrstop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef WX_PRECOMP
|
||||||
|
#include "wx/app.h"
|
||||||
|
#include "wx/log.h"
|
||||||
|
#include "wx/intl.h"
|
||||||
|
#endif // WX_PRECOMP
|
||||||
|
|
||||||
|
#if wxUSE_DEBUGREPORT
|
||||||
|
|
||||||
|
#include "wx/debugrpt.h"
|
||||||
|
|
||||||
|
#include "wx/filename.h"
|
||||||
|
#include "wx/dir.h"
|
||||||
|
#include "wx/dynlib.h"
|
||||||
|
|
||||||
|
#include "wx/xml/xml.h"
|
||||||
|
|
||||||
|
#if wxUSE_STACKWALKER
|
||||||
|
#include "wx/stackwalk.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if wxUSE_CRASHREPORT
|
||||||
|
#include "wx/msw/crashrpt.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if wxUSE_ZIPSTREAM
|
||||||
|
#include "wx/wfstream.h"
|
||||||
|
#include "wx/zipstrm.h"
|
||||||
|
#endif // wxUSE_ZIPSTREAM
|
||||||
|
|
||||||
|
#if wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// XmlStackWalker: stack walker specialization which dumps stack in XML
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class XmlStackWalker : public wxStackWalker
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
XmlStackWalker(wxXmlNode *nodeStack)
|
||||||
|
{
|
||||||
|
m_isOk = false;
|
||||||
|
m_nodeStack = nodeStack;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool IsOk() const { return m_isOk; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void OnStackFrame(const wxStackFrame& frame);
|
||||||
|
|
||||||
|
wxXmlNode *m_nodeStack;
|
||||||
|
bool m_isOk;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// local functions
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
HexProperty(wxXmlNode *node, const wxChar *name, unsigned long value)
|
||||||
|
{
|
||||||
|
node->AddProperty(name, wxString::Format(_T("%08x"), value));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
NumProperty(wxXmlNode *node, const wxChar *name, unsigned long value)
|
||||||
|
{
|
||||||
|
node->AddProperty(name, wxString::Format(_T("%lu"), value));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
TextElement(wxXmlNode *node, const wxChar *name, const wxString& value)
|
||||||
|
{
|
||||||
|
wxXmlNode *nodeChild = new wxXmlNode(wxXML_ELEMENT_NODE, name);
|
||||||
|
node->AddChild(nodeChild);
|
||||||
|
nodeChild->AddChild(new wxXmlNode(wxXML_TEXT_NODE, _T(""), value));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
HexElement(wxXmlNode *node, const wxChar *name, unsigned long value)
|
||||||
|
{
|
||||||
|
TextElement(node, name, wxString::Format(_T("%08x"), value));
|
||||||
|
}
|
||||||
|
|
||||||
|
#if wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// XmlStackWalker implementation
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
void XmlStackWalker::OnStackFrame(const wxStackFrame& frame)
|
||||||
|
{
|
||||||
|
m_isOk = true;
|
||||||
|
|
||||||
|
wxXmlNode *nodeFrame = new wxXmlNode(wxXML_ELEMENT_NODE, _T("frame"));
|
||||||
|
m_nodeStack->AddChild(nodeFrame);
|
||||||
|
|
||||||
|
NumProperty(nodeFrame, _T("level"), frame.GetLevel());
|
||||||
|
wxString func = frame.GetName();
|
||||||
|
if ( !func.empty() )
|
||||||
|
{
|
||||||
|
nodeFrame->AddProperty(_T("function"), func);
|
||||||
|
HexProperty(nodeFrame, _T("offset"), frame.GetOffset());
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( frame.HasSourceLocation() )
|
||||||
|
{
|
||||||
|
nodeFrame->AddProperty(_T("file"), frame.GetFileName());
|
||||||
|
NumProperty(nodeFrame, _T("line"), frame.GetLine());
|
||||||
|
}
|
||||||
|
|
||||||
|
const size_t nParams = frame.GetParamCount();
|
||||||
|
if ( nParams )
|
||||||
|
{
|
||||||
|
wxXmlNode *nodeParams = new wxXmlNode(wxXML_ELEMENT_NODE, _T("parameters"));
|
||||||
|
nodeFrame->AddChild(nodeParams);
|
||||||
|
|
||||||
|
for ( size_t n = 0; n < nParams; n++ )
|
||||||
|
{
|
||||||
|
wxXmlNode *
|
||||||
|
nodeParam = new wxXmlNode(wxXML_ELEMENT_NODE, _T("parameter"));
|
||||||
|
nodeParams->AddChild(nodeParam);
|
||||||
|
|
||||||
|
NumProperty(nodeParam, _T("number"), n);
|
||||||
|
|
||||||
|
wxString type, name, value;
|
||||||
|
if ( !frame.GetParam(n, &type, &name, &value) )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if ( !type.empty() )
|
||||||
|
TextElement(nodeParam, _T("type"), type);
|
||||||
|
|
||||||
|
if ( !name.empty() )
|
||||||
|
TextElement(nodeParam, _T("name"), name);
|
||||||
|
|
||||||
|
if ( !value.empty() )
|
||||||
|
TextElement(nodeParam, _T("value"), value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// wxDebugReport implementation
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// initialization and cleanup
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxDebugReport::wxDebugReport()
|
||||||
|
{
|
||||||
|
// get a temporary directory name
|
||||||
|
wxString appname(wxTheApp ? wxTheApp->GetAppName() : _T("wx"));
|
||||||
|
|
||||||
|
// we can't use CreateTempFileName() because it creates a file, not a
|
||||||
|
// directory, so do our best to create a unique name ourselves
|
||||||
|
//
|
||||||
|
// of course, this doesn't protect us against malicious users...
|
||||||
|
wxFileName fn;
|
||||||
|
fn.AssignTempFileName(appname);
|
||||||
|
m_dir.Printf(_T("%s%c%s_dbgrpt-%lu-%s"),
|
||||||
|
fn.GetPath(), wxFILE_SEP_PATH, appname.c_str(),
|
||||||
|
wxGetProcessId(),
|
||||||
|
wxDateTime::Now().Format(_T("%Y%m%dT%H%M%S")).c_str());
|
||||||
|
|
||||||
|
// as we are going to save the process state there use restrictive
|
||||||
|
// permissions
|
||||||
|
if ( !wxMkdir(m_dir, 0700) )
|
||||||
|
{
|
||||||
|
wxLogSysError(_("Failed to create directory \"%s\""), m_dir.c_str());
|
||||||
|
wxLogError(_("Debug report couldn't be created."));
|
||||||
|
|
||||||
|
Reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wxDebugReport::~wxDebugReport()
|
||||||
|
{
|
||||||
|
if ( !m_dir.empty() )
|
||||||
|
{
|
||||||
|
// remove all files in this directory
|
||||||
|
wxDir dir(m_dir);
|
||||||
|
wxString file;
|
||||||
|
for ( bool cont = dir.GetFirst(&file); cont; cont = dir.GetNext(&file) )
|
||||||
|
{
|
||||||
|
if ( wxRemove(wxFileName(m_dir, file).GetFullPath()) != 0 )
|
||||||
|
{
|
||||||
|
wxLogSysError(_("Failed to remove debug report file \"%s\""),
|
||||||
|
file.c_str());
|
||||||
|
m_dir.clear();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !m_dir.empty() )
|
||||||
|
{
|
||||||
|
if ( wxRmDir(m_dir) != 0 )
|
||||||
|
{
|
||||||
|
wxLogSysError(_("Failed to clean up debug report directory \"%s\""),
|
||||||
|
m_dir.c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// various helpers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxString wxDebugReport::GetReportName() const
|
||||||
|
{
|
||||||
|
return wxString(wxTheApp ? wxTheApp->GetAppName() : _T("wx"));
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDebugReport::AddFile(const wxString& name, const wxString& description)
|
||||||
|
{
|
||||||
|
m_files.Add(name);
|
||||||
|
m_descriptions.Add(description);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDebugReport::RemoveFile(const wxString& name)
|
||||||
|
{
|
||||||
|
const int n = m_files.Index(name);
|
||||||
|
wxCHECK_RET( n != wxNOT_FOUND, _T("No such file in wxDebugReport") );
|
||||||
|
|
||||||
|
m_files.RemoveAt(n);
|
||||||
|
m_descriptions.RemoveAt(n);
|
||||||
|
|
||||||
|
wxRemove(wxFileName(GetDirectory(), name).GetFullPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReport::GetFile(size_t n, wxString *name, wxString *desc) const
|
||||||
|
{
|
||||||
|
if ( n >= m_files.GetCount() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if ( name )
|
||||||
|
*name = m_files[n];
|
||||||
|
if ( desc )
|
||||||
|
*desc = m_descriptions[n];
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDebugReport::AddAll(Context context)
|
||||||
|
{
|
||||||
|
#if wxUSE_STACKWALKER
|
||||||
|
AddContext(context);
|
||||||
|
#endif // wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
#if wxUSE_CRASHREPORT
|
||||||
|
AddDump(context);
|
||||||
|
#endif // wxUSE_CRASHREPORT
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// adding basic text information about current context
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#if wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
bool wxDebugReport::DoAddSystemInfo(wxXmlNode *nodeSystemInfo)
|
||||||
|
{
|
||||||
|
nodeSystemInfo->AddProperty(_T("description"), wxGetOsDescription());
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReport::DoAddLoadedModules(wxXmlNode *nodeModules)
|
||||||
|
{
|
||||||
|
wxDynamicLibraryDetailsArray modules(wxDynamicLibrary::ListLoaded());
|
||||||
|
const size_t count = modules.GetCount();
|
||||||
|
if ( !count )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
const wxDynamicLibraryDetails& info = modules[n];
|
||||||
|
|
||||||
|
wxXmlNode *nodeModule = new wxXmlNode(wxXML_ELEMENT_NODE, _T("module"));
|
||||||
|
nodeModules->AddChild(nodeModule);
|
||||||
|
|
||||||
|
wxString path = info.GetPath();
|
||||||
|
if ( path.empty() )
|
||||||
|
path = info.GetName();
|
||||||
|
if ( !path.empty() )
|
||||||
|
nodeModule->AddProperty(_T("path"), path);
|
||||||
|
|
||||||
|
void *addr;
|
||||||
|
size_t len;
|
||||||
|
if ( info.GetAddress(&addr, &len) )
|
||||||
|
{
|
||||||
|
HexProperty(nodeModule, _T("address"), (unsigned long)addr);
|
||||||
|
HexProperty(nodeModule, _T("size"), len);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxString ver = info.GetVersion();
|
||||||
|
if ( !ver.empty() )
|
||||||
|
{
|
||||||
|
nodeModule->AddProperty(_T("version"), ver);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReport::DoAddExceptionInfo(wxXmlNode *nodeContext)
|
||||||
|
{
|
||||||
|
#if wxUSE_CRASHREPORT
|
||||||
|
wxCrashContext c;
|
||||||
|
if ( !c.code )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
wxXmlNode *nodeExc = new wxXmlNode(wxXML_ELEMENT_NODE, _T("exception"));
|
||||||
|
nodeContext->AddChild(nodeExc);
|
||||||
|
|
||||||
|
HexProperty(nodeExc, _T("code"), c.code);
|
||||||
|
nodeExc->AddProperty(_T("name"), c.GetExceptionString());
|
||||||
|
HexProperty(nodeExc, _T("address"), (unsigned long)c.addr);
|
||||||
|
|
||||||
|
#ifdef __INTEL__
|
||||||
|
wxXmlNode *nodeRegs = new wxXmlNode(wxXML_ELEMENT_NODE, _T("registers"));
|
||||||
|
nodeContext->AddChild(nodeRegs);
|
||||||
|
HexElement(nodeRegs, _T("eax"), c.regs.eax);
|
||||||
|
HexElement(nodeRegs, _T("ebx"), c.regs.ebx);
|
||||||
|
HexElement(nodeRegs, _T("ecx"), c.regs.edx);
|
||||||
|
HexElement(nodeRegs, _T("edx"), c.regs.edx);
|
||||||
|
HexElement(nodeRegs, _T("esi"), c.regs.esi);
|
||||||
|
HexElement(nodeRegs, _T("edi"), c.regs.edi);
|
||||||
|
|
||||||
|
HexElement(nodeRegs, _T("ebp"), c.regs.ebp);
|
||||||
|
HexElement(nodeRegs, _T("esp"), c.regs.esp);
|
||||||
|
HexElement(nodeRegs, _T("eip"), c.regs.eip);
|
||||||
|
|
||||||
|
HexElement(nodeRegs, _T("cs"), c.regs.cs);
|
||||||
|
HexElement(nodeRegs, _T("ds"), c.regs.ds);
|
||||||
|
HexElement(nodeRegs, _T("es"), c.regs.es);
|
||||||
|
HexElement(nodeRegs, _T("fs"), c.regs.fs);
|
||||||
|
HexElement(nodeRegs, _T("gs"), c.regs.gs);
|
||||||
|
HexElement(nodeRegs, _T("ss"), c.regs.ss);
|
||||||
|
|
||||||
|
HexElement(nodeRegs, _T("flags"), c.regs.flags);
|
||||||
|
#endif // __INTEL__
|
||||||
|
|
||||||
|
return true;
|
||||||
|
#else // !wxUSE_CRASHREPORT
|
||||||
|
wxUnusedVar(nodeContext);
|
||||||
|
|
||||||
|
return false;
|
||||||
|
#endif // wxUSE_CRASHREPORT/!wxUSE_CRASHREPORT
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReport::AddContext(wxDebugReport::Context ctx)
|
||||||
|
{
|
||||||
|
wxCHECK_MSG( IsOk(), false, _T("use IsOk() first") );
|
||||||
|
|
||||||
|
// create XML dump of current context
|
||||||
|
wxXmlDocument xmldoc;
|
||||||
|
wxXmlNode *nodeRoot = new wxXmlNode(wxXML_ELEMENT_NODE, _T("report"));
|
||||||
|
xmldoc.SetRoot(nodeRoot);
|
||||||
|
nodeRoot->AddProperty(_T("version"), _T("1.0"));
|
||||||
|
nodeRoot->AddProperty(_T("kind"), ctx == Context_Curent ? _T("user")
|
||||||
|
: _T("exception"));
|
||||||
|
|
||||||
|
// add system information
|
||||||
|
wxXmlNode *nodeSystemInfo = new wxXmlNode(wxXML_ELEMENT_NODE, _T("system"));
|
||||||
|
if ( DoAddSystemInfo(nodeSystemInfo) )
|
||||||
|
nodeRoot->AddChild(nodeSystemInfo);
|
||||||
|
else
|
||||||
|
delete nodeSystemInfo;
|
||||||
|
|
||||||
|
// add information about the loaded modules
|
||||||
|
wxXmlNode *nodeModules = new wxXmlNode(wxXML_ELEMENT_NODE, _T("modules"));
|
||||||
|
if ( DoAddLoadedModules(nodeModules) )
|
||||||
|
nodeRoot->AddChild(nodeModules);
|
||||||
|
else
|
||||||
|
delete nodeModules;
|
||||||
|
|
||||||
|
// add CPU context information: this only makes sense for exceptions as our
|
||||||
|
// current context is not very interesting otherwise
|
||||||
|
if ( ctx == Context_Exception )
|
||||||
|
{
|
||||||
|
wxXmlNode *nodeContext = new wxXmlNode(wxXML_ELEMENT_NODE, _T("context"));
|
||||||
|
if ( DoAddExceptionInfo(nodeContext) )
|
||||||
|
nodeRoot->AddChild(nodeContext);
|
||||||
|
else
|
||||||
|
delete nodeContext;
|
||||||
|
}
|
||||||
|
|
||||||
|
// add stack traceback
|
||||||
|
#if wxUSE_STACKWALKER
|
||||||
|
wxXmlNode *nodeStack = new wxXmlNode(wxXML_ELEMENT_NODE, _T("stack"));
|
||||||
|
XmlStackWalker sw(nodeStack);
|
||||||
|
if ( ctx == Context_Exception )
|
||||||
|
{
|
||||||
|
sw.WalkFromException();
|
||||||
|
}
|
||||||
|
else // Context_Curent
|
||||||
|
{
|
||||||
|
sw.Walk();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( sw.IsOk() )
|
||||||
|
nodeRoot->AddChild(nodeStack);
|
||||||
|
else
|
||||||
|
delete nodeStack;
|
||||||
|
#endif // wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
// finally let the user add any extra information he needs
|
||||||
|
DoAddCustomContext(nodeRoot);
|
||||||
|
|
||||||
|
|
||||||
|
// save the entire context dump in a file
|
||||||
|
wxFileName fn(m_dir, GetReportName(), _T("xml"));
|
||||||
|
|
||||||
|
if ( !xmldoc.Save(fn.GetFullPath()) )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
AddFile(fn.GetFullName(), _("process context description"));
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_STACKWALKER
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// adding core dump
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#if wxUSE_CRASHREPORT
|
||||||
|
|
||||||
|
bool wxDebugReport::AddDump(Context ctx)
|
||||||
|
{
|
||||||
|
wxCHECK_MSG( IsOk(), false, _T("use IsOk() first") );
|
||||||
|
|
||||||
|
wxFileName fn(m_dir, GetReportName(), _T("dmp"));
|
||||||
|
wxCrashReport::SetFileName(fn.GetFullPath());
|
||||||
|
|
||||||
|
if ( !(ctx == Context_Exception ? wxCrashReport::Generate()
|
||||||
|
: wxCrashReport::GenerateNow()) )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
AddFile(fn.GetFullName(), _("dump of the process state (binary)"));
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_CRASHREPORT
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// report processing
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxDebugReport::Process()
|
||||||
|
{
|
||||||
|
if ( !GetFilesCount() )
|
||||||
|
{
|
||||||
|
wxLogError(_("Debug report generation has failed."));
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !DoProcess() )
|
||||||
|
{
|
||||||
|
wxLogError(_("Processing debug report has failed, leaving the files in \"%s\" directory."),
|
||||||
|
GetDirectory().c_str());
|
||||||
|
|
||||||
|
Reset();
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReport::DoProcess()
|
||||||
|
{
|
||||||
|
wxString msg = _("*** A debug report has been generated\n");
|
||||||
|
msg += wxString::Format(_("*** It can be found in \"%s\"\n"),
|
||||||
|
GetDirectory().c_str());
|
||||||
|
msg += _("*** And includes the following files:\n");
|
||||||
|
|
||||||
|
wxString name, desc;
|
||||||
|
const size_t count = GetFilesCount();
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
GetFile(n, &name, &desc);
|
||||||
|
msg += wxString::Format(_("\t%s: %s\n"), name.c_str(), desc.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
msg += _("\nPlease send this report to the program maintainer, thank you!\n");
|
||||||
|
|
||||||
|
wxLogMessage(_T("%s"), msg.c_str());
|
||||||
|
|
||||||
|
// we have to do this or the report would be deleted, and we don't even
|
||||||
|
// have any way to ask the user if he wants to keep it from here
|
||||||
|
Reset();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// wxDebugReport-derived classes
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
#if wxUSE_ZIPSTREAM
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportCompress
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxDebugReportCompress::DoProcess()
|
||||||
|
{
|
||||||
|
const size_t count = GetFilesCount();
|
||||||
|
if ( !count )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// create the streams
|
||||||
|
wxFileName fn(GetDirectory(), GetReportName(), _T("zip"));
|
||||||
|
wxFFileOutputStream os(fn.GetFullPath(), _T("wb"));
|
||||||
|
wxZipOutputStream zos(os, 9);
|
||||||
|
|
||||||
|
// add all files to the ZIP one
|
||||||
|
wxString name, desc;
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
GetFile(n, &name, &desc);
|
||||||
|
|
||||||
|
wxZipEntry *ze = new wxZipEntry(name);
|
||||||
|
ze->SetComment(desc);
|
||||||
|
|
||||||
|
if ( !zos.PutNextEntry(ze) )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
wxFFileInputStream is(wxFileName(fn.GetPath(), name).GetFullPath());
|
||||||
|
if ( !is.IsOk() || !zos.Write(is).IsOk() )
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !zos.Close() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
m_zipfile = fn.GetFullPath();
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportUpload
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxDebugReportUpload::wxDebugReportUpload(const wxString& url,
|
||||||
|
const wxString& input,
|
||||||
|
const wxString& action,
|
||||||
|
const wxString& curl)
|
||||||
|
: m_uploadURL(url),
|
||||||
|
m_inputField(input),
|
||||||
|
m_curlCmd(curl)
|
||||||
|
{
|
||||||
|
if ( m_uploadURL.Last() != _T('/') )
|
||||||
|
m_uploadURL += _T('/');
|
||||||
|
m_uploadURL += action;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReportUpload::DoProcess()
|
||||||
|
{
|
||||||
|
if ( !wxDebugReportCompress::DoProcess() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
|
||||||
|
wxArrayString output, errors;
|
||||||
|
int rc = wxExecute(wxString::Format
|
||||||
|
(
|
||||||
|
_T("%s -F %s=@%s %s"),
|
||||||
|
m_curlCmd.c_str(),
|
||||||
|
m_inputField.c_str(),
|
||||||
|
GetCompressedFileName().c_str(),
|
||||||
|
m_uploadURL.c_str()
|
||||||
|
),
|
||||||
|
output,
|
||||||
|
errors);
|
||||||
|
if ( rc == -1 )
|
||||||
|
{
|
||||||
|
wxLogError(_("Failed to execute curl, please install it in PATH."));
|
||||||
|
}
|
||||||
|
else if ( rc != 0 )
|
||||||
|
{
|
||||||
|
const size_t count = errors.GetCount();
|
||||||
|
if ( count )
|
||||||
|
{
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
wxLogWarning(_T("%s"), errors[n].c_str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wxLogError(_("Failed to upload the debug report (error code %d)."), rc);
|
||||||
|
}
|
||||||
|
else // rc == 0
|
||||||
|
{
|
||||||
|
if ( OnServerReply(output) )
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_ZIPSTREAM
|
||||||
|
|
||||||
|
#endif // wxUSE_DEBUGREPORT
|
||||||
|
|
488
src/generic/dbgrptg.cpp
Normal file
488
src/generic/dbgrptg.cpp
Normal file
@@ -0,0 +1,488 @@
|
|||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Name: src/generic/dbgrptg.cpp
|
||||||
|
// Purpose: implementation of wxDebugReportPreviewStd
|
||||||
|
// Author: Vadim Zeitlin, Andrej Putrin
|
||||||
|
// Modified by:
|
||||||
|
// Created: 2005-01-21
|
||||||
|
// RCS-ID: $Id$
|
||||||
|
// Copyright: (c) 2005 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
|
||||||
|
// License: wxWindows licence
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// declarations
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// headers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#include "wx/wxprec.h"
|
||||||
|
|
||||||
|
#ifdef __BORLANDC__
|
||||||
|
#pragma hdrstop
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef WX_PRECOMP
|
||||||
|
#include "wx/sizer.h"
|
||||||
|
#include "wx/checklst.h"
|
||||||
|
#include "wx/textctrl.h"
|
||||||
|
#endif // WX_PRECOMP
|
||||||
|
|
||||||
|
#if wxUSE_DEBUGREPORT
|
||||||
|
|
||||||
|
#include "wx/debugrpt.h"
|
||||||
|
|
||||||
|
#include "wx/intl.h"
|
||||||
|
#include "wx/filename.h"
|
||||||
|
#include "wx/ffile.h"
|
||||||
|
#include "wx/mimetype.h"
|
||||||
|
|
||||||
|
#include "wx/statline.h"
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDumpPreviewDlg: simple class for showing ASCII preview of dump files
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDumpPreviewDlg : public wxDialog
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxDumpPreviewDlg(wxWindow *parent,
|
||||||
|
const wxString& title,
|
||||||
|
const wxString& text);
|
||||||
|
|
||||||
|
private:
|
||||||
|
// the text we show
|
||||||
|
wxTextCtrl *m_text;
|
||||||
|
|
||||||
|
DECLARE_NO_COPY_CLASS(wxDumpPreviewDlg)
|
||||||
|
};
|
||||||
|
|
||||||
|
wxDumpPreviewDlg::wxDumpPreviewDlg(wxWindow *parent,
|
||||||
|
const wxString& title,
|
||||||
|
const wxString& text)
|
||||||
|
: wxDialog(parent, wxID_ANY, title,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER)
|
||||||
|
{
|
||||||
|
// create controls
|
||||||
|
// ---------------
|
||||||
|
|
||||||
|
// use wxTE_RICH2 style to avoid 64kB limit under MSW and display big files
|
||||||
|
// faster than with wxTE_RICH
|
||||||
|
m_text = new wxTextCtrl(this, wxID_ANY, wxEmptyString,
|
||||||
|
wxPoint(0, 0), wxDefaultSize,
|
||||||
|
wxTE_MULTILINE |
|
||||||
|
wxTE_READONLY |
|
||||||
|
wxTE_NOHIDESEL |
|
||||||
|
wxTE_RICH2);
|
||||||
|
m_text->SetValue(text);
|
||||||
|
|
||||||
|
// use fixed-width font
|
||||||
|
m_text->SetFont(wxFont(12, wxFONTFAMILY_TELETYPE,
|
||||||
|
wxFONTSTYLE_NORMAL, wxFONTWEIGHT_NORMAL));
|
||||||
|
|
||||||
|
wxButton *btnClose = new wxButton(this, wxID_CANCEL, _("Close"));
|
||||||
|
|
||||||
|
|
||||||
|
// layout them
|
||||||
|
// -----------
|
||||||
|
|
||||||
|
wxSizer *sizerTop = new wxBoxSizer(wxVERTICAL),
|
||||||
|
*sizerBtns = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
||||||
|
sizerBtns->Add(btnClose, 0, 0, 1);
|
||||||
|
|
||||||
|
sizerTop->Add(m_text, 1, wxEXPAND);
|
||||||
|
sizerTop->Add(sizerBtns, 0, wxALIGN_RIGHT | wxTOP | wxBOTTOM | wxRIGHT, 1);
|
||||||
|
|
||||||
|
// set the sizer &c
|
||||||
|
// ----------------
|
||||||
|
|
||||||
|
// make the text window bigger to show more contents of the file
|
||||||
|
sizerTop->SetItemMinSize(m_text, 600, 300);
|
||||||
|
SetSizer(sizerTop);
|
||||||
|
|
||||||
|
Layout();
|
||||||
|
Fit();
|
||||||
|
|
||||||
|
m_text->SetFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDumpOpenExternalDlg: choose a command for opening the given file
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDumpOpenExternalDlg : public wxDialog
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxDumpOpenExternalDlg(wxWindow *parent, const wxFileName& filename);
|
||||||
|
|
||||||
|
// return the command chosed by user to open this file
|
||||||
|
const wxString& GetCommand() const { return m_command; }
|
||||||
|
|
||||||
|
wxString m_command;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void OnBrowse(wxCommandEvent& event);
|
||||||
|
|
||||||
|
DECLARE_EVENT_TABLE()
|
||||||
|
DECLARE_NO_COPY_CLASS(wxDumpOpenExternalDlg)
|
||||||
|
};
|
||||||
|
|
||||||
|
BEGIN_EVENT_TABLE(wxDumpOpenExternalDlg, wxDialog)
|
||||||
|
EVT_BUTTON(wxID_MORE, wxDumpOpenExternalDlg::OnBrowse)
|
||||||
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
|
||||||
|
wxDumpOpenExternalDlg::wxDumpOpenExternalDlg(wxWindow *parent,
|
||||||
|
const wxFileName& filename)
|
||||||
|
: wxDialog(parent,
|
||||||
|
wxID_ANY,
|
||||||
|
wxString::Format
|
||||||
|
(
|
||||||
|
_("Open file \"%s\""),
|
||||||
|
filename.GetFullPath().c_str()
|
||||||
|
))
|
||||||
|
{
|
||||||
|
// create controls
|
||||||
|
// ---------------
|
||||||
|
|
||||||
|
wxSizer *sizerTop = new wxBoxSizer(wxVERTICAL);
|
||||||
|
sizerTop->Add(new wxStaticText(this, wxID_ANY,
|
||||||
|
wxString::Format
|
||||||
|
(
|
||||||
|
_("Enter command to open file \"%s\":"),
|
||||||
|
filename.GetFullName().c_str()
|
||||||
|
)),
|
||||||
|
wxSizerFlags().Border());
|
||||||
|
|
||||||
|
wxSizer *sizerH = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
|
||||||
|
wxTextCtrl *command = new wxTextCtrl
|
||||||
|
(
|
||||||
|
this,
|
||||||
|
wxID_ANY,
|
||||||
|
wxEmptyString,
|
||||||
|
wxDefaultPosition,
|
||||||
|
wxSize(250, -1),
|
||||||
|
0,
|
||||||
|
wxTextValidator(wxFILTER_NONE, &m_command)
|
||||||
|
);
|
||||||
|
sizerH->Add(command,
|
||||||
|
wxSizerFlags(1).Align(wxALIGN_CENTER_VERTICAL));
|
||||||
|
wxButton *browse = new wxButton(this, wxID_MORE, wxT(">>"),
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxBU_EXACTFIT);
|
||||||
|
sizerH->Add(browse,
|
||||||
|
wxSizerFlags(0).Align(wxALIGN_CENTER_VERTICAL). Border(wxLEFT));
|
||||||
|
|
||||||
|
sizerTop->Add(sizerH, wxSizerFlags(0).Expand().Border());
|
||||||
|
|
||||||
|
sizerTop->Add(new wxStaticLine(this), wxSizerFlags().Expand().Border());
|
||||||
|
|
||||||
|
sizerTop->Add(CreateStdDialogButtonSizer(wxOK | wxCANCEL),
|
||||||
|
wxSizerFlags().Align(wxALIGN_RIGHT).Border());
|
||||||
|
|
||||||
|
// set the sizer &c
|
||||||
|
// ----------------
|
||||||
|
|
||||||
|
SetSizer(sizerTop);
|
||||||
|
|
||||||
|
Layout();
|
||||||
|
Fit();
|
||||||
|
|
||||||
|
command->SetFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDumpOpenExternalDlg::OnBrowse(wxCommandEvent& )
|
||||||
|
{
|
||||||
|
wxFileName fname(m_command);
|
||||||
|
wxFileDialog dlg(this,
|
||||||
|
wxFileSelectorPromptStr,
|
||||||
|
fname.GetPathWithSep(),
|
||||||
|
fname.GetFullName()
|
||||||
|
#ifdef __WXMSW__
|
||||||
|
, _("Executable files (*.exe)|*.exe|All files (*.*)|*.*||")
|
||||||
|
#endif // __WXMSW__
|
||||||
|
);
|
||||||
|
if ( dlg.ShowModal() == wxID_OK )
|
||||||
|
{
|
||||||
|
m_command = dlg.GetPath();
|
||||||
|
TransferDataToWindow();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxDebugReportDialog: class showing debug report to the user
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class wxDebugReportDialog : public wxDialog
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxDebugReportDialog(wxDebugReport& dbgrpt);
|
||||||
|
|
||||||
|
virtual bool TransferDataToWindow();
|
||||||
|
virtual bool TransferDataFromWindow();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void OnView(wxCommandEvent& );
|
||||||
|
void OnViewUpdate(wxUpdateUIEvent& );
|
||||||
|
void OnOpen(wxCommandEvent& );
|
||||||
|
|
||||||
|
|
||||||
|
// small helper: add wxEXPAND and wxALL flags
|
||||||
|
static wxSizerFlags SizerFlags(int proportion)
|
||||||
|
{
|
||||||
|
return wxSizerFlags(proportion).Expand().Border();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
wxDebugReport& m_dbgrpt;
|
||||||
|
|
||||||
|
wxCheckListBox *m_checklst;
|
||||||
|
wxTextCtrl *m_notes;
|
||||||
|
|
||||||
|
wxArrayString m_files;
|
||||||
|
|
||||||
|
DECLARE_EVENT_TABLE()
|
||||||
|
DECLARE_NO_COPY_CLASS(wxDebugReportDialog)
|
||||||
|
};
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// wxDebugReportDialog implementation
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
BEGIN_EVENT_TABLE(wxDebugReportDialog, wxDialog)
|
||||||
|
EVT_BUTTON(wxID_VIEW_DETAILS, wxDebugReportDialog::OnView)
|
||||||
|
EVT_UPDATE_UI(wxID_VIEW_DETAILS, wxDebugReportDialog::OnViewUpdate)
|
||||||
|
EVT_BUTTON(wxID_OPEN, wxDebugReportDialog::OnOpen)
|
||||||
|
EVT_UPDATE_UI(wxID_OPEN, wxDebugReportDialog::OnViewUpdate)
|
||||||
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// construction
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
wxDebugReportDialog::wxDebugReportDialog(wxDebugReport& dbgrpt)
|
||||||
|
: wxDialog(NULL, wxID_ANY,
|
||||||
|
wxString::Format(_("Debug report \"%s\""),
|
||||||
|
dbgrpt.GetReportName().c_str()),
|
||||||
|
wxDefaultPosition,
|
||||||
|
wxDefaultSize,
|
||||||
|
wxDEFAULT_DIALOG_STYLE | wxTHICK_FRAME),
|
||||||
|
m_dbgrpt(dbgrpt)
|
||||||
|
{
|
||||||
|
// upper part of the dialog: explanatory message
|
||||||
|
wxString msg;
|
||||||
|
msg << _("A debug report has been generated in the directory\n")
|
||||||
|
<< _T('\n')
|
||||||
|
<< _T(" \"") << dbgrpt.GetDirectory() << _T("\"\n")
|
||||||
|
<< _T('\n')
|
||||||
|
<< _("The report contains the files listed below. If any of these ")
|
||||||
|
<< _("files contain private information,\n")
|
||||||
|
<< _("please uncheck them and they will be removed from the report.\n")
|
||||||
|
<< _T('\n')
|
||||||
|
<< _("If you wish to suppress this debug report completely, please ")
|
||||||
|
<< _("choose the \"Cancel\" button,\n")
|
||||||
|
<< _("but be warned that it may hinder improving the program, so if\n")
|
||||||
|
<< _("at all possible please do continue with the report generation.\n")
|
||||||
|
<< _T('\n')
|
||||||
|
<< _(" Thank you and we're sorry for the inconvenience!\n")
|
||||||
|
<< _T("\n\n"); // just some white space to separate from other stuff
|
||||||
|
|
||||||
|
const wxSizerFlags flagsFixed(SizerFlags(0));
|
||||||
|
const wxSizerFlags flagsExpand(SizerFlags(1));
|
||||||
|
const wxSizerFlags flagsExpand2(SizerFlags(2));
|
||||||
|
|
||||||
|
wxSizer *sizerPreview =
|
||||||
|
new wxStaticBoxSizer(wxVERTICAL, this, _("&Debug report preview:"));
|
||||||
|
sizerPreview->Add(CreateTextSizer(msg), SizerFlags(0).Centre());
|
||||||
|
|
||||||
|
// ... and the list of files in this debug report with buttons to view them
|
||||||
|
wxSizer *sizerFileBtns = new wxBoxSizer(wxVERTICAL);
|
||||||
|
sizerFileBtns->AddStretchSpacer(1);
|
||||||
|
sizerFileBtns->Add(new wxButton(this, wxID_VIEW_DETAILS, _T("&View...")),
|
||||||
|
wxSizerFlags().Border(wxBOTTOM));
|
||||||
|
sizerFileBtns->Add(new wxButton(this, wxID_OPEN, _T("&Open...")),
|
||||||
|
wxSizerFlags().Border(wxTOP));
|
||||||
|
sizerFileBtns->AddStretchSpacer(1);
|
||||||
|
|
||||||
|
m_checklst = new wxCheckListBox(this, wxID_ANY);
|
||||||
|
|
||||||
|
wxSizer *sizerFiles = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
sizerFiles->Add(m_checklst, flagsExpand);
|
||||||
|
sizerFiles->Add(sizerFileBtns, flagsFixed);
|
||||||
|
|
||||||
|
sizerPreview->Add(sizerFiles, flagsExpand2);
|
||||||
|
|
||||||
|
|
||||||
|
// lower part of the dialog: notes field
|
||||||
|
wxSizer *sizerNotes = new wxStaticBoxSizer(wxVERTICAL, this, _("&Notes:"));
|
||||||
|
|
||||||
|
msg = _("If you have any additional information pertaining to this bug\n");
|
||||||
|
msg << _("report, please enter it here and it will be joined to it:");
|
||||||
|
|
||||||
|
m_notes = new wxTextCtrl(this, wxID_ANY, wxEmptyString,
|
||||||
|
wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_MULTILINE);
|
||||||
|
|
||||||
|
sizerNotes->Add(CreateTextSizer(msg), flagsFixed);
|
||||||
|
sizerNotes->Add(m_notes, flagsExpand);
|
||||||
|
|
||||||
|
|
||||||
|
wxSizer *sizerTop = new wxBoxSizer(wxVERTICAL);
|
||||||
|
sizerTop->Add(sizerPreview, flagsExpand2);
|
||||||
|
sizerTop->AddSpacer(5);
|
||||||
|
sizerTop->Add(sizerNotes, flagsExpand);
|
||||||
|
sizerTop->Add(CreateStdDialogButtonSizer(wxOK | wxCANCEL), flagsFixed);
|
||||||
|
|
||||||
|
SetSizerAndFit(sizerTop);
|
||||||
|
Layout();
|
||||||
|
CentreOnScreen();
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// data exchange
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxDebugReportDialog::TransferDataToWindow()
|
||||||
|
{
|
||||||
|
// all files are included in the report by default
|
||||||
|
const size_t count = m_dbgrpt.GetFilesCount();
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
wxString name,
|
||||||
|
desc;
|
||||||
|
if ( m_dbgrpt.GetFile(n, &name, &desc) )
|
||||||
|
{
|
||||||
|
m_checklst->Append(name + _T(" (") + desc + _T(')'));
|
||||||
|
m_checklst->Check(n);
|
||||||
|
|
||||||
|
m_files.Add(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxDebugReportDialog::TransferDataFromWindow()
|
||||||
|
{
|
||||||
|
// any unchecked files should be removed from the report
|
||||||
|
const size_t count = m_checklst->GetCount();
|
||||||
|
for ( size_t n = 0; n < count; n++ )
|
||||||
|
{
|
||||||
|
if ( !m_checklst->IsChecked(n) )
|
||||||
|
{
|
||||||
|
m_dbgrpt.RemoveFile(m_files[n]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// if the user entered any notes, add them to the report
|
||||||
|
const wxString notes = m_notes->GetValue();
|
||||||
|
if ( !notes.empty() )
|
||||||
|
{
|
||||||
|
// for now it's fixed, could make it configurable in the future...
|
||||||
|
const wxChar *NOTES_FILE_NAME = _T("notes.txt");
|
||||||
|
wxFileName fn(m_dbgrpt.GetDirectory(), NOTES_FILE_NAME);
|
||||||
|
wxFFile file(fn.GetFullPath(), _T("w"));
|
||||||
|
if ( file.IsOpened() && file.Write(notes) )
|
||||||
|
{
|
||||||
|
m_dbgrpt.AddFile(NOTES_FILE_NAME, _T("user notes"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// event handlers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void wxDebugReportDialog::OnView(wxCommandEvent& )
|
||||||
|
{
|
||||||
|
const int sel = m_checklst->GetSelection();
|
||||||
|
wxCHECK_RET( sel != -1, _T("invalid selection in OnView()") );
|
||||||
|
|
||||||
|
wxFileName fn(m_dbgrpt.GetDirectory(), m_files[sel]);
|
||||||
|
wxString str;
|
||||||
|
|
||||||
|
wxFFile file(fn.GetFullPath());
|
||||||
|
if ( file.IsOpened() && file.ReadAll(&str) )
|
||||||
|
{
|
||||||
|
wxDumpPreviewDlg dlg(this, m_files[sel], str);
|
||||||
|
dlg.ShowModal();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDebugReportDialog::OnOpen(wxCommandEvent& )
|
||||||
|
{
|
||||||
|
const int sel = m_checklst->GetSelection();
|
||||||
|
wxCHECK_RET( sel != -1, _T("invalid selection in OnOpen()") );
|
||||||
|
|
||||||
|
wxFileName fn(m_dbgrpt.GetDirectory(), m_files[sel]);
|
||||||
|
|
||||||
|
// try to get the command to open this kind of files ourselves
|
||||||
|
wxString command;
|
||||||
|
wxFileType *
|
||||||
|
ft = wxTheMimeTypesManager->GetFileTypeFromExtension(fn.GetExt());
|
||||||
|
if ( ft )
|
||||||
|
{
|
||||||
|
command = ft->GetOpenCommand(fn.GetFullPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
// if we couldn't, ask the user
|
||||||
|
if ( command.empty() )
|
||||||
|
{
|
||||||
|
wxDumpOpenExternalDlg dlg(this, fn);
|
||||||
|
if ( dlg.ShowModal() == wxID_OK )
|
||||||
|
{
|
||||||
|
// get the command chosen by the user and append file name to it
|
||||||
|
|
||||||
|
// if we don't have place marker for file name in the command...
|
||||||
|
wxString cmd = dlg.GetCommand();
|
||||||
|
if ( cmd.find(_T('%')) == wxString::npos )
|
||||||
|
{
|
||||||
|
// ...add it
|
||||||
|
cmd += _T(" \"%s\"");
|
||||||
|
}
|
||||||
|
|
||||||
|
command = wxFileType::ExpandCommand(cmd, fn.GetFullPath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !command.empty() )
|
||||||
|
::wxExecute(command);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxDebugReportDialog::OnViewUpdate(wxUpdateUIEvent& event)
|
||||||
|
{
|
||||||
|
int sel = m_checklst->GetSelection();
|
||||||
|
if (sel >= 0)
|
||||||
|
{
|
||||||
|
wxFileName fn(m_dbgrpt.GetDirectory(), m_files[sel]);
|
||||||
|
event.Enable(fn.FileExists());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
event.Enable(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// wxDebugReportPreviewStd implementation
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
bool wxDebugReportPreviewStd::Show(wxDebugReport& dbgrpt) const
|
||||||
|
{
|
||||||
|
if ( !dbgrpt.GetFilesCount() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
wxDebugReportDialog dlg(dbgrpt);
|
||||||
|
|
||||||
|
return dlg.ShowModal() == wxID_OK && dbgrpt.GetFilesCount() != 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // wxUSE_DEBUGREPORT
|
||||||
|
|
@@ -401,6 +401,10 @@ SOURCE=.\common\dcbase.cpp
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\common\debugrpt.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\common\dircmn.cpp
|
SOURCE=.\common\dircmn.cpp
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -918,6 +922,10 @@ SOURCE=.\generic\datectlg.cpp
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=.\generic\dbgrptg.cpp
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=.\generic\dcpsg.cpp
|
SOURCE=.\generic\dcpsg.cpp
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
@@ -2139,6 +2147,10 @@ SOURCE=..\include\wx\debug.h
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\include\wx\debugrpt.h
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=..\include\wx\defs.h
|
SOURCE=..\include\wx\defs.h
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
Reference in New Issue
Block a user