From 0d382a262c0638d0f572fc37193ccc5ed3dc895f Mon Sep 17 00:00:00 2001 From: tpearson Date: Wed, 17 Feb 2010 00:32:19 +0000 Subject: [PATCH] Added old abandoned version of k9copy git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/k9copy@1091546 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- AUTHORS | 1 + COPYING | 340 + ChangeLog | 1 + INSTALL | 167 + Makefile.am | 39 + Makefile.cvs | 10 + NEWS | 1 + README | 12 + TODO | 3 + acinclude.m4 | 11207 +++++++++++++++++++++++++++ aclocal.m4 | 881 +++ config.h.in | 257 + configure.files | 3 + configure.in | 273 + configure.in.in | 54 + doc/Makefile.am | 6 + doc/k9copy/Makefile.am | 5 + doc/k9copy/btncopy.png | Bin 0 -> 1431 bytes doc/k9copy/btnmp4.png | Bin 0 -> 1637 bytes doc/k9copy/index.docbook | 459 ++ doc/k9copy/index.xml | 445 ++ doc/k9copy/keepmenus.png | Bin 0 -> 1740 bytes doc/k9copy/mainwindow.png | Bin 0 -> 156069 bytes doc/k9copy/open1.png | Bin 0 -> 5433 bytes doc/k9copy/open2.png | Bin 0 -> 1345 bytes doc/k9copy/playback.png | Bin 0 -> 16550 bytes doc/k9copy/settingsDVD.png | Bin 0 -> 41718 bytes doc/k9copy/settingsMP4.png | Bin 0 -> 40664 bytes doc/k9copy/settingsMencoder.png | Bin 0 -> 52333 bytes doc/k9copy/treeview.png | Bin 0 -> 34120 bytes dvdread/Makefile.am | 8 + dvdread/bswap.h | 126 + dvdread/dvd_input.c | 414 + dvdread/dvd_input.h | 55 + dvdread/dvd_reader.c | 1614 ++++ dvdread/dvd_reader.h | 344 + dvdread/dvd_udf.c | 1216 +++ dvdread/dvd_udf.h | 66 + dvdread/dvdread_internal.h | 18 + dvdread/ifo_read.c | 2181 ++++++ dvdread/ifo_read.h | 228 + dvdread/ifo_types.h | 893 +++ dvdread/md5.c | 407 + dvdread/md5.h | 162 + dvdread/nav_read.c | 209 + dvdread/nav_read.h | 52 + dvdread/nav_types.h | 307 + k9Mplayer/Makefile.am | 8 + k9Mplayer/k9mplayer.cpp | 234 + k9Mplayer/k9mplayer.h | 66 + k9Mplayer/mplayer.cpp | 663 ++ k9Mplayer/mplayer.ui | 439 ++ k9author/Makefile.am | 18 + k9author/chapterEdit.cpp | 212 + k9author/chapterEdit.ui | 359 + k9author/import.cpp | 130 + k9author/import.ui | 207 + k9author/k9avidecode.cpp | 265 + k9author/k9avidecode.h | 112 + k9author/k9avifile.cpp | 185 + k9author/k9avifile.h | 80 + k9author/k9canvasselection.cpp | 330 + k9author/k9canvasselection.h | 71 + k9author/k9chapteredit.cpp | 200 + k9author/k9chapteredit.h | 60 + k9author/k9import.cpp | 250 + k9author/k9import.h | 79 + k9author/k9importfiles.cpp | 52 + k9author/k9importfiles.h | 42 + k9author/k9lvitemimport.cpp | 54 + k9author/k9lvitemimport.h | 43 + k9author/k9menu.cpp | 333 + k9author/k9menu.h | 71 + k9author/k9menubutton.cpp | 296 + k9author/k9menubutton.h | 116 + k9author/k9menuedit.cpp | 319 + k9author/k9menuedit.h | 85 + k9author/k9menueditor.cpp | 237 + k9author/k9menueditor.h | 64 + k9author/k9newdvd.cpp | 439 ++ k9author/k9newdvd.h | 95 + k9author/k9newtitle.cpp | 171 + k9author/k9newtitle.h | 52 + k9author/k9title.cpp | 64 + k9author/k9title.h | 57 + k9author/menuEdit.cpp | 211 + k9author/menuEdit.ui | 342 + k9author/newTitle.cpp | 158 + k9author/newTitle.ui | 284 + k9decmpeg/Makefile.am | 19 + k9decmpeg/alloc.cpp | 70 + k9decmpeg/attributes.h | 37 + k9decmpeg/bswap.h | 98 + k9decmpeg/convert_internal.h | 41 + k9decmpeg/cpu_accel.cpp | 220 + k9decmpeg/cpu_state.cpp | 128 + k9decmpeg/decode.cpp | 446 ++ k9decmpeg/header.cpp | 892 +++ k9decmpeg/idct.cpp | 286 + k9decmpeg/idct_alpha.cpp | 378 + k9decmpeg/idct_altivec.cpp | 287 + k9decmpeg/idct_mmx.cpp | 812 ++ k9decmpeg/k9decodethread.cpp | 105 + k9decmpeg/k9decodethread.h | 52 + k9decmpeg/k9plaympeg2.cpp | 277 + k9decmpeg/k9plaympeg2.h | 66 + k9decmpeg/kdecmpeg2.cpp | 439 ++ k9decmpeg/kdecmpeg2.h | 99 + k9decmpeg/mmx.h | 263 + k9decmpeg/motion_comp.cpp | 130 + k9decmpeg/motion_comp_alpha.cpp | 253 + k9decmpeg/motion_comp_altivec.cpp | 1010 +++ k9decmpeg/motion_comp_mmx.cpp | 1005 +++ k9decmpeg/motion_comp_vis.cpp | 2061 +++++ k9decmpeg/mpeg2.h | 196 + k9decmpeg/mpeg2_internal.h | 300 + k9decmpeg/mpeg2convert.h | 48 + k9decmpeg/rgb.cpp | 583 ++ k9decmpeg/rgb_mmx.cpp | 310 + k9decmpeg/rgb_vis.cpp | 384 + k9decmpeg/slice.cpp | 2058 +++++ k9decmpeg/tendra.h | 35 + k9decmpeg/uyvy.cpp | 127 + k9decmpeg/video_out.h | 58 + k9decmpeg/vis.h | 328 + k9decmpeg/vlc.h | 429 + k9devices/Makefile.am | 10 + k9devices/configure.in.in | 134 + k9devices/k9cddrive.cpp | 199 + k9devices/k9cddrive.h | 87 + k9devices/k9dbusdispatch.cpp | 231 + k9devices/k9dbusdispatch.h | 66 + k9devices/k9halconnection.cpp | 159 + k9devices/k9halconnection.h | 66 + k9devices/k9haldevice.cpp | 112 + k9devices/k9haldevice.h | 86 + k9vamps/Makefile.am | 12 + k9vamps/ac.h | 83 + k9vamps/cputest.cpp | 274 + k9vamps/getvlc.h | 401 + k9vamps/k9fifo.cpp | 54 + k9vamps/k9fifo.h | 39 + k9vamps/k9requant.cpp | 2481 ++++++ k9vamps/k9requant.h | 278 + k9vamps/k9requant2.h | 126 + k9vamps/k9vamps.cpp | 1100 +++ k9vamps/k9vamps.h | 168 + k9vamps/putvlc.h | 250 + k9vamps/qTable.h | 1141 +++ k9vamps/tcmemcpy.cpp | 483 ++ libdvdnav/Makefile.am | 14 + libdvdnav/common.h | 16 + libdvdnav/compat.h | 58 + libdvdnav/decoder.c | 777 ++ libdvdnav/decoder.h | 118 + libdvdnav/dvd_types.h | 281 + libdvdnav/dvdnav.c | 1093 +++ libdvdnav/dvdnav.h | 630 ++ libdvdnav/dvdnav_events.h | 241 + libdvdnav/dvdnav_internal.h | 199 + libdvdnav/dvdread.c | 74 + libdvdnav/dvdread.h | 28 + libdvdnav/highlight.c | 512 ++ libdvdnav/navigation.c | 231 + libdvdnav/read_cache.c | 347 + libdvdnav/read_cache.h | 51 + libdvdnav/remap.c | 257 + libdvdnav/remap.h | 33 + libdvdnav/searching.c | 567 ++ libdvdnav/settings.c | 121 + libdvdnav/vm.c | 1861 +++++ libdvdnav/vm.h | 181 + libdvdnav/vmcmd.c | 539 ++ libdvdnav/vmcmd.h | 33 + libk9copy/Makefile.am | 29 + libk9copy/backupdlg.cpp | 174 + libk9copy/backupdlg.ui | 383 + libk9copy/bswap.h | 98 + libk9copy/dvdprogress.cpp | 97 + libk9copy/dvdprogress.ui | 141 + libk9copy/k9audiocodecs.cpp | 118 + libk9copy/k9audiocodecs.h | 45 + libk9copy/k9backupdlg.cpp | 182 + libk9copy/k9backupdlg.h | 78 + libk9copy/k9burndvd.cpp | 381 + libk9copy/k9burndvd.h | 83 + libk9copy/k9cell.cpp | 443 ++ libk9copy/k9cell.h | 129 + libk9copy/k9cellcopylist.cpp | 373 + libk9copy/k9cellcopylist.h | 97 + libk9copy/k9common.h | 48 + libk9copy/k9config.cpp | 157 + libk9copy/k9config.h | 453 ++ libk9copy/k9drawimage.cpp | 49 + libk9copy/k9drawimage.h | 36 + libk9copy/k9dvd.cpp | 1095 +++ libk9copy/k9dvd.h | 174 + libk9copy/k9dvdauthor.cpp | 591 ++ libk9copy/k9dvdauthor.h | 85 + libk9copy/k9dvdbackup.cpp | 1776 +++++ libk9copy/k9dvdbackup.h | 140 + libk9copy/k9dvdchapter.cpp | 69 + libk9copy/k9dvdchapter.h | 88 + libk9copy/k9dvdprogress.cpp | 62 + libk9copy/k9dvdprogress.h | 51 + libk9copy/k9dvdread.cpp | 171 + libk9copy/k9dvdread.h | 70 + libk9copy/k9dvdsize.cpp | 43 + libk9copy/k9dvdsize.h | 34 + libk9copy/k9dvdtitle.cpp | 503 ++ libk9copy/k9dvdtitle.h | 259 + libk9copy/k9dvdtitleset.cpp | 138 + libk9copy/k9dvdtitleset.h | 48 + libk9copy/k9ifo2.cpp | 933 +++ libk9copy/k9ifo2.h | 85 + libk9copy/k9mp4dlg.cpp | 80 + libk9copy/k9mp4dlg.h | 49 + libk9copy/k9mp4enc.cpp | 571 ++ libk9copy/k9mp4enc.h | 131 + libk9copy/k9process.cpp | 59 + libk9copy/k9process.h | 38 + libk9copy/k9processlist.cpp | 192 + libk9copy/k9processlist.h | 65 + libk9copy/k9progress.cpp | 116 + libk9copy/k9progress.h | 58 + libk9copy/k9saveimage.cpp | 84 + libk9copy/k9saveimage.h | 60 + libk9copy/k9script.cpp | 391 + libk9copy/k9script.h | 55 + libk9copy/k9titleencopt.cpp | 159 + libk9copy/k9titleencopt.h | 87 + libk9copy/k9tools.cpp | 38 + libk9copy/k9tools.h | 29 + libk9copy/k9videocodecs.cpp | 174 + libk9copy/k9videocodecs.h | 54 + libk9copy/mp4dlg.cpp | 159 + libk9copy/mp4dlg.ui | 281 + libk9copy/processList.cpp | 81 + libk9copy/processList.ui | 116 + libk9copy/progress.cpp | 127 + libk9copy/progress.ui | 245 + po/Makefile.am | 4 + po/ca.po | 1325 ++++ po/cs.po | 1511 ++++ po/de.po | 1531 ++++ po/el.po | 1512 ++++ po/es.po | 1325 ++++ po/es_AR.po | 1550 ++++ po/fr.po | 2187 ++++++ po/it.po | 2202 ++++++ po/nl.po | 1327 ++++ po/pl.po | 2548 ++++++ po/pt_BR.po | 2190 ++++++ po/ru.po | 2188 ++++++ po/sr.po | 2196 ++++++ po/sr@latin.po | 2196 ++++++ po/tr.po | 2196 ++++++ po/zh_TW.po | 2527 ++++++ src/Makefile.am | 59 + src/anim.mng | Bin 0 -> 585180 bytes src/configDlg.cpp | 119 + src/configDlg.ui | 196 + src/hi16-app-k9copy.png | Bin 0 -> 883 bytes src/hi32-app-k9copy.png | Bin 0 -> 2215 bytes src/hi48-app-k9copy.png | Bin 0 -> 4000 bytes src/icons/Makefile.am | 2 + src/icons/hi16-action-dvdcopy.png | Bin 0 -> 1050 bytes src/icons/hi16-action-mp4.png | Bin 0 -> 757 bytes src/icons/hi16-action-mpeg.png | Bin 0 -> 783 bytes src/icons/hi22-action-author.png | Bin 0 -> 1273 bytes src/icons/hi22-action-cycle.png | Bin 0 -> 1286 bytes src/icons/hi22-action-dvdcopy.png | Bin 0 -> 1133 bytes src/icons/hi22-action-mp4.png | Bin 0 -> 1336 bytes src/icons/hi22-action-mpeg.png | Bin 0 -> 1342 bytes src/icons/hi22-action-title.png | Bin 0 -> 1594 bytes src/icons/hi32-action-author.png | Bin 0 -> 2632 bytes src/icons/hi32-action-dvdcopy.png | Bin 0 -> 2658 bytes src/icons/hi32-action-mp4.png | Bin 0 -> 2871 bytes src/icons/hi32-action-mpeg.png | Bin 0 -> 2876 bytes src/icons/hi48-action-author.png | Bin 0 -> 4563 bytes src/icons/hi48-action-dvdcopy.png | Bin 0 -> 4782 bytes src/icons/hi48-action-mencoder.png | Bin 0 -> 3679 bytes src/icons/hi48-action-mp4.png | Bin 0 -> 5002 bytes src/icons/hi48-action-mpeg.png | Bin 0 -> 5025 bytes src/icons/hi48-action-mplayer.png | Bin 0 -> 6324 bytes src/images.h | 777 ++ src/k9copy.cpp | 528 ++ src/k9copy.desktop | 17 + src/k9copy.h | 121 + src/k9copy.png | Bin 0 -> 4000 bytes src/k9copy_open.desktop | 11 + src/k9copyui.rc | 38 + src/k9glwidget.cpp | 185 + src/k9glwidget.h | 99 + src/k9langselect.cpp | 178 + src/k9langselect.h | 73 + src/k9main.cpp | 1532 ++++ src/k9main.h | 240 + src/k9mainw.cpp | 216 + src/k9mainw.ui | 427 + src/k9mainwsov.ui | 424 + src/k9mencodercmdgen.cpp | 670 ++ src/k9mencodercmdgen.h | 67 + src/k9mp4title.cpp | 210 + src/k9mp4title.h | 59 + src/k9play.cpp | 568 ++ src/k9play.h | 101 + src/k9playbackoptions.cpp | 223 + src/k9playbackoptions.h | 79 + src/k9prefauthor.cpp | 60 + src/k9prefauthor.h | 41 + src/k9prefdvd.cpp | 57 + src/k9prefdvd.h | 40 + src/k9prefmencoder.cpp | 198 + src/k9prefmencoder.h | 65 + src/k9prefmpeg4.cpp | 110 + src/k9prefmpeg4.h | 58 + src/k9prefpreview.cpp | 76 + src/k9prefpreview.h | 41 + src/k9redirect.cpp | 44 + src/k9redirect.h | 28 + src/k9settings.cpp | 97 + src/k9settings.h | 46 + src/k9titlefactor.cpp | 145 + src/k9titlefactor.h | 55 + src/k9updatefactor.cpp | 43 + src/k9updatefactor.h | 42 + src/kconfigdlg.cpp | 151 + src/kconfigdlg.h | 44 + src/kviewmpeg2.cpp | 229 + src/kviewmpeg2.h | 101 + src/langselectw.cpp | 123 + src/langselectw.ui | 72 + src/main.cpp | 154 + src/mencoder.xml | 726 ++ src/mencoderCmdGen.cpp | 129 + src/mencoderCmdGen.ui | 215 + src/pellicule.png | Bin 0 -> 947 bytes src/playbackoptionsw.cpp | 279 + src/playbackoptionsw.ui | 405 + src/prefAuthor.cpp | 165 + src/prefAuthor.ui | 251 + src/prefDVD.cpp | 114 + src/prefDVD.ui | 175 + src/prefMPEG4.cpp | 418 + src/prefMPEG4.ui | 705 ++ src/prefMencoder.cpp | 426 + src/prefMencoder.ui | 825 ++ src/prefpreview.cpp | 171 + src/prefpreview.ui | 336 + src/titlefactor.cpp | 346 + src/titlefactor.ui | 165 + src/viewmpeg2.cpp | 229 + src/viewmpeg2.ui | 183 + stamp-h.in | 0 subdirs | 11 + 356 files changed, 120285 insertions(+) create mode 100755 AUTHORS create mode 100755 COPYING create mode 100755 ChangeLog create mode 100755 INSTALL create mode 100644 Makefile.am create mode 100755 Makefile.cvs create mode 100755 NEWS create mode 100755 README create mode 100755 TODO create mode 100644 acinclude.m4 create mode 100644 aclocal.m4 create mode 100644 config.h.in create mode 100644 configure.files create mode 100644 configure.in create mode 100755 configure.in.in create mode 100755 doc/Makefile.am create mode 100644 doc/k9copy/Makefile.am create mode 100644 doc/k9copy/btncopy.png create mode 100644 doc/k9copy/btnmp4.png create mode 100644 doc/k9copy/index.docbook create mode 100644 doc/k9copy/index.xml create mode 100644 doc/k9copy/keepmenus.png create mode 100644 doc/k9copy/mainwindow.png create mode 100644 doc/k9copy/open1.png create mode 100644 doc/k9copy/open2.png create mode 100644 doc/k9copy/playback.png create mode 100644 doc/k9copy/settingsDVD.png create mode 100644 doc/k9copy/settingsMP4.png create mode 100644 doc/k9copy/settingsMencoder.png create mode 100644 doc/k9copy/treeview.png create mode 100644 dvdread/Makefile.am create mode 100644 dvdread/bswap.h create mode 100644 dvdread/dvd_input.c create mode 100644 dvdread/dvd_input.h create mode 100644 dvdread/dvd_reader.c create mode 100644 dvdread/dvd_reader.h create mode 100644 dvdread/dvd_udf.c create mode 100644 dvdread/dvd_udf.h create mode 100644 dvdread/dvdread_internal.h create mode 100644 dvdread/ifo_read.c create mode 100644 dvdread/ifo_read.h create mode 100644 dvdread/ifo_types.h create mode 100644 dvdread/md5.c create mode 100644 dvdread/md5.h create mode 100644 dvdread/nav_read.c create mode 100644 dvdread/nav_read.h create mode 100644 dvdread/nav_types.h create mode 100644 k9Mplayer/Makefile.am create mode 100644 k9Mplayer/k9mplayer.cpp create mode 100644 k9Mplayer/k9mplayer.h create mode 100644 k9Mplayer/mplayer.cpp create mode 100644 k9Mplayer/mplayer.ui create mode 100644 k9author/Makefile.am create mode 100644 k9author/chapterEdit.cpp create mode 100644 k9author/chapterEdit.ui create mode 100644 k9author/import.cpp create mode 100644 k9author/import.ui create mode 100644 k9author/k9avidecode.cpp create mode 100644 k9author/k9avidecode.h create mode 100644 k9author/k9avifile.cpp create mode 100644 k9author/k9avifile.h create mode 100644 k9author/k9canvasselection.cpp create mode 100644 k9author/k9canvasselection.h create mode 100644 k9author/k9chapteredit.cpp create mode 100644 k9author/k9chapteredit.h create mode 100644 k9author/k9import.cpp create mode 100644 k9author/k9import.h create mode 100644 k9author/k9importfiles.cpp create mode 100644 k9author/k9importfiles.h create mode 100644 k9author/k9lvitemimport.cpp create mode 100644 k9author/k9lvitemimport.h create mode 100644 k9author/k9menu.cpp create mode 100644 k9author/k9menu.h create mode 100644 k9author/k9menubutton.cpp create mode 100644 k9author/k9menubutton.h create mode 100644 k9author/k9menuedit.cpp create mode 100644 k9author/k9menuedit.h create mode 100644 k9author/k9menueditor.cpp create mode 100644 k9author/k9menueditor.h create mode 100644 k9author/k9newdvd.cpp create mode 100644 k9author/k9newdvd.h create mode 100644 k9author/k9newtitle.cpp create mode 100644 k9author/k9newtitle.h create mode 100644 k9author/k9title.cpp create mode 100644 k9author/k9title.h create mode 100644 k9author/menuEdit.cpp create mode 100644 k9author/menuEdit.ui create mode 100644 k9author/newTitle.cpp create mode 100644 k9author/newTitle.ui create mode 100644 k9decmpeg/Makefile.am create mode 100755 k9decmpeg/alloc.cpp create mode 100755 k9decmpeg/attributes.h create mode 100755 k9decmpeg/bswap.h create mode 100755 k9decmpeg/convert_internal.h create mode 100755 k9decmpeg/cpu_accel.cpp create mode 100755 k9decmpeg/cpu_state.cpp create mode 100755 k9decmpeg/decode.cpp create mode 100755 k9decmpeg/header.cpp create mode 100755 k9decmpeg/idct.cpp create mode 100755 k9decmpeg/idct_alpha.cpp create mode 100755 k9decmpeg/idct_altivec.cpp create mode 100755 k9decmpeg/idct_mmx.cpp create mode 100644 k9decmpeg/k9decodethread.cpp create mode 100644 k9decmpeg/k9decodethread.h create mode 100644 k9decmpeg/k9plaympeg2.cpp create mode 100644 k9decmpeg/k9plaympeg2.h create mode 100755 k9decmpeg/kdecmpeg2.cpp create mode 100755 k9decmpeg/kdecmpeg2.h create mode 100755 k9decmpeg/mmx.h create mode 100755 k9decmpeg/motion_comp.cpp create mode 100755 k9decmpeg/motion_comp_alpha.cpp create mode 100755 k9decmpeg/motion_comp_altivec.cpp create mode 100755 k9decmpeg/motion_comp_mmx.cpp create mode 100755 k9decmpeg/motion_comp_vis.cpp create mode 100755 k9decmpeg/mpeg2.h create mode 100755 k9decmpeg/mpeg2_internal.h create mode 100755 k9decmpeg/mpeg2convert.h create mode 100755 k9decmpeg/rgb.cpp create mode 100755 k9decmpeg/rgb_mmx.cpp create mode 100755 k9decmpeg/rgb_vis.cpp create mode 100755 k9decmpeg/slice.cpp create mode 100755 k9decmpeg/tendra.h create mode 100755 k9decmpeg/uyvy.cpp create mode 100755 k9decmpeg/video_out.h create mode 100755 k9decmpeg/vis.h create mode 100755 k9decmpeg/vlc.h create mode 100644 k9devices/Makefile.am create mode 100644 k9devices/configure.in.in create mode 100644 k9devices/k9cddrive.cpp create mode 100644 k9devices/k9cddrive.h create mode 100644 k9devices/k9dbusdispatch.cpp create mode 100644 k9devices/k9dbusdispatch.h create mode 100644 k9devices/k9halconnection.cpp create mode 100644 k9devices/k9halconnection.h create mode 100644 k9devices/k9haldevice.cpp create mode 100644 k9devices/k9haldevice.h create mode 100644 k9vamps/Makefile.am create mode 100644 k9vamps/ac.h create mode 100644 k9vamps/cputest.cpp create mode 100644 k9vamps/getvlc.h create mode 100644 k9vamps/k9fifo.cpp create mode 100644 k9vamps/k9fifo.h create mode 100644 k9vamps/k9requant.cpp create mode 100644 k9vamps/k9requant.h create mode 100755 k9vamps/k9requant2.h create mode 100755 k9vamps/k9vamps.cpp create mode 100755 k9vamps/k9vamps.h create mode 100644 k9vamps/putvlc.h create mode 100644 k9vamps/qTable.h create mode 100644 k9vamps/tcmemcpy.cpp create mode 100644 libdvdnav/Makefile.am create mode 100644 libdvdnav/common.h create mode 100644 libdvdnav/compat.h create mode 100644 libdvdnav/decoder.c create mode 100644 libdvdnav/decoder.h create mode 100644 libdvdnav/dvd_types.h create mode 100644 libdvdnav/dvdnav.c create mode 100644 libdvdnav/dvdnav.h create mode 100644 libdvdnav/dvdnav_events.h create mode 100644 libdvdnav/dvdnav_internal.h create mode 100644 libdvdnav/dvdread.c create mode 100644 libdvdnav/dvdread.h create mode 100644 libdvdnav/highlight.c create mode 100644 libdvdnav/navigation.c create mode 100644 libdvdnav/read_cache.c create mode 100644 libdvdnav/read_cache.h create mode 100644 libdvdnav/remap.c create mode 100644 libdvdnav/remap.h create mode 100644 libdvdnav/searching.c create mode 100644 libdvdnav/settings.c create mode 100644 libdvdnav/vm.c create mode 100644 libdvdnav/vm.h create mode 100644 libdvdnav/vmcmd.c create mode 100644 libdvdnav/vmcmd.h create mode 100644 libk9copy/Makefile.am create mode 100644 libk9copy/backupdlg.cpp create mode 100644 libk9copy/backupdlg.ui create mode 100755 libk9copy/bswap.h create mode 100644 libk9copy/dvdprogress.cpp create mode 100755 libk9copy/dvdprogress.ui create mode 100644 libk9copy/k9audiocodecs.cpp create mode 100644 libk9copy/k9audiocodecs.h create mode 100644 libk9copy/k9backupdlg.cpp create mode 100644 libk9copy/k9backupdlg.h create mode 100644 libk9copy/k9burndvd.cpp create mode 100644 libk9copy/k9burndvd.h create mode 100755 libk9copy/k9cell.cpp create mode 100755 libk9copy/k9cell.h create mode 100644 libk9copy/k9cellcopylist.cpp create mode 100644 libk9copy/k9cellcopylist.h create mode 100644 libk9copy/k9common.h create mode 100644 libk9copy/k9config.cpp create mode 100644 libk9copy/k9config.h create mode 100644 libk9copy/k9drawimage.cpp create mode 100644 libk9copy/k9drawimage.h create mode 100755 libk9copy/k9dvd.cpp create mode 100755 libk9copy/k9dvd.h create mode 100755 libk9copy/k9dvdauthor.cpp create mode 100755 libk9copy/k9dvdauthor.h create mode 100755 libk9copy/k9dvdbackup.cpp create mode 100755 libk9copy/k9dvdbackup.h create mode 100644 libk9copy/k9dvdchapter.cpp create mode 100644 libk9copy/k9dvdchapter.h create mode 100755 libk9copy/k9dvdprogress.cpp create mode 100755 libk9copy/k9dvdprogress.h create mode 100644 libk9copy/k9dvdread.cpp create mode 100644 libk9copy/k9dvdread.h create mode 100644 libk9copy/k9dvdsize.cpp create mode 100644 libk9copy/k9dvdsize.h create mode 100644 libk9copy/k9dvdtitle.cpp create mode 100644 libk9copy/k9dvdtitle.h create mode 100644 libk9copy/k9dvdtitleset.cpp create mode 100644 libk9copy/k9dvdtitleset.h create mode 100644 libk9copy/k9ifo2.cpp create mode 100644 libk9copy/k9ifo2.h create mode 100644 libk9copy/k9mp4dlg.cpp create mode 100644 libk9copy/k9mp4dlg.h create mode 100644 libk9copy/k9mp4enc.cpp create mode 100644 libk9copy/k9mp4enc.h create mode 100644 libk9copy/k9process.cpp create mode 100644 libk9copy/k9process.h create mode 100644 libk9copy/k9processlist.cpp create mode 100644 libk9copy/k9processlist.h create mode 100644 libk9copy/k9progress.cpp create mode 100644 libk9copy/k9progress.h create mode 100644 libk9copy/k9saveimage.cpp create mode 100644 libk9copy/k9saveimage.h create mode 100644 libk9copy/k9script.cpp create mode 100644 libk9copy/k9script.h create mode 100644 libk9copy/k9titleencopt.cpp create mode 100644 libk9copy/k9titleencopt.h create mode 100644 libk9copy/k9tools.cpp create mode 100644 libk9copy/k9tools.h create mode 100644 libk9copy/k9videocodecs.cpp create mode 100644 libk9copy/k9videocodecs.h create mode 100644 libk9copy/mp4dlg.cpp create mode 100644 libk9copy/mp4dlg.ui create mode 100644 libk9copy/processList.cpp create mode 100644 libk9copy/processList.ui create mode 100644 libk9copy/progress.cpp create mode 100644 libk9copy/progress.ui create mode 100644 po/Makefile.am create mode 100755 po/ca.po create mode 100644 po/cs.po create mode 100644 po/de.po create mode 100644 po/el.po create mode 100644 po/es.po create mode 100644 po/es_AR.po create mode 100644 po/fr.po create mode 100644 po/it.po create mode 100644 po/nl.po create mode 100644 po/pl.po create mode 100644 po/pt_BR.po create mode 100644 po/ru.po create mode 100644 po/sr.po create mode 100644 po/sr@latin.po create mode 100644 po/tr.po create mode 100644 po/zh_TW.po create mode 100644 src/Makefile.am create mode 100644 src/anim.mng create mode 100644 src/configDlg.cpp create mode 100644 src/configDlg.ui create mode 100755 src/hi16-app-k9copy.png create mode 100755 src/hi32-app-k9copy.png create mode 100755 src/hi48-app-k9copy.png create mode 100644 src/icons/Makefile.am create mode 100644 src/icons/hi16-action-dvdcopy.png create mode 100644 src/icons/hi16-action-mp4.png create mode 100644 src/icons/hi16-action-mpeg.png create mode 100644 src/icons/hi22-action-author.png create mode 100644 src/icons/hi22-action-cycle.png create mode 100644 src/icons/hi22-action-dvdcopy.png create mode 100644 src/icons/hi22-action-mp4.png create mode 100644 src/icons/hi22-action-mpeg.png create mode 100644 src/icons/hi22-action-title.png create mode 100644 src/icons/hi32-action-author.png create mode 100644 src/icons/hi32-action-dvdcopy.png create mode 100644 src/icons/hi32-action-mp4.png create mode 100644 src/icons/hi32-action-mpeg.png create mode 100644 src/icons/hi48-action-author.png create mode 100644 src/icons/hi48-action-dvdcopy.png create mode 100644 src/icons/hi48-action-mencoder.png create mode 100644 src/icons/hi48-action-mp4.png create mode 100644 src/icons/hi48-action-mpeg.png create mode 100644 src/icons/hi48-action-mplayer.png create mode 100755 src/images.h create mode 100644 src/k9copy.cpp create mode 100644 src/k9copy.desktop create mode 100644 src/k9copy.h create mode 100755 src/k9copy.png create mode 100644 src/k9copy_open.desktop create mode 100755 src/k9copyui.rc create mode 100644 src/k9glwidget.cpp create mode 100644 src/k9glwidget.h create mode 100644 src/k9langselect.cpp create mode 100644 src/k9langselect.h create mode 100644 src/k9main.cpp create mode 100644 src/k9main.h create mode 100644 src/k9mainw.cpp create mode 100644 src/k9mainw.ui create mode 100644 src/k9mainwsov.ui create mode 100644 src/k9mencodercmdgen.cpp create mode 100644 src/k9mencodercmdgen.h create mode 100644 src/k9mp4title.cpp create mode 100644 src/k9mp4title.h create mode 100644 src/k9play.cpp create mode 100644 src/k9play.h create mode 100644 src/k9playbackoptions.cpp create mode 100644 src/k9playbackoptions.h create mode 100644 src/k9prefauthor.cpp create mode 100644 src/k9prefauthor.h create mode 100644 src/k9prefdvd.cpp create mode 100644 src/k9prefdvd.h create mode 100644 src/k9prefmencoder.cpp create mode 100644 src/k9prefmencoder.h create mode 100644 src/k9prefmpeg4.cpp create mode 100644 src/k9prefmpeg4.h create mode 100644 src/k9prefpreview.cpp create mode 100644 src/k9prefpreview.h create mode 100644 src/k9redirect.cpp create mode 100644 src/k9redirect.h create mode 100644 src/k9settings.cpp create mode 100644 src/k9settings.h create mode 100644 src/k9titlefactor.cpp create mode 100644 src/k9titlefactor.h create mode 100644 src/k9updatefactor.cpp create mode 100644 src/k9updatefactor.h create mode 100644 src/kconfigdlg.cpp create mode 100644 src/kconfigdlg.h create mode 100755 src/kviewmpeg2.cpp create mode 100755 src/kviewmpeg2.h create mode 100644 src/langselectw.cpp create mode 100644 src/langselectw.ui create mode 100755 src/main.cpp create mode 100644 src/mencoder.xml create mode 100644 src/mencoderCmdGen.cpp create mode 100644 src/mencoderCmdGen.ui create mode 100644 src/pellicule.png create mode 100644 src/playbackoptionsw.cpp create mode 100644 src/playbackoptionsw.ui create mode 100644 src/prefAuthor.cpp create mode 100644 src/prefAuthor.ui create mode 100644 src/prefDVD.cpp create mode 100644 src/prefDVD.ui create mode 100644 src/prefMPEG4.cpp create mode 100644 src/prefMPEG4.ui create mode 100644 src/prefMencoder.cpp create mode 100644 src/prefMencoder.ui create mode 100644 src/prefpreview.cpp create mode 100644 src/prefpreview.ui create mode 100644 src/titlefactor.cpp create mode 100644 src/titlefactor.ui create mode 100644 src/viewmpeg2.cpp create mode 100755 src/viewmpeg2.ui create mode 100755 stamp-h.in create mode 100644 subdirs diff --git a/AUTHORS b/AUTHORS new file mode 100755 index 0000000..b727fda --- /dev/null +++ b/AUTHORS @@ -0,0 +1 @@ +Jean-Michel PETIT diff --git a/COPYING b/COPYING new file mode 100755 index 0000000..c13faf0 --- /dev/null +++ b/COPYING @@ -0,0 +1,340 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Library General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + , 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Library General +Public License instead of this License. diff --git a/ChangeLog b/ChangeLog new file mode 100755 index 0000000..0519ecb --- /dev/null +++ b/ChangeLog @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/INSTALL b/INSTALL new file mode 100755 index 0000000..02a4a07 --- /dev/null +++ b/INSTALL @@ -0,0 +1,167 @@ +Basic Installation +================== + + These are generic installation instructions. + + The `configure' shell script attempts to guess correct values for +various system-dependent variables used during compilation. It uses +those values to create a `Makefile' in each directory of the package. +It may also create one or more `.h' files containing system-dependent +definitions. Finally, it creates a shell script `config.status' that +you can run in the future to recreate the current configuration, a file +`config.cache' that saves the results of its tests to speed up +reconfiguring, and a file `config.log' containing compiler output +(useful mainly for debugging `configure'). + + If you need to do unusual things to compile the package, please try +to figure out how `configure' could check whether to do them, and mail +diffs or instructions to the address given in the `README' so they can +be considered for the next release. If at some point `config.cache' +contains results you don't want to keep, you may remove or edit it. + + The file `configure.in' is used to create `configure' by a program +called `autoconf'. You only need `configure.in' if you want to change +it or regenerate `configure' using a newer version of `autoconf'. + +The simplest way to compile this package is: + + 1. `cd' to the directory containing the package's source code and type + `./configure' to configure the package for your system. If you're + using `csh' on an old version of System V, you might need to type + `sh ./configure' instead to prevent `csh' from trying to execute + `configure' itself. + + Running `configure' takes a while. While running, it prints some + messages telling which features it is checking for. + + 2. Type `make' to compile the package. + + 3. Type `make install' to install the programs and any data files and + documentation. + + 4. You can remove the program binaries and object files from the + source code directory by typing `make clean'. + +Compilers and Options +===================== + + Some systems require unusual options for compilation or linking that +the `configure' script does not know about. You can give `configure' +initial values for variables by setting them in the environment. Using +a Bourne-compatible shell, you can do that on the command line like +this: + CC=c89 CFLAGS=-O2 LIBS=-lposix ./configure + +Or on systems that have the `env' program, you can do it like this: + env CPPFLAGS=-I/usr/local/include LDFLAGS=-s ./configure + +Compiling For Multiple Architectures +==================================== + + You can compile the package for more than one kind of computer at the +same time, by placing the object files for each architecture in their +own directory. To do this, you must use a version of `make' that +supports the `VPATH' variable, such as GNU `make'. `cd' to the +directory where you want the object files and executables to go and run +the `configure' script. `configure' automatically checks for the +source code in the directory that `configure' is in and in `..'. + + If you have to use a `make' that does not supports the `VPATH' +variable, you have to compile the package for one architecture at a time +in the source code directory. After you have installed the package for +one architecture, use `make distclean' before reconfiguring for another +architecture. + +Installation Names +================== + + By default, `make install' will install the package's files in +`/usr/local/bin', `/usr/local/man', etc. You can specify an +installation prefix other than `/usr/local' by giving `configure' the +option `--prefix=PATH'. + + You can specify separate installation prefixes for +architecture-specific files and architecture-independent files. If you +give `configure' the option `--exec-prefix=PATH', the package will use +PATH as the prefix for installing programs and libraries. +Documentation and other data files will still use the regular prefix. + + If the package supports it, you can cause programs to be installed +with an extra prefix or suffix on their names by giving `configure' the +option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'. + +Optional Features +================= + + Some packages pay attention to `--enable-FEATURE' options to +`configure', where FEATURE indicates an optional part of the package. +They may also pay attention to `--with-PACKAGE' options, where PACKAGE +is something like `gnu-as' or `x' (for the X Window System). The +`README' should mention any `--enable-' and `--with-' options that the +package recognizes. + + For packages that use the X Window System, `configure' can usually +find the X include and library files automatically, but if it doesn't, +you can use the `configure' options `--x-includes=DIR' and +`--x-libraries=DIR' to specify their locations. + +Specifying the System Type +========================== + + There may be some features `configure' can not figure out +automatically, but needs to determine by the type of host the package +will run on. Usually `configure' can figure that out, but if it prints +a message saying it can not guess the host type, give it the +`--host=TYPE' option. TYPE can either be a short name for the system +type, such as `sun4', or a canonical name with three fields: + CPU-COMPANY-SYSTEM + +See the file `config.sub' for the possible values of each field. If +`config.sub' isn't included in this package, then this package doesn't +need to know the host type. + + If you are building compiler tools for cross-compiling, you can also +use the `--target=TYPE' option to select the type of system they will +produce code for and the `--build=TYPE' option to select the type of +system on which you are compiling the package. + +Sharing Defaults +================ + + If you want to set default values for `configure' scripts to share, +you can create a site shell script called `config.site' that gives +default values for variables like `CC', `cache_file', and `prefix'. +`configure' looks for `PREFIX/share/config.site' if it exists, then +`PREFIX/etc/config.site' if it exists. Or, you can set the +`CONFIG_SITE' environment variable to the location of the site script. +A warning: not all `configure' scripts look for a site script. + +Operation Controls +================== + + `configure' recognizes the following options to control how it +operates. + +`--cache-file=FILE' + Use and save the results of the tests in FILE instead of + `./config.cache'. Set FILE to `/dev/null' to disable caching, for + debugging `configure'. + +`--help' + Print a summary of the options to `configure', and exit. + +`--quiet' +`--silent' +`-q' + Do not print messages saying which checks are being made. + +`--srcdir=DIR' + Look for the package's source code in directory DIR. Usually + `configure' can determine that directory automatically. + +`--version' + Print the version of Autoconf used to generate the `configure' + script, and exit. + +`configure' also accepts some other, not widely useful, options. + diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 0000000..a7dae17 --- /dev/null +++ b/Makefile.am @@ -0,0 +1,39 @@ +SUBDIRS = doc dvdread libdvdnav k9Mplayer libk9copy k9author k9decmpeg k9devices k9vamps \ + po src + +$(top_srcdir)/configure.in: configure.in.in $(top_srcdir)/subdirs + cd $(top_srcdir) && $(MAKE) -f admin/Makefile.common configure.in ; + +$(top_srcdir)/subdirs: + cd $(top_srcdir) && $(MAKE) -f admin/Makefile.common subdirs + +$(top_srcdir)/acinclude.m4: $(top_srcdir)/admin/acinclude.m4.in $(top_srcdir)/admin/libtool.m4.in + @cd $(top_srcdir) && cat admin/acinclude.m4.in admin/libtool.m4.in > acinclude.m4 + +MAINTAINERCLEANFILES = subdirs configure.in acinclude.m4 configure.files + +messages: rc.cpp + $(EXTRACTRC) `find . -name "*.ui"` >> rc.cpp + $(EXTRACTRC) `find . -name "*.rc"` >> rc.cpp + $(XGETTEXT) `find -name "*.cpp"` -o $(podir)/k9copy.pot + +package-messages: + cd $(top_srcdir) && $(MAKE) -f admin/Makefile.common package-messages + $(MAKE) -C po merge + +EXTRA_DIST = admin COPYING configure.in.in + +dist-hook: + cd $(top_distdir) && perl admin/am_edit -padmin + cd $(top_distdir) && $(MAKE) -f admin/Makefile.common subdirs + +AM_CXXFLAGS = -O0 -g3 + + + + + + + + +INCLUDES = -I$(top_srcdir)/dvdread diff --git a/Makefile.cvs b/Makefile.cvs new file mode 100755 index 0000000..4c0afd1 --- /dev/null +++ b/Makefile.cvs @@ -0,0 +1,10 @@ +all: + @echo "This Makefile is only for the CVS repository" + @echo "This will be deleted before making the distribution" + @echo "" + $(MAKE) -f admin/Makefile.common cvs + +dist: + $(MAKE) -f admin/Makefile.common dist + +.SILENT: diff --git a/NEWS b/NEWS new file mode 100755 index 0000000..0519ecb --- /dev/null +++ b/NEWS @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/README b/README new file mode 100755 index 0000000..ea5b96d --- /dev/null +++ b/README @@ -0,0 +1,12 @@ +install from sources: + +make -f Makefile.cvs +./configure --prefix=/usr +make +make install (as root) + + +k9copy can now copy dvd with bad sectors. +for a faster copy from a dvd with bad sectors : reduce the readahead for the drive : + +as root: hdparm -a8 /dev/dvd diff --git a/TODO b/TODO new file mode 100755 index 0000000..dc90d46 --- /dev/null +++ b/TODO @@ -0,0 +1,3 @@ +more options for mp4 encoding +improve copy with bad sectors + \ No newline at end of file diff --git a/acinclude.m4 b/acinclude.m4 new file mode 100644 index 0000000..c4bc9ed --- /dev/null +++ b/acinclude.m4 @@ -0,0 +1,11207 @@ +## -*- autoconf -*- + +dnl This file is part of the KDE libraries/packages +dnl Copyright (C) 1997 Janos Farkas (chexum@shadow.banki.hu) +dnl (C) 1997,98,99 Stephan Kulow (coolo@kde.org) + +dnl This file is free software; you can redistribute it and/or +dnl modify it under the terms of the GNU Library General Public +dnl License as published by the Free Software Foundation; either +dnl version 2 of the License, or (at your option) any later version. + +dnl This library is distributed in the hope that it will be useful, +dnl but WITHOUT ANY WARRANTY; without even the implied warranty of +dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +dnl Library General Public License for more details. + +dnl You should have received a copy of the GNU Library General Public License +dnl along with this library; see the file COPYING.LIB. If not, write to +dnl the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, +dnl Boston, MA 02110-1301, USA. + +dnl IMPORTANT NOTE: +dnl Please do not modify this file unless you expect your modifications to be +dnl carried into every other module in the repository. +dnl +dnl Single-module modifications are best placed in configure.in for kdelibs +dnl and kdebase or configure.in.in if present. + +# KDE_PATH_X_DIRECT +dnl Internal subroutine of AC_PATH_X. +dnl Set ac_x_includes and/or ac_x_libraries. +AC_DEFUN([KDE_PATH_X_DIRECT], +[ +AC_REQUIRE([KDE_CHECK_LIB64]) + +if test "$ac_x_includes" = NO; then + # Guess where to find include files, by looking for this one X11 .h file. + test -z "$x_direct_test_include" && x_direct_test_include=X11/Intrinsic.h + + # First, try using that file with no special directory specified. +AC_TRY_CPP([#include <$x_direct_test_include>], +[# We can compile using X headers with no special include directory. +ac_x_includes=], +[# Look for the header file in a standard set of common directories. +# Check X11 before X11Rn because it is often a symlink to the current release. + for ac_dir in \ + /usr/X11/include \ + /usr/X11R6/include \ + /usr/X11R5/include \ + /usr/X11R4/include \ + \ + /usr/include/X11 \ + /usr/include/X11R6 \ + /usr/include/X11R5 \ + /usr/include/X11R4 \ + \ + /usr/local/X11/include \ + /usr/local/X11R6/include \ + /usr/local/X11R5/include \ + /usr/local/X11R4/include \ + \ + /usr/local/include/X11 \ + /usr/local/include/X11R6 \ + /usr/local/include/X11R5 \ + /usr/local/include/X11R4 \ + \ + /usr/X386/include \ + /usr/x386/include \ + /usr/XFree86/include/X11 \ + \ + /usr/include \ + /usr/local/include \ + /usr/unsupported/include \ + /usr/athena/include \ + /usr/local/x11r5/include \ + /usr/lpp/Xamples/include \ + \ + /usr/openwin/include \ + /usr/openwin/share/include \ + ; \ + do + if test -r "$ac_dir/$x_direct_test_include"; then + ac_x_includes=$ac_dir + break + fi + done]) +fi # $ac_x_includes = NO + +if test "$ac_x_libraries" = NO; then + # Check for the libraries. + + test -z "$x_direct_test_library" && x_direct_test_library=Xt + test -z "$x_direct_test_function" && x_direct_test_function=XtMalloc + + # See if we find them without any special options. + # Don't add to $LIBS permanently. + ac_save_LIBS="$LIBS" + LIBS="-l$x_direct_test_library $LIBS" +AC_TRY_LINK(, [${x_direct_test_function}()], +[LIBS="$ac_save_LIBS" +# We can link X programs with no special library path. +ac_x_libraries=], +[LIBS="$ac_save_LIBS" +# First see if replacing the include by lib works. +# Check X11 before X11Rn because it is often a symlink to the current release. +for ac_dir in `echo "$ac_x_includes" | sed s/include/lib${kdelibsuff}/` \ + /usr/X11/lib${kdelibsuff} \ + /usr/X11R6/lib${kdelibsuff} \ + /usr/X11R5/lib${kdelibsuff} \ + /usr/X11R4/lib${kdelibsuff} \ + \ + /usr/lib${kdelibsuff}/X11 \ + /usr/lib${kdelibsuff}/X11R6 \ + /usr/lib${kdelibsuff}/X11R5 \ + /usr/lib${kdelibsuff}/X11R4 \ + \ + /usr/local/X11/lib${kdelibsuff} \ + /usr/local/X11R6/lib${kdelibsuff} \ + /usr/local/X11R5/lib${kdelibsuff} \ + /usr/local/X11R4/lib${kdelibsuff} \ + \ + /usr/local/lib${kdelibsuff}/X11 \ + /usr/local/lib${kdelibsuff}/X11R6 \ + /usr/local/lib${kdelibsuff}/X11R5 \ + /usr/local/lib${kdelibsuff}/X11R4 \ + \ + /usr/X386/lib${kdelibsuff} \ + /usr/x386/lib${kdelibsuff} \ + /usr/XFree86/lib${kdelibsuff}/X11 \ + \ + /usr/lib${kdelibsuff} \ + /usr/local/lib${kdelibsuff} \ + /usr/unsupported/lib${kdelibsuff} \ + /usr/athena/lib${kdelibsuff} \ + /usr/local/x11r5/lib${kdelibsuff} \ + /usr/lpp/Xamples/lib${kdelibsuff} \ + /lib/usr/lib${kdelibsuff}/X11 \ + \ + /usr/openwin/lib${kdelibsuff} \ + /usr/openwin/share/lib${kdelibsuff} \ + ; \ +do +dnl Don't even attempt the hair of trying to link an X program! + for ac_extension in a so sl; do + if test -r $ac_dir/lib${x_direct_test_library}.$ac_extension; then + ac_x_libraries=$ac_dir + break 2 + fi + done +done]) +fi # $ac_x_libraries = NO +]) + + +dnl ------------------------------------------------------------------------ +dnl Find a file (or one of more files in a list of dirs) +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_FIND_FILE], +[ +$3=NO +for i in $2; +do + for j in $1; + do + echo "configure: __oline__: $i/$j" >&AC_FD_CC + if test -r "$i/$j"; then + echo "taking that" >&AC_FD_CC + $3=$i + break 2 + fi + done +done +]) + +dnl KDE_FIND_PATH(programm-name, variable-name, list of directories, +dnl if-not-found, test-parameter) +AC_DEFUN([KDE_FIND_PATH], +[ + AC_MSG_CHECKING([for $1]) + if test -n "$$2"; then + kde_cv_path="$$2"; + else + kde_cache=`echo $1 | sed 'y%./+-%__p_%'` + + AC_CACHE_VAL(kde_cv_path_$kde_cache, + [ + kde_cv_path="NONE" + dirs="$3" + kde_save_IFS=$IFS + IFS=':' + for dir in $PATH; do + dirs="$dirs $dir" + done + IFS=$kde_save_IFS + + for dir in $dirs; do + if test -x "$dir/$1"; then + if test -n "$5" + then + evalstr="$dir/$1 $5 2>&1 " + if eval $evalstr; then + kde_cv_path="$dir/$1" + break + fi + else + kde_cv_path="$dir/$1" + break + fi + fi + done + + eval "kde_cv_path_$kde_cache=$kde_cv_path" + + ]) + + eval "kde_cv_path=\"`echo '$kde_cv_path_'$kde_cache`\"" + + fi + + if test -z "$kde_cv_path" || test "$kde_cv_path" = NONE; then + AC_MSG_RESULT(not found) + $4 + else + AC_MSG_RESULT($kde_cv_path) + $2=$kde_cv_path + + fi +]) + +AC_DEFUN([KDE_MOC_ERROR_MESSAGE], +[ + AC_MSG_ERROR([No Qt meta object compiler (moc) found! +Please check whether you installed Qt correctly. +You need to have a running moc binary. +configure tried to run $ac_cv_path_moc and the test didn't +succeed. If configure shouldn't have tried this one, set +the environment variable MOC to the right one before running +configure. +]) +]) + +AC_DEFUN([KDE_UIC_ERROR_MESSAGE], +[ + AC_MSG_WARN([No Qt ui compiler (uic) found! +Please check whether you installed Qt correctly. +You need to have a running uic binary. +configure tried to run $ac_cv_path_uic and the test didn't +succeed. If configure shouldn't have tried this one, set +the environment variable UIC to the right one before running +configure. +]) +]) + + +AC_DEFUN([KDE_CHECK_UIC_FLAG], +[ + AC_MSG_CHECKING([whether uic supports -$1 ]) + kde_cache=`echo $1 | sed 'y% .=/+-%____p_%'` + AC_CACHE_VAL(kde_cv_prog_uic_$kde_cache, + [ + cat >conftest.ui < +EOT + ac_uic_testrun="$UIC_PATH -$1 $2 conftest.ui >/dev/null" + if AC_TRY_EVAL(ac_uic_testrun); then + eval "kde_cv_prog_uic_$kde_cache=yes" + else + eval "kde_cv_prog_uic_$kde_cache=no" + fi + rm -f conftest* + ]) + + if eval "test \"`echo '$kde_cv_prog_uic_'$kde_cache`\" = yes"; then + AC_MSG_RESULT([yes]) + : + $3 + else + AC_MSG_RESULT([no]) + : + $4 + fi +]) + + +dnl ------------------------------------------------------------------------ +dnl Find the meta object compiler and the ui compiler in the PATH, +dnl in $QTDIR/bin, and some more usual places +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_PATH_QT_MOC_UIC], +[ + AC_REQUIRE([KDE_CHECK_PERL]) + qt_bindirs="" + for dir in $kde_qt_dirs; do + qt_bindirs="$qt_bindirs $dir/bin $dir/src/moc" + done + qt_bindirs="$qt_bindirs /usr/bin /usr/X11R6/bin /usr/local/qt/bin" + if test ! "$ac_qt_bindir" = "NO"; then + qt_bindirs="$ac_qt_bindir $qt_bindirs" + fi + + KDE_FIND_PATH(moc, MOC, [$qt_bindirs], [KDE_MOC_ERROR_MESSAGE]) + if test -z "$UIC_NOT_NEEDED"; then + KDE_FIND_PATH(uic, UIC_PATH, [$qt_bindirs], [UIC_PATH=""]) + if test -z "$UIC_PATH" ; then + KDE_UIC_ERROR_MESSAGE + exit 1 + else + UIC=$UIC_PATH + + if test $kde_qtver = 3; then + KDE_CHECK_UIC_FLAG(L,[/nonexistent],ac_uic_supports_libpath=yes,ac_uic_supports_libpath=no) + KDE_CHECK_UIC_FLAG(nounload,,ac_uic_supports_nounload=yes,ac_uic_supports_nounload=no) + + if test x$ac_uic_supports_libpath = xyes; then + UIC="$UIC -L \$(kde_widgetdir)" + fi + if test x$ac_uic_supports_nounload = xyes; then + UIC="$UIC -nounload" + fi + fi + fi + else + UIC="echo uic not available: " + fi + + AC_SUBST(MOC) + AC_SUBST(UIC) + + UIC_TR="i18n" + if test $kde_qtver = 3; then + UIC_TR="tr2i18n" + fi + + AC_SUBST(UIC_TR) +]) + +AC_DEFUN([KDE_1_CHECK_PATHS], +[ + KDE_1_CHECK_PATH_HEADERS + + KDE_TEST_RPATH= + + if test -n "$USE_RPATH"; then + + if test -n "$kde_libraries"; then + KDE_TEST_RPATH="-R $kde_libraries" + fi + + if test -n "$qt_libraries"; then + KDE_TEST_RPATH="$KDE_TEST_RPATH -R $qt_libraries" + fi + + if test -n "$x_libraries"; then + KDE_TEST_RPATH="$KDE_TEST_RPATH -R $x_libraries" + fi + + KDE_TEST_RPATH="$KDE_TEST_RPATH $KDE_EXTRA_RPATH" + fi + +AC_MSG_CHECKING([for KDE libraries installed]) +ac_link='$LIBTOOL_SHELL --silent --mode=link ${CXX-g++} -o conftest $CXXFLAGS $all_includes $CPPFLAGS $LDFLAGS $all_libraries conftest.$ac_ext $LIBS -lkdecore $LIBQT $KDE_TEST_RPATH 1>&5' + +if AC_TRY_EVAL(ac_link) && test -s conftest; then + AC_MSG_RESULT(yes) +else + AC_MSG_ERROR([your system fails at linking a small KDE application! +Check, if your compiler is installed correctly and if you have used the +same compiler to compile Qt and kdelibs as you did use now. +For more details about this problem, look at the end of config.log.]) +fi + +if eval `KDEDIR= ./conftest 2>&5`; then + kde_result=done +else + kde_result=problems +fi + +KDEDIR= ./conftest 2> /dev/null >&5 # make an echo for config.log +kde_have_all_paths=yes + +KDE_SET_PATHS($kde_result) + +]) + +AC_DEFUN([KDE_SET_PATHS], +[ + kde_cv_all_paths="kde_have_all_paths=\"yes\" \ + kde_htmldir=\"$kde_htmldir\" \ + kde_appsdir=\"$kde_appsdir\" \ + kde_icondir=\"$kde_icondir\" \ + kde_sounddir=\"$kde_sounddir\" \ + kde_datadir=\"$kde_datadir\" \ + kde_locale=\"$kde_locale\" \ + kde_cgidir=\"$kde_cgidir\" \ + kde_confdir=\"$kde_confdir\" \ + kde_kcfgdir=\"$kde_kcfgdir\" \ + kde_mimedir=\"$kde_mimedir\" \ + kde_toolbardir=\"$kde_toolbardir\" \ + kde_wallpaperdir=\"$kde_wallpaperdir\" \ + kde_templatesdir=\"$kde_templatesdir\" \ + kde_bindir=\"$kde_bindir\" \ + kde_servicesdir=\"$kde_servicesdir\" \ + kde_servicetypesdir=\"$kde_servicetypesdir\" \ + kde_moduledir=\"$kde_moduledir\" \ + kde_styledir=\"$kde_styledir\" \ + kde_widgetdir=\"$kde_widgetdir\" \ + xdg_appsdir=\"$xdg_appsdir\" \ + xdg_menudir=\"$xdg_menudir\" \ + xdg_directorydir=\"$xdg_directorydir\" \ + kde_result=$1" +]) + +AC_DEFUN([KDE_SET_DEFAULT_PATHS], +[ +if test "$1" = "default"; then + + if test -z "$kde_htmldir"; then + kde_htmldir='\${datadir}/doc/HTML' + fi + if test -z "$kde_appsdir"; then + kde_appsdir='\${datadir}/applnk' + fi + if test -z "$kde_icondir"; then + kde_icondir='\${datadir}/icons' + fi + if test -z "$kde_sounddir"; then + kde_sounddir='\${datadir}/sounds' + fi + if test -z "$kde_datadir"; then + kde_datadir='\${datadir}/apps' + fi + if test -z "$kde_locale"; then + kde_locale='\${datadir}/locale' + fi + if test -z "$kde_cgidir"; then + kde_cgidir='\${exec_prefix}/cgi-bin' + fi + if test -z "$kde_confdir"; then + kde_confdir='\${datadir}/config' + fi + if test -z "$kde_kcfgdir"; then + kde_kcfgdir='\${datadir}/config.kcfg' + fi + if test -z "$kde_mimedir"; then + kde_mimedir='\${datadir}/mimelnk' + fi + if test -z "$kde_toolbardir"; then + kde_toolbardir='\${datadir}/toolbar' + fi + if test -z "$kde_wallpaperdir"; then + kde_wallpaperdir='\${datadir}/wallpapers' + fi + if test -z "$kde_templatesdir"; then + kde_templatesdir='\${datadir}/templates' + fi + if test -z "$kde_bindir"; then + kde_bindir='\${exec_prefix}/bin' + fi + if test -z "$kde_servicesdir"; then + kde_servicesdir='\${datadir}/services' + fi + if test -z "$kde_servicetypesdir"; then + kde_servicetypesdir='\${datadir}/servicetypes' + fi + if test -z "$kde_moduledir"; then + if test "$kde_qtver" = "2"; then + kde_moduledir='\${libdir}/kde2' + else + kde_moduledir='\${libdir}/kde3' + fi + fi + if test -z "$kde_styledir"; then + kde_styledir='\${libdir}/kde3/plugins/styles' + fi + if test -z "$kde_widgetdir"; then + kde_widgetdir='\${libdir}/kde3/plugins/designer' + fi + if test -z "$xdg_appsdir"; then + xdg_appsdir='\${datadir}/applications/kde' + fi + if test -z "$xdg_menudir"; then + xdg_menudir='\${sysconfdir}/xdg/menus' + fi + if test -z "$xdg_directorydir"; then + xdg_directorydir='\${datadir}/desktop-directories' + fi + + KDE_SET_PATHS(defaults) + +else + + if test $kde_qtver = 1; then + AC_MSG_RESULT([compiling]) + KDE_1_CHECK_PATHS + else + AC_MSG_ERROR([path checking not yet supported for KDE 2]) + fi + +fi +]) + +AC_DEFUN([KDE_CHECK_PATHS_FOR_COMPLETENESS], +[ if test -z "$kde_htmldir" || test -z "$kde_appsdir" || + test -z "$kde_icondir" || test -z "$kde_sounddir" || + test -z "$kde_datadir" || test -z "$kde_locale" || + test -z "$kde_cgidir" || test -z "$kde_confdir" || + test -z "$kde_kcfgdir" || + test -z "$kde_mimedir" || test -z "$kde_toolbardir" || + test -z "$kde_wallpaperdir" || test -z "$kde_templatesdir" || + test -z "$kde_bindir" || test -z "$kde_servicesdir" || + test -z "$kde_servicetypesdir" || test -z "$kde_moduledir" || + test -z "$kde_styledir" || test -z "kde_widgetdir" || + test -z "$xdg_appsdir" || test -z "$xdg_menudir" || test -z "$xdg_directorydir" || + test "x$kde_have_all_paths" != "xyes"; then + kde_have_all_paths=no + fi +]) + +AC_DEFUN([KDE_MISSING_PROG_ERROR], +[ + AC_MSG_ERROR([The important program $1 was not found! +Please check whether you installed KDE correctly. +]) +]) + +AC_DEFUN([KDE_MISSING_ARTS_ERROR], +[ + AC_MSG_ERROR([The important program $1 was not found! +Please check whether you installed aRts correctly or use +--without-arts to compile without aRts support (this will remove functionality). +]) +]) + +AC_DEFUN([KDE_SUBST_PROGRAMS], +[ + AC_ARG_WITH(arts, + AC_HELP_STRING([--without-arts],[build without aRts [default=yes]]), + [build_arts=$withval], + [build_arts=yes] + ) + AM_CONDITIONAL(include_ARTS, test "$build_arts" != "no") + + kde_default_bindirs="/usr/bin /usr/local/bin /opt/local/bin /usr/X11R6/bin /opt/kde/bin /opt/kde3/bin /usr/kde/bin /usr/local/kde/bin" + test -n "$KDEDIR" && kde_default_bindirs="$KDEDIR/bin $kde_default_bindirs" + if test -n "$KDEDIRS"; then + kde_save_IFS=$IFS + IFS=: + for dir in $KDEDIRS; do + kde_default_bindirs="$dir/bin $kde_default_bindirs " + done + IFS=$kde_save_IFS + fi + kde_default_bindirs="$exec_prefix/bin $prefix/bin $kde_default_bindirs" + KDE_FIND_PATH(dcopidl, DCOPIDL, [$kde_default_bindirs], [KDE_MISSING_PROG_ERROR(dcopidl)]) + KDE_FIND_PATH(dcopidl2cpp, DCOPIDL2CPP, [$kde_default_bindirs], [KDE_MISSING_PROG_ERROR(dcopidl2cpp)]) + if test "$build_arts" != "no"; then + KDE_FIND_PATH(mcopidl, MCOPIDL, [$kde_default_bindirs], [KDE_MISSING_ARTS_ERROR(mcopidl)]) + KDE_FIND_PATH(artsc-config, ARTSCCONFIG, [$kde_default_bindirs], [KDE_MISSING_ARTS_ERROR(artsc-config)]) + fi + KDE_FIND_PATH(kde-config, KDECONFIG, [$kde_default_bindirs]) + KDE_FIND_PATH(meinproc, MEINPROC, [$kde_default_bindirs]) + + kde32ornewer=1 + if test -n "$kde_qtver" && test "$kde_qtver" -lt 3; then + kde32ornewer= + else + if test "$kde_qtver" = "3" && test "$kde_qtsubver" -le 1; then + kde32ornewer= + fi + fi + + if test -n "$kde32ornewer"; then + KDE_FIND_PATH(kconfig_compiler, KCONFIG_COMPILER, [$kde_default_bindirs], [KDE_MISSING_PROG_ERROR(kconfig_compiler)]) + KDE_FIND_PATH(dcopidlng, DCOPIDLNG, [$kde_default_bindirs], [KDE_MISSING_PROG_ERROR(dcopidlng)]) + fi + KDE_FIND_PATH(xmllint, XMLLINT, [${prefix}/bin ${exec_prefix}/bin /usr/local/bin /opt/local/bin], [XMLLINT=""]) + + if test -n "$MEINPROC" && test ! "$MEINPROC" = "compiled"; then + kde_sharedirs="/usr/share/kde /usr/local/share /usr/share /opt/kde3/share /opt/kde/share $prefix/share" + test -n "$KDEDIR" && kde_sharedirs="$KDEDIR/share $kde_sharedirs" + AC_FIND_FILE(apps/ksgmltools2/customization/kde-chunk.xsl, $kde_sharedirs, KDE_XSL_STYLESHEET) + if test "$KDE_XSL_STYLESHEET" = "NO"; then + KDE_XSL_STYLESHEET="" + else + KDE_XSL_STYLESHEET="$KDE_XSL_STYLESHEET/apps/ksgmltools2/customization/kde-chunk.xsl" + fi + fi + + DCOP_DEPENDENCIES='$(DCOPIDL)' + if test -n "$kde32ornewer"; then + KCFG_DEPENDENCIES='$(KCONFIG_COMPILER)' + DCOP_DEPENDENCIES='$(DCOPIDL) $(DCOPIDLNG)' + AC_SUBST(KCONFIG_COMPILER) + AC_SUBST(KCFG_DEPENDENCIES) + AC_SUBST(DCOPIDLNG) + fi + AC_SUBST(DCOPIDL) + AC_SUBST(DCOPIDL2CPP) + AC_SUBST(DCOP_DEPENDENCIES) + AC_SUBST(MCOPIDL) + AC_SUBST(ARTSCCONFIG) + AC_SUBST(KDECONFIG) + AC_SUBST(MEINPROC) + AC_SUBST(KDE_XSL_STYLESHEET) + AC_SUBST(XMLLINT) + + if test -x "$KDECONFIG"; then # it can be "compiled" + kde_libs_prefix=`$KDECONFIG --prefix` + if test -z "$kde_libs_prefix" || test ! -x "$kde_libs_prefix"; then + AC_MSG_ERROR([$KDECONFIG --prefix outputed the non existant prefix '$kde_libs_prefix' for kdelibs. + This means it has been moved since you installed it. + This won't work. Please recompile kdelibs for the new prefix. + ]) + fi + kde_libs_htmldir=`$KDECONFIG --install html --expandvars` + else + kde_libs_prefix='$(prefix)' + kde_libs_htmldir='$(kde_htmldir)' + fi + AC_SUBST(kde_libs_prefix) + AC_SUBST(kde_libs_htmldir) +])dnl + +AC_DEFUN([AC_CREATE_KFSSTND], +[ +AC_REQUIRE([AC_CHECK_RPATH]) + +AC_MSG_CHECKING([for KDE paths]) +kde_result="" +kde_cached_paths=yes +AC_CACHE_VAL(kde_cv_all_paths, +[ + KDE_SET_DEFAULT_PATHS($1) + kde_cached_paths=no +]) +eval "$kde_cv_all_paths" +KDE_CHECK_PATHS_FOR_COMPLETENESS +if test "$kde_have_all_paths" = "no" && test "$kde_cached_paths" = "yes"; then + # wrong values were cached, may be, we can set better ones + kde_result= + kde_htmldir= kde_appsdir= kde_icondir= kde_sounddir= + kde_datadir= kde_locale= kde_cgidir= kde_confdir= kde_kcfgdir= + kde_mimedir= kde_toolbardir= kde_wallpaperdir= kde_templatesdir= + kde_bindir= kde_servicesdir= kde_servicetypesdir= kde_moduledir= + kde_have_all_paths= + kde_styledir= + kde_widgetdir= + xdg_appsdir = xdg_menudir= xdg_directorydir= + KDE_SET_DEFAULT_PATHS($1) + eval "$kde_cv_all_paths" + KDE_CHECK_PATHS_FOR_COMPLETENESS + kde_result="$kde_result (cache overridden)" +fi +if test "$kde_have_all_paths" = "no"; then + AC_MSG_ERROR([configure could not run a little KDE program to test the environment. +Since it had compiled and linked before, it must be a strange problem on your system. +Look at config.log for details. If you are not able to fix this, look at +http://www.kde.org/faq/installation.html or any www.kde.org mirror. +(If you're using an egcs version on Linux, you may update binutils!) +]) +else + rm -f conftest* + AC_MSG_RESULT($kde_result) +fi + +bindir=$kde_bindir + +KDE_SUBST_PROGRAMS + +]) + +AC_DEFUN([AC_SUBST_KFSSTND], +[ +AC_SUBST(kde_htmldir) +AC_SUBST(kde_appsdir) +AC_SUBST(kde_icondir) +AC_SUBST(kde_sounddir) +AC_SUBST(kde_datadir) +AC_SUBST(kde_locale) +AC_SUBST(kde_confdir) +AC_SUBST(kde_kcfgdir) +AC_SUBST(kde_mimedir) +AC_SUBST(kde_wallpaperdir) +AC_SUBST(kde_bindir) +dnl X Desktop Group standards +AC_SUBST(xdg_appsdir) +AC_SUBST(xdg_menudir) +AC_SUBST(xdg_directorydir) +dnl for KDE 2 +AC_SUBST(kde_templatesdir) +AC_SUBST(kde_servicesdir) +AC_SUBST(kde_servicetypesdir) +AC_SUBST(kde_moduledir) +AC_SUBST(kdeinitdir, '$(kde_moduledir)') +AC_SUBST(kde_styledir) +AC_SUBST(kde_widgetdir) +if test "$kde_qtver" = 1; then + kde_minidir="$kde_icondir/mini" +else +# for KDE 1 - this breaks KDE2 apps using minidir, but +# that's the plan ;-/ + kde_minidir="/dev/null" +fi +dnl AC_SUBST(kde_minidir) +dnl AC_SUBST(kde_cgidir) +dnl AC_SUBST(kde_toolbardir) +]) + +AC_DEFUN([KDE_MISC_TESTS], +[ + dnl Checks for libraries. + AC_CHECK_LIB(util, main, [LIBUTIL="-lutil"]) dnl for *BSD + AC_SUBST(LIBUTIL) + AC_CHECK_LIB(compat, main, [LIBCOMPAT="-lcompat"]) dnl for *BSD + AC_SUBST(LIBCOMPAT) + kde_have_crypt= + AC_CHECK_LIB(crypt, crypt, [LIBCRYPT="-lcrypt"; kde_have_crypt=yes], + AC_CHECK_LIB(c, crypt, [kde_have_crypt=yes], [ + AC_MSG_WARN([you have no crypt in either libcrypt or libc. +You should install libcrypt from another source or configure with PAM +support]) + kde_have_crypt=no + ])) + AC_SUBST(LIBCRYPT) + if test $kde_have_crypt = yes; then + AC_DEFINE_UNQUOTED(HAVE_CRYPT, 1, [Defines if your system has the crypt function]) + fi + AC_CHECK_SOCKLEN_T + AC_CHECK_LIB(dnet, dnet_ntoa, [X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet"]) + if test $ac_cv_lib_dnet_dnet_ntoa = no; then + AC_CHECK_LIB(dnet_stub, dnet_ntoa, + [X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet_stub"]) + fi + AC_CHECK_FUNC(inet_ntoa) + if test $ac_cv_func_inet_ntoa = no; then + AC_CHECK_LIB(nsl, inet_ntoa, X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl") + fi + AC_CHECK_FUNC(connect) + if test $ac_cv_func_connect = no; then + AC_CHECK_LIB(socket, connect, X_EXTRA_LIBS="-lsocket $X_EXTRA_LIBS", , + $X_EXTRA_LIBS) + fi + + AC_CHECK_FUNC(remove) + if test $ac_cv_func_remove = no; then + AC_CHECK_LIB(posix, remove, X_EXTRA_LIBS="$X_EXTRA_LIBS -lposix") + fi + + # BSDI BSD/OS 2.1 needs -lipc for XOpenDisplay. + AC_CHECK_FUNC(shmat, , + AC_CHECK_LIB(ipc, shmat, X_EXTRA_LIBS="$X_EXTRA_LIBS -lipc")) + + # more headers that need to be explicitly included on darwin + AC_CHECK_HEADERS(sys/types.h stdint.h) + + # darwin requires a poll emulation library + AC_CHECK_LIB(poll, poll, LIB_POLL="-lpoll") + + # CoreAudio framework + AC_CHECK_HEADER(CoreAudio/CoreAudio.h, [ + AC_DEFINE(HAVE_COREAUDIO, 1, [Define if you have the CoreAudio API]) + FRAMEWORK_COREAUDIO="-Xlinker -framework -Xlinker CoreAudio" + ]) + + AC_CHECK_RES_INIT + AC_SUBST(LIB_POLL) + AC_SUBST(FRAMEWORK_COREAUDIO) + LIBSOCKET="$X_EXTRA_LIBS" + AC_SUBST(LIBSOCKET) + AC_SUBST(X_EXTRA_LIBS) + AC_CHECK_LIB(ucb, killpg, [LIBUCB="-lucb"]) dnl for Solaris2.4 + AC_SUBST(LIBUCB) + + case $host in dnl this *is* LynxOS specific + *-*-lynxos* ) + AC_MSG_CHECKING([LynxOS header file wrappers]) + [CFLAGS="$CFLAGS -D__NO_INCLUDE_WARN__"] + AC_MSG_RESULT(disabled) + AC_CHECK_LIB(bsd, gethostbyname, [LIBSOCKET="-lbsd"]) dnl for LynxOS + ;; + esac + + KDE_CHECK_TYPES + KDE_CHECK_LIBDL + KDE_CHECK_STRLCPY + +# darwin needs this to initialize the environment +AC_CHECK_HEADERS(crt_externs.h) +AC_CHECK_FUNC(_NSGetEnviron, [AC_DEFINE(HAVE_NSGETENVIRON, 1, [Define if your system needs _NSGetEnviron to set up the environment])]) + +AH_VERBATIM(_DARWIN_ENVIRON, +[ +#if defined(HAVE_NSGETENVIRON) && defined(HAVE_CRT_EXTERNS_H) +# include +# include +# define environ (*_NSGetEnviron()) +#endif +]) + +AH_VERBATIM(_AIX_STRINGS_H_BZERO, +[ +/* + * AIX defines FD_SET in terms of bzero, but fails to include + * that defines bzero. + */ + +#if defined(_AIX) +#include +#endif +]) + +AC_CHECK_FUNCS([vsnprintf snprintf]) + +AH_VERBATIM(_TRU64,[ +/* + * On HP-UX, the declaration of vsnprintf() is needed every time ! + */ + +#if !defined(HAVE_VSNPRINTF) || defined(hpux) +#if __STDC__ +#include +#include +#else +#include +#endif +#ifdef __cplusplus +extern "C" +#endif +int vsnprintf(char *str, size_t n, char const *fmt, va_list ap); +#ifdef __cplusplus +extern "C" +#endif +int snprintf(char *str, size_t n, char const *fmt, ...); +#endif +]) + +]) + +dnl ------------------------------------------------------------------------ +dnl Find the header files and libraries for X-Windows. Extended the +dnl macro AC_PATH_X +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([K_PATH_X], +[ +AC_REQUIRE([KDE_MISC_TESTS])dnl +AC_REQUIRE([KDE_CHECK_LIB64]) + +AC_ARG_ENABLE( + embedded, + AC_HELP_STRING([--enable-embedded],[link to Qt-embedded, don't use X]), + kde_use_qt_emb=$enableval, + kde_use_qt_emb=no +) + +AC_ARG_ENABLE( + qtopia, + AC_HELP_STRING([--enable-qtopia],[link to Qt-embedded, link to the Qtopia Environment]), + kde_use_qt_emb_palm=$enableval, + kde_use_qt_emb_palm=no +) + +AC_ARG_ENABLE( + mac, + AC_HELP_STRING([--enable-mac],[link to Qt/Mac (don't use X)]), + kde_use_qt_mac=$enableval, + kde_use_qt_mac=no +) + +if test "$kde_use_qt_emb" = "no" && test "$kde_use_qt_mac" = "no"; then + +AC_MSG_CHECKING(for X) + +AC_CACHE_VAL(kde_cv_have_x, +[# One or both of the vars are not set, and there is no cached value. +if test "{$x_includes+set}" = set || test "$x_includes" = NONE; then + kde_x_includes=NO +else + kde_x_includes=$x_includes +fi +if test "{$x_libraries+set}" = set || test "$x_libraries" = NONE; then + kde_x_libraries=NO +else + kde_x_libraries=$x_libraries +fi + +# below we use the standard autoconf calls +ac_x_libraries=$kde_x_libraries +ac_x_includes=$kde_x_includes + +KDE_PATH_X_DIRECT +dnl AC_PATH_X_XMKMF picks /usr/lib as the path for the X libraries. +dnl Unfortunately, if compiling with the N32 ABI, this is not the correct +dnl location. The correct location is /usr/lib32 or an undefined value +dnl (the linker is smart enough to pick the correct default library). +dnl Things work just fine if you use just AC_PATH_X_DIRECT. +dnl Solaris has a similar problem. AC_PATH_X_XMKMF forces x_includes to +dnl /usr/openwin/include, which doesn't work. /usr/include does work, so +dnl x_includes should be left alone. +case "$host" in +mips-sgi-irix6*) + ;; +*-*-solaris*) + ;; +*) + _AC_PATH_X_XMKMF + if test -z "$ac_x_includes"; then + ac_x_includes="." + fi + if test -z "$ac_x_libraries"; then + ac_x_libraries="/usr/lib${kdelibsuff}" + fi +esac +#from now on we use our own again + +# when the user already gave --x-includes, we ignore +# what the standard autoconf macros told us. +if test "$kde_x_includes" = NO; then + kde_x_includes=$ac_x_includes +fi + +# for --x-libraries too +if test "$kde_x_libraries" = NO; then + kde_x_libraries=$ac_x_libraries +fi + +if test "$kde_x_includes" = NO; then + AC_MSG_ERROR([Can't find X includes. Please check your installation and add the correct paths!]) +fi + +if test "$kde_x_libraries" = NO; then + AC_MSG_ERROR([Can't find X libraries. Please check your installation and add the correct paths!]) +fi + +# Record where we found X for the cache. +kde_cv_have_x="have_x=yes \ + kde_x_includes=$kde_x_includes kde_x_libraries=$kde_x_libraries" +])dnl + +eval "$kde_cv_have_x" + +if test "$have_x" != yes; then + AC_MSG_RESULT($have_x) + no_x=yes +else + AC_MSG_RESULT([libraries $kde_x_libraries, headers $kde_x_includes]) +fi + +if test -z "$kde_x_includes" || test "x$kde_x_includes" = xNONE; then + X_INCLUDES="" + x_includes="."; dnl better than nothing :- + else + x_includes=$kde_x_includes + X_INCLUDES="-I$x_includes" +fi + +if test -z "$kde_x_libraries" || test "x$kde_x_libraries" = xNONE; then + X_LDFLAGS="" + x_libraries="/usr/lib"; dnl better than nothing :- + else + x_libraries=$kde_x_libraries + X_LDFLAGS="-L$x_libraries" +fi +all_includes="$X_INCLUDES" +all_libraries="$X_LDFLAGS" + +# Check for libraries that X11R6 Xt/Xaw programs need. +ac_save_LDFLAGS="$LDFLAGS" +LDFLAGS="$LDFLAGS $X_LDFLAGS" +# SM needs ICE to (dynamically) link under SunOS 4.x (so we have to +# check for ICE first), but we must link in the order -lSM -lICE or +# we get undefined symbols. So assume we have SM if we have ICE. +# These have to be linked with before -lX11, unlike the other +# libraries we check for below, so use a different variable. +# --interran@uluru.Stanford.EDU, kb@cs.umb.edu. +AC_CHECK_LIB(ICE, IceConnectionNumber, + [LIBSM="-lSM -lICE"], , $X_EXTRA_LIBS) +LDFLAGS="$ac_save_LDFLAGS" + +LIB_X11='-lX11 $(LIBSOCKET)' + +AC_MSG_CHECKING(for libXext) +AC_CACHE_VAL(kde_cv_have_libXext, +[ +kde_ldflags_safe="$LDFLAGS" +kde_libs_safe="$LIBS" + +LDFLAGS="$LDFLAGS $X_LDFLAGS $USER_LDFLAGS" +LIBS="-lXext -lX11 $LIBSOCKET" + +AC_TRY_LINK([ +#include +#ifdef STDC_HEADERS +# include +#endif +], +[ +printf("hello Xext\n"); +], +kde_cv_have_libXext=yes, +kde_cv_have_libXext=no +) + +LDFLAGS=$kde_ldflags_safe +LIBS=$kde_libs_safe +]) + +AC_MSG_RESULT($kde_cv_have_libXext) + +if test "$kde_cv_have_libXext" = "no"; then + AC_MSG_ERROR([We need a working libXext to proceed. Since configure +can't find it itself, we stop here assuming that make wouldn't find +them either.]) +fi + +LIB_XEXT="-lXext" +QTE_NORTTI="" + +elif test "$kde_use_qt_emb" = "yes"; then + dnl We're using QT Embedded + CPPFLAGS=-DQWS + CXXFLAGS="$CXXFLAGS -fno-rtti" + QTE_NORTTI="-fno-rtti -DQWS" + X_PRE_LIBS="" + LIB_X11="" + LIB_XEXT="" + LIB_XRENDER="" + LIBSM="" + X_INCLUDES="" + X_LDFLAGS="" + x_includes="" + x_libraries="" +elif test "$kde_use_qt_mac" = "yes"; then + dnl We're using QT/Mac (I use QT_MAC so that qglobal.h doesn't *have* to + dnl be included to get the information) --Sam + CXXFLAGS="$CXXFLAGS -DQT_MAC -no-cpp-precomp" + CFLAGS="$CFLAGS -DQT_MAC -no-cpp-precomp" + X_PRE_LIBS="" + LIB_X11="" + LIB_XEXT="" + LIB_XRENDER="" + LIBSM="" + X_INCLUDES="" + X_LDFLAGS="" + x_includes="" + x_libraries="" +fi +AC_SUBST(X_PRE_LIBS) +AC_SUBST(LIB_X11) +AC_SUBST(LIB_XRENDER) +AC_SUBST(LIBSM) +AC_SUBST(X_INCLUDES) +AC_SUBST(X_LDFLAGS) +AC_SUBST(x_includes) +AC_SUBST(x_libraries) +AC_SUBST(QTE_NORTTI) +AC_SUBST(LIB_XEXT) + +]) + +AC_DEFUN([KDE_PRINT_QT_PROGRAM], +[ +AC_REQUIRE([KDE_USE_QT]) +cat > conftest.$ac_ext < +#include +EOF +if test "$kde_qtver" = "2"; then +cat >> conftest.$ac_ext < +#include +#include +EOF + +if test $kde_qtsubver -gt 0; then +cat >> conftest.$ac_ext <> conftest.$ac_ext < +#include +#include +EOF +fi + +echo "#if ! ($kde_qt_verstring)" >> conftest.$ac_ext +cat >> conftest.$ac_ext <> conftest.$ac_ext <> conftest.$ac_ext <> conftest.$ac_ext <> conftest.$ac_ext <&AC_FD_CC + cat conftest.$ac_ext >&AC_FD_CC +fi + +rm -f conftest* +CXXFLAGS="$ac_cxxflags_safe" +LDFLAGS="$ac_ldflags_safe" +LIBS="$ac_libs_safe" + +LD_LIBRARY_PATH="$ac_LD_LIBRARY_PATH_safe" +export LD_LIBRARY_PATH +LIBRARY_PATH="$ac_LIBRARY_PATH" +export LIBRARY_PATH +AC_LANG_RESTORE +]) + +if test "$kde_cv_qt_direct" = "yes"; then + AC_MSG_RESULT(yes) + $1 +else + AC_MSG_RESULT(no) + $2 +fi +]) + +dnl ------------------------------------------------------------------------ +dnl Try to find the Qt headers and libraries. +dnl $(QT_LDFLAGS) will be -Lqtliblocation (if needed) +dnl and $(QT_INCLUDES) will be -Iqthdrlocation (if needed) +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_PATH_QT_1_3], +[ +AC_REQUIRE([K_PATH_X]) +AC_REQUIRE([KDE_USE_QT]) +AC_REQUIRE([KDE_CHECK_LIB64]) + +dnl ------------------------------------------------------------------------ +dnl Add configure flag to enable linking to MT version of Qt library. +dnl ------------------------------------------------------------------------ + +AC_ARG_ENABLE( + mt, + AC_HELP_STRING([--disable-mt],[link to non-threaded Qt (deprecated)]), + kde_use_qt_mt=$enableval, + [ + if test $kde_qtver = 3; then + kde_use_qt_mt=yes + else + kde_use_qt_mt=no + fi + ] +) + +USING_QT_MT="" + +dnl ------------------------------------------------------------------------ +dnl If we not get --disable-qt-mt then adjust some vars for the host. +dnl ------------------------------------------------------------------------ + +KDE_MT_LDFLAGS= +KDE_MT_LIBS= +if test "x$kde_use_qt_mt" = "xyes"; then + KDE_CHECK_THREADING + if test "x$kde_use_threading" = "xyes"; then + CPPFLAGS="$USE_THREADS -DQT_THREAD_SUPPORT $CPPFLAGS" + KDE_MT_LDFLAGS="$USE_THREADS" + KDE_MT_LIBS="$LIBPTHREAD" + else + kde_use_qt_mt=no + fi +fi +AC_SUBST(KDE_MT_LDFLAGS) +AC_SUBST(KDE_MT_LIBS) + +kde_qt_was_given=yes + +dnl ------------------------------------------------------------------------ +dnl If we haven't been told how to link to Qt, we work it out for ourselves. +dnl ------------------------------------------------------------------------ +if test -z "$LIBQT_GLOB"; then + if test "x$kde_use_qt_emb" = "xyes"; then + LIBQT_GLOB="libqte.*" + else + LIBQT_GLOB="libqt.*" + fi +fi + +if test -z "$LIBQT"; then +dnl ------------------------------------------------------------ +dnl If we got --enable-embedded then adjust the Qt library name. +dnl ------------------------------------------------------------ + if test "x$kde_use_qt_emb" = "xyes"; then + qtlib="qte" + else + qtlib="qt" + fi + + kde_int_qt="-l$qtlib" +else + kde_int_qt="$LIBQT" + kde_lib_qt_set=yes +fi + +if test -z "$LIBQPE"; then +dnl ------------------------------------------------------------ +dnl If we got --enable-palmtop then add -lqpe to the link line +dnl ------------------------------------------------------------ + if test "x$kde_use_qt_emb" = "xyes"; then + if test "x$kde_use_qt_emb_palm" = "xyes"; then + LIB_QPE="-lqpe" + else + LIB_QPE="" + fi + else + LIB_QPE="" + fi +fi + +dnl ------------------------------------------------------------------------ +dnl If we got --enable-qt-mt then adjust the Qt library name for the host. +dnl ------------------------------------------------------------------------ + +if test "x$kde_use_qt_mt" = "xyes"; then + if test -z "$LIBQT"; then + LIBQT="-l$qtlib-mt" + kde_int_qt="-l$qtlib-mt" + else + LIBQT="$qtlib-mt" + kde_int_qt="$qtlib-mt" + fi + LIBQT_GLOB="lib$qtlib-mt.*" + USING_QT_MT="using -mt" +else + LIBQT="-l$qtlib" +fi + +if test $kde_qtver != 1; then + + AC_REQUIRE([AC_FIND_PNG]) + AC_REQUIRE([AC_FIND_JPEG]) + LIBQT="$LIBQT $LIBPNG $LIBJPEG" +fi + +if test $kde_qtver = 3; then + AC_REQUIRE([KDE_CHECK_LIBDL]) + LIBQT="$LIBQT $LIBDL" +fi + +AC_MSG_CHECKING([for Qt]) + +if test "x$kde_use_qt_emb" != "xyes" && test "x$kde_use_qt_mac" != "xyes"; then +LIBQT="$LIBQT $X_PRE_LIBS -lXext -lX11 $LIBSM $LIBSOCKET" +fi +ac_qt_includes=NO ac_qt_libraries=NO ac_qt_bindir=NO +qt_libraries="" +qt_includes="" +AC_ARG_WITH(qt-dir, + AC_HELP_STRING([--with-qt-dir=DIR],[where the root of Qt is installed ]), + [ ac_qt_includes="$withval"/include + ac_qt_libraries="$withval"/lib${kdelibsuff} + ac_qt_bindir="$withval"/bin + ]) + +AC_ARG_WITH(qt-includes, + AC_HELP_STRING([--with-qt-includes=DIR],[where the Qt includes are. ]), + [ + ac_qt_includes="$withval" + ]) + +kde_qt_libs_given=no + +AC_ARG_WITH(qt-libraries, + AC_HELP_STRING([--with-qt-libraries=DIR],[where the Qt library is installed.]), + [ ac_qt_libraries="$withval" + kde_qt_libs_given=yes + ]) + +AC_CACHE_VAL(ac_cv_have_qt, +[#try to guess Qt locations + +qt_incdirs="" +for dir in $kde_qt_dirs; do + qt_incdirs="$qt_incdirs $dir/include $dir" +done +qt_incdirs="$QTINC $qt_incdirs /usr/local/qt/include /usr/include/qt /usr/include /usr/X11R6/include/X11/qt /usr/X11R6/include/qt /usr/X11R6/include/qt2 /usr/include/qt3 $x_includes" +if test ! "$ac_qt_includes" = "NO"; then + qt_incdirs="$ac_qt_includes $qt_incdirs" +fi + +if test "$kde_qtver" != "1"; then + kde_qt_header=qstyle.h +else + kde_qt_header=qglobal.h +fi + +AC_FIND_FILE($kde_qt_header, $qt_incdirs, qt_incdir) +ac_qt_includes="$qt_incdir" + +qt_libdirs="" +for dir in $kde_qt_dirs; do + qt_libdirs="$qt_libdirs $dir/lib${kdelibsuff} $dir" +done +qt_libdirs="$QTLIB $qt_libdirs /usr/X11R6/lib /usr/lib /usr/local/qt/lib $x_libraries" +if test ! "$ac_qt_libraries" = "NO"; then + qt_libdir=$ac_qt_libraries +else + qt_libdirs="$ac_qt_libraries $qt_libdirs" + # if the Qt was given, the chance is too big that libqt.* doesn't exist + qt_libdir=NONE + for dir in $qt_libdirs; do + try="ls -1 $dir/${LIBQT_GLOB}" + if test -n "`$try 2> /dev/null`"; then qt_libdir=$dir; break; else echo "tried $dir" >&AC_FD_CC ; fi + done +fi +for a in $qt_libdir/lib`echo ${kde_int_qt} | sed 's,^-l,,'`_incremental.*; do + if test -e "$a"; then + LIBQT="$LIBQT ${kde_int_qt}_incremental" + break + fi +done + +ac_qt_libraries="$qt_libdir" + +AC_LANG_SAVE +AC_LANG_CPLUSPLUS + +ac_cxxflags_safe="$CXXFLAGS" +ac_ldflags_safe="$LDFLAGS" +ac_libs_safe="$LIBS" + +CXXFLAGS="$CXXFLAGS -I$qt_incdir $all_includes" +LDFLAGS="$LDFLAGS -L$qt_libdir $all_libraries $USER_LDFLAGS $KDE_MT_LDFLAGS" +LIBS="$LIBS $LIBQT $KDE_MT_LIBS" + +KDE_PRINT_QT_PROGRAM + +if AC_TRY_EVAL(ac_link) && test -s conftest; then + rm -f conftest* +else + echo "configure: failed program was:" >&AC_FD_CC + cat conftest.$ac_ext >&AC_FD_CC + ac_qt_libraries="NO" +fi +rm -f conftest* +CXXFLAGS="$ac_cxxflags_safe" +LDFLAGS="$ac_ldflags_safe" +LIBS="$ac_libs_safe" + +AC_LANG_RESTORE +if test "$ac_qt_includes" = NO || test "$ac_qt_libraries" = NO; then + ac_cv_have_qt="have_qt=no" + ac_qt_notfound="" + missing_qt_mt="" + if test "$ac_qt_includes" = NO; then + if test "$ac_qt_libraries" = NO; then + ac_qt_notfound="(headers and libraries)"; + else + ac_qt_notfound="(headers)"; + fi + else + if test "x$kde_use_qt_mt" = "xyes"; then + missing_qt_mt=" +Make sure that you have compiled Qt with thread support!" + ac_qt_notfound="(library $qtlib-mt)"; + else + ac_qt_notfound="(library $qtlib)"; + fi + fi + + AC_MSG_ERROR([Qt ($kde_qt_minversion) $ac_qt_notfound not found. Please check your installation! +For more details about this problem, look at the end of config.log.$missing_qt_mt]) +else + have_qt="yes" +fi +]) + +eval "$ac_cv_have_qt" + +if test "$have_qt" != yes; then + AC_MSG_RESULT([$have_qt]); +else + ac_cv_have_qt="have_qt=yes \ + ac_qt_includes=$ac_qt_includes ac_qt_libraries=$ac_qt_libraries" + AC_MSG_RESULT([libraries $ac_qt_libraries, headers $ac_qt_includes $USING_QT_MT]) + + qt_libraries="$ac_qt_libraries" + qt_includes="$ac_qt_includes" +fi + +if test ! "$kde_qt_libs_given" = "yes" && test ! "$kde_qtver" = 3; then + KDE_CHECK_QT_DIRECT(qt_libraries= ,[]) +fi + +AC_SUBST(qt_libraries) +AC_SUBST(qt_includes) + +if test "$qt_includes" = "$x_includes" || test -z "$qt_includes"; then + QT_INCLUDES="" +else + QT_INCLUDES="-I$qt_includes" + all_includes="$QT_INCLUDES $all_includes" +fi + +if test "$qt_libraries" = "$x_libraries" || test -z "$qt_libraries"; then + QT_LDFLAGS="" +else + QT_LDFLAGS="-L$qt_libraries" + all_libraries="$all_libraries $QT_LDFLAGS" +fi +test -z "$KDE_MT_LDFLAGS" || all_libraries="$all_libraries $KDE_MT_LDFLAGS" + +AC_SUBST(QT_INCLUDES) +AC_SUBST(QT_LDFLAGS) +AC_PATH_QT_MOC_UIC + +KDE_CHECK_QT_JPEG + +if test "x$kde_use_qt_emb" != "xyes" && test "x$kde_use_qt_mac" != "xyes"; then +LIB_QT="$kde_int_qt $LIBJPEG_QT "'$(LIBZ) $(LIBPNG) -lXext $(LIB_X11) $(LIBSM)' +else +LIB_QT="$kde_int_qt $LIBJPEG_QT "'$(LIBZ) $(LIBPNG)' +fi +test -z "$KDE_MT_LIBS" || LIB_QT="$LIB_QT $KDE_MT_LIBS" +for a in $qt_libdir/lib`echo ${kde_int_qt} | sed 's,^-l,,'`_incremental.*; do + if test -e "$a"; then + LIB_QT="$LIB_QT ${kde_int_qt}_incremental" + break + fi +done + +AC_SUBST(LIB_QT) +AC_SUBST(LIB_QPE) + +AC_SUBST(kde_qtver) +]) + +AC_DEFUN([AC_PATH_QT], +[ +AC_PATH_QT_1_3 +]) + +AC_DEFUN([KDE_CHECK_UIC_PLUGINS], +[ +AC_REQUIRE([AC_PATH_QT_MOC_UIC]) + +if test x$ac_uic_supports_libpath = xyes; then + +AC_MSG_CHECKING([if UIC has KDE plugins available]) +AC_CACHE_VAL(kde_cv_uic_plugins, +[ +cat > actest.ui << EOF + +NewConnectionDialog + + + + testInput + + + + +EOF + + + +kde_cv_uic_plugins=no +kde_line="$UIC_PATH -L $kde_widgetdir" +if test x$ac_uic_supports_nounload = xyes; then + kde_line="$kde_line -nounload" +fi +kde_line="$kde_line -impl actest.h actest.ui > actest.cpp" +if AC_TRY_EVAL(kde_line); then + # if you're trying to debug this check and think it's incorrect, + # better check your installation. The check _is_ correct - your + # installation is not. + if test -f actest.cpp && grep klineedit actest.cpp > /dev/null; then + kde_cv_uic_plugins=yes + fi +fi +rm -f actest.ui actest.cpp +]) + +AC_MSG_RESULT([$kde_cv_uic_plugins]) +if test "$kde_cv_uic_plugins" != yes; then + AC_MSG_ERROR([you need to install kdelibs first.]) +fi +fi +]) + +AC_DEFUN([KDE_CHECK_FINAL], +[ + AC_ARG_ENABLE(final, + AC_HELP_STRING([--enable-final], + [build size optimized apps (experimental - needs lots of memory)]), + kde_use_final=$enableval, kde_use_final=no) + + if test "x$kde_use_final" = "xyes"; then + KDE_USE_FINAL_TRUE="" + KDE_USE_FINAL_FALSE="#" + else + KDE_USE_FINAL_TRUE="#" + KDE_USE_FINAL_FALSE="" + fi + AC_SUBST(KDE_USE_FINAL_TRUE) + AC_SUBST(KDE_USE_FINAL_FALSE) +]) + +AC_DEFUN([KDE_CHECK_CLOSURE], +[ + AC_ARG_ENABLE(closure, + AC_HELP_STRING([--enable-closure],[delay template instantiation]), + kde_use_closure=$enableval, kde_use_closure=no) + + KDE_NO_UNDEFINED="" + if test "x$kde_use_closure" = "xyes"; then + KDE_USE_CLOSURE_TRUE="" + KDE_USE_CLOSURE_FALSE="#" +# CXXFLAGS="$CXXFLAGS $REPO" + else + KDE_USE_CLOSURE_TRUE="#" + KDE_USE_CLOSURE_FALSE="" + KDE_NO_UNDEFINED="" + case $host in + *-*-linux-gnu) + KDE_CHECK_COMPILER_FLAG([Wl,--no-undefined], + [KDE_CHECK_COMPILER_FLAG([Wl,--allow-shlib-undefined], + [KDE_NO_UNDEFINED="-Wl,--no-undefined -Wl,--allow-shlib-undefined"], + [KDE_NO_UNDEFINED=""])], + [KDE_NO_UNDEFINED=""]) + ;; + esac + fi + AC_SUBST(KDE_USE_CLOSURE_TRUE) + AC_SUBST(KDE_USE_CLOSURE_FALSE) + AC_SUBST(KDE_NO_UNDEFINED) +]) + +AC_DEFUN([KDE_CHECK_NMCHECK], +[ + AC_ARG_ENABLE(nmcheck,AC_HELP_STRING([--enable-nmcheck],[enable automatic namespace cleanness check]), + kde_use_nmcheck=$enableval, kde_use_nmcheck=no) + + if test "$kde_use_nmcheck" = "yes"; then + KDE_USE_NMCHECK_TRUE="" + KDE_USE_NMCHECK_FALSE="#" + else + KDE_USE_NMCHECK_TRUE="#" + KDE_USE_NMCHECK_FALSE="" + fi + AC_SUBST(KDE_USE_NMCHECK_TRUE) + AC_SUBST(KDE_USE_NMCHECK_FALSE) +]) + +AC_DEFUN([KDE_EXPAND_MAKEVAR], [ +savex=$exec_prefix +test "x$exec_prefix" = xNONE && exec_prefix=$prefix +tmp=$$2 +while $1=`eval echo "$tmp"`; test "x$$1" != "x$tmp"; do tmp=$$1; done +exec_prefix=$savex +]) + +dnl ------------------------------------------------------------------------ +dnl Now, the same with KDE +dnl $(KDE_LDFLAGS) will be the kdeliblocation (if needed) +dnl and $(kde_includes) will be the kdehdrlocation (if needed) +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_BASE_PATH_KDE], +[ +AC_REQUIRE([KDE_CHECK_STL]) +AC_REQUIRE([AC_PATH_QT])dnl +AC_REQUIRE([KDE_CHECK_LIB64]) + +AC_CHECK_RPATH +AC_MSG_CHECKING([for KDE]) + +if test "${prefix}" != NONE; then + kde_includes=${includedir} + KDE_EXPAND_MAKEVAR(ac_kde_includes, includedir) + + kde_libraries=${libdir} + KDE_EXPAND_MAKEVAR(ac_kde_libraries, libdir) + +else + ac_kde_includes= + ac_kde_libraries= + kde_libraries="" + kde_includes="" +fi + +AC_CACHE_VAL(ac_cv_have_kde, +[#try to guess kde locations + +if test "$kde_qtver" = 1; then + kde_check_header="ksock.h" + kde_check_lib="libkdecore.la" +else + kde_check_header="ksharedptr.h" + kde_check_lib="libkio.la" +fi + +if test -z "$1"; then + +kde_incdirs="/usr/lib/kde/include /usr/local/kde/include /usr/local/include /usr/kde/include /usr/include/kde /usr/include /opt/kde3/include /opt/kde/include $x_includes $qt_includes" +test -n "$KDEDIR" && kde_incdirs="$KDEDIR/include $KDEDIR/include/kde $KDEDIR $kde_incdirs" +kde_incdirs="$ac_kde_includes $kde_incdirs" +AC_FIND_FILE($kde_check_header, $kde_incdirs, kde_incdir) +ac_kde_includes="$kde_incdir" + +if test -n "$ac_kde_includes" && test ! -r "$ac_kde_includes/$kde_check_header"; then + AC_MSG_ERROR([ +in the prefix, you've chosen, are no KDE headers installed. This will fail. +So, check this please and use another prefix!]) +fi + +kde_libdirs="/usr/lib/kde/lib${kdelibsuff} /usr/local/kde/lib${kdelibsuff} /usr/kde/lib${kdelibsuff} /usr/lib${kdelibsuff}/kde /usr/lib${kdelibsuff}/kde3 /usr/lib${kdelibsuff} /usr/X11R6/lib${kdelibsuff} /usr/local/lib${kdelibsuff} /opt/kde3/lib${kdelibsuff} /opt/kde/lib${kdelibsuff} /usr/X11R6/kde/lib${kdelibsuff}" +test -n "$KDEDIR" && kde_libdirs="$KDEDIR/lib${kdelibsuff} $KDEDIR $kde_libdirs" +kde_libdirs="$ac_kde_libraries $libdir $kde_libdirs" +AC_FIND_FILE($kde_check_lib, $kde_libdirs, kde_libdir) +ac_kde_libraries="$kde_libdir" + +kde_widgetdir=NO +dnl this might be somewhere else +AC_FIND_FILE("kde3/plugins/designer/kdewidgets.la", $kde_libdirs, kde_widgetdir) + +if test -n "$ac_kde_libraries" && test ! -r "$ac_kde_libraries/$kde_check_lib"; then +AC_MSG_ERROR([ +in the prefix, you've chosen, are no KDE libraries installed. This will fail. +So, check this please and use another prefix!]) +fi + +if test -n "$kde_widgetdir" && test ! -r "$kde_widgetdir/kde3/plugins/designer/kdewidgets.la"; then +AC_MSG_ERROR([ +I can't find the designer plugins. These are required and should have been installed +by kdelibs]) +fi + +if test -n "$kde_widgetdir"; then + kde_widgetdir="$kde_widgetdir/kde3/plugins/designer" +fi + + +if test "$ac_kde_includes" = NO || test "$ac_kde_libraries" = NO || test "$kde_widgetdir" = NO; then + ac_cv_have_kde="have_kde=no" +else + ac_cv_have_kde="have_kde=yes \ + ac_kde_includes=$ac_kde_includes ac_kde_libraries=$ac_kde_libraries" +fi + +else dnl test -z $1 + + ac_cv_have_kde="have_kde=no" + +fi +])dnl + +eval "$ac_cv_have_kde" + +if test "$have_kde" != "yes"; then + if test "${prefix}" = NONE; then + ac_kde_prefix="$ac_default_prefix" + else + ac_kde_prefix="$prefix" + fi + if test "$exec_prefix" = NONE; then + ac_kde_exec_prefix="$ac_kde_prefix" + AC_MSG_RESULT([will be installed in $ac_kde_prefix]) + else + ac_kde_exec_prefix="$exec_prefix" + AC_MSG_RESULT([will be installed in $ac_kde_prefix and $ac_kde_exec_prefix]) + fi + + kde_libraries="${libdir}" + kde_includes="${includedir}" + +else + ac_cv_have_kde="have_kde=yes \ + ac_kde_includes=$ac_kde_includes ac_kde_libraries=$ac_kde_libraries" + AC_MSG_RESULT([libraries $ac_kde_libraries, headers $ac_kde_includes]) + + kde_libraries="$ac_kde_libraries" + kde_includes="$ac_kde_includes" +fi +AC_SUBST(kde_libraries) +AC_SUBST(kde_includes) + +if test "$kde_includes" = "$x_includes" || test "$kde_includes" = "$qt_includes" || test "$kde_includes" = "/usr/include"; then + KDE_INCLUDES="" +else + KDE_INCLUDES="-I$kde_includes" + all_includes="$KDE_INCLUDES $all_includes" +fi + +KDE_DEFAULT_CXXFLAGS="-DQT_CLEAN_NAMESPACE -DQT_NO_ASCII_CAST -DQT_NO_STL -DQT_NO_COMPAT -DQT_NO_TRANSLATION" + +KDE_LDFLAGS="-L$kde_libraries" +if test ! "$kde_libraries" = "$x_libraries" && test ! "$kde_libraries" = "$qt_libraries" ; then + all_libraries="$all_libraries $KDE_LDFLAGS" +fi + +AC_SUBST(KDE_LDFLAGS) +AC_SUBST(KDE_INCLUDES) + +AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) + +all_libraries="$all_libraries $USER_LDFLAGS" +all_includes="$all_includes $USER_INCLUDES" +AC_SUBST(all_includes) +AC_SUBST(all_libraries) + +if test -z "$1"; then +KDE_CHECK_UIC_PLUGINS +fi + +ac_kde_libraries="$kde_libdir" + +AC_SUBST(AUTODIRS) + + +]) + +AC_DEFUN([KDE_CHECK_EXTRA_LIBS], +[ +AC_MSG_CHECKING(for extra includes) +AC_ARG_WITH(extra-includes,AC_HELP_STRING([--with-extra-includes=DIR],[adds non standard include paths]), + kde_use_extra_includes="$withval", + kde_use_extra_includes=NONE +) +kde_extra_includes= +if test -n "$kde_use_extra_includes" && \ + test "$kde_use_extra_includes" != "NONE"; then + + ac_save_ifs=$IFS + IFS=':' + for dir in $kde_use_extra_includes; do + kde_extra_includes="$kde_extra_includes $dir" + USER_INCLUDES="$USER_INCLUDES -I$dir" + done + IFS=$ac_save_ifs + kde_use_extra_includes="added" +else + kde_use_extra_includes="no" +fi +AC_SUBST(USER_INCLUDES) + +AC_MSG_RESULT($kde_use_extra_includes) + +kde_extra_libs= +AC_MSG_CHECKING(for extra libs) +AC_ARG_WITH(extra-libs,AC_HELP_STRING([--with-extra-libs=DIR],[adds non standard library paths]), + kde_use_extra_libs=$withval, + kde_use_extra_libs=NONE +) +if test -n "$kde_use_extra_libs" && \ + test "$kde_use_extra_libs" != "NONE"; then + + ac_save_ifs=$IFS + IFS=':' + for dir in $kde_use_extra_libs; do + kde_extra_libs="$kde_extra_libs $dir" + KDE_EXTRA_RPATH="$KDE_EXTRA_RPATH -R $dir" + USER_LDFLAGS="$USER_LDFLAGS -L$dir" + done + IFS=$ac_save_ifs + kde_use_extra_libs="added" +else + kde_use_extra_libs="no" +fi + +AC_SUBST(USER_LDFLAGS) + +AC_MSG_RESULT($kde_use_extra_libs) + +]) + +AC_DEFUN([KDE_1_CHECK_PATH_HEADERS], +[ + AC_MSG_CHECKING([for KDE headers installed]) + AC_LANG_SAVE + AC_LANG_CPLUSPLUS +cat > conftest.$ac_ext < +#endif +#include +#include "confdefs.h" +#include + +int main() { + printf("kde_htmldir=\\"%s\\"\n", KApplication::kde_htmldir().data()); + printf("kde_appsdir=\\"%s\\"\n", KApplication::kde_appsdir().data()); + printf("kde_icondir=\\"%s\\"\n", KApplication::kde_icondir().data()); + printf("kde_sounddir=\\"%s\\"\n", KApplication::kde_sounddir().data()); + printf("kde_datadir=\\"%s\\"\n", KApplication::kde_datadir().data()); + printf("kde_locale=\\"%s\\"\n", KApplication::kde_localedir().data()); + printf("kde_cgidir=\\"%s\\"\n", KApplication::kde_cgidir().data()); + printf("kde_confdir=\\"%s\\"\n", KApplication::kde_configdir().data()); + printf("kde_mimedir=\\"%s\\"\n", KApplication::kde_mimedir().data()); + printf("kde_toolbardir=\\"%s\\"\n", KApplication::kde_toolbardir().data()); + printf("kde_wallpaperdir=\\"%s\\"\n", + KApplication::kde_wallpaperdir().data()); + printf("kde_bindir=\\"%s\\"\n", KApplication::kde_bindir().data()); + printf("kde_partsdir=\\"%s\\"\n", KApplication::kde_partsdir().data()); + printf("kde_servicesdir=\\"/tmp/dummy\\"\n"); + printf("kde_servicetypesdir=\\"/tmp/dummy\\"\n"); + printf("kde_moduledir=\\"/tmp/dummy\\"\n"); + printf("kde_styledir=\\"/tmp/dummy\\"\n"); + printf("kde_widgetdir=\\"/tmp/dummy\\"\n"); + printf("xdg_appsdir=\\"/tmp/dummy\\"\n"); + printf("xdg_menudir=\\"/tmp/dummy\\"\n"); + printf("xdg_directorydir=\\"/tmp/dummy\\"\n"); + printf("kde_kcfgdir=\\"/tmp/dummy\\"\n"); + return 0; + } +EOF + + ac_save_CPPFLAGS=$CPPFLAGS + CPPFLAGS="$all_includes $CPPFLAGS" + if AC_TRY_EVAL(ac_compile); then + AC_MSG_RESULT(yes) + else + AC_MSG_ERROR([your system is not able to compile a small KDE application! +Check, if you installed the KDE header files correctly. +For more details about this problem, look at the end of config.log.]) + fi + CPPFLAGS=$ac_save_CPPFLAGS + + AC_LANG_RESTORE +]) + +AC_DEFUN([KDE_CHECK_KDEQTADDON], +[ +AC_MSG_CHECKING(for kde-qt-addon) +AC_CACHE_VAL(kde_cv_have_kdeqtaddon, +[ + kde_ldflags_safe="$LDFLAGS" + kde_libs_safe="$LIBS" + kde_cxxflags_safe="$CXXFLAGS" + + LIBS="-lkde-qt-addon $LIBQT $LIBS" + CXXFLAGS="$CXXFLAGS -I$prefix/include -I$prefix/include/kde $all_includes" + LDFLAGS="$LDFLAGS $all_libraries $USER_LDFLAGS" + + AC_TRY_LINK([ + #include + ], + [ + QDomDocument doc; + ], + kde_cv_have_kdeqtaddon=yes, + kde_cv_have_kdeqtaddon=no + ) + + LDFLAGS=$kde_ldflags_safe + LIBS=$kde_libs_safe + CXXFLAGS=$kde_cxxflags_safe +]) + +AC_MSG_RESULT($kde_cv_have_kdeqtaddon) + +if test "$kde_cv_have_kdeqtaddon" = "no"; then + AC_MSG_ERROR([Can't find libkde-qt-addon. You need to install it first. +It is a separate package (and CVS module) named kde-qt-addon.]) +fi +]) + +AC_DEFUN([KDE_CREATE_LIBS_ALIASES], +[ + AC_REQUIRE([KDE_MISC_TESTS]) + AC_REQUIRE([KDE_CHECK_LIBDL]) + AC_REQUIRE([K_PATH_X]) + +if test $kde_qtver = 3; then + AC_SUBST(LIB_KDECORE, "-lkdecore") + AC_SUBST(LIB_KDEUI, "-lkdeui") + AC_SUBST(LIB_KIO, "-lkio") + AC_SUBST(LIB_SMB, "-lsmb") + AC_SUBST(LIB_KAB, "-lkab") + AC_SUBST(LIB_KABC, "-lkabc") + AC_SUBST(LIB_KHTML, "-lkhtml") + AC_SUBST(LIB_KSPELL, "-lkspell") + AC_SUBST(LIB_KPARTS, "-lkparts") + AC_SUBST(LIB_KDEPRINT, "-lkdeprint") + AC_SUBST(LIB_KUTILS, "-lkutils") + AC_SUBST(LIB_KDEPIM, "-lkdepim") +# these are for backward compatibility + AC_SUBST(LIB_KSYCOCA, "-lkio") + AC_SUBST(LIB_KFILE, "-lkio") +elif test $kde_qtver = 2; then + AC_SUBST(LIB_KDECORE, "-lkdecore") + AC_SUBST(LIB_KDEUI, "-lkdeui") + AC_SUBST(LIB_KIO, "-lkio") + AC_SUBST(LIB_KSYCOCA, "-lksycoca") + AC_SUBST(LIB_SMB, "-lsmb") + AC_SUBST(LIB_KFILE, "-lkfile") + AC_SUBST(LIB_KAB, "-lkab") + AC_SUBST(LIB_KHTML, "-lkhtml") + AC_SUBST(LIB_KSPELL, "-lkspell") + AC_SUBST(LIB_KPARTS, "-lkparts") + AC_SUBST(LIB_KDEPRINT, "-lkdeprint") +else + AC_SUBST(LIB_KDECORE, "-lkdecore -lXext $(LIB_QT)") + AC_SUBST(LIB_KDEUI, "-lkdeui $(LIB_KDECORE)") + AC_SUBST(LIB_KFM, "-lkfm $(LIB_KDECORE)") + AC_SUBST(LIB_KFILE, "-lkfile $(LIB_KFM) $(LIB_KDEUI)") + AC_SUBST(LIB_KAB, "-lkab $(LIB_KIMGIO) $(LIB_KDECORE)") +fi +]) + +AC_DEFUN([AC_PATH_KDE], +[ + AC_BASE_PATH_KDE + AC_ARG_ENABLE(path-check,AC_HELP_STRING([--disable-path-check],[don't try to find out, where to install]), + [ + if test "$enableval" = "no"; + then ac_use_path_checking="default" + else ac_use_path_checking="" + fi + ], + [ + if test "$kde_qtver" = 1; + then ac_use_path_checking="" + else ac_use_path_checking="default" + fi + ] + ) + + AC_CREATE_KFSSTND($ac_use_path_checking) + + AC_SUBST_KFSSTND + KDE_CREATE_LIBS_ALIASES +]) + +dnl KDE_CHECK_FUNC_EXT(, [headers], [sample-use], [C prototype], [autoheader define], [call if found]) +AC_DEFUN([KDE_CHECK_FUNC_EXT], +[ +AC_MSG_CHECKING(for $1) +AC_CACHE_VAL(kde_cv_func_$1, +[ +AC_LANG_SAVE +AC_LANG_CPLUSPLUS +save_CXXFLAGS="$CXXFLAGS" +kde_safe_LIBS="$LIBS" +LIBS="$LIBS $X_EXTRA_LIBS" +if test "$GXX" = "yes"; then +CXXFLAGS="$CXXFLAGS -pedantic-errors" +fi +AC_TRY_COMPILE([ +$2 +], +[ +$3 +], +kde_cv_func_$1=yes, +kde_cv_func_$1=no) +CXXFLAGS="$save_CXXFLAGS" +LIBS="$kde_safe_LIBS" +AC_LANG_RESTORE +]) + +AC_MSG_RESULT($kde_cv_func_$1) + +AC_MSG_CHECKING([if $1 needs custom prototype]) +AC_CACHE_VAL(kde_cv_proto_$1, +[ +if test "x$kde_cv_func_$1" = xyes; then + kde_cv_proto_$1=no +else + case "$1" in + setenv|unsetenv|usleep|random|srandom|seteuid|mkstemps|mkstemp|revoke|vsnprintf|strlcpy|strlcat) + kde_cv_proto_$1="yes - in libkdefakes" + ;; + *) + kde_cv_proto_$1=unknown + ;; + esac +fi + +if test "x$kde_cv_proto_$1" = xunknown; then + +AC_LANG_SAVE +AC_LANG_CPLUSPLUS + kde_safe_libs=$LIBS + LIBS="$LIBS $X_EXTRA_LIBS" + AC_TRY_LINK([ +$2 + +extern "C" $4; +], +[ +$3 +], +[ kde_cv_func_$1=yes + kde_cv_proto_$1=yes ], + [kde_cv_proto_$1="$1 unavailable"] +) +LIBS=$kde_safe_libs +AC_LANG_RESTORE +fi +]) +AC_MSG_RESULT($kde_cv_proto_$1) + +if test "x$kde_cv_func_$1" = xyes; then + AC_DEFINE(HAVE_$5, 1, [Define if you have $1]) + $6 +fi +if test "x$kde_cv_proto_$1" = xno; then + AC_DEFINE(HAVE_$5_PROTO, 1, + [Define if you have the $1 prototype]) +fi + +AH_VERBATIM([_HAVE_$5_PROTO], +[ +#if !defined(HAVE_$5_PROTO) +#ifdef __cplusplus +extern "C" { +#endif +$4; +#ifdef __cplusplus +} +#endif +#endif +]) +]) + +AC_DEFUN([AC_CHECK_SETENV], +[ + KDE_CHECK_FUNC_EXT(setenv, [ +#include +], + [setenv("VAR", "VALUE", 1);], + [int setenv (const char *, const char *, int)], + [SETENV]) +]) + +AC_DEFUN([AC_CHECK_UNSETENV], +[ + KDE_CHECK_FUNC_EXT(unsetenv, [ +#include +], + [unsetenv("VAR");], + [void unsetenv (const char *)], + [UNSETENV]) +]) + +AC_DEFUN([AC_CHECK_GETDOMAINNAME], +[ + KDE_CHECK_FUNC_EXT(getdomainname, [ +#include +#include +#include +], + [ +char buffer[200]; +getdomainname(buffer, 200); +], + [#include + int getdomainname (char *, size_t)], + [GETDOMAINNAME]) +]) + +AC_DEFUN([AC_CHECK_GETHOSTNAME], +[ + KDE_CHECK_FUNC_EXT(gethostname, [ +#include +#include +], + [ +char buffer[200]; +gethostname(buffer, 200); +], + [int gethostname (char *, unsigned int)], + [GETHOSTNAME]) +]) + +AC_DEFUN([AC_CHECK_USLEEP], +[ + KDE_CHECK_FUNC_EXT(usleep, [ +#include +], + [ +usleep(200); +], + [int usleep (unsigned int)], + [USLEEP]) +]) + + +AC_DEFUN([AC_CHECK_RANDOM], +[ + KDE_CHECK_FUNC_EXT(random, [ +#include +], + [ +random(); +], + [long int random(void)], + [RANDOM]) + + KDE_CHECK_FUNC_EXT(srandom, [ +#include +], + [ +srandom(27); +], + [void srandom(unsigned int)], + [SRANDOM]) + +]) + +AC_DEFUN([AC_CHECK_INITGROUPS], +[ + KDE_CHECK_FUNC_EXT(initgroups, [ +#include +#include +#include +], + [ +char buffer[200]; +initgroups(buffer, 27); +], + [int initgroups(const char *, gid_t)], + [INITGROUPS]) +]) + +AC_DEFUN([AC_CHECK_MKSTEMPS], +[ + KDE_CHECK_FUNC_EXT(mkstemps, [ +#include +#include +], + [ +mkstemps("/tmp/aaaXXXXXX", 6); +], + [int mkstemps(char *, int)], + [MKSTEMPS]) +]) + +AC_DEFUN([AC_CHECK_MKDTEMP], +[ + KDE_CHECK_FUNC_EXT(mkdtemp, [ +#include +#include +], + [ +mkdtemp("/tmp/aaaXXXXXX"); +], + [char *mkdtemp(char *)], + [MKDTEMP]) +]) + + +AC_DEFUN([AC_CHECK_RES_INIT], +[ + AC_MSG_CHECKING([if res_init needs -lresolv]) + kde_libs_safe="$LIBS" + LIBS="$LIBS $X_EXTRA_LIBS -lresolv" + AC_TRY_LINK( + [ +#include +#include +#include +#include + ], + [ + res_init(); + ], + [ + LIBRESOLV="-lresolv" + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_RES_INIT, 1, [Define if you have the res_init function]) + ], + [ AC_MSG_RESULT(no) ] + ) + LIBS=$kde_libs_safe + AC_SUBST(LIBRESOLV) + + AC_MSG_CHECKING([if res_init is available]) + AC_TRY_COMPILE( + [ +#include +#include +#include +#include + ], + [ + res_init(); + ], + [ + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_RES_INIT, 1, [Define if you have the res_init function]) + ], + [ AC_MSG_RESULT(no) ] + ) +]) + +AC_DEFUN([AC_CHECK_STRLCPY], +[ + KDE_CHECK_FUNC_EXT(strlcpy, [ +#include +], +[ char buf[20]; + strlcpy(buf, "KDE function test", sizeof(buf)); +], + [unsigned long strlcpy(char*, const char*, unsigned long)], + [STRLCPY]) +]) + +AC_DEFUN([AC_CHECK_STRLCAT], +[ + KDE_CHECK_FUNC_EXT(strlcat, [ +#include +], +[ char buf[20]; + buf[0]='\0'; + strlcat(buf, "KDE function test", sizeof(buf)); +], + [unsigned long strlcat(char*, const char*, unsigned long)], + [STRLCAT]) +]) + +AC_DEFUN([AC_FIND_GIF], + [AC_MSG_CHECKING([for giflib]) +AC_CACHE_VAL(ac_cv_lib_gif, +[ac_save_LIBS="$LIBS" +if test "x$kde_use_qt_emb" != "xyes" && test "x$kde_use_qt_mac" != "xyes"; then +LIBS="$all_libraries -lgif -lX11 $LIBSOCKET" +else +LIBS="$all_libraries -lgif" +fi +AC_TRY_LINK(dnl +[ +#ifdef __cplusplus +extern "C" { +#endif +int GifLastError(void); +#ifdef __cplusplus +} +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +], + [return GifLastError();], + eval "ac_cv_lib_gif=yes", + eval "ac_cv_lib_gif=no") +LIBS="$ac_save_LIBS" +])dnl +if eval "test \"`echo $ac_cv_lib_gif`\" = yes"; then + AC_MSG_RESULT(yes) + AC_DEFINE_UNQUOTED(HAVE_LIBGIF, 1, [Define if you have libgif]) +else + AC_MSG_ERROR(You need giflib30. Please install the kdesupport package) +fi +]) + +AC_DEFUN([KDE_FIND_JPEG_HELPER], +[ +AC_MSG_CHECKING([for libjpeg$2]) +AC_CACHE_VAL(ac_cv_lib_jpeg_$1, +[ +ac_save_LIBS="$LIBS" +LIBS="$all_libraries $USER_LDFLAGS -ljpeg$2 -lm" +ac_save_CFLAGS="$CFLAGS" +CFLAGS="$CFLAGS $all_includes $USER_INCLUDES" +AC_TRY_LINK( +[/* Override any gcc2 internal prototype to avoid an error. */ +struct jpeg_decompress_struct; +typedef struct jpeg_decompress_struct * j_decompress_ptr; +typedef int size_t; +#ifdef __cplusplus +extern "C" { +#endif + void jpeg_CreateDecompress(j_decompress_ptr cinfo, + int version, size_t structsize); +#ifdef __cplusplus +} +#endif +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +], + [jpeg_CreateDecompress(0L, 0, 0);], + eval "ac_cv_lib_jpeg_$1=-ljpeg$2", + eval "ac_cv_lib_jpeg_$1=no") +LIBS="$ac_save_LIBS" +CFLAGS="$ac_save_CFLAGS" +]) + +if eval "test ! \"`echo $ac_cv_lib_jpeg_$1`\" = no"; then + LIBJPEG="$ac_cv_lib_jpeg_$1" + AC_MSG_RESULT($ac_cv_lib_jpeg_$1) +else + AC_MSG_RESULT(no) + $3 +fi + +]) + +AC_DEFUN([AC_FIND_JPEG], +[ +dnl first look for libraries +KDE_FIND_JPEG_HELPER(6b, 6b, + KDE_FIND_JPEG_HELPER(normal, [], + [ + LIBJPEG= + ] + ) +) + +dnl then search the headers (can't use simply AC_TRY_xxx, as jpeglib.h +dnl requires system dependent includes loaded before it) +jpeg_incdirs="$includedir /usr/include /usr/local/include $kde_extra_includes" +AC_FIND_FILE(jpeglib.h, $jpeg_incdirs, jpeg_incdir) +test "x$jpeg_incdir" = xNO && jpeg_incdir= + +dnl if headers _and_ libraries are missing, this is no error, and we +dnl continue with a warning (the user will get no jpeg support in khtml) +dnl if only one is missing, it means a configuration error, but we still +dnl only warn +if test -n "$jpeg_incdir" && test -n "$LIBJPEG" ; then + AC_DEFINE_UNQUOTED(HAVE_LIBJPEG, 1, [Define if you have libjpeg]) +else + if test -n "$jpeg_incdir" || test -n "$LIBJPEG" ; then + AC_MSG_WARN([ +There is an installation error in jpeg support. You seem to have only one +of either the headers _or_ the libraries installed. You may need to either +provide correct --with-extra-... options, or the development package of +libjpeg6b. You can get a source package of libjpeg from http://www.ijg.org/ +Disabling JPEG support. +]) + else + AC_MSG_WARN([libjpeg not found. disable JPEG support.]) + fi + jpeg_incdir= + LIBJPEG= +fi + +AC_SUBST(LIBJPEG) +AH_VERBATIM(_AC_CHECK_JPEG, +[/* + * jpeg.h needs HAVE_BOOLEAN, when the system uses boolean in system + * headers and I'm too lazy to write a configure test as long as only + * unixware is related + */ +#ifdef _UNIXWARE +#define HAVE_BOOLEAN +#endif +]) +]) + +AC_DEFUN([KDE_CHECK_QT_JPEG], +[ +if test -n "$LIBJPEG"; then +AC_MSG_CHECKING([if Qt needs $LIBJPEG]) +AC_CACHE_VAL(kde_cv_qt_jpeg, +[ +AC_LANG_SAVE +AC_LANG_CPLUSPLUS +ac_save_LIBS="$LIBS" +LIBS="$all_libraries $USER_LDFLAGS $LIBQT" +LIBS=`echo $LIBS | sed "s/$LIBJPEG//"` +ac_save_CXXFLAGS="$CXXFLAGS" +CXXFLAGS="$CXXFLAGS $all_includes $USER_INCLUDES" +AC_TRY_LINK( +[#include ], + [ + int argc; + char** argv; + QApplication app(argc, argv);], + eval "kde_cv_qt_jpeg=no", + eval "kde_cv_qt_jpeg=yes") +LIBS="$ac_save_LIBS" +CXXFLAGS="$ac_save_CXXFLAGS" +AC_LANG_RESTORE +fi +]) + +if eval "test ! \"`echo $kde_cv_qt_jpeg`\" = no"; then + AC_MSG_RESULT(yes) + LIBJPEG_QT='$(LIBJPEG)' +else + AC_MSG_RESULT(no) + LIBJPEG_QT= +fi + +]) + +AC_DEFUN([AC_FIND_ZLIB], +[ +AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) +AC_MSG_CHECKING([for libz]) +AC_CACHE_VAL(ac_cv_lib_z, +[ +kde_save_LIBS="$LIBS" +LIBS="$all_libraries $USER_LDFLAGS -lz $LIBSOCKET" +kde_save_CFLAGS="$CFLAGS" +CFLAGS="$CFLAGS $all_includes $USER_INCLUDES" +AC_TRY_LINK(dnl +[ +#include +], +[ + char buf[42]; + gzFile f = (gzFile) 0; + /* this would segfault.. but we only link, don't run */ + (void) gzgets(f, buf, sizeof(buf)); + + return (zlibVersion() == ZLIB_VERSION); +], + eval "ac_cv_lib_z='-lz'", + eval "ac_cv_lib_z=no") +LIBS="$kde_save_LIBS" +CFLAGS="$kde_save_CFLAGS" +])dnl +if test ! "$ac_cv_lib_z" = no; then + AC_DEFINE_UNQUOTED(HAVE_LIBZ, 1, [Define if you have libz]) + LIBZ="$ac_cv_lib_z" + AC_MSG_RESULT($ac_cv_lib_z) +else + AC_MSG_ERROR(not found. + Possibly configure picks up an outdated version + installed by XFree86. Remove it from your system. + + Check your installation and look into config.log) + LIBZ="" +fi +AC_SUBST(LIBZ) +]) + +AC_DEFUN([KDE_TRY_TIFFLIB], +[ +AC_MSG_CHECKING([for libtiff $1]) + +AC_CACHE_VAL(kde_cv_libtiff_$1, +[ +AC_LANG_SAVE +AC_LANG_CPLUSPLUS +kde_save_LIBS="$LIBS" +if test "x$kde_use_qt_emb" != "xyes" && test "x$kde_use_qt_mac" != "xyes"; then +LIBS="$all_libraries $USER_LDFLAGS -l$1 $LIBJPEG $LIBZ -lX11 $LIBSOCKET -lm" +else +LIBS="$all_libraries $USER_LDFLAGS -l$1 $LIBJPEG $LIBZ -lm" +fi +kde_save_CXXFLAGS="$CXXFLAGS" +CXXFLAGS="$CXXFLAGS $all_includes $USER_INCLUDES" + +AC_TRY_LINK(dnl +[ +#include +], + [return (TIFFOpen( "", "r") == 0); ], +[ + kde_cv_libtiff_$1="-l$1 $LIBJPEG $LIBZ" +], [ + kde_cv_libtiff_$1=no +]) + +LIBS="$kde_save_LIBS" +CXXFLAGS="$kde_save_CXXFLAGS" +AC_LANG_RESTORE +]) + +if test "$kde_cv_libtiff_$1" = "no"; then + AC_MSG_RESULT(no) + LIBTIFF="" + $3 +else + LIBTIFF="$kde_cv_libtiff_$1" + AC_MSG_RESULT(yes) + AC_DEFINE_UNQUOTED(HAVE_LIBTIFF, 1, [Define if you have libtiff]) + $2 +fi + +]) + +AC_DEFUN([AC_FIND_TIFF], +[ +AC_REQUIRE([K_PATH_X]) +AC_REQUIRE([AC_FIND_ZLIB]) +AC_REQUIRE([AC_FIND_JPEG]) +AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) + +KDE_TRY_TIFFLIB(tiff, [], + KDE_TRY_TIFFLIB(tiff34)) + +AC_SUBST(LIBTIFF) +]) + + +AC_DEFUN([AC_FIND_PNG], +[ +AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) +AC_REQUIRE([AC_FIND_ZLIB]) +AC_MSG_CHECKING([for libpng]) +AC_CACHE_VAL(ac_cv_lib_png, +[ +kde_save_LIBS="$LIBS" +if test "x$kde_use_qt_emb" != "xyes" && test "x$kde_use_qt_mac" != "xyes"; then +LIBS="$LIBS $all_libraries $USER_LDFLAGS -lpng $LIBZ -lm -lX11 $LIBSOCKET" +else +LIBS="$LIBS $all_libraries $USER_LDFLAGS -lpng $LIBZ -lm" +fi +kde_save_CFLAGS="$CFLAGS" +CFLAGS="$CFLAGS $all_includes $USER_INCLUDES" + +AC_TRY_LINK(dnl + [ + #include + ], + [ + png_structp png_ptr = png_create_read_struct( /* image ptr */ + PNG_LIBPNG_VER_STRING, 0, 0, 0 ); + return( png_ptr != 0 ); + ], + eval "ac_cv_lib_png='-lpng $LIBZ -lm'", + eval "ac_cv_lib_png=no" +) +LIBS="$kde_save_LIBS" +CFLAGS="$kde_save_CFLAGS" +])dnl +if eval "test ! \"`echo $ac_cv_lib_png`\" = no"; then + AC_DEFINE_UNQUOTED(HAVE_LIBPNG, 1, [Define if you have libpng]) + LIBPNG="$ac_cv_lib_png" + AC_SUBST(LIBPNG) + AC_MSG_RESULT($ac_cv_lib_png) +else + AC_MSG_RESULT(no) + LIBPNG="" + AC_SUBST(LIBPNG) +fi +]) + + +AC_DEFUN([AC_FIND_JASPER], +[ +AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) +AC_REQUIRE([AC_FIND_JPEG]) +AC_MSG_CHECKING([for jasper]) +AC_CACHE_VAL(ac_cv_jasper, +[ +kde_save_LIBS="$LIBS" +LIBS="$LIBS $all_libraries $USER_LDFLAGS -ljasper $LIBJPEG -lm" +kde_save_CFLAGS="$CFLAGS" +CFLAGS="$CFLAGS $all_includes $USER_INCLUDES" + +AC_TRY_LINK(dnl + [ + #include + ], + [ + return( jas_init() ); + ], + eval "ac_cv_jasper='-ljasper $LIBJPEG -lm'", + eval "ac_cv_jasper=no" +) +LIBS="$kde_save_LIBS" +CFLAGS="$kde_save_CFLAGS" +])dnl +if eval "test ! \"`echo $ac_cv_jasper`\" = no"; then + AC_DEFINE_UNQUOTED(HAVE_JASPER, 1, [Define if you have jasper]) + LIB_JASPER="$ac_cv_jasper" + AC_MSG_RESULT($ac_cv_jasper) +else + AC_MSG_RESULT(no) + LIB_JASPER="" +fi +AC_SUBST(LIB_JASPER) +]) + +AC_DEFUN([AC_CHECK_BOOL], +[ + AC_DEFINE_UNQUOTED(HAVE_BOOL, 1, [You _must_ have bool]) +]) + +AC_DEFUN([AC_CHECK_GNU_EXTENSIONS], +[ +AC_MSG_CHECKING(if you need GNU extensions) +AC_CACHE_VAL(ac_cv_gnu_extensions, +[ +cat > conftest.c << EOF +#include + +#ifdef __GNU_LIBRARY__ +yes +#endif +EOF + +if (eval "$ac_cpp conftest.c") 2>&5 | + egrep "yes" >/dev/null 2>&1; then + rm -rf conftest* + ac_cv_gnu_extensions=yes +else + ac_cv_gnu_extensions=no +fi +]) + +AC_MSG_RESULT($ac_cv_gnu_extensions) +if test "$ac_cv_gnu_extensions" = "yes"; then + AC_DEFINE_UNQUOTED(_GNU_SOURCE, 1, [Define if you need to use the GNU extensions]) +fi +]) + +AC_DEFUN([KDE_CHECK_COMPILER_FLAG], +[ +AC_MSG_CHECKING([whether $CXX supports -$1]) +kde_cache=`echo $1 | sed 'y% .=/+-,%____p__%'` +AC_CACHE_VAL(kde_cv_prog_cxx_$kde_cache, +[ + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + save_CXXFLAGS="$CXXFLAGS" + CXXFLAGS="$CXXFLAGS -$1" + AC_TRY_LINK([],[ return 0; ], [eval "kde_cv_prog_cxx_$kde_cache=yes"], []) + CXXFLAGS="$save_CXXFLAGS" + AC_LANG_RESTORE +]) +if eval "test \"`echo '$kde_cv_prog_cxx_'$kde_cache`\" = yes"; then + AC_MSG_RESULT(yes) + : + $2 +else + AC_MSG_RESULT(no) + : + $3 +fi +]) + +dnl AC_REMOVE_FORBIDDEN removes forbidden arguments from variables +dnl use: AC_REMOVE_FORBIDDEN(CC, [-forbid -bad-option whatever]) +dnl it's all white-space separated +AC_DEFUN([AC_REMOVE_FORBIDDEN], +[ __val=$$1 + __forbid=" $2 " + if test -n "$__val"; then + __new="" + ac_save_IFS=$IFS + IFS=" " + for i in $__val; do + case "$__forbid" in + *" $i "*) AC_MSG_WARN([found forbidden $i in $1, removing it]) ;; + *) # Careful to not add spaces, where there were none, because otherwise + # libtool gets confused, if we change e.g. CXX + if test -z "$__new" ; then __new=$i ; else __new="$__new $i" ; fi ;; + esac + done + IFS=$ac_save_IFS + $1=$__new + fi +]) + +dnl AC_VALIDIFY_CXXFLAGS checks for forbidden flags the user may have given +AC_DEFUN([AC_VALIDIFY_CXXFLAGS], +[dnl +if test "x$kde_use_qt_emb" != "xyes"; then + AC_REMOVE_FORBIDDEN(CXX, [-fno-rtti -rpath]) + AC_REMOVE_FORBIDDEN(CXXFLAGS, [-fno-rtti -rpath]) +else + AC_REMOVE_FORBIDDEN(CXX, [-rpath]) + AC_REMOVE_FORBIDDEN(CXXFLAGS, [-rpath]) +fi +]) + +AC_DEFUN([AC_CHECK_COMPILERS], +[ + AC_ARG_ENABLE(debug, + AC_HELP_STRING([--enable-debug=ARG],[enables debug symbols (yes|no|full) [default=no]]), + [ + case $enableval in + yes) + kde_use_debug_code="yes" + kde_use_debug_define=no + ;; + full) + kde_use_debug_code="full" + kde_use_debug_define=no + ;; + *) + kde_use_debug_code="no" + kde_use_debug_define=yes + ;; + esac + ], + [kde_use_debug_code="no" + kde_use_debug_define=no + ]) + + dnl Just for configure --help + AC_ARG_ENABLE(dummyoption, + AC_HELP_STRING([--disable-debug], + [disables debug output and debug symbols [default=no]]), + [],[]) + + AC_ARG_ENABLE(strict, + AC_HELP_STRING([--enable-strict], + [compiles with strict compiler options (may not work!)]), + [ + if test $enableval = "no"; then + kde_use_strict_options="no" + else + kde_use_strict_options="yes" + fi + ], [kde_use_strict_options="no"]) + + AC_ARG_ENABLE(warnings,AC_HELP_STRING([--disable-warnings],[disables compilation with -Wall and similiar]), + [ + if test $enableval = "no"; then + kde_use_warnings="no" + else + kde_use_warnings="yes" + fi + ], [kde_use_warnings="yes"]) + + dnl enable warnings for debug build + if test "$kde_use_debug_code" != "no"; then + kde_use_warnings=yes + fi + + AC_ARG_ENABLE(profile,AC_HELP_STRING([--enable-profile],[creates profiling infos [default=no]]), + [kde_use_profiling=$enableval], + [kde_use_profiling="no"] + ) + + dnl this prevents stupid AC_PROG_CC to add "-g" to the default CFLAGS + CFLAGS=" $CFLAGS" + + AC_PROG_CC + + AC_PROG_CPP + + if test "$GCC" = "yes"; then + if test "$kde_use_debug_code" != "no"; then + if test $kde_use_debug_code = "full"; then + CFLAGS="-g3 -fno-inline $CFLAGS" + else + CFLAGS="-g -O2 $CFLAGS" + fi + else + CFLAGS="-O2 $CFLAGS" + fi + fi + + if test "$kde_use_debug_define" = "yes"; then + CFLAGS="-DNDEBUG $CFLAGS" + fi + + + case "$host" in + *-*-sysv4.2uw*) CFLAGS="-D_UNIXWARE $CFLAGS";; + *-*-sysv5uw7*) CFLAGS="-D_UNIXWARE7 $CFLAGS";; + esac + + if test -z "$LDFLAGS" && test "$kde_use_debug_code" = "no" && test "$GCC" = "yes"; then + LDFLAGS="" + fi + + CXXFLAGS=" $CXXFLAGS" + + AC_PROG_CXX + + if test "$GXX" = "yes" || test "$CXX" = "KCC"; then + if test "$kde_use_debug_code" != "no"; then + if test "$CXX" = "KCC"; then + CXXFLAGS="+K0 -Wall -pedantic -W -Wpointer-arith -Wwrite-strings $CXXFLAGS" + else + if test "$kde_use_debug_code" = "full"; then + CXXFLAGS="-g3 -fno-inline $CXXFLAGS" + else + CXXFLAGS="-g -O2 $CXXFLAGS" + fi + fi + KDE_CHECK_COMPILER_FLAG(fno-builtin,[CXXFLAGS="-fno-builtin $CXXFLAGS"]) + + dnl convenience compiler flags + KDE_CHECK_COMPILER_FLAG(Woverloaded-virtual, [WOVERLOADED_VIRTUAL="-Woverloaded-virtual"], [WOVERLOADED_VRITUAL=""]) + AC_SUBST(WOVERLOADED_VIRTUAL) + else + if test "$CXX" = "KCC"; then + CXXFLAGS="+K3 $CXXFLAGS" + else + CXXFLAGS="-O2 $CXXFLAGS" + fi + fi + fi + + if test "$kde_use_debug_define" = "yes"; then + CXXFLAGS="-DNDEBUG -DNO_DEBUG $CXXFLAGS" + fi + + if test "$kde_use_profiling" = "yes"; then + KDE_CHECK_COMPILER_FLAG(pg, + [ + CFLAGS="-pg $CFLAGS" + CXXFLAGS="-pg $CXXFLAGS" + ]) + fi + + if test "$kde_use_warnings" = "yes"; then + if test "$GCC" = "yes"; then + case $host in + *-*-linux-gnu) + CFLAGS="-ansi -W -Wall -Wchar-subscripts -Wshadow -Wpointer-arith -Wmissing-prototypes -Wwrite-strings -D_XOPEN_SOURCE=500 -D_BSD_SOURCE $CFLAGS" + CXXFLAGS="-ansi -D_XOPEN_SOURCE=500 -D_BSD_SOURCE -Wcast-align -Wconversion -Wchar-subscripts $CXXFLAGS" + KDE_CHECK_COMPILER_FLAG(Wmissing-format-attribute, [CXXFLAGS="$CXXFLAGS -Wformat-security -Wmissing-format-attribute"; CFLAGS="$CFLAGS -Wformat-security -Wmissing-format-attribute"]) + ;; + esac + CXXFLAGS="-Wall -W -Wpointer-arith -Wwrite-strings $CXXFLAGS" + KDE_CHECK_COMPILER_FLAG(Wundef,[CXXFLAGS="-Wundef $CXXFLAGS"]) + KDE_CHECK_COMPILER_FLAG(Wno-long-long,[CXXFLAGS="-Wno-long-long $CXXFLAGS"]) + KDE_CHECK_COMPILER_FLAG(Wnon-virtual-dtor,[CXXFLAGS="-Wnon-virtual-dtor $CXXFLAGS"]) + fi + fi + + if test "$GXX" = "yes" && test "$kde_use_strict_options" = "yes"; then + CXXFLAGS="-Wcast-qual -Wshadow -Wcast-align $CXXFLAGS" + fi + + if test "$GXX" = "yes"; then + KDE_CHECK_COMPILER_FLAG(fno-exceptions,[CXXFLAGS="$CXXFLAGS -fno-exceptions"]) + KDE_CHECK_COMPILER_FLAG(fno-check-new, [CXXFLAGS="$CXXFLAGS -fno-check-new"]) + KDE_CHECK_COMPILER_FLAG(fno-common, [CXXFLAGS="$CXXFLAGS -fno-common"]) + KDE_CHECK_COMPILER_FLAG(fexceptions, [USE_EXCEPTIONS="-fexceptions"], USE_EXCEPTIONS= ) + fi + if test "$CXX" = "KCC"; then + dnl unfortunately we currently cannot disable exception support in KCC + dnl because doing so is binary incompatible and Qt by default links with exceptions :-( + dnl KDE_CHECK_COMPILER_FLAG(-no_exceptions,[CXXFLAGS="$CXXFLAGS --no_exceptions"]) + dnl KDE_CHECK_COMPILER_FLAG(-exceptions, [USE_EXCEPTIONS="--exceptions"], USE_EXCEPTIONS= ) + + AC_ARG_ENABLE(pch, + AC_HELP_STRING([--enable-pch], + [enables precompiled header support (currently only KCC) [default=no]]), + [ + kde_use_pch=$enableval + ],[kde_use_pch=no]) + + if test "$kde_use_pch" = "yes"; then + dnl TODO: support --pch-dir! + KDE_CHECK_COMPILER_FLAG(-pch,[CXXFLAGS="$CXXFLAGS --pch"]) + dnl the below works (but the dir must exist), but it's + dnl useless for a whole package. + dnl The are precompiled headers for each source file, so when compiling + dnl from scratch, it doesn't make a difference, and they take up + dnl around ~5Mb _per_ sourcefile. + dnl KDE_CHECK_COMPILER_FLAG(-pch_dir /tmp, + dnl [CXXFLAGS="$CXXFLAGS --pch_dir `pwd`/pcheaders"]) + fi + dnl this flag controls inlining. by default KCC inlines in optimisation mode + dnl all implementations that are defined inside the class {} declaration. + dnl because of templates-compatibility with broken gcc compilers, this + dnl can cause excessive inlining. This flag limits it to a sane level + KDE_CHECK_COMPILER_FLAG(-inline_keyword_space_time=6,[CXXFLAGS="$CXXFLAGS --inline_keyword_space_time=6"]) + KDE_CHECK_COMPILER_FLAG(-inline_auto_space_time=2,[CXXFLAGS="$CXXFLAGS --inline_auto_space_time=2"]) + KDE_CHECK_COMPILER_FLAG(-inline_implicit_space_time=2.0,[CXXFLAGS="$CXXFLAGS --inline_implicit_space_time=2.0"]) + KDE_CHECK_COMPILER_FLAG(-inline_generated_space_time=2.0,[CXXFLAGS="$CXXFLAGS --inline_generated_space_time=2.0"]) + dnl Some source files are shared between multiple executables + dnl (or libraries) and some of those need template instantiations. + dnl In that case KCC needs to compile those sources with + dnl --one_instantiation_per_object. To make it easy for us we compile + dnl _all_ objects with that flag (--one_per is a shorthand). + KDE_CHECK_COMPILER_FLAG(-one_per, [CXXFLAGS="$CXXFLAGS --one_per"]) + fi + AC_SUBST(USE_EXCEPTIONS) + dnl obsolete macro - provided to keep things going + USE_RTTI= + AC_SUBST(USE_RTTI) + + case "$host" in + *-*-irix*) test "$GXX" = yes && CXXFLAGS="-D_LANGUAGE_C_PLUS_PLUS -D__LANGUAGE_C_PLUS_PLUS $CXXFLAGS" ;; + *-*-sysv4.2uw*) CXXFLAGS="-D_UNIXWARE $CXXFLAGS";; + *-*-sysv5uw7*) CXXFLAGS="-D_UNIXWARE7 $CXXFLAGS";; + *-*-solaris*) + if test "$GXX" = yes; then + libstdcpp=`$CXX -print-file-name=libstdc++.so` + if test ! -f $libstdcpp; then + AC_MSG_ERROR([You've compiled gcc without --enable-shared. This doesn't work with KDE. Please recompile gcc with --enable-shared to receive a libstdc++.so]) + fi + fi + ;; + esac + + AC_VALIDIFY_CXXFLAGS + + AC_PROG_CXXCPP + + if test "$GCC" = yes; then + NOOPT_CFLAGS=-O0 + fi + KDE_CHECK_COMPILER_FLAG(O0,[NOOPT_CXXFLAGS=-O0]) + + AC_SUBST(NOOPT_CXXFLAGS) + AC_SUBST(NOOPT_CFLAGS) + + KDE_CHECK_FINAL + KDE_CHECK_CLOSURE + KDE_CHECK_NMCHECK + + ifdef([AM_DEPENDENCIES], AC_REQUIRE([KDE_ADD_DEPENDENCIES]), []) +]) + +AC_DEFUN([KDE_ADD_DEPENDENCIES], +[ + [A]M_DEPENDENCIES(CC) + [A]M_DEPENDENCIES(CXX) +]) + +dnl just a wrapper to clean up configure.in +AC_DEFUN([KDE_PROG_LIBTOOL], +[ +AC_REQUIRE([AC_CHECK_COMPILERS]) +AC_REQUIRE([AC_ENABLE_SHARED]) +AC_REQUIRE([AC_ENABLE_STATIC]) + +AC_REQUIRE([AC_LIBTOOL_DLOPEN]) +AC_REQUIRE([KDE_CHECK_LIB64]) + +AC_OBJEXT +AC_EXEEXT + +AM_PROG_LIBTOOL +AC_LIBTOOL_CXX + +LIBTOOL_SHELL="/bin/sh ./libtool" +# LIBTOOL="$LIBTOOL --silent" +KDE_PLUGIN="-avoid-version -module -no-undefined \$(KDE_NO_UNDEFINED) \$(KDE_RPATH) \$(KDE_MT_LDFLAGS)" +AC_SUBST(KDE_PLUGIN) + +# we patch configure quite some so we better keep that consistent for incremental runs +AC_SUBST(AUTOCONF,'$(SHELL) $(top_srcdir)/admin/cvs.sh configure || touch configure') +]) + +AC_DEFUN([KDE_CHECK_LIB64], +[ + kdelibsuff=no + AC_ARG_ENABLE(libsuffix, + AC_HELP_STRING([--enable-libsuffix], + [/lib directory suffix (64,32,none[=default])]), + kdelibsuff=$enableval) + # TODO: add an auto case that compiles a little C app to check + # where the glibc is + if test "$kdelibsuff" = "no"; then + kdelibsuff= + fi + if test -z "$kdelibsuff"; then + AC_MSG_RESULT([not using lib directory suffix]) + AC_DEFINE(KDELIBSUFF, [""], Suffix for lib directories) + else + if test "$libdir" = '${exec_prefix}/lib'; then + libdir="$libdir${kdelibsuff}" + AC_SUBST([libdir], ["$libdir"]) dnl ugly hack for lib64 platforms + fi + AC_DEFINE_UNQUOTED(KDELIBSUFF, ["\"${kdelibsuff}\""], Suffix for lib directories) + AC_MSG_RESULT([using lib directory suffix $kdelibsuff]) + fi +]) + +AC_DEFUN([KDE_CHECK_TYPES], +[ AC_CHECK_SIZEOF(int, 4)dnl + AC_CHECK_SIZEOF(short)dnl + AC_CHECK_SIZEOF(long, 4)dnl + AC_CHECK_SIZEOF(char *, 4)dnl +])dnl + +AC_DEFUN([KDE_DO_IT_ALL], +[ +AC_CANONICAL_SYSTEM +AC_ARG_PROGRAM +AM_INIT_AUTOMAKE($1, $2) +AM_DISABLE_LIBRARIES +AC_PREFIX_DEFAULT(${KDEDIR:-/usr/local/kde}) +AC_CHECK_COMPILERS +KDE_PROG_LIBTOOL +AM_KDE_WITH_NLS +AC_PATH_KDE +]) + +AC_DEFUN([AC_CHECK_RPATH], +[ +AC_MSG_CHECKING(for rpath) +AC_ARG_ENABLE(rpath, + AC_HELP_STRING([--disable-rpath],[do not use the rpath feature of ld]), + USE_RPATH=$enableval, USE_RPATH=yes) + +if test -z "$KDE_RPATH" && test "$USE_RPATH" = "yes"; then + + KDE_RPATH="-R \$(kde_libraries)" + + if test -n "$qt_libraries"; then + KDE_RPATH="$KDE_RPATH -R \$(qt_libraries)" + fi + dnl $x_libraries is set to /usr/lib in case + if test -n "$X_LDFLAGS"; then + X_RPATH="-R \$(x_libraries)" + KDE_RPATH="$KDE_RPATH $X_RPATH" + fi + if test -n "$KDE_EXTRA_RPATH"; then + KDE_RPATH="$KDE_RPATH \$(KDE_EXTRA_RPATH)" + fi +fi +AC_SUBST(KDE_EXTRA_RPATH) +AC_SUBST(KDE_RPATH) +AC_SUBST(X_RPATH) +AC_MSG_RESULT($USE_RPATH) +]) + +dnl Check for the type of the third argument of getsockname +AC_DEFUN([AC_CHECK_SOCKLEN_T], [ + AC_MSG_CHECKING(for socklen_t) + AC_CACHE_VAL(ac_cv_socklen_t, [ + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + AC_TRY_COMPILE([ +#include +#include + ],[ +socklen_t a=0; +getsockname(0,(struct sockaddr*)0, &a); + ], + ac_cv_socklen_t=socklen_t, + AC_TRY_COMPILE([ +#include +#include + ],[ +int a=0; +getsockname(0,(struct sockaddr*)0, &a); + ], + ac_cv_socklen_t=int, + ac_cv_socklen_t=size_t + ) + ) + AC_LANG_RESTORE + ]) + + AC_MSG_RESULT($ac_cv_socklen_t) + if test "$ac_cv_socklen_t" != "socklen_t"; then + AC_DEFINE_UNQUOTED(socklen_t, $ac_cv_socklen_t, + [Define the real type of socklen_t]) + fi + AC_DEFINE_UNQUOTED(ksize_t, socklen_t, [Compatibility define]) + +]) + +dnl This is a merge of some macros out of the gettext aclocal.m4 +dnl since we don't need anything, I took the things we need +dnl the copyright for them is: +dnl > +dnl Copyright (C) 1994, 1995, 1996, 1997, 1998 Free Software Foundation, Inc. +dnl This Makefile.in is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl This program is distributed in the hope that it will be useful, +dnl but WITHOUT ANY WARRANTY, to the extent permitted by law; without +dnl even the implied warranty of MERCHANTABILITY or FITNESS FOR A +dnl PARTICULAR PURPOSE. +dnl > +dnl for this file it is relicensed under LGPL + +AC_DEFUN([AM_KDE_WITH_NLS], + [ + dnl If we use NLS figure out what method + + AM_PATH_PROG_WITH_TEST_KDE(MSGFMT, msgfmt, + [test -n "`$ac_dir/$ac_word --version 2>&1 | grep 'GNU gettext'`"], msgfmt) + AC_PATH_PROG(GMSGFMT, gmsgfmt, $MSGFMT) + + if test -z "`$GMSGFMT --version 2>&1 | grep 'GNU gettext'`"; then + AC_MSG_RESULT([found msgfmt program is not GNU msgfmt; ignore it]) + GMSGFMT=":" + fi + MSGFMT=$GMSGFMT + AC_SUBST(GMSGFMT) + AC_SUBST(MSGFMT) + + AM_PATH_PROG_WITH_TEST_KDE(XGETTEXT, xgettext, + [test -z "`$ac_dir/$ac_word -h 2>&1 | grep '(HELP)'`"], :) + + dnl Test whether we really found GNU xgettext. + if test "$XGETTEXT" != ":"; then + dnl If it is no GNU xgettext we define it as : so that the + dnl Makefiles still can work. + if $XGETTEXT --omit-header /dev/null 2> /dev/null; then + : ; + else + AC_MSG_RESULT( + [found xgettext programs is not GNU xgettext; ignore it]) + XGETTEXT=":" + fi + fi + AC_SUBST(XGETTEXT) + + ]) + +# Search path for a program which passes the given test. +# Ulrich Drepper , 1996. + +# serial 1 +# Stephan Kulow: I appended a _KDE against name conflicts + +dnl AM_PATH_PROG_WITH_TEST_KDE(VARIABLE, PROG-TO-CHECK-FOR, +dnl TEST-PERFORMED-ON-FOUND_PROGRAM [, VALUE-IF-NOT-FOUND [, PATH]]) +AC_DEFUN([AM_PATH_PROG_WITH_TEST_KDE], +[# Extract the first word of "$2", so it can be a program name with args. +set dummy $2; ac_word=[$]2 +AC_MSG_CHECKING([for $ac_word]) +AC_CACHE_VAL(ac_cv_path_$1, +[case "[$]$1" in + /*) + ac_cv_path_$1="[$]$1" # Let the user override the test with a path. + ;; + *) + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS="${IFS}:" + for ac_dir in ifelse([$5], , $PATH, [$5]); do + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$ac_word; then + if [$3]; then + ac_cv_path_$1="$ac_dir/$ac_word" + break + fi + fi + done + IFS="$ac_save_ifs" +dnl If no 4th arg is given, leave the cache variable unset, +dnl so AC_PATH_PROGS will keep looking. +ifelse([$4], , , [ test -z "[$]ac_cv_path_$1" && ac_cv_path_$1="$4" +])dnl + ;; +esac])dnl +$1="$ac_cv_path_$1" +if test -n "[$]$1"; then + AC_MSG_RESULT([$]$1) +else + AC_MSG_RESULT(no) +fi +AC_SUBST($1)dnl +]) + + +# Check whether LC_MESSAGES is available in . +# Ulrich Drepper , 1995. + +# serial 1 + +AC_DEFUN([AM_LC_MESSAGES], + [if test $ac_cv_header_locale_h = yes; then + AC_CACHE_CHECK([for LC_MESSAGES], am_cv_val_LC_MESSAGES, + [AC_TRY_LINK([#include ], [return LC_MESSAGES], + am_cv_val_LC_MESSAGES=yes, am_cv_val_LC_MESSAGES=no)]) + if test $am_cv_val_LC_MESSAGES = yes; then + AC_DEFINE(HAVE_LC_MESSAGES, 1, [Define if your locale.h file contains LC_MESSAGES]) + fi + fi]) + +dnl From Jim Meyering. +dnl FIXME: migrate into libit. + +AC_DEFUN([AM_FUNC_OBSTACK], +[AC_CACHE_CHECK([for obstacks], am_cv_func_obstack, + [AC_TRY_LINK([#include "obstack.h"], + [struct obstack *mem;obstack_free(mem,(char *) 0)], + am_cv_func_obstack=yes, + am_cv_func_obstack=no)]) + if test $am_cv_func_obstack = yes; then + AC_DEFINE(HAVE_OBSTACK) + else + LIBOBJS="$LIBOBJS obstack.o" + fi +]) + +dnl From Jim Meyering. Use this if you use the GNU error.[ch]. +dnl FIXME: Migrate into libit + +AC_DEFUN([AM_FUNC_ERROR_AT_LINE], +[AC_CACHE_CHECK([for error_at_line], am_cv_lib_error_at_line, + [AC_TRY_LINK([],[error_at_line(0, 0, "", 0, "");], + am_cv_lib_error_at_line=yes, + am_cv_lib_error_at_line=no)]) + if test $am_cv_lib_error_at_line = no; then + LIBOBJS="$LIBOBJS error.o" + fi + AC_SUBST(LIBOBJS)dnl +]) + +# Macro to add for using GNU gettext. +# Ulrich Drepper , 1995. + +# serial 1 +# Stephan Kulow: I put a KDE in it to avoid name conflicts + +AC_DEFUN([AM_KDE_GNU_GETTEXT], + [AC_REQUIRE([AC_PROG_MAKE_SET])dnl + AC_REQUIRE([AC_PROG_RANLIB])dnl + AC_REQUIRE([AC_HEADER_STDC])dnl + AC_REQUIRE([AC_TYPE_OFF_T])dnl + AC_REQUIRE([AC_TYPE_SIZE_T])dnl + AC_REQUIRE([AC_FUNC_ALLOCA])dnl + AC_REQUIRE([AC_FUNC_MMAP])dnl + AC_REQUIRE([AM_KDE_WITH_NLS])dnl + AC_CHECK_HEADERS([limits.h locale.h nl_types.h string.h values.h alloca.h]) + AC_CHECK_FUNCS([getcwd munmap putenv setlocale strchr strcasecmp \ +__argz_count __argz_stringify __argz_next]) + + AC_MSG_CHECKING(for stpcpy) + AC_CACHE_VAL(kde_cv_func_stpcpy, + [ + kde_safe_cxxflags=$CXXFLAGS + CXXFLAGS="-Werror" + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + AC_TRY_COMPILE([ + #include + ], + [ + char buffer[200]; + stpcpy(buffer, buffer); + ], + kde_cv_func_stpcpy=yes, + kde_cv_func_stpcpy=no) + AC_LANG_RESTORE + CXXFLAGS=$kde_safe_cxxflags + ]) + AC_MSG_RESULT($kde_cv_func_stpcpy) + if eval "test \"`echo $kde_cv_func_stpcpy`\" = yes"; then + AC_DEFINE(HAVE_STPCPY, 1, [Define if you have stpcpy]) + fi + + AM_LC_MESSAGES + + if test "x$CATOBJEXT" != "x"; then + if test "x$ALL_LINGUAS" = "x"; then + LINGUAS= + else + AC_MSG_CHECKING(for catalogs to be installed) + NEW_LINGUAS= + for lang in ${LINGUAS=$ALL_LINGUAS}; do + case "$ALL_LINGUAS" in + *$lang*) NEW_LINGUAS="$NEW_LINGUAS $lang" ;; + esac + done + LINGUAS=$NEW_LINGUAS + AC_MSG_RESULT($LINGUAS) + fi + + dnl Construct list of names of catalog files to be constructed. + if test -n "$LINGUAS"; then + for lang in $LINGUAS; do CATALOGS="$CATALOGS $lang$CATOBJEXT"; done + fi + fi + + ]) + +AC_DEFUN([AC_HAVE_XPM], + [AC_REQUIRE_CPP()dnl + AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) + + test -z "$XPM_LDFLAGS" && XPM_LDFLAGS= + test -z "$XPM_INCLUDE" && XPM_INCLUDE= + + AC_ARG_WITH(xpm,AC_HELP_STRING([--without-xpm],[disable color pixmap XPM tests]), + xpm_test=$withval, xpm_test="yes") + if test "x$xpm_test" = xno; then + ac_cv_have_xpm=no + else + AC_MSG_CHECKING(for XPM) + AC_CACHE_VAL(ac_cv_have_xpm, + [ + ac_save_ldflags="$LDFLAGS" + ac_save_cflags="$CFLAGS" + if test "x$kde_use_qt_emb" != "xyes" && test "x$kde_use_qt_mac" != "xyes"; then + LDFLAGS="$LDFLAGS $X_LDFLAGS $USER_LDFLAGS $LDFLAGS $XPM_LDFLAGS $all_libraries -lXpm -lX11 -lXext $LIBZ $LIBSOCKET" + else + LDFLAGS="$LDFLAGS $X_LDFLAGS $USER_LDFLAGS $LDFLAGS $XPM_LDFLAGS $all_libraries -lXpm $LIBZ $LIBSOCKET" + fi + CFLAGS="$CFLAGS $X_INCLUDES $USER_INCLUDES" + test -n "$XPM_INCLUDE" && CFLAGS="-I$XPM_INCLUDE $CFLAGS" + AC_TRY_LINK([#include ],[], + ac_cv_have_xpm="yes",ac_cv_have_xpm="no") + LDFLAGS="$ac_save_ldflags" + CFLAGS="$ac_save_cflags" + ])dnl + + if test "$ac_cv_have_xpm" = no; then + AC_MSG_RESULT(no) + XPM_LDFLAGS="" + XPMINC="" + $2 + else + AC_DEFINE(HAVE_XPM, 1, [Define if you have XPM support]) + if test "$XPM_LDFLAGS" = ""; then + XPMLIB='-lXpm $(LIB_X11)' + else + XPMLIB="-L$XPM_LDFLAGS -lXpm "'$(LIB_X11)' + fi + if test "$XPM_INCLUDE" = ""; then + XPMINC="" + else + XPMINC="-I$XPM_INCLUDE" + fi + AC_MSG_RESULT(yes) + $1 + fi + fi + AC_SUBST(XPMINC) + AC_SUBST(XPMLIB) +]) + +AC_DEFUN([AC_HAVE_DPMS], + [AC_REQUIRE_CPP()dnl + AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) + + test -z "$DPMS_LDFLAGS" && DPMS_LDFLAGS= + test -z "$DPMS_INCLUDE" && DPMS_INCLUDE= + DPMS_LIB= + + AC_ARG_WITH(dpms,AC_HELP_STRING([--without-dpms],[disable DPMS power saving]), + dpms_test=$withval, dpms_test="yes") + if test "x$dpms_test" = xno; then + ac_cv_have_dpms=no + else + AC_MSG_CHECKING(for DPMS) + dnl Note: ac_cv_have_dpms can be no, yes, or -lXdpms. + dnl 'yes' means DPMS_LIB="", '-lXdpms' means DPMS_LIB="-lXdpms". + AC_CACHE_VAL(ac_cv_have_dpms, + [ + if test "x$kde_use_qt_emb" = "xyes" || test "x$kde_use_qt_mac" = "xyes"; then + AC_MSG_RESULT(no) + ac_cv_have_dpms="no" + else + ac_save_ldflags="$LDFLAGS" + ac_save_cflags="$CFLAGS" + ac_save_libs="$LIBS" + LDFLAGS="$LDFLAGS $DPMS_LDFLAGS $all_libraries -lX11 -lXext $LIBSOCKET" + CFLAGS="$CFLAGS $X_INCLUDES" + test -n "$DPMS_INCLUDE" && CFLAGS="-I$DPMS_INCLUDE $CFLAGS" + AC_TRY_LINK([ + #include + #include + #include + #include + int foo_test_dpms() + { return DPMSSetTimeouts( 0, 0, 0, 0 ); }],[], + ac_cv_have_dpms="yes", [ + LDFLAGS="$ac_save_ldflags" + CFLAGS="$ac_save_cflags" + LDFLAGS="$LDFLAGS $DPMS_LDFLAGS $all_libraries -lX11 -lXext $LIBSOCKET" + LIBS="$LIBS -lXdpms" + CFLAGS="$CFLAGS $X_INCLUDES" + test -n "$DPMS_INCLUDE" && CFLAGS="-I$DPMS_INCLUDE $CFLAGS" + AC_TRY_LINK([ + #include + #include + #include + #include + int foo_test_dpms() + { return DPMSSetTimeouts( 0, 0, 0, 0 ); }],[], + [ + ac_cv_have_dpms="-lXdpms" + ],ac_cv_have_dpms="no") + ]) + LDFLAGS="$ac_save_ldflags" + CFLAGS="$ac_save_cflags" + LIBS="$ac_save_libs" + fi + ])dnl + + if test "$ac_cv_have_dpms" = no; then + AC_MSG_RESULT(no) + DPMS_LDFLAGS="" + DPMSINC="" + $2 + else + AC_DEFINE(HAVE_DPMS, 1, [Define if you have DPMS support]) + if test "$ac_cv_have_dpms" = "-lXdpms"; then + DPMS_LIB="-lXdpms" + fi + if test "$DPMS_LDFLAGS" = ""; then + DPMSLIB="$DPMS_LIB "'$(LIB_X11)' + else + DPMSLIB="$DPMS_LDFLAGS $DPMS_LIB "'$(LIB_X11)' + fi + if test "$DPMS_INCLUDE" = ""; then + DPMSINC="" + else + DPMSINC="-I$DPMS_INCLUDE" + fi + AC_MSG_RESULT(yes) + $1 + fi + fi + ac_save_cflags="$CFLAGS" + CFLAGS="$CFLAGS $X_INCLUDES" + test -n "$DPMS_INCLUDE" && CFLAGS="-I$DPMS_INCLUDE $CFLAGS" + AH_TEMPLATE(HAVE_DPMSCAPABLE_PROTO, + [Define if you have the DPMSCapable prototype in ]) + AC_CHECK_DECL(DPMSCapable, + AC_DEFINE(HAVE_DPMSCAPABLE_PROTO),, + [#include ]) + AH_TEMPLATE(HAVE_DPMSINFO_PROTO, + [Define if you have the DPMSInfo prototype in ]) + AC_CHECK_DECL(DPMSInfo, + AC_DEFINE(HAVE_DPMSINFO_PROTO),, + [#include ]) + CFLAGS="$ac_save_cflags" + AC_SUBST(DPMSINC) + AC_SUBST(DPMSLIB) +]) + +AC_DEFUN([AC_HAVE_GL], + [AC_REQUIRE_CPP()dnl + AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) + + test -z "$GL_LDFLAGS" && GL_LDFLAGS= + test -z "$GL_INCLUDE" && GL_INCLUDE= + + AC_ARG_WITH(gl,AC_HELP_STRING([--without-gl],[disable 3D GL modes]), + gl_test=$withval, gl_test="yes") + if test "x$kde_use_qt_emb" = "xyes"; then + # GL and Qt Embedded is a no-go for now. + ac_cv_have_gl=no + elif test "x$gl_test" = xno; then + ac_cv_have_gl=no + else + AC_MSG_CHECKING(for GL) + AC_CACHE_VAL(ac_cv_have_gl, + [ + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + ac_save_ldflags="$LDFLAGS" + ac_save_cxxflags="$CXXFLAGS" + LDFLAGS="$LDFLAGS $GL_LDFLAGS $X_LDFLAGS $all_libraries -lMesaGL -lMesaGLU" + test "x$kde_use_qt_mac" != xyes && test "x$kde_use_qt_emb" != xyes && LDFLAGS="$LDFLAGS -lX11" + LDFLAGS="$LDFLAGS $LIB_XEXT -lm $LIBSOCKET" + CXXFLAGS="$CFLAGS $X_INCLUDES" + test -n "$GL_INCLUDE" && CFLAGS="-I$GL_INCLUDE $CFLAGS" + AC_TRY_LINK([#include +#include +], [], + ac_cv_have_gl="mesa", ac_cv_have_gl="no") + if test "x$ac_cv_have_gl" = "xno"; then + LDFLAGS="$ac_save_ldflags $X_LDFLAGS $GL_LDFLAGS $all_libraries -lGLU -lGL" + test "x$kde_use_qt_mac" != xyes && test "x$kde_use_qt_emb" != xyes && LDFLAGS="$LDFLAGS -lX11" + LDFLAGS="$LDFLAGS $LIB_XEXT -lm $LIBSOCKET" + CXXFLAGS="$ac_save_cflags $X_INCLUDES" + test -n "$GL_INCLUDE" && CFLAGS="-I$GL_INCLUDE $CFLAGS" + AC_TRY_LINK([#include +#include +], [], + ac_cv_have_gl="yes", ac_cv_have_gl="no") + fi + AC_LANG_RESTORE + LDFLAGS="$ac_save_ldflags" + CXXFLAGS="$ac_save_cxxflags" + ])dnl + + if test "$ac_cv_have_gl" = "no"; then + AC_MSG_RESULT(no) + GL_LDFLAGS="" + GLINC="" + $2 + else + AC_DEFINE(HAVE_GL, 1, [Defines if you have GL (Mesa, OpenGL, ...)]) + if test "$GL_LDFLAGS" = ""; then + if test "$ac_cv_have_gl" = "mesa"; then + GLLIB='-lMesaGLU -lMesaGL $(LIB_X11)' + else + GLLIB='-lGLU -lGL $(LIB_X11)' + fi + else + if test "$ac_cv_have_gl" = "mesa"; then + GLLIB="$GL_LDFLAGS -lMesaGLU -lMesaGL "'$(LIB_X11)' + else + GLLIB="$GL_LDFLAGS -lGLU -lGL "'$(LIB_X11)' + fi + fi + if test "$GL_INCLUDE" = ""; then + GLINC="" + else + GLINC="-I$GL_INCLUDE" + fi + AC_MSG_RESULT($ac_cv_have_gl) + $1 + fi + fi + AC_SUBST(GLINC) + AC_SUBST(GLLIB) +]) + + + dnl shadow password and PAM magic - maintained by ossi@kde.org + +AC_DEFUN([KDE_PAM], [ + AC_REQUIRE([KDE_CHECK_LIBDL]) + + want_pam= + AC_ARG_WITH(pam, + AC_HELP_STRING([--with-pam[=ARG]],[enable support for PAM: ARG=[yes|no|service name]]), + [ if test "x$withval" = "xyes"; then + want_pam=yes + pam_service=kde + elif test "x$withval" = "xno"; then + want_pam=no + else + want_pam=yes + pam_service=$withval + fi + ], [ pam_service=kde ]) + + use_pam= + PAMLIBS= + if test "x$want_pam" != xno; then + AC_CHECK_LIB(pam, pam_start, [ + AC_CHECK_HEADER(security/pam_appl.h, + [ pam_header=security/pam_appl.h ], + [ AC_CHECK_HEADER(pam/pam_appl.h, + [ pam_header=pam/pam_appl.h ], + [ + AC_MSG_WARN([PAM detected, but no headers found! +Make sure you have the necessary development packages installed.]) + ] + ) + ] + ) + ], , $LIBDL) + if test -z "$pam_header"; then + if test "x$want_pam" = xyes; then + AC_MSG_ERROR([--with-pam was specified, but cannot compile with PAM!]) + fi + else + AC_DEFINE(HAVE_PAM, 1, [Defines if you have PAM (Pluggable Authentication Modules)]) + PAMLIBS="$PAM_MISC_LIB -lpam $LIBDL" + use_pam=yes + + dnl darwin claims to be something special + if test "$pam_header" = "pam/pam_appl.h"; then + AC_DEFINE(HAVE_PAM_PAM_APPL_H, 1, [Define if your PAM headers are in pam/ instead of security/]) + fi + + dnl test whether struct pam_message is const (Linux) or not (Sun) + AC_MSG_CHECKING(for const pam_message) + AC_EGREP_HEADER([struct pam_message], $pam_header, + [ AC_EGREP_HEADER([const struct pam_message], $pam_header, + [AC_MSG_RESULT([const: Linux-type PAM])], + [AC_MSG_RESULT([nonconst: Sun-type PAM]) + AC_DEFINE(PAM_MESSAGE_NONCONST, 1, [Define if your PAM support takes non-const arguments (Solaris)])] + )], + [AC_MSG_RESULT([not found - assume const, Linux-type PAM])]) + fi + fi + + AC_SUBST(PAMLIBS) +]) + +dnl DEF_PAM_SERVICE(arg name, full name, define name) +AC_DEFUN([DEF_PAM_SERVICE], [ + AC_ARG_WITH($1-pam, + AC_HELP_STRING([--with-$1-pam=[val]],[override PAM service from --with-pam for $2]), + [ if test "x$use_pam" = xyes; then + $3_PAM_SERVICE=$withval + else + AC_MSG_ERROR([Cannot use use --with-$1-pam, as no PAM was detected. +You may want to enforce it by using --with-pam.]) + fi + ], + [ if test "x$use_pam" = xyes; then + $3_PAM_SERVICE="$pam_service" + fi + ]) + if test -n "$$3_PAM_SERVICE"; then + AC_MSG_RESULT([The PAM service used by $2 will be $$3_PAM_SERVICE]) + AC_DEFINE_UNQUOTED($3_PAM_SERVICE, "$$3_PAM_SERVICE", [The PAM service to be used by $2]) + fi + AC_SUBST($3_PAM_SERVICE) +]) + +AC_DEFUN([KDE_SHADOWPASSWD], [ + AC_REQUIRE([KDE_PAM]) + + AC_CHECK_LIB(shadow, getspent, + [ LIBSHADOW="-lshadow" + ac_use_shadow=yes + ], + [ dnl for UnixWare + AC_CHECK_LIB(gen, getspent, + [ LIBGEN="-lgen" + ac_use_shadow=yes + ], + [ AC_CHECK_FUNC(getspent, + [ ac_use_shadow=yes ], + [ ac_use_shadow=no ]) + ]) + ]) + AC_SUBST(LIBSHADOW) + AC_SUBST(LIBGEN) + + AC_MSG_CHECKING([for shadow passwords]) + + AC_ARG_WITH(shadow, + AC_HELP_STRING([--with-shadow],[If you want shadow password support]), + [ if test "x$withval" != "xno"; then + use_shadow=yes + else + use_shadow=no + fi + ], [ + use_shadow="$ac_use_shadow" + ]) + + if test "x$use_shadow" = xyes; then + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_SHADOW, 1, [Define if you use shadow passwords]) + else + AC_MSG_RESULT(no) + LIBSHADOW= + LIBGEN= + fi + + dnl finally make the relevant binaries setuid root, if we have shadow passwds. + dnl this still applies, if we could use it indirectly through pam. + if test "x$use_shadow" = xyes || + ( test "x$use_pam" = xyes && test "x$ac_use_shadow" = xyes ); then + case $host in + *-*-freebsd* | *-*-netbsd* | *-*-openbsd*) + SETUIDFLAGS="-m 4755 -o root";; + *) + SETUIDFLAGS="-m 4755";; + esac + fi + AC_SUBST(SETUIDFLAGS) + +]) + +AC_DEFUN([KDE_PASSWDLIBS], [ + AC_REQUIRE([KDE_MISC_TESTS]) dnl for LIBCRYPT + AC_REQUIRE([KDE_PAM]) + AC_REQUIRE([KDE_SHADOWPASSWD]) + + if test "x$use_pam" = "xyes"; then + PASSWDLIBS="$PAMLIBS" + else + PASSWDLIBS="$LIBCRYPT $LIBSHADOW $LIBGEN" + fi + + dnl FreeBSD uses a shadow-like setup, where /etc/passwd holds the users, but + dnl /etc/master.passwd holds the actual passwords. /etc/master.passwd requires + dnl root to read, so kcheckpass needs to be root (even when using pam, since pam + dnl may need to read /etc/master.passwd). + case $host in + *-*-freebsd*) + SETUIDFLAGS="-m 4755 -o root" + ;; + *) + ;; + esac + + AC_SUBST(PASSWDLIBS) +]) + +AC_DEFUN([KDE_CHECK_LIBDL], +[ +AC_CHECK_LIB(dl, dlopen, [ +LIBDL="-ldl" +ac_cv_have_dlfcn=yes +]) + +AC_CHECK_LIB(dld, shl_unload, [ +LIBDL="-ldld" +ac_cv_have_shload=yes +]) + +AC_SUBST(LIBDL) +]) + +AC_DEFUN([KDE_CHECK_DLOPEN], +[ +KDE_CHECK_LIBDL +AC_CHECK_HEADERS(dlfcn.h dl.h) +if test "$ac_cv_header_dlfcn_h" = "no"; then + ac_cv_have_dlfcn=no +fi + +if test "$ac_cv_header_dl_h" = "no"; then + ac_cv_have_shload=no +fi + +dnl XXX why change enable_dlopen? its already set by autoconf's AC_ARG_ENABLE +dnl (MM) +AC_ARG_ENABLE(dlopen, +AC_HELP_STRING([--disable-dlopen],[link statically [default=no]]), +enable_dlopen=$enableval, +enable_dlopen=yes) + +# override the user's opinion, if we know it better ;) +if test "$ac_cv_have_dlfcn" = "no" && test "$ac_cv_have_shload" = "no"; then + enable_dlopen=no +fi + +if test "$ac_cv_have_dlfcn" = "yes"; then + AC_DEFINE_UNQUOTED(HAVE_DLFCN, 1, [Define if you have dlfcn]) +fi + +if test "$ac_cv_have_shload" = "yes"; then + AC_DEFINE_UNQUOTED(HAVE_SHLOAD, 1, [Define if you have shload]) +fi + +if test "$enable_dlopen" = no ; then + test -n "$1" && eval $1 +else + test -n "$2" && eval $2 +fi + +]) + +AC_DEFUN([KDE_CHECK_DYNAMIC_LOADING], +[ +KDE_CHECK_DLOPEN(libtool_enable_shared=yes, libtool_enable_static=no) +KDE_PROG_LIBTOOL +AC_MSG_CHECKING([dynamic loading]) +eval "`egrep '^build_libtool_libs=' libtool`" +if test "$build_libtool_libs" = "yes" && test "$enable_dlopen" = "yes"; then + dynamic_loading=yes + AC_DEFINE_UNQUOTED(HAVE_DYNAMIC_LOADING) +else + dynamic_loading=no +fi +AC_MSG_RESULT($dynamic_loading) +if test "$dynamic_loading" = "yes"; then + $1 +else + $2 +fi +]) + +AC_DEFUN([KDE_ADD_INCLUDES], +[ +if test -z "$1"; then + test_include="Pix.h" +else + test_include="$1" +fi + +AC_MSG_CHECKING([for libg++ ($test_include)]) + +AC_CACHE_VAL(kde_cv_libgpp_includes, +[ +kde_cv_libgpp_includes=no + + for ac_dir in \ + \ + /usr/include/g++ \ + /usr/include \ + /usr/unsupported/include \ + /opt/include \ + $extra_include \ + ; \ + do + if test -r "$ac_dir/$test_include"; then + kde_cv_libgpp_includes=$ac_dir + break + fi + done +]) + +AC_MSG_RESULT($kde_cv_libgpp_includes) +if test "$kde_cv_libgpp_includes" != "no"; then + all_includes="-I$kde_cv_libgpp_includes $all_includes $USER_INCLUDES" +fi +]) +]) + +AC_DEFUN([KDE_CHECK_LIBPTHREAD], +[ + LIBPTHREAD="" + + if test -n "$PTHREAD_LIBS"; then + PTHREAD_LIBS_save="$PTHREAD_LIBS" + PTHREAD_LIBS=`echo "$PTHREAD_LIBS_save" | sed -e 's,^-l,,g'` + KDE_CHECK_LIB($PTHREAD_LIBS, pthread_create, [LIBPTHREAD="$PTHREAD_LIBS_save"] ) + PTHREAD_LIBS="$PTHREAD_LIBS_save" + fi + + if test -z "$LIBPTHREAD"; then + AC_CHECK_LIB(pthread, pthread_create, [LIBPTHREAD="-lpthread"] ) + fi + + AC_SUBST(LIBPTHREAD) +]) + +AC_DEFUN([KDE_CHECK_PTHREAD_OPTION], +[ + USE_THREADS="" + if test -z "$LIBPTHREAD"; then + KDE_CHECK_COMPILER_FLAG(pthread, [USE_THREADS="-D_THREAD_SAFE -pthread"]) + fi + + AH_VERBATIM(__svr_define, [ +#if defined(__SVR4) && !defined(__svr4__) +#define __svr4__ 1 +#endif +]) + case $host_os in + solaris*) + KDE_CHECK_COMPILER_FLAG(mt, [USE_THREADS="-mt"]) + CPPFLAGS="$CPPFLAGS -D_REENTRANT -D_POSIX_PTHREAD_SEMANTICS -DUSE_SOLARIS -DSVR4" + ;; + freebsd*) + CPPFLAGS="$CPPFLAGS -D_THREAD_SAFE $PTHREAD_CFLAGS" + ;; + aix*) + CPPFLAGS="$CPPFLAGS -D_THREAD_SAFE" + LIBPTHREAD="$LIBPTHREAD -lc_r" + ;; + linux*) CPPFLAGS="$CPPFLAGS -D_REENTRANT" + if test "$CXX" = "KCC"; then + CXXFLAGS="$CXXFLAGS --thread_safe" + NOOPT_CXXFLAGS="$NOOPT_CXXFLAGS --thread_safe" + fi + ;; + *) + ;; + esac + AC_SUBST(USE_THREADS) + AC_SUBST(LIBPTHREAD) +]) + +AC_DEFUN([KDE_CHECK_THREADING], +[ + AC_REQUIRE([KDE_CHECK_LIBPTHREAD]) + AC_REQUIRE([KDE_CHECK_PTHREAD_OPTION]) + dnl default is yes if libpthread is found and no if no libpthread is available + if test -z "$LIBPTHREAD"; then + if test -z "$USE_THREADS"; then + kde_check_threading_default=no + else + kde_check_threading_default=yes + fi + else + kde_check_threading_default=yes + fi + AC_ARG_ENABLE(threading,AC_HELP_STRING([--disable-threading],[disables threading even if libpthread found]), + kde_use_threading=$enableval, kde_use_threading=$kde_check_threading_default) + if test "x$kde_use_threading" = "xyes"; then + AC_DEFINE(HAVE_LIBPTHREAD, 1, [Define if you have a working libpthread (will enable threaded code)]) + fi +]) + +AC_DEFUN([KDE_TRY_LINK_PYTHON], +[ +if test "$kde_python_link_found" = no; then + +if test "$1" = normal; then + AC_MSG_CHECKING(if a Python application links) +else + AC_MSG_CHECKING(if Python depends on $2) +fi + +AC_CACHE_VAL(kde_cv_try_link_python_$1, +[ +kde_save_cflags="$CFLAGS" +CFLAGS="$CFLAGS $PYTHONINC" +kde_save_libs="$LIBS" +LIBS="$LIBS $LIBPYTHON $2 $LIBDL $LIBSOCKET" +kde_save_ldflags="$LDFLAGS" +LDFLAGS="$LDFLAGS $PYTHONLIB" + +AC_TRY_LINK( +[ +#include +],[ + PySys_SetArgv(1, 0); +], + [kde_cv_try_link_python_$1=yes], + [kde_cv_try_link_python_$1=no] +) +CFLAGS="$kde_save_cflags" +LIBS="$kde_save_libs" +LDFLAGS="$kde_save_ldflags" +]) + +if test "$kde_cv_try_link_python_$1" = "yes"; then + AC_MSG_RESULT(yes) + kde_python_link_found=yes + if test ! "$1" = normal; then + LIBPYTHON="$LIBPYTHON $2" + fi + $3 +else + AC_MSG_RESULT(no) + $4 +fi + +fi + +]) + +AC_DEFUN([KDE_CHECK_PYTHON_DIR], +[ +AC_MSG_CHECKING([for Python directory]) + +AC_CACHE_VAL(kde_cv_pythondir, +[ + if test -z "$PYTHONDIR"; then + kde_cv_pythondir=/usr/local + else + kde_cv_pythondir="$PYTHONDIR" + fi +]) + +AC_ARG_WITH(pythondir, +AC_HELP_STRING([--with-pythondir=pythondir],[use python installed in pythondir]), +[ + ac_python_dir=$withval +], ac_python_dir=$kde_cv_pythondir +) + +AC_MSG_RESULT($ac_python_dir) +]) + +AC_DEFUN([KDE_CHECK_PYTHON_INTERN], +[ +AC_REQUIRE([KDE_CHECK_LIBDL]) +AC_REQUIRE([KDE_CHECK_LIBPTHREAD]) +AC_REQUIRE([KDE_CHECK_PYTHON_DIR]) + +if test -z "$1"; then + version="1.5" +else + version="$1" +fi + +AC_MSG_CHECKING([for Python$version]) + +python_incdirs="$ac_python_dir/include /usr/include /usr/local/include/ $kde_extra_includes" +AC_FIND_FILE(Python.h, $python_incdirs, python_incdir) +if test ! -r $python_incdir/Python.h; then + AC_FIND_FILE(python$version/Python.h, $python_incdirs, python_incdir) + python_incdir=$python_incdir/python$version + if test ! -r $python_incdir/Python.h; then + python_incdir=no + fi +fi + +PYTHONINC=-I$python_incdir + +python_libdirs="$ac_python_dir/lib$kdelibsuff /usr/lib$kdelibsuff /usr/local /usr/lib$kdelibsuff $kde_extra_libs" +AC_FIND_FILE(libpython$version.so, $python_libdirs, python_libdir) +if test ! -r $python_libdir/libpython$version.so; then + AC_FIND_FILE(libpython$version.a, $python_libdirs, python_libdir) + if test ! -r $python_libdir/libpython$version.a; then + AC_FIND_FILE(python$version/config/libpython$version.a, $python_libdirs, python_libdir) + python_libdir=$python_libdir/python$version/config + if test ! -r $python_libdir/libpython$version.a; then + python_libdir=no + fi + fi +fi + +PYTHONLIB=-L$python_libdir +kde_orig_LIBPYTHON=$LIBPYTHON +if test -z "$LIBPYTHON"; then + LIBPYTHON=-lpython$version +fi + +AC_FIND_FILE(python$version/copy.py, $python_libdirs, python_moddir) +python_moddir=$python_moddir/python$version +if test ! -r $python_moddir/copy.py; then + python_moddir=no +fi + +PYTHONMODDIR=$python_moddir + +AC_MSG_RESULT(header $python_incdir library $python_libdir modules $python_moddir) + +if test x$python_incdir = xno || test x$python_libdir = xno || test x$python_moddir = xno; then + LIBPYTHON=$kde_orig_LIBPYTHON + test "x$PYTHONLIB" = "x-Lno" && PYTHONLIB="" + test "x$PYTHONINC" = "x-Ino" && PYTHONINC="" + $2 +else + dnl Note: this test is very weak + kde_python_link_found=no + KDE_TRY_LINK_PYTHON(normal) + KDE_TRY_LINK_PYTHON(m, -lm) + KDE_TRY_LINK_PYTHON(pthread, $LIBPTHREAD) + KDE_TRY_LINK_PYTHON(tcl, -ltcl) + KDE_TRY_LINK_PYTHON(db2, -ldb2) + KDE_TRY_LINK_PYTHON(m_and_thread, [$LIBPTHREAD -lm]) + KDE_TRY_LINK_PYTHON(m_and_thread_and_util, [$LIBPTHREAD -lm -lutil]) + KDE_TRY_LINK_PYTHON(m_and_thread_and_db3, [$LIBPTHREAD -lm -ldb-3 -lutil]) + KDE_TRY_LINK_PYTHON(pthread_and_db3, [$LIBPTHREAD -ldb-3]) + KDE_TRY_LINK_PYTHON(m_and_thread_and_db, [$LIBPTHREAD -lm -ldb -ltermcap -lutil]) + KDE_TRY_LINK_PYTHON(pthread_and_dl, [$LIBPTHREAD $LIBDL -lutil -lreadline -lncurses -lm]) + KDE_TRY_LINK_PYTHON(pthread_and_panel_curses, [$LIBPTHREAD $LIBDL -lm -lpanel -lcurses]) + KDE_TRY_LINK_PYTHON(m_and_thread_and_db_special, [$LIBPTHREAD -lm -ldb -lutil], [], + [AC_MSG_WARN([it seems, Python depends on another library. + Please set LIBPYTHON to '-lpython$version -lotherlib' before calling configure to fix this + and contact the authors to let them know about this problem]) + ]) + + LIBPYTHON="$LIBPYTHON $LIBDL $LIBSOCKET" + AC_SUBST(PYTHONINC) + AC_SUBST(PYTHONLIB) + AC_SUBST(LIBPYTHON) + AC_SUBST(PYTHONMODDIR) + AC_DEFINE(HAVE_PYTHON, 1, [Define if you have the development files for python]) +fi + +]) + + +AC_DEFUN([KDE_CHECK_PYTHON], +[ + KDE_CHECK_PYTHON_INTERN("2.3", + [KDE_CHECK_PYTHON_INTERN("2.2", + [KDE_CHECK_PYTHON_INTERN("2.1", + [KDE_CHECK_PYTHON_INTERN("2.0", + [KDE_CHECK_PYTHON_INTERN($1, $2) ]) + ]) + ]) + ]) +]) + +AC_DEFUN([KDE_CHECK_STL], +[ + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + ac_save_CXXFLAGS="$CXXFLAGS" + CXXFLAGS="`echo $CXXFLAGS | sed s/-fno-exceptions//`" + + AC_MSG_CHECKING([if C++ programs can be compiled]) + AC_CACHE_VAL(kde_cv_stl_works, + [ + AC_TRY_COMPILE([ +#include +using namespace std; +],[ + string astring="Hallo Welt."; + astring.erase(0, 6); // now astring is "Welt" + return 0; +], kde_cv_stl_works=yes, + kde_cv_stl_works=no) +]) + + AC_MSG_RESULT($kde_cv_stl_works) + + if test "$kde_cv_stl_works" = "yes"; then + # back compatible + AC_DEFINE_UNQUOTED(HAVE_SGI_STL, 1, [Define if you have a STL implementation by SGI]) + else + AC_MSG_ERROR([Your Installation isn't able to compile simple C++ programs. +Check config.log for details - if you're using a Linux distribution you might miss +a package named similiar to libstd++-dev.]) + fi + + CXXFLAGS="$ac_save_CXXFLAGS" + AC_LANG_RESTORE +]) + +AC_DEFUN([AC_FIND_QIMGIO], + [AC_REQUIRE([AC_FIND_JPEG]) +AC_REQUIRE([KDE_CHECK_EXTRA_LIBS]) +AC_MSG_CHECKING([for qimgio]) +AC_CACHE_VAL(ac_cv_lib_qimgio, +[ +AC_LANG_SAVE +AC_LANG_CPLUSPLUS +ac_save_LIBS="$LIBS" +ac_save_CXXFLAGS="$CXXFLAGS" +LIBS="$all_libraries -lqimgio -lpng -lz $LIBJPEG $LIBQT" +CXXFLAGS="$CXXFLAGS -I$qt_incdir $all_includes" +AC_TRY_RUN(dnl +[ +#include +#include +int main() { + QString t = "hallo"; + t.fill('t'); + qInitImageIO(); +} +], + ac_cv_lib_qimgio=yes, + ac_cv_lib_qimgio=no, + ac_cv_lib_qimgio=no) +LIBS="$ac_save_LIBS" +CXXFLAGS="$ac_save_CXXFLAGS" +AC_LANG_RESTORE +])dnl +if eval "test \"`echo $ac_cv_lib_qimgio`\" = yes"; then + LIBQIMGIO="-lqimgio -lpng -lz $LIBJPEG" + AC_MSG_RESULT(yes) + AC_DEFINE_UNQUOTED(HAVE_QIMGIO, 1, [Define if you have the Qt extension qimgio available]) + AC_SUBST(LIBQIMGIO) +else + AC_MSG_RESULT(not found) +fi +]) + +AC_DEFUN([AM_DISABLE_LIBRARIES], +[ + AC_PROVIDE([AM_ENABLE_STATIC]) + AC_PROVIDE([AM_ENABLE_SHARED]) + enable_static=no + enable_shared=yes +]) + + +AC_DEFUN([AC_CHECK_UTMP_FILE], +[ + AC_MSG_CHECKING([for utmp file]) + + AC_CACHE_VAL(kde_cv_utmp_file, + [ + kde_cv_utmp_file=no + + for ac_file in \ + \ + /var/run/utmp \ + /var/adm/utmp \ + /etc/utmp \ + ; \ + do + if test -r "$ac_file"; then + kde_cv_utmp_file=$ac_file + break + fi + done + ]) + + if test "$kde_cv_utmp_file" != "no"; then + AC_DEFINE_UNQUOTED(UTMP, "$kde_cv_utmp_file", [Define the file for utmp entries]) + $1 + AC_MSG_RESULT($kde_cv_utmp_file) + else + $2 + AC_MSG_RESULT([non found]) + fi +]) + + +AC_DEFUN([KDE_CREATE_SUBDIRSLIST], +[ + +DO_NOT_COMPILE="$DO_NOT_COMPILE CVS debian bsd-port admin" + +if test ! -s $srcdir/subdirs; then + dnl Note: Makefile.common creates subdirs, so this is just a fallback + TOPSUBDIRS="" + files=`cd $srcdir && ls -1` + dirs=`for i in $files; do if test -d $i; then echo $i; fi; done` + for i in $dirs; do + echo $i >> $srcdir/subdirs + done +fi + +ac_topsubdirs= +if test -s $srcdir/inst-apps; then + ac_topsubdirs="`cat $srcdir/inst-apps`" +elif test -s $srcdir/subdirs; then + ac_topsubdirs="`cat $srcdir/subdirs`" +fi + +for i in $ac_topsubdirs; do + AC_MSG_CHECKING([if $i should be compiled]) + if test -d $srcdir/$i; then + install_it="yes" + for j in $DO_NOT_COMPILE; do + if test $i = $j; then + install_it="no" + fi + done + else + install_it="no" + fi + AC_MSG_RESULT($install_it) + vari=`echo $i | sed -e 's,[[-+.]],_,g'` + if test $install_it = "yes"; then + TOPSUBDIRS="$TOPSUBDIRS $i" + eval "$vari""_SUBDIR_included=yes" + else + eval "$vari""_SUBDIR_included=no" + fi +done + +AC_SUBST(TOPSUBDIRS) +]) + +AC_DEFUN([KDE_CHECK_NAMESPACES], +[ +AC_MSG_CHECKING(whether C++ compiler supports namespaces) +AC_LANG_SAVE +AC_LANG_CPLUSPLUS +AC_TRY_COMPILE([ +], +[ +namespace Foo { + extern int i; + namespace Bar { + extern int i; + } +} + +int Foo::i = 0; +int Foo::Bar::i = 1; +],[ + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_NAMESPACES) +], [ +AC_MSG_RESULT(no) +]) +AC_LANG_RESTORE +]) + +dnl ------------------------------------------------------------------------ +dnl Check for S_ISSOCK macro. Doesn't exist on Unix SCO. faure@kde.org +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_CHECK_S_ISSOCK], +[ +AC_MSG_CHECKING(for S_ISSOCK) +AC_CACHE_VAL(ac_cv_have_s_issock, +[ +AC_TRY_LINK( +[ +#include +], +[ +struct stat buff; +int b = S_ISSOCK( buff.st_mode ); +], +ac_cv_have_s_issock=yes, +ac_cv_have_s_issock=no) +]) +AC_MSG_RESULT($ac_cv_have_s_issock) +if test "$ac_cv_have_s_issock" = "yes"; then + AC_DEFINE_UNQUOTED(HAVE_S_ISSOCK, 1, [Define if sys/stat.h declares S_ISSOCK.]) +fi + +AH_VERBATIM(_ISSOCK, +[ +#ifndef HAVE_S_ISSOCK +#define HAVE_S_ISSOCK +#define S_ISSOCK(mode) (1==0) +#endif +]) + +]) + +dnl ------------------------------------------------------------------------ +dnl Check for MAXPATHLEN macro, defines KDEMAXPATHLEN. faure@kde.org +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([AC_CHECK_KDEMAXPATHLEN], +[ +AC_MSG_CHECKING(for MAXPATHLEN) +AC_CACHE_VAL(ac_cv_maxpathlen, +[ +cat > conftest.$ac_ext < +#endif +#include +#include +#ifndef MAXPATHLEN +#define MAXPATHLEN 1024 +#endif + +KDE_HELLO MAXPATHLEN + +EOF + +ac_try="$ac_cpp conftest.$ac_ext 2>/dev/null | grep '^KDE_HELLO' >conftest.out" + +if AC_TRY_EVAL(ac_try) && test -s conftest.out; then + ac_cv_maxpathlen=`sed 's#KDE_HELLO ##' conftest.out` +else + ac_cv_maxpathlen=1024 +fi + +rm conftest.* + +]) +AC_MSG_RESULT($ac_cv_maxpathlen) +AC_DEFINE_UNQUOTED(KDEMAXPATHLEN,$ac_cv_maxpathlen, [Define a safe value for MAXPATHLEN] ) +]) + +AC_DEFUN([KDE_CHECK_HEADER], +[ + AC_LANG_SAVE + kde_safe_cppflags=$CPPFLAGS + CPPFLAGS="$CPPFLAGS $all_includes" + AC_LANG_CPLUSPLUS + AC_CHECK_HEADER([$1], [$2], [$3], [$4]) + CPPFLAGS=$kde_safe_cppflags + AC_LANG_RESTORE +]) + +AC_DEFUN([KDE_CHECK_HEADERS], +[ + AH_CHECK_HEADERS([$1]) + AC_LANG_SAVE + kde_safe_cppflags=$CPPFLAGS + CPPFLAGS="$CPPFLAGS $all_includes" + AC_LANG_CPLUSPLUS + AC_CHECK_HEADERS([$1], [$2], [$3], [$4]) + CPPFLAGS=$kde_safe_cppflags + AC_LANG_RESTORE +]) + +AC_DEFUN([KDE_FAST_CONFIGURE], +[ + dnl makes configure fast (needs perl) + AC_ARG_ENABLE(fast-perl, AC_HELP_STRING([--disable-fast-perl],[disable fast Makefile generation (needs perl)]), + with_fast_perl=$enableval, with_fast_perl=yes) +]) + +AC_DEFUN([KDE_CONF_FILES], +[ + val= + if test -f $srcdir/configure.files ; then + val=`sed -e 's%^%\$(top_srcdir)/%' $srcdir/configure.files` + fi + CONF_FILES= + if test -n "$val" ; then + for i in $val ; do + CONF_FILES="$CONF_FILES $i" + done + fi + AC_SUBST(CONF_FILES) +])dnl + +AC_DEFUN([KDE_SET_PREFIX], +[ + unset CDPATH + dnl make $KDEDIR the default for the installation + AC_PREFIX_DEFAULT(${KDEDIR:-/usr/local/kde}) + + if test "x$prefix" = "xNONE"; then + prefix=$ac_default_prefix + ac_configure_args="$ac_configure_args --prefix=$prefix" + fi + # And delete superfluous '/' to make compares easier + prefix=`echo "$prefix" | sed 's,//*,/,g' | sed -e 's,/$,,'` + exec_prefix=`echo "$exec_prefix" | sed 's,//*,/,g' | sed -e 's,/$,,'` + KDE_FAST_CONFIGURE + KDE_CONF_FILES +]) + +pushdef([AC_PROG_INSTALL], +[ + dnl our own version, testing for a -p flag + popdef([AC_PROG_INSTALL]) + dnl as AC_PROG_INSTALL works as it works we first have + dnl to save if the user didn't specify INSTALL, as the + dnl autoconf one overwrites INSTALL and we have no chance to find + dnl out afterwards + test -n "$INSTALL" && kde_save_INSTALL_given=$INSTALL + test -n "$INSTALL_PROGRAM" && kde_save_INSTALL_PROGRAM_given=$INSTALL_PROGRAM + test -n "$INSTALL_SCRIPT" && kde_save_INSTALL_SCRIPT_given=$INSTALL_SCRIPT + AC_PROG_INSTALL + + if test -z "$kde_save_INSTALL_given" ; then + # OK, user hasn't given any INSTALL, autoconf found one for us + # now we test, if it supports the -p flag + AC_MSG_CHECKING(for -p flag to install) + rm -f confinst.$$.* > /dev/null 2>&1 + echo "Testtest" > confinst.$$.orig + ac_res=no + if ${INSTALL} -p confinst.$$.orig confinst.$$.new > /dev/null 2>&1 ; then + if test -f confinst.$$.new ; then + # OK, -p seems to do no harm to install + INSTALL="${INSTALL} -p" + ac_res=yes + fi + fi + rm -f confinst.$$.* + AC_MSG_RESULT($ac_res) + fi + dnl the following tries to resolve some signs and wonders coming up + dnl with different autoconf/automake versions + dnl e.g.: + dnl *automake 1.4 install-strip sets A_M_INSTALL_PROGRAM_FLAGS to -s + dnl and has INSTALL_PROGRAM = @INSTALL_PROGRAM@ $(A_M_INSTALL_PROGRAM_FLAGS) + dnl it header-vars.am, so there the actual INSTALL_PROGRAM gets the -s + dnl *automake 1.4a (and above) use INSTALL_STRIP_FLAG and only has + dnl INSTALL_PROGRAM = @INSTALL_PROGRAM@ there, but changes the + dnl install-@DIR@PROGRAMS targets to explicitly use that flag + dnl *autoconf 2.13 is dumb, and thinks it can use INSTALL_PROGRAM as + dnl INSTALL_SCRIPT, which breaks with automake <= 1.4 + dnl *autoconf >2.13 (since 10.Apr 1999) has not that failure + dnl *sometimes KDE does not use the install-@DIR@PROGRAM targets from + dnl automake (due to broken Makefile.am or whatever) to install programs, + dnl and so does not see the -s flag in automake > 1.4 + dnl to clean up that mess we: + dnl +set INSTALL_PROGRAM to use INSTALL_STRIP_FLAG + dnl which cleans KDE's program with automake > 1.4; + dnl +set INSTALL_SCRIPT to only use INSTALL, to clean up autoconf's problems + dnl with automake<=1.4 + dnl note that dues to this sometimes two '-s' flags are used (if KDE + dnl properly uses install-@DIR@PROGRAMS, but I don't care + dnl + dnl And to all this comes, that I even can't write in comments variable + dnl names used by automake, because it is so stupid to think I wanted to + dnl _use_ them, therefor I have written A_M_... instead of AM_ + dnl hmm, I wanted to say something ... ahh yes: Arghhh. + + if test -z "$kde_save_INSTALL_PROGRAM_given" ; then + INSTALL_PROGRAM='${INSTALL} $(INSTALL_STRIP_FLAG)' + fi + if test -z "$kde_save_INSTALL_SCRIPT_given" ; then + INSTALL_SCRIPT='${INSTALL}' + fi +])dnl + +AC_DEFUN([KDE_LANG_CPLUSPLUS], +[AC_LANG_CPLUSPLUS +ac_link='rm -rf SunWS_cache; ${CXX-g++} -o conftest${ac_exeext} $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS 1>&AC_FD_CC' +pushdef([AC_LANG_CPLUSPLUS], [popdef([AC_LANG_CPLUSPLUS]) KDE_LANG_CPLUSPLUS]) +]) + +pushdef([AC_LANG_CPLUSPLUS], +[popdef([AC_LANG_CPLUSPLUS]) +KDE_LANG_CPLUSPLUS +]) + +AC_DEFUN([KDE_CHECK_LONG_LONG], +[ +AC_MSG_CHECKING(for long long) +AC_CACHE_VAL(kde_cv_c_long_long, +[ + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + AC_TRY_LINK([], [ + long long foo = 0; + foo = foo+1; + ], + kde_cv_c_long_long=yes, kde_cv_c_long_long=no) + AC_LANG_RESTORE +]) +AC_MSG_RESULT($kde_cv_c_long_long) +if test "$kde_cv_c_long_long" = yes; then + AC_DEFINE(HAVE_LONG_LONG, 1, [Define if you have long long as datatype]) +fi +]) + +AC_DEFUN([KDE_CHECK_LIB], +[ + kde_save_LDFLAGS="$LDFLAGS" + dnl AC_CHECK_LIB modifies LIBS, so save it here + kde_save_LIBS="$LIBS" + LDFLAGS="$LDFLAGS $all_libraries" + case $host_os in + aix*) LDFLAGS="-brtl $LDFLAGS" + test "$GCC" = yes && LDFLAGS="-Wl,$LDFLAGS" + ;; + esac + AC_CHECK_LIB($1, $2, $3, $4, $5) + LDFLAGS="$kde_save_LDFLAGS" + LIBS="$kde_save_LIBS" +]) + +AC_DEFUN([KDE_JAVA_PREFIX], +[ + dir=`dirname "$1"` + base=`basename "$1"` + list=`ls -1 $dir 2> /dev/null` + for entry in $list; do + if test -d $dir/$entry/bin; then + case $entry in + $base) + javadirs="$javadirs $dir/$entry/bin" + ;; + esac + elif test -d $dir/$entry/jre/bin; then + case $entry in + $base) + javadirs="$javadirs $dir/$entry/jre/bin" + ;; + esac + fi + done +]) + +dnl KDE_CHEC_JAVA_DIR(onlyjre) +AC_DEFUN([KDE_CHECK_JAVA_DIR], +[ + +AC_ARG_WITH(java, +AC_HELP_STRING([--with-java=javadir],[use java installed in javadir, --without-java disables]), +[ ac_java_dir=$withval +], ac_java_dir="" +) + +AC_MSG_CHECKING([for Java]) + +dnl at this point ac_java_dir is either a dir, 'no' to disable, or '' to say look in $PATH +if test "x$ac_java_dir" = "xno"; then + kde_java_bindir=no + kde_java_includedir=no + kde_java_libjvmdir=no + kde_java_libgcjdir=no + kde_java_libhpidir=no +else + if test "x$ac_java_dir" = "x"; then + + + dnl No option set -> collect list of candidate paths + if test -n "$JAVA_HOME"; then + KDE_JAVA_PREFIX($JAVA_HOME) + fi + KDE_JAVA_PREFIX(/usr/j2se) + KDE_JAVA_PREFIX(/usr/lib/j2se) + KDE_JAVA_PREFIX(/usr/j*dk*) + KDE_JAVA_PREFIX(/usr/lib/j*dk*) + KDE_JAVA_PREFIX(/opt/j*sdk*) + KDE_JAVA_PREFIX(/usr/lib/java*) + KDE_JAVA_PREFIX(/usr/java*) + KDE_JAVA_PREFIX(/usr/java/j*dk*) + KDE_JAVA_PREFIX(/usr/java/j*re*) + KDE_JAVA_PREFIX(/usr/lib/SunJava2*) + KDE_JAVA_PREFIX(/usr/lib/SunJava*) + KDE_JAVA_PREFIX(/usr/lib/IBMJava2*) + KDE_JAVA_PREFIX(/usr/lib/IBMJava*) + KDE_JAVA_PREFIX(/opt/java*) + + kde_cv_path="NONE" + kde_save_IFS=$IFS + IFS=':' + for dir in $PATH; do + if test -d "$dir"; then + javadirs="$javadirs $dir" + fi + done + IFS=$kde_save_IFS + jredirs= + + dnl Now javadirs contains a list of paths that exist, all ending with bin/ + for dir in $javadirs; do + dnl Check for the java executable + if test -x "$dir/java"; then + dnl And also check for a libjvm.so somewhere under there + dnl Since we have to go to the parent dir, /usr/bin is excluded, /usr is too big. + if test "$dir" != "/usr/bin"; then + libjvmdir=`find $dir/.. -name libjvm.so | sed 's,libjvm.so,,'|head -n 1` + if test ! -f $libjvmdir/libjvm.so; then continue; fi + jredirs="$jredirs $dir" + fi + fi + done + + dnl Now jredirs contains a reduced list, of paths where both java and ../**/libjvm.so was found + JAVAC= + JAVA= + kde_java_bindir=no + for dir in $jredirs; do + JAVA="$dir/java" + kde_java_bindir=$dir + if test -x "$dir/javac"; then + JAVAC="$dir/javac" + break + fi + done + + if test -n "$JAVAC"; then + dnl this substitution might not work - well, we test for jni.h below + kde_java_includedir=`echo $JAVAC | sed -e 's,bin/javac$,include/,'` + else + kde_java_includedir=no + fi + else + dnl config option set + kde_java_bindir=$ac_java_dir/bin + if test -x $ac_java_dir/bin/java && test ! -x $ac_java_dir/bin/javac; then + kde_java_includedir=no + else + kde_java_includedir=$ac_java_dir/include + fi + fi +fi + +dnl At this point kde_java_bindir and kde_java_includedir are either set or "no" +if test "x$kde_java_bindir" != "xno"; then + + dnl Look for libjvm.so + kde_java_libjvmdir=`find $kde_java_bindir/.. -name libjvm.so | sed 's,libjvm.so,,'|head -n 1` + dnl Look for libgcj.so + kde_java_libgcjdir=`find $kde_java_bindir/.. -name libgcj.so | sed 's,libgcj.so,,'|head -n 1` + dnl Look for libhpi.so and avoid green threads + kde_java_libhpidir=`find $kde_java_bindir/.. -name libhpi.so | grep -v green | sed 's,libhpi.so,,' | head -n 1` + + dnl Now check everything's fine under there + dnl the include dir is our flag for having the JDK + if test -d "$kde_java_includedir"; then + if test ! -x "$kde_java_bindir/javac"; then + AC_MSG_ERROR([javac not found under $kde_java_bindir - it seems you passed a wrong --with-java.]) + fi + if test ! -x "$kde_java_bindir/javah"; then + AC_MSG_ERROR([javah not found under $kde_java_bindir. javac was found though! Use --with-java or --without-java.]) + fi + if test ! -x "$kde_java_bindir/jar"; then + AC_MSG_ERROR([jar not found under $kde_java_bindir. javac was found though! Use --with-java or --without-java.]) + fi + if test ! -r "$kde_java_includedir/jni.h"; then + AC_MSG_ERROR([jni.h not found under $kde_java_includedir. Use --with-java or --without-java.]) + fi + + jni_includes="-I$kde_java_includedir" + dnl Strange thing, jni.h requires jni_md.h which is under genunix here.. + dnl and under linux here.. + + dnl not needed for gcj + + if test "x$kde_java_libgcjdir" = "x"; then + test -d "$kde_java_includedir/linux" && jni_includes="$jni_includes -I$kde_java_includedir/linux" + test -d "$kde_java_includedir/solaris" && jni_includes="$jni_includes -I$kde_java_includedir/solaris" + test -d "$kde_java_includedir/genunix" && jni_includes="$jni_includes -I$kde_java_includedir/genunix" + fi + + else + JAVAC= + jni_includes= + fi + + if test "x$kde_java_libgcjdir" = "x"; then + if test ! -r "$kde_java_libjvmdir/libjvm.so"; then + AC_MSG_ERROR([libjvm.so not found under $kde_java_libjvmdir. Use --without-java.]) + fi + else + if test ! -r "$kde_java_libgcjdir/libgcj.so"; then + AC_MSG_ERROR([libgcj.so not found under $kde_java_libgcjdir. Use --without-java.]) + fi + fi + + if test ! -x "$kde_java_bindir/java"; then + AC_MSG_ERROR([java not found under $kde_java_bindir. javac was found though! Use --with-java or --without-java.]) + fi + + dnl not needed for gcj compile + + if test "x$kde_java_libgcjdir" = "x"; then + if test ! -r "$kde_java_libhpidir/libhpi.so"; then + AC_MSG_ERROR([libhpi.so not found under $kde_java_libhpidir. Use --without-java.]) + fi + fi + + if test -n "$jni_includes"; then + dnl Check for JNI version + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + ac_cxxflags_safe="$CXXFLAGS" + CXXFLAGS="$CXXFLAGS $all_includes $jni_includes" + + AC_TRY_COMPILE([ + #include + ], + [ + #ifndef JNI_VERSION_1_2 + Syntax Error + #endif + ],[ kde_jni_works=yes ], + [ kde_jni_works=no ]) + + if test $kde_jni_works = no; then + AC_MSG_ERROR([Incorrect version of $kde_java_includedir/jni.h. + You need to have Java Development Kit (JDK) version 1.2. + + Use --with-java to specify another location. + Use --without-java to configure without java support. + Or download a newer JDK and try again. + See e.g. http://java.sun.com/products/jdk/1.2 ]) + fi + + CXXFLAGS="$ac_cxxflags_safe" + AC_LANG_RESTORE + + dnl All tests ok, inform and subst the variables + + JAVAC=$kde_java_bindir/javac + JAVAH=$kde_java_bindir/javah + JAR=$kde_java_bindir/jar + AC_DEFINE_UNQUOTED(PATH_JAVA, "$kde_java_bindir/java", [Define where your java executable is]) + if test "x$kde_java_libgcjdir" = "x"; then + JVMLIBS="-L$kde_java_libjvmdir -ljvm -L$kde_java_libhpidir -lhpi" + else + JVMLIBS="-L$kde_java_libgcjdir -lgcj" + fi + AC_MSG_RESULT([java JDK in $kde_java_bindir]) + + else + AC_DEFINE_UNQUOTED(PATH_JAVA, "$kde_java_bindir/java", [Define where your java executable is]) + AC_MSG_RESULT([java JRE in $kde_java_bindir]) + fi +elif test -d "/Library/Java/Home"; then + kde_java_bindir="/Library/Java/Home/bin" + jni_includes="-I/Library/Java/Home/include" + + JAVAC=$kde_java_bindir/javac + JAVAH=$kde_java_bindir/javah + JAR=$kde_java_bindir/jar + JVMLIBS="-Xlinker -framework -Xlinker JavaVM" + + AC_DEFINE_UNQUOTED(PATH_JAVA, "$kde_java_bindir/java", [Define where your java executable is]) + AC_MSG_RESULT([Apple Java Framework]) +else + AC_MSG_RESULT([none found]) +fi + +AC_SUBST(JAVAC) +AC_SUBST(JAVAH) +AC_SUBST(JAR) +AC_SUBST(JVMLIBS) +AC_SUBST(jni_includes) + +# for backward compat +kde_cv_java_includedir=$kde_java_includedir +kde_cv_java_bindir=$kde_java_bindir +]) + +dnl this is a redefinition of autoconf 2.5x's AC_FOREACH. +dnl When the argument list becomes big, as in KDE for AC_OUTPUT in +dnl big packages, m4_foreach is dog-slow. So use our own version of +dnl it. (matz@kde.org) +m4_define([mm_foreach], +[m4_pushdef([$1])_mm_foreach($@)m4_popdef([$1])]) +m4_define([mm_car], [[$1]]) +m4_define([mm_car2], [[$@]]) +m4_define([_mm_foreach], +[m4_if(m4_quote($2), [], [], + [m4_define([$1], mm_car($2))$3[]_mm_foreach([$1], + mm_car2(m4_shift($2)), + [$3])])]) +m4_define([AC_FOREACH], +[mm_foreach([$1], m4_split(m4_normalize([$2])), [$3])]) + +AC_DEFUN([KDE_NEED_FLEX], +[ +kde_libs_safe=$LIBS +LIBS="$LIBS $USER_LDFLAGS" +AM_PROG_LEX +LIBS=$kde_libs_safe +if test -z "$LEXLIB"; then + AC_MSG_ERROR([You need to have flex installed.]) +fi +AC_SUBST(LEXLIB) +]) + +AC_DEFUN([AC_PATH_QTOPIA], +[ + dnl TODO: use AC_CACHE_VAL + + if test -z "$1"; then + qtopia_minver_maj=1 + qtopia_minver_min=5 + qtopia_minver_pat=0 + else + qtopia_minver_maj=`echo "$1" | sed -e "s/^\(.*\)\..*\..*$/\1/"` + qtopia_minver_min=`echo "$1" | sed -e "s/^.*\.\(.*\)\..*$/\1/"` + qtopia_minver_pat=`echo "$1" | sed -e "s/^.*\..*\.\(.*\)$/\1/"` + fi + + qtopia_minver="$qtopia_minver_maj$qtopia_minver_min$qtopia_minver_pat" + qtopia_minverstr="$qtopia_minver_maj.$qtopia_minver_min.$qtopia_minver_pat" + + AC_REQUIRE([AC_PATH_QT]) + + AC_MSG_CHECKING([for Qtopia]) + + LIB_QTOPIA="-lqpe" + AC_SUBST(LIB_QTOPIA) + + kde_qtopia_dirs="$QPEDIR /opt/Qtopia" + + ac_qtopia_incdir=NO + + AC_ARG_WITH(qtopia-dir, + AC_HELP_STRING([--with-qtopia-dir=DIR],[where the root of Qtopia is installed]), + [ ac_qtopia_incdir="$withval"/include] ) + + qtopia_incdirs="" + for dir in $kde_qtopia_dirs; do + qtopia_incdirs="$qtopia_incdirs $dir/include" + done + + if test ! "$ac_qtopia_incdir" = "NO"; then + qtopia_incdirs="$ac_qtopia_incdir $qtopia_incdirs" + fi + + qtopia_incdir="" + AC_FIND_FILE(qpe/qpeapplication.h, $qtopia_incdirs, qtopia_incdir) + ac_qtopia_incdir="$qtopia_incdir" + + if test -z "$qtopia_incdir"; then + AC_MSG_ERROR([Cannot find Qtopia headers. Please check your installation.]) + fi + + qtopia_ver_maj=`cat $qtopia_incdir/qpe/version.h | sed -n -e 's,.*QPE_VERSION "\(.*\)\..*\..*".*,\1,p'`; + qtopia_ver_min=`cat $qtopia_incdir/qpe/version.h | sed -n -e 's,.*QPE_VERSION ".*\.\(.*\)\..*".*,\1,p'`; + qtopia_ver_pat=`cat $qtopia_incdir/qpe/version.h | sed -n -e 's,.*QPE_VERSION ".*\..*\.\(.*\)".*,\1,p'`; + + qtopia_ver="$qtopia_ver_maj$qtopia_ver_min$qtopia_ver_pat" + qtopia_verstr="$qtopia_ver_maj.$qtopia_ver_min.$qtopia_ver_pat" + if test "$qtopia_ver" -lt "$qtopia_minver"; then + AC_MSG_ERROR([found Qtopia version $qtopia_verstr but version $qtopia_minverstr +is required.]) + fi + + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + + ac_cxxflags_safe="$CXXFLAGS" + ac_ldflags_safe="$LDFLAGS" + ac_libs_safe="$LIBS" + + CXXFLAGS="$CXXFLAGS -I$qtopia_incdir $all_includes" + LDFLAGS="$LDFLAGS $QT_LDFLAGS $all_libraries $USER_LDFLAGS $KDE_MT_LDFLAGS" + LIBS="$LIBS $LIB_QTOPIA $LIBQT" + + cat > conftest.$ac_ext < +#include + +int main( int argc, char **argv ) +{ + QPEApplication app( argc, argv ); + return 0; +} +EOF + + if AC_TRY_EVAL(ac_link) && test -s conftest; then + rm -f conftest* + else + rm -f conftest* + AC_MSG_ERROR([Cannot link small Qtopia Application. For more details look at +the end of config.log]) + fi + + CXXFLAGS="$ac_cxxflags_safe" + LDFLAGS="$ac_ldflags_safe" + LIBS="$ac_libs_safe" + + AC_LANG_RESTORE + + QTOPIA_INCLUDES="-I$qtopia_incdir" + AC_SUBST(QTOPIA_INCLUDES) + + AC_MSG_RESULT([found version $qtopia_verstr with headers at $qtopia_incdir]) +]) + + +AC_DEFUN([KDE_INIT_DOXYGEN], +[ +AC_MSG_CHECKING([for Qt docs]) +kde_qtdir= +if test "${with_qt_dir+set}" = set; then + kde_qtdir="$with_qt_dir" +fi + +AC_FIND_FILE(qsql.html, [ $kde_qtdir/doc/html $QTDIR/doc/html /usr/share/doc/packages/qt3/html /usr/lib/qt/doc /usr/lib/qt3/doc /usr/lib/qt3/doc/html /usr/doc/qt3/html /usr/doc/qt3 /usr/share/doc/qt3-doc /usr/share/qt3/doc/html /usr/X11R6/share/doc/qt/html ], QTDOCDIR) +AC_MSG_RESULT($QTDOCDIR) + +AC_SUBST(QTDOCDIR) + +KDE_FIND_PATH(dot, DOT, [], []) +if test -n "$DOT"; then + KDE_HAVE_DOT="YES" +else + KDE_HAVE_DOT="NO" +fi +AC_SUBST(KDE_HAVE_DOT) +KDE_FIND_PATH(doxygen, DOXYGEN, [], []) +AC_SUBST(DOXYGEN) + +DOXYGEN_PROJECT_NAME="$1" +DOXYGEN_PROJECT_NUMBER="$2" +AC_SUBST(DOXYGEN_PROJECT_NAME) +AC_SUBST(DOXYGEN_PROJECT_NUMBER) + +KDE_HAS_DOXYGEN=no +if test -n "$DOXYGEN" && test -x "$DOXYGEN" && test -f $QTDOCDIR/qsql.html; then + KDE_HAS_DOXYGEN=yes +fi +AC_SUBST(KDE_HAS_DOXYGEN) + +]) + + +AC_DEFUN([AC_FIND_BZIP2], +[ +AC_MSG_CHECKING([for bzDecompress in libbz2]) +AC_CACHE_VAL(ac_cv_lib_bzip2, +[ +AC_LANG_SAVE +AC_LANG_CPLUSPLUS +kde_save_LIBS="$LIBS" +LIBS="$all_libraries $USER_LDFLAGS -lbz2 $LIBSOCKET" +kde_save_CXXFLAGS="$CXXFLAGS" +CXXFLAGS="$CXXFLAGS $all_includes $USER_INCLUDES" +AC_TRY_LINK(dnl +[ +#define BZ_NO_STDIO +#include +], + [ bz_stream s; (void) bzDecompress(&s); ], + eval "ac_cv_lib_bzip2='-lbz2'", + eval "ac_cv_lib_bzip2=no") +LIBS="$kde_save_LIBS" +CXXFLAGS="$kde_save_CXXFLAGS" +AC_LANG_RESTORE +])dnl +AC_MSG_RESULT($ac_cv_lib_bzip2) + +if test ! "$ac_cv_lib_bzip2" = no; then + BZIP2DIR=bzip2 + + LIBBZ2="$ac_cv_lib_bzip2" + AC_SUBST(LIBBZ2) + +else + + cxx_shared_flag= + ld_shared_flag= + KDE_CHECK_COMPILER_FLAG(shared, [ + ld_shared_flag="-shared" + ]) + KDE_CHECK_COMPILER_FLAG(fPIC, [ + cxx_shared_flag="-fPIC" + ]) + + AC_MSG_CHECKING([for BZ2_bzDecompress in (shared) libbz2]) + AC_CACHE_VAL(ac_cv_lib_bzip2_prefix, + [ + AC_LANG_SAVE + AC_LANG_CPLUSPLUS + kde_save_LIBS="$LIBS" + LIBS="$all_libraries $USER_LDFLAGS $ld_shared_flag -lbz2 $LIBSOCKET" + kde_save_CXXFLAGS="$CXXFLAGS" + CXXFLAGS="$CFLAGS $cxx_shared_flag $all_includes $USER_INCLUDES" + + AC_TRY_LINK(dnl + [ + #define BZ_NO_STDIO + #include + ], + [ bz_stream s; (void) BZ2_bzDecompress(&s); ], + eval "ac_cv_lib_bzip2_prefix='-lbz2'", + eval "ac_cv_lib_bzip2_prefix=no") + LIBS="$kde_save_LIBS" + CXXFLAGS="$kde_save_CXXFLAGS" + AC_LANG_RESTORE + ])dnl + + AC_MSG_RESULT($ac_cv_lib_bzip2_prefix) + + if test ! "$ac_cv_lib_bzip2_prefix" = no; then + BZIP2DIR=bzip2 + + LIBBZ2="$ac_cv_lib_bzip2_prefix" + AC_SUBST(LIBBZ2) + + AC_DEFINE(NEED_BZ2_PREFIX, 1, [Define if the libbz2 functions need the BZ2_ prefix]) + dnl else, we just ignore this + fi + +fi +AM_CONDITIONAL(include_BZIP2, test -n "$BZIP2DIR") +]) + +dnl ------------------------------------------------------------------------ +dnl Try to find the SSL headers and libraries. +dnl $(SSL_LDFLAGS) will be -Lsslliblocation (if needed) +dnl and $(SSL_INCLUDES) will be -Isslhdrlocation (if needed) +dnl ------------------------------------------------------------------------ +dnl +AC_DEFUN([KDE_CHECK_SSL], +[ +LIBSSL="-lssl -lcrypto" +AC_REQUIRE([KDE_CHECK_LIB64]) + +ac_ssl_includes=NO ac_ssl_libraries=NO +ssl_libraries="" +ssl_includes="" +AC_ARG_WITH(ssl-dir, + AC_HELP_STRING([--with-ssl-dir=DIR],[where the root of OpenSSL is installed]), + [ ac_ssl_includes="$withval"/include + ac_ssl_libraries="$withval"/lib$kdelibsuff + ]) + +want_ssl=yes +AC_ARG_WITH(ssl, + AC_HELP_STRING([--without-ssl],[disable SSL checks]), + [want_ssl=$withval]) + +if test $want_ssl = yes; then + +AC_MSG_CHECKING(for OpenSSL) + +AC_CACHE_VAL(ac_cv_have_ssl, +[#try to guess OpenSSL locations + + ssl_incdirs="/usr/include /usr/local/include /usr/ssl/include /usr/local/ssl/include $prefix/include $kde_extra_includes" + ssl_incdirs="$ac_ssl_includes $ssl_incdirs" + AC_FIND_FILE(openssl/ssl.h, $ssl_incdirs, ssl_incdir) + ac_ssl_includes="$ssl_incdir" + + ssl_libdirs="/usr/lib$kdelibsuff /usr/local/lib$kdelibsuff /usr/ssl/lib$kdelibsuff /usr/local/ssl/lib$kdelibsuff $libdir $prefix/lib$kdelibsuff $exec_prefix/lib$kdelibsuff $kde_extra_libs" + if test ! "$ac_ssl_libraries" = "NO"; then + ssl_libdirs="$ac_ssl_libraries $ssl_libdirs" + fi + + test=NONE + ssl_libdir=NONE + for dir in $ssl_libdirs; do + try="ls -1 $dir/libssl*" + if test=`eval $try 2> /dev/null`; then ssl_libdir=$dir; break; else echo "tried $dir" >&AC_FD_CC ; fi + done + + ac_ssl_libraries="$ssl_libdir" + + ac_ldflags_safe="$LDFLAGS" + ac_libs_safe="$LIBS" + + LDFLAGS="$LDFLAGS -L$ssl_libdir $all_libraries" + LIBS="$LIBS $LIBSSL -lRSAglue -lrsaref" + + AC_TRY_LINK(,void RSAPrivateEncrypt(void);RSAPrivateEncrypt();, + ac_ssl_rsaref="yes" + , + ac_ssl_rsaref="no" + ) + + LDFLAGS="$ac_ldflags_safe" + LIBS="$ac_libs_safe" + + if test "$ac_ssl_includes" = NO || test "$ac_ssl_libraries" = NO; then + have_ssl=no + else + have_ssl=yes; + fi + + ]) + + eval "$ac_cv_have_ssl" + + AC_MSG_RESULT([libraries $ac_ssl_libraries, headers $ac_ssl_includes]) + + AC_MSG_CHECKING([whether OpenSSL uses rsaref]) + AC_MSG_RESULT($ac_ssl_rsaref) + + AC_MSG_CHECKING([for easter eggs]) + AC_MSG_RESULT([none found]) + +else + have_ssl=no +fi + +if test "$have_ssl" = yes; then + AC_MSG_CHECKING(for OpenSSL version) + dnl Check for SSL version + AC_CACHE_VAL(ac_cv_ssl_version, + [ + + cat >conftest.$ac_ext < +#include + int main() { + +#ifndef OPENSSL_VERSION_NUMBER + printf("ssl_version=\\"error\\"\n"); +#else + if (OPENSSL_VERSION_NUMBER < 0x00906000) + printf("ssl_version=\\"old\\"\n"); + else + printf("ssl_version=\\"ok\\"\n"); +#endif + return (0); + } +EOF + + ac_save_CPPFLAGS=$CPPFLAGS + if test "$ac_ssl_includes" != "/usr/include"; then + CPPFLAGS="$CPPFLAGS -I$ac_ssl_includes" + fi + + if AC_TRY_EVAL(ac_link); then + + if eval `./conftest 2>&5`; then + if test $ssl_version = error; then + AC_MSG_ERROR([$ssl_incdir/openssl/opensslv.h doesn't define OPENSSL_VERSION_NUMBER !]) + else + if test $ssl_version = old; then + AC_MSG_WARN([OpenSSL version too old. Upgrade to 0.9.6 at least, see http://www.openssl.org. SSL support disabled.]) + have_ssl=no + fi + fi + ac_cv_ssl_version="ssl_version=$ssl_version" + else + AC_MSG_ERROR([Your system couldn't run a small SSL test program. + Check config.log, and if you can't figure it out, send a mail to + David Faure , attaching your config.log]) + fi + + else + AC_MSG_ERROR([Your system couldn't link a small SSL test program. + Check config.log, and if you can't figure it out, send a mail to + David Faure , attaching your config.log]) + fi + CPPFLAGS=$ac_save_CPPFLAGS + + ]) + + eval "$ac_cv_ssl_version" + AC_MSG_RESULT($ssl_version) +fi + +if test "$have_ssl" != yes; then + LIBSSL=""; +else + AC_DEFINE(HAVE_SSL, 1, [If we are going to use OpenSSL]) + ac_cv_have_ssl="have_ssl=yes \ + ac_ssl_includes=$ac_ssl_includes ac_ssl_libraries=$ac_ssl_libraries ac_ssl_rsaref=$ac_ssl_rsaref" + + + ssl_libraries="$ac_ssl_libraries" + ssl_includes="$ac_ssl_includes" + + if test "$ac_ssl_rsaref" = yes; then + LIBSSL="-lssl -lcrypto -lRSAglue -lrsaref" + fi + + if test $ssl_version = "old"; then + AC_DEFINE(HAVE_OLD_SSL_API, 1, [Define if you have OpenSSL < 0.9.6]) + fi +fi + +SSL_INCLUDES= + +if test "$ssl_includes" = "/usr/include"; then + if test -f /usr/kerberos/include/krb5.h; then + SSL_INCLUDES="-I/usr/kerberos/include" + fi +elif test "$ssl_includes" != "/usr/local/include" && test -n "$ssl_includes"; then + SSL_INCLUDES="-I$ssl_includes" +fi + +if test "$ssl_libraries" = "/usr/lib" || test "$ssl_libraries" = "/usr/local/lib" || test -z "$ssl_libraries" || test "$ssl_libraries" = "NONE"; then + SSL_LDFLAGS="" +else + SSL_LDFLAGS="-L$ssl_libraries -R$ssl_libraries" +fi + +AC_SUBST(SSL_INCLUDES) +AC_SUBST(SSL_LDFLAGS) +AC_SUBST(LIBSSL) +]) + +AC_DEFUN([KDE_CHECK_STRLCPY], +[ + AC_REQUIRE([AC_CHECK_STRLCAT]) + AC_REQUIRE([AC_CHECK_STRLCPY]) + AC_CHECK_SIZEOF(size_t) + AC_CHECK_SIZEOF(unsigned long) + + AC_MSG_CHECKING([sizeof size_t == sizeof unsigned long]) + AC_TRY_COMPILE(,[ + #if SIZEOF_SIZE_T != SIZEOF_UNSIGNED_LONG + choke me + #endif + ],AC_MSG_RESULT([yes]),[ + AC_MSG_RESULT(no) + AC_MSG_ERROR([ + Apparently on your system our assumption sizeof size_t == sizeof unsigned long + does not apply. Please mail kde-devel@kde.org with a description of your system! + ]) + ]) +]) + +AC_DEFUN([KDE_CHECK_BINUTILS], +[ + AC_MSG_CHECKING([if ld supports unversioned version maps]) + + kde_save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS -Wl,--version-script=conftest.map" + echo "{ local: extern \"C++\" { foo }; };" > conftest.map + AC_TRY_LINK([int foo;], +[ +#ifdef __INTEL_COMPILER +icc apparently does not support libtools version-info and version-script +at the same time. Dunno where the bug is, but until somebody figured out, +better disable the optional version scripts. +#endif + + foo = 42; +], kde_supports_versionmaps=yes, kde_supports_versionmaps=no) + LDFLAGS="$kde_save_LDFLAGS" + rm -f conftest.map + AM_CONDITIONAL(include_VERSION_SCRIPT, + [test "$kde_supports_versionmaps" = "yes" && test "$kde_use_debug_code" = "no"]) + + AC_MSG_RESULT($kde_supports_versionmaps) +]) + +AC_DEFUN([AM_PROG_OBJC],[ +AC_CHECK_PROGS(OBJC, gcc, gcc) +test -z "$OBJC" && AC_MSG_ERROR([no acceptable objective-c gcc found in \$PATH]) +if test "x${OBJCFLAGS-unset}" = xunset; then + OBJCFLAGS="-g -O2" +fi +AC_SUBST(OBJCFLAGS) +_AM_IF_OPTION([no-dependencies],, [_AM_DEPENDENCIES(OBJC)]) +]) + +AC_DEFUN([KDE_CHECK_PERL], +[ + KDE_FIND_PATH(perl, PERL, [$bindir $exec_prefix/bin $prefix/bin], [ + AC_MSG_ERROR([No Perl found in your $PATH. +We need perl to generate some code.]) + ]) + AC_SUBST(PERL) +]) +# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*- +## Copyright 1996, 1997, 1998, 1999, 2000, 2001 +## Free Software Foundation, Inc. +## Originally by Gordon Matzigkeit , 1996 +## +## This program is free software; you can redistribute it and/or modify +## it under the terms of the GNU General Public License as published by +## the Free Software Foundation; either version 2 of the License, or +## (at your option) any later version. +## +## This program is distributed in the hope that it will be useful, but +## WITHOUT ANY WARRANTY; without even the implied warranty of +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +## General Public License for more details. +## +## You should have received a copy of the GNU General Public License +## along with this program; if not, write to the Free Software +## Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +## +## As a special exception to the GNU General Public License, if you +## distribute this file as part of a program that contains a +## configuration script generated by Autoconf, you may include it under +## the same distribution terms that you use for the rest of that program. + +# serial 47 AC_PROG_LIBTOOL + + +# AC_PROVIDE_IFELSE(MACRO-NAME, IF-PROVIDED, IF-NOT-PROVIDED) +# ----------------------------------------------------------- +# If this macro is not defined by Autoconf, define it here. +m4_ifdef([AC_PROVIDE_IFELSE], + [], + [m4_define([AC_PROVIDE_IFELSE], + [m4_ifdef([AC_PROVIDE_$1], + [$2], [$3])])]) + + +# AC_PROG_LIBTOOL +# --------------- +AC_DEFUN([AC_PROG_LIBTOOL], +[AC_REQUIRE([_AC_PROG_LIBTOOL])dnl +dnl If AC_PROG_CXX has already been expanded, run AC_LIBTOOL_CXX +dnl immediately, otherwise, hook it in at the end of AC_PROG_CXX. + AC_PROVIDE_IFELSE([AC_PROG_CXX], + [AC_LIBTOOL_CXX], + [define([AC_PROG_CXX], defn([AC_PROG_CXX])[AC_LIBTOOL_CXX + ])]) +dnl And a similar setup for Fortran 77 support + AC_PROVIDE_IFELSE([AC_PROG_F77], + [AC_LIBTOOL_F77], + [define([AC_PROG_F77], defn([AC_PROG_F77])[AC_LIBTOOL_F77 +])]) + +dnl Quote A][M_PROG_GCJ so that aclocal doesn't bring it in needlessly. +dnl If either AC_PROG_GCJ or A][M_PROG_GCJ have already been expanded, run +dnl AC_LIBTOOL_GCJ immediately, otherwise, hook it in at the end of both. + AC_PROVIDE_IFELSE([AC_PROG_GCJ], + [AC_LIBTOOL_GCJ], + [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], + [AC_LIBTOOL_GCJ], + [AC_PROVIDE_IFELSE([LT_AC_PROG_GCJ], + [AC_LIBTOOL_GCJ], + [ifdef([AC_PROG_GCJ], + [define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[AC_LIBTOOL_GCJ])]) + ifdef([A][M_PROG_GCJ], + [define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[AC_LIBTOOL_GCJ])]) + ifdef([LT_AC_PROG_GCJ], + [define([LT_AC_PROG_GCJ], + defn([LT_AC_PROG_GCJ])[AC_LIBTOOL_GCJ])])])]) +])])# AC_PROG_LIBTOOL + + +# _AC_PROG_LIBTOOL +# ---------------- +AC_DEFUN([_AC_PROG_LIBTOOL], +[AC_REQUIRE([AC_LIBTOOL_SETUP])dnl +AC_BEFORE([$0],[AC_LIBTOOL_CXX])dnl +AC_BEFORE([$0],[AC_LIBTOOL_F77])dnl +AC_BEFORE([$0],[AC_LIBTOOL_GCJ])dnl + +# This can be used to rebuild libtool when needed +LIBTOOL_DEPS="$ac_aux_dir/ltmain.sh" + +# Always use our own libtool. +LIBTOOL='$(SHELL) $(top_builddir)/libtool --silent' +AC_SUBST(LIBTOOL)dnl + +# Prevent multiple expansion +define([AC_PROG_LIBTOOL], []) +])# _AC_PROG_LIBTOOL + + +# AC_LIBTOOL_SETUP +# ---------------- +AC_DEFUN([AC_LIBTOOL_SETUP], +[AC_PREREQ(2.50)dnl +AC_REQUIRE([AC_ENABLE_SHARED])dnl +AC_REQUIRE([AC_ENABLE_STATIC])dnl +AC_REQUIRE([AC_ENABLE_FAST_INSTALL])dnl +AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_PROG_LD])dnl +AC_REQUIRE([AC_PROG_LD_RELOAD_FLAG])dnl +AC_REQUIRE([AC_PROG_NM])dnl + +AC_REQUIRE([AC_PROG_LN_S])dnl +AC_REQUIRE([AC_DEPLIBS_CHECK_METHOD])dnl +# Autoconf 2.13's AC_OBJEXT and AC_EXEEXT macros only works for C compilers! +AC_REQUIRE([AC_OBJEXT])dnl +AC_REQUIRE([AC_EXEEXT])dnl +dnl + +AC_LIBTOOL_SYS_MAX_CMD_LEN +AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE +AC_LIBTOOL_OBJDIR + +AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl +_LT_AC_PROG_ECHO_BACKSLASH + +case $host_os in +aix3*) + # AIX sometimes has problems with the GCC collect2 program. For some + # reason, if we set the COLLECT_NAMES environment variable, the problems + # vanish in a puff of smoke. + if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES + fi + ;; +esac + +# Sed substitution that helps us do robust quoting. It backslashifies +# metacharacters that are still active within double-quoted strings. +Xsed='sed -e s/^X//' +[sed_quote_subst='s/\([\\"\\`$\\\\]\)/\\\1/g'] + +# Same as above, but do not quote variable references. +[double_quote_subst='s/\([\\"\\`\\\\]\)/\\\1/g'] + +# Sed substitution to delay expansion of an escaped shell variable in a +# double_quote_subst'ed string. +delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' + +# Sed substitution to avoid accidental globbing in evaled expressions +no_glob_subst='s/\*/\\\*/g' + +# Constants: +rm="rm -f" + +# Global variables: +default_ofile=libtool +can_build_shared=yes + +# All known linkers require a `.a' archive for static linking (except M$VC, +# which needs '.lib'). +libext=a +ltmain="$ac_aux_dir/ltmain.sh" +ofile="$default_ofile" +with_gnu_ld="$lt_cv_prog_gnu_ld" + +AC_CHECK_TOOL(AR, ar, false) +AC_CHECK_TOOL(RANLIB, ranlib, :) +AC_CHECK_TOOL(STRIP, strip, :) + +old_CC="$CC" +old_CFLAGS="$CFLAGS" + +# Set sane defaults for various variables +test -z "$AR" && AR=ar +test -z "$AR_FLAGS" && AR_FLAGS=cru +test -z "$AS" && AS=as +test -z "$CC" && CC=cc +test -z "$LTCC" && LTCC=$CC +test -z "$DLLTOOL" && DLLTOOL=dlltool +test -z "$LD" && LD=ld +test -z "$LN_S" && LN_S="ln -s" +test -z "$MAGIC_CMD" && MAGIC_CMD=file +test -z "$NM" && NM=nm +test -z "$SED" && SED=sed +test -z "$OBJDUMP" && OBJDUMP=objdump +test -z "$RANLIB" && RANLIB=: +test -z "$STRIP" && STRIP=: +test -z "$ac_objext" && ac_objext=o + +# Determine commands to create old-style static archives. +old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs$old_deplibs' +old_postinstall_cmds='chmod 644 $oldlib' +old_postuninstall_cmds= + +if test -n "$RANLIB"; then + case $host_os in + openbsd*) + old_postinstall_cmds="\$RANLIB -t \$oldlib~$old_postinstall_cmds" + ;; + *) + old_postinstall_cmds="\$RANLIB \$oldlib~$old_postinstall_cmds" + ;; + esac + old_archive_cmds="$old_archive_cmds~\$RANLIB \$oldlib" +fi + +# Only perform the check for file, if the check method requires it +case $deplibs_check_method in +file_magic*) + if test "$file_magic_cmd" = '$MAGIC_CMD'; then + AC_PATH_MAGIC + fi + ;; +esac + +AC_PROVIDE_IFELSE([AC_LIBTOOL_DLOPEN], enable_dlopen=yes, enable_dlopen=no) +AC_PROVIDE_IFELSE([AC_LIBTOOL_WIN32_DLL], +enable_win32_dll=yes, enable_win32_dll=no) + +AC_ARG_ENABLE([libtool-lock], + [AC_HELP_STRING([--disable-libtool-lock], + [avoid locking (might break parallel builds)])]) +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +AC_ARG_WITH([pic], + [AC_HELP_STRING([--with-pic], + [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], + [pic_mode="$withval"], + [pic_mode=default]) +test -z "$pic_mode" && pic_mode=default + +# Use C for the default configuration in the libtool script +tagname= +AC_LIBTOOL_LANG_C_CONFIG +_LT_AC_TAGCONFIG +])# AC_LIBTOOL_SETUP + + +# _LT_AC_SYS_COMPILER +# ------------------- +AC_DEFUN([_LT_AC_SYS_COMPILER], +[AC_REQUIRE([AC_PROG_CC])dnl + +# If no C compiler was specified, use CC. +LTCC=${LTCC-"$CC"} + +# Allow CC to be a program name with arguments. +compiler=$CC +])# _LT_AC_SYS_COMPILER + + +# _LT_AC_SYS_LIBPATH_AIX +# ---------------------- +# Links a minimal program and checks the executable +# for the system default hardcoded library path. In most cases, +# this is /usr/lib:/lib, but when the MPI compilers are used +# the location of the communication and MPI libs are included too. +# If we don't find anything, use the default library path according +# to the aix ld manual. +AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX], +[AC_LINK_IFELSE(AC_LANG_PROGRAM,[ +aix_libpath=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'` +# Check for a 64-bit object if we didn't find anything. +if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } +}'`; fi],[]) +if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib"; fi +])# _LT_AC_SYS_LIBPATH_AIX + + +# _LT_AC_SHELL_INIT(ARG) +# ---------------------- +AC_DEFUN([_LT_AC_SHELL_INIT], +[ifdef([AC_DIVERSION_NOTICE], + [AC_DIVERT_PUSH(AC_DIVERSION_NOTICE)], + [AC_DIVERT_PUSH(NOTICE)]) +$1 +AC_DIVERT_POP +])# _LT_AC_SHELL_INIT + + +# _LT_AC_PROG_ECHO_BACKSLASH +# -------------------------- +# Add some code to the start of the generated configure script which +# will find an echo command which doesn't interpret backslashes. +AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH], +[_LT_AC_SHELL_INIT([ +# Check that we are running under the correct shell. +SHELL=${CONFIG_SHELL-/bin/sh} + +case X$ECHO in +X*--fallback-echo) + # Remove one level of quotation (which was required for Make). + ECHO=`echo "$ECHO" | sed 's,\\\\\[$]\\[$]0,'[$]0','` + ;; +esac + +echo=${ECHO-echo} +if test "X[$]1" = X--no-reexec; then + # Discard the --no-reexec flag, and continue. + shift +elif test "X[$]1" = X--fallback-echo; then + # Avoid inline document here, it may be left over + : +elif test "X`($echo '\t') 2>/dev/null`" = 'X\t' ; then + # Yippee, $echo works! + : +else + # Restart under the correct shell. + exec $SHELL "[$]0" --no-reexec ${1+"[$]@"} +fi + +if test "X[$]1" = X--fallback-echo; then + # used as fallback echo + shift + cat </dev/null && + echo_test_string="`eval $cmd`" && + (test "X$echo_test_string" = "X$echo_test_string") 2>/dev/null + then + break + fi + done +fi + +if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + : +else + # The Solaris, AIX, and Digital Unix default echo programs unquote + # backslashes. This makes it impossible to quote backslashes using + # echo "$something" | sed 's/\\/\\\\/g' + # + # So, first we look for a working echo in the user's PATH. + + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for dir in $PATH /usr/ucb; do + IFS="$lt_save_ifs" + if (test -f $dir/echo || test -f $dir/echo$ac_exeext) && + test "X`($dir/echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($dir/echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + echo="$dir/echo" + break + fi + done + IFS="$lt_save_ifs" + + if test "X$echo" = Xecho; then + # We didn't find a better echo, so look for alternatives. + if test "X`(print -r '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`(print -r "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # This shell has a builtin print -r that does the trick. + echo='print -r' + elif (test -f /bin/ksh || test -f /bin/ksh$ac_exeext) && + test "X$CONFIG_SHELL" != X/bin/ksh; then + # If we have ksh, try running configure again with it. + ORIGINAL_CONFIG_SHELL=${CONFIG_SHELL-/bin/sh} + export ORIGINAL_CONFIG_SHELL + CONFIG_SHELL=/bin/ksh + export CONFIG_SHELL + exec $CONFIG_SHELL "[$]0" --no-reexec ${1+"[$]@"} + else + # Try using printf. + echo='printf %s\n' + if test "X`($echo '\t') 2>/dev/null`" = 'X\t' && + echo_testing_string=`($echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + # Cool, printf works + : + elif echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($ORIGINAL_CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + CONFIG_SHELL=$ORIGINAL_CONFIG_SHELL + export CONFIG_SHELL + SHELL="$CONFIG_SHELL" + export SHELL + echo="$CONFIG_SHELL [$]0 --fallback-echo" + elif echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo '\t') 2>/dev/null` && + test "X$echo_testing_string" = 'X\t' && + echo_testing_string=`($CONFIG_SHELL "[$]0" --fallback-echo "$echo_test_string") 2>/dev/null` && + test "X$echo_testing_string" = "X$echo_test_string"; then + echo="$CONFIG_SHELL [$]0 --fallback-echo" + else + # maybe with a smaller string... + prev=: + + for cmd in 'echo test' 'sed 2q "[$]0"' 'sed 10q "[$]0"' 'sed 20q "[$]0"' 'sed 50q "[$]0"'; do + if (test "X$echo_test_string" = "X`eval $cmd`") 2>/dev/null + then + break + fi + prev="$cmd" + done + + if test "$prev" != 'sed 50q "[$]0"'; then + echo_test_string=`eval $prev` + export echo_test_string + exec ${ORIGINAL_CONFIG_SHELL-${CONFIG_SHELL-/bin/sh}} "[$]0" ${1+"[$]@"} + else + # Oops. We lost completely, so just stick with echo. + echo=echo + fi + fi + fi + fi +fi +fi + +# Copy echo and quote the copy suitably for passing to libtool from +# the Makefile, instead of quoting the original, which is used later. +ECHO=$echo +if test "X$ECHO" = "X$CONFIG_SHELL [$]0 --fallback-echo"; then + ECHO="$CONFIG_SHELL \\\$\[$]0 --fallback-echo" +fi + +AC_SUBST(ECHO) +])])# _LT_AC_PROG_ECHO_BACKSLASH + + +# _LT_AC_LOCK +# ----------- +AC_DEFUN([_LT_AC_LOCK], +[AC_ARG_ENABLE([libtool-lock], + [AC_HELP_STRING([--disable-libtool-lock], + [avoid locking (might break parallel builds)])]) +test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes + +# Some flags need to be propagated to the compiler or linker for good +# libtool support. +case $host in +ia64-*-hpux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case `/usr/bin/file conftest.$ac_objext` in + *ELF-32*) + HPUX_IA64_MODE="32" + ;; + *ELF-64*) + HPUX_IA64_MODE="64" + ;; + esac + fi + rm -rf conftest* + ;; +*-*-irix6*) + # Find out which ABI we are using. + echo '[#]line __oline__ "configure"' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + if test "$lt_cv_prog_gnu_ld" = yes; then + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -melf32bsmip" + ;; + *N32*) + LD="${LD-ld} -melf32bmipn32" + ;; + *64-bit*) + LD="${LD-ld} -melf64bmip" + ;; + esac + else + case `/usr/bin/file conftest.$ac_objext` in + *32-bit*) + LD="${LD-ld} -32" + ;; + *N32*) + LD="${LD-ld} -n32" + ;; + *64-bit*) + LD="${LD-ld} -64" + ;; + esac + fi + fi + rm -rf conftest* + ;; + +x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*|s390*-*linux*|sparc*-*linux*) + # Find out which ABI we are using. + echo 'int i;' > conftest.$ac_ext + if AC_TRY_EVAL(ac_compile); then + case "`/usr/bin/file conftest.o`" in + *32-bit*) + LINUX_64_MODE="32" + case $host in + x86_64-*linux*) + LD="${LD-ld} -m elf_i386" + ;; + ppc64-*linux*) + LD="${LD-ld} -m elf32ppclinux" + ;; + s390x-*linux*) + LD="${LD-ld} -m elf_s390" + ;; + sparc64-*linux*) + LD="${LD-ld} -m elf32_sparc" + ;; + esac + ;; + *64-bit*) + LINUX_64_MODE="64" + case $host in + x86_64-*linux*) + LD="${LD-ld} -m elf_x86_64" + ;; + ppc*-*linux*|powerpc*-*linux*) + LD="${LD-ld} -m elf64ppc" + ;; + s390*-*linux*) + LD="${LD-ld} -m elf64_s390" + ;; + sparc*-*linux*) + LD="${LD-ld} -m elf64_sparc" + ;; + esac + ;; + esac + fi + rm -rf conftest* + ;; + +*-*-sco3.2v5*) + # On SCO OpenServer 5, we need -belf to get full-featured binaries. + SAVE_CFLAGS="$CFLAGS" + CFLAGS="$CFLAGS -belf" + AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, + [AC_LANG_PUSH(C) + AC_TRY_LINK([],[],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) + AC_LANG_POP]) + if test x"$lt_cv_cc_needs_belf" != x"yes"; then + # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf + CFLAGS="$SAVE_CFLAGS" + fi + ;; +AC_PROVIDE_IFELSE([AC_LIBTOOL_WIN32_DLL], +[*-*-cygwin* | *-*-mingw* | *-*-pw32*) + AC_CHECK_TOOL(DLLTOOL, dlltool, false) + AC_CHECK_TOOL(AS, as, false) + AC_CHECK_TOOL(OBJDUMP, objdump, false) + ;; + ]) +esac + +need_locks="$enable_libtool_lock" + +])# _LT_AC_LOCK + + +# AC_LIBTOOL_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) +# ---------------------------------------------------------------- +# Check whether the given compiler option works +AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], +[AC_REQUIRE([LT_AC_PROG_SED]) +AC_CACHE_CHECK([$1], [$2], + [$2=no + ifelse([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + lt_compiler_flag="$3" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + # The option is referenced via a variable to avoid confusing sed. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}? :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>conftest.err) + ac_status=$? + cat conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s "$ac_outfile"; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + if test ! -s conftest.err; then + $2=yes + fi + fi + $rm conftest* +]) + +if test x"[$]$2" = xyes; then + ifelse([$5], , :, [$5]) +else + ifelse([$6], , :, [$6]) +fi +])# AC_LIBTOOL_COMPILER_OPTION + + +# AC_LIBTOOL_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, +# [ACTION-SUCCESS], [ACTION-FAILURE]) +# ------------------------------------------------------------ +# Check whether the given compiler option works +AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], +[AC_CACHE_CHECK([$1], [$2], + [$2=no + save_LDFLAGS="$LDFLAGS" + LDFLAGS="$LDFLAGS $3" + printf "$lt_simple_link_test_code" > conftest.$ac_ext + if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + if test -s conftest.err; then + # Append any errors to the config.log. + cat conftest.err 1>&AS_MESSAGE_LOG_FD + else + $2=yes + fi + fi + $rm conftest* + LDFLAGS="$save_LDFLAGS" +]) + +if test x"[$]$2" = xyes; then + ifelse([$4], , :, [$4]) +else + ifelse([$5], , :, [$5]) +fi +])# AC_LIBTOOL_LINKER_OPTION + + +# AC_LIBTOOL_SYS_MAX_CMD_LEN +# -------------------------- +AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], +[# find the maximum length of command line arguments +AC_MSG_CHECKING([the maximum length of command line arguments]) +AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl + i=0 + testring="ABCD" + + case $build_os in + msdosdjgpp*) + # On DJGPP, this test can blow up pretty badly due to problems in libc + # (any single argument exceeding 2000 bytes causes a buffer overrun + # during glob expansion). Even if it were fixed, the result of this + # check would be larger than it should be. + lt_cv_sys_max_cmd_len=12288; # 12K is about right + ;; + + gnu*) + # Under GNU Hurd, this test is not required because there is + # no limit to the length of command line arguments. + # Libtool will interpret -1 as no limit whatsoever + lt_cv_sys_max_cmd_len=-1; + ;; + + cygwin* | mingw*) + # On Win9x/ME, this test blows up -- it succeeds, but takes + # about 5 minutes as the teststring grows exponentially. + # Worse, since 9x/ME are not pre-emptively multitasking, + # you end up with a "frozen" computer, even though with patience + # the test eventually succeeds (with a max line length of 256k). + # Instead, let's just punt: use the minimum linelength reported by + # all of the supported platforms: 8192 (on NT/2K/XP). + lt_cv_sys_max_cmd_len=8192; + ;; + + *) + # If test is not a shell built-in, we'll probably end up computing a + # maximum length that is only half of the actual maximum length, but + # we can't tell. + while (test "X"`$CONFIG_SHELL [$]0 --fallback-echo "X$testring" 2>/dev/null` \ + = "XX$testring") >/dev/null 2>&1 && + new_result=`expr "X$testring" : ".*" 2>&1` && + lt_cv_sys_max_cmd_len=$new_result && + test $i != 17 # 1/2 MB should be enough + do + i=`expr $i + 1` + testring=$testring$testring + done + testring= + # Add a significant safety factor because C++ compilers can tack on massive + # amounts of additional arguments before passing them to the linker. + # It appears as though 1/2 is a usable value. + lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` + ;; + esac +]) +if test -n $lt_cv_sys_max_cmd_len ; then + AC_MSG_RESULT($lt_cv_sys_max_cmd_len) +else + AC_MSG_RESULT(none) +fi +])# AC_LIBTOOL_SYS_MAX_CMD_LEN + + +# _LT_AC_CHECK_DLFCN +# -------------------- +AC_DEFUN([_LT_AC_CHECK_DLFCN], +[AC_CHECK_HEADERS(dlfcn.h)dnl +])# _LT_AC_CHECK_DLFCN + + +# _LT_AC_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, +# ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) +# ------------------------------------------------------------------ +AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF], +[AC_REQUIRE([_LT_AC_CHECK_DLFCN])dnl +if test "$cross_compiling" = yes; then : + [$4] +else + lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 + lt_status=$lt_dlunknown + cat > conftest.$ac_ext < +#endif + +#include + +#ifdef RTLD_GLOBAL +# define LT_DLGLOBAL RTLD_GLOBAL +#else +# ifdef DL_GLOBAL +# define LT_DLGLOBAL DL_GLOBAL +# else +# define LT_DLGLOBAL 0 +# endif +#endif + +/* We may have to define LT_DLLAZY_OR_NOW in the command line if we + find out it does not work in some platform. */ +#ifndef LT_DLLAZY_OR_NOW +# ifdef RTLD_LAZY +# define LT_DLLAZY_OR_NOW RTLD_LAZY +# else +# ifdef DL_LAZY +# define LT_DLLAZY_OR_NOW DL_LAZY +# else +# ifdef RTLD_NOW +# define LT_DLLAZY_OR_NOW RTLD_NOW +# else +# ifdef DL_NOW +# define LT_DLLAZY_OR_NOW DL_NOW +# else +# define LT_DLLAZY_OR_NOW 0 +# endif +# endif +# endif +# endif +#endif + +#ifdef __cplusplus +extern "C" void exit (int); +#endif + +void fnord() { int i=42;} +int main () +{ + void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); + int status = $lt_dlunknown; + + if (self) + { + if (dlsym (self,"fnord")) status = $lt_dlno_uscore; + else if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; + /* dlclose (self); */ + } + + exit (status); +}] +EOF + if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then + (./conftest; exit; ) 2>/dev/null + lt_status=$? + case x$lt_status in + x$lt_dlno_uscore) $1 ;; + x$lt_dlneed_uscore) $2 ;; + x$lt_unknown|x*) $3 ;; + esac + else : + # compilation failed + $3 + fi +fi +rm -fr conftest* +])# _LT_AC_TRY_DLOPEN_SELF + + +# AC_LIBTOOL_DLOPEN_SELF +# ------------------- +AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], +[AC_REQUIRE([_LT_AC_CHECK_DLFCN])dnl +if test "x$enable_dlopen" != xyes; then + enable_dlopen=unknown + enable_dlopen_self=unknown + enable_dlopen_self_static=unknown +else + lt_cv_dlopen=no + lt_cv_dlopen_libs= + + case $host_os in + beos*) + lt_cv_dlopen="load_add_on" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ;; + + mingw* | pw32*) + lt_cv_dlopen="LoadLibrary" + lt_cv_dlopen_libs= + ;; + + cygwin*) + lt_cv_dlopen="dlopen" + lt_cv_dlopen_libs= + ;; + + darwin*) + # if libdl is installed we need to link against it + AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[ + lt_cv_dlopen="dyld" + lt_cv_dlopen_libs= + lt_cv_dlopen_self=yes + ]) + ;; + + *) + AC_CHECK_FUNC([shl_load], + [lt_cv_dlopen="shl_load"], + [AC_CHECK_LIB([dld], [shl_load], + [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-dld"], + [AC_CHECK_FUNC([dlopen], + [lt_cv_dlopen="dlopen"], + [AC_CHECK_LIB([dl], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"], + [AC_CHECK_LIB([svld], [dlopen], + [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"], + [AC_CHECK_LIB([dld], [dld_link], + [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-dld"]) + ]) + ]) + ]) + ]) + ]) + ;; + esac + + if test "x$lt_cv_dlopen" != xno; then + enable_dlopen=yes + else + enable_dlopen=no + fi + + case $lt_cv_dlopen in + dlopen) + save_CPPFLAGS="$CPPFLAGS" + test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" + + save_LDFLAGS="$LDFLAGS" + eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" + + save_LIBS="$LIBS" + LIBS="$lt_cv_dlopen_libs $LIBS" + + AC_CACHE_CHECK([whether a program can dlopen itself], + lt_cv_dlopen_self, [dnl + _LT_AC_TRY_DLOPEN_SELF( + lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, + lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) + ]) + + if test "x$lt_cv_dlopen_self" = xyes; then + LDFLAGS="$LDFLAGS $link_static_flag" + AC_CACHE_CHECK([whether a statically linked program can dlopen itself], + lt_cv_dlopen_self_static, [dnl + _LT_AC_TRY_DLOPEN_SELF( + lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, + lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) + ]) + fi + + CPPFLAGS="$save_CPPFLAGS" + LDFLAGS="$save_LDFLAGS" + LIBS="$save_LIBS" + ;; + esac + + case $lt_cv_dlopen_self in + yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; + *) enable_dlopen_self=unknown ;; + esac + + case $lt_cv_dlopen_self_static in + yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; + *) enable_dlopen_self_static=unknown ;; + esac +fi +])# AC_LIBTOOL_DLOPEN_SELF + + +# AC_LIBTOOL_PROG_CC_C_O([TAGNAME]) +# --------------------------------- +# Check to see if options -c and -o are simultaneously supported by compiler +AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O], +[AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl +AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], + [_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)], + [_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no + $rm -r conftest 2>/dev/null + mkdir conftest + cd conftest + mkdir out + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + # According to Tom Tromey, Ian Lance Taylor reported there are C compilers + # that will create temporary files in the current directory regardless of + # the output directory. Thus, making CWD read-only will cause this test + # to fail, enabling locking or at least warning the user not to do parallel + # builds. + chmod -w . + + lt_compiler_flag="-o out/conftest2.$ac_objext" + # Insert the option either (1) after the last *FLAGS variable, or + # (2) before a word containing "conftest.", or (3) at the end. + # Note that $ac_compile itself does not contain backslashes and begins + # with a dollar sign (not a hyphen), so the echo should work correctly. + lt_compile=`echo "$ac_compile" | $SED \ + -e 's:.*FLAGS}? :&$lt_compiler_flag :; t' \ + -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ + -e 's:$: $lt_compiler_flag:'` + (eval echo "\"\$as_me:__oline__: $lt_compile\"" >&AS_MESSAGE_LOG_FD) + (eval "$lt_compile" 2>out/conftest.err) + ac_status=$? + cat out/conftest.err >&AS_MESSAGE_LOG_FD + echo "$as_me:__oline__: \$? = $ac_status" >&AS_MESSAGE_LOG_FD + if (exit $ac_status) && test -s out/conftest2.$ac_objext + then + # The compiler can only warn and ignore the option if not recognized + # So say no if there are warnings + if test ! -s out/conftest.err; then + _LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes + fi + fi + chmod u+w . + $rm conftest* out/* + rmdir out + cd .. + rmdir conftest + $rm conftest* +]) +])# AC_LIBTOOL_PROG_CC_C_O + + +# AC_LIBTOOL_SYS_HARD_LINK_LOCKS([TAGNAME]) +# ----------------------------------------- +# Check to see if we can do hard links to lock some files if needed +AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], +[AC_REQUIRE([_LT_AC_LOCK])dnl + +hard_links="nottested" +if test "$_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then + # do not overwrite the value of need_locks provided by the user + AC_MSG_CHECKING([if we can lock with hard links]) + hard_links=yes + $rm conftest* + ln conftest.a conftest.b 2>/dev/null && hard_links=no + touch conftest.a + ln conftest.a conftest.b 2>&5 || hard_links=no + ln conftest.a conftest.b 2>/dev/null && hard_links=no + AC_MSG_RESULT([$hard_links]) + if test "$hard_links" = no; then + AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe]) + need_locks=warn + fi +else + need_locks=no +fi +])# AC_LIBTOOL_SYS_HARD_LINK_LOCKS + + +# AC_LIBTOOL_OBJDIR +# ----------------- +AC_DEFUN([AC_LIBTOOL_OBJDIR], +[AC_CACHE_CHECK([for objdir], [lt_cv_objdir], +[rm -f .libs 2>/dev/null +mkdir .libs 2>/dev/null +if test -d .libs; then + lt_cv_objdir=.libs +else + # MS-DOS does not allow filenames that begin with a dot. + lt_cv_objdir=_libs +fi +rmdir .libs 2>/dev/null]) +objdir=$lt_cv_objdir +])# AC_LIBTOOL_OBJDIR + + +# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH([TAGNAME]) +# ---------------------------------------------- +# Check hardcoding attributes. +AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], +[AC_MSG_CHECKING([how to hardcode library paths into programs]) +_LT_AC_TAGVAR(hardcode_action, $1)= +if test -n "$_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)" || \ + test -n "$_LT_AC_TAGVAR(runpath_var $1)" || \ + test "X$_LT_AC_TAGVAR(hardcode_automatic, $1)"="Xyes" ; then + + # We can hardcode non-existant directories. + if test "$_LT_AC_TAGVAR(hardcode_direct, $1)" != no && + # If the only mechanism to avoid hardcoding is shlibpath_var, we + # have to relink, otherwise we might link with an installed library + # when we should be linking with a yet-to-be-installed one + ## test "$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1)" != no && + test "$_LT_AC_TAGVAR(hardcode_minus_L, $1)" != no; then + # Linking always hardcodes the temporary library directory. + _LT_AC_TAGVAR(hardcode_action, $1)=relink + else + # We can link without hardcoding, and we can hardcode nonexisting dirs. + _LT_AC_TAGVAR(hardcode_action, $1)=immediate + fi +else + # We cannot hardcode anything, or else we can only hardcode existing + # directories. + _LT_AC_TAGVAR(hardcode_action, $1)=unsupported +fi +AC_MSG_RESULT([$_LT_AC_TAGVAR(hardcode_action, $1)]) + +if test "$_LT_AC_TAGVAR(hardcode_action, $1)" = relink; then + # Fast installation is not supported + enable_fast_install=no +elif test "$shlibpath_overrides_runpath" = yes || + test "$enable_shared" = no; then + # Fast installation is not necessary + enable_fast_install=needless +fi +])# AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH + + +# AC_LIBTOOL_SYS_LIB_STRIP +# ------------------------ +AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP], +[striplib= +old_striplib= +AC_MSG_CHECKING([whether stripping libraries is possible]) +if test -n "$STRIP" && $STRIP -V 2>&1 | grep "GNU strip" >/dev/null; then + test -z "$old_striplib" && old_striplib="$STRIP --strip-debug" + test -z "$striplib" && striplib="$STRIP --strip-unneeded" + AC_MSG_RESULT([yes]) +else +# FIXME - insert some real tests, host_os isn't really good enough + case $host_os in + darwin*) + if test -n "$STRIP" ; then + striplib="$STRIP -x" + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no]) +fi + ;; + *) + AC_MSG_RESULT([no]) + ;; + esac +fi +])# AC_LIBTOOL_SYS_LIB_STRIP + + +# AC_LIBTOOL_SYS_DYNAMIC_LINKER +# ----------------------------- +# PORTME Fill in your ld.so characteristics +AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER], +[AC_MSG_CHECKING([dynamic linker characteristics]) +library_names_spec= +libname_spec='lib$name' +soname_spec= +shrext=".so" +postinstall_cmds= +postuninstall_cmds= +finish_cmds= +finish_eval= +shlibpath_var= +shlibpath_overrides_runpath=unknown +version_type=none +dynamic_linker="$host_os ld.so" +sys_lib_dlsearch_path_spec="/lib /usr/lib" +sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" +need_lib_prefix=unknown +hardcode_into_libs=no + +# when you set need_version to no, make sure it does not cause -set_version +# flags to be left without arguments +need_version=unknown + +case $host_os in +aix3*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a' + shlibpath_var=LIBPATH + + # AIX 3 has no versioning support, so we append a major version to the name. + soname_spec='${libname}${release}${shared_ext}$major' + ;; + +aix4* | aix5*) + version_type=linux + need_lib_prefix=no + need_version=no + hardcode_into_libs=yes + if test "$host_cpu" = ia64; then + # AIX 5 supports IA64 + library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + else + # With GCC up to 2.95.x, collect2 would create an import file + # for dependence libraries. The import file would start with + # the line `#! .'. This would cause the generated library to + # depend on `.', always an invalid library. This was fixed in + # development snapshots of GCC prior to 3.0. + case $host_os in + aix4 | aix4.[[01]] | aix4.[[01]].*) + if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' + echo ' yes ' + echo '#endif'; } | ${CC} -E - | grep yes > /dev/null; then + : + else + can_build_shared=no + fi + ;; + esac + # AIX (on Power*) has no versioning support, so currently we can not hardcode correct + # soname into executable. Probably we can add versioning support to + # collect2, so additional links can be useful in future. + if test "$aix_use_runtimelinking" = yes; then + # If using run time linking (on AIX 4.2 or later) use lib.so + # instead of lib.a to let people know that these are not + # typical AIX shared libraries. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + else + # We preserve .a as extension for shared libraries through AIX4.2 + # and later when we are not doing run time linking. + library_names_spec='${libname}${release}.a $libname.a' + soname_spec='${libname}${release}${shared_ext}$major' + fi + shlibpath_var=LIBPATH + fi + ;; + +amigaos*) + library_names_spec='$libname.ixlibrary $libname.a' + # Create ${libname}_ixlibrary.a entries in /sys/libs. + finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`$echo "X$lib" | $Xsed -e '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $rm /sys/libs/${libname}_ixlibrary.a; $show "(cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a)"; (cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a) || exit 1; done' + ;; + +beos*) + library_names_spec='${libname}${shared_ext}' + dynamic_linker="$host_os ld.so" + shlibpath_var=LIBRARY_PATH + ;; + +bsdi4*) + version_type=linux + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" + sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" + # the default ld.so.conf also contains /usr/contrib/lib and + # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow + # libtool to hard-code these into programs + ;; + +cygwin* | mingw* | pw32*) + version_type=windows + shrext=".dll" + need_version=no + need_lib_prefix=no + + case $GCC,$host_os in + yes,cygwin* | yes,mingw* | yes,pw32*) + library_names_spec='$libname.dll.a' + # DLL is installed to $(libdir)/../bin by postinstall_cmds + postinstall_cmds='base_file=`basename \${file}`~ + dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i;echo \$dlname'\''`~ + dldir=$destdir/`dirname \$dlpath`~ + test -d \$dldir || mkdir -p \$dldir~ + $install_prog $dir/$dlname \$dldir/$dlname' + postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ + dlpath=$dir/\$dldll~ + $rm \$dlpath' + shlibpath_overrides_runpath=yes + + case $host_os in + cygwin*) + # Cygwin DLLs use 'cyg' prefix rather than 'lib' + soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec="/usr/lib /lib/w32api /lib /usr/local/lib" + ;; + mingw*) + # MinGW DLLs use traditional 'lib' prefix + soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}' + sys_lib_search_path_spec=`$CC -print-search-dirs | grep "^libraries:" | $SED -e "s/^libraries://" -e "s,=/,/,g"` + if echo "$sys_lib_search_path_spec" | [grep ';[c-zC-Z]:/' >/dev/null]; then + # It is most probably a Windows format PATH printed by + # mingw gcc, but we are running on Cygwin. Gcc prints its search + # path with ; separators, and with drive letters. We can handle the + # drive letters (cygwin fileutils understands them), so leave them, + # especially as we might pass files found there to a mingw objdump, + # which wouldn't understand a cygwinified path. Ahh. + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` + else + sys_lib_search_path_spec=`echo "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` + fi + ;; + pw32*) + # pw32 DLLs use 'pw' prefix rather than 'lib' + library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}' + ;; + esac + ;; + + *) + library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib' + ;; + esac + dynamic_linker='Win32 ld.exe' + # FIXME: first we should search . and the directory the executable is in + shlibpath_var=PATH + ;; + +darwin* | rhapsody*) + dynamic_linker="$host_os dyld" + version_type=darwin + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${versuffix}$shared_ext ${libname}${release}${major}$shared_ext ${libname}$shared_ext' + soname_spec='${libname}${release}${major}$shared_ext' + shlibpath_overrides_runpath=yes + shlibpath_var=DYLD_LIBRARY_PATH + shrext='$(test .$module = .yes && echo .so || echo .dylib)' + # Apple's gcc prints 'gcc -print-search-dirs' doesn't operate the same. + if test "$GCC" = yes; then + sys_lib_search_path_spec=`$CC -print-search-dirs | tr "\n" "$PATH_SEPARATOR" | sed -e 's/libraries:/@libraries:/' | tr "@" "\n" | grep "^libraries:" | sed -e "s/^libraries://" -e "s,=/,/,g" -e "s,$PATH_SEPARATOR, ,g" -e "s,.*,& /lib /usr/lib /usr/local/lib,g"` + else + sys_lib_search_path_spec='/lib /usr/lib /usr/local/lib' + fi + sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' + ;; + +dgux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +freebsd1*) + dynamic_linker=no + ;; + +freebsd*-gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + dynamic_linker='GNU ld.so' + ;; + +freebsd*) + objformat=`test -x /usr/bin/objformat && /usr/bin/objformat || echo aout` + version_type=freebsd-$objformat + case $version_type in + freebsd-elf*) + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}' + need_version=no + need_lib_prefix=no + ;; + freebsd-*) + library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix' + need_version=yes + ;; + esac + shlibpath_var=LD_LIBRARY_PATH + case $host_os in + freebsd2*) + shlibpath_overrides_runpath=yes + ;; + freebsd3.[01]* | freebsdelf3.[01]*) + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + *) # from 3.2 on + shlibpath_overrides_runpath=no + hardcode_into_libs=yes + ;; + esac + ;; + +gnu*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + hardcode_into_libs=yes + ;; + +hpux9* | hpux10* | hpux11*) + # Give a soname corresponding to the major version so that dld.sl refuses to + # link against other versions. + version_type=sunos + need_lib_prefix=no + need_version=no + case "$host_cpu" in + ia64*) + shrext='.so' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.so" + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + if test "X$HPUX_IA64_MODE" = X32; then + sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" + else + sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" + fi + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + hppa*64*) + shrext='.sl' + hardcode_into_libs=yes + dynamic_linker="$host_os dld.sl" + shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH + shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" + sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec + ;; + *) + shrext='.sl' + dynamic_linker="$host_os dld.sl" + shlibpath_var=SHLIB_PATH + shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + ;; + esac + # HP-UX runs *really* slowly unless shared libraries are mode 555. + postinstall_cmds='chmod 555 $lib' + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + nonstopux*) version_type=nonstopux ;; + *) + if test "$lt_cv_prog_gnu_ld" = yes; then + version_type=linux + else + version_type=irix + fi ;; + esac + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}' + case $host_os in + irix5* | nonstopux*) + libsuff= shlibsuff= + ;; + *) + case $LD in # libtool.m4 will add one of these switches to LD + *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") + libsuff= shlibsuff= libmagic=32-bit;; + *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") + libsuff=32 shlibsuff=N32 libmagic=N32;; + *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") + libsuff=64 shlibsuff=64 libmagic=64-bit;; + *) libsuff= shlibsuff= libmagic=never-match;; + esac + ;; + esac + shlibpath_var=LD_LIBRARY${shlibsuff}_PATH + shlibpath_overrides_runpath=no + sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}" + sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}" + hardcode_into_libs=yes + ;; + +# No shared lib support for Linux oldld, aout, or coff. +linux*oldld* | linux*aout* | linux*coff*) + dynamic_linker=no + ;; + +# This must be Linux ELF. +linux*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' + libsuff= + if test "x$LINUX_64_MODE" = x64; then + # Some platforms are per default 64-bit, so there's no /lib64 + if test -d /lib64; then + libsuff=64 + fi + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=no + sys_lib_dlsearch_path_spec="/lib${libsuff} /usr/lib${libsuff}" + sys_lib_search_path_spec="/lib${libsuff} /usr/lib${libsuff} /usr/local/lib${libsuff}" + # This implies no fast_install, which is unacceptable. + # Some rework will be needed to allow for fast_install + # before this can be enabled. + hardcode_into_libs=yes + + # We used to test for /lib/ld.so.1 and disable shared libraries on + # powerpc, because MkLinux only supported shared libraries with the + # GNU dynamic linker. Since this was broken with cross compilers, + # most powerpc-linux boxes support dynamic linking these days and + # people can always --disable-shared, the test was removed, and we + # assume the GNU/Linux dynamic linker is in use. + dynamic_linker='GNU/Linux ld.so' + ;; + +netbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + dynamic_linker='NetBSD (a.out) ld.so' + else + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} ${libname}${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + dynamic_linker='NetBSD ld.elf_so' + fi + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + ;; + +newsos6) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +nto-qnx*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + ;; + +openbsd*) + version_type=sunos + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' + shlibpath_var=LD_LIBRARY_PATH + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + case $host_os in + openbsd2.[[89]] | openbsd2.[[89]].*) + shlibpath_overrides_runpath=no + ;; + *) + shlibpath_overrides_runpath=yes + ;; + esac + else + shlibpath_overrides_runpath=yes + fi + ;; + +os2*) + libname_spec='$name' + shrext=".dll" + need_lib_prefix=no + library_names_spec='$libname${shared_ext} $libname.a' + dynamic_linker='OS/2 ld.exe' + shlibpath_var=LIBPATH + ;; + +osf3* | osf4* | osf5*) + version_type=osf + need_lib_prefix=no + need_version=no + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" + sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec" + ;; + +sco3.2v5*) + version_type=osf + soname_spec='${libname}${release}${shared_ext}$major' + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + shlibpath_var=LD_LIBRARY_PATH + ;; + +solaris*) + version_type=linux + need_lib_prefix=no + need_version=no + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + hardcode_into_libs=yes + # ldd complains unless libraries are executable + postinstall_cmds='chmod +x $lib' + ;; + +sunos4*) + version_type=sunos + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix' + finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' + shlibpath_var=LD_LIBRARY_PATH + shlibpath_overrides_runpath=yes + if test "$with_gnu_ld" = yes; then + need_lib_prefix=no + fi + need_version=yes + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + case $host_vendor in + sni) + shlibpath_overrides_runpath=no + need_lib_prefix=no + export_dynamic_flag_spec='${wl}-Blargedynsym' + runpath_var=LD_RUN_PATH + ;; + siemens) + need_lib_prefix=no + ;; + motorola) + need_lib_prefix=no + need_version=no + shlibpath_overrides_runpath=no + sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' + ;; + esac + ;; + +sysv4*MP*) + if test -d /usr/nec ;then + version_type=linux + library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}' + soname_spec='$libname${shared_ext}.$major' + shlibpath_var=LD_LIBRARY_PATH + fi + ;; + +uts4*) + version_type=linux + library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}' + soname_spec='${libname}${release}${shared_ext}$major' + shlibpath_var=LD_LIBRARY_PATH + ;; + +*) + dynamic_linker=no + ;; +esac +AC_MSG_RESULT([$dynamic_linker]) +test "$dynamic_linker" = no && can_build_shared=no +])# AC_LIBTOOL_SYS_DYNAMIC_LINKER + + +# _LT_AC_TAGCONFIG +# ---------------- +AC_DEFUN([_LT_AC_TAGCONFIG], +[AC_ARG_WITH([tags], + [AC_HELP_STRING([--with-tags@<:@=TAGS@:>@], + [include additional configurations @<:@automatic@:>@])], + [tagnames="$withval"]) + +if test -f "$ltmain" && test -n "$tagnames"; then + if test ! -f "${ofile}"; then + AC_MSG_WARN([output file `$ofile' does not exist]) + fi + + if test -z "$LTCC"; then + eval "`$SHELL ${ofile} --config | grep '^LTCC='`" + if test -z "$LTCC"; then + AC_MSG_WARN([output file `$ofile' does not look like a libtool script]) + else + AC_MSG_WARN([using `LTCC=$LTCC', extracted from `$ofile']) + fi + fi + + # Extract list of available tagged configurations in $ofile. + # Note that this assumes the entire list is on one line. + available_tags=`grep "^available_tags=" "${ofile}" | $SED -e 's/available_tags=\(.*$\)/\1/' -e 's/\"//g'` + + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for tagname in $tagnames; do + IFS="$lt_save_ifs" + # Check whether tagname contains only valid characters + case `$echo "X$tagname" | $Xsed -e 's:[[-_ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890,/]]::g'` in + "") ;; + *) AC_MSG_ERROR([invalid tag name: $tagname]) + ;; + esac + + if grep "^# ### BEGIN LIBTOOL TAG CONFIG: $tagname$" < "${ofile}" > /dev/null + then + AC_MSG_ERROR([tag name \"$tagname\" already exists]) + fi + + # Update the list of available tags. + if test -n "$tagname"; then + echo appending configuration tag \"$tagname\" to $ofile + + case $tagname in + CXX) + if test -n "$CXX" && test "X$CXX" != "Xno"; then + AC_LIBTOOL_LANG_CXX_CONFIG + else + tagname="" + fi + ;; + + F77) + if test -n "$F77" && test "X$F77" != "Xno"; then + AC_LIBTOOL_LANG_F77_CONFIG + else + tagname="" + fi + ;; + + GCJ) + if test -n "$GCJ" && test "X$GCJ" != "Xno"; then + AC_LIBTOOL_LANG_GCJ_CONFIG + else + tagname="" + fi + ;; + + RC) + AC_LIBTOOL_LANG_RC_CONFIG + ;; + + *) + AC_MSG_ERROR([Unsupported tag name: $tagname]) + ;; + esac + + # Append the new tag name to the list of available tags. + if test -n "$tagname" ; then + available_tags="$available_tags $tagname" + fi + fi + done + IFS="$lt_save_ifs" + + # Now substitute the updated list of available tags. + if eval "sed -e 's/^available_tags=.*\$/available_tags=\"$available_tags\"/' \"$ofile\" > \"${ofile}T\""; then + mv "${ofile}T" "$ofile" + chmod +x "$ofile" + else + rm -f "${ofile}T" + AC_MSG_ERROR([unable to update list of available tagged configurations.]) + fi +fi +])# _LT_AC_TAGCONFIG + + +# AC_LIBTOOL_DLOPEN +# ----------------- +# enable checks for dlopen support +AC_DEFUN([AC_LIBTOOL_DLOPEN], + [AC_BEFORE([$0],[AC_LIBTOOL_SETUP]) +])# AC_LIBTOOL_DLOPEN + + +# AC_LIBTOOL_WIN32_DLL +# -------------------- +# declare package support for building win32 dll's +AC_DEFUN([AC_LIBTOOL_WIN32_DLL], +[AC_BEFORE([$0], [AC_LIBTOOL_SETUP]) +])# AC_LIBTOOL_WIN32_DLL + + +# AC_ENABLE_SHARED([DEFAULT]) +# --------------------------- +# implement the --enable-shared flag +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +AC_DEFUN([AC_ENABLE_SHARED], +[define([AC_ENABLE_SHARED_DEFAULT], ifelse($1, no, no, yes))dnl +AC_ARG_ENABLE([shared], + [AC_HELP_STRING([--enable-shared@<:@=PKGS@:>@], + [build shared libraries @<:@default=]AC_ENABLE_SHARED_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_shared=yes ;; + no) enable_shared=no ;; + *) + enable_shared=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_shared=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_shared=]AC_ENABLE_SHARED_DEFAULT) +])# AC_ENABLE_SHARED + + +# AC_DISABLE_SHARED +# ----------------- +#- set the default shared flag to --disable-shared +AC_DEFUN([AC_DISABLE_SHARED], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +AC_ENABLE_SHARED(no) +])# AC_DISABLE_SHARED + + +# AC_ENABLE_STATIC([DEFAULT]) +# --------------------------- +# implement the --enable-static flag +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +AC_DEFUN([AC_ENABLE_STATIC], +[define([AC_ENABLE_STATIC_DEFAULT], ifelse($1, no, no, yes))dnl +AC_ARG_ENABLE([static], + [AC_HELP_STRING([--enable-static@<:@=PKGS@:>@], + [build static libraries @<:@default=]AC_ENABLE_STATIC_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_static=yes ;; + no) enable_static=no ;; + *) + enable_static=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_static=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_static=]AC_ENABLE_STATIC_DEFAULT) +])# AC_ENABLE_STATIC + + +# AC_DISABLE_STATIC +# ----------------- +# set the default static flag to --disable-static +AC_DEFUN([AC_DISABLE_STATIC], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +AC_ENABLE_STATIC(no) +])# AC_DISABLE_STATIC + + +# AC_ENABLE_FAST_INSTALL([DEFAULT]) +# --------------------------------- +# implement the --enable-fast-install flag +# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'. +AC_DEFUN([AC_ENABLE_FAST_INSTALL], +[define([AC_ENABLE_FAST_INSTALL_DEFAULT], ifelse($1, no, no, yes))dnl +AC_ARG_ENABLE([fast-install], + [AC_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], + [optimize for fast installation @<:@default=]AC_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], + [p=${PACKAGE-default} + case $enableval in + yes) enable_fast_install=yes ;; + no) enable_fast_install=no ;; + *) + enable_fast_install=no + # Look at the argument we got. We use all the common list separators. + lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR," + for pkg in $enableval; do + IFS="$lt_save_ifs" + if test "X$pkg" = "X$p"; then + enable_fast_install=yes + fi + done + IFS="$lt_save_ifs" + ;; + esac], + [enable_fast_install=]AC_ENABLE_FAST_INSTALL_DEFAULT) +])# AC_ENABLE_FAST_INSTALL + + +# AC_DISABLE_FAST_INSTALL +# ----------------------- +# set the default to --disable-fast-install +AC_DEFUN([AC_DISABLE_FAST_INSTALL], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +AC_ENABLE_FAST_INSTALL(no) +])# AC_DISABLE_FAST_INSTALL + + +# AC_LIBTOOL_PICMODE([MODE]) +# -------------------------- +# implement the --with-pic flag +# MODE is either `yes' or `no'. If omitted, it defaults to `both'. +AC_DEFUN([AC_LIBTOOL_PICMODE], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl +pic_mode=ifelse($#,1,$1,default) +])# AC_LIBTOOL_PICMODE + + +# AC_PROG_EGREP +# ------------- +# This is predefined starting with Autoconf 2.54, so this conditional +# definition can be removed once we require Autoconf 2.54 or later. +m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP], +[AC_CACHE_CHECK([for egrep], [ac_cv_prog_egrep], + [if echo a | (grep -E '(a|b)') >/dev/null 2>&1 + then ac_cv_prog_egrep='grep -E' + else ac_cv_prog_egrep='egrep' + fi]) + EGREP=$ac_cv_prog_egrep + AC_SUBST([EGREP]) +])]) + + +# AC_PATH_TOOL_PREFIX +# ------------------- +# find a file program which can recognise shared library +AC_DEFUN([AC_PATH_TOOL_PREFIX], +[AC_REQUIRE([AC_PROG_EGREP])dnl +AC_MSG_CHECKING([for $1]) +AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, +[case $MAGIC_CMD in +[[\\/*] | ?:[\\/]*]) + lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path. + ;; +*) + lt_save_MAGIC_CMD="$MAGIC_CMD" + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR +dnl $ac_dummy forces splitting on constant user-supplied paths. +dnl POSIX.2 word splitting is done only on the output of word expansions, +dnl not every word. This closes a longstanding sh security hole. + ac_dummy="ifelse([$2], , $PATH, [$2])" + for ac_dir in $ac_dummy; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$1; then + lt_cv_path_MAGIC_CMD="$ac_dir/$1" + if test -n "$file_magic_test_file"; then + case $deplibs_check_method in + "file_magic "*) + file_magic_regex="`expr \"$deplibs_check_method\" : \"file_magic \(.*\)\"`" + MAGIC_CMD="$lt_cv_path_MAGIC_CMD" + if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | + $EGREP "$file_magic_regex" > /dev/null; then + : + else + cat <&2 + +*** Warning: the command libtool uses to detect shared libraries, +*** $file_magic_cmd, produces output that libtool cannot recognize. +*** The result is that libtool may fail to recognize shared libraries +*** as such. This will affect the creation of libtool libraries that +*** depend on shared libraries, but programs linked with such libtool +*** libraries will work regardless of this problem. Nevertheless, you +*** may want to report the problem to your system manager and/or to +*** bug-libtool@gnu.org + +EOF + fi ;; + esac + fi + break + fi + done + IFS="$lt_save_ifs" + MAGIC_CMD="$lt_save_MAGIC_CMD" + ;; +esac]) +MAGIC_CMD="$lt_cv_path_MAGIC_CMD" +if test -n "$MAGIC_CMD"; then + AC_MSG_RESULT($MAGIC_CMD) +else + AC_MSG_RESULT(no) +fi +])# AC_PATH_TOOL_PREFIX + + +# AC_PATH_MAGIC +# ------------- +# find a file program which can recognise a shared library +AC_DEFUN([AC_PATH_MAGIC], +[AC_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) +if test -z "$lt_cv_path_MAGIC_CMD"; then + if test -n "$ac_tool_prefix"; then + AC_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) + else + MAGIC_CMD=: + fi +fi +])# AC_PATH_MAGIC + + +# AC_PROG_LD +# ---------- +# find the pathname to the GNU or non-GNU linker +AC_DEFUN([AC_PROG_LD], +[AC_ARG_WITH([gnu-ld], + [AC_HELP_STRING([--with-gnu-ld], + [assume the C compiler uses GNU ld @<:@default=no@:>@])], + [test "$withval" = no || with_gnu_ld=yes], + [with_gnu_ld=no]) +AC_REQUIRE([LT_AC_PROG_SED])dnl +AC_REQUIRE([AC_PROG_CC])dnl +AC_REQUIRE([AC_CANONICAL_HOST])dnl +AC_REQUIRE([AC_CANONICAL_BUILD])dnl +ac_prog=ld +if test "$GCC" = yes; then + # Check if gcc -print-prog-name=ld gives a path. + AC_MSG_CHECKING([for ld used by $CC]) + case $host in + *-*-mingw*) + # gcc leaves a trailing carriage return which upsets mingw + ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; + *) + ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; + esac + case $ac_prog in + # Accept absolute paths. + [[\\/]]* | ?:[[\\/]]*) + re_direlt='/[[^/]][[^/]]*/\.\./' + # Canonicalize the pathname of ld + ac_prog=`echo $ac_prog| $SED 's%\\\\%/%g'` + while echo $ac_prog | grep "$re_direlt" > /dev/null 2>&1; do + ac_prog=`echo $ac_prog| $SED "s%$re_direlt%/%"` + done + test -z "$LD" && LD="$ac_prog" + ;; + "") + # If it fails, then pretend we aren't using GCC. + ac_prog=ld + ;; + *) + # If it is relative, then search for the first ld in PATH. + with_gnu_ld=unknown + ;; + esac +elif test "$with_gnu_ld" = yes; then + AC_MSG_CHECKING([for GNU ld]) +else + AC_MSG_CHECKING([for non-GNU ld]) +fi +AC_CACHE_VAL(lt_cv_path_LD, +[if test -z "$LD"; then + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then + lt_cv_path_LD="$ac_dir/$ac_prog" + # Check to see if the program is GNU ld. I'd rather use --version, + # but apparently some GNU ld's only accept -v. + # Break only if it was the GNU/non-GNU ld that we prefer. + case `"$lt_cv_path_LD" -v 2>&1 &1 /dev/null; then + case $host_cpu in + i*86 ) + # Not sure whether the presence of OpenBSD here was a mistake. + # Let's accept both of them until this is cleared up. + lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD)/i[[3-9]]86 (compact )?demand paged shared library' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + ;; + esac + else + lt_cv_deplibs_check_method=pass_all + fi + ;; + +gnu*) + lt_cv_deplibs_check_method=pass_all + ;; + +hpux10.20* | hpux11*) + lt_cv_file_magic_cmd=/usr/bin/file + case "$host_cpu" in + ia64*) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' + lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so + ;; + hppa*64*) + [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - PA-RISC [0-9].[0-9]'] + lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl + ;; + *) + lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]].[[0-9]]) shared library' + lt_cv_file_magic_test_file=/usr/lib/libc.sl + ;; + esac + ;; + +irix5* | irix6* | nonstopux*) + case $host_os in + irix5* | nonstopux*) + # this will be overridden with pass_all, but let us keep it just in case + lt_cv_deplibs_check_method="file_magic ELF 32-bit MSB dynamic lib MIPS - version 1" + ;; + *) + case $LD in + *-32|*"-32 ") libmagic=32-bit;; + *-n32|*"-n32 ") libmagic=N32;; + *-64|*"-64 ") libmagic=64-bit;; + *) libmagic=never-match;; + esac + # this will be overridden with pass_all, but let us keep it just in case + lt_cv_deplibs_check_method="file_magic ELF ${libmagic} MSB mips-[[1234]] dynamic lib MIPS - version 1" + ;; + esac + lt_cv_file_magic_test_file=`echo /lib${libsuff}/libc.so*` + lt_cv_deplibs_check_method=pass_all + ;; + +# This must be Linux ELF. +linux*) + case $host_cpu in + alpha* | hppa* | i*86 | ia64* | m68* | mips* | powerpc* | sparc* | s390* | sh* | x86_64* ) + lt_cv_deplibs_check_method=pass_all ;; + # the debian people say, arm and glibc 2.3.1 works for them with pass_all + arm* ) + lt_cv_deplibs_check_method=pass_all ;; + *) + # glibc up to 2.1.1 does not perform some relocations on ARM + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' ;; + esac + lt_cv_file_magic_test_file=`echo /lib/libc.so* /lib/libc-*.so` + ;; + +netbsd*) + if echo __ELF__ | $CC -E - | grep __ELF__ > /dev/null; then + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' + else + lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' + fi + ;; + +newos6*) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=/usr/lib/libnls.so + ;; + +nto-qnx*) + lt_cv_deplibs_check_method=unknown + ;; + +openbsd*) + lt_cv_file_magic_cmd=/usr/bin/file + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB shared object' + else + lt_cv_deplibs_check_method='file_magic OpenBSD.* shared library' + fi + ;; + +osf3* | osf4* | osf5*) + # this will be overridden with pass_all, but let us keep it just in case + lt_cv_deplibs_check_method='file_magic COFF format alpha shared library' + lt_cv_file_magic_test_file=/shlib/libc.so + lt_cv_deplibs_check_method=pass_all + ;; + +sco3.2v5*) + lt_cv_deplibs_check_method=pass_all + ;; + +solaris*) + lt_cv_deplibs_check_method=pass_all + lt_cv_file_magic_test_file=/lib/libc.so + ;; + +sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + case $host_vendor in + motorola) + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' + lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` + ;; + ncr) + lt_cv_deplibs_check_method=pass_all + ;; + sequent) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' + ;; + sni) + lt_cv_file_magic_cmd='/bin/file' + lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" + lt_cv_file_magic_test_file=/lib/libc.so + ;; + siemens) + lt_cv_deplibs_check_method=pass_all + ;; + esac + ;; + +sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7* | sysv4*uw2*) + lt_cv_deplibs_check_method=pass_all + ;; +esac +]) +file_magic_cmd=$lt_cv_file_magic_cmd +deplibs_check_method=$lt_cv_deplibs_check_method +test -z "$deplibs_check_method" && deplibs_check_method=unknown +])# AC_DEPLIBS_CHECK_METHOD + + +# AC_PROG_NM +# ---------- +# find the pathname to a BSD-compatible name lister +AC_DEFUN([AC_PROG_NM], +[AC_CACHE_CHECK([for BSD-compatible nm], lt_cv_path_NM, +[if test -n "$NM"; then + # Let the user override the test. + lt_cv_path_NM="$NM" +else + lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR + for ac_dir in $PATH /usr/ccs/bin /usr/ucb /bin; do + IFS="$lt_save_ifs" + test -z "$ac_dir" && ac_dir=. + tmp_nm="$ac_dir/${ac_tool_prefix}nm" + if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then + # Check to see if the nm accepts a BSD-compat flag. + # Adding the `sed 1q' prevents false positives on HP-UX, which says: + # nm: unknown option "B" ignored + # Tru64's nm complains that /dev/null is an invalid object file + case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in + */dev/null* | *'Invalid file or object type'*) + lt_cv_path_NM="$tmp_nm -B" + break + ;; + *) + case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in + */dev/null*) + lt_cv_path_NM="$tmp_nm -p" + break + ;; + *) + lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but + continue # so that we can try to find one that supports BSD flags + ;; + esac + esac + fi + done + IFS="$lt_save_ifs" + test -z "$lt_cv_path_NM" && lt_cv_path_NM=nm +fi]) +NM="$lt_cv_path_NM" +])# AC_PROG_NM + + +# AC_CHECK_LIBM +# ------------- +# check for math library +AC_DEFUN([AC_CHECK_LIBM], +[AC_REQUIRE([AC_CANONICAL_HOST])dnl +LIBM= +case $host in +*-*-beos* | *-*-cygwin* | *-*-pw32* | *-*-darwin*) + # These system don't have libm, or don't need it + ;; +*-ncr-sysv4.3*) + AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw") + AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") + ;; +*) + AC_CHECK_LIB(m, cos, LIBM="-lm") + ;; +esac +])# AC_CHECK_LIBM + + +# AC_LIBLTDL_CONVENIENCE([DIRECTORY]) +# ----------------------------------- +# sets LIBLTDL to the link flags for the libltdl convenience library and +# LTDLINCL to the include flags for the libltdl header and adds +# --enable-ltdl-convenience to the configure arguments. Note that LIBLTDL +# and LTDLINCL are not AC_SUBSTed, nor is AC_CONFIG_SUBDIRS called. If +# DIRECTORY is not provided, it is assumed to be `libltdl'. LIBLTDL will +# be prefixed with '${top_builddir}/' and LTDLINCL will be prefixed with +# '${top_srcdir}/' (note the single quotes!). If your package is not +# flat and you're not using automake, define top_builddir and +# top_srcdir appropriately in the Makefiles. +AC_DEFUN([AC_LIBLTDL_CONVENIENCE], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl + case $enable_ltdl_convenience in + no) AC_MSG_ERROR([this package needs a convenience libltdl]) ;; + "") enable_ltdl_convenience=yes + ac_configure_args="$ac_configure_args --enable-ltdl-convenience" ;; + esac + LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdlc.la + LTDLINCL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl']) + # For backwards non-gettext consistent compatibility... + INCLTDL="$LTDLINCL" +])# AC_LIBLTDL_CONVENIENCE + + +# AC_LIBLTDL_INSTALLABLE([DIRECTORY]) +# ----------------------------------- +# sets LIBLTDL to the link flags for the libltdl installable library and +# LTDLINCL to the include flags for the libltdl header and adds +# --enable-ltdl-install to the configure arguments. Note that LIBLTDL +# and LTDLINCL are not AC_SUBSTed, nor is AC_CONFIG_SUBDIRS called. If +# DIRECTORY is not provided and an installed libltdl is not found, it is +# assumed to be `libltdl'. LIBLTDL will be prefixed with '${top_builddir}/' +# and LTDLINCL will be prefixed with '${top_srcdir}/' (note the single +# quotes!). If your package is not flat and you're not using automake, +# define top_builddir and top_srcdir appropriately in the Makefiles. +# In the future, this macro may have to be called after AC_PROG_LIBTOOL. +AC_DEFUN([AC_LIBLTDL_INSTALLABLE], +[AC_BEFORE([$0],[AC_LIBTOOL_SETUP])dnl + AC_CHECK_LIB(ltdl, lt_dlinit, + [test x"$enable_ltdl_install" != xyes && enable_ltdl_install=no], + [if test x"$enable_ltdl_install" = xno; then + AC_MSG_WARN([libltdl not installed, but installation disabled]) + else + enable_ltdl_install=yes + fi + ]) + if test x"$enable_ltdl_install" = x"yes"; then + ac_configure_args="$ac_configure_args --enable-ltdl-install" + LIBLTDL='${top_builddir}/'ifelse($#,1,[$1],['libltdl'])/libltdl.la + LTDLINCL='-I${top_srcdir}/'ifelse($#,1,[$1],['libltdl']) + else + ac_configure_args="$ac_configure_args --enable-ltdl-install=no" + LIBLTDL="-lltdl" + LTDLINCL= + fi + # For backwards non-gettext consistent compatibility... + INCLTDL="$LTDLINCL" +])# AC_LIBLTDL_INSTALLABLE + + +# AC_LIBTOOL_CXX +# -------------- +# enable support for C++ libraries +AC_DEFUN([AC_LIBTOOL_CXX], +[AC_REQUIRE([_LT_AC_LANG_CXX]) +])# AC_LIBTOOL_CXX + + +# _LT_AC_LANG_CXX +# --------------- +AC_DEFUN([_LT_AC_LANG_CXX], +[AC_REQUIRE([AC_PROG_CXX]) +AC_REQUIRE([AC_PROG_CXXCPP]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}CXX]) +])# _LT_AC_LANG_CXX + + +# AC_LIBTOOL_F77 +# -------------- +# enable support for Fortran 77 libraries +AC_DEFUN([AC_LIBTOOL_F77], +[AC_REQUIRE([_LT_AC_LANG_F77]) +])# AC_LIBTOOL_F77 + + +# _LT_AC_LANG_F77 +# --------------- +AC_DEFUN([_LT_AC_LANG_F77], +[AC_REQUIRE([AC_PROG_F77]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}F77]) +])# _LT_AC_LANG_F77 + + +# AC_LIBTOOL_GCJ +# -------------- +# enable support for GCJ libraries +AC_DEFUN([AC_LIBTOOL_GCJ], +[AC_REQUIRE([_LT_AC_LANG_GCJ]) +])# AC_LIBTOOL_GCJ + + +# _LT_AC_LANG_GCJ +# --------------- +AC_DEFUN([_LT_AC_LANG_GCJ], +[AC_PROVIDE_IFELSE([AC_PROG_GCJ],[], + [AC_PROVIDE_IFELSE([A][M_PROG_GCJ],[], + [AC_PROVIDE_IFELSE([LT_AC_PROG_GCJ],[], + [ifdef([AC_PROG_GCJ],[AC_REQUIRE([AC_PROG_GCJ])], + [ifdef([A][M_PROG_GCJ],[AC_REQUIRE([A][M_PROG_GCJ])], + [AC_REQUIRE([A][C_PROG_GCJ_OR_A][M_PROG_GCJ])])])])])]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}GCJ]) +])# _LT_AC_LANG_GCJ + + +# AC_LIBTOOL_RC +# -------------- +# enable support for Windows resource files +AC_DEFUN([AC_LIBTOOL_RC], +[AC_REQUIRE([LT_AC_PROG_RC]) +_LT_AC_SHELL_INIT([tagnames=${tagnames+${tagnames},}RC]) +])# AC_LIBTOOL_RC + + +# AC_LIBTOOL_LANG_C_CONFIG +# ------------------------ +# Ensure that the configuration vars for the C compiler are +# suitably defined. Those variables are subsequently used by +# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'. +AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG], [_LT_AC_LANG_C_CONFIG]) +AC_DEFUN([_LT_AC_LANG_C_CONFIG], +[lt_save_CC="$CC" +AC_LANG_PUSH(C) + +# Source file extension for C test sources. +ac_ext=c + +# Object file extension for compiled C test sources. +objext=o +_LT_AC_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(){return(0);}\n' + +_LT_AC_SYS_COMPILER + +# +# Check for any special shared library compilation flags. +# +_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)= +if test "$GCC" = no; then + case $host_os in + sco3.2v5*) + _LT_AC_TAGVAR(lt_prog_cc_shlib, $1)='-belf' + ;; + esac +fi +if test -n "$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)"; then + AC_MSG_WARN([`$CC' requires `$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)' to build shared libraries]) + if echo "$old_CC $old_CFLAGS " | grep "[[ ]]$]_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)[[[ ]]" >/dev/null; then : + else + AC_MSG_WARN([add `$_LT_AC_TAGVAR(lt_prog_cc_shlib, $1)' to the CC or CFLAGS env variable and reconfigure]) + _LT_AC_TAGVAR(lt_cv_prog_cc_can_build_shared, $1)=no + fi +fi + + +# +# Check to make sure the static flag actually works. +# +AC_LIBTOOL_LINKER_OPTION([if $compiler static flag $_LT_AC_TAGVAR(lt_prog_compiler_static, $1) works], + _LT_AC_TAGVAR(lt_prog_compiler_static_works, $1), + $_LT_AC_TAGVAR(lt_prog_compiler_static, $1), + [], + [_LT_AC_TAGVAR(lt_prog_compiler_static, $1)=]) + + +## CAVEAT EMPTOR: +## There is no encapsulation within the following macros, do not change +## the running order or otherwise move them around unless you know exactly +## what you are doing... +AC_LIBTOOL_PROG_COMPILER_NO_RTTI($1) +AC_LIBTOOL_PROG_COMPILER_PIC($1) +AC_LIBTOOL_PROG_CC_C_O($1) +AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1) +AC_LIBTOOL_PROG_LD_SHLIBS($1) +AC_LIBTOOL_SYS_DYNAMIC_LINKER($1) +AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1) +AC_LIBTOOL_SYS_LIB_STRIP +AC_LIBTOOL_DLOPEN_SELF($1) + +# Report which librarie types wil actually be built +AC_MSG_CHECKING([if libtool supports shared libraries]) +AC_MSG_RESULT([$can_build_shared]) + +AC_MSG_CHECKING([whether to build shared libraries]) +test "$can_build_shared" = "no" && enable_shared=no + +# On AIX, shared libraries and static libraries use the same namespace, and +# are all built from PIC. +case "$host_os" in +aix3*) + test "$enable_shared" = yes && enable_static=no + if test -n "$RANLIB"; then + archive_cmds="$archive_cmds~\$RANLIB \$lib" + postinstall_cmds='$RANLIB $lib' + fi + ;; + +aix4*) + if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then + test "$enable_shared" = yes && enable_static=no + fi + ;; + darwin* | rhapsody*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + case "$host_os" in + rhapsody* | darwin1.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-undefined suppress' + ;; + *) # Darwin 1.3 on + test -z ${LD_TWOLEVEL_NAMESPACE} && _LT_AC_TAGVAR(allow_undefined_flag, $1)='-flat_namespace -undefined suppress' + ;; + esac + output_verbose_link_cmd='echo' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs$compiler_flags -install_name $rpath/$soname $verstring' + _LT_AC_TAGVAR(module_cmds, $1)='$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib $allow_undefined_flag -o $lib $libobjs $deplibs$compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_automatic, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-all_load $convenience' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; +esac +AC_MSG_RESULT([$enable_shared]) + +AC_MSG_CHECKING([whether to build static libraries]) +# Make sure either enable_shared or enable_static is yes. +test "$enable_shared" = yes || enable_static=yes +AC_MSG_RESULT([$enable_static]) + +AC_LIBTOOL_CONFIG($1) + +AC_LANG_POP +CC="$lt_save_CC" +])# AC_LIBTOOL_LANG_C_CONFIG + + +# AC_LIBTOOL_LANG_CXX_CONFIG +# -------------------------- +# Ensure that the configuration vars for the C compiler are +# suitably defined. Those variables are subsequently used by +# AC_LIBTOOL_CONFIG to write the compiler configuration to `libtool'. +AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG], [_LT_AC_LANG_CXX_CONFIG(CXX)]) +AC_DEFUN([_LT_AC_LANG_CXX_CONFIG], +[AC_LANG_PUSH(C++) +AC_REQUIRE([AC_PROG_CXX]) +AC_REQUIRE([AC_PROG_CXXCPP]) + +_LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no +_LT_AC_TAGVAR(allow_undefined_flag, $1)= +_LT_AC_TAGVAR(always_export_symbols, $1)=no +_LT_AC_TAGVAR(archive_expsym_cmds, $1)= +_LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= +_LT_AC_TAGVAR(hardcode_direct, $1)=no +_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= +_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= +_LT_AC_TAGVAR(hardcode_libdir_separator, $1)= +_LT_AC_TAGVAR(hardcode_minus_L, $1)=no +_LT_AC_TAGVAR(hardcode_automatic, $1)=no +_LT_AC_TAGVAR(module_cmds, $1)= +_LT_AC_TAGVAR(module_expsym_cmds, $1)= +_LT_AC_TAGVAR(link_all_deplibs, $1)=unknown +_LT_AC_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds +_LT_AC_TAGVAR(no_undefined_flag, $1)= +_LT_AC_TAGVAR(whole_archive_flag_spec, $1)= +_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no + +# Dependencies to place before and after the object being linked: +_LT_AC_TAGVAR(predep_objects, $1)= +_LT_AC_TAGVAR(postdep_objects, $1)= +_LT_AC_TAGVAR(predeps, $1)= +_LT_AC_TAGVAR(postdeps, $1)= +_LT_AC_TAGVAR(compiler_lib_search_path, $1)= + +# Source file extension for C++ test sources. +ac_ext=cc + +# Object file extension for compiled C++ test sources. +objext=o +_LT_AC_TAGVAR(objext, $1)=$objext + +# Code to be used in simple compile tests +lt_simple_compile_test_code="int some_variable = 0;\n" + +# Code to be used in simple link tests +lt_simple_link_test_code='int main(int, char *[]) { return(0); }\n' + +# ltmain only uses $CC for tagged configurations so make sure $CC is set. +_LT_AC_SYS_COMPILER + +# Allow CC to be a program name with arguments. +lt_save_CC=$CC +lt_save_LD=$LD +lt_save_GCC=$GCC +GCC=$GXX +lt_save_with_gnu_ld=$with_gnu_ld +lt_save_path_LD=$lt_cv_path_LD +if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then + lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx +else + unset lt_cv_prog_gnu_ld +fi +if test -n "${lt_cv_path_LDCXX+set}"; then + lt_cv_path_LD=$lt_cv_path_LDCXX +else + unset lt_cv_path_LD +fi +test -z "${LDCXX+set}" || LD=$LDCXX +CC=${CXX-"c++"} +compiler=$CC +_LT_AC_TAGVAR(compiler, $1)=$CC +cc_basename=`$echo X"$compiler" | $Xsed -e 's%^.*/%%'` + +# We don't want -fno-exception wen compiling C++ code, so set the +# no_builtin_flag separately +if test "$GXX" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' +else + _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= +fi + +if test "$GXX" = yes; then + # Set up default GNU C++ configuration + + AC_PROG_LD + + # Check if GNU C++ uses GNU ld as the underlying linker, since the + # archiving commands below assume that GNU ld is being used. + if test "$with_gnu_ld" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + + # If archive_cmds runs LD, not CC, wlarc should be empty + # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to + # investigate it a little bit more. (MM) + wlarc='${wl}' + + # ancient GNU ld didn't support --whole-archive et. al. + if eval "`$CC -print-prog-name=ld` --help 2>&1" | \ + grep 'no-whole-archive' > /dev/null; then + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + fi + else + with_gnu_ld=no + wlarc= + + # A generic and very simple default shared library creation + # command for GNU C++ for the case where it uses the native + # linker, instead of GNU ld. If possible, this setting should + # overridden to take advantage of the native linker features on + # the platform it is being used on. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' + fi + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + +else + GXX=no + with_gnu_ld=no + wlarc= +fi + +# PORTME: fill in a description of your system's C++ link characteristics +AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) +_LT_AC_TAGVAR(ld_shlibs, $1)=yes +case $host_os in + aix3*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # KDE requires run time linking. Make it the default. + aix_use_runtimelinking=yes + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_AC_TAGVAR(archive_cmds, $1)='' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + if test "$GXX" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + else + # We have old collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)= + fi + esac + shared_flag='-shared' + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='-qmkshrobj ${wl}-G' + else + shared_flag='-qmkshrobj' + fi + fi + fi + + # Let the compiler handle the export list. + _LT_AC_TAGVAR(always_export_symbols, $1)=no + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + + _LT_AC_TAGVAR(archive_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '" $shared_flag" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' + _LT_AC_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + # Exported symbols can be pulled into shared objects from archives + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=' ' + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + # This is similar to how AIX traditionally builds it's shared libraries. + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + chorus*) + case $cc_basename in + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(always_export_symbols, $1)=no + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + darwin* | rhapsody*) + if test "$GXX" = yes; then + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + case "$host_os" in + rhapsody* | darwin1.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-undefined suppress' + ;; + *) # Darwin 1.3 on + test -z ${LD_TWOLEVEL_NAMESPACE} && _LT_AC_TAGVAR(allow_undefined_flag, $1)='-flat_namespace -undefined suppress' + ;; + esac + lt_int_apple_cc_single_mod=no + output_verbose_link_cmd='echo' + if $CC -dumpspecs 2>&1 | grep 'single_module' >/dev/null ; then + lt_int_apple_cc_single_mod=yes + fi + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -r ${wl}-bind_at_load -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + fi + _LT_AC_TAGVAR(module_cmds, $1)='$CC ${wl}-bind_at_load $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -r ${wl}-bind_at_load -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + fi + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_automatic, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-all_load $convenience' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + dgux*) + case $cc_basename in + ec++) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + ghcx) + # Green Hills C++ Compiler + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + freebsd[12]*) + # C++ shared libraries reported to be fairly broken before switch to ELF + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + freebsd-elf*) + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + ;; + freebsd*) + # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF + # conventions + _LT_AC_TAGVAR(ld_shlibs, $1)=yes + ;; + gnu*) + ;; + hpux9*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + + case $cc_basename in + CC) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + aCC) + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | egrep "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -shared -nostdlib -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + hpux10*|hpux11*) + if test $with_gnu_ld = no; then + case "$host_cpu" in + hppa*64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + ia64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + ;; + *) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + ;; + esac + fi + case "$host_cpu" in + hppa*64*) + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + ia64*) + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + *) + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, + # but as the default + # location of the library. + ;; + esac + + case $cc_basename in + CC) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + aCC) + case "$host_cpu" in + hppa*64*|ia64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | grep "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes; then + if test $with_gnu_ld = no; then + case "$host_cpu" in + ia64*|hppa*64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $linker_flags $libobjs $deplibs' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + ;; + esac + fi + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + irix5* | irix6*) + case $cc_basename in + CC) + # SGI C++ + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${objdir}/so_locations -o $lib' + + # Archives containing C++ object files must be created using + # "CC -ar", where "CC" is the IRIX C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' + ;; + *) + if test "$GXX" = yes; then + if test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${objdir}/so_locations -o $lib' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` -o $lib' + fi + fi + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + ;; + esac + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + linux*) + case $cc_basename in + KCC) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib' + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | grep "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath,$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' + ;; + icpc) + # Intel C++ + with_gnu_ld=yes + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive' + ;; + cxx) + # Compaq C++ + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols' + + runpath_var=LD_RUN_PATH + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + esac + ;; + lynxos*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + m88k*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + mvs*) + case $cc_basename in + cxx) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + netbsd*) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' + wlarc= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + fi + # Workaround some broken pre-1.5 toolchains + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' + ;; + osf3*) + case $cc_basename in + KCC) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Archives containing C++ object files must be created using + # "CC -Bstatic", where "CC" is the KAI C++ compiler. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' + + ;; + RCC) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + cxx) + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && echo ${wl}-set_version $verstring` -update_registry ${objdir}/so_locations -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${objdir}/so_locations -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + osf4* | osf5*) + case $cc_basename in + KCC) + # Kuck and Associates, Inc. (KAI) C++ Compiler + + # KCC will only create a shared library if the output file + # ends with ".so" (or ".sl" for HP-UX), so rename the library + # to its proper name (with version) after linking. + _LT_AC_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Archives containing C++ object files must be created using + # the KAI C++ compiler. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' + ;; + RCC) + # Rational C++ 2.4.1 + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + cxx) + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ + echo "-hidden">> $lib.exp~ + $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname -Wl,-input -Wl,$lib.exp `test -n "$verstring" && echo -set_version $verstring` -update_registry $objdir/so_locations -o $lib~ + $rm $lib.exp' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "ld" | grep -v "ld:"`; templist=`echo $templist | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + ;; + *) + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${objdir}/so_locations -o $lib' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep "\-L"' + + else + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + ;; + psos*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + sco*) + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + case $cc_basename in + CC) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC) + # Sun C++ 4.x + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + lcc) + # Lucid + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + solaris*) + case $cc_basename in + CC) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_AC_TAGVAR(no_undefined_flag, $1)=' -zdefs' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -nolib -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -G${allow_undefined_flag} -nolib ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[0-5] | solaris2.[0-5].*) ;; + *) + # The C++ compiler is used as linker so we must use $wl + # flag to pass the commands to the underlying system + # linker. + # Supported since Solaris 2.6 (maybe 2.5.1?) + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract' + ;; + esac + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + # + # There doesn't appear to be a way to prevent this compiler from + # explicitly linking system object files so we need to strip them + # from the output so that they don't get included in the library + # dependencies. + output_verbose_link_cmd='templist=`$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep "\-[[LR]]"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; echo $list' + + # Archives containing C++ object files must be created using + # "CC -xar", where "CC" is the Sun C++ compiler. This is + # necessary to make sure instantiated templates are included + # in the archive. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' + ;; + gcx) + # Green Hills C++ Compiler + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + + # The C++ compiler must be used to create the archive. + _LT_AC_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' + ;; + *) + # GNU C++ compiler with Solaris linker + if test "$GXX" = yes && test "$with_gnu_ld" = no; then + _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs' + if $CC --version | grep -v '^2\.7' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd="$CC -shared $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" + else + # g++ 2.7 appears to require `-G' NOT `-shared' on this + # platform. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$rm $lib.exp' + + # Commands to make compiler produce verbose output that lists + # what "hidden" libraries, object files and flags are used when + # linking a shared library. + output_verbose_link_cmd="$CC -G $CFLAGS -v conftest.$objext 2>&1 | grep \"\-L\"" + fi + + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir' + fi + ;; + esac + ;; + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7*) + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + ;; + tandem*) + case $cc_basename in + NCC) + # NonStop-UX NCC 3.20 + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + ;; + vxworks*) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + *) + # FIXME: insert proper C++ library support + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; +esac +AC_MSG_RESULT([$_LT_AC_TAGVAR(ld_shlibs, $1)]) +test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no + +_LT_AC_TAGVAR(GCC, $1)="$GXX" +_LT_AC_TAGVAR(LD, $1)="$LD" + +## CAVEAT EMPTOR: +## There is no encapsulation within the following macros, do not change +## the running order or otherwise move them around unless you know exactly +## what you are doing... +AC_LIBTOOL_POSTDEP_PREDEP($1) +AC_LIBTOOL_PROG_COMPILER_PIC($1) +AC_LIBTOOL_PROG_CC_C_O($1) +AC_LIBTOOL_SYS_HARD_LINK_LOCKS($1) +AC_LIBTOOL_PROG_LD_SHLIBS($1) +AC_LIBTOOL_SYS_DYNAMIC_LINKER($1) +AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH($1) +AC_LIBTOOL_SYS_LIB_STRIP +AC_LIBTOOL_DLOPEN_SELF($1) + +AC_LIBTOOL_CONFIG($1) + +AC_LANG_POP +CC=$lt_save_CC +LDCXX=$LD +LD=$lt_save_LD +GCC=$lt_save_GCC +with_gnu_ldcxx=$with_gnu_ld +with_gnu_ld=$lt_save_with_gnu_ld +lt_cv_path_LDCXX=$lt_cv_path_LD +lt_cv_path_LD=$lt_save_path_LD +lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld +lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld +])# AC_LIBTOOL_LANG_CXX_CONFIG + +# AC_LIBTOOL_POSTDEP_PREDEP([TAGNAME]) +# ------------------------ +# Figure out "hidden" library dependencies from verbose +# compiler output when linking a shared library. +# Parse the compiler output and extract the necessary +# objects, libraries and library flags. +AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP],[ +dnl we can't use the lt_simple_compile_test_code here, +dnl because it contains code intended for an executable, +dnl not a library. It's possible we should let each +dnl tag define a new lt_????_link_test_code variable, +dnl but it's only used here... +ifelse([$1],[],[cat > conftest.$ac_ext < conftest.$ac_ext < conftest.$ac_ext < conftest.$ac_ext <> "$cfgfile" +ifelse([$1], [], +[#! $SHELL + +# `$echo "$cfgfile" | sed 's%^.*/%%'` - Provide generalized library-building support services. +# Generated automatically by $PROGRAM (GNU $PACKAGE $VERSION$TIMESTAMP) +# NOTE: Changes made to this file will be lost: look at ltmain.sh. +# +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001 +# Free Software Foundation, Inc. +# +# This file is part of GNU Libtool: +# Originally by Gordon Matzigkeit , 1996 +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +# +# As a special exception to the GNU General Public License, if you +# distribute this file as part of a program that contains a +# configuration script generated by Autoconf, you may include it under +# the same distribution terms that you use for the rest of that program. + +# A sed program that does not truncate output. +SED=$lt_SED + +# Sed that helps us avoid accidentally triggering echo(1) options like -n. +Xsed="$SED -e s/^X//" + +# The HP-UX ksh and POSIX shell print the target directory to stdout +# if CDPATH is set. +if test "X\${CDPATH+set}" = Xset; then CDPATH=:; export CDPATH; fi + +# The names of the tagged configurations supported by this script. +available_tags= + +# ### BEGIN LIBTOOL CONFIG], +[# ### BEGIN LIBTOOL TAG CONFIG: $tagname]) + +# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: + +# Shell to use when invoking shell scripts. +SHELL=$lt_SHELL + +# Whether or not to build shared libraries. +build_libtool_libs=$enable_shared + +# Whether or not to build static libraries. +build_old_libs=$enable_static + +# Whether or not to add -lc for building shared libraries. +build_libtool_need_lc=$_LT_AC_TAGVAR(archive_cmds_need_lc, $1) + +# Whether or not to disallow shared libs when runtime libs are static +allow_libtool_libs_with_static_runtimes=$_LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1) + +# Whether or not to optimize for fast installation. +fast_install=$enable_fast_install + +# The host system. +host_alias=$host_alias +host=$host + +# An echo program that does not interpret backslashes. +echo=$lt_echo + +# The archiver. +AR=$lt_AR +AR_FLAGS=$lt_AR_FLAGS + +# A C compiler. +LTCC=$lt_LTCC + +# A language-specific compiler. +CC=$lt_[]_LT_AC_TAGVAR(compiler, $1) + +# Is the compiler the GNU C compiler? +with_gcc=$_LT_AC_TAGVAR(GCC, $1) + +# An ERE matcher. +EGREP=$lt_EGREP + +# The linker used to build libraries. +LD=$lt_[]_LT_AC_TAGVAR(LD, $1) + +# Whether we need hard or soft links. +LN_S=$lt_LN_S + +# A BSD-compatible nm program. +NM=$lt_NM + +# A symbol stripping program +STRIP=$STRIP + +# Used to examine libraries when file_magic_cmd begins "file" +MAGIC_CMD=$MAGIC_CMD + +# Used on cygwin: DLL creation program. +DLLTOOL="$DLLTOOL" + +# Used on cygwin: object dumper. +OBJDUMP="$OBJDUMP" + +# Used on cygwin: assembler. +AS="$AS" + +# The name of the directory that contains temporary libtool files. +objdir=$objdir + +# How to create reloadable object files. +reload_flag=$lt_reload_flag +reload_cmds=$lt_reload_cmds + +# How to pass a linker flag through the compiler. +wl=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_wl, $1) + +# Object file suffix (normally "o"). +objext="$ac_objext" + +# Old archive suffix (normally "a"). +libext="$libext" + +# Shared library suffix (normally ".so"). +shrext='$shrext' + +# Executable file suffix (normally ""). +exeext="$exeext" + +# Additional compiler flags for building library objects. +pic_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) +pic_mode=$pic_mode + +# What is the maximum length of a command? +max_cmd_len=$lt_cv_sys_max_cmd_len + +# Does compiler simultaneously support -c and -o options? +compiler_c_o=$lt_[]_LT_AC_TAGVAR(lt_cv_prog_compiler_c_o, $1) + +# Must we lock files when doing compilation ? +need_locks=$lt_need_locks + +# Do we need the lib prefix for modules? +need_lib_prefix=$need_lib_prefix + +# Do we need a version for libraries? +need_version=$need_version + +# Whether dlopen is supported. +dlopen_support=$enable_dlopen + +# Whether dlopen of programs is supported. +dlopen_self=$enable_dlopen_self + +# Whether dlopen of statically linked programs is supported. +dlopen_self_static=$enable_dlopen_self_static + +# Compiler flag to prevent dynamic linking. +link_static_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_static, $1) + +# Compiler flag to turn off builtin functions. +no_builtin_flag=$lt_[]_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) + +# Compiler flag to allow reflexive dlopens. +export_dynamic_flag_spec=$lt_[]_LT_AC_TAGVAR(export_dynamic_flag_spec, $1) + +# Compiler flag to generate shared objects directly from archives. +whole_archive_flag_spec=$lt_[]_LT_AC_TAGVAR(whole_archive_flag_spec, $1) + +# Compiler flag to generate thread-safe objects. +thread_safe_flag_spec=$lt_[]_LT_AC_TAGVAR(thread_safe_flag_spec, $1) + +# Library versioning type. +version_type=$version_type + +# Format of library name prefix. +libname_spec=$lt_libname_spec + +# List of archive names. First name is the real one, the rest are links. +# The last name is the one that the linker finds with -lNAME. +library_names_spec=$lt_library_names_spec + +# The coded name of the library, if different from the real name. +soname_spec=$lt_soname_spec + +# Commands used to build and install an old-style archive. +RANLIB=$lt_RANLIB +old_archive_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_cmds, $1) +old_postinstall_cmds=$lt_old_postinstall_cmds +old_postuninstall_cmds=$lt_old_postuninstall_cmds + +# Create an old-style archive from a shared archive. +old_archive_from_new_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_from_new_cmds, $1) + +# Create a temporary old-style archive to link instead of a shared archive. +old_archive_from_expsyms_cmds=$lt_[]_LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1) + +# Commands used to build and install a shared archive. +archive_cmds=$lt_[]_LT_AC_TAGVAR(archive_cmds, $1) +archive_expsym_cmds=$lt_[]_LT_AC_TAGVAR(archive_expsym_cmds, $1) +postinstall_cmds=$lt_postinstall_cmds +postuninstall_cmds=$lt_postuninstall_cmds + +# Commands used to build a loadable module (assumed same as above if empty) +module_cmds=$lt_[]_LT_AC_TAGVAR(module_cmds, $1) +module_expsym_cmds=$lt_[]_LT_AC_TAGVAR(module_expsym_cmds, $1) + +# Commands to strip libraries. +old_striplib=$lt_old_striplib +striplib=$lt_striplib + +# Dependencies to place before the objects being linked to create a +# shared library. +predep_objects=$lt_[]_LT_AC_TAGVAR(predep_objects, $1) + +# Dependencies to place after the objects being linked to create a +# shared library. +postdep_objects=$lt_[]_LT_AC_TAGVAR(postdep_objects, $1) + +# Dependencies to place before the objects being linked to create a +# shared library. +predeps=$lt_[]_LT_AC_TAGVAR(predeps, $1) + +# Dependencies to place after the objects being linked to create a +# shared library. +postdeps=$lt_[]_LT_AC_TAGVAR(postdeps, $1) + +# The library search path used internally by the compiler when linking +# a shared library. +compiler_lib_search_path=$lt_[]_LT_AC_TAGVAR(compiler_lib_search_path, $1) + +# Method to check whether dependent libraries are shared objects. +deplibs_check_method=$lt_deplibs_check_method + +# Command to use when deplibs_check_method == file_magic. +file_magic_cmd=$lt_file_magic_cmd + +# Flag that allows shared libraries with undefined symbols to be built. +allow_undefined_flag=$lt_[]_LT_AC_TAGVAR(allow_undefined_flag, $1) + +# Flag that forces no undefined symbols. +no_undefined_flag=$lt_[]_LT_AC_TAGVAR(no_undefined_flag, $1) + +# Commands used to finish a libtool library installation in a directory. +finish_cmds=$lt_finish_cmds + +# Same as above, but a single script fragment to be evaled but not shown. +finish_eval=$lt_finish_eval + +# Take the output of nm and produce a listing of raw symbols and C names. +global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe + +# Transform the output of nm in a proper C declaration +global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl + +# Transform the output of nm in a C name address pair +global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address + +# This is the shared library runtime path variable. +runpath_var=$runpath_var + +# This is the shared library path variable. +shlibpath_var=$shlibpath_var + +# Is shlibpath searched before the hard-coded library search path? +shlibpath_overrides_runpath=$shlibpath_overrides_runpath + +# How to hardcode a shared library path into an executable. +hardcode_action=$_LT_AC_TAGVAR(hardcode_action, $1) + +# Whether we should hardcode library paths into libraries. +hardcode_into_libs=$hardcode_into_libs + +# Flag to hardcode \$libdir into a binary during linking. +# This must work even if \$libdir does not exist. +hardcode_libdir_flag_spec=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) + +# If ld is used when linking, flag to hardcode \$libdir into +# a binary during linking. This must work even if \$libdir does +# not exist. +hardcode_libdir_flag_spec_ld=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1) + +# Whether we need a single -rpath flag with a separated argument. +hardcode_libdir_separator=$lt_[]_LT_AC_TAGVAR(hardcode_libdir_separator, $1) + +# Set to yes if using DIR/libNAME${shared_ext} during linking hardcodes DIR into the +# resulting binary. +hardcode_direct=$_LT_AC_TAGVAR(hardcode_direct, $1) + +# Set to yes if using the -LDIR flag during linking hardcodes DIR into the +# resulting binary. +hardcode_minus_L=$_LT_AC_TAGVAR(hardcode_minus_L, $1) + +# Set to yes if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into +# the resulting binary. +hardcode_shlibpath_var=$_LT_AC_TAGVAR(hardcode_shlibpath_var, $1) + +# Set to yes if building a shared library automatically hardcodes DIR into the library +# and all subsequent libraries and executables linked against it. +hardcode_automatic=$_LT_AC_TAGVAR(hardcode_automatic, $1) + +# Variables whose values should be saved in libtool wrapper scripts and +# restored at relink time. +variables_saved_for_relink="$variables_saved_for_relink" + +# Whether libtool must link a program against all its dependency libraries. +link_all_deplibs=$_LT_AC_TAGVAR(link_all_deplibs, $1) + +# Compile-time system search path for libraries +sys_lib_search_path_spec=$lt_sys_lib_search_path_spec + +# Run-time system search path for libraries +sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec + +# Fix the shell variable \$srcfile for the compiler. +fix_srcfile_path="$_LT_AC_TAGVAR(fix_srcfile_path, $1)" + +# Set to yes if exported symbols are required. +always_export_symbols=$_LT_AC_TAGVAR(always_export_symbols, $1) + +# The commands to list exported symbols. +export_symbols_cmds=$lt_[]_LT_AC_TAGVAR(export_symbols_cmds, $1) + +# The commands to extract the exported symbol list from a shared archive. +extract_expsyms_cmds=$lt_extract_expsyms_cmds + +# Symbols that should not be listed in the preloaded symbols. +exclude_expsyms=$lt_[]_LT_AC_TAGVAR(exclude_expsyms, $1) + +# Symbols that must always be exported. +include_expsyms=$lt_[]_LT_AC_TAGVAR(include_expsyms, $1) + +ifelse([$1],[], +[# ### END LIBTOOL CONFIG], +[# ### END LIBTOOL TAG CONFIG: $tagname]) + +__EOF__ + +ifelse([$1],[], [ + case $host_os in + aix3*) + cat <<\EOF >> "$cfgfile" + +# AIX sometimes has problems with the GCC collect2 program. For some +# reason, if we set the COLLECT_NAMES environment variable, the problems +# vanish in a puff of smoke. +if test "X${COLLECT_NAMES+set}" != Xset; then + COLLECT_NAMES= + export COLLECT_NAMES +fi +EOF + ;; + esac + + # We use sed instead of cat because bash on DJGPP gets confused if + # if finds mixed CR/LF and LF-only lines. Since sed operates in + # text mode, it properly converts lines to CR/LF. This bash problem + # is reportedly fixed, but why not run on old versions too? + sed '$q' "$ltmain" >> "$cfgfile" || (rm -f "$cfgfile"; exit 1) + + mv -f "$cfgfile" "$ofile" || \ + (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") + chmod +x "$ofile" +]) +else + # If there is no Makefile yet, we rely on a make rule to execute + # `config.status --recheck' to rerun these tests and create the + # libtool script then. + test -f Makefile && make "$ltmain" +fi +])# AC_LIBTOOL_CONFIG + + +# AC_LIBTOOL_PROG_COMPILER_NO_RTTI([TAGNAME]) +# ------------------------------------------- +AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], +[AC_REQUIRE([_LT_AC_SYS_COMPILER])dnl + +_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= + +if test "$GCC" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' + + AC_LIBTOOL_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], + lt_cv_prog_compiler_rtti_exceptions, + [-fno-rtti -fno-exceptions], [], + [_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) +fi +])# AC_LIBTOOL_PROG_COMPILER_NO_RTTI + + +# AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE +# --------------------------------- +AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], +[AC_REQUIRE([AC_CANONICAL_HOST]) +AC_REQUIRE([AC_PROG_NM]) +AC_REQUIRE([AC_OBJEXT]) +# Check for command to grab the raw symbol name followed by C symbol from nm. +AC_MSG_CHECKING([command to parse $NM output from $compiler object]) +AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], +[ +# These are sane defaults that work on at least a few old systems. +# [They come from Ultrix. What could be older than Ultrix?!! ;)] + +# Character class describing NM global symbol codes. +symcode='[[BCDEGRST]]' + +# Regexp to match symbols that can be accessed directly from C. +sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' + +# Transform the above into a raw symbol and a C symbol. +symxfrm='\1 \2\3 \3' + +# Transform an extracted symbol line into a proper C declaration +lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^. .* \(.*\)$/extern int \1;/p'" + +# Transform an extracted symbol line into symbol name and symbol address +lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + +# Define system-specific variables. +case $host_os in +aix*) + symcode='[[BCDT]]' + ;; +cygwin* | mingw* | pw32*) + symcode='[[ABCDGISTW]]' + ;; +hpux*) # Its linker distinguishes data from code symbols + if test "$host_cpu" = ia64; then + symcode='[[ABCDEGRST]]' + fi + lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'" + lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\) $/ {\\\"\1\\\", (lt_ptr) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (lt_ptr) \&\2},/p'" + ;; +irix* | nonstopux*) + symcode='[[BCDEGRST]]' + ;; +osf*) + symcode='[[BCDEGQRST]]' + ;; +solaris* | sysv5*) + symcode='[[BDT]]' + ;; +sysv4) + symcode='[[DFNSTU]]' + ;; +esac + +# Handle CRLF in mingw tool chain +opt_cr= +case $build_os in +mingw*) + opt_cr=`echo 'x\{0,1\}' | tr x '\015'` # option cr in regexp + ;; +esac + +# If we're using GNU nm, then use its standard symbol codes. +case `$NM -V 2>&1` in +*GNU* | *'with BFD'*) + symcode='[[ABCDGISTW]]' ;; +esac + +# Try without a prefix undercore, then with it. +for ac_symprfx in "" "_"; do + + # Write the raw and C identifiers. + lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*\($ac_symprfx\)$sympat$opt_cr$/$symxfrm/p'" + + # Check to see that the pipe works correctly. + pipe_works=no + + rm -f conftest* + cat > conftest.$ac_ext < $nlist) && test -s "$nlist"; then + # Try sorting and uniquifying the output. + if sort "$nlist" | uniq > "$nlist"T; then + mv -f "$nlist"T "$nlist" + else + rm -f "$nlist"T + fi + + # Make sure that we snagged all the symbols we need. + if grep ' nm_test_var$' "$nlist" >/dev/null; then + if grep ' nm_test_func$' "$nlist" >/dev/null; then + cat < conftest.$ac_ext +#ifdef __cplusplus +extern "C" { +#endif + +EOF + # Now generate the symbol file. + eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | grep -v main >> conftest.$ac_ext' + + cat <> conftest.$ac_ext +#if defined (__STDC__) && __STDC__ +# define lt_ptr_t void * +#else +# define lt_ptr_t char * +# define const +#endif + +/* The mapping between symbol names and symbols. */ +const struct { + const char *name; + lt_ptr_t address; +} +lt_preloaded_symbols[[]] = +{ +EOF + $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (lt_ptr_t) \&\2},/" < "$nlist" | grep -v main >> conftest.$ac_ext + cat <<\EOF >> conftest.$ac_ext + {0, (lt_ptr_t) 0} +}; + +#ifdef __cplusplus +} +#endif +EOF + # Now try linking the two files. + mv conftest.$ac_objext conftstm.$ac_objext + lt_save_LIBS="$LIBS" + lt_save_CFLAGS="$CFLAGS" + LIBS="conftstm.$ac_objext" + CFLAGS="$CFLAGS$_LT_AC_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" + if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then + pipe_works=yes + fi + LIBS="$lt_save_LIBS" + CFLAGS="$lt_save_CFLAGS" + else + echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD + fi + else + echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD + fi + else + echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD + cat conftest.$ac_ext >&5 + fi + rm -f conftest* conftst* + + # Do not use the global_symbol_pipe unless it works. + if test "$pipe_works" = yes; then + break + else + lt_cv_sys_global_symbol_pipe= + fi +done +]) +if test -z "$lt_cv_sys_global_symbol_pipe"; then + lt_cv_sys_global_symbol_to_cdecl= +fi +if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then + AC_MSG_RESULT(failed) +else + AC_MSG_RESULT(ok) +fi +]) # AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE + + +# AC_LIBTOOL_PROG_COMPILER_PIC([TAGNAME]) +# --------------------------------------- +AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC], +[_LT_AC_TAGVAR(lt_prog_compiler_wl, $1)= +_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= +_LT_AC_TAGVAR(lt_prog_compiler_static, $1)= + +AC_MSG_CHECKING([for $compiler option to produce PIC]) + ifelse([$1],[CXX],[ + # C++ specific cases for pic, static, wl, etc. + if test "$GXX" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + mingw* | os2* | pw32*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT' + ;; + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + *djgpp*) + # DJGPP does not support shared libraries at all + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + sysv4*MP*) + if test -d /usr/nec; then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case "$host_cpu" in + hppa*64*|ia64*) + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + case $host_os in + aix4* | aix5*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + chorus*) + case $cc_basename in + cxch68) + # Green Hills C++ Compiler + # _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" + ;; + esac + ;; + dgux*) + case $cc_basename in + ec++) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + ghcx) + # Green Hills C++ Compiler + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + freebsd*) + # FreeBSD uses GNU C++ + ;; + hpux9* | hpux10* | hpux11*) + case $cc_basename in + CC) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive" + if test "$host_cpu" != ia64; then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + fi + ;; + aCC) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)="${ac_cv_prog_cc_wl}-a ${ac_cv_prog_cc_wl}archive" + case "$host_cpu" in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + ;; + *) + ;; + esac + ;; + irix5* | irix6* | nonstopux*) + case $cc_basename in + CC) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + # CC pic flag -KPIC is the default. + ;; + *) + ;; + esac + ;; + linux*) + case $cc_basename in + KCC) + # KAI C++ Compiler + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + icpc) + # Intel C++ + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + cxx) + # Compaq C++ + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + *) + ;; + esac + ;; + lynxos*) + ;; + m88k*) + ;; + mvs*) + case $cc_basename in + cxx) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' + ;; + *) + ;; + esac + ;; + netbsd*) + ;; + osf3* | osf4* | osf5*) + case $cc_basename in + KCC) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' + ;; + RCC) + # Rational C++ 2.4.1 + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + cxx) + # Digital/Compaq C++ + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # Make sure the PIC flag is empty. It appears that all Alpha + # Linux and Compaq Tru64 Unix objects are PIC. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + *) + ;; + esac + ;; + psos*) + ;; + sco*) + case $cc_basename in + CC) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + *) + ;; + esac + ;; + solaris*) + case $cc_basename in + CC) + # Sun C++ 4.2, 5.x and Centerline C++ + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + ;; + gcx) + # Green Hills C++ Compiler + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + ;; + *) + ;; + esac + ;; + sunos4*) + case $cc_basename in + CC) + # Sun C++ 4.x + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + lcc) + # Lucid + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + ;; + *) + ;; + esac + ;; + tandem*) + case $cc_basename in + NCC) + # NonStop-UX NCC 3.20 + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + ;; + *) + ;; + esac + ;; + unixware*) + ;; + vxworks*) + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +], +[ + if test "$GCC" = yes; then + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + + case $host_os in + aix*) + # All AIX code is PIC. + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + amigaos*) + # FIXME: we need at least 68020 code to build shared libraries, but + # adding the `-m68020' flag to GCC prevents building anything better, + # like `-m68040'. + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' + ;; + + beos* | cygwin* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) + # PIC is the default for these OSes. + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT' + ;; + + darwin* | rhapsody*) + # PIC is the default on this platform + # Common symbols not allowed in MH_DYLIB files + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' + ;; + + msdosdjgpp*) + # Just because we use GCC doesn't mean we suddenly get shared libraries + # on systems that don't support them. + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + enable_shared=no + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic + fi + ;; + + hpux*) + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case "$host_cpu" in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + ;; + + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' + ;; + esac + else + # PORTME Check for flag to pass linker flags through the system compiler. + case $host_os in + aix*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + if test "$host_cpu" = ia64; then + # AIX 5 now supports IA64 processor + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + else + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' + fi + ;; + + mingw* | pw32* | os2*) + # This hack is so that the source file can tell whether it is being + # built for inclusion in a dll (and should export symbols for example). + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT' + ;; + + hpux9* | hpux10* | hpux11*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but + # not for PA HP-UX. + case "$host_cpu" in + hppa*64*|ia64*) + # +Z the default + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='+Z' + ;; + esac + # Is there a better lt_prog_compiler_static that works with the bundled CC? + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive' + ;; + + irix5* | irix6* | nonstopux*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # PIC (with -KPIC) is the default. + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + newsos6) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + linux*) + case $CC in + icc* | ecc*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-static' + ;; + ccc*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All Alpha code is PIC. + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + esac + ;; + + osf3* | osf4* | osf5*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + # All OSF/1 code is PIC. + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' + ;; + + sco3.2v5*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-Kpic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-dn' + ;; + + solaris*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sunos4*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) + _LT_AC_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + sysv4*MP*) + if test -d /usr/nec ;then + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + fi + ;; + + uts4*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)='-pic' + _LT_AC_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' + ;; + + *) + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no + ;; + esac + fi +]) +AC_MSG_RESULT([$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)]) + +# +# Check to make sure the PIC flag actually works. +# +if test -n "$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)"; then + AC_LIBTOOL_COMPILER_OPTION([if $compiler PIC flag $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) works], + _LT_AC_TAGVAR(lt_prog_compiler_pic_works, $1), + [$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)ifelse([$1],[],[ -DPIC],[ifelse([$1],[CXX],[ -DPIC],[])])], [], + [case $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1) in + "" | " "*) ;; + *) _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)" ;; + esac], + [_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + _LT_AC_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) +fi +case "$host_os" in + # For platforms which do not support PIC, -DPIC is meaningless: + *djgpp*) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)= + ;; + *) + _LT_AC_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_AC_TAGVAR(lt_prog_compiler_pic, $1)ifelse([$1],[],[ -DPIC],[ifelse([$1],[CXX],[ -DPIC],[])])" + ;; +esac +]) + + +# AC_LIBTOOL_PROG_LD_SHLIBS([TAGNAME]) +# ------------------------------------ +# See if the linker supports building shared libraries. +AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS], +[AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) +ifelse([$1],[CXX],[ + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + case $host_os in + aix4* | aix5*) + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + else + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + fi + ;; + pw32*) + _LT_AC_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds" + ;; + cygwin* | mingw*) + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGS]] /s/.* \([[^ ]]*\)/\1 DATA/'\'' | $SED -e '\''/^[[AITW]] /s/.* //'\'' | sort | uniq > $export_symbols' + ;; + *) + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + ;; + esac +],[ + runpath_var= + _LT_AC_TAGVAR(allow_undefined_flag, $1)= + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=no + _LT_AC_TAGVAR(archive_cmds, $1)= + _LT_AC_TAGVAR(archive_expsym_cmds, $1)= + _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)= + _LT_AC_TAGVAR(old_archive_from_expsyms_cmds, $1)= + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)= + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + _LT_AC_TAGVAR(thread_safe_flag_spec, $1)= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)= + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)= + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_minus_L, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(link_all_deplibs, $1)=unknown + _LT_AC_TAGVAR(hardcode_automatic, $1)=no + _LT_AC_TAGVAR(module_cmds, $1)= + _LT_AC_TAGVAR(module_expsym_cmds, $1)= + _LT_AC_TAGVAR(always_export_symbols, $1)=no + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' + # include_expsyms should be a list of space-separated symbols to be *always* + # included in the symbol list + _LT_AC_TAGVAR(include_expsyms, $1)= + # exclude_expsyms can be an extended regexp of symbols to exclude + # it will be wrapped by ` (' and `)$', so one must not match beginning or + # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc', + # as well as any symbol that contains `d'. + _LT_AC_TAGVAR(exclude_expsyms, $1)="_GLOBAL_OFFSET_TABLE_" + # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out + # platforms (ab)use it in PIC code, but their linkers get confused if + # the symbol is explicitly referenced. Since portable code cannot + # rely on this symbol name, it's probably fine to never include it in + # preloaded symbol tables. + extract_expsyms_cmds= + + case $host_os in + cygwin* | mingw* | pw32*) + # FIXME: the MSVC++ port hasn't been tested in a loooong time + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + if test "$GCC" != yes; then + with_gnu_ld=no + fi + ;; + openbsd*) + with_gnu_ld=no + ;; + esac + + _LT_AC_TAGVAR(ld_shlibs, $1)=yes + if test "$with_gnu_ld" = yes; then + # If archive_cmds runs LD, not CC, wlarc should be empty + wlarc='${wl}' + + # See if GNU ld supports shared libraries. + case $host_os in + aix3* | aix4* | aix5*) + # On AIX/PPC, the GNU linker is very broken + if test "$host_cpu" != ia64; then + _LT_AC_TAGVAR(ld_shlibs, $1)=no + cat <&2 + +*** Warning: the GNU linker, at least up to release 2.9.1, is reported +*** to be unable to reliably create shared libraries on AIX. +*** Therefore, libtool is disabling shared libraries support. If you +*** really care for shared libraries, you may want to modify your PATH +*** so that a non-GNU linker is found, and then restart. + +EOF + fi + ;; + + amigaos*) + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + + # Samuel A. Falvo II reports + # that the semantics of dynamic libraries on AmigaOS, at least up + # to version 4, is to share data among multiple programs linked + # with the same dynamic library. Since this doesn't match the + # behavior of shared libraries on other platforms, we can't use + # them. + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + + beos*) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + # Joseph Beckenbach says some releases of gcc + # support --undefined. This deserves some investigation. FIXME + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + cygwin* | mingw* | pw32*) + # _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, + # as there is no search path for DLLs. + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(always_export_symbols, $1)=no + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGS]] /s/.* \([[^ ]]*\)/\1 DATA/'\'' | $SED -e '\''/^[[AITW]] /s/.* //'\'' | sort | uniq > $export_symbols' + + if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + # If the export-symbols file already is a .def file (1st line + # is EXPORTS), use it as is; otherwise, prepend... + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then + cp $export_symbols $output_objdir/$soname.def; + else + echo EXPORTS > $output_objdir/$soname.def; + cat $export_symbols >> $output_objdir/$soname.def; + fi~ + $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--image-base=0x10000000 ${wl}--out-implib,$lib' + else + ld_shlibs=no + fi + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' + wlarc= + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + fi + ;; + + solaris* | sysv5*) + if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then + _LT_AC_TAGVAR(ld_shlibs, $1)=no + cat <&2 + +*** Warning: The releases 2.8.* of the GNU linker cannot reliably +*** create shared libraries on Solaris systems. Therefore, libtool +*** is disabling shared libraries support. We urge you to upgrade GNU +*** binutils to release 2.9.1 or newer. Another option is to modify +*** your PATH or compiler configuration so that the native linker is +*** used, and then restart. + +EOF + elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + sunos4*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' + wlarc= + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib' + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + esac + + if test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = yes; then + runpath_var=LD_RUN_PATH + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic' + # ancient GNU ld didn't support --whole-archive et. al. + if $LD --help 2>&1 | grep 'no-whole-archive' > /dev/null; then + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive' + else + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)= + fi + fi + else + # PORTME fill in a description of your system's linker (not GNU ld) + case $host_os in + aix3*) + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' + # Note: this linker hardcodes the directories in LIBPATH if there + # are no directories specified by -L. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + if test "$GCC" = yes && test -z "$link_static_flag"; then + # Neither direct hardcoding nor static linking is supported with a + # broken collect2. + _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported + fi + ;; + + aix4* | aix5*) + if test "$host_cpu" = ia64; then + # On IA64, the linker does run time linking by default, so we don't + # have to do anything special. + aix_use_runtimelinking=no + exp_sym_flag='-Bexport' + no_entry_flag="" + else + # If we're using GNU nm, then we don't want the "-C" option. + # -C means demangle to AIX nm, but means don't demangle with GNU nm + if $NM -V 2>&1 | grep 'GNU' > /dev/null; then + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + else + _LT_AC_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\[$]2 == "T") || (\[$]2 == "D") || (\[$]2 == "B")) && ([substr](\[$]3,1,1) != ".")) { print \[$]3 } }'\'' | sort -u > $export_symbols' + fi + + # KDE requires run time linking. Make it the default. + aix_use_runtimelinking=yes + exp_sym_flag='-bexport' + no_entry_flag='-bnoentry' + fi + + # When large executables or shared objects are built, AIX ld can + # have problems creating the table of contents. If linking a library + # or program results in "error TOC overflow" add -mminimal-toc to + # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not + # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. + + _LT_AC_TAGVAR(archive_cmds, $1)='' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=':' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + + if test "$GCC" = yes; then + case $host_os in aix4.[012]|aix4.[012].*) + # We only want to do this on AIX 4.2 and lower, the check + # below for broken collect2 doesn't work under 4.3+ + collect2name=`${CC} -print-prog-name=collect2` + if test -f "$collect2name" && \ + strings "$collect2name" | grep resolve_lib_name >/dev/null + then + # We have reworked collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + else + # We have old collect2 + _LT_AC_TAGVAR(hardcode_direct, $1)=unsupported + # It fails to find uninstalled libraries when the uninstalled + # path is not listed in the libpath. Setting hardcode_minus_L + # to unsupported forces relinking + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)= + fi + esac + shared_flag='-shared' + else + # not using gcc + if test "$host_cpu" = ia64; then + # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release + # chokes on -Wl,-G. The following line is correct: + shared_flag='-G' + else + if test "$aix_use_runtimelinking" = yes; then + shared_flag='-qmkshrobj ${wl}-G' + else + shared_flag='-qmkshrobj' + fi + fi + fi + + # Let the compiler handle the export list. + _LT_AC_TAGVAR(always_export_symbols, $1)=no + if test "$aix_use_runtimelinking" = yes; then + # Warning - without using the other runtime loading flags (-brtl), + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-berok' + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + _LT_AC_TAGVAR(archive_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '" $shared_flag" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then echo "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag" + else + if test "$host_cpu" = ia64; then + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib' + _LT_AC_TAGVAR(allow_undefined_flag, $1)="-z nodefs" + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$no_entry_flag \${wl}$exp_sym_flag:\$export_symbols" + else + # Determine the default libpath from the value encoded in an empty executable. + _LT_AC_SYS_LIBPATH_AIX + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath" + # Warning - without using the other run time loading flags, + # -berok will link without error, but may produce a broken library. + _LT_AC_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok' + # -bexpall does not export symbols beginning with underscore (_) + _LT_AC_TAGVAR(always_export_symbols, $1)=yes + # Exported symbols can be pulled into shared objects from archives + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)=' ' + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + # This is similar to how AIX traditionally builds it's shared libraries. + _LT_AC_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs $compiler_flags ${wl}-bE:$export_symbols ${wl}-bnoentry${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname' + fi + fi + ;; + + amigaos*) + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/a2ixlibrary.data~$echo "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$echo "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$echo "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$echo "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + # see comment about different semantics on the GNU ld section + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + + bsdi4*) + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic + ;; + + cygwin* | mingw* | pw32*) + # When not using gcc, we currently assume that we are using + # Microsoft Visual C++. + # hardcode_libdir_flag_spec is actually meaningless, as there is + # no search path for DLLs. + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + # Tell ltmain to make .lib files, not .a files. + libext=lib + # Tell ltmain to make .dll files, not .so files. + shrext=".dll" + # FIXME: Setting linknames here is a bad hack. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `echo "$deplibs" | $SED -e '\''s/ -lc$//'\''` -link -dll~linknames=' + # The linker will automatically build a .lib file if we build a DLL. + _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)='true' + # FIXME: Should let the user specify the lib program. + _LT_AC_TAGVAR(old_archive_cmds, $1)='lib /OUT:$oldlib$oldobjs$old_deplibs' + fix_srcfile_path='`cygpath -w "$srcfile"`' + _LT_AC_TAGVAR(enable_shared_with_static_runtimes, $1)=yes + ;; + + darwin* | rhapsody*) + if test "$GXX" = yes ; then + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + case "$host_os" in + rhapsody* | darwin1.[[012]]) + _LT_AC_TAGVAR(allow_undefined_flag, $1)='-undefined suppress' + ;; + *) # Darwin 1.3 on + test -z ${LD_TWOLEVEL_NAMESPACE} && _LT_AC_TAGVAR(allow_undefined_flag, $1)='-flat_namespace -undefined suppress' + ;; + esac + lt_int_apple_cc_single_mod=no + output_verbose_link_cmd='echo' + if $CC -dumpspecs 2>&1 | grep 'single_module' >/dev/null ; then + lt_int_apple_cc_single_mod=yes + fi + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -r ${wl}-bind_at_load -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring' + fi + _LT_AC_TAGVAR(module_cmds, $1)='$CC ${wl}-bind_at_load $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags' + # Don't fix this by using the ld -exported_symbols_list flag, it doesn't exist in older darwin ld's + if test "X$lt_int_apple_cc_single_mod" = Xyes ; then + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -dynamiclib -single_module $allow_undefined_flag -o $lib $libobjs $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + else + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC -r ${wl}-bind_at_load -keep_private_externs -nostdlib -o ${lib}-master.o $libobjs~$CC -dynamiclib $allow_undefined_flag -o $lib ${lib}-master.o $deplibs $compiler_flags -install_name $rpath/$soname $verstring~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + fi + _LT_AC_TAGVAR(module_expsym_cmds, $1)='sed -e "s,#.*,," -e "s,^[ ]*,," -e "s,^\(..*\),_&," < $export_symbols > $output_objdir/${libname}-symbols.expsym~$CC $allow_undefined_flag -o $lib -bundle $libobjs $deplibs$compiler_flags~nmedit -s $output_objdir/${libname}-symbols.expsym ${lib}' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_automatic, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=unsupported + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-all_load $convenience' + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + else + _LT_AC_TAGVAR(ld_shlibs, $1)=no + fi + ;; + + dgux*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + freebsd1*) + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + + # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor + # support. Future versions do this automatically, but an explicit c++rt0.o + # does not break anything, and helps significantly (at the cost of a little + # extra space). + freebsd2.2*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # Unfortunately, older versions of FreeBSD 2 do not have this feature. + freebsd2*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + # FreeBSD 3 and greater uses gcc -shared to do shared libraries. + freebsd*) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + hpux9*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$CC -shared -fPIC ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$rm $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + ;; + + hpux10* | hpux11*) + if test "$GCC" = yes -a "$with_gnu_ld" = no; then + case "$host_cpu" in + hppa*64*|ia64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared -fPIC ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags' + ;; + esac + else + case "$host_cpu" in + hppa*64*|ia64*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname -o $lib $libobjs $deplibs $linker_flags' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' + ;; + esac + fi + if test "$with_gnu_ld" = no; then + case "$host_cpu" in + hppa*64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='+b $libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + ia64*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + ;; + *) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + + # hardcode_minus_L: Not really in the search PATH, + # but as the default location of the library. + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + ;; + esac + fi + ;; + + irix5* | irix6* | nonstopux*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec_ld, $1)='-rpath $libdir' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + ;; + + netbsd*) + if echo __ELF__ | $CC -E - | grep __ELF__ >/dev/null; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + newsos6) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + openbsd*) + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E' + else + case $host_os in + openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + ;; + *) + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir' + ;; + esac + fi + ;; + + os2*) + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(allow_undefined_flag, $1)=unsupported + _LT_AC_TAGVAR(archive_cmds, $1)='$echo "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$echo "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~$echo DATA >> $output_objdir/$libname.def~$echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~$echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def' + _LT_AC_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def' + ;; + + osf3*) + if test "$GCC" = yes; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + else + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + osf4* | osf5*) # as osf3* with the addition of -msym flag + if test "$GCC" = yes; then + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*' + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && echo ${wl}-set_version ${wl}$verstring` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir' + else + _LT_AC_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -shared${allow_undefined_flag} $libobjs $deplibs $linker_flags -msym -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${output_objdir}/so_locations -o $lib' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; echo "-hidden">> $lib.exp~ + $LD -shared${allow_undefined_flag} -input $lib.exp $linker_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && echo -set_version $verstring` -update_registry ${objdir}/so_locations -o $lib~$rm $lib.exp' + + # Both c and cxx compiler support -rpath directly + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' + fi + _LT_AC_TAGVAR(hardcode_libdir_separator, $1)=: + ;; + + sco3.2v5*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport' + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + ;; + + solaris*) + _LT_AC_TAGVAR(no_undefined_flag, $1)=' -z text' + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $CC -shared ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$rm $lib.exp' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + case $host_os in + solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; + *) # Supported since Solaris 2.6 (maybe 2.5.1?) + _LT_AC_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; + esac + _LT_AC_TAGVAR(link_all_deplibs, $1)=yes + ;; + + sunos4*) + if test "x$host_vendor" = xsequent; then + # Use $CC to link under sequent, because it throws in some extra .o + # files that make .init and .fini sections work. + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' + fi + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=yes + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4) + case $host_vendor in + sni) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes # is this really true??? + ;; + siemens) + ## LD is ld it makes a PLAMLIB + ## CC just makes a GrossModule. + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' + _LT_AC_TAGVAR(hardcode_direct, $1)=no + ;; + motorola) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie + ;; + esac + runpath_var='LD_RUN_PATH' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv4.3*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + _LT_AC_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' + ;; + + sysv4*MP*) + if test -d /usr/nec; then + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var=LD_RUN_PATH + hardcode_runpath_var=yes + _LT_AC_TAGVAR(ld_shlibs, $1)=yes + fi + ;; + + sysv4.2uw2*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_direct, $1)=yes + _LT_AC_TAGVAR(hardcode_minus_L, $1)=no + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + hardcode_runpath_var=yes + runpath_var=LD_RUN_PATH + ;; + + sysv5OpenUNIX8* | sysv5UnixWare7* | sysv5uw[[78]]* | unixware7*) + _LT_AC_TAGVAR(no_undefined_flag, $1)='${wl}-z ${wl}text' + if test "$GCC" = yes; then + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + else + _LT_AC_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags' + fi + runpath_var='LD_RUN_PATH' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + sysv5*) + _LT_AC_TAGVAR(no_undefined_flag, $1)=' -z text' + # $CC -shared without GNU ld will not create a library from C++ + # object files and a static libstdc++, better avoid it by now + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(archive_expsym_cmds, $1)='$echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~$echo "local: *; };" >> $lib.exp~ + $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$rm $lib.exp' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)= + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + runpath_var='LD_RUN_PATH' + ;; + + uts4*) + _LT_AC_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' + _LT_AC_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' + _LT_AC_TAGVAR(hardcode_shlibpath_var, $1)=no + ;; + + *) + _LT_AC_TAGVAR(ld_shlibs, $1)=no + ;; + esac + fi +]) +AC_MSG_RESULT([$_LT_AC_TAGVAR(ld_shlibs, $1)]) +test "$_LT_AC_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no + +variables_saved_for_relink="PATH $shlibpath_var $runpath_var" +if test "$GCC" = yes; then + variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" +fi + +# +# Do we need to explicitly link libc? +# +case "x$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)" in +x|xyes) + # Assume -lc should be added + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + + if test "$enable_shared" = yes && test "$GCC" = yes; then + case $_LT_AC_TAGVAR(archive_cmds, $1) in + *'~'*) + # FIXME: we may have to deal with multi-command sequences. + ;; + '$CC '*) + # Test whether the compiler implicitly links with -lc since on some + # systems, -lgcc has to come before -lc. If gcc already passes -lc + # to ld, don't add -lc before -lgcc. + AC_MSG_CHECKING([whether -lc should be explicitly linked in]) + $rm conftest* + printf "$lt_simple_compile_test_code" > conftest.$ac_ext + + if AC_TRY_EVAL(ac_compile) 2>conftest.err; then + soname=conftest + lib=conftest + libobjs=conftest.$ac_objext + deplibs= + wl=$_LT_AC_TAGVAR(lt_prog_compiler_wl, $1) + compiler_flags=-v + linker_flags=-v + verstring= + output_objdir=. + libname=conftest + lt_save_allow_undefined_flag=$_LT_AC_TAGVAR(allow_undefined_flag, $1) + _LT_AC_TAGVAR(allow_undefined_flag, $1)= + if AC_TRY_EVAL(_LT_AC_TAGVAR(archive_cmds, $1) 2\>\&1 \| grep \" -lc \" \>/dev/null 2\>\&1) + then + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=no + else + _LT_AC_TAGVAR(archive_cmds_need_lc, $1)=yes + fi + _LT_AC_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag + else + cat conftest.err 1>&5 + fi + $rm conftest* + AC_MSG_RESULT([$_LT_AC_TAGVAR(archive_cmds_need_lc, $1)]) + ;; + esac + fi + ;; +esac +])# AC_LIBTOOL_PROG_LD_SHLIBS + + +# _LT_AC_FILE_LTDLL_C +# ------------------- +# Be careful that the start marker always follows a newline. +AC_DEFUN([_LT_AC_FILE_LTDLL_C], [ +# /* ltdll.c starts here */ +# #define WIN32_LEAN_AND_MEAN +# #include +# #undef WIN32_LEAN_AND_MEAN +# #include +# +# #ifndef __CYGWIN__ +# # ifdef __CYGWIN32__ +# # define __CYGWIN__ __CYGWIN32__ +# # endif +# #endif +# +# #ifdef __cplusplus +# extern "C" { +# #endif +# BOOL APIENTRY DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved); +# #ifdef __cplusplus +# } +# #endif +# +# #ifdef __CYGWIN__ +# #include +# DECLARE_CYGWIN_DLL( DllMain ); +# #endif +# HINSTANCE __hDllInstance_base; +# +# BOOL APIENTRY +# DllMain (HINSTANCE hInst, DWORD reason, LPVOID reserved) +# { +# __hDllInstance_base = hInst; +# return TRUE; +# } +# /* ltdll.c ends here */ +])# _LT_AC_FILE_LTDLL_C + + +# _LT_AC_TAGVAR(VARNAME, [TAGNAME]) +# --------------------------------- +AC_DEFUN([_LT_AC_TAGVAR], [ifelse([$2], [], [$1], [$1_$2])]) + + +# old names +AC_DEFUN([AM_PROG_LIBTOOL], [AC_PROG_LIBTOOL]) +AC_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) +AC_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) +AC_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) +AC_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) +AC_DEFUN([AM_PROG_LD], [AC_PROG_LD]) +AC_DEFUN([AM_PROG_NM], [AC_PROG_NM]) + +# This is just to silence aclocal about the macro not being used +ifelse([AC_DISABLE_FAST_INSTALL]) + +AC_DEFUN([LT_AC_PROG_GCJ], +[AC_CHECK_TOOL(GCJ, gcj, no) + test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2" + AC_SUBST(GCJFLAGS) +]) + +AC_DEFUN([LT_AC_PROG_RC], +[AC_CHECK_TOOL(RC, windres, no) +]) + +############################################################ +# NOTE: This macro has been submitted for inclusion into # +# GNU Autoconf as AC_PROG_SED. When it is available in # +# a released version of Autoconf we should remove this # +# macro and use it instead. # +############################################################ +# LT_AC_PROG_SED +# -------------- +# Check for a fully-functional sed program, that truncates +# as few characters as possible. Prefer GNU sed if found. +AC_DEFUN([LT_AC_PROG_SED], +[AC_MSG_CHECKING([for a sed that does not truncate output]) +AC_CACHE_VAL(lt_cv_path_SED, +[# Loop through the user's path and test for sed and gsed. +# Then use that list of sed's as ones to test for truncation. +as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for lt_ac_prog in sed gsed; do + for ac_exec_ext in '' $ac_executable_extensions; do + if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then + lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" + fi + done + done +done +lt_ac_max=0 +lt_ac_count=0 +# Add /usr/xpg4/bin/sed as it is typically found on Solaris +# along with /bin/sed that truncates output. +for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do + test ! -f $lt_ac_sed && break + cat /dev/null > conftest.in + lt_ac_count=0 + echo $ECHO_N "0123456789$ECHO_C" >conftest.in + # Check for GNU sed and select it if it is found. + if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then + lt_cv_path_SED=$lt_ac_sed + break + fi + while true; do + cat conftest.in conftest.in >conftest.tmp + mv conftest.tmp conftest.in + cp conftest.in conftest.nl + echo >>conftest.nl + $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break + cmp -s conftest.out conftest.nl || break + # 10000 chars as input seems more than enough + test $lt_ac_count -gt 10 && break + lt_ac_count=`expr $lt_ac_count + 1` + if test $lt_ac_count -gt $lt_ac_max; then + lt_ac_max=$lt_ac_count + lt_cv_path_SED=$lt_ac_sed + fi + done +done +]) +SED=$lt_cv_path_SED +AC_MSG_RESULT([$SED]) +]) diff --git a/aclocal.m4 b/aclocal.m4 new file mode 100644 index 0000000..87ce185 --- /dev/null +++ b/aclocal.m4 @@ -0,0 +1,881 @@ +# generated automatically by aclocal 1.10.1 -*- Autoconf -*- + +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, +# 2005, 2006, 2007, 2008 Free Software Foundation, Inc. +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +m4_if(AC_AUTOCONF_VERSION, [2.63],, +[m4_warning([this file was generated for autoconf 2.63. +You have another version of autoconf. It may work, but is not guaranteed to. +If you have problems, you may need to regenerate the build system entirely. +To do so, use the procedure documented by the package, typically `autoreconf'.])]) + +# Copyright (C) 2002, 2003, 2005, 2006, 2007 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_AUTOMAKE_VERSION(VERSION) +# ---------------------------- +# Automake X.Y traces this macro to ensure aclocal.m4 has been +# generated from the m4 files accompanying Automake X.Y. +# (This private macro should not be called outside this file.) +AC_DEFUN([AM_AUTOMAKE_VERSION], +[am__api_version='1.10' +dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to +dnl require some minimum version. Point them to the right macro. +m4_if([$1], [1.10.1], [], + [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl +]) + +# _AM_AUTOCONF_VERSION(VERSION) +# ----------------------------- +# aclocal traces this macro to find the Autoconf version. +# This is a private macro too. Using m4_define simplifies +# the logic in aclocal, which can simply ignore this definition. +m4_define([_AM_AUTOCONF_VERSION], []) + +# AM_SET_CURRENT_AUTOMAKE_VERSION +# ------------------------------- +# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. +# This function is AC_REQUIREd by AC_INIT_AUTOMAKE. +AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], +[AM_AUTOMAKE_VERSION([1.10.1])dnl +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +_AM_AUTOCONF_VERSION(AC_AUTOCONF_VERSION)]) + +# AM_AUX_DIR_EXPAND -*- Autoconf -*- + +# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets +# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to +# `$srcdir', `$srcdir/..', or `$srcdir/../..'. +# +# Of course, Automake must honor this variable whenever it calls a +# tool from the auxiliary directory. The problem is that $srcdir (and +# therefore $ac_aux_dir as well) can be either absolute or relative, +# depending on how configure is run. This is pretty annoying, since +# it makes $ac_aux_dir quite unusable in subdirectories: in the top +# source directory, any form will work fine, but in subdirectories a +# relative path needs to be adjusted first. +# +# $ac_aux_dir/missing +# fails when called from a subdirectory if $ac_aux_dir is relative +# $top_srcdir/$ac_aux_dir/missing +# fails if $ac_aux_dir is absolute, +# fails when called from a subdirectory in a VPATH build with +# a relative $ac_aux_dir +# +# The reason of the latter failure is that $top_srcdir and $ac_aux_dir +# are both prefixed by $srcdir. In an in-source build this is usually +# harmless because $srcdir is `.', but things will broke when you +# start a VPATH build or use an absolute $srcdir. +# +# So we could use something similar to $top_srcdir/$ac_aux_dir/missing, +# iff we strip the leading $srcdir from $ac_aux_dir. That would be: +# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` +# and then we would define $MISSING as +# MISSING="\${SHELL} $am_aux_dir/missing" +# This will work as long as MISSING is not called from configure, because +# unfortunately $(top_srcdir) has no meaning in configure. +# However there are other variables, like CC, which are often used in +# configure, and could therefore not use this "fixed" $ac_aux_dir. +# +# Another solution, used here, is to always expand $ac_aux_dir to an +# absolute PATH. The drawback is that using absolute paths prevent a +# configured tree to be moved without reconfiguration. + +AC_DEFUN([AM_AUX_DIR_EXPAND], +[dnl Rely on autoconf to set up CDPATH properly. +AC_PREREQ([2.50])dnl +# expand $ac_aux_dir to an absolute path +am_aux_dir=`cd $ac_aux_dir && pwd` +]) + +# AM_CONDITIONAL -*- Autoconf -*- + +# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005, 2006 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 8 + +# AM_CONDITIONAL(NAME, SHELL-CONDITION) +# ------------------------------------- +# Define a conditional. +AC_DEFUN([AM_CONDITIONAL], +[AC_PREREQ(2.52)dnl + ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], + [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl +AC_SUBST([$1_TRUE])dnl +AC_SUBST([$1_FALSE])dnl +_AM_SUBST_NOTMAKE([$1_TRUE])dnl +_AM_SUBST_NOTMAKE([$1_FALSE])dnl +if $2; then + $1_TRUE= + $1_FALSE='#' +else + $1_TRUE='#' + $1_FALSE= +fi +AC_CONFIG_COMMANDS_PRE( +[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then + AC_MSG_ERROR([[conditional "$1" was never defined. +Usually this means the macro was only invoked conditionally.]]) +fi])]) + +# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 9 + +# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be +# written in clear, in which case automake, when reading aclocal.m4, +# will think it sees a *use*, and therefore will trigger all it's +# C support machinery. Also note that it means that autoscan, seeing +# CC etc. in the Makefile, will ask for an AC_PROG_CC use... + + +# _AM_DEPENDENCIES(NAME) +# ---------------------- +# See how the compiler implements dependency checking. +# NAME is "CC", "CXX", "GCJ", or "OBJC". +# We try a few techniques and use that to set a single cache variable. +# +# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was +# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular +# dependency, and given that the user is not expected to run this macro, +# just rely on AC_PROG_CC. +AC_DEFUN([_AM_DEPENDENCIES], +[AC_REQUIRE([AM_SET_DEPDIR])dnl +AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl +AC_REQUIRE([AM_MAKE_INCLUDE])dnl +AC_REQUIRE([AM_DEP_TRACK])dnl + +ifelse([$1], CC, [depcc="$CC" am_compiler_list=], + [$1], CXX, [depcc="$CXX" am_compiler_list=], + [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'], + [$1], UPC, [depcc="$UPC" am_compiler_list=], + [$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'], + [depcc="$$1" am_compiler_list=]) + +AC_CACHE_CHECK([dependency style of $depcc], + [am_cv_$1_dependencies_compiler_type], +[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then + # We make a subdir and do the tests there. Otherwise we can end up + # making bogus files that we don't know about and never remove. For + # instance it was reported that on HP-UX the gcc test will end up + # making a dummy file named `D' -- because `-MD' means `put the output + # in D'. + mkdir conftest.dir + # Copy depcomp to subdir because otherwise we won't find it if we're + # using a relative directory. + cp "$am_depcomp" conftest.dir + cd conftest.dir + # We will build objects and dependencies in a subdirectory because + # it helps to detect inapplicable dependency modes. For instance + # both Tru64's cc and ICC support -MD to output dependencies as a + # side effect of compilation, but ICC will put the dependencies in + # the current directory while Tru64 will put them in the object + # directory. + mkdir sub + + am_cv_$1_dependencies_compiler_type=none + if test "$am_compiler_list" = ""; then + am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` + fi + for depmode in $am_compiler_list; do + # Setup a source with many dependencies, because some compilers + # like to wrap large dependency lists on column 80 (with \), and + # we should not choose a depcomp mode which is confused by this. + # + # We need to recreate these files for each test, as the compiler may + # overwrite some of them when testing with obscure command lines. + # This happens at least with the AIX C compiler. + : > sub/conftest.c + for i in 1 2 3 4 5 6; do + echo '#include "conftst'$i'.h"' >> sub/conftest.c + # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with + # Solaris 8's {/usr,}/bin/sh. + touch sub/conftst$i.h + done + echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf + + case $depmode in + nosideeffect) + # after this tag, mechanisms are not by side-effect, so they'll + # only be used when explicitly requested + if test "x$enable_dependency_tracking" = xyes; then + continue + else + break + fi + ;; + none) break ;; + esac + # We check with `-c' and `-o' for the sake of the "dashmstdout" + # mode. It turns out that the SunPro C++ compiler does not properly + # handle `-M -o', and we need to detect this. + if depmode=$depmode \ + source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \ + depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ + $SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \ + >/dev/null 2>conftest.err && + grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && + grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 && + ${MAKE-make} -s -f confmf > /dev/null 2>&1; then + # icc doesn't choke on unknown options, it will just issue warnings + # or remarks (even with -Werror). So we grep stderr for any message + # that says an option was ignored or not supported. + # When given -MP, icc 7.0 and 7.1 complain thusly: + # icc: Command line warning: ignoring option '-M'; no argument required + # The diagnosis changed in icc 8.0: + # icc: Command line remark: option '-MP' not supported + if (grep 'ignoring option' conftest.err || + grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else + am_cv_$1_dependencies_compiler_type=$depmode + break + fi + fi + done + + cd .. + rm -rf conftest.dir +else + am_cv_$1_dependencies_compiler_type=none +fi +]) +AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) +AM_CONDITIONAL([am__fastdep$1], [ + test "x$enable_dependency_tracking" != xno \ + && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) +]) + + +# AM_SET_DEPDIR +# ------------- +# Choose a directory name for dependency files. +# This macro is AC_REQUIREd in _AM_DEPENDENCIES +AC_DEFUN([AM_SET_DEPDIR], +[AC_REQUIRE([AM_SET_LEADING_DOT])dnl +AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl +]) + + +# AM_DEP_TRACK +# ------------ +AC_DEFUN([AM_DEP_TRACK], +[AC_ARG_ENABLE(dependency-tracking, +[ --disable-dependency-tracking speeds up one-time build + --enable-dependency-tracking do not reject slow dependency extractors]) +if test "x$enable_dependency_tracking" != xno; then + am_depcomp="$ac_aux_dir/depcomp" + AMDEPBACKSLASH='\' +fi +AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) +AC_SUBST([AMDEPBACKSLASH])dnl +_AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl +]) + +# Generate code to set up dependency tracking. -*- Autoconf -*- + +# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +#serial 3 + +# _AM_OUTPUT_DEPENDENCY_COMMANDS +# ------------------------------ +AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], +[for mf in $CONFIG_FILES; do + # Strip MF so we end up with the name of the file. + mf=`echo "$mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile or not. + # We used to match only the files named `Makefile.in', but + # some people rename them; so instead we look at the file content. + # Grep'ing the first line is not enough: some people post-process + # each Makefile.in and add a new line on top of each file to say so. + # Grep'ing the whole file is not good either: AIX grep has a line + # limit of 2048, but all sed's we know have understand at least 4000. + if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then + dirpart=`AS_DIRNAME("$mf")` + else + continue + fi + # Extract the definition of DEPDIR, am__include, and am__quote + # from the Makefile without running `make'. + DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` + test -z "$DEPDIR" && continue + am__include=`sed -n 's/^am__include = //p' < "$mf"` + test -z "am__include" && continue + am__quote=`sed -n 's/^am__quote = //p' < "$mf"` + # When using ansi2knr, U may be empty or an underscore; expand it + U=`sed -n 's/^U = //p' < "$mf"` + # Find all dependency output files, they are included files with + # $(DEPDIR) in their names. We invoke sed twice because it is the + # simplest approach to changing $(DEPDIR) to its actual value in the + # expansion. + for file in `sed -n " + s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ + sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do + # Make sure the directory exists. + test -f "$dirpart/$file" && continue + fdir=`AS_DIRNAME(["$file"])` + AS_MKDIR_P([$dirpart/$fdir]) + # echo "creating $dirpart/$file" + echo '# dummy' > "$dirpart/$file" + done +done +])# _AM_OUTPUT_DEPENDENCY_COMMANDS + + +# AM_OUTPUT_DEPENDENCY_COMMANDS +# ----------------------------- +# This macro should only be invoked once -- use via AC_REQUIRE. +# +# This code is only required when automatic dependency tracking +# is enabled. FIXME. This creates each `.P' file that we will +# need in order to bootstrap the dependency handling code. +AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], +[AC_CONFIG_COMMANDS([depfiles], + [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], + [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) +]) + +# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 8 + +# AM_CONFIG_HEADER is obsolete. It has been replaced by AC_CONFIG_HEADERS. +AU_DEFUN([AM_CONFIG_HEADER], [AC_CONFIG_HEADERS($@)]) + +# Do all the work for Automake. -*- Autoconf -*- + +# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, +# 2005, 2006, 2008 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 13 + +# This macro actually does too much. Some checks are only needed if +# your package does certain things. But this isn't really a big deal. + +# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) +# AM_INIT_AUTOMAKE([OPTIONS]) +# ----------------------------------------------- +# The call with PACKAGE and VERSION arguments is the old style +# call (pre autoconf-2.50), which is being phased out. PACKAGE +# and VERSION should now be passed to AC_INIT and removed from +# the call to AM_INIT_AUTOMAKE. +# We support both call styles for the transition. After +# the next Automake release, Autoconf can make the AC_INIT +# arguments mandatory, and then we can depend on a new Autoconf +# release and drop the old call support. +AC_DEFUN([AM_INIT_AUTOMAKE], +[AC_PREREQ([2.60])dnl +dnl Autoconf wants to disallow AM_ names. We explicitly allow +dnl the ones we care about. +m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl +AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl +AC_REQUIRE([AC_PROG_INSTALL])dnl +if test "`cd $srcdir && pwd`" != "`pwd`"; then + # Use -I$(srcdir) only when $(srcdir) != ., so that make's output + # is not polluted with repeated "-I." + AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl + # test to see if srcdir already configured + if test -f $srcdir/config.status; then + AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) + fi +fi + +# test whether we have cygpath +if test -z "$CYGPATH_W"; then + if (cygpath --version) >/dev/null 2>/dev/null; then + CYGPATH_W='cygpath -w' + else + CYGPATH_W=echo + fi +fi +AC_SUBST([CYGPATH_W]) + +# Define the identity of the package. +dnl Distinguish between old-style and new-style calls. +m4_ifval([$2], +[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl + AC_SUBST([PACKAGE], [$1])dnl + AC_SUBST([VERSION], [$2])], +[_AM_SET_OPTIONS([$1])dnl +dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. +m4_if(m4_ifdef([AC_PACKAGE_NAME], 1)m4_ifdef([AC_PACKAGE_VERSION], 1), 11,, + [m4_fatal([AC_INIT should be called with package and version arguments])])dnl + AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl + AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl + +_AM_IF_OPTION([no-define],, +[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) + AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl + +# Some tools Automake needs. +AC_REQUIRE([AM_SANITY_CHECK])dnl +AC_REQUIRE([AC_ARG_PROGRAM])dnl +AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version}) +AM_MISSING_PROG(AUTOCONF, autoconf) +AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version}) +AM_MISSING_PROG(AUTOHEADER, autoheader) +AM_MISSING_PROG(MAKEINFO, makeinfo) +AM_PROG_INSTALL_SH +AM_PROG_INSTALL_STRIP +AC_REQUIRE([AM_PROG_MKDIR_P])dnl +# We need awk for the "check" target. The system "awk" is bad on +# some platforms. +AC_REQUIRE([AC_PROG_AWK])dnl +AC_REQUIRE([AC_PROG_MAKE_SET])dnl +AC_REQUIRE([AM_SET_LEADING_DOT])dnl +_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], + [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], + [_AM_PROG_TAR([v7])])]) +_AM_IF_OPTION([no-dependencies],, +[AC_PROVIDE_IFELSE([AC_PROG_CC], + [_AM_DEPENDENCIES(CC)], + [define([AC_PROG_CC], + defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl +AC_PROVIDE_IFELSE([AC_PROG_CXX], + [_AM_DEPENDENCIES(CXX)], + [define([AC_PROG_CXX], + defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl +AC_PROVIDE_IFELSE([AC_PROG_OBJC], + [_AM_DEPENDENCIES(OBJC)], + [define([AC_PROG_OBJC], + defn([AC_PROG_OBJC])[_AM_DEPENDENCIES(OBJC)])])dnl +]) +]) + + +# When config.status generates a header, we must update the stamp-h file. +# This file resides in the same directory as the config header +# that is generated. The stamp files are numbered to have different names. + +# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the +# loop where config.status creates the headers, so we can generate +# our stamp files there. +AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], +[# Compute $1's index in $config_headers. +_am_arg=$1 +_am_stamp_count=1 +for _am_header in $config_headers :; do + case $_am_header in + $_am_arg | $_am_arg:* ) + break ;; + * ) + _am_stamp_count=`expr $_am_stamp_count + 1` ;; + esac +done +echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) + +# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_SH +# ------------------ +# Define $install_sh. +AC_DEFUN([AM_PROG_INSTALL_SH], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +install_sh=${install_sh-"\$(SHELL) $am_aux_dir/install-sh"} +AC_SUBST(install_sh)]) + +# Copyright (C) 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 2 + +# Check whether the underlying file-system supports filenames +# with a leading dot. For instance MS-DOS doesn't. +AC_DEFUN([AM_SET_LEADING_DOT], +[rm -rf .tst 2>/dev/null +mkdir .tst 2>/dev/null +if test -d .tst; then + am__leading_dot=. +else + am__leading_dot=_ +fi +rmdir .tst 2>/dev/null +AC_SUBST([am__leading_dot])]) + +# Check to see how 'make' treats includes. -*- Autoconf -*- + +# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 3 + +# AM_MAKE_INCLUDE() +# ----------------- +# Check to see how make treats includes. +AC_DEFUN([AM_MAKE_INCLUDE], +[am_make=${MAKE-make} +cat > confinc << 'END' +am__doit: + @echo done +.PHONY: am__doit +END +# If we don't find an include directive, just comment out the code. +AC_MSG_CHECKING([for style of include used by $am_make]) +am__include="#" +am__quote= +_am_result=none +# First try GNU make style include. +echo "include confinc" > confmf +# We grep out `Entering directory' and `Leaving directory' +# messages which can occur if `w' ends up in MAKEFLAGS. +# In particular we don't look at `^make:' because GNU make might +# be invoked under some other name (usually "gmake"), in which +# case it prints its new name instead of `make'. +if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then + am__include=include + am__quote= + _am_result=GNU +fi +# Now try BSD make style include. +if test "$am__include" = "#"; then + echo '.include "confinc"' > confmf + if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then + am__include=.include + am__quote="\"" + _am_result=BSD + fi +fi +AC_SUBST([am__include]) +AC_SUBST([am__quote]) +AC_MSG_RESULT([$_am_result]) +rm -f confinc confmf +]) + +# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- + +# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2004, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 5 + +# AM_MISSING_PROG(NAME, PROGRAM) +# ------------------------------ +AC_DEFUN([AM_MISSING_PROG], +[AC_REQUIRE([AM_MISSING_HAS_RUN]) +$1=${$1-"${am_missing_run}$2"} +AC_SUBST($1)]) + + +# AM_MISSING_HAS_RUN +# ------------------ +# Define MISSING if not defined so far and test if it supports --run. +# If it does, set am_missing_run to use it, otherwise, to nothing. +AC_DEFUN([AM_MISSING_HAS_RUN], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +AC_REQUIRE_AUX_FILE([missing])dnl +test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing" +# Use eval to expand $SHELL +if eval "$MISSING --run true"; then + am_missing_run="$MISSING --run " +else + am_missing_run= + AC_MSG_WARN([`missing' script is too old or missing]) +fi +]) + +# Copyright (C) 2003, 2004, 2005, 2006 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_MKDIR_P +# --------------- +# Check for `mkdir -p'. +AC_DEFUN([AM_PROG_MKDIR_P], +[AC_PREREQ([2.60])dnl +AC_REQUIRE([AC_PROG_MKDIR_P])dnl +dnl Automake 1.8 to 1.9.6 used to define mkdir_p. We now use MKDIR_P, +dnl while keeping a definition of mkdir_p for backward compatibility. +dnl @MKDIR_P@ is magic: AC_OUTPUT adjusts its value for each Makefile. +dnl However we cannot define mkdir_p as $(MKDIR_P) for the sake of +dnl Makefile.ins that do not define MKDIR_P, so we do our own +dnl adjustment using top_builddir (which is defined more often than +dnl MKDIR_P). +AC_SUBST([mkdir_p], ["$MKDIR_P"])dnl +case $mkdir_p in + [[\\/$]]* | ?:[[\\/]]*) ;; + */*) mkdir_p="\$(top_builddir)/$mkdir_p" ;; +esac +]) + +# Helper functions for option handling. -*- Autoconf -*- + +# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 3 + +# _AM_MANGLE_OPTION(NAME) +# ----------------------- +AC_DEFUN([_AM_MANGLE_OPTION], +[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) + +# _AM_SET_OPTION(NAME) +# ------------------------------ +# Set option NAME. Presently that only means defining a flag for this option. +AC_DEFUN([_AM_SET_OPTION], +[m4_define(_AM_MANGLE_OPTION([$1]), 1)]) + +# _AM_SET_OPTIONS(OPTIONS) +# ---------------------------------- +# OPTIONS is a space-separated list of Automake options. +AC_DEFUN([_AM_SET_OPTIONS], +[AC_FOREACH([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) + +# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) +# ------------------------------------------- +# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. +AC_DEFUN([_AM_IF_OPTION], +[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) + +# Check to make sure that the build environment is sane. -*- Autoconf -*- + +# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005 +# Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 4 + +# AM_SANITY_CHECK +# --------------- +AC_DEFUN([AM_SANITY_CHECK], +[AC_MSG_CHECKING([whether build environment is sane]) +# Just in case +sleep 1 +echo timestamp > conftest.file +# Do `set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null` + if test "$[*]" = "X"; then + # -L didn't work. + set X `ls -t $srcdir/configure conftest.file` + fi + rm -f conftest.file + if test "$[*]" != "X $srcdir/configure conftest.file" \ + && test "$[*]" != "X conftest.file $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken +alias in your environment]) + fi + + test "$[2]" = conftest.file + ) +then + # Ok. + : +else + AC_MSG_ERROR([newly created file is older than distributed files! +Check your system clock]) +fi +AC_MSG_RESULT(yes)]) + +# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# AM_PROG_INSTALL_STRIP +# --------------------- +# One issue with vendor `install' (even GNU) is that you can't +# specify the program used to strip binaries. This is especially +# annoying in cross-compiling environments, where the build's strip +# is unlikely to handle the host's binaries. +# Fortunately install-sh will honor a STRIPPROG variable, so we +# always use install-sh in `make install-strip', and initialize +# STRIPPROG with the value of the STRIP variable (set by the user). +AC_DEFUN([AM_PROG_INSTALL_STRIP], +[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl +# Installed binaries are usually stripped using `strip' when the user +# run `make install-strip'. However `strip' might not be the right +# tool to use in cross-compilation environments, therefore Automake +# will honor the `STRIP' environment variable to overrule this program. +dnl Don't test for $cross_compiling = yes, because it might be `maybe'. +if test "$cross_compiling" != no; then + AC_CHECK_TOOL([STRIP], [strip], :) +fi +INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" +AC_SUBST([INSTALL_STRIP_PROGRAM])]) + +# Copyright (C) 2006 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# _AM_SUBST_NOTMAKE(VARIABLE) +# --------------------------- +# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. +# This macro is traced by Automake. +AC_DEFUN([_AM_SUBST_NOTMAKE]) + +# Check how to create a tarball. -*- Autoconf -*- + +# Copyright (C) 2004, 2005 Free Software Foundation, Inc. +# +# This file is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# serial 2 + +# _AM_PROG_TAR(FORMAT) +# -------------------- +# Check how to create a tarball in format FORMAT. +# FORMAT should be one of `v7', `ustar', or `pax'. +# +# Substitute a variable $(am__tar) that is a command +# writing to stdout a FORMAT-tarball containing the directory +# $tardir. +# tardir=directory && $(am__tar) > result.tar +# +# Substitute a variable $(am__untar) that extract such +# a tarball read from stdin. +# $(am__untar) < result.tar +AC_DEFUN([_AM_PROG_TAR], +[# Always define AMTAR for backward compatibility. +AM_MISSING_PROG([AMTAR], [tar]) +m4_if([$1], [v7], + [am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'], + [m4_case([$1], [ustar],, [pax],, + [m4_fatal([Unknown tar format])]) +AC_MSG_CHECKING([how to create a $1 tar archive]) +# Loop over all known methods to create a tar archive until one works. +_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' +_am_tools=${am_cv_prog_tar_$1-$_am_tools} +# Do not fold the above two line into one, because Tru64 sh and +# Solaris sh will not grok spaces in the rhs of `-'. +for _am_tool in $_am_tools +do + case $_am_tool in + gnutar) + for _am_tar in tar gnutar gtar; + do + AM_RUN_LOG([$_am_tar --version]) && break + done + am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' + am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' + am__untar="$_am_tar -xf -" + ;; + plaintar) + # Must skip GNU tar: if it does not support --format= it doesn't create + # ustar tarball either. + (tar --version) >/dev/null 2>&1 && continue + am__tar='tar chf - "$$tardir"' + am__tar_='tar chf - "$tardir"' + am__untar='tar xf -' + ;; + pax) + am__tar='pax -L -x $1 -w "$$tardir"' + am__tar_='pax -L -x $1 -w "$tardir"' + am__untar='pax -r' + ;; + cpio) + am__tar='find "$$tardir" -print | cpio -o -H $1 -L' + am__tar_='find "$tardir" -print | cpio -o -H $1 -L' + am__untar='cpio -i -H $1 -d' + ;; + none) + am__tar=false + am__tar_=false + am__untar=false + ;; + esac + + # If the value was cached, stop now. We just wanted to have am__tar + # and am__untar set. + test -n "${am_cv_prog_tar_$1}" && break + + # tar/untar a dummy directory, and stop if the command works + rm -rf conftest.dir + mkdir conftest.dir + echo GrepMe > conftest.dir/file + AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) + rm -rf conftest.dir + if test -s conftest.tar; then + AM_RUN_LOG([$am__untar /dev/null 2>&1 && break + fi +done +rm -rf conftest.dir + +AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) +AC_MSG_RESULT([$am_cv_prog_tar_$1])]) +AC_SUBST([am__tar]) +AC_SUBST([am__untar]) +]) # _AM_PROG_TAR + +m4_include([acinclude.m4]) diff --git a/config.h.in b/config.h.in new file mode 100644 index 0000000..03d3c27 --- /dev/null +++ b/config.h.in @@ -0,0 +1,257 @@ +/* config.h.in. Generated from configure.in by autoheader. */ + +/* Define if building universal (internal helper macro) */ +#undef AC_APPLE_UNIVERSAL_BUILD + +/* 386 architecture */ +#undef ARCH_386 + +/* x86 architecture */ +#undef ARCH_X86 + +/* x86_64 architecture */ +#undef ARCH_X86_64 + +/* HAL API version 0.4 */ +#undef HAL_0_4 + +/* Define if you have the CoreAudio API */ +#undef HAVE_COREAUDIO + +/* Define to 1 if you have the header file. */ +#undef HAVE_CRT_EXTERNS_H + +/* Defines if your system has the crypt function */ +#undef HAVE_CRYPT + +/* Define to 1 if you have the header file. */ +#undef HAVE_DLFCN_H + +/* compile in HAL support */ +#undef HAVE_HAL + +/* Define to 1 if you have the header file. */ +#undef HAVE_INTTYPES_H + +/* Define if you have libjpeg */ +#undef HAVE_LIBJPEG + +/* Define if you have libpng */ +#undef HAVE_LIBPNG + +/* Define if you have a working libpthread (will enable threaded code) */ +#undef HAVE_LIBPTHREAD + +/* Define if you have libz */ +#undef HAVE_LIBZ + +/* Define to 1 if you have the header file. */ +#undef HAVE_MEMORY_H + +/* Define if your system needs _NSGetEnviron to set up the environment */ +#undef HAVE_NSGETENVIRON + +/* openGL support */ +#undef HAVE_OPENGL + +/* Define if you have the res_init function */ +#undef HAVE_RES_INIT + +/* Define if you have a STL implementation by SGI */ +#undef HAVE_SGI_STL + +/* Define to 1 if you have the `snprintf' function. */ +#undef HAVE_SNPRINTF + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDINT_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STDLIB_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STRINGS_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_STRING_H + +/* Define if you have strlcat */ +#undef HAVE_STRLCAT + +/* Define if you have the strlcat prototype */ +#undef HAVE_STRLCAT_PROTO + +/* Define if you have strlcpy */ +#undef HAVE_STRLCPY + +/* Define if you have the strlcpy prototype */ +#undef HAVE_STRLCPY_PROTO + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_STAT_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_SYS_TYPES_H + +/* Define to 1 if you have the header file. */ +#undef HAVE_UNISTD_H + +/* Define to 1 if you have the `vsnprintf' function. */ +#undef HAVE_VSNPRINTF + +/* Suffix for lib directories */ +#undef KDELIBSUFF + +/* Define a safe value for MAXPATHLEN */ +#undef KDEMAXPATHLEN + +/* new ffmpeg */ +#undef NEW_FFMPEG + +/* No openGL support */ +#undef NO_OPENGL + +/* old ffmpeg */ +#undef OLD_FFMPEG + +/* Name of package */ +#undef PACKAGE + +/* Define to the address where bug reports for this package should be sent. */ +#undef PACKAGE_BUGREPORT + +/* Define to the full name of this package. */ +#undef PACKAGE_NAME + +/* Define to the full name and version of this package. */ +#undef PACKAGE_STRING + +/* Define to the one symbol short name of this package. */ +#undef PACKAGE_TARNAME + +/* Define to the version of this package. */ +#undef PACKAGE_VERSION + +/* The size of `char *', as computed by sizeof. */ +#undef SIZEOF_CHAR_P + +/* The size of `int', as computed by sizeof. */ +#undef SIZEOF_INT + +/* The size of `long', as computed by sizeof. */ +#undef SIZEOF_LONG + +/* The size of `short', as computed by sizeof. */ +#undef SIZEOF_SHORT + +/* The size of `size_t', as computed by sizeof. */ +#undef SIZEOF_SIZE_T + +/* The size of `unsigned long', as computed by sizeof. */ +#undef SIZEOF_UNSIGNED_LONG + +/* Define to 1 if you have the ANSI C header files. */ +#undef STDC_HEADERS + +/* Version number of package */ +#undef VERSION + +/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most + significant byte first (like Motorola and SPARC, unlike Intel). */ +#if defined AC_APPLE_UNIVERSAL_BUILD +# if defined __BIG_ENDIAN__ +# define WORDS_BIGENDIAN 1 +# endif +#else +# ifndef WORDS_BIGENDIAN +# undef WORDS_BIGENDIAN +# endif +#endif + +/* + * jpeg.h needs HAVE_BOOLEAN, when the system uses boolean in system + * headers and I'm too lazy to write a configure test as long as only + * unixware is related + */ +#ifdef _UNIXWARE +#define HAVE_BOOLEAN +#endif + + + +/* + * AIX defines FD_SET in terms of bzero, but fails to include + * that defines bzero. + */ + +#if defined(_AIX) +#include +#endif + + + +#if defined(HAVE_NSGETENVIRON) && defined(HAVE_CRT_EXTERNS_H) +# include +# include +# define environ (*_NSGetEnviron()) +#endif + + + +#if !defined(HAVE_STRLCAT_PROTO) +#ifdef __cplusplus +extern "C" { +#endif +unsigned long strlcat(char*, const char*, unsigned long); +#ifdef __cplusplus +} +#endif +#endif + + + +#if !defined(HAVE_STRLCPY_PROTO) +#ifdef __cplusplus +extern "C" { +#endif +unsigned long strlcpy(char*, const char*, unsigned long); +#ifdef __cplusplus +} +#endif +#endif + + + +/* + * On HP-UX, the declaration of vsnprintf() is needed every time ! + */ + +#if !defined(HAVE_VSNPRINTF) || defined(hpux) +#if __STDC__ +#include +#include +#else +#include +#endif +#ifdef __cplusplus +extern "C" +#endif +int vsnprintf(char *str, size_t n, char const *fmt, va_list ap); +#ifdef __cplusplus +extern "C" +#endif +int snprintf(char *str, size_t n, char const *fmt, ...); +#endif + + + +#if defined(__SVR4) && !defined(__svr4__) +#define __svr4__ 1 +#endif + + +/* Compatibility define */ +#undef ksize_t + +/* Define the real type of socklen_t */ +#undef socklen_t diff --git a/configure.files b/configure.files new file mode 100644 index 0000000..89d14b2 --- /dev/null +++ b/configure.files @@ -0,0 +1,3 @@ +./admin/configure.in.min +configure.in.in +./k9devices/configure.in.in diff --git a/configure.in b/configure.in new file mode 100644 index 0000000..726148d --- /dev/null +++ b/configure.in @@ -0,0 +1,273 @@ +dnl This file is part of the KDE libraries/packages +dnl Copyright (C) 2001 Stephan Kulow (coolo@kde.org) + +dnl This file is free software; you can redistribute it and/or +dnl modify it under the terms of the GNU Library General Public +dnl License as published by the Free Software Foundation; either +dnl version 2 of the License, or (at your option) any later version. + +dnl This library is distributed in the hope that it will be useful, +dnl but WITHOUT ANY WARRANTY; without even the implied warranty of +dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +dnl Library General Public License for more details. + +dnl You should have received a copy of the GNU Library General Public License +dnl along with this library; see the file COPYING.LIB. If not, write to +dnl the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, +dnl Boston, MA 02110-1301, USA. + +# Original Author was Kalle@kde.org +# I lifted it in some mater. (Stephan Kulow) +# I used much code from Janos Farkas + +dnl Process this file with autoconf to produce a configure script. + +AC_INIT(acinclude.m4) dnl a source file from your sub dir + +dnl This is so we can use kde-common +AC_CONFIG_AUX_DIR(admin) + +dnl This ksh/zsh feature conflicts with `cd blah ; pwd` +unset CDPATH + +dnl Checking host/target/build systems, for make, install etc. +AC_CANONICAL_SYSTEM +dnl Perform program name transformation +AC_ARG_PROGRAM + +dnl Automake doc recommends to do this only here. (Janos) +AM_INIT_AUTOMAKE(k9copy, 1.2.4) dnl searches for some needed programs + +KDE_SET_PREFIX + +dnl generate the config header +AM_CONFIG_HEADER(config.h) dnl at the distribution this done + +dnl Checks for programs. +AC_CHECK_COMPILERS +AC_ENABLE_SHARED(yes) +AC_ENABLE_STATIC(no) +KDE_PROG_LIBTOOL + +dnl for NLS support. Call them in this order! +dnl WITH_NLS is for the po files +AM_KDE_WITH_NLS + +KDE_USE_QT(3.0.0) +AC_PATH_KDE +#MIN_CONFIG(3.0.0) + +dnl PACKAGE set before +AC_C_BIGENDIAN +AC_CHECK_KDEMAXPATHLEN + +case "$target" in + i?86-* | k?-*) + AC_DEFINE([ARCH_X86],,[x86 architecture]) + AC_DEFINE([ARCH_386],,[386 architecture]) + ARCH_X86=yes + ARCH_386=yes + ARCH_X86_64=no + ;; + x86_64-*) + AC_DEFINE([ARCH_X86_64],,[x86_64 architecture]) + ARCH_X86=no + ARCH_386=no + ARCH_X86_64=yes + ;; + *) + ARCH_X86=no + ARCH_386=no + ARCH_X86_64=no + ;; +esac + +AC_MSG_CHECKING(for X86 architecture) +AC_MSG_RESULT($ARCH_X86) +AM_CONDITIONAL(ARCH_X86, [test "$ARCH_X86" = "yes"]) + +AC_MSG_CHECKING(for 386 architecture) +AC_MSG_RESULT($ARCH_386) +AM_CONDITIONAL(ARCH_386, [test "$ARCH_386" = "yes"]) + +AC_MSG_CHECKING(for X86_64 architecture) +AC_MSG_RESULT($ARCH_X86_64) +AM_CONDITIONAL(ARCH_X86_64, [test "$ARCH_X86_64" = "yes"]) + +have_gl=no +AC_CHECK_HEADER([GL/gl.h], \ +[AC_DEFINE(HAVE_OPENGL, 1, [openGL support]) have_gl=yes], \ +[AC_DEFINE(NO_OPENGL, 1, [No openGL support])]) + + +AC_CHECK_HEADER([ffmpeg/avcodec.h], \ +[AC_DEFINE(OLD_FFMPEG,1, [old ffmpeg])], \ + [AC_CHECK_HEADER([libavcodec/avcodec.h], \ + [AC_DEFINE(NEW_FFMPEG,1, [new ffmpeg])], \ + [AC_MSG_ERROR([libavcodec may be missing]) ])]) + + + + + have_hal=no + AC_MSG_CHECKING(for the HAL) + + AC_ARG_ENABLE([k3bdevices], + AC_HELP_STRING([--enable-k3bdevices], + [do not activate hal/dbus support (use k3bdevice instead)]), + [enable_hal=no], + [enable_hal=yes]) + + + if test x"$enable_hal" = xyes; then + hal_inc=NOTFOUND + hal_lib=NOTFOUND + hal=NOTFOUND + + search_incs="$kde_includes /usr/include /usr/include/hal /usr/local/include /usr/local/include/hal" + AC_FIND_FILE(libhal.h libhal-storage.h, $search_incs, hal_incdir) + + if [test -r $hal_incdir/libhal.h] ; then + HAL_INCS="-I$hal_incdir" + hal_inc=FOUND + fi + + if test -r $hal_incdir/libhal-storage.h ; then + hal_storage_version=4 + grep LibHalVolume $hal_incdir/libhal-storage.h \ + > /dev/null 2>&1 && hal_storage_version=5 + if test $hal_storage_version = 4 ; then + AC_DEFINE(HAL_0_4, , [HAL API version 0.4]) + fi + fi + + search_libs="$kde_libraries /usr/lib64 /usr/lib /usr/local/lib /lib /lib64" + AC_FIND_FILE(libhal.so, $search_libs, hal_libdir) + + if [test -r $hal_libdir/libhal.so] ; then + HAL_LIBS="-L$hal_libdir -lhal" + hal_lib=FOUND + fi + + if [test -r $hal_libdir/libhal-storage.so] ; then + HAL_LIBS_STORAGE="-L$hal_libdir -lhal-storage" + hal_lib_storage=FOUND + fi + + if [test $hal_inc = FOUND] && [test $hal_lib = FOUND] ; then + AC_MSG_RESULT(headers $hal_incdir libraries $hal_libdir) + hal=FOUND + else + AC_MSG_RESULT(searched but not found) + AC_MSG_ERROR(libhal may be missing) + fi + + AC_SUBST(HAL_INCS) + AC_SUBST(HAL_LIBS) + + + ########### Check for DBus + + AC_MSG_CHECKING(for DBus) + + dbus_inc=NOTFOUND + dbus_lib=NOTFOUND + dbus=NOTFOUND + + search_incs="$kde_includes /usr/include /usr/include/dbus-1.0 /usr/local/include /usr/local/include/dbus-1.0" + AC_FIND_FILE(dbus/dbus.h, $search_incs, dbus_incdir) + + search_incs_arch_deps="$kde_includes /usr/lib64/dbus-1.0/include /usr/lib/dbus-1.0/include /usr/local/lib/dbus-1.0/include" + AC_FIND_FILE(dbus/dbus-arch-deps.h, $search_incs_arch_deps, dbus_incdir_arch_deps) + + if [test -r $dbus_incdir/dbus/dbus.h] && [test -r $dbus_incdir_arch_deps/dbus/dbus-arch-deps.h] ; then + DBUS_INCS="-I$dbus_incdir -I$dbus_incdir_arch_deps" + dbus_inc=FOUND + fi + + search_libs="$kde_libraries /usr/lib64 /usr/lib /usr/local/lib /lib /lib64" + AC_FIND_FILE(libdbus-1.so, $search_libs, dbus_libdir) + + if test -r $dbus_libdir/libdbus-1.so ; then + DBUS_LIBS="-L$dbus_libdir -ldbus-1" + dbus_lib=FOUND + fi + + if [test $dbus_inc = FOUND] && [test $dbus_lib = FOUND] ; then + AC_MSG_RESULT(headers $dbus_incdir $dbus_incdir_arch_deps libraries $dbus_libdir) + dbus=FOUND + else + AC_MSG_RESULT(searched but not found) + AC_MSG_ERROR(dbus may be missing) + fi + + AC_SUBST(DBUS_INCS) + AC_SUBST(DBUS_LIBS) + + + ########### Check if media HAL backend should be compiled + + HAL_DBUS_LIBS="" + if [test "x$hal" = "xFOUND"] && [test "x$dbus" = "xFOUND"] && [ test $hal_storage_version = 5 ] ; then + AC_DEFINE(HAVE_HAL, , [compile in HAL support]) + have_hal=yes + HAL_DBUS_LIBS="$HAL_LIBS $HAL_LIBS_STORAGE $DBUS_LIBS" + fi + + AC_SUBST(HAL_DBUS_LIBS) +else + search_incs="$kde_includes /usr/include /usr/local/include" + AC_FIND_FILE(k3bdevice.h, $search_incs, k3b_incdir) + + if [test -r $k3b_incdir/k3bdevice.h] ; then + k3b_inc=FOUND + fi + + search_libs="$kde_libraries /usr/lib64 /usr/lib /usr/local/lib /lib /lib64" + AC_FIND_FILE(libk3bdevice.so, $search_libs, k3b_libdir) + + if [test -r $k3b_libdir/libk3bdevice.so] ; then + K3B_LIBS="-lk3bdevice" + k3b_lib=FOUND + fi + + if [test $k3b_inc = FOUND] && [test $k3b_lib = FOUND] ; then + AC_MSG_RESULT(headers $k3b_incdir libraries $k3b_libdir) + k3b=FOUND + else + AC_MSG_RESULT(libk3bdevice searched but not found) + AC_MSG_ERROR(libk3bdevice may be missing) + fi + + AC_SUBST(K3B_LIBS) + +fi + +KDE_CREATE_SUBDIRSLIST +AC_CONFIG_FILES([ Makefile ]) +AC_CONFIG_FILES([ doc/Makefile ]) +AC_CONFIG_FILES([ doc/k9copy/Makefile ]) +AC_CONFIG_FILES([ dvdread/Makefile ]) +AC_CONFIG_FILES([ k9author/Makefile ]) +AC_CONFIG_FILES([ k9decmpeg/Makefile ]) +AC_CONFIG_FILES([ k9devices/Makefile ]) +AC_CONFIG_FILES([ k9Mplayer/Makefile ]) +AC_CONFIG_FILES([ k9vamps/Makefile ]) +AC_CONFIG_FILES([ libdvdnav/Makefile ]) +AC_CONFIG_FILES([ libk9copy/Makefile ]) +AC_CONFIG_FILES([ po/Makefile ]) +AC_CONFIG_FILES([ src/Makefile ]) +AC_CONFIG_FILES([ src/icons/Makefile ]) +AC_OUTPUT +if test "$all_tests" = "bad"; then + if test ! "$cache_file" = "/dev/null"; then + echo "" + echo "Please remove the file $cache_file after changing your setup" + echo "so that configure will find the changes next time." + echo "" + fi +else + echo "" + echo "Good - your configure finished. Start make now" + echo "" +fi diff --git a/configure.in.in b/configure.in.in new file mode 100755 index 0000000..f8ff819 --- /dev/null +++ b/configure.in.in @@ -0,0 +1,54 @@ +#MIN_CONFIG(3.0.0) + +AM_INIT_AUTOMAKE(k9copy, 1.2.4) +AC_C_BIGENDIAN +AC_CHECK_KDEMAXPATHLEN + +case "$target" in + i?86-* | k?-*) + AC_DEFINE([ARCH_X86],,[x86 architecture]) + AC_DEFINE([ARCH_386],,[386 architecture]) + ARCH_X86=yes + ARCH_386=yes + ARCH_X86_64=no + ;; + x86_64-*) + AC_DEFINE([ARCH_X86_64],,[x86_64 architecture]) + ARCH_X86=no + ARCH_386=no + ARCH_X86_64=yes + ;; + *) + ARCH_X86=no + ARCH_386=no + ARCH_X86_64=no + ;; +esac + +AC_MSG_CHECKING(for X86 architecture) +AC_MSG_RESULT($ARCH_X86) +AM_CONDITIONAL(ARCH_X86, [test "$ARCH_X86" = "yes"]) + +AC_MSG_CHECKING(for 386 architecture) +AC_MSG_RESULT($ARCH_386) +AM_CONDITIONAL(ARCH_386, [test "$ARCH_386" = "yes"]) + +AC_MSG_CHECKING(for X86_64 architecture) +AC_MSG_RESULT($ARCH_X86_64) +AM_CONDITIONAL(ARCH_X86_64, [test "$ARCH_X86_64" = "yes"]) + +have_gl=no +AC_CHECK_HEADER([GL/gl.h], \ +[AC_DEFINE(HAVE_OPENGL, 1, [openGL support]) have_gl=yes], \ +[AC_DEFINE(NO_OPENGL, 1, [No openGL support])]) + + +AC_CHECK_HEADER([ffmpeg/avcodec.h], \ +[AC_DEFINE(OLD_FFMPEG,1, [old ffmpeg])], \ + [AC_CHECK_HEADER([libavcodec/avcodec.h], \ + [AC_DEFINE(NEW_FFMPEG,1, [new ffmpeg])], \ + [AC_MSG_ERROR([libavcodec may be missing]) ])]) + + + + diff --git a/doc/Makefile.am b/doc/Makefile.am new file mode 100755 index 0000000..6d4e373 --- /dev/null +++ b/doc/Makefile.am @@ -0,0 +1,6 @@ +# the SUBDIRS is filled automatically by am_edit. If files are +# in this directory they are installed into the english dir + +KDE_LANG = en +KDE_DOCS = AUTO +SUBDIRS = k9copy diff --git a/doc/k9copy/Makefile.am b/doc/k9copy/Makefile.am new file mode 100644 index 0000000..22146b2 --- /dev/null +++ b/doc/k9copy/Makefile.am @@ -0,0 +1,5 @@ +KDE_LANG = en +KDE_DOCS = k9copy +kde_docs_KDEDOCS = mainwindow.png open1.png open2.png treeview.png \ + keepmenus.png playback.png btncopy.png settingsDVD.png btnmp4.png settingsMP4.png \ + settingsMencoder.png diff --git a/doc/k9copy/btncopy.png b/doc/k9copy/btncopy.png new file mode 100644 index 0000000000000000000000000000000000000000..0c7980458c2406573c2a5ff47e7de7d62fc321a0 GIT binary patch literal 1431 zcmV;I1!($-P)C9tzEhq6h#0fC9j% zsoC4wdWfd!on5$yo;_QnY20rBSI3E=3H3X_{_nX*72eiF7bHw?*l7T^}AEK5*bbXXmksiVBLN zD2jp*>axBHV|RV`&Ku{yT0VPyZ7`**mkYF|r9lwHsj27YZgsW2ySoz&3=9D-dl<#I%$ zuUA(7YHV}^01$%3Kr@+4G#ag|t3wC@09cmIvto=r9#407cQe-kX!*PAu;3y z`x{sfMHOT%1UfY}YqfGLYsnvRyPc6pR1jphyBZW9^`TJ6=kpP0H}Rw10oSs%omL zL0#7inI%aw3542<#E*!bAk_|>ad zRaG@ZChMvClfVD~0D<9W#o4$R-!7;mk*X?dPmllh?T0U3ERK!_0|7sTP?i;0RtQmH zG#V{rMhGzsW3gDwT0;msI@%cv-TTogP17Vvl4V(vq#N>$pAHV@UHACAm;byRTz|T) ze$8ZfNg`EMww@mU%*;X{;714%qU0AGi^ba7+WyguG3GdqWm%SG8HO1OR{#l8>sY4tc&{ z>0Pc`K@d$!mSr)2lM=$1zZlYb-xUMP_g0C4*Bk%@`v zcsym+T9y@AR?S5e$>L%RYFfbp`F!4`r6rS+rfEWmvPl2{6P;n0WAkm6*A@T((17=W z_nW>zcxEn{OqLGna8#Z>`^n(o@bvVYAcz|kCxnn}mghJI8%9AhLa42+_3`7!fk1!| zB1w|2>zbzJSs{cR$6dR2EpYn7)sfYwUxfGkzUN%W@s`{qV{xsnu6n)R(pf#8nsetq z9U2-L8w=LfI&C&Coz4-Wo;h>UZnxpZm>WoJaGNx~{LUuV1-x zg%DD`$3Ecd`}UXA$9nr`hmwYnpg`>oz8xAG_FlN~Wg?M|$J62P^6}&Cq9_jyjr1Q1 zQviVC8C6wXTU(o&n&LRl=WVL8J9s`9i@ur%(Dtk?>+tbt4#-&DY-u4}x%IyR{ToyR?A=abkfQ(q002ovPDHLkV1gKMsC@tc literal 0 HcmV?d00001 diff --git a/doc/k9copy/btnmp4.png b/doc/k9copy/btnmp4.png new file mode 100644 index 0000000000000000000000000000000000000000..1ab5e6f967b502413ab93e29f925fa82a83c1216 GIT binary patch literal 1637 zcmV-r2AcVaP)Rx!gC+P*K!34X~Y_!R=P~E4C+u6bgk{EVh(N zijqKd4FHNll*MB6`~4ip(KNja+gvU`Gc)~_76i}pkw|1U_jq5si)*%9%m$3H4&dCv z<13*ra`|FYQ*%dWFc1h}Tx}F|T@Q!D7#lh}JJ8_ZV6j*jkKkOw0L?RO$$03Baw+)BGZnxWHGO;X+Hr|#b$!@pz_4QRl#`FBxKSJL-q%_v% zp`n&Q`rd5v4-hNibAHurF9D!tAK(4$@ZbM<<$nF4*E|Qip^*_)t;XY9m9)^c zn+`{P=;PabDgS)1R#)?>RB9XBnVA`%&xa5~2tf!HMOlYCaNxk%vuCRzTU#sUR~Ghp zOR5e&yf**qcVb28@O8gxu-GI;6%*1GzdmZkP(N8cGyI-iEoQ&$a zUddS$MM4Nd2xDBnuEPxt4OO`y=H_NQIEpr?vDxh12ke=*jyLT!E~gT_C<&4(NSYw4 zqM}(Ez47$gUq?TA>4mm?bJ>TB5BFLn1WUzYv68c_Ys=gyrg7w+7- zbLrA0P17n_Bod4MCI}#EZE^CY<@ZPaB}<}N&a4)SyrlAyBFL&B>k6REzIMCaoXxK) zDj0q*M3k(z!I(%SDmf#BXqq+}jTmE$F-1}93nG`x)z#HaPEMXWb?Wlv%SVqM^?JQq zTHKwueUO{N7+~6JHW{a83*UX^xoGr3rljk%IbSG=vO-}j2>kWXmG|HMi@G-blM{~j z{&wqI?p3$bIz5kCT3WVrP9~EMhl61lmSq`+p=o+Oa+yq~zrVk~zh4l9N+TT7tj2BrKJ64DALZ+?|d)? zwOpxGaa!x^ojfm;u^5KI8$U*q$<*813joOH^VhFm-v*ANFhDf`=>Qoaf^Yq}{a3$R zTu7v5CYMB9yTZ_k==ef5?|=ObXS2;{gfXuB`_5aMPA&{DU->Kz%v*;I0O0d+V`HEB zd>q3t27^JC<@IT8Zf?GM_3Fu!CyyOF76=5oy1L9}^OhFz`|-{e6=MRh1t3d}&7R8e zQ}M!?H{VDnlHu?zv9YzK`(?A0rhq^}Qrpz<=XY=ND@#B7f#vPd<>0=9ot+&OhE1_7 zJ3T$!+S;lpiYSVxr>Do`@wBzI9Y1~?0Kl^B{{8zakpTcwskC!1F|%SB4&oY)bASBL z*)JyN4V1i8(rkeP1`Ht(DX2i8V*{dVEF6hV#FhI=SnqHi={{V^++;HGJU>1@?sBEx+pGYK^mu|fI(_cJT+-1hFeUGZDrqk(2B*L=nj&}%`%bCtH1Ykl4Ap`)hsZcII zd0T$+rT!RWr_FY+uMV(vh^0Zv2_wc;D1y-*+v&On=Kd&QUe16 z!^6X>s#eeE^?Gz2mQl(O8&#VKHbt&_K?rG@rn7v$=Pz8iP<{M1daaZKm4mv0vH`tK%CrSsU0vPK(9r4Ar{nQ>G#ahG<&zQG z)bXZoZl`46|8l4%gb0F=$z+nr8U=qK7-q> jp26)_&){~eryB0xjcVTZs?Y_T00000NkvXXu0mjf4Zk>T literal 0 HcmV?d00001 diff --git a/doc/k9copy/index.docbook b/doc/k9copy/index.docbook new file mode 100644 index 0000000..1e25fb9 --- /dev/null +++ b/doc/k9copy/index.docbook @@ -0,0 +1,459 @@ + + + k9copy"> + + + + +]> + + + + + +&k9copy; Handbook + + + +Jean-Michel + +Petit + +
k9copy@free.fr
+
+
+
+ + + + +2004 +2007 +The k9copy Author + + + +&FDLNotice; + + + +02/11/2007 +1.1.0 + + + + + +A DVD Backup tool for KDE. http://k9copy.sourceforge.net + + + + + + +k9copy +vamps +dvd + + +
+ + + + + +k9copy shell + + +The Main Window + + +Main Window + + + + + + + Screenshot + + + + +The main goal of k9copy is to be an easy to use and powerfull DVD backup app. + + +Once oppened, the DVD structure is shown in a treeview (the central widget). + + +The selection is made by checkboxes. You can select the entire DVD, a Titleset or just a specific language or subtitle from a DVD title. + +The backup can be made in three ways : +- backup with orginal menus. In this case, k9copy reproduces the orginial structure of the DVD without the unselected parts. + +- backup without menus. In this case, k9copy reproduces the orginial structure of the DVD without the unselected parts and without menus. + +- backup without menus via dvdauthor . In this case, k9copy makes a reauthoring of the DVD. K9copy uses libdvdnav from xine to ensure that the DVD will be copied as it were played with xine. + + + + +Make a dvd backup + +Open the dvd + + Select a dvd device from the list or click on buttons on right of the list to select a directory or a dvd image file. + + + + + + + Click on the button Open from the main toolbar or File->Open from the main menu. + + + + + + + + + The treeview will be filled with the DVD structure + + + + + Selection of titles to copy + + DVD structure + + + + + + Screenshot + + + + + + Use the checkbox at the top of the treeview to make a copy of the entire DVD. + + + Use the checkbox beside the titleset to make a copy of a whole titleset. + + + It's now possible to selecte only the wanted chapters from a title. + + + A title must have a video stream : if you select an audio language or a subtitle language, the video stream will be automatically selected. If you deselect the video stream, the title will not be backuped. + + + + +Playback options of the new DVD + +If the DVD you want to backup has interactive menus, you can keep them on your backup. Some DVDs have menus whose size is important. To preserve these menus would increase the shrink factor and would involve a loss of quality. + + + + + + + +If you chose not to preserve the menus, you can then define some playback options : + + + + + + + + + + +When a title is selected, it appears in the Selected Titles list. Use buttons on the right of this list to define in which order the titles will be played. + + +You can define the default audio language or the default subtitle for each title. Hilite a title in the title list and the two comboboxes will be filled with the available languages (those which where selected in the treeview). + + + +Perform the copy + +Once you have selected the titles, you can proceed with copy : + + + + + + + + + + +DVD backup settings + + DVD backup settings + + + + + + Screenshot + + + + + + Temporary files will be placed in the output directory + Define the max size of the backup + By default, &k9copy; uses its own burning method. Since the burning options are limited, you can use the a powerfull burning software: k3b. + AutoBurn allows to run the DVD burning without confirmation. + When using quickscan, &k9copy; will not analyze the dvd title to estimate the sizes of each stream. The DVD analyze can take a long time if DVD contains many features. + + + + + +MPEG-4 Encoding +&k9copy; offers the possibility to encode DVD titles in MPEG-4 via MEncoder. + + +Just select an audio stream from a title in the treeview and click on the button + + + + + + + + +MPEG-4 settings + + MPEG-4 settings + + + + + + Screenshot + + + + + + Select the codec used to encode mp4. Default codecs are XViD and lavc MP4, but you can add other codecs supported by MEncoder. + Choose the max size of an avi file an the number of files wanted. + Enter the width of the mpeg4 video. + Enter the height of the mpeg4 video. + Audio will be encoded in mp3 using lame. You can choose the bitrate of the mp3 audio stream. + + + + + + +MEncoder settings + + MEncoder settings + + + + + + Screenshot + + + + +You can add codecs supported by MEncoder: + +Video example : xvid -xvidencopts bitrate=$VIDBR + +Audio example : mp3lame -lameopts abr:br=$AUDBR + +You can use following variables : + + $VIDBR : video bitrate (calculated) + $AUDBR : audio bitrate (settings) + $WIDTH : width (settings) + $HEIGHT : height (settings) + $PASS : pass number (runtime) + + + + + + + + +Command Line Options + +Usage: + +k9copy +--input +--output +--play +--dvdtitle +--startsector +--endsector +--audiofilter +--subpicturefilter +--vampsfactor +--inputsize +--totalsize +--dvdsize +--chapter +--cell +--inject +--initstatus + + + + + + + + + +input device + + + +output device + + + +&k9copy; is used to play a title or part of title to stdout + + + + +the dvd title to play + + + +sector to start playing from + + + +sector to end playing from + + +Selection of audio streams + + + +Selection of subtitles + + + +Shrink factor + + + +Size of the cell being copied + + + +Total size of titles to play + + + +Final size of the dvd to produce + + + +Number of the chapter to play + + + +Number of a cell from chapter to play + + + +Name of the file used to save status between 2 calls of k9copy + + + +Initialize status file + + + + + + + + + + +Copyright and License + + +Program copyright 2004-2007, Jean-Michel Petit + + + + +&underFDL; + + + + +&underGPL; + + + + +&documentation.index; +
+ + + + + + + + + + + + + + diff --git a/doc/k9copy/index.xml b/doc/k9copy/index.xml new file mode 100644 index 0000000..0fcc227 --- /dev/null +++ b/doc/k9copy/index.xml @@ -0,0 +1,445 @@ + + + K9Copy"> + + + + +]> + + + + + +&k9copy; Handbook + + + +Jean-Michel + +Petit + +
k9copy@free.fr
+
+
+
+ + + + +2004 +2006 +The K9Copy Authors + + + +&FDLNotice; + + + +04/06/2006 +1.1.0 + + + + + +A DVD Backup tool for KDE. http://k9copy.sourceforge.net + + + + + + +k9copy +vamps +dvd + + +
+ + + + + +k9copy shell + + +The Main Window + + +Main Window + + + + + + + Screenshot + + + + +The main goal of k9copy is to be an easy to use and powerfull DVD backup app. + + +Once oppened, the DVD structure is shown in a treeview (the central widget). + + +The selection is made by checkboxes. You can select the entire DVD, a Titleset or just a specific language or subtitle from a DVD title. + +For DVD backup there are two possibilities : +- backup with orginal menus. In this case, k9copy reproduces the orginial structure of the DVD without the unselected parts. + +- backup without menus. In this case, k9copy makes a reauthoring of the DVD. K9copy uses libdvdnav from xine to ensure that the DVD will be copied as it were played with xine. + + + + +Making a dvd backup + +Open the dvd + + Select a dvd device from the list or click on buttons on right of the list to select a directory or a dvd image file. + + + + + + + Click on the button Open from the main toolbar or File->Open from the main menu. + + + + + + + + + The treeview will be filled with the DVD structure + + + + + Selection of titles to copy + + DVD structure + + + + + + Screenshot + + + + + + Use the checkbox at the top of the treeview to make a copy of the entire DVD. + + + Use the checkbox beside the titleset to make a copy of an entire titleset. + + + A title must have a video stream : if you select an audio language or a subtitle language, the video stream will be automatically selected. If you deselect the video stream, the title will not be backuped. + + + + +Playback options of the new DVD + +If the DVD you want to backup has interactive menus, you can keep them on your backup. On some DVDs, menus are very big and keeping them will increase the shrink factor and reduce the quality of the video stream. + + + + + + + +If you have choosen to not keep original menus, it's possible to define some playback options : + + + + + + + + + + +When a title is selected, it appears in the Selected Titles list. Use buttons on the right of this list to define in which order the titles will be played. + + +You can define the default audio language or the default subtitle for each title. Hilite a title in the title list and the two comboboxes will be filled with the available languages (those which where selected in the treeview). + + + +Executing the copy + +Once you have selected the titles, you can proceed with copy : + + + + + + + + + + +DVD backup settings + + DVD backup settings + + + + + + Screenshot + + + + + + Temporary files will be placed in the output directory + Define the max size of the backup + By default, &k9copy; uses its own burning method. Since the burning options are limited, you can use the a powerfull burning software: k3b. + AutoBurn allows to run the DVD burning without confirmation. + When using quickscan, &k9copy; will not analyze the dvd title to estimate the sizes of each stream. The DVD analyze can take a long time if DVD contains many features. + + + + + +Encoding MPEG-4 +&k9copy; offers the possibility to encode DVD titles in MPEG-4 by using MEncoder. + + +Just select an audio stream from a title in the treeview and click on the button + + + + + + + + +MPEG-4 settings + + MPEG-4 settings + + + + + + Screenshot + + + + + + Select the codec used to encode mp4. Default codecs are XViD and lavc MP4, but you can add other codecs supported by MEncoder. + Choose the max size of an avi file an the number of files wanted. + Enter the width of the mpeg4 video. + Enter the height of the mpeg4 video. + Audio will be encoded in mp3 using lame. You can choose the bitrate of the mp3 audio stream. + + + + + + + +Command Line Options + +Usage: + +k9copy + + + + + + +--fullscreen +--play +--audiodriver +--videodriver +--device +--verbose +--wizard +file + + + + + + + + + +Starts &k9copy; in fullscreen mode. + + + + +Starts with last played track. + + + + +Sets the audio driver. Arguments can be: alsa, arts, oss, ... + + + + +Sets the video driver. Arguments can be: xv, xshm, dxr3 ,... + + + + +Sets the Audio-CD/VCD/DVD path to (argument). + + + + +Outputs more debug messages. + + + +Runs installation wizard. + + + + +Files to play. Can be local files, a directory, an URL or "AudioCD", "VCD", "DVD". + + + + + + + + + + + +Questions and Answers + + + +Kaffeine-FAQ + + +xine-FAQ + + +For Questions use the k9copy-user mailinglist. +(First check the archive + if the question is still answered.) + + + + + + +Reporting BUGS + + +Before you report a bug, please first make sure the bug has not been reported +yet in the bug tracking system at http://www.sourceforge.net/projects/k9copy. +Also have a look into the mailinglist archive. + + + +Please use only the tracking system on sourceforge for reporting bugs and log in before +submitting (if you've a sourceforge account). + + + +When you submit a bug, please include all of the following information: + + +versions of Kaffeine, xine, KDE, X11 +the backtrace from KDE's Crash Manager +console output (you can use --verbose to get more) + + + + + + + +Copyright and License + + +Program copyright 2003-2005, The Kaffeine Authors + + + + +Documentation copyright 2003-2005, Jürgen Kofler k9copy@gmx.net, Christophe Thommeret hftom@free.fr + + + + +&underFDL; + + + + +&underGPL; + + + + +&documentation.index; +
+ + + + + + + + + + + + + + diff --git a/doc/k9copy/keepmenus.png b/doc/k9copy/keepmenus.png new file mode 100644 index 0000000000000000000000000000000000000000..c2bc3e8852bbd5d757d56f0ad3f0fb81365ea73f GIT binary patch literal 1740 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°tTfS!C{#+gx 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 KyGZLs#Qy=|Po%d1 literal 0 HcmV?d00001 diff --git a/doc/k9copy/open1.png b/doc/k9copy/open1.png new file mode 100644 index 0000000000000000000000000000000000000000..f598c50980ce68d6e531e2483fe73dd6935a2939 GIT binary patch literal 5433 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 OfU1&~V%bacp#K3*hOiX? literal 0 HcmV?d00001 diff --git a/doc/k9copy/open2.png b/doc/k9copy/open2.png new file mode 100644 index 0000000000000000000000000000000000000000..8f4ac4ca589e45f87a40e3121aa10467216f40d2 GIT binary patch literal 1345 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 Xo+J?~P|g$XfFv#={VG>j`|JM!Uhcn~ literal 0 HcmV?d00001 diff --git a/doc/k9copy/settingsDVD.png b/doc/k9copy/settingsDVD.png new file mode 100644 index 0000000000000000000000000000000000000000..bc0ae902e8926aa3428281e47d9f2f922ad265a7 GIT binary patch literal 41718 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 literal 0 HcmV?d00001 diff --git a/doc/k9copy/settingsMP4.png b/doc/k9copy/settingsMP4.png new file mode 100644 index 0000000000000000000000000000000000000000..9bb24ab21a8184a63f6b1cba94d6dca57b442bf0 GIT binary patch literal 40664 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

    gX2+WT4;B6-T(XaaPdBa<8mY%3s$ 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

    !qvun1Pmx3C}7 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 literal 0 HcmV?d00001 diff --git a/doc/k9copy/settingsMencoder.png b/doc/k9copy/settingsMencoder.png new file mode 100644 index 0000000000000000000000000000000000000000..f9eed5da43c8efba0a47b926b85f4a703db67b19 GIT binary patch literal 52333 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 literal 0 HcmV?d00001 diff --git a/doc/k9copy/treeview.png b/doc/k9copy/treeview.png new file mode 100644 index 0000000000000000000000000000000000000000..1744acf4ef62960408c41715871940367df3badc GIT binary patch literal 34120 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 literal 0 HcmV?d00001 diff --git a/dvdread/Makefile.am b/dvdread/Makefile.am new file mode 100644 index 0000000..5c9fddf --- /dev/null +++ b/dvdread/Makefile.am @@ -0,0 +1,8 @@ + +METASOURCES = AUTO +noinst_LTLIBRARIES = libdvdread.la +libdvdread_la_LDFLAGS = $(all_libraries) +libdvdread_la_SOURCES = dvd_input.c dvd_reader.c dvd_udf.c ifo_read.c md5.c \ + nav_read.c +noinst_HEADERS = bswap.h dvd_input.h dvd_reader.h dvd_udf.h dvdread_internal.h \ + ifo_read.h ifo_types.h md5.h nav_read.h nav_types.h diff --git a/dvdread/bswap.h b/dvdread/bswap.h new file mode 100644 index 0000000..11c9774 --- /dev/null +++ b/dvdread/bswap.h @@ -0,0 +1,126 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +#ifndef BSWAP_H_INCLUDED +#define BSWAP_H_INCLUDED + +/* + * Copyright (C) 2000, 2001 Billy Biggs , + * Håkan Hjort + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#if defined(WORDS_BIGENDIAN) +/* All bigendian systems are fine, just ignore the swaps. */ +#define B2N_16(x) (void)(x) +#define B2N_32(x) (void)(x) +#define B2N_64(x) (void)(x) + +#else + +/* For __FreeBSD_version */ +#if defined(HAVE_SYS_PARAM_H) +#include +#endif + +#if defined(__linux__) +#include +#define B2N_16(x) x = bswap_16(x) +#define B2N_32(x) x = bswap_32(x) +#define B2N_64(x) x = bswap_64(x) + +#elif defined(__NetBSD__) +#include +#define B2N_16(x) BE16TOH(x) +#define B2N_32(x) BE32TOH(x) +#define B2N_64(x) BE64TOH(x) + +#elif defined(__OpenBSD__) +#include +#define B2N_16(x) x = swap16(x) +#define B2N_32(x) x = swap32(x) +#define B2N_64(x) x = swap64(x) + +#elif defined(__FreeBSD__) && __FreeBSD_version >= 470000 +#include +#define B2N_16(x) x = be16toh(x) +#define B2N_32(x) x = be32toh(x) +#if __FreeBSD_version >= 500000 +#define B2N_64(x) x = be64toh(x) +#else +#define B2N_64(x) \ + x = ((((x) & 0xff00000000000000) >> 56) | \ + (((x) & 0x00ff000000000000) >> 40) | \ + (((x) & 0x0000ff0000000000) >> 24) | \ + (((x) & 0x000000ff00000000) >> 8) | \ + (((x) & 0x00000000ff000000) << 8) | \ + (((x) & 0x0000000000ff0000) << 24) | \ + (((x) & 0x000000000000ff00) << 40) | \ + (((x) & 0x00000000000000ff) << 56)) +#endif /* _FreeBSD_version >= 500000 */ + +#elif defined(__DragonFly__) +#include +#define B2N_16(x) x = be16toh(x) +#define B2N_32(x) x = be32toh(x) +#define B2N_64(x) x = be64toh(x) + + +#elif defined(__APPLE__) || defined(__DARWIN__) +#include +#define B2N_16(x) x = OSSwapBigToHostConstInt16(x) +#define B2N_32(x) x = OSSwapBigToHostConstInt32(x) +#define B2N_64(x) x = OSSwapBigToHostConstInt64(x) + +#else +#if defined(__FreeBSD__) || defined(__sun) || defined(__bsdi__) || defined(WIN32) || defined(__BEOS__) || defined(__INTERIX) +/* These systems don't have swap macros */ +#else +/* If there isn't a header provided with your system with this functionality + * add the relevant || define( ) to the list above. + */ +#warning "You should add endian swap macros for your system" +#endif + +/* This is a slow but portable implementation, it has multiple evaluation + * problems so beware. + * Old FreeBSD's and Solaris don't have or any other such + * functionality! + */ + +#define B2N_16(x) \ + x = ((((x) & 0xff00) >> 8) | \ + (((x) & 0x00ff) << 8)) +#define B2N_32(x) \ + x = ((((x) & 0xff000000) >> 24) | \ + (((x) & 0x00ff0000) >> 8) | \ + (((x) & 0x0000ff00) << 8) | \ + (((x) & 0x000000ff) << 24)) +#define B2N_64(x) \ + x = ((((x) & 0xff00000000000000) >> 56) | \ + (((x) & 0x00ff000000000000) >> 40) | \ + (((x) & 0x0000ff0000000000) >> 24) | \ + (((x) & 0x000000ff00000000) >> 8) | \ + (((x) & 0x00000000ff000000) << 8) | \ + (((x) & 0x0000000000ff0000) << 24) | \ + (((x) & 0x000000000000ff00) << 40) | \ + (((x) & 0x00000000000000ff) << 56)) + + + +#endif + +#endif /* WORDS_BIGENDIAN */ + +#endif /* BSWAP_H_INCLUDED */ diff --git a/dvdread/dvd_input.c b/dvdread/dvd_input.c new file mode 100644 index 0000000..99ddd2d --- /dev/null +++ b/dvdread/dvd_input.c @@ -0,0 +1,414 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +/* + * Copyright (C) 2002 Samuel Hocevar , + * Håkan Hjort + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111, USA. + */ + +#include "config.h" + +#include +#include +#define __USE_GNU /* to get O_DIRECT in linux */ +#include +#include + +#include "dvd_reader.h" +#include "dvd_input.h" + +#include "dvdread_internal.h" + +/* The function pointers that is the exported interface of this file. */ +dvd_input_t (*dvdinput_open) (const char *); +int (*dvdinput_close) (dvd_input_t); +int (*dvdinput_seek) (dvd_input_t, int); +int (*dvdinput_title) (dvd_input_t, int); +/** + * pointer must be aligned to 2048 bytes + * if reading from a raw/O_DIRECT file + */ +int (*dvdinput_read) (dvd_input_t, void *, int, int); + +char * (*dvdinput_error) (dvd_input_t); + +#ifdef HAVE_DVDCSS_DVDCSS_H +/* linking to libdvdcss */ +#include +#define DVDcss_open(a) dvdcss_open((char*)(a)) +#define DVDcss_close dvdcss_close +#define DVDcss_seek dvdcss_seek +#define DVDcss_title dvdcss_title +#define DVDcss_read dvdcss_read +#define DVDcss_error dvdcss_error +#else +/* dlopening libdvdcss */ +#include +typedef struct dvdcss_s *dvdcss_handle; +static dvdcss_handle (*DVDcss_open) (const char *); +static int (*DVDcss_close) (dvdcss_handle); +static int (*DVDcss_seek) (dvdcss_handle, int, int); +static int (*DVDcss_title) (dvdcss_handle, int); +static int (*DVDcss_read) (dvdcss_handle, void *, int, int); +static char * (*DVDcss_error) (dvdcss_handle); +#endif + +/* The DVDinput handle, add stuff here for new input methods. */ +struct dvd_input_s { + /* libdvdcss handle */ + dvdcss_handle dvdcss; + + /* dummy file input */ + int fd; +}; + + +/** + * initialize and open a DVD device or file. + */ +static dvd_input_t css_open(const char *target) +{ + dvd_input_t dev; + + /* Allocate the handle structure */ + dev = (dvd_input_t) malloc(sizeof(struct dvd_input_s)); + if(dev == NULL) { + /* malloc has set errno to ENOMEM */ + return NULL; + } + + /* Really open it with libdvdcss */ + dev->dvdcss = DVDcss_open(target); + if(dev->dvdcss == 0) { + free(dev); + dev = NULL; + } + + return dev; +} + +/** + * return the last error message + */ +static char *css_error(dvd_input_t dev) +{ + return DVDcss_error(dev->dvdcss); +} + +/** + * seek into the device. + */ +static int css_seek(dvd_input_t dev, int blocks) +{ + /* DVDINPUT_NOFLAGS should match the DVDCSS_NOFLAGS value. */ + return DVDcss_seek(dev->dvdcss, blocks, DVDINPUT_NOFLAGS); +} + +/** + * set the block for the begining of a new title (key). + */ +static int css_title(dvd_input_t dev, int block) +{ + return DVDcss_title(dev->dvdcss, block); +} + +/** + * read data from the device. + */ +static int css_read(dvd_input_t dev, void *buffer, int blocks, int flags) +{ + return DVDcss_read(dev->dvdcss, buffer, blocks, flags); +} + +/** + * close the DVD device and clean up the library. + */ +static int css_close(dvd_input_t dev) +{ + int ret; + + ret = DVDcss_close(dev->dvdcss); + + if(ret < 0) + return ret; + + free(dev); + + return 0; +} + +/* Need to use O_BINARY for WIN32 */ +#ifndef O_BINARY +#ifdef _O_BINARY +#define O_BINARY _O_BINARY +#else +#define O_BINARY 0 +#endif +#endif + +/** + * initialize and open a DVD device or file. + */ +static dvd_input_t file_open(const char *target) +{ + dvd_input_t dev; + char *use_odirect; + int oflags; + + oflags = O_RDONLY | O_BINARY; + use_odirect = getenv("DVDREAD_USE_DIRECT"); + if(use_odirect) { +#ifndef O_DIRECT +#define O_DIRECT 0 +#endif + oflags |= O_DIRECT; + } + /* Allocate the library structure */ + dev = (dvd_input_t) malloc(sizeof(struct dvd_input_s)); + if(dev == NULL) { + return NULL; + } + + /* Open the device */ + dev->fd = open(target, oflags); + if(dev->fd < 0) { + free(dev); + return NULL; + } + + return dev; +} + +/** + * return the last error message + */ +static char *file_error(dvd_input_t dev) +{ + /* use strerror(errno)? */ + return (char *)"unknown error"; +} + +/** + * seek into the device. + */ +static int file_seek(dvd_input_t dev, int blocks) +{ + off_t pos = (off_t)blocks * (off_t)DVD_VIDEO_LB_LEN; + + pos = lseek(dev->fd, pos, SEEK_SET); + if(pos < 0) { + return pos; + } + /* assert pos % DVD_VIDEO_LB_LEN == 0 */ + return (int) (pos / DVD_VIDEO_LB_LEN); +} + +/** + * set the block for the begining of a new title (key). + */ +static int file_title(dvd_input_t dev, int block) +{ + return -1; +} + +/** + * read data from the device. + */ +static int file_read(dvd_input_t dev, void *buffer, int blocks, int flags) +{ + size_t len; + ssize_t ret; + unsigned char *buf = buffer; + + len = (size_t)blocks * DVD_VIDEO_LB_LEN; + + while(len > 0) { + + ret = read(dev->fd, buf, len); + + if(ret < 0) { + /* One of the reads failed, too bad. We won't even bother + * returning the reads that went ok, and as in the posix spec + * the file postition is left unspecified after a failure. */ + return ret; + } + + if(ret == 0) { + /* Nothing more to read. Return the whole blocks, if any, that we got. + and adjust the file possition back to the previous block boundary. */ + size_t bytes = (size_t)blocks * DVD_VIDEO_LB_LEN - len; + off_t over_read = -(bytes % DVD_VIDEO_LB_LEN); + /*off_t pos =*/ lseek(dev->fd, over_read, SEEK_CUR); + /* should have pos % 2048 == 0 */ + return (int) (bytes / DVD_VIDEO_LB_LEN); + } + + buf+=ret; + len -= ret; + } + + return blocks; +} + +/** + * close the DVD device and clean up. + */ +static int file_close(dvd_input_t dev) +{ + int ret; + + ret = close(dev->fd); + + if(ret < 0) + return ret; + + free(dev); + + return 0; +} + + +static void *dvdcss_library = NULL; +static int dvdcss_library_init = 0; + +/** + * Free any objects allocated by dvdinput_setup. + * Should only be called when libdvdread is not to be used any more. + * Closes dlopened libraries. + */ +void dvdinput_free(void) +{ +#ifdef HAVE_DVDCSS_DVDCSS_H + /* linked statically, nothing to free */ + return; +#else + if(dvdcss_library) { + dlclose(dvdcss_library); + dvdcss_library = NULL; + } + dvdcss_library_init = 0; + return; +#endif +} + + +/** + * Setup read functions with either libdvdcss or minimal DVD access. + */ +int dvdinput_setup(void) +{ + char **dvdcss_version = NULL; + int verbose; + + /* dlopening libdvdcss */ + if(dvdcss_library_init) { + /* libdvdcss is already dlopened, function ptrs set */ + if(dvdcss_library) { + return 1; /* css available */ + } else { + return 0; /* css not available */ + } + } + + verbose = get_verbose(); + +#ifdef HAVE_DVDCSS_DVDCSS_H + /* linking to libdvdcss */ + dvdcss_library = &dvdcss_library; /* Give it some value != NULL */ + /* the DVDcss_* functions have been #defined at the top */ + dvdcss_version = &dvdcss_interface_2; + +#else + + dvdcss_library = dlopen("libdvdcss.so.2", RTLD_LAZY); + + if(dvdcss_library != NULL) { +#if defined(__OpenBSD__) && !defined(__ELF__) +#define U_S "_" +#else +#define U_S +#endif + DVDcss_open = (dvdcss_handle (*)(const char*)) + dlsym(dvdcss_library, U_S "dvdcss_open"); + DVDcss_close = (int (*)(dvdcss_handle)) + dlsym(dvdcss_library, U_S "dvdcss_close"); + DVDcss_title = (int (*)(dvdcss_handle, int)) + dlsym(dvdcss_library, U_S "dvdcss_title"); + DVDcss_seek = (int (*)(dvdcss_handle, int, int)) + dlsym(dvdcss_library, U_S "dvdcss_seek"); + DVDcss_read = (int (*)(dvdcss_handle, void*, int, int)) + dlsym(dvdcss_library, U_S "dvdcss_read"); + DVDcss_error = (char* (*)(dvdcss_handle)) + dlsym(dvdcss_library, U_S "dvdcss_error"); + + dvdcss_version = (char **)dlsym(dvdcss_library, U_S "dvdcss_interface_2"); + + if(dlsym(dvdcss_library, U_S "dvdcss_crack")) { + if(verbose >= 0) { + fprintf(stderr, + "libdvdread: Old (pre-0.0.2) version of libdvdcss found.\n" + "libdvdread: You should get the latest version from " + "http://www.videolan.org/\n" ); + } + dlclose(dvdcss_library); + dvdcss_library = NULL; + } else if(!DVDcss_open || !DVDcss_close || !DVDcss_title || !DVDcss_seek + || !DVDcss_read || !DVDcss_error || !dvdcss_version) { + if(verbose >= 0) { + fprintf(stderr, "libdvdread: Missing symbols in libdvdcss.so.2, " + "this shouldn't happen !\n"); + } + dlclose(dvdcss_library); + dvdcss_library = NULL; + } + } +#endif /* HAVE_DVDCSS_DVDCSS_H */ + + dvdcss_library_init = 1; + + if(dvdcss_library) { + /* + char *psz_method = getenv( "DVDCSS_METHOD" ); + char *psz_verbose = getenv( "DVDCSS_VERBOSE" ); + fprintf(stderr, "DVDCSS_METHOD %s\n", psz_method); + fprintf(stderr, "DVDCSS_VERBOSE %s\n", psz_verbose); + */ + if(verbose >= 1) { + fprintf(stderr, "libdvdread: Using libdvdcss version %s for DVD access\n", + *dvdcss_version); + } + /* libdvdcss wrapper functions */ + dvdinput_open = css_open; + dvdinput_close = css_close; + dvdinput_seek = css_seek; + dvdinput_title = css_title; + dvdinput_read = css_read; + dvdinput_error = css_error; + return 1; + + } else { + if(verbose >= 1) { + fprintf(stderr, "libdvdread: Encrypted DVD support unavailable.\n"); + } + /* libdvdcss replacement functions */ + dvdinput_open = file_open; + dvdinput_close = file_close; + dvdinput_seek = file_seek; + dvdinput_title = file_title; + dvdinput_read = file_read; + dvdinput_error = file_error; + return 0; + } +} diff --git a/dvdread/dvd_input.h b/dvdread/dvd_input.h new file mode 100644 index 0000000..bc9544d --- /dev/null +++ b/dvdread/dvd_input.h @@ -0,0 +1,55 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +#ifndef DVD_INPUT_H_INCLUDED +#define DVD_INPUT_H_INCLUDED + +/* + * Copyright (C) 2001, 2002 Samuel Hocevar , + * Håkan Hjort + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111, USA. + */ + +/** + * Defines and flags. Make sure they fit the libdvdcss API! + */ +#define DVDINPUT_NOFLAGS 0 + +#define DVDINPUT_READ_DECRYPT (1 << 0) + +typedef struct dvd_input_s *dvd_input_t; + +/** + * Pointers which will be filled either the input methods functions. + */ +extern dvd_input_t (*dvdinput_open) (const char *); +extern int (*dvdinput_close) (dvd_input_t); +extern int (*dvdinput_seek) (dvd_input_t, int); +extern int (*dvdinput_title) (dvd_input_t, int); +extern int (*dvdinput_read) (dvd_input_t, void *, int, int); +extern char * (*dvdinput_error) (dvd_input_t); + +/** + * Free any objects allocated by dvdinput_setup. + * Should only be called when libdvdread is not to be used any more. + * Closes dlopened libraries. + */ +void dvdinput_free(void); + +/** + * Setup function accessed by dvd_reader.c. Returns 1 if there is CSS support. + */ +int dvdinput_setup(void); + +#endif /* DVD_INPUT_H_INCLUDED */ diff --git a/dvdread/dvd_reader.c b/dvdread/dvd_reader.c new file mode 100644 index 0000000..d1d9c97 --- /dev/null +++ b/dvdread/dvd_reader.c @@ -0,0 +1,1614 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +/* + * Copyright (C) 2001, 2002, 2003 Billy Biggs , + * H�kan Hjort , + * Bj�rn Englund + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111, USA. + */ + +#include "config.h" + +#include +#include +#include /* For the timing of dvdcss_title crack. */ +#include +#include +#include +#include +#include +#include +#include +#include + +#if defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__NetBSD__) || defined(__bsdi__) || defined(__DARWIN__) || defined(__DragonFly__) +#define SYS_BSD 1 +#endif + +#if defined(__sun) +#include +#elif defined(SYS_BSD) +#include +#elif defined(__linux__) +#include +#endif + +#include "dvd_reader.h" +#include "dvd_input.h" +#include "dvd_udf.h" +#include "md5.h" + +#include "dvdread_internal.h" + +#define DEFAULT_UDF_CACHE_LEVEL 1 + +struct dvd_reader_s { + /* Basic information. */ + int isImageFile; + + /* Hack for keeping track of the css status. + * 0: no css, 1: perhaps (need init of keys), 2: have done init */ + int css_state; + int css_title; /* Last title that we have called dvdinpute_title for. */ + + /* Information required for an image file. */ + dvd_input_t dev; + + /* Information required for a directory path drive. */ + char *path_root; + + /* Filesystem cache */ + int udfcache_level; /* 0 - turned off, 1 - on */ + void *udfcache; + + /* block aligned malloc */ + void *align; + + /* error message verbosity level */ + int verbose; +}; + +struct dvd_file_s { + /* Basic information. */ + dvd_reader_t *dvd; + + /* Hack for selecting the right css title. */ + int css_title; + + /* Information required for an image file. */ + uint32_t lb_start; + uint32_t seek_pos; + + /* Information required for a directory path drive. */ + size_t title_sizes[ 9 ]; + dvd_input_t title_devs[ 9 ]; + + /* Calculated at open-time, size in blocks. */ + ssize_t filesize; +}; + + +#define DVDREAD_VERBOSE_DEFAULT 0 + +int get_verbose(void) +{ + char *dvdread_verbose; + int verbose; + + dvdread_verbose = getenv("DVDREAD_VERBOSE"); + if(dvdread_verbose) { + verbose = (int)strtol(dvdread_verbose, NULL, 0); + } else { + verbose = DVDREAD_VERBOSE_DEFAULT; + } + return verbose; +} + +int dvdread_verbose(dvd_reader_t *dvd) +{ + return dvd->verbose; +} + +dvd_reader_t *device_of_file(dvd_file_t *file) +{ + return file->dvd; +} + +/** + * Returns the compiled version. (DVDREAD_VERSION as an int) + */ +int DVDVersion(void) +{ + return DVDREAD_VERSION; +} + + +/** + * Set the level of caching on udf + * level = 0 (no caching) + * level = 1 (caching filesystem info) + */ +int DVDUDFCacheLevel(dvd_reader_t *device, int level) +{ + struct dvd_reader_s *dev = (struct dvd_reader_s *)device; + + if(level > 0) { + level = 1; + } else if(level < 0) { + return dev->udfcache_level; + } + + dev->udfcache_level = level; + + return level; +} + +void *GetUDFCacheHandle(dvd_reader_t *device) +{ + struct dvd_reader_s *dev = (struct dvd_reader_s *)device; + + return dev->udfcache; +} + +void SetUDFCacheHandle(dvd_reader_t *device, void *cache) +{ + struct dvd_reader_s *dev = (struct dvd_reader_s *)device; + + dev->udfcache = cache; +} + +void *GetAlignHandle(dvd_reader_t *device) +{ + struct dvd_reader_s *dev = (struct dvd_reader_s *)device; + + return dev->align; +} + +void SetAlignHandle(dvd_reader_t *device, void *align) +{ + struct dvd_reader_s *dev = (struct dvd_reader_s *)device; + + dev->align = align; +} + +#ifdef WIN32 /* replacement gettimeofday implementation */ +#include +static int gettimeofday( struct timeval *tv, void *tz ) +{ + struct timeb t; + ftime( &t ); + tv->tv_sec = t.time; + tv->tv_usec = t.millitm * 1000; + return 0; +} +#endif + + +/* Loop over all titles and call dvdcss_title to crack the keys. */ +static int initAllCSSKeys( dvd_reader_t *dvd ) +{ + struct timeval all_s, all_e; + struct timeval t_s, t_e; + char filename[ MAX_UDF_FILE_NAME_LEN ]; + uint32_t start, len; + int title; + + char *nokeys_str = getenv("DVDREAD_NOKEYS"); + if(nokeys_str != NULL) + return 0; + + if(dvd->verbose >= 1) { + fprintf( stderr, "\n" ); + fprintf( stderr, "libdvdread: Attempting to retrieve all CSS keys\n" ); + fprintf( stderr, "libdvdread: This can take a _long_ time, " + "please be patient\n\n" ); + } + gettimeofday(&all_s, NULL); + + for( title = 0; title < 100; title++ ) { + gettimeofday( &t_s, NULL ); + if( title == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.VOB" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02d_%d.VOB", title, 0 ); + } + start = UDFFindFile( dvd, filename, &len ); + if( start != 0 && len != 0 ) { + /* Perform CSS key cracking for this title. */ + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Get key for %s at 0x%08x\n", + filename, start ); + } + if( dvdinput_title( dvd->dev, (int)start ) < 0 ) { + if(dvd->verbose >= 0) { + fprintf( stderr, "libdvdread: Error cracking CSS key for %s (0x%08x)\n", filename, start); + } + } + gettimeofday( &t_e, NULL ); + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Elapsed time %ld\n", + (long int) t_e.tv_sec - t_s.tv_sec ); + } + } + + if( title == 0 ) continue; + + gettimeofday( &t_s, NULL ); + sprintf( filename, "/VIDEO_TS/VTS_%02d_%d.VOB", title, 1 ); + start = UDFFindFile( dvd, filename, &len ); + if( start == 0 || len == 0 ) break; + + /* Perform CSS key cracking for this title. */ + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Get key for %s at 0x%08x\n", + filename, start ); + } + if( dvdinput_title( dvd->dev, (int)start ) < 0 ) { + if(dvd->verbose >= 0) { + fprintf( stderr, "libdvdread: Error cracking CSS key for %s (0x%08x)!!\n", filename, start); + } + } + gettimeofday( &t_e, NULL ); + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Elapsed time %ld\n", + (long int) t_e.tv_sec - t_s.tv_sec ); + } + } + title--; + + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Found %d VTS's\n", title ); + } + gettimeofday(&all_e, NULL); + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Elapsed time %ld\n", + (long int) all_e.tv_sec - all_s.tv_sec ); + } + return 0; +} + + + +/** + * Open a DVD image or block device file. + * Checks if the root directory in the udf image file can be found. + * If not it assumes this isn't a valid udf image and returns NULL + */ +static dvd_reader_t *DVDOpenImageFile( const char *location, int have_css ) +{ + dvd_reader_t *dvd; + dvd_input_t dev; + int verbose; + + verbose = get_verbose(); + + dev = dvdinput_open( location ); + if( !dev ) { + if(verbose >= 1) { + fprintf( stderr, "libdvdread: Can't open '%s' for reading: %s\n", + location, strerror(errno)); + } + return NULL; + } + + dvd = (dvd_reader_t *) malloc( sizeof( dvd_reader_t ) ); + if( !dvd ) { + int tmp_errno = errno; + dvdinput_close(dev); + errno = tmp_errno; + return NULL; + } + dvd->verbose = verbose; + dvd->isImageFile = 1; + dvd->dev = dev; + dvd->path_root = NULL; + + dvd->udfcache_level = DEFAULT_UDF_CACHE_LEVEL; + dvd->udfcache = NULL; + + dvd->align = NULL; + + if( have_css ) { + /* Only if DVDCSS_METHOD = title, a bit if it's disc or if + * DVDCSS_METHOD = key but region missmatch. Unfortunaly we + * don't have that information. */ + + dvd->css_state = 1; /* Need key init. */ + } + dvd->css_title = 0; + + /* sanity check, is it a valid UDF image, can we find the root dir */ + if(!UDFFindFile(dvd, "/", NULL)) { + dvdinput_close(dvd->dev); + if(dvd->udfcache) { + FreeUDFCache(dvd, dvd->udfcache); + } + if(dvd->align) { + if(dvd->verbose >= 0) { + fprintf(stderr, "libdvdread: DVDOpenImageFile(): Memory leak in align functions 1\n"); + } + } + free(dvd); + return NULL; + } + return dvd; +} + +static dvd_reader_t *DVDOpenPath( const char *path_root ) +{ + dvd_reader_t *dvd; + + dvd = (dvd_reader_t *) malloc( sizeof( dvd_reader_t ) ); + if( !dvd ) { + return NULL; + } + dvd->verbose = get_verbose(); + dvd->isImageFile = 0; + dvd->dev = 0; + dvd->path_root = strdup( path_root ); + if(!dvd->path_root) { + free(dvd); + return 0; + } + dvd->udfcache_level = DEFAULT_UDF_CACHE_LEVEL; + dvd->udfcache = NULL; + + dvd->align = NULL; + + dvd->css_state = 0; /* Only used in the UDF path */ + dvd->css_title = 0; /* Only matters in the UDF path */ + + return dvd; +} + +#if defined(__sun) +/* /dev/rdsk/c0t6d0s0 (link to /devices/...) + /vol/dev/rdsk/c0t6d0/?? + /vol/rdsk/ */ +static char *sun_block2char( const char *path ) +{ + char *new_path; + + /* Must contain "/dsk/" */ + if( !strstr( path, "/dsk/" ) ) return (char *) strdup( path ); + + /* Replace "/dsk/" with "/rdsk/" */ + new_path = malloc( strlen(path) + 2 ); + strcpy( new_path, path ); + strcpy( strstr( new_path, "/dsk/" ), "" ); + strcat( new_path, "/rdsk/" ); + strcat( new_path, strstr( path, "/dsk/" ) + strlen( "/dsk/" ) ); + + return new_path; +} +#endif + +#if defined(SYS_BSD) +/* FreeBSD /dev/(r)(a)cd0c (a is for atapi), recomended to _not_ use r + update: FreeBSD and DragonFly no longer uses the prefix so don't add it. + + OpenBSD /dev/rcd0c, it needs to be the raw device + NetBSD /dev/rcd0[d|c|..] d for x86, c (for non x86), perhaps others + Darwin /dev/rdisk0, it needs to be the raw device + BSD/OS /dev/sr0c (if not mounted) or /dev/rsr0c ('c' any letter will do) + + returns a string allocated with strdup which should be free()'d when + no longer used. +*/ +static char *bsd_block2char( const char *path ) +{ +#if defined(__FreeBSD__) || defined(__DragonFly__) + return (char *) strdup( path ); +#else + char *new_path; + + /* If it doesn't start with "/dev/" or does start with "/dev/r" exit */ + if( strncmp( path, "/dev/", 5 ) || !strncmp( path, "/dev/r", 6 ) ) + return (char *) strdup( path ); + + /* Replace "/dev/" with "/dev/r" */ + new_path = malloc( strlen(path) + 2 ); + strcpy( new_path, "/dev/r" ); + strcat( new_path, path + strlen( "/dev/" ) ); + + return new_path; +#endif /* __FreeBSD__ || __DragonFly__ */ +} +#endif + + +dvd_reader_t *DVDOpen( const char *path ) +{ + struct stat fileinfo; + int ret, have_css; + char *dev_name = NULL; + int internal_errno = 0; + int verbose; + + if( path == NULL ) { + errno = EINVAL; + return NULL; + } + + verbose = get_verbose(); + +#ifdef WIN32 + /* Stat doesn't work on devices under mingwin/cygwin. */ + if( path[0] && path[1] == ':' && path[2] == '\0' ) + { + /* Don't try to stat the file */ + fileinfo.st_mode = S_IFBLK; + } + else +#endif + { + ret = stat( path, &fileinfo ); + if( ret < 0 ) { + int tmp_errno = errno; + /* If we can't stat the file, give up */ + if(verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat '%s': %s\n", + path, strerror(errno)); + } + errno = tmp_errno; + return NULL; + } + } + + /* Try to open libdvdcss or fall back to standard functions */ + have_css = dvdinput_setup(); + + /* First check if this is a block/char device or a file*/ + if( S_ISBLK( fileinfo.st_mode ) || + S_ISCHR( fileinfo.st_mode ) || + S_ISREG( fileinfo.st_mode ) ) { + /** + * Block devices and regular files are assumed to be DVD-Video images. + */ + dvd_reader_t *dvd = NULL; +#if defined(__sun) + dev_name = sun_block2char( path ); +#elif defined(SYS_BSD) + dev_name = bsd_block2char( path ); +#else + dev_name = strdup( path ); +#endif + dvd = DVDOpenImageFile( dev_name, have_css ); + free( dev_name ); + + return dvd; + } else if( S_ISDIR( fileinfo.st_mode ) ) { + dvd_reader_t *auth_drive = 0; + char *path_copy; +#if defined(SYS_BSD) + struct fstab* fe; +#elif defined(__sun) || defined(__linux__) + FILE *mntfile; +#endif + + /* XXX: We should scream real loud here. */ + if( !(path_copy = strdup( path ) ) ) return 0; + +#ifndef WIN32 /* don't have fchdir, and getcwd( NULL, ... ) is strange */ + /* Resolve any symlinks and get the absolut dir name. */ + { + char *new_path; + char *current_path; + + current_path = malloc(PATH_MAX); + if(current_path) { + if(!getcwd(current_path, PATH_MAX)) { + free(current_path); + current_path = NULL; + } + } + if(current_path) { + chdir( path_copy ); + new_path = malloc(PATH_MAX); + if(new_path) { + if(!getcwd(new_path, PATH_MAX )) { + free(new_path); + new_path = NULL; + } + } + + chdir(current_path); + free(current_path); + if( new_path ) { + free( path_copy ); + path_copy = new_path; + } + } + } +#endif + + /** + * If we're being asked to open a directory, check if that directory + * is the mountpoint for a DVD-ROM which we can use instead. + */ + + if( strlen( path_copy ) > 1 ) { + if( path_copy[ strlen( path_copy ) - 1 ] == '/' ) { + path_copy[ strlen( path_copy ) - 1 ] = '\0'; + } + } + + if( strlen( path_copy ) >= 9 ) { + if( !strcasecmp( &(path_copy[ strlen( path_copy ) - 9 ]), + "/video_ts" ) ) { + path_copy[ strlen( path_copy ) - 9 ] = '\0'; + if(path_copy[0] == '\0') { + path_copy[0] = '/'; + path_copy[1] = '\0'; + } + } + } + +#if defined(SYS_BSD) + if( ( fe = getfsfile( path_copy ) ) ) { + dev_name = bsd_block2char( fe->fs_spec ); + if(verbose >= 1) { + fprintf( stderr, + "libdvdread: Attempting to use device %s" + " mounted on %s%s\n", + dev_name, + fe->fs_file, + have_css ? " for CSS authentication" : ""); + } + auth_drive = DVDOpenImageFile( dev_name, have_css ); + if(!auth_drive) { + internal_errno = errno; + } + } +#elif defined(__sun) + mntfile = fopen( MNTTAB, "r" ); + if( mntfile ) { + struct mnttab mp; + int res; + + while( ( res = getmntent( mntfile, &mp ) ) != -1 ) { + if( res == 0 && !strcmp( mp.mnt_mountp, path_copy ) ) { + dev_name = sun_block2char( mp.mnt_special ); + if(verbose >= 1) { + fprintf( stderr, + "libdvdread: Attempting to use device %s" + " mounted on %s%s\n", + dev_name, + mp.mnt_mountp, + have_css ? " for CSS authentication" : ""); + } + auth_drive = DVDOpenImageFile( dev_name, have_css ); + if(!auth_drive) { + internal_errno = errno; + } + break; + } + } + fclose( mntfile ); + } +#elif defined(__linux__) + mntfile = fopen( MOUNTED, "r" ); + if( mntfile ) { + struct mntent *me; + + while( ( me = getmntent( mntfile ) ) ) { + if( !strcmp( me->mnt_dir, path_copy ) ) { + if(verbose >= 1) { + fprintf( stderr, + "libdvdread: Attempting to use device %s" + " mounted on %s%s\n", + me->mnt_fsname, + me->mnt_dir, + have_css ? " for CSS authentication" : ""); + } + auth_drive = DVDOpenImageFile( me->mnt_fsname, have_css ); + if(!auth_drive) { + internal_errno = errno; + } + dev_name = strdup(me->mnt_fsname); + break; + } + } + fclose( mntfile ); + } +#endif + if( !dev_name ) { + if(verbose >= 1) { + fprintf( stderr, "libdvdread: Couldn't find device name.\n" ); + } + } else if( !auth_drive ) { + if(verbose >= 1) { + fprintf( stderr, "libdvdread: Device %s inaccessible%s: %s\n", + dev_name, + have_css ? ", CSS authentication not available" : "", + strerror(internal_errno)); + } + } + + free( dev_name ); + free( path_copy ); + + /** + * If we've opened a drive, just use that. + */ + if( auth_drive ) { + return auth_drive; + } + /** + * Otherwise, we now try to open the directory tree instead. + */ + return DVDOpenPath( path ); + } + + /* If it's none of the above, screw it. */ + if(verbose >= 1) { + fprintf( stderr, "libdvdread: Could not open %s\n", path ); + } + return 0; +} + +void DVDClose( dvd_reader_t *dvd ) +{ + if( dvd ) { + if( dvd->dev ) dvdinput_close( dvd->dev ); + if( dvd->path_root ) free( dvd->path_root ); + if( dvd->udfcache ) FreeUDFCache( dvd, dvd->udfcache ); + if(dvd->align) { + if(dvd->verbose >= 0) { + fprintf(stderr, "libdvdread: DVDClose(): Memory leak in align functions\n"); + } + } + + free( dvd ); + } +} + +void DVDInit(void) +{ + dvdinput_setup(); +} + +void DVDFinish(void) +{ + dvdinput_free(); +} + +/** + * Open an unencrypted file on a DVD image file. + */ +static dvd_file_t *DVDOpenFileUDF( dvd_reader_t *dvd, char *filename ) +{ + uint32_t start, len; + dvd_file_t *dvd_file; + + start = UDFFindFile( dvd, filename, &len ); + if( !start ) return 0; + + dvd_file = (dvd_file_t *) malloc( sizeof( dvd_file_t ) ); + if( !dvd_file ) return 0; + dvd_file->dvd = dvd; + dvd_file->lb_start = start; + dvd_file->seek_pos = 0; + memset( dvd_file->title_sizes, 0, sizeof( dvd_file->title_sizes ) ); + memset( dvd_file->title_devs, 0, sizeof( dvd_file->title_devs ) ); + dvd_file->filesize = len / DVD_VIDEO_LB_LEN; + + return dvd_file; +} + +/** + * Searches for in directory , ignoring case. + * Returns 0 and full filename in . + * or -1 on file not found. + * or -2 on path not found. + */ +static int findDirFile( const char *path, const char *file, char *filename ) +{ + DIR *dir; + struct dirent *ent; + + dir = opendir( path ); + if( !dir ) return -2; + + while( ( ent = readdir( dir ) ) != NULL ) { + if( !strcasecmp( ent->d_name, file ) ) { + sprintf( filename, "%s%s%s", path, + ( ( path[ strlen( path ) - 1 ] == '/' ) ? "" : "/" ), + ent->d_name ); + closedir(dir); + return 0; + } + } + closedir(dir); + return -1; +} + +static int findDVDFile( dvd_reader_t *dvd, const char *file, char *filename ) +{ + char video_path[ PATH_MAX + 1 ]; + const char *nodirfile; + int ret; + + /* Strip off the directory for our search */ + if( !strncasecmp( "/VIDEO_TS/", file, 10 ) ) { + nodirfile = &(file[ 10 ]); + } else { + nodirfile = file; + } + + ret = findDirFile( dvd->path_root, nodirfile, filename ); + if( ret < 0 ) { + /* Try also with adding the path, just in case. */ + sprintf( video_path, "%s/VIDEO_TS/", dvd->path_root ); + ret = findDirFile( video_path, nodirfile, filename ); + if( ret < 0 ) { + /* Try with the path, but in lower case. */ + sprintf( video_path, "%s/video_ts/", dvd->path_root ); + ret = findDirFile( video_path, nodirfile, filename ); + if( ret < 0 ) { + return 0; + } + } + } + + return 1; +} + +/** + * Open an unencrypted file from a DVD directory tree. + */ +static dvd_file_t *DVDOpenFilePath( dvd_reader_t *dvd, char *filename ) +{ + char full_path[ PATH_MAX + 1 ]; + dvd_file_t *dvd_file; + struct stat fileinfo; + dvd_input_t dev; + + /* Get the full path of the file. */ + if( !findDVDFile( dvd, filename, full_path ) ) return 0; + + dev = dvdinput_open( full_path ); + if( !dev ) return 0; + + dvd_file = (dvd_file_t *) malloc( sizeof( dvd_file_t ) ); + if( !dvd_file ) return 0; + dvd_file->dvd = dvd; + dvd_file->lb_start = 0; + dvd_file->seek_pos = 0; + memset( dvd_file->title_sizes, 0, sizeof( dvd_file->title_sizes ) ); + memset( dvd_file->title_devs, 0, sizeof( dvd_file->title_devs ) ); + dvd_file->filesize = 0; + + if( stat( full_path, &fileinfo ) < 0 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat() %s.\n", filename ); + } + free( dvd_file ); + return 0; + } + dvd_file->title_sizes[ 0 ] = fileinfo.st_size / DVD_VIDEO_LB_LEN; + dvd_file->title_devs[ 0 ] = dev; + dvd_file->filesize = dvd_file->title_sizes[ 0 ]; + + return dvd_file; +} + +static dvd_file_t *DVDOpenVOBUDF( dvd_reader_t *dvd, int title, int menu ) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + uint32_t start, len; + dvd_file_t *dvd_file; + + if( title == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.VOB" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02d_%d.VOB", title, menu ? 0 : 1 ); + } + start = UDFFindFile( dvd, filename, &len ); + if( start == 0 ) return 0; + + dvd_file = (dvd_file_t *) malloc( sizeof( dvd_file_t ) ); + if( !dvd_file ) return 0; + dvd_file->dvd = dvd; + /*Hack*/ dvd_file->css_title = title << 1 | menu; + dvd_file->lb_start = start; + dvd_file->seek_pos = 0; + memset( dvd_file->title_sizes, 0, sizeof( dvd_file->title_sizes ) ); + memset( dvd_file->title_devs, 0, sizeof( dvd_file->title_devs ) ); + dvd_file->filesize = len / DVD_VIDEO_LB_LEN; + + /* Calculate the complete file size for every file in the VOBS */ + if( !menu ) { + int cur; + + for( cur = 2; cur < 10; cur++ ) { + sprintf( filename, "/VIDEO_TS/VTS_%02d_%d.VOB", title, cur ); + if( !UDFFindFile( dvd, filename, &len ) ) break; + dvd_file->filesize += len / DVD_VIDEO_LB_LEN; + } + } + + if( dvd->css_state == 1 /* Need key init */ ) { + initAllCSSKeys( dvd ); + dvd->css_state = 2; + } + /* + if( dvdinput_title( dvd_file->dvd->dev, (int)start ) < 0 ) { + fprintf( stderr, "libdvdread: Error cracking CSS key for %s\n", + filename ); + } + */ + + return dvd_file; +} + +static dvd_file_t *DVDOpenVOBPath( dvd_reader_t *dvd, int title, int menu ) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + char full_path[ PATH_MAX + 1 ]; + struct stat fileinfo; + dvd_file_t *dvd_file; + int i; + + dvd_file = (dvd_file_t *) malloc( sizeof( dvd_file_t ) ); + if( !dvd_file ) return 0; + dvd_file->dvd = dvd; + /*Hack*/ dvd_file->css_title = title << 1 | menu; + dvd_file->lb_start = 0; + dvd_file->seek_pos = 0; + memset( dvd_file->title_sizes, 0, sizeof( dvd_file->title_sizes ) ); + memset( dvd_file->title_devs, 0, sizeof( dvd_file->title_devs ) ); + dvd_file->filesize = 0; + + if( menu ) { + dvd_input_t dev; + + if( title == 0 ) { + sprintf( filename, "VIDEO_TS.VOB" ); + } else { + sprintf( filename, "VTS_%02i_0.VOB", title ); + } + if( !findDVDFile( dvd, filename, full_path ) ) { + free( dvd_file ); + return 0; + } + + dev = dvdinput_open( full_path ); + if( dev == NULL ) { + free( dvd_file ); + return 0; + } + + if( stat( full_path, &fileinfo ) < 0 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat() %s.\n", filename ); + } + free( dvd_file ); + return 0; + } + dvd_file->title_sizes[ 0 ] = fileinfo.st_size / DVD_VIDEO_LB_LEN; + dvd_file->title_devs[ 0 ] = dev; + dvdinput_title( dvd_file->title_devs[0], 0); + dvd_file->filesize = dvd_file->title_sizes[ 0 ]; + + } else { + for( i = 0; i < 9; ++i ) { + + sprintf( filename, "VTS_%02i_%i.VOB", title, i + 1 ); + if( !findDVDFile( dvd, filename, full_path ) ) { + break; + } + + if( stat( full_path, &fileinfo ) < 0 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat() %s.\n", filename ); + } + break; + } + + dvd_file->title_sizes[ i ] = fileinfo.st_size / DVD_VIDEO_LB_LEN; + dvd_file->title_devs[ i ] = dvdinput_open( full_path ); + dvdinput_title( dvd_file->title_devs[ i ], 0 ); + dvd_file->filesize += dvd_file->title_sizes[ i ]; + } + if( !dvd_file->title_devs[ 0 ] ) { + free( dvd_file ); + return 0; + } + } + + return dvd_file; +} + +dvd_file_t *DVDOpenFile( dvd_reader_t *dvd, int titlenum, + dvd_read_domain_t domain ) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + + /* Check arguments. */ + if( dvd == NULL || titlenum < 0 ) { + errno = EINVAL; + return NULL; + } + + switch( domain ) { + case DVD_READ_INFO_FILE: + if( titlenum == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.IFO" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02i_0.IFO", titlenum ); + } + break; + case DVD_READ_INFO_BACKUP_FILE: + if( titlenum == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.BUP" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02i_0.BUP", titlenum ); + } + break; + case DVD_READ_MENU_VOBS: + if( dvd->isImageFile ) { + return DVDOpenVOBUDF( dvd, titlenum, 1 ); + } else { + return DVDOpenVOBPath( dvd, titlenum, 1 ); + } + break; + case DVD_READ_TITLE_VOBS: + if( titlenum == 0 ) return 0; + if( dvd->isImageFile ) { + return DVDOpenVOBUDF( dvd, titlenum, 0 ); + } else { + return DVDOpenVOBPath( dvd, titlenum, 0 ); + } + break; + default: + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Invalid domain for file open.\n" ); + } + errno = EINVAL; + return NULL; + } + + if( dvd->isImageFile ) { + return DVDOpenFileUDF( dvd, filename ); + } else { + return DVDOpenFilePath( dvd, filename ); + } +} + +void DVDCloseFile( dvd_file_t *dvd_file ) +{ + int i; + + if( dvd_file ) { + if( dvd_file->dvd->isImageFile ) { + ; + } else { + for( i = 0; i < 9; ++i ) { + if( dvd_file->title_devs[ i ] ) { + dvdinput_close( dvd_file->title_devs[i] ); + } + } + } + + free( dvd_file ); + dvd_file = 0; + } +} + +static int DVDFileStatVOBUDF(dvd_reader_t *dvd, int title, + int menu, dvd_stat_t *statbuf) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + uint32_t size; + off_t tot_size; + off_t parts_size[9]; + int nr_parts = 0; + int n; + + if( title == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.VOB" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02d_%d.VOB", title, menu ? 0 : 1 ); + } + if(!UDFFindFile( dvd, filename, &size )) { + return -1; + } + tot_size = size; + nr_parts = 1; + parts_size[0] = size; + + if( !menu ) { + int cur; + + for( cur = 2; cur < 10; cur++ ) { + sprintf( filename, "/VIDEO_TS/VTS_%02d_%d.VOB", title, cur ); + if( !UDFFindFile( dvd, filename, &size ) ) { + break; + } + parts_size[nr_parts] = size; + tot_size += size; + nr_parts++; + } + } + + statbuf->size = tot_size; + statbuf->nr_parts = nr_parts; + for(n = 0; n < nr_parts; n++) { + statbuf->parts_size[n] = parts_size[n]; + } + return 0; +} + + +static int DVDFileStatVOBPath( dvd_reader_t *dvd, int title, + int menu, dvd_stat_t *statbuf ) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + char full_path[ PATH_MAX + 1 ]; + struct stat fileinfo; + off_t tot_size; + off_t parts_size[9]; + int nr_parts = 0; + int n; + + + + if( title == 0 ) { + sprintf( filename, "VIDEO_TS.VOB" ); + } else { + sprintf( filename, "VTS_%02d_%d.VOB", title, menu ? 0 : 1 ); + } + if( !findDVDFile( dvd, filename, full_path ) ) { + return -1; + } + + if( stat( full_path, &fileinfo ) < 0 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat() %s.\n", filename ); + } + return -1; + } + + + tot_size = fileinfo.st_size; + nr_parts = 1; + parts_size[0] = fileinfo.st_size; + + if( !menu ) { + int cur; + + for( cur = 2; cur < 10; cur++ ) { + + sprintf( filename, "VTS_%02d_%d.VOB", title, cur ); + if( !findDVDFile( dvd, filename, full_path ) ) { + break; + } + + if( stat( full_path, &fileinfo ) < 0 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat() %s.\n", filename ); + } + break; + } + + parts_size[nr_parts] = fileinfo.st_size; + tot_size += parts_size[nr_parts]; + nr_parts++; + } + } + + statbuf->size = tot_size; + statbuf->nr_parts = nr_parts; + for(n = 0; n < nr_parts; n++) { + statbuf->parts_size[n] = parts_size[n]; + } + return 0; +} + + +int DVDFileStat(dvd_reader_t *dvd, int titlenum, + dvd_read_domain_t domain, dvd_stat_t *statbuf) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + char full_path[ PATH_MAX + 1 ]; + struct stat fileinfo; + uint32_t size; + + /* Check arguments. */ + if( dvd == NULL || titlenum < 0 ) { + errno = EINVAL; + return -1; + } + + switch( domain ) { + case DVD_READ_INFO_FILE: + if( titlenum == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.IFO" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02i_0.IFO", titlenum ); + } + break; + case DVD_READ_INFO_BACKUP_FILE: + if( titlenum == 0 ) { + sprintf( filename, "/VIDEO_TS/VIDEO_TS.BUP" ); + } else { + sprintf( filename, "/VIDEO_TS/VTS_%02i_0.BUP", titlenum ); + } + break; + case DVD_READ_MENU_VOBS: + if( dvd->isImageFile ) { + return DVDFileStatVOBUDF( dvd, titlenum, 1, statbuf ); + } else { + return DVDFileStatVOBPath( dvd, titlenum, 1, statbuf ); + } + break; + case DVD_READ_TITLE_VOBS: + if( titlenum == 0 ) { + return -1; + } + if( dvd->isImageFile ) { + return DVDFileStatVOBUDF( dvd, titlenum, 0, statbuf ); + } else { + return DVDFileStatVOBPath( dvd, titlenum, 0, statbuf ); + } + break; + default: + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Invalid domain for file stat.\n" ); + } + errno = EINVAL; + return -1; + } + + if( dvd->isImageFile ) { + if( UDFFindFile( dvd, filename, &size ) ) { + statbuf->size = size; + statbuf->nr_parts = 1; + statbuf->parts_size[0] = size; + return 0; + } + } else { + if( findDVDFile( dvd, filename, full_path ) ) { + if( stat( full_path, &fileinfo ) < 0 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: Can't stat() %s.\n", filename ); + } + } else { + statbuf->size = fileinfo.st_size; + statbuf->nr_parts = 1; + statbuf->parts_size[0] = statbuf->size; + return 0; + } + } + } + return -1; +} + +/** + * Internal, but used from dvd_udf.c + * + * @param device A read handle. + * @param lb_number Logical block number to start read from. + * @param block_count Number of logical blocks to read. + * @param data Pointer to buffer where read data should be stored. + * This buffer must be large enough to hold lb_number*2048 bytes. + * The pointer must be aligned to the logical block size when + * reading from a raw/O_DIRECT device. + * @param encrypted 0 if no decryption shall be performed, + * 1 if decryption shall be performed + * @param return Returns number of blocks read on success, negative on error + */ +int UDFReadBlocksRaw( dvd_reader_t *device, uint32_t lb_number, + size_t block_count, unsigned char *data, + int encrypted ) +{ + int ret; + + if( !device->dev ) { + if(device->verbose >= 1) { + fprintf( stderr, "libdvdread: Fatal error in block read.\n" ); + } + return 0; + } + + ret = dvdinput_seek( device->dev, (int) lb_number ); + if( ret != (int) lb_number ) { + if(device->verbose >= 1) { + fprintf( stderr, + "libdvdread: UDFReadBlocksRaw: Can't seek to block %u\n", + lb_number ); + } + return 0; + } + + return dvdinput_read( device->dev, (char *) data, + (int) block_count, encrypted ); +} + +/** + * This is using a single input and starting from 'dvd_file->lb_start' offset. + * + * Reads 'block_count' blocks from 'dvd_file' at block offset 'offset' + * into the buffer located at 'data' and if 'encrypted' is set + * descramble the data if it's encrypted. Returning either an + * negative error or the number of blocks read. + * + * @param data Pointer to buffer where read data should be placed. + * This buffer must be large enough to hold block_count*2048 bytes. + * The pointer must be aligned to 2048 bytes when reading from + * a raw/O_DIRECT device. + * @return Returns the number of blocks read on success or a negative error. + */ +static int DVDReadBlocksUDF( dvd_file_t *dvd_file, uint32_t offset, + size_t block_count, unsigned char *data, + int encrypted ) +{ + return UDFReadBlocksRaw( dvd_file->dvd, dvd_file->lb_start + offset, + block_count, data, encrypted ); +} + +/** + * This is using possibly several inputs and starting from an offset of '0'. + * data must be aligned to logical block size (2048 bytes) of the device + * for raw/O_DIRECT devices to work + * Reads 'block_count' blocks from 'dvd_file' at block offset 'offset' + * into the buffer located at 'data' and if 'encrypted' is set + * descramble the data if it's encrypted. Returning either an + * negative error or the number of blocks read. + * + * @param dvd_file A file read handle. + * @param offset Block offset from start of file. + * @return Returns number of blocks read on success, negative on error. + */ +static int DVDReadBlocksPath( dvd_file_t *dvd_file, unsigned int offset, + size_t block_count, unsigned char *data, + int encrypted ) +{ + int i; + int ret, ret2, off; + + ret = 0; + ret2 = 0; + for( i = 0; i < 9; ++i ) { + if( !dvd_file->title_sizes[ i ] ) return 0; /* Past end of file */ + + if( offset < dvd_file->title_sizes[ i ] ) { + if( ( offset + block_count ) <= dvd_file->title_sizes[ i ] ) { + off = dvdinput_seek( dvd_file->title_devs[ i ], (int)offset ); + if( off < 0 || off != (int)offset ) { + if(dvd_file->dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: DVDReadBlocksPath1: Can't seek to block %d\n", + offset ); + } + return off < 0 ? off : 0; + } + ret = dvdinput_read( dvd_file->title_devs[ i ], data, + (int)block_count, encrypted ); + break; + } else { + size_t part1_size = dvd_file->title_sizes[ i ] - offset; + /* FIXME: Really needs to be a while loop. + * (This is only true if you try and read >1GB at a time) */ + + /* Read part 1 */ + off = dvdinput_seek( dvd_file->title_devs[ i ], (int)offset ); + if( off < 0 || off != (int)offset ) { + if(dvd_file->dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: DVDReadBlocksPath2: Can't seek to block %d\n", + offset ); + } + return off < 0 ? off : 0; + } + ret = dvdinput_read( dvd_file->title_devs[ i ], data, + (int)part1_size, encrypted ); + if( ret < 0 ) return ret; + /* FIXME: This is wrong if i is the last file in the set. + * also error from this read will not show in ret. */ + + /* Does the next part exist? If not then return now. */ + if( !dvd_file->title_devs[ i + 1 ] ) return ret; + + /* Read part 2 */ + off = dvdinput_seek( dvd_file->title_devs[ i + 1 ], 0 ); + if( off < 0 || off != 0 ) { + if(dvd_file->dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: DVDReadBlocksPath3: Can't seek to block %d\n", 0 ); + } + return off < 0 ? off : 0; + } + ret2 = dvdinput_read( dvd_file->title_devs[ i + 1 ], + data + ( part1_size + * (int64_t)DVD_VIDEO_LB_LEN ), + (int)(block_count - part1_size), + encrypted ); + if( ret2 < 0 ) return ret2; + break; + } + } else { + offset -= dvd_file->title_sizes[ i ]; + } + } + + return ret + ret2; +} + +/** + * This is broken reading more than 2Gb at a time if ssize_t is 32-bit. + */ +ssize_t DVDReadBlocks( dvd_file_t *dvd_file, int offset, + size_t block_count, unsigned char *data ) +{ + int ret; + + /* Check arguments. */ + if( dvd_file == NULL || offset < 0 || data == NULL ) + return -1; + + /* Hack, and it will still fail for multiple opens in a threaded app ! */ + if( dvd_file->dvd->css_title != dvd_file->css_title ) { + dvd_file->dvd->css_title = dvd_file->css_title; + if( dvd_file->dvd->isImageFile ) { + dvdinput_title( dvd_file->dvd->dev, (int)dvd_file->lb_start ); + } + /* Here each vobu has it's own dvdcss handle, so no need to update + else { + dvdinput_title( dvd_file->title_devs[ 0 ], (int)dvd_file->lb_start ); + }*/ + } + + if( dvd_file->dvd->isImageFile ) { + ret = DVDReadBlocksUDF( dvd_file, (uint32_t)offset, + block_count, data, DVDINPUT_READ_DECRYPT ); + } else { + ret = DVDReadBlocksPath( dvd_file, (unsigned int)offset, + block_count, data, DVDINPUT_READ_DECRYPT ); + } + + return (ssize_t)ret; +} + +int DVDFileSeek( dvd_file_t *dvd_file, int offset ) +{ + /* Check arguments. */ + if( dvd_file == NULL || offset < 0 ) + return -1; + + if( offset > dvd_file->filesize * DVD_VIDEO_LB_LEN ) { + return -1; + } + dvd_file->seek_pos = (uint32_t) offset; + return offset; +} + +#ifndef HAVE_UINTPTR_T +#warning "Assuming that (unsigned long) can hold (void *)" +/*typedef unsigned long uintptr_t;*/ +#endif + +#define DVD_ALIGN(ptr) (void *)((((uintptr_t)(ptr)) + (DVD_VIDEO_LB_LEN-1)) \ + / DVD_VIDEO_LB_LEN * DVD_VIDEO_LB_LEN) + +ssize_t DVDReadBytes( dvd_file_t *dvd_file, void *data, size_t byte_size ) +{ + unsigned char *secbuf_start; + unsigned char *secbuf; /*must be aligned to 2048-bytes for raw/O_DIRECT*/ + unsigned int numsec, seek_sector, seek_byte; + int ret; + + /* Check arguments. */ + if( dvd_file == NULL || data == NULL ) { + errno = EINVAL; + return -1; + } + seek_sector = dvd_file->seek_pos / DVD_VIDEO_LB_LEN; + seek_byte = dvd_file->seek_pos % DVD_VIDEO_LB_LEN; + + numsec = ( ( seek_byte + byte_size ) / DVD_VIDEO_LB_LEN ) + + ( ( ( seek_byte + byte_size ) % DVD_VIDEO_LB_LEN ) ? 1 : 0 ); + + /* must align to 2048 bytes if we are reading from raw/O_DIRECT */ + secbuf_start = (unsigned char *) malloc( (numsec+1) * DVD_VIDEO_LB_LEN ); + if( !secbuf_start ) { + /* errno will be set to ENOMEM by malloc */ + return -1; + } + + secbuf = DVD_ALIGN(secbuf_start); + + if( dvd_file->dvd->isImageFile ) { + ret = DVDReadBlocksUDF( dvd_file, (uint32_t) seek_sector, + (size_t) numsec, secbuf, DVDINPUT_NOFLAGS ); + } else { + ret = DVDReadBlocksPath( dvd_file, seek_sector, + (size_t) numsec, secbuf, DVDINPUT_NOFLAGS ); + } + + if( ret != (int) numsec ) { + free( secbuf_start ); + return ret < 0 ? ret : 0; + } + + memcpy( data, &(secbuf[ seek_byte ]), byte_size ); + free( secbuf_start ); + + dvd_file->seek_pos += byte_size; + return byte_size; +} + +ssize_t DVDFileSize( dvd_file_t *dvd_file ) +{ + /* Check arguments. */ + if( dvd_file == NULL ) + return -1; + + return dvd_file->filesize; +} + +int DVDDiscID( dvd_reader_t *dvd, unsigned char *discid ) +{ + struct md5_ctx ctx; + int title; + int nr_of_files = 0; + int tmp_errno; + int nofiles_errno = ENOENT; + /* Check arguments. */ + if( dvd == NULL || discid == NULL ) { + errno = EINVAL; + return -1; + } + /* Go through the first 10 IFO:s, in order, + * and md5sum them, i.e VIDEO_TS.IFO and VTS_0?_0.IFO */ + md5_init_ctx( &ctx ); + for( title = 0; title < 10; title++ ) { + dvd_file_t *dvd_file = DVDOpenFile( dvd, title, DVD_READ_INFO_FILE ); + if( dvd_file != NULL ) { + ssize_t bytes_read; + size_t file_size = dvd_file->filesize * DVD_VIDEO_LB_LEN; + char *buffer = malloc( file_size ); + + nr_of_files++; + + if( buffer == NULL ) { + /* errno will be set to ENOMEM by malloc */ + return -1; + } + + bytes_read = DVDReadBytes( dvd_file, buffer, file_size ); + if( bytes_read != file_size ) { + tmp_errno = errno; + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: DVDDiscId read returned %d bytes" + ", wanted %d\n", (int)bytes_read, (int)file_size ); + } + free(buffer); + DVDCloseFile( dvd_file ); + errno = tmp_errno; + return -1; + } + + md5_process_bytes( buffer, file_size, &ctx ); + + DVDCloseFile( dvd_file ); + free( buffer ); + } else { + if(errno != ENOENT) { + nofiles_errno = errno; + } + } + } + md5_finish_ctx( &ctx, discid ); + if(nr_of_files == 0) { + errno = nofiles_errno; + return -1; + } + return 0; +} + + +int DVDISOVolumeInfo( dvd_reader_t *dvd, + char *volid, unsigned int volid_size, + unsigned char *volsetid, unsigned int volsetid_size ) +{ + unsigned char *buffer; /* must be aligned to 2048 for raw/O_DIRECT */ + unsigned char *buffer_start; + int ret; + + /* Check arguments. */ + if( dvd == NULL ) { + errno = EINVAL; + return -1; + } + + if( dvd->dev == NULL ) { + /* No block access, so no ISO... */ + errno = EINVAL; + return -1; + } + + buffer_start = malloc( 2 * DVD_VIDEO_LB_LEN ); + if( buffer_start == NULL ) { + return -1; + } + + buffer = DVD_ALIGN(buffer_start); + + ret = UDFReadBlocksRaw( dvd, 16, 1, buffer, 0 ); + if( ret != 1 ) { + if(dvd->verbose >= 1) { + fprintf( stderr, "libdvdread: DVDISOVolumeInfo, failed to " + "read ISO9660 Primary Volume Descriptor!\n" ); + } + free(buffer_start); + return -1; + } + + if( (volid != NULL) && (volid_size > 0) ) { + unsigned int n; + for(n = 0; n < 32; n++) { + if(buffer[40+n] == 0x20) { + break; + } + } + + if(volid_size > n+1) { + volid_size = n+1; + } + + memcpy(volid, &buffer[40], volid_size-1); + volid[volid_size-1] = '\0'; + } + + if( (volsetid != NULL) && (volsetid_size > 0) ) { + if(volsetid_size > 128) { + volsetid_size = 128; + } + memcpy(volsetid, &buffer[190], volsetid_size); + } + free(buffer_start); + + return 0; +} + + +int DVDUDFVolumeInfo( dvd_reader_t *dvd, + char *volid, unsigned int volid_size, + unsigned char *volsetid, unsigned int volsetid_size ) +{ + int ret; + /* Check arguments. */ + if( dvd == NULL ) + return -1; + + if( dvd->dev == NULL ) { + /* No block access, so no UDF VolumeSet Identifier */ + return -1; + } + + if( (volid != NULL) && (volid_size > 0) ) { + ret = UDFGetVolumeIdentifier(dvd, volid, volid_size); + if(!ret) { + return -1; + } + } + if( (volsetid != NULL) && (volsetid_size > 0) ) { + ret = UDFGetVolumeSetIdentifier(dvd, volsetid, volsetid_size); + if(!ret) { + return -1; + } + } + + return 0; +} diff --git a/dvdread/dvd_reader.h b/dvdread/dvd_reader.h new file mode 100644 index 0000000..d666e8a --- /dev/null +++ b/dvdread/dvd_reader.h @@ -0,0 +1,344 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +#ifndef DVD_READER_H_INCLUDED +#define DVD_READER_H_INCLUDED + +/* + * Copyright (C) 2001, 2002 Billy Biggs , + * Håkan Hjort , + * Björn Englund + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#include + +/** + * The DVD access interface. + * + * This file contains the functions that form the interface to to + * reading files located on a DVD. + */ + +/** + * The current version. (0.9.4 => 904, 1.2.3 => 10203) + */ +#define DVDREAD_VERSION 907 + + +/** + * The length of one Logical Block of a DVD. + */ +#define DVD_VIDEO_LB_LEN 2048 + +/** + * Maximum length of filenames allowed in UDF. + */ +#define MAX_UDF_FILE_NAME_LEN 2048 + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * Opaque type that is used as a handle for one instance of an opened DVD. + */ +typedef struct dvd_reader_s dvd_reader_t; + +/** + * Opaque type for a file read handle, much like a normal fd or FILE *. + */ +typedef struct dvd_file_s dvd_file_t; + +/** + * Returns the compiled version. (DVDREAD_VERSION as an int) + */ +int DVDVersion(void); + + +/** + * Opens a block device of a DVD-ROM file, or an image file, or a directory + * name for a mounted DVD or HD copy of a DVD. + * + * If the given file is a block device, or is the mountpoint for a block + * device, then that device is used for CSS authentication using libdvdcss. + * If no device is available, then no CSS authentication is performed, + * and we hope that the image is decrypted. + * + * If the path given is a directory, then the files in that directory may be + * in any one of these formats: + * + * path/VIDEO_TS/VTS_01_1.VOB + * path/video_ts/vts_01_1.vob + * path/VTS_01_1.VOB + * path/vts_01_1.vob + * + * @param path Specifies the the device, file or directory to be used. + * @return If successful a a read handle is returned. Otherwise 0 is returned. + * + * dvd = DVDOpen(path); + * + * Threads: this function uses chdir() and getcwd(). + * The current working directory is global to all threads, + * so using chdir/getcwd in another thread could give unexpected results. + */ +dvd_reader_t *DVDOpen( const char * ); + +/** + * Closes and cleans up the DVD reader object. + * + * You must close all open files before calling this function. + * + * @param dvd A read handle that should be closed. + * + * DVDClose(dvd); + */ +void DVDClose( dvd_reader_t * ); + +/** + * Initializes libdvdread to be used with multithreading apps. + * + * You must call this function before using any other functions of libdvdread + * if you are going to use libdvdread in multiple threads in your program. + * If you are not using threads, or using libdvdread from just one thread, + * you do not need to call this, but you are allowed to do so anyway. + * + * There are several restrictions on how you can use libdvdread in + * multithreading apps, see further documentation. + * + * If you have called DVDFinish() you need to call DVDInit again to use + * libdvdread in multiple threads. + * + * DVDInit(void); + */ +void DVDInit(void); + +/** + * frees any dlopened objects. + * + * You must DVDClose all handles opened with DVDOpen before calling this. + * Use this function if you need to close the dlopened libs and any other + * objects that have been dynamically allocated by libdvdread. + * + * DVDFinish(void); + */ +void DVDFinish(void); + +/** + * + */ +typedef enum { + DVD_READ_INFO_FILE, /**< VIDEO_TS.IFO or VTS_XX_0.IFO (title) */ + DVD_READ_INFO_BACKUP_FILE, /**< VIDEO_TS.BUP or VTS_XX_0.BUP (title) */ + DVD_READ_MENU_VOBS, /**< VIDEO_TS.VOB or VTS_XX_0.VOB (title) */ + DVD_READ_TITLE_VOBS /**< VTS_XX_[1-9].VOB (title). All files in + the title set are opened and read as a + single file. */ +} dvd_read_domain_t; + +/** + * + */ +typedef struct { + off_t size; /**< Total size of file in bytes */ + int nr_parts; /**< Number of file parts */ + off_t parts_size[9]; /**< Size of each part in bytes */ +} dvd_stat_t; + +/** + * Stats a file on the DVD given the title number and domain. + * The information about the file is stored in a dvd_stat_t + * which contains information about the size of the file and + * the number of parts in case of a multipart file and the respective + * sizes of the parts. + * A multipart file is for instance VTS_02_1.VOB, VTS_02_2.VOB, VTS_02_3.VOB + * The size of VTS_02_1.VOB will be stored in stat->parts_size[0], + * VTS_02_2.VOB in stat->parts_size[1], ... + * The total size (sum of all parts) is stored in stat->size and + * stat->nr_parts will hold the number of parts. + * Only DVD_READ_TITLE_VOBS (VTS_??_[1-9].VOB) can be multipart files. + * + * This function is only of use if you want to get the size of each file + * in the filesystem. These sizes are not needed to use any other + * functions in libdvdread. + * + * @param dvd A dvd read handle. + * @param titlenum Which Video Title Set should be used, VIDEO_TS is 0. + * @param domain Which domain. + * @param stat Pointer to where the result is stored. + * @return If successful 0, otherwise -1. + * + * int DVDFileStat(dvd, titlenum, domain, stat); + */ +int DVDFileStat(dvd_reader_t *, int, dvd_read_domain_t, dvd_stat_t *); + +/** + * Opens a file on the DVD given the title number and domain. + * + * If the title number is 0, the video manager information is opened + * (VIDEO_TS.[IFO,BUP,VOB]). Returns a file structure which may be + * used for reads, or 0 if the file was not found. + * + * @param dvd A dvd read handle. + * @param titlenum Which Video Title Set should be used, VIDEO_TS is 0. + * @param domain Which domain. + * @return If successful a a file read handle is returned, otherwise 0. + * + * dvd_file = DVDOpenFile(dvd, titlenum, domain); */ +dvd_file_t *DVDOpenFile( dvd_reader_t *, int, dvd_read_domain_t ); + +/** + * Closes a file and frees the associated structure. + * + * @param dvd_file The file read handle to be closed. + * + * DVDCloseFile(dvd_file); + */ +void DVDCloseFile( dvd_file_t * ); + +/** + * Reads block_count number of blocks from the file at the given block offset. + * Returns number of blocks read on success, -1 on error. This call is only + * for reading VOB data, and should not be used when reading the IFO files. + * When reading from an encrypted drive, blocks are decrypted using libdvdcss + * where required. + * + * @param dvd_file A file read handle. + * @param offset Block offset from the start of the file to start reading at. + * @param block_count Number of block to read. + * @param data Pointer to a buffer to write the data into. + * It must be aligned to the logical block size of the device when + * reading from a raw/O_DIRECT device (2048 bytes for DVD) + * @return Returns number of blocks read on success, -1 on error. + * + * blocks_read = DVDReadBlocks(dvd_file, offset, block_count, data); + */ +ssize_t DVDReadBlocks( dvd_file_t *, int, size_t, unsigned char * ); + +/** + * Seek to the given position in the file. Returns the resulting position in + * bytes from the beginning of the file. The seek position is only used for + * byte reads from the file, the block read call always reads from the given + * offset. + * + * @param dvd_file A file read handle. + * @param seek_offset Byte offset from the start of the file to seek to. + * @return The resulting position in bytes from the beginning of the file. + * + * offset_set = DVDFileSeek(dvd_file, seek_offset); + */ +int DVDFileSeek( dvd_file_t *, int ); + +/** + * Reads the given number of bytes from the file. This call can only be used + * on the information files, and may not be used for reading from a VOB. This + * reads from and increments the currrent seek position for the file. + * + * @param dvd_file A file read handle. + * @param data Pointer to a buffer to write the data into. + * @param bytes Number of bytes to read. + * @return Returns number of bytes read on success, -1 on error. + * + * bytes_read = DVDReadBytes(dvd_file, data, bytes); + */ +ssize_t DVDReadBytes( dvd_file_t *, void *, size_t ); + +/** + * Returns the file size in blocks. + * + * @param dvd_file A file read handle. + * @return The size of the file in blocks, -1 on error. + * + * blocks = DVDFileSize(dvd_file); + */ +ssize_t DVDFileSize( dvd_file_t * ); + +/** + * Get a unique 128 bit disc ID. + * This is the MD5 sum of VIDEO_TS.IFO and the VTS_0?_0.IFO files + * in title order (those that exist). + * If you need a 'text' representation of the id, print it as a + * hexadecimal number, using lowercase letters, discid[0] first. + * I.e. the same format as the command-line 'md5sum' program uses. + * + * @param dvd A read handle to get the disc ID from + * @param discid The buffer to put the disc ID into. The buffer must + * have room for 128 bits (16 chars). + * @return 0 on success, -1 on error. + */ +int DVDDiscID( dvd_reader_t *, unsigned char * ); + +/** + * Get the UDF VolumeIdentifier and VolumeSetIdentifier + * from the PrimaryVolumeDescriptor. + * + * @param dvd A read handle to get the disc ID from + * @param volid The buffer to put the VolumeIdentifier into. + * The VolumeIdentifier is latin-1 encoded (8bit unicode) + * null terminated and max 32 bytes (including '\0') + * @param volid_size No more than volid_size bytes will be copied to volid. + * If the VolumeIdentifier is truncated because of this + * it will still be null terminated. + * @param volsetid The buffer to put the VolumeSetIdentifier into. + * The VolumeIdentifier is 128 bytes as + * stored in the UDF PrimaryVolumeDescriptor. + * Note that this is not a null terminated string. + * @param volsetid_size At most volsetid_size bytes will be copied to volsetid. + * @return 0 on success, -1 on error. + */ +int DVDUDFVolumeInfo( dvd_reader_t *, char *, unsigned int, + unsigned char *, unsigned int ); + +/** + * Get the ISO9660 VolumeIdentifier and VolumeSetIdentifier + * + * * Only use this function as fallback if DVDUDFVolumeInfo returns 0 * + * * this will happen on a disc mastered only with a iso9660 filesystem * + * * All video DVD discs have UDF filesystem * + * + * @param dvd A read handle to get the disc ID from + * @param volid The buffer to put the VolumeIdentifier into. + * The VolumeIdentifier is coded with '0-9','A-Z','_' + * null terminated and max 33 bytes (including '\0') + * @param volid_size No more than volid_size bytes will be copied to volid. + * If the VolumeIdentifier is truncated because of this + * it will still be null terminated. + * @param volsetid The buffer to put the VolumeSetIdentifier into. + * The VolumeIdentifier is 128 bytes as + * stored in the ISO9660 PrimaryVolumeDescriptor. + * Note that this is not a null terminated string. + * @param volsetid_size At most volsetid_size bytes will be copied to volsetid. + * @return 0 on success, -1 on error. + */ +int DVDISOVolumeInfo( dvd_reader_t *, char *, unsigned int, + unsigned char *, unsigned int ); + +/** + * Sets the level of caching that is done when reading from a device + * + * @param dvd A read handle to get the disc ID from + * @param level The level of caching wanted. + * -1 - returns the current setting. + * 0 - UDF Cache turned off. + * 1 - (default level) Pointers to IFO files and some data from + * PrimaryVolumeDescriptor are cached. + * + * @return The level of caching. + */ +int DVDUDFCacheLevel( dvd_reader_t *, int ); + +#ifdef __cplusplus +}; +#endif +#endif /* DVD_READER_H_INCLUDED */ diff --git a/dvdread/dvd_udf.c b/dvdread/dvd_udf.c new file mode 100644 index 0000000..9af6ad0 --- /dev/null +++ b/dvdread/dvd_udf.c @@ -0,0 +1,1216 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +/* + * This code is based on dvdudf by: + * Christian Wolff . + * + * Modifications by: + * Billy Biggs . + * Bj�rn Englund . + * + * dvdudf: parse and read the UDF volume information of a DVD Video + * Copyright (C) 1999 Christian Wolff for convergence integrated media + * GmbH The author can be reached at scarabaeus@convergence.de, the + * project's page is at http://linuxtv.org/dvd/ + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + * 02110-1301, USA. Or, point your browser to + * http://www.gnu.org/copyleft/gpl.html + */ + +#include "config.h" + +#include +#include +#include + +#include +#include +#include +#include + +#if defined(HAVE_INTTYPES_H) +#include +#elif defined(HAVE_STDINT_H) +#include +#endif + +#include "dvd_reader.h" +#include "dvd_udf.h" +#include "dvdread_internal.h" + +#ifndef EMEDIUMTYPE +#define EMEDIUMTYPE ENOENT +#endif + +#ifndef HAVE_UINTPTR_T +#warning "Assuming that (unsigned long) can hold (void *)" +/*typedef unsigned long uintptr_t;*/ +#endif + +#define DVD_ALIGN(ptr) (void *)((((uintptr_t)(ptr)) + (DVD_VIDEO_LB_LEN-1)) \ + / DVD_VIDEO_LB_LEN * DVD_VIDEO_LB_LEN) + +typedef struct { + void *start; + void *aligned; +} dvdalign_ptrs_t; + +typedef struct { + dvdalign_ptrs_t *ptrs; + uint32_t ptrs_in_use; + uint32_t ptrs_max; +} dvdalign_t; + +extern void *GetAlignHandle(dvd_reader_t *device); +extern void SetAlignHandle(dvd_reader_t *device, void *align); + +/** + * Allocates aligned memory (for use with reads from raw/O_DIRECT devices). + * This memory must be freed with dvdalign_free() + * The size of the memory that is allocate is num_lbs*2048 bytes. + * The memory will be suitably aligned for use with + * block reads from raw/O_DIRECT device. + * @param num_lbs Number of logical blocks (2048 bytes) to allocate. + * @return Returns pointer to allocated memory, or NULL on failure + * This isn't supposed to be fast/efficient, if that is needed + * this function should be rewritten to use posix_memalign or similar. + * It's just needed for aligning memory for small block reads from + * raw/O_DIRECT devices. + * We assume that 2048 is enough alignment for all systems at the moment. + * Not thread safe. Only use this from one thread. + * Depends on sizeof(unsigned long) being at least as large as sizeof(void *) + */ +static void *dvdalign_lbmalloc(dvd_reader_t *device, uint32_t num_lbs) +{ + void *m; + int n; + dvdalign_t *a; + + m = malloc((num_lbs+1)*DVD_VIDEO_LB_LEN); + if(m == NULL) { + return m; + } + a = (dvdalign_t *)GetAlignHandle(device); + if(a == NULL) { + a = malloc(sizeof(dvdalign_t)); + if(a == NULL) { + return a; + } + a->ptrs = NULL; + a->ptrs_in_use = 0; + a->ptrs_max = 0; + SetAlignHandle(device, (void *)a); + } + + if(a->ptrs_in_use >= a->ptrs_max) { + a->ptrs = realloc(a->ptrs, (a->ptrs_max+10)*sizeof(dvdalign_ptrs_t)); + if(a->ptrs == NULL) { + free(m); + return NULL; + } + a->ptrs_max+=10; + for(n = a->ptrs_in_use; n < a->ptrs_max; n++) { + a->ptrs[n].start = NULL; + a->ptrs[n].aligned = NULL; + } + n = a->ptrs_in_use; + } else { + for(n = 0; n < a->ptrs_max; n++) { + if(a->ptrs[n].start == NULL) { + break; + } + } + } + + a->ptrs[n].start = m; + a->ptrs[n].aligned = DVD_ALIGN(m); + + a->ptrs_in_use++; + + /* If this function starts to be used too much print a warning. + Either there is a memory leak somewhere or we need to rewrite this to + a more efficient version. + */ + if(a->ptrs_in_use > 50) { + if(dvdread_verbose(device) >= 0) { + fprintf(stderr, "libdvdread: dvdalign_lbmalloc(), more allocs than supposed: %u\n", a->ptrs_in_use); + } + } + + return a->ptrs[n].aligned; +} + +/** + * Frees memory allocated with dvdalign_lbmemory() + * @param ptr Pointer to memory space to free + * Not thread safe. + */ +static void dvdalign_lbfree(dvd_reader_t *device, void *ptr) +{ + int n; + dvdalign_t *a; + + a = (dvdalign_t *)GetAlignHandle(device); + if(a && a->ptrs) { + for(n = 0; n < a->ptrs_max; n++) { + if(a->ptrs[n].aligned == ptr) { + free(a->ptrs[n].start); + a->ptrs[n].start = NULL; + a->ptrs[n].aligned = NULL; + a->ptrs_in_use--; + if(a->ptrs_in_use == 0) { + free(a->ptrs); + a->ptrs = NULL; + a->ptrs_max = 0; + free(a); + a = NULL; + SetAlignHandle(device, (void *)a); + } + return; + } + } + } + if(dvdread_verbose(device) >= 0) { + fprintf(stderr, "libdvdread: dvdalign_lbfree(), error trying to free mem: %08lx (%u)\n", (unsigned long)ptr, a ? a->ptrs_in_use : 0); + } +} + + +/* Private but located in/shared with dvd_reader.c */ +extern int UDFReadBlocksRaw( dvd_reader_t *device, uint32_t lb_number, + size_t block_count, unsigned char *data, + int encrypted ); + +/** @internal + * Its required to either fail or deliver all the blocks asked for. + * + * @param data Pointer to a buffer where data is returned. This must be large + * enough to hold lb_number*2048 bytes. + * It must be aligned to system specific (2048) logical blocks size when + * reading from raw/O_DIRECT device. + */ +static int DVDReadLBUDF( dvd_reader_t *device, uint32_t lb_number, + size_t block_count, unsigned char *data, + int encrypted ) +{ + int ret; + size_t count = block_count; + + while(count > 0) { + + ret = UDFReadBlocksRaw(device, lb_number, count, data, encrypted); + + if(ret <= 0) { + /* One of the reads failed or nothing more to read, too bad. + * We won't even bother returning the reads that went ok. */ + return ret; + } + + count -= (size_t)ret; + lb_number += (uint32_t)ret; + } + + return block_count; +} + + +#ifndef NULL +#define NULL ((void *)0) +#endif + +struct Partition { + int valid; + char VolumeDesc[128]; + uint16_t Flags; + uint16_t Number; + char Contents[32]; + uint32_t AccessType; + uint32_t Start; + uint32_t Length; +}; + +struct AD { + uint32_t Location; + uint32_t Length; + uint8_t Flags; + uint16_t Partition; +}; + +struct extent_ad { + uint32_t location; + uint32_t length; +}; + +struct avdp_t { + struct extent_ad mvds; + struct extent_ad rvds; +}; + +struct pvd_t { + uint8_t VolumeIdentifier[32]; + uint8_t VolumeSetIdentifier[128]; +}; + +struct lbudf { + uint32_t lb; + uint8_t *data; +}; + +struct icbmap { + uint32_t lbn; + struct AD file; + uint8_t filetype; +}; + +struct udf_cache { + int avdp_valid; + struct avdp_t avdp; + int pvd_valid; + struct pvd_t pvd; + int partition_valid; + struct Partition partition; + int rooticb_valid; + struct AD rooticb; + int lb_num; + struct lbudf *lbs; + int map_num; + struct icbmap *maps; +}; + +typedef enum { + PartitionCache, RootICBCache, LBUDFCache, MapCache, AVDPCache, PVDCache +} UDFCacheType; + +extern void *GetUDFCacheHandle(dvd_reader_t *device); +extern void SetUDFCacheHandle(dvd_reader_t *device, void *cache); + + +void FreeUDFCache(dvd_reader_t *device, void *cache) +{ + int n; + + struct udf_cache *c = (struct udf_cache *)cache; + if(c == NULL) { + return; + } + + for(n = 0; n < c->lb_num; n++) { + if(c->lbs[n].data) { + /* free data */ + dvdalign_lbfree(device, c->lbs[n].data); + } + } + c->lb_num = 0; + + if(c->lbs) { + free(c->lbs); + } + if(c->maps) { + free(c->maps); + } + free(c); +} + + +static int GetUDFCache(dvd_reader_t *device, UDFCacheType type, + uint32_t nr, void *data) +{ + int n; + struct udf_cache *c; + + if(DVDUDFCacheLevel(device, -1) <= 0) { + return 0; + } + + c = (struct udf_cache *)GetUDFCacheHandle(device); + + if(c == NULL) { + return 0; + } + + switch(type) { + case AVDPCache: + if(c->avdp_valid) { + *(struct avdp_t *)data = c->avdp; + return 1; + } + break; + case PVDCache: + if(c->pvd_valid) { + *(struct pvd_t *)data = c->pvd; + return 1; + } + break; + case PartitionCache: + if(c->partition_valid) { + *(struct Partition *)data = c->partition; + return 1; + } + break; + case RootICBCache: + if(c->rooticb_valid) { + *(struct AD *)data = c->rooticb; + return 1; + } + break; + case LBUDFCache: + for(n = 0; n < c->lb_num; n++) { + if(c->lbs[n].lb == nr) { + *(uint8_t **)data = c->lbs[n].data; + return 1; + } + } + break; + case MapCache: + for(n = 0; n < c->map_num; n++) { + if(c->maps[n].lbn == nr) { + *(struct icbmap *)data = c->maps[n]; + return 1; + } + } + break; + default: + break; + } + + return 0; +} + +static int SetUDFCache(dvd_reader_t *device, UDFCacheType type, + uint32_t nr, void *data) +{ + int n; + struct udf_cache *c; + + if(DVDUDFCacheLevel(device, -1) <= 0) { + return 0; + } + + c = (struct udf_cache *)GetUDFCacheHandle(device); + + if(c == NULL) { + c = calloc(1, sizeof(struct udf_cache)); + /* fprintf(stderr, "calloc: %d\n", sizeof(struct udf_cache)); */ + if(c == NULL) { + return 0; + } + SetUDFCacheHandle(device, c); + } + + + switch(type) { + case AVDPCache: + c->avdp = *(struct avdp_t *)data; + c->avdp_valid = 1; + break; + case PVDCache: + c->pvd = *(struct pvd_t *)data; + c->pvd_valid = 1; + break; + case PartitionCache: + c->partition = *(struct Partition *)data; + c->partition_valid = 1; + break; + case RootICBCache: + c->rooticb = *(struct AD *)data; + c->rooticb_valid = 1; + break; + case LBUDFCache: + for(n = 0; n < c->lb_num; n++) { + if(c->lbs[n].lb == nr) { + /* replace with new data */ + c->lbs[n].data = *(uint8_t **)data; + c->lbs[n].lb = nr; + return 1; + } + } + c->lb_num++; + c->lbs = realloc(c->lbs, c->lb_num * sizeof(struct lbudf)); + /* + fprintf(stderr, "realloc lb: %d * %d = %d\n", + c->lb_num, sizeof(struct lbudf), + c->lb_num * sizeof(struct lbudf)); + */ + if(c->lbs == NULL) { + c->lb_num = 0; + return 0; + } + c->lbs[n].data = *(uint8_t **)data; + c->lbs[n].lb = nr; + break; + case MapCache: + for(n = 0; n < c->map_num; n++) { + if(c->maps[n].lbn == nr) { + /* replace with new data */ + c->maps[n] = *(struct icbmap *)data; + c->maps[n].lbn = nr; + return 1; + } + } + c->map_num++; + c->maps = realloc(c->maps, c->map_num * sizeof(struct icbmap)); + /* + fprintf(stderr, "realloc maps: %d * %d = %d\n", + c->map_num, sizeof(struct icbmap), + c->map_num * sizeof(struct icbmap)); + */ + if(c->maps == NULL) { + c->map_num = 0; + return 0; + } + c->maps[n] = *(struct icbmap *)data; + c->maps[n].lbn = nr; + break; + default: + return 0; + } + + return 1; +} + + +/* For direct data access, LSB first */ +#define GETN1(p) ((uint8_t)data[p]) +#define GETN2(p) ((uint16_t)data[p] | ((uint16_t)data[(p) + 1] << 8)) +#define GETN3(p) ((uint32_t)data[p] | ((uint32_t)data[(p) + 1] << 8) \ + | ((uint32_t)data[(p) + 2] << 16)) +#define GETN4(p) ((uint32_t)data[p] \ + | ((uint32_t)data[(p) + 1] << 8) \ + | ((uint32_t)data[(p) + 2] << 16) \ + | ((uint32_t)data[(p) + 3] << 24)) +/* This is wrong with regard to endianess */ +#define GETN(p, n, target) memcpy(target, &data[p], n) + +static int Unicodedecode( uint8_t *data, int len, char *target ) +{ + int p = 1, i = 0; + + if( ( data[ 0 ] == 8 ) || ( data[ 0 ] == 16 ) ) do { + if( data[ 0 ] == 16 ) p++; /* Ignore MSB of unicode16 */ + if( p < len ) { + target[ i++ ] = data[ p++ ]; + } + } while( p < len ); + + target[ i ] = '\0'; + return 0; +} + +static int UDFDescriptor( uint8_t *data, uint16_t *TagID ) +{ + *TagID = GETN2(0); + return 0; +} + +static int UDFExtentAD( uint8_t *data, uint32_t *Length, uint32_t *Location ) +{ + *Length = GETN4(0); + *Location = GETN4(4); + return 0; +} + +static int UDFShortAD( uint8_t *data, struct AD *ad, + struct Partition *partition ) +{ + ad->Length = GETN4(0); + ad->Flags = ad->Length >> 30; + ad->Length &= 0x3FFFFFFF; + ad->Location = GETN4(4); + ad->Partition = partition->Number; /* use number of current partition*/ + return 0; +} + +static int UDFLongAD( uint8_t *data, struct AD *ad ) +{ + ad->Length = GETN4(0); + ad->Flags = ad->Length >> 30; + ad->Length &= 0x3FFFFFFF; + ad->Location = GETN4(4); + ad->Partition = GETN2(8); + /*GETN(10, 6, Use);*/ + return 0; +} + +static int UDFExtAD( uint8_t *data, struct AD *ad ) +{ + ad->Length = GETN4(0); + ad->Flags = ad->Length >> 30; + ad->Length &= 0x3FFFFFFF; + ad->Location = GETN4(12); + ad->Partition = GETN2(16); + /*GETN(10, 6, Use);*/ + return 0; +} + +static int UDFICB( uint8_t *data, uint8_t *FileType, uint16_t *Flags ) +{ + *FileType = GETN1(11); + *Flags = GETN2(18); + return 0; +} + + +static int UDFPartition( uint8_t *data, uint16_t *Flags, uint16_t *Number, + char *Contents, uint32_t *Start, uint32_t *Length ) +{ + *Flags = GETN2(20); + *Number = GETN2(22); + GETN(24, 32, Contents); + *Start = GETN4(188); + *Length = GETN4(192); + return 0; +} + +/** + * Reads the volume descriptor and checks the parameters. Returns 0 on OK, 1 + * on error. + */ +static int UDFLogVolume( uint8_t *data, char *VolumeDescriptor ) +{ + uint32_t lbsize, MT_L, N_PM; + Unicodedecode(&data[84], 128, VolumeDescriptor); + lbsize = GETN4(212); /* should be 2048*/ + MT_L = GETN4(264); /* should be 6 */ + N_PM = GETN4(268); /* should be 1 */ + if (lbsize != DVD_VIDEO_LB_LEN) return 1; + return 0; +} + +static int UDFFileEntry( uint8_t *data, uint8_t *FileType, + struct Partition *partition, struct AD *ad ) +{ + uint16_t flags; + uint32_t L_EA, L_AD; + unsigned int p; + + UDFICB( &data[ 16 ], FileType, &flags ); + + /* Init ad for an empty file (i.e. there isn't a AD, L_AD == 0 ) */ + ad->Length = GETN4( 60 ); /* Really 8 bytes a 56*/ + ad->Flags = 0; + ad->Location = 0; /* what should we put here? */ + ad->Partition = partition->Number; /* use number of current partition*/ + + L_EA = GETN4( 168 ); + L_AD = GETN4( 172 ); + p = 176 + L_EA; + while( p < 176 + L_EA + L_AD ) { + switch( flags & 0x0007 ) { + case 0: UDFShortAD( &data[ p ], ad, partition ); p += 8; break; + case 1: UDFLongAD( &data[ p ], ad ); p += 16; break; + case 2: UDFExtAD( &data[ p ], ad ); p += 20; break; + case 3: + switch( L_AD ) { + case 8: UDFShortAD( &data[ p ], ad, partition ); break; + case 16: UDFLongAD( &data[ p ], ad ); break; + case 20: UDFExtAD( &data[ p ], ad ); break; + } + p += L_AD; + break; + default: + p += L_AD; break; + } + } + return 0; +} + +static int UDFFileIdentifier( uint8_t *data, uint8_t *FileCharacteristics, + char *FileName, struct AD *FileICB ) +{ + uint8_t L_FI; + uint16_t L_IU; + + *FileCharacteristics = GETN1(18); + L_FI = GETN1(19); + UDFLongAD(&data[20], FileICB); + L_IU = GETN2(36); + if (L_FI) Unicodedecode(&data[38 + L_IU], L_FI, FileName); + else FileName[0] = '\0'; + return 4 * ((38 + L_FI + L_IU + 3) / 4); +} + +/** + * Maps ICB to FileAD + * ICB: Location of ICB of directory to scan + * FileType: Type of the file + * File: Location of file the ICB is pointing to + * return 1 on success, 0 on error; + */ +static int UDFMapICB( dvd_reader_t *device, struct AD ICB, uint8_t *FileType, + struct Partition *partition, struct AD *File ) +{ + uint8_t *LogBlock; + uint32_t lbnum; + uint16_t TagID; + struct icbmap tmpmap; + + lbnum = partition->Start + ICB.Location; + tmpmap.lbn = lbnum; + if(GetUDFCache(device, MapCache, lbnum, &tmpmap)) { + *FileType = tmpmap.filetype; + *File = tmpmap.file; + return 1; + } + + LogBlock = dvdalign_lbmalloc(device, 1); + if(!LogBlock) { + return 0; + } + + do { + if( DVDReadLBUDF( device, lbnum++, 1, LogBlock, 0 ) <= 0 ) { + TagID = 0; + } else { + UDFDescriptor( LogBlock, &TagID ); + } + + if( TagID == 261 ) { + UDFFileEntry( LogBlock, FileType, partition, File ); + tmpmap.file = *File; + tmpmap.filetype = *FileType; + SetUDFCache(device, MapCache, tmpmap.lbn, &tmpmap); + dvdalign_lbfree(device, LogBlock); + return 1; + }; + } while( ( lbnum <= partition->Start + ICB.Location + ( ICB.Length - 1 ) + / DVD_VIDEO_LB_LEN ) && ( TagID != 261 ) ); + + dvdalign_lbfree(device, LogBlock); + return 0; +} + +/** + * Dir: Location of directory to scan + * FileName: Name of file to look for + * FileICB: Location of ICB of the found file + * return 1 on success, 0 on error; + */ +static int UDFScanDir( dvd_reader_t *device, struct AD Dir, char *FileName, + struct Partition *partition, struct AD *FileICB, + int cache_file_info) +{ + char filename[ MAX_UDF_FILE_NAME_LEN ]; + uint8_t *directory; + uint32_t lbnum; + uint16_t TagID; + uint8_t filechar; + unsigned int p; + uint8_t *cached_dir = NULL; + uint32_t dir_lba; + struct AD tmpICB; + int found = 0; + int in_cache = 0; + + /* Scan dir for ICB of file */ + lbnum = partition->Start + Dir.Location; + + if(DVDUDFCacheLevel(device, -1) > 0) { + /* caching */ + + if(!GetUDFCache(device, LBUDFCache, lbnum, &cached_dir)) { + dir_lba = (Dir.Length + DVD_VIDEO_LB_LEN) / DVD_VIDEO_LB_LEN; + if((cached_dir = dvdalign_lbmalloc(device, dir_lba)) == NULL) { + return 0; + } + if( DVDReadLBUDF( device, lbnum, dir_lba, cached_dir, 0) <= 0 ) { + dvdalign_lbfree(device, cached_dir); + cached_dir = NULL; + } + SetUDFCache(device, LBUDFCache, lbnum, &cached_dir); + } else { + in_cache = 1; + } + + if(cached_dir == NULL) { + return 0; + } + + p = 0; + + while( p < Dir.Length ) { + UDFDescriptor( &cached_dir[ p ], &TagID ); + if( TagID == 257 ) { + p += UDFFileIdentifier( &cached_dir[ p ], &filechar, + filename, &tmpICB ); + if(cache_file_info && !in_cache) { + uint8_t tmpFiletype; + struct AD tmpFile; + + if( !strcasecmp( FileName, filename ) ) { + *FileICB = tmpICB; + found = 1; + + } + UDFMapICB(device, tmpICB, &tmpFiletype, + partition, &tmpFile); + } else { + if( !strcasecmp( FileName, filename ) ) { + *FileICB = tmpICB; + return 1; + } + } + } else { + if(cache_file_info && (!in_cache) && found) { + return 1; + } + return 0; + } + } + if(cache_file_info && (!in_cache) && found) { + return 1; + } + return 0; + } + + directory = dvdalign_lbmalloc(device, 2); + if(!directory) { + return 0; + } + if( DVDReadLBUDF( device, lbnum, 2, directory, 0 ) <= 0 ) { + dvdalign_lbfree(device, directory); + return 0; + } + + p = 0; + while( p < Dir.Length ) { + if( p > DVD_VIDEO_LB_LEN ) { + ++lbnum; + p -= DVD_VIDEO_LB_LEN; + Dir.Length -= DVD_VIDEO_LB_LEN; + if( DVDReadLBUDF( device, lbnum, 2, directory, 0 ) <= 0 ) { + dvdalign_lbfree(device, directory); + return 0; + } + } + UDFDescriptor( &directory[ p ], &TagID ); + if( TagID == 257 ) { + p += UDFFileIdentifier( &directory[ p ], &filechar, + filename, FileICB ); + if( !strcasecmp( FileName, filename ) ) { + dvdalign_lbfree(device, directory); + return 1; + } + } else { + dvdalign_lbfree(device, directory); + return 0; + } + } + + dvdalign_lbfree(device, directory); + return 0; +} + + +static int UDFGetAVDP( dvd_reader_t *device, + struct avdp_t *avdp) +{ + uint8_t *Anchor; + uint32_t lbnum, MVDS_location, MVDS_length; + uint16_t TagID; + uint32_t lastsector; + int terminate; + struct avdp_t; + + if(GetUDFCache(device, AVDPCache, 0, avdp)) { + return 1; + } + + /* Find Anchor */ + lastsector = 0; + lbnum = 256; /* Try #1, prime anchor */ + terminate = 0; + + Anchor = dvdalign_lbmalloc(device, 1); + if(!Anchor) { + return 0; + } + for(;;) { + if( DVDReadLBUDF( device, lbnum, 1, Anchor, 0 ) > 0 ) { + UDFDescriptor( Anchor, &TagID ); + } else { + TagID = 0; + } + if (TagID != 2) { + /* Not an anchor */ + if( terminate ) { + dvdalign_lbfree(device, Anchor); + errno = EMEDIUMTYPE; + return 0; /* Final try failed */ + } + + if( lastsector ) { + /* We already found the last sector. Try #3, alternative + * backup anchor. If that fails, don't try again. + */ + lbnum = lastsector; + terminate = 1; + } else { + /* TODO: Find last sector of the disc (this is optional). */ + if( lastsector ) { + /* Try #2, backup anchor */ + lbnum = lastsector - 256; + } else { + /* Unable to find last sector */ + dvdalign_lbfree(device, Anchor); + errno = EMEDIUMTYPE; + return 0; + } + } + } else { + /* It's an anchor! We can leave */ + break; + } + } + /* Main volume descriptor */ + UDFExtentAD( &Anchor[ 16 ], &MVDS_length, &MVDS_location ); + avdp->mvds.location = MVDS_location; + avdp->mvds.length = MVDS_length; + + /* Backup volume descriptor */ + UDFExtentAD( &Anchor[ 24 ], &MVDS_length, &MVDS_location ); + avdp->rvds.location = MVDS_location; + avdp->rvds.length = MVDS_length; + + SetUDFCache(device, AVDPCache, 0, avdp); + + dvdalign_lbfree(device, Anchor); + return 1; +} + +/** + * Looks for partition on the disc. Returns 1 if partition found, 0 on error. + * partnum: Number of the partition, starting at 0. + * part: structure to fill with the partition information + */ +static int UDFFindPartition( dvd_reader_t *device, int partnum, + struct Partition *part ) +{ + uint8_t *LogBlock; + uint32_t lbnum, MVDS_location, MVDS_length; + uint16_t TagID; + int i, volvalid; + struct avdp_t avdp; + + + if(!UDFGetAVDP(device, &avdp)) { + return 0; + } + + LogBlock = dvdalign_lbmalloc(device, 1); + if(!LogBlock) { + return 0; + } + /* Main volume descriptor */ + MVDS_location = avdp.mvds.location; + MVDS_length = avdp.mvds.length; + + part->valid = 0; + volvalid = 0; + part->VolumeDesc[ 0 ] = '\0'; + i = 1; + do { + /* Find Volume Descriptor */ + lbnum = MVDS_location; + do { + + if( DVDReadLBUDF( device, lbnum++, 1, LogBlock, 0 ) <= 0 ) { + TagID = 0; + } else { + UDFDescriptor( LogBlock, &TagID ); + } + + if( ( TagID == 5 ) && ( !part->valid ) ) { + /* Partition Descriptor */ + UDFPartition( LogBlock, &part->Flags, &part->Number, + part->Contents, &part->Start, &part->Length ); + part->valid = ( partnum == part->Number ); + } else if( ( TagID == 6 ) && ( !volvalid ) ) { + /* Logical Volume Descriptor */ + if( UDFLogVolume( LogBlock, part->VolumeDesc ) ) { + /* TODO: sector size wrong! */ + } else { + volvalid = 1; + } + } + + } while( ( lbnum <= MVDS_location + ( MVDS_length - 1 ) + / DVD_VIDEO_LB_LEN ) && ( TagID != 8 ) + && ( ( !part->valid ) || ( !volvalid ) ) ); + + if( ( !part->valid) || ( !volvalid ) ) { + /* Backup volume descriptor */ + MVDS_location = avdp.mvds.location; + MVDS_length = avdp.mvds.length; + } + } while( i-- && ( ( !part->valid ) || ( !volvalid ) ) ); + + dvdalign_lbfree(device, LogBlock); + /* We only care for the partition, not the volume */ + return part->valid; +} + +uint32_t UDFFindFile( dvd_reader_t *device, char *filename, + uint32_t *filesize ) +{ + uint8_t *LogBlock; + uint32_t lbnum; + uint16_t TagID; + struct Partition partition; + struct AD RootICB, File, ICB; + char tokenline[ MAX_UDF_FILE_NAME_LEN ]; + char *token; + uint8_t filetype; + + if(filesize) { + *filesize = 0; + } + tokenline[0] = '\0'; + strcat( tokenline, filename ); + + + if(!(GetUDFCache(device, PartitionCache, 0, &partition) && + GetUDFCache(device, RootICBCache, 0, &RootICB))) { + /* Find partition, 0 is the standard location for DVD Video.*/ + if( !UDFFindPartition( device, 0, &partition ) ) { + return 0; + } + SetUDFCache(device, PartitionCache, 0, &partition); + + LogBlock = dvdalign_lbmalloc(device, 1); + if(!LogBlock) { + return 0; + } + /* Find root dir ICB */ + lbnum = partition.Start; + do { + if( DVDReadLBUDF( device, lbnum++, 1, LogBlock, 0 ) <= 0 ) { + TagID = 0; + } else { + UDFDescriptor( LogBlock, &TagID ); + } + + /* File Set Descriptor */ + if( TagID == 256 ) { /* File Set Descriptor*/ + UDFLongAD( &LogBlock[ 400 ], &RootICB ); + } + } while( ( lbnum < partition.Start + partition.Length ) + && ( TagID != 8 ) && ( TagID != 256 ) ); + + dvdalign_lbfree(device, LogBlock); + + /* Sanity checks. */ + if( TagID != 256 ) { + return 0; + } + if( RootICB.Partition != 0 ) { + return 0; + } + SetUDFCache(device, RootICBCache, 0, &RootICB); + } + + /* Find root dir */ + if( !UDFMapICB( device, RootICB, &filetype, &partition, &File ) ) { + return 0; + } + if( filetype != 4 ) { + return 0; /* Root dir should be dir */ + } + { + int cache_file_info = 0; + /* Tokenize filepath */ + token = strtok(tokenline, "/"); + + while( token != NULL ) { + + if( !UDFScanDir( device, File, token, &partition, &ICB, + cache_file_info)) { + return 0; + } + if( !UDFMapICB( device, ICB, &filetype, &partition, &File ) ) { + return 0; + } + if(!strcmp(token, "VIDEO_TS")) { + cache_file_info = 1; + } + token = strtok( NULL, "/" ); + } + } + + /* Sanity check. */ + if( File.Partition != 0 ) { + return 0; + } + + if(filesize) { + *filesize = File.Length; + } + /* Hack to not return partition.Start for empty files. */ + if( !File.Location ) { + return 0; + } else { + return partition.Start + File.Location; + } +} + + + +/** + * Gets a Descriptor . + * Returns 1 if descriptor found, 0 on error. + * id, tagid of descriptor + * bufsize, size of BlockBuf (must be >= DVD_VIDEO_LB_LEN) + * and aligned for raw/O_DIRECT read. + */ +static int UDFGetDescriptor( dvd_reader_t *device, int id, + uint8_t *descriptor, int bufsize) +{ + uint32_t lbnum, MVDS_location, MVDS_length; + struct avdp_t avdp; + uint16_t TagID; + uint32_t lastsector; + int i, terminate; + int desc_found = 0; + /* Find Anchor */ + lastsector = 0; + lbnum = 256; /* Try #1, prime anchor */ + terminate = 0; + if(bufsize < DVD_VIDEO_LB_LEN) { + return 0; + } + + if(!UDFGetAVDP(device, &avdp)) { + return 0; + } + + /* Main volume descriptor */ + MVDS_location = avdp.mvds.location; + MVDS_length = avdp.mvds.length; + + i = 1; + do { + /* Find Descriptor */ + lbnum = MVDS_location; + do { + + if( DVDReadLBUDF( device, lbnum++, 1, descriptor, 0 ) <= 0 ) { + TagID = 0; + } else { + UDFDescriptor( descriptor, &TagID ); + } + + if( (TagID == id) && ( !desc_found ) ) { + /* Descriptor */ + desc_found = 1; + } + } while( ( lbnum <= MVDS_location + ( MVDS_length - 1 ) + / DVD_VIDEO_LB_LEN ) && ( TagID != 8 ) + && ( !desc_found) ); + + if( !desc_found ) { + /* Backup volume descriptor */ + MVDS_location = avdp.rvds.location; + MVDS_length = avdp.rvds.length; + } + } while( i-- && ( !desc_found ) ); + + + return desc_found; +} + + +static int UDFGetPVD(dvd_reader_t *device, struct pvd_t *pvd) +{ + uint8_t *pvd_buf; + + if(GetUDFCache(device, PVDCache, 0, pvd)) { + return 1; + } + + pvd_buf = dvdalign_lbmalloc(device, 1); + if(!pvd_buf) { + return 0; + } + if(!UDFGetDescriptor( device, 1, pvd_buf, 1*DVD_VIDEO_LB_LEN)) { + dvdalign_lbfree(device, pvd_buf); + return 0; + } + + memcpy(pvd->VolumeIdentifier, &pvd_buf[24], 32); + memcpy(pvd->VolumeSetIdentifier, &pvd_buf[72], 128); + SetUDFCache(device, PVDCache, 0, pvd); + + dvdalign_lbfree(device, pvd_buf); + + return 1; +} + +/** + * Gets the Volume Identifier string, in 8bit unicode (latin-1) + * volid, place to put the string + * volid_size, size of the buffer volid points to + * returns the size of buffer needed for all data + */ +int UDFGetVolumeIdentifier(dvd_reader_t *device, char *volid, + unsigned int volid_size) +{ + struct pvd_t pvd; + unsigned int volid_len; + + /* get primary volume descriptor */ + if(!UDFGetPVD(device, &pvd)) { + return 0; + } + + volid_len = pvd.VolumeIdentifier[31]; + if(volid_len > 31) { + /* this field is only 32 bytes something is wrong */ + volid_len = 31; + } + if(volid_size > volid_len) { + volid_size = volid_len; + } + Unicodedecode(pvd.VolumeIdentifier, volid_size, volid); + + return volid_len; +} + +/** + * Gets the Volume Set Identifier, as a 128-byte dstring (not decoded) + * WARNING This is not a null terminated string + * volsetid, place to put the data + * volsetid_size, size of the buffer volsetid points to + * the buffer should be >=128 bytes to store the whole volumesetidentifier + * returns the size of the available volsetid information (128) + * or 0 on error + */ +int UDFGetVolumeSetIdentifier(dvd_reader_t *device, uint8_t *volsetid, + unsigned int volsetid_size) +{ + struct pvd_t pvd; + + /* get primary volume descriptor */ + if(!UDFGetPVD(device, &pvd)) { + return 0; + } + + + if(volsetid_size > 128) { + volsetid_size = 128; + } + + memcpy(volsetid, pvd.VolumeSetIdentifier, volsetid_size); + + return 128; +} diff --git a/dvdread/dvd_udf.h b/dvdread/dvd_udf.h new file mode 100644 index 0000000..cf66ce4 --- /dev/null +++ b/dvdread/dvd_udf.h @@ -0,0 +1,66 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +#ifndef DVD_UDF_H_INCLUDED +#define DVD_UDF_H_INCLUDED + +/* + * This code is based on dvdudf by: + * Christian Wolff . + * + * Modifications by: + * Billy Biggs . + * Björn Englund . + * + * dvdudf: parse and read the UDF volume information of a DVD Video + * Copyright (C) 1999 Christian Wolff for convergence integrated media + * GmbH The author can be reached at scarabaeus@convergence.de, the + * project's page is at http://linuxtv.org/dvd/ + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or (at + * your option) any later version. + * + * This program is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA + * 02110-1301, USA. Or, point your browser to + * http://www.gnu.org/copyleft/gpl.html + */ + +#if defined(HAVE_INTTYPES_H) +#include +#elif defined(HAVE_STDINT_H) +#include +#endif + +#include "dvd_reader.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * Looks for a file on the UDF disc/imagefile and returns the block number + * where it begins, or 0 if it is not found. The filename should be an + * absolute pathname on the UDF filesystem, starting with '/'. For example, + * '/VIDEO_TS/VTS_01_1.IFO'. On success, filesize will be set to the size of + * the file in bytes. + * This implementation relies on that the file size is less than 2^32 + * A DVD file can at most be 2^30 (-2048 ?). + */ +uint32_t UDFFindFile( dvd_reader_t *device, char *filename, uint32_t *size ); + +void FreeUDFCache(dvd_reader_t *device, void *cache); +int UDFGetVolumeIdentifier(dvd_reader_t *device, + char *volid, unsigned int volid_size); +int UDFGetVolumeSetIdentifier(dvd_reader_t *device, + uint8_t *volsetid, unsigned int volsetid_size); +#ifdef __cplusplus +}; +#endif +#endif /* DVD_UDF_H_INCLUDED */ diff --git a/dvdread/dvdread_internal.h b/dvdread/dvdread_internal.h new file mode 100644 index 0000000..995d491 --- /dev/null +++ b/dvdread/dvdread_internal.h @@ -0,0 +1,18 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +#ifndef DVDREAD_INTERNAL_H +#define DVDREAD_INTERNAL_H + + +#define CHECK_VALUE(arg) \ + if(!(arg)) { \ + fprintf(stderr, "\n*** libdvdread: CHECK_VALUE failed in %s:%i ***" \ + "\n*** for %s ***\n\n", \ + __FILE__, __LINE__, # arg ); \ + } + + +int get_verbose(void); +int dvdread_verbose(dvd_reader_t *dvd); +dvd_reader_t *device_of_file(dvd_file_t *file); + +#endif /* DVDREAD_INTERNAL_H */ diff --git a/dvdread/ifo_read.c b/dvdread/ifo_read.c new file mode 100644 index 0000000..e58b913 --- /dev/null +++ b/dvdread/ifo_read.c @@ -0,0 +1,2181 @@ +/* -*- c-basic-offset: 2; indent-tabs-mode: nil -*- */ +/* + * Copyright (C) 2000, 2001, 2002, 2003 + * Bj�rn Englund , + * H�kan Hjort + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#include "config.h" + +#include +#include + +#if defined(HAVE_INTTYPES_H) +#include +#elif defined(HAVE_STDINT_H) +#include +#endif + +#include +#include + +#include "bswap.h" +#include "ifo_types.h" +#include "ifo_read.h" +#include "dvd_reader.h" +#include "dvdread_internal.h" + +#ifndef DVD_BLOCK_LEN +#define DVD_BLOCK_LEN 2048 +#endif + +#ifndef NDEBUG +#define CHECK_ZERO0(arg) \ + if(arg != 0) { \ + fprintf(stderr, "*** Zero check failed in %s:%i\n for %s = 0x%x\n", \ + __FILE__, __LINE__, # arg, arg); \ + } +#define CHECK_ZERO(arg) \ + if(memcmp(my_friendly_zeros, &arg, sizeof(arg))) { \ + unsigned int i_CZ; \ + fprintf(stderr, "*** Zero check failed in %s:%i\n for %s = 0x", \ + __FILE__, __LINE__, # arg ); \ + for(i_CZ = 0; i_CZ < sizeof(arg); i_CZ++) \ + fprintf(stderr, "%02x", *((uint8_t *)&arg + i_CZ)); \ + fprintf(stderr, "\n"); \ + } +static const uint8_t my_friendly_zeros[2048]; +#else +#define CHECK_ZERO0(arg) (void)(arg) +#define CHECK_ZERO(arg) (void)(arg) +#endif + + +/* Prototypes for internal functions */ +static int ifoRead_VMG(ifo_handle_t *ifofile); +static int ifoRead_VTS(ifo_handle_t *ifofile); +static int ifoRead_PGC(ifo_handle_t *ifofile, pgc_t *pgc, unsigned int offset); +static int ifoRead_PGC_COMMAND_TBL(ifo_handle_t *ifofile, + pgc_command_tbl_t *cmd_tbl, + unsigned int offset); +static int ifoRead_PGC_PROGRAM_MAP(ifo_handle_t *ifofile, + pgc_program_map_t *program_map, + unsigned int nr, unsigned int offset); +static int ifoRead_CELL_PLAYBACK_TBL(ifo_handle_t *ifofile, + cell_playback_t *cell_playback, + unsigned int nr, unsigned int offset); +static int ifoRead_CELL_POSITION_TBL(ifo_handle_t *ifofile, + cell_position_t *cell_position, + unsigned int nr, unsigned int offset); +static int ifoRead_VTS_ATTRIBUTES(ifo_handle_t *ifofile, + vts_attributes_t *vts_attributes, + unsigned int offset); +static int ifoRead_C_ADT_internal(ifo_handle_t *ifofile, c_adt_t *c_adt, + unsigned int sector); +static int ifoRead_VOBU_ADMAP_internal(ifo_handle_t *ifofile, + vobu_admap_t *vobu_admap, + unsigned int sector); +static int ifoRead_PGCIT_internal(ifo_handle_t *ifofile, pgcit_t *pgcit, + unsigned