summaryrefslogtreecommitdiff
path: root/packages/extra/sdl/sdl_sound.pas
diff options
context:
space:
mode:
authorpeter <peter@3ad0048d-3df7-0310-abae-a5850022a9f2>2008-02-02 15:48:09 +0000
committerpeter <peter@3ad0048d-3df7-0310-abae-a5850022a9f2>2008-02-02 15:48:09 +0000
commitc8845dfe5ca36797bebc57bcc37aae6a8e94444a (patch)
treea815946b5827956fef96fe9548e4a9c4d1e1b7d7 /packages/extra/sdl/sdl_sound.pas
parentd7617abfb24ee7c360c3d123e1e9b2b5cc800a5d (diff)
downloadfpc-c8845dfe5ca36797bebc57bcc37aae6a8e94444a.tar.gz
Merged revisions 9692,9694-9695,9697-9714,9720,9722,9729,9732-9733,9740,9745,9749-9750,9753-9757,9760-9766,9768-9770,9772-9774,9783,9786,9788,9814,9822,9825,9837-9850,9852,9855-9856,9863-9864,9867,9882,9891-9892,9897,9899-9900,9902-9904,9907-9911,9913,9915,9917,9920,9922-9937,9939-9974,9976-10005,10007-10012,10014-10046,10049-10051,10053-10067,10069-10071,10074,10079,10082,10084-10086,10091,10099-10100,10102-10103,10113-10114,10129-10130,10136 via svnmerge from
http://svn.freepascal.org/svn/fpc/trunk ........ r9783 | joost | 2008-01-18 23:52:13 +0100 (Fri, 18 Jan 2008) | 1 line * DigestTestREport makes it possible to write the unittest results to a testsuite-digest ........ r9786 | joost | 2008-01-19 00:40:44 +0100 (Sat, 19 Jan 2008) | 1 line * Added dependency on paszlib to fcl-fpcunit ........ r9788 | jonas | 2008-01-19 01:20:49 +0100 (Sat, 19 Jan 2008) | 2 lines + also add fpc-unit dependency on paszlib to build dependencies ........ r9882 | peter | 2008-01-23 18:04:40 +0100 (Wed, 23 Jan 2008) | 2 lines * shell/awk script to help creating fpmake.pp from existing ppu files ........ r9891 | peter | 2008-01-24 08:47:03 +0100 (Thu, 24 Jan 2008) | 2 lines * obsolete files ........ r9892 | peter | 2008-01-24 08:52:43 +0100 (Thu, 24 Jan 2008) | 2 lines * fpmake added ........ r9897 | peter | 2008-01-24 21:53:26 +0100 (Thu, 24 Jan 2008) | 2 lines * remove dos dependency ........ r9899 | peter | 2008-01-24 22:50:42 +0100 (Thu, 24 Jan 2008) | 2 lines * fpmake support ........ r9900 | peter | 2008-01-24 22:58:28 +0100 (Thu, 24 Jan 2008) | 2 lines * don't inlcude rtl unit depnedencies ........ r9902 | peter | 2008-01-24 23:08:59 +0100 (Thu, 24 Jan 2008) | 2 lines * fpmake added ........ r9903 | peter | 2008-01-24 23:57:37 +0100 (Thu, 24 Jan 2008) | 2 lines * new fpmake.pp ........ r9904 | peter | 2008-01-24 23:57:55 +0100 (Thu, 24 Jan 2008) | 2 lines * winunits-jedi deps ........ r9907 | peter | 2008-01-25 00:09:54 +0100 (Fri, 25 Jan 2008) | 3 lines * move pasjpeg * add fpmake.pp for pasjpeg ........ r9908 | peter | 2008-01-25 00:12:13 +0100 (Fri, 25 Jan 2008) | 2 lines * fpmake.pp ........ r9909 | peter | 2008-01-25 00:30:20 +0100 (Fri, 25 Jan 2008) | 4 lines * move uriparser to fcl-base * move netdb unit and examples to fcl-net * removed netdb package ........ r9910 | peter | 2008-01-25 00:35:30 +0100 (Fri, 25 Jan 2008) | 3 lines * mode objfpc added * remove old fpmake ........ r9911 | peter | 2008-01-25 00:37:32 +0100 (Fri, 25 Jan 2008) | 2 lines * new fpmake.pp ........ r9913 | peter | 2008-01-25 00:49:49 +0100 (Fri, 25 Jan 2008) | 2 lines * new fpmake.pp ........ r9915 | peter | 2008-01-25 00:59:57 +0100 (Fri, 25 Jan 2008) | 2 lines * build unit dependencies ........ r9917 | peter | 2008-01-25 01:16:33 +0100 (Fri, 25 Jan 2008) | 2 lines * new fpmake.pp ........ r9920 | peter | 2008-01-25 17:23:31 +0100 (Fri, 25 Jan 2008) | 2 lines * remove dependency on itself ........ r9922 | marco | 2008-01-26 14:08:46 +0100 (Sat, 26 Jan 2008) | 3 lines * Basic moving and updating of mysql. makefile.fpc's included, regened makefiles not. fpmake also in separate commit (will follow shortly) ........ r9923 | marco | 2008-01-26 14:12:04 +0100 (Sat, 26 Jan 2008) | 2 lines * regened makefiles for mysql move in separate commit to ease merging. ........ r9924 | marco | 2008-01-26 14:30:07 +0100 (Sat, 26 Jan 2008) | 2 lines * fpmake for mysql ........ r9925 | marco | 2008-01-26 14:53:13 +0100 (Sat, 26 Jan 2008) | 3 lines * Package ibase moved + makefile.fpc's. fpmake and regenned makefiles follow in separate commits ........ r9926 | marco | 2008-01-26 14:54:17 +0100 (Sat, 26 Jan 2008) | 2 lines * makefiles of ibase moving ........ r9927 | marco | 2008-01-26 14:54:47 +0100 (Sat, 26 Jan 2008) | 2 lines * Makefile mysql move was not committed, fixed ........ r9928 | marco | 2008-01-26 15:09:42 +0100 (Sat, 26 Jan 2008) | 2 lines * fpmake for ibase ........ r9929 | marco | 2008-01-26 15:34:28 +0100 (Sat, 26 Jan 2008) | 2 lines * removed exces files + mysql/readme move ........ r9930 | marco | 2008-01-26 15:51:36 +0100 (Sat, 26 Jan 2008) | 2 lines * ncurses moved. makefile.fpc + fpmake included, makefile in separate commit ........ r9931 | marco | 2008-01-26 16:04:58 +0100 (Sat, 26 Jan 2008) | 2 lines * Unzip moved ........ r9932 | marco | 2008-01-26 16:12:56 +0100 (Sat, 26 Jan 2008) | 2 lines * zlib moved ........ r9933 | marco | 2008-01-26 16:14:00 +0100 (Sat, 26 Jan 2008) | 2 lines * cleanup moved pkgs ........ r9934 | marco | 2008-01-26 16:28:25 +0100 (Sat, 26 Jan 2008) | 2 lines * oracle moved + makefile.fpc + fpmake ........ r9935 | marco | 2008-01-26 17:19:50 +0100 (Sat, 26 Jan 2008) | 2 lines * Dbus moved, incl everything ........ r9936 | marco | 2008-01-26 17:37:27 +0100 (Sat, 26 Jan 2008) | 2 lines * libc moved ........ r9937 | marco | 2008-01-26 17:38:26 +0100 (Sat, 26 Jan 2008) | 1 line * libc deleted ........ r9939 | marco | 2008-01-26 17:46:49 +0100 (Sat, 26 Jan 2008) | 2 lines * Moved odbc ........ r9940 | marco | 2008-01-26 17:47:05 +0100 (Sat, 26 Jan 2008) | 2 lines * removed ........ r9941 | marco | 2008-01-26 17:47:34 +0100 (Sat, 26 Jan 2008) | 2 lines * deleted ........ r9942 | peter | 2008-01-26 17:49:25 +0100 (Sat, 26 Jan 2008) | 2 lines * netdb is unix only ........ r9943 | marco | 2008-01-26 17:57:00 +0100 (Sat, 26 Jan 2008) | 2 lines * regexpr moved ........ r9944 | marco | 2008-01-26 17:57:23 +0100 (Sat, 26 Jan 2008) | 2 lines * delete ........ r9945 | marco | 2008-01-26 18:12:43 +0100 (Sat, 26 Jan 2008) | 2 lines * postgres and sqlite moved ........ r9946 | jonas | 2008-01-26 18:16:46 +0100 (Sat, 26 Jan 2008) | 4 lines + added missing Makefiles * regenerated packages/extra Makefile after several packages were moved ........ r9947 | marco | 2008-01-26 18:26:21 +0100 (Sat, 26 Jan 2008) | 2 lines * missing files added ........ r9948 | marco | 2008-01-26 18:45:32 +0100 (Sat, 26 Jan 2008) | 2 lines * pthreads moved ........ r9949 | marco | 2008-01-26 18:46:00 +0100 (Sat, 26 Jan 2008) | 2 lines * excess packages deleted ........ r9950 | marco | 2008-01-26 19:03:23 +0100 (Sat, 26 Jan 2008) | 2 lines * Imagemagick moved ........ r9951 | marco | 2008-01-26 19:18:09 +0100 (Sat, 26 Jan 2008) | 2 lines * gdbint moved ........ r9952 | marco | 2008-01-26 19:24:29 +0100 (Sat, 26 Jan 2008) | 2 lines * libpng moved for Florian ........ r9953 | marco | 2008-01-26 19:24:59 +0100 (Sat, 26 Jan 2008) | 2 lines * packages removed ........ r9954 | peter | 2008-01-26 19:26:35 +0100 (Sat, 26 Jan 2008) | 2 lines * move cgiapp and ezcgi to fcl-web ........ r9955 | peter | 2008-01-26 19:58:55 +0100 (Sat, 26 Jan 2008) | 2 lines * new fpmake.pp ........ r9956 | peter | 2008-01-26 20:15:13 +0100 (Sat, 26 Jan 2008) | 2 lines * add mode objfpc ........ r9957 | peter | 2008-01-26 20:18:39 +0100 (Sat, 26 Jan 2008) | 2 lines * add fpmake.pp ........ r9958 | peter | 2008-01-26 20:18:52 +0100 (Sat, 26 Jan 2008) | 2 lines * new fpmake.pp ........ r9959 | marco | 2008-01-26 20:34:39 +0100 (Sat, 26 Jan 2008) | 2 lines * os2 compilation fixed. didn't work because of outdated fpmkunit ........ r9960 | peter | 2008-01-26 20:42:50 +0100 (Sat, 26 Jan 2008) | 2 lines * top level packages building ........ r9961 | peter | 2008-01-26 20:46:02 +0100 (Sat, 26 Jan 2008) | 2 lines * add commandline how to generate the include lines ........ r9962 | marco | 2008-01-26 20:54:31 +0100 (Sat, 26 Jan 2008) | 2 lines * unixutil moved ........ r9963 | marco | 2008-01-26 21:02:30 +0100 (Sat, 26 Jan 2008) | 2 lines * X11 moved ........ r9964 | marco | 2008-01-26 21:11:31 +0100 (Sat, 26 Jan 2008) | 2 lines * uuid moved ........ r9965 | marco | 2008-01-26 21:12:36 +0100 (Sat, 26 Jan 2008) | 2 lines * removed rests of moved pkgs ........ r9966 | marco | 2008-01-26 21:17:35 +0100 (Sat, 26 Jan 2008) | 2 lines * ldap moved ........ r9967 | peter | 2008-01-26 21:20:09 +0100 (Sat, 26 Jan 2008) | 2 lines * create fpc-all package from all other packages ........ r9968 | marco | 2008-01-26 21:26:01 +0100 (Sat, 26 Jan 2008) | 2 lines * mad,modplug,dts ........ r9969 | marco | 2008-01-26 21:27:05 +0100 (Sat, 26 Jan 2008) | 2 lines * and delete 4 pkgs leftovers, ldap mad modplug dts ........ r9970 | marco | 2008-01-26 21:43:23 +0100 (Sat, 26 Jan 2008) | 2 lines * gdbm tcl syslog libcurl ........ r9971 | marco | 2008-01-26 21:44:11 +0100 (Sat, 26 Jan 2008) | 2 lines * gdbm libcurl tcl syslog removed from extra (leftover makefiles etc) ........ r9972 | peter | 2008-01-26 21:52:25 +0100 (Sat, 26 Jan 2008) | 2 lines * new fpmake.pp ........ r9973 | marco | 2008-01-26 21:55:34 +0100 (Sat, 26 Jan 2008) | 2 lines * opengl ........ r9974 | marco | 2008-01-26 22:00:05 +0100 (Sat, 26 Jan 2008) | 2 lines * opengl deleted ........ r9976 | marco | 2008-01-26 22:06:36 +0100 (Sat, 26 Jan 2008) | 2 lines * move whole dirs, delete possible conflicting files beforehand ........ r9977 | marco | 2008-01-26 22:07:16 +0100 (Sat, 26 Jan 2008) | 2 lines * more makefile ........ r9978 | marco | 2008-01-26 22:17:10 +0100 (Sat, 26 Jan 2008) | 2 lines * Moved gtk -> gtk1 first pass ........ r9979 | marco | 2008-01-26 22:18:35 +0100 (Sat, 26 Jan 2008) | 2 lines * gtkgl lost its own makefile in the change -> demo moved to examples ........ r9980 | marco | 2008-01-26 22:22:36 +0100 (Sat, 26 Jan 2008) | 2 lines * fpmake for gtk1 ........ r9981 | marco | 2008-01-26 22:32:36 +0100 (Sat, 26 Jan 2008) | 2 lines * Pass two, src/ creation ........ r9982 | marco | 2008-01-26 22:58:23 +0100 (Sat, 26 Jan 2008) | 2 lines * matroska moved ........ r9983 | marco | 2008-01-26 23:03:51 +0100 (Sat, 26 Jan 2008) | 2 lines * Cairo moved ........ r9984 | marco | 2008-01-26 23:06:01 +0100 (Sat, 26 Jan 2008) | 2 lines * toplevel makefiles updated ........ r9985 | marco | 2008-01-26 23:20:45 +0100 (Sat, 26 Jan 2008) | 2 lines * gtk2 first pass ........ r9986 | marco | 2008-01-26 23:23:03 +0100 (Sat, 26 Jan 2008) | 2 lines * one more file moved to gtk2 ........ r9987 | marco | 2008-01-26 23:28:06 +0100 (Sat, 26 Jan 2008) | 2 lines * chm moved ........ r9988 | marco | 2008-01-26 23:41:08 +0100 (Sat, 26 Jan 2008) | 2 lines * 4 pkgs a52 bfd aspell bzip2. Bzip2 didn't compile ........ r9989 | marco | 2008-01-26 23:44:42 +0100 (Sat, 26 Jan 2008) | 2 lines * 6 old pkgs deleted a52 bfd aspell bzip2 gtk2 chm ........ r9990 | marco | 2008-01-26 23:45:24 +0100 (Sat, 26 Jan 2008) | 2 lines * removed old dirs cairo extra pkg ........ r9991 | marco | 2008-01-26 23:45:46 +0100 (Sat, 26 Jan 2008) | 2 lines * delete matroska ........ r9992 | marco | 2008-01-26 23:47:18 +0100 (Sat, 26 Jan 2008) | 2 lines * delete old pkg gtk, is now gtk1 ........ r9993 | marco | 2008-01-26 23:51:58 +0100 (Sat, 26 Jan 2008) | 2 lines * makefiles somewhat regenned for chm-gtk2-a52-bfd-aspell-bzip2 pkgs ........ r9994 | marco | 2008-01-26 23:58:46 +0100 (Sat, 26 Jan 2008) | 2 lines * fpgtk first pass ........ r9995 | marco | 2008-01-27 00:00:46 +0100 (Sun, 27 Jan 2008) | 2 lines * examples moved ........ r9996 | marco | 2008-01-27 00:01:37 +0100 (Sun, 27 Jan 2008) | 1 line * stale dir moved ........ r9997 | marco | 2008-01-27 00:05:38 +0100 (Sun, 27 Jan 2008) | 2 lines * newt moved ........ r9998 | marco | 2008-01-27 00:06:56 +0100 (Sun, 27 Jan 2008) | 2 lines * cleanup after moving ........ r9999 | marco | 2008-01-27 00:11:25 +0100 (Sun, 27 Jan 2008) | 2 lines * imlib moved ........ r10000 | marco | 2008-01-27 00:11:45 +0100 (Sun, 27 Jan 2008) | 2 lines * old imlib remove ........ r10001 | marco | 2008-01-27 00:18:37 +0100 (Sun, 27 Jan 2008) | 2 lines * cdrom ........ r10002 | marco | 2008-01-27 00:20:18 +0100 (Sun, 27 Jan 2008) | 1 line * forgot one file ........ r10003 | marco | 2008-01-27 00:32:11 +0100 (Sun, 27 Jan 2008) | 1 line * hermes moved ........ r10004 | marco | 2008-01-27 00:32:49 +0100 (Sun, 27 Jan 2008) | 1 line * delete old hermes ........ r10005 | marco | 2008-01-27 00:36:53 +0100 (Sun, 27 Jan 2008) | 1 line * libgd moved ........ r10007 | marco | 2008-01-27 00:39:08 +0100 (Sun, 27 Jan 2008) | 2 lines * users first pass ........ r10008 | marco | 2008-01-27 00:46:10 +0100 (Sun, 27 Jan 2008) | 3 lines * Moved users pkg, added makefile.fpc, and made it in general somewhat compilable. Demo still fails due to crypt_h unit missing ........ r10009 | marco | 2008-01-27 00:46:31 +0100 (Sun, 27 Jan 2008) | 1 line * remove users ........ r10010 | marco | 2008-01-27 00:48:51 +0100 (Sun, 27 Jan 2008) | 2 lines * utmp moved ........ r10011 | marco | 2008-01-27 00:53:01 +0100 (Sun, 27 Jan 2008) | 1 line * moved svgalib ........ r10012 | marco | 2008-01-27 01:00:07 +0100 (Sun, 27 Jan 2008) | 2 lines * Makefiles regenned ........ r10014 | marco | 2008-01-27 10:39:14 +0100 (Sun, 27 Jan 2008) | 1 line * openal moved ........ r10015 | marco | 2008-01-27 10:51:30 +0100 (Sun, 27 Jan 2008) | 1 line * xforms moved ........ r10016 | marco | 2008-01-27 11:04:56 +0100 (Sun, 27 Jan 2008) | 1 line * fftw, minor updates to xforms ........ r10017 | marco | 2008-01-27 11:10:59 +0100 (Sun, 27 Jan 2008) | 1 line * numlib moved ........ r10018 | marco | 2008-01-27 11:13:37 +0100 (Sun, 27 Jan 2008) | 1 line * pcap moved ........ r10019 | marco | 2008-01-27 11:18:45 +0100 (Sun, 27 Jan 2008) | 1 line * rexx moved ........ r10020 | marco | 2008-01-27 11:22:08 +0100 (Sun, 27 Jan 2008) | 1 line * oggvorbis first pass ........ r10021 | marco | 2008-01-27 11:23:33 +0100 (Sun, 27 Jan 2008) | 1 line * oggvorbis move + cleanup ........ r10022 | marco | 2008-01-27 11:28:44 +0100 (Sun, 27 Jan 2008) | 1 line * ggi moved ........ r10023 | michael | 2008-01-27 11:32:11 +0100 (Sun, 27 Jan 2008) | 1 line * Added support for bitpacked ........ r10024 | marco | 2008-01-27 11:35:18 +0100 (Sun, 27 Jan 2008) | 1 line * sdl moved ........ r10025 | michael | 2008-01-27 11:39:07 +0100 (Sun, 27 Jan 2008) | 1 line * Save bitpacked also, not just register ........ r10026 | michael | 2008-01-27 11:40:41 +0100 (Sun, 27 Jan 2008) | 1 line * GetDeclaration reflects bitpacked ........ r10027 | marco | 2008-01-27 11:43:35 +0100 (Sun, 27 Jan 2008) | 1 line * sndfile ........ r10028 | marco | 2008-01-27 11:45:21 +0100 (Sun, 27 Jan 2008) | 1 line * removed dead utmp dir ........ r10029 | michael | 2008-01-27 11:48:45 +0100 (Sun, 27 Jan 2008) | 1 line * Support for bitpacked and removed stray debug writeln ........ r10030 | marco | 2008-01-27 11:49:05 +0100 (Sun, 27 Jan 2008) | 1 line * shellscript to print deps based on makefile.fpc requirement lines ........ r10031 | marco | 2008-01-27 11:52:27 +0100 (Sun, 27 Jan 2008) | 1 line * lua moved ........ r10032 | marco | 2008-01-27 11:56:35 +0100 (Sun, 27 Jan 2008) | 1 line * openssl moved ........ r10033 | marco | 2008-01-27 12:09:10 +0100 (Sun, 27 Jan 2008) | 1 line * makefiles regenned ........ r10034 | marco | 2008-01-27 12:15:57 +0100 (Sun, 27 Jan 2008) | 1 line * gbaunits moved ........ r10035 | marco | 2008-01-27 12:20:55 +0100 (Sun, 27 Jan 2008) | 1 line * palmunits moved ........ r10036 | marco | 2008-01-27 12:43:58 +0100 (Sun, 27 Jan 2008) | 1 line * graph moved ........ r10037 | marco | 2008-01-27 12:53:57 +0100 (Sun, 27 Jan 2008) | 1 line * os2units moved ........ r10038 | marco | 2008-01-27 13:00:36 +0100 (Sun, 27 Jan 2008) | 1 line * libndsfpc moved ........ r10039 | marco | 2008-01-27 13:01:35 +0100 (Sun, 27 Jan 2008) | 1 line * os2units leftovers removed ........ r10040 | marco | 2008-01-27 13:24:32 +0100 (Sun, 27 Jan 2008) | 1 line * gnome1 moved ........ r10041 | marco | 2008-01-27 13:32:52 +0100 (Sun, 27 Jan 2008) | 1 line * regened, mostly working again ........ r10042 | marco | 2008-01-27 13:43:51 +0100 (Sun, 27 Jan 2008) | 2 lines * dep fixed ........ r10043 | marco | 2008-01-27 14:16:04 +0100 (Sun, 27 Jan 2008) | 1 line * amunits moved ........ r10044 | marco | 2008-01-27 14:30:17 +0100 (Sun, 27 Jan 2008) | 1 line * moved univint ........ r10045 | marco | 2008-01-27 14:55:40 +0100 (Sun, 27 Jan 2008) | 1 line * makefiles updated. httpd removed from compilation pending full removal ........ r10046 | michael | 2008-01-27 15:03:14 +0100 (Sun, 27 Jan 2008) | 1 line * Initial implementation ........ r10049 | marco | 2008-01-27 15:28:09 +0100 (Sun, 27 Jan 2008) | 1 line * gdbint removed from some platforms for mischi ........ r10050 | marco | 2008-01-27 15:42:46 +0100 (Sun, 27 Jan 2008) | 1 line * moved ptc ........ r10051 | marco | 2008-01-27 15:56:21 +0100 (Sun, 27 Jan 2008) | 2 lines * added ........ r10053 | marco | 2008-01-27 16:14:51 +0100 (Sun, 27 Jan 2008) | 1 line * gnome dep on gtk ........ r10054 | marco | 2008-01-27 16:21:51 +0100 (Sun, 27 Jan 2008) | 1 line * gnome1 now also dep on imlib ........ r10055 | marco | 2008-01-27 16:29:42 +0100 (Sun, 27 Jan 2008) | 1 line * more Gnome fixes ........ r10056 | marco | 2008-01-27 16:50:12 +0100 (Sun, 27 Jan 2008) | 2 lines * Another gnome order fix ........ r10057 | marco | 2008-01-27 16:52:05 +0100 (Sun, 27 Jan 2008) | 1 line * extra/ removed + packages/makefile update ........ r10058 | marco | 2008-01-27 17:34:53 +0100 (Sun, 27 Jan 2008) | 1 line * apache example fixes before moving ........ r10059 | marco | 2008-01-27 17:50:36 +0100 (Sun, 27 Jan 2008) | 2 lines * ptrint for a longint(ptr) typecast ........ r10060 | jonas | 2008-01-27 18:10:54 +0100 (Sun, 27 Jan 2008) | 7 lines - don't compile sdl for darwin/ppc64 and darwin/x86_64 (it also wasn't in the past) * graph does not depend on sdl for go32v2 (sdl is not compiled for go32v2) * sdl does not depend on pthreads and x11 for non-unix * opengl does not depend on x11 for non-unix - removed duplicated opengl dependencies declaration ........ r10061 | marco | 2008-01-27 18:22:29 +0100 (Sun, 27 Jan 2008) | 1 line * httpd moved, splitted, decapitated and rejoined ........ r10062 | marco | 2008-01-27 18:32:37 +0100 (Sun, 27 Jan 2008) | 1 line * httpd22 now added to all platforms that had dep on base/httpd ........ r10063 | marco | 2008-01-27 18:32:57 +0100 (Sun, 27 Jan 2008) | 1 line * base removed ........ r10064 | marco | 2008-01-27 18:45:38 +0100 (Sun, 27 Jan 2008) | 1 line * initial version ........ r10065 | marco | 2008-01-27 18:47:47 +0100 (Sun, 27 Jan 2008) | 1 line * fpmake ........ r10066 | marco | 2008-01-27 18:59:57 +0100 (Sun, 27 Jan 2008) | 1 line * base removed makefile changes ........ r10067 | peter | 2008-01-27 19:04:11 +0100 (Sun, 27 Jan 2008) | 2 lines * missing src/ for gdbint build with gdbver found ........ r10069 | jonas | 2008-01-27 22:23:10 +0100 (Sun, 27 Jan 2008) | 2 lines * fixed go32v2 check for sdl ........ r10070 | peter | 2008-01-27 22:31:33 +0100 (Sun, 27 Jan 2008) | 2 lines * gtk1, gtk2 for windows fixed ........ r10071 | peter | 2008-01-27 22:33:51 +0100 (Sun, 27 Jan 2008) | 2 lines * fixed win32 build ........ r10074 | peter | 2008-01-27 23:10:55 +0100 (Sun, 27 Jan 2008) | 2 lines * updated includes ........ r10079 | peter | 2008-01-28 09:08:35 +0100 (Mon, 28 Jan 2008) | 2 lines * Makefiles added ........ r10084 | vincents | 2008-01-28 20:20:26 +0100 (Mon, 28 Jan 2008) | 1 line * fixed win64 compilation ........ r10085 | marco | 2008-01-28 20:41:24 +0100 (Mon, 28 Jan 2008) | 1 line * includepath added ........ r10086 | marco | 2008-01-28 21:04:31 +0100 (Mon, 28 Jan 2008) | 1 line * sw_word -> longint ........ r10091 | michael | 2008-01-28 22:13:19 +0100 (Mon, 28 Jan 2008) | 1 line * Set windows library name correct ........ r10099 | marco | 2008-01-29 21:18:17 +0100 (Tue, 29 Jan 2008) | 1 line * gtk1 now depends on opengl in toplevel makefile ........ r10100 | marco | 2008-01-29 21:27:09 +0100 (Tue, 29 Jan 2008) | 2 lines * fixed typo ........ r10102 | peter | 2008-01-29 22:13:20 +0100 (Tue, 29 Jan 2008) | 2 lines * fixed typo in r10100 ........ r10103 | peter | 2008-01-29 22:48:45 +0100 (Tue, 29 Jan 2008) | 2 lines * fixed fpcdir ........ r10113 | michael | 2008-01-30 10:07:12 +0100 (Wed, 30 Jan 2008) | 1 line * PXlib added ........ r10114 | michael | 2008-01-30 11:52:34 +0100 (Wed, 30 Jan 2008) | 1 line * Unixtype removed for non-unix ........ r10136 | yury | 2008-02-01 20:20:26 +0100 (Fri, 01 Feb 2008) | 1 line * Fixed packages compilation for wince. ........ git-svn-id: http://svn.freepascal.org/svn/fpc/branches/fixes_2_2@10151 3ad0048d-3df7-0310-abae-a5850022a9f2
Diffstat (limited to 'packages/extra/sdl/sdl_sound.pas')
-rw-r--r--packages/extra/sdl/sdl_sound.pas562
1 files changed, 0 insertions, 562 deletions
diff --git a/packages/extra/sdl/sdl_sound.pas b/packages/extra/sdl/sdl_sound.pas
deleted file mode 100644
index 7f6f6c7d38..0000000000
--- a/packages/extra/sdl/sdl_sound.pas
+++ /dev/null
@@ -1,562 +0,0 @@
-unit sdl_sound;
-{
- $Id: sdl_sound.pas,v 1.5 2004/12/23 23:38:40 savage Exp $
-
-}
-(*
- * SDL_sound -- An abstract sound format decoding API.
- * Copyright (C) 2001 Ryan C. Gordon.
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 2.1 of the License, or (at your option) any later version.
- *
- * This library 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- *)
-(**
- * @overview
- *
- * The basic gist of SDL_sound is that you use an SDL_RWops to get sound data
- * into this library, and SDL_sound will take that data, in one of several
- * popular formats, and decode it into raw waveform data in the format of
- * your choice. This gives you a nice abstraction for getting sound into your
- * game or application; just feed it to SDL_sound, and it will handle
- * decoding and converting, so you can just pass it to your SDL audio
- * callback (or whatever). Since it gets data from an SDL_RWops, you can get
- * the initial sound data from any number of sources: file, memory buffer,
- * network connection, etc.
- *
- * As the name implies, this library depends on SDL: Simple Directmedia Layer,
- * which is a powerful, free, and cross-platform multimedia library. It can
- * be found at http://www.libsdl.org/
- *
- * Support is in place or planned for the following sound formats:
- * - .WAV (Microsoft WAVfile RIFF data, internal.)
- * - .VOC (Creative Labs' Voice format, internal.)
- * - .MP3 (MPEG-1 Layer 3 support, via the SMPEG library.)
- * - .MID (MIDI music converted to Waveform data, internal.)
- * - .MOD (MOD files, via MikMod and ModPlug.)
- * - .OGG (Ogg files, via Ogg Vorbis libraries.)
- * - .SHN (Shorten files, internal.)
- * - .RAW (Raw sound data in any format, internal.)
- * - .AU (Sun's Audio format, internal.)
- * - .AIFF (Audio Interchange format, internal.)
- * - .FLAC (Lossless audio compression, via libFLAC.)
- *
- * (...and more to come...)
- *
- * Please see the file COPYING in the source's root directory.
- *
- * This file written by Ryan C. Gordon. (icculus@clutteredmind.org)
- *)
-{ April 03 2003 - DL : Added jedi-sdl.inc include file to support more }
-{ Pascal compilers. Initial support is now included }
-{ for GnuPascal, VirtualPascal, TMT and obviously }
-{ continue support for Delphi Kylix and FreePascal. }
-{ }
-{ May 03 2003 - DL : under instruction from David Mears AKA }
-{ Jason Siletto, I have added FPC Linux support. }
-{ }
-{
- $Log: sdl_sound.pas,v $
- Revision 1.5 2004/12/23 23:38:40 savage
- Applied Patches supplied by Michalis Kamburelis ( THANKS! ), for tidier code.
-
- Revision 1.4 2004/08/14 22:54:30 savage
- Updated so that Library name defines are correctly defined for MacOS X.
-
- Revision 1.3 2004/05/10 14:10:04 savage
- Initial MacOS X support. Fixed defines for MACOS ( Classic ) and DARWIN ( MacOS X ).
-
- Revision 1.2 2004/03/30 20:23:28 savage
- Tidied up use of UNIX compiler directive.
-
- Revision 1.1 2004/02/16 22:16:40 savage
- v1.0 changes
-
-
-}
-{******************************************************************************}
-
-{$I jedi-sdl.inc}
-
-interface
-
-uses
-{$IFDEF WIN32}
- Windows,
-{$ENDIF}
- sdl;
-
-const
-{$IFDEF WIN32}
- SDLSoundLibName = 'SDL_sound.dll';
-{$ENDIF}
-
-{$IFDEF UNIX}
-{$IFDEF DARWIN}
- SDLSoundLibName = 'libSDL_sound.dylib';
-{$ELSE}
- SDLSoundLibName = 'libSDL_sound.so';
-{$ENDIF}
-{$ENDIF}
-
-{$IFDEF MACOS}
- SDLSoundLibName = 'SDL_sound';
-{$ENDIF}
-
- SOUND_VER_MAJOR = 0;
-{$EXTERNALSYM SOUND_VER_MAJOR}
- SOUND_VER_MINOR = 1;
-{$EXTERNALSYM SOUND_VER_MINOR}
- SOUND_VER_PATCH = 5;
-{$EXTERNALSYM SOUND_VER_PATCH}
-
- (**
- * These are flags that are used in a Sound_Sample to show various states.
- *
- * To use: 'if (sample.flags and SOUND_SAMPLEFLAG_ERROR) begin dosomething; end;'
- *
- * @param SOUND_SAMPLEFLAG_NONE nil flag.
- * @param SOUND_SAMPLEFLAG_NEEDSEEK SDL_RWops must be able to seek.
- * @param SOUND_SAMPLEFLAG_EOF end of input stream.
- * @param SOUND_SAMPLEFLAG_ERROR unrecoverable error.
- * @param SOUND_SAMPLEFLAG_EAGAIN function would block, or temp error.
- *)
- SOUND_SAMPLEFLAG_NONE = 0;
-{$EXTERNALSYM SOUND_SAMPLEFLAG_NONE}
- (* these are set at sample creation time... *)
- SOUND_SAMPLEFLAG_NEEDSEEK = 1;
-{$EXTERNALSYM SOUND_SAMPLEFLAG_NEEDSEEK}
- (* these are set during decoding... *)
- SOUND_SAMPLEFLAG_EOF = 1 shl 29;
-{$EXTERNALSYM SOUND_SAMPLEFLAG_EOF}
- SOUND_SAMPLEFLAG_ERROR = 1 shl 30;
-{$EXTERNALSYM SOUND_SAMPLEFLAG_ERROR}
- SOUND_SAMPLEFLAG_EAGAIN = 1 shl 31;
-{$EXTERNALSYM SOUND_SAMPLEFLAG_EAGAIN}
-
- (**
- * These are the basics of a decoded sample's data type = recordure: data format
- * (see AUDIO_U8 and friends in SDL_audio.h), number of channels, and sample
- * rate. If you need more explanation than that, you should stop developing
- * sound code right now.
- *
- * @param format Equivalent of SDL_AudioSpec.format.
- * @param channels Number of sound channels. 1 = mono, 2 = stereo.
- * @param rate Sample rate; frequency of sample points per second (44100,
- * 22050, 8000, etc.)
- *)
-type
- TSound_SampleFlags = Integer;
-
- PSound_AudioInfo = ^Sound_AudioInfo;
- Sound_AudioInfo = record
- format: Uint16;
- channels: Uint8;
- rate: Uint32;
- end;
- TSound_AudioInfo = Sound_AudioInfo;
-{$EXTERNALSYM Sound_AudioInfo}
-
- (**
- * Each decoder sets up one of these type = records, which can be retrieved via
- * the Sound_AvailableDecoders function. EVERY FIELD IN THIS IS READ-ONLY.
- *
- * @param extensions File extensions, list ends with nil. Read it like this:
- * const : PChar *ext;
- * for (ext := info.extensions; *ext <> nil; ext++)
- * printf(' File extension \'%s\'', *ext);
- * @param description Human readable description of decoder.
- * @param author 'Name Of Author <email@emailhost.dom>'
- * @param url URL specific to this decoder.
- *)
- PSound_DecoderInfo = ^Sound_DecoderInfo;
- Sound_DecoderInfo = record
- extensions: PChar;
- description: PChar;
- author: PChar;
- url: PChar;
- end;
- TSound_DecoderInfo = Sound_DecoderInfo;
-{$EXTERNALSYM Sound_DecoderInfo}
-
- (**
- * The Sound_Sample type = recordure is the heart of SDL_sound. This holds
- * information about a source of sound data as it is being decoded.
- * EVERY FIELD IN THIS IS READ-ONLY. Please use the API functions to
- * change them.
- *
- * @param opaque Internal use only. Don't touch.
- * @param decoder Decoder used for this sample.
- * @param desired Desired audio format for conversion.
- * @param actual Actual audio format of sample.
- * @param buffer Decoded sound data lands in here.
- * @param buffer_size Current size of (buffer), in bytes (Uint8).
- * @param flags Flags relating to this sample.
- *)
- PSound_Sample = ^Sound_Sample;
- Sound_Sample = record
- opaque: Pointer;
- decoder: PSound_DecoderInfo;
- desired: Sound_AudioInfo;
- actual: Sound_AudioInfo;
- buffer: Pointer;
- buffer_size: Uint32;
- flags: TSound_SampleFlags;
- end;
- TSound_Sample = Sound_Sample;
-{$EXTERNALSYM Sound_Sample}
-
- (**
- * Just what it says: a major.minor.patch style version number...
- *
- * @param major The major version number.
- * @param minor The minor version number.
- * @param patch The patchlevel version number.
- *)
- PSound_Version = ^Sound_Version;
- Sound_Version = record
- major: integer;
- minor: integer;
- patch: integer;
- end;
- TSound_Version = Sound_Version;
-{$EXTERNALSYM Sound_Version}
-
- (* functions and macros... *)
-
-procedure SOUND_GETVERSION(var x: TSound_Version);
-
-(**
- * Get the version of SDL_sound that is linked against your program. If you
- * are using a shared library (DLL) version of SDL_sound, then it is possible
- * that it will be different than the version you compiled against.
- *
- * This is a real function; the macro SOUND_VERSION tells you what version
- * of SDL_sound you compiled against:
- *
- * Sound_Version compiled;
- * Sound_Version linked;
- *
- * SOUND_VERSION(@compiled);
- * Sound_GetLinkedVersion(@linked);
- * printf('We compiled against SDL_sound version %d.%d.%d ...',
- * compiled.major, compiled.minor, compiled.patch);
- * printf('But we linked against SDL_sound version %d.%d.%d.',
- * linked.major, linked.minor, linked.patch);
- *
- * This function may be called safely at any time, even before Sound_Init.
- *
- * @param ver Sound_Version type = recordure to fill with shared library's version.
- *)
-procedure Sound_GetLinkedVersion(ver: PSound_Version);
-cdecl; external {$IFDEF __GPC__}name 'Sound_GetLinkedVersion'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_GetLinkedVersion}
-
-(**
- * Initialize SDL_sound. This must be called before any other SDL_sound
- * function (except perhaps Sound_GetLinkedVersion). You should call
- * SDL_Init before calling this. Sound_Init will attempt to call
- * SDL_Init(SDL_INIT_AUDIO), just in . This is a safe behaviour, but it
- * may not configure SDL to your liking by itself.
- *
- * @returns nonzero on success, zero on error. Specifics of the
- * error can be gleaned from Sound_GetError.
- *)
-function Sound_Init: integer;
-cdecl; external {$IFDEF __GPC__}name 'Sound_Init'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_Init}
-
-(**
- * Shutdown SDL_sound. This closes any SDL_RWops that were being used as
- * sound sources, and frees any resources in use by SDL_sound.
- *
- * All Sound_Sample pointers you had prior to this call are INVALIDATED.
- *
- * Once successfully deinitialized, Sound_Init can be called again to
- * restart the subsystem. All default API states are restored at this
- * point.
- *
- * You should call this BEFORE SDL_Quit. This will NOT call SDL_Quit
- * for younot
- *
- * @returns nonzero on success, zero on error. Specifics of the error
- * can be gleaned from Sound_GetError. If failure, state of
- * SDL_sound is undefined, and probably badly screwed up.
- *)
-function Sound_Quit: integer;
-cdecl; external {$IFDEF __GPC__}name 'Sound_Quit'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_Quit}
-
-(**
- * Get a list of sound formats supported by this implementation of SDL_sound.
- * This is for informational purposes only. Note that the extension listed is
- * merely convention: if we list 'MP3', you can open an MPEG-1 Layer 3 audio
- * file with an extension of 'XYZ', if you like. The file extensions are
- * informational, and only required as a h : integer to choosing the correct
- * decoder, since the sound data may not be coming from a file at all, thanks
- * to the abstraction that an SDL_RWops provides.
- *
- * The result value is an array of pointers to Sound_DecoderInfo type = recordures,
- * with a nil entry to signify the end of the list:
- *
- * Sound_DecoderInfo **i;
- *
- * for (i := Sound_AvailableDecoders; *i <> nil; i++)
- * begin
- * printf('Supported sound format: : array[ 0..%s- 1 ] of , which is : array[ 0..%s- 1 ] of .',
- * i.extension, i.description);
- * // ...and other fields...
- * end;
- *
- * The return values are pointers to static internal memory, and should
- * be considered READ ONLY, and never freed.
- *
- * @returns READ ONLY nil-terminated array of READ ONLY type = recordures.
- *)
-function Sound_AvailableDecoders: PSound_DecoderInfo;
-cdecl; external {$IFDEF __GPC__}name 'Sound_AvailableDecoders'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_AvailableDecoders}
-
-(**
- * Get the last SDL_sound error message as a nil-terminated string.
- * This will be nil if there's been no error since the last call to this
- * function. The pointer returned by this call points to an internal buffer.
- * Each thread has a unique error state associated with it, but each time
- * a new error message is set, it will overwrite the previous one associated
- * with that thread. It is safe to call this function at anytime, even
- * before Sound_Init.
- *
- * @returns READ ONLY string of last error message.
- *)
-function Sound_GetError: PChar;
-cdecl; external {$IFDEF __GPC__}name 'Sound_GetError'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_GetError}
-
-(**
- * Clear the current error message, so the next call to Sound_GetError will
- * return nil.
- *)
-procedure Sound_ClearError;
-cdecl; external {$IFDEF __GPC__}name 'Sound_ClearError'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_ClearError}
-
-(**
- * Start decoding a new sound sample. The data is read via an SDL_RWops
- * type = recordure (see SDL_rwops.h in the SDL include directory), so it may be
- * coming from memory, disk, network stream, etc. The (ext) parameter is
- * merely a h : integer to determining the correct decoder; if you specify, for
- * example, 'mp3' for an extension, and one of the decoders lists that
- * as a handled extension, then that decoder is given first shot at trying
- * to claim the data for decoding. If none of the extensions match (or the
- * extension is nil), then every decoder examines the data to determine if
- * it can handle it, until one accepts it. In such a your SDL_RWops will
- * need to be capable of rewinding to the start of the stream.
- * If no decoders can handle the data, a nil value is returned, and a human
- * readable error message can be fetched from Sound_GetError.
- * Optionally, a desired audio format can be specified. If the incoming data
- * is in a different format, SDL_sound will convert it to the desired format
- * on the fly. Note that this can be an expensive operation, so it may be
- * wise to convert data before you need to play it back, if possible, or
- * make sure your data is initially in the format that you need it in.
- * If you don't want to convert the data, you can specify nil for a desired
- * format. The incoming format of the data, preconversion, can be found
- * in the Sound_Sample type = recordure.
- * Note that the raw sound data 'decoder' needs you to specify both the
- * extension 'RAW' and a 'desired' format, or it will refuse to handle
- * the data. This is to prevent it from catching all formats unsupported
- * by the other decoders.
- * Finally, specify an initial buffer size; this is the number of bytes that
- * will be allocated to store each read from the sound buffer. The more you
- * can safely allocate, the more decoding can be done in one block, but the
- * more resources you have to use up, and the longer each decoding call will
- * take. Note that different data formats require more or less space to
- * store. This buffer can be resized via Sound_SetBufferSize ...
- * The buffer size specified must be a multiple of the size of a single
- * sample point. So, if you want 16-bit, stereo samples, then your sample
- * po : integer size is (2 channels * 16 bits), or 32 bits per sample, which is four
- * bytes. In such a , you could specify 128 or 132 bytes for a buffer,
- * but not 129, 130, or 131 (although in reality, you'll want to specify a
- * MUCH larger buffer).
- * When you are done with this Sound_Sample pointer, you can dispose of it
- * via Sound_FreeSample.
- * You do not have to keep a reference to (rw) around. If this function
- * suceeds, it stores (rw) internally (and disposes of it during the call
- * to Sound_FreeSample). If this function fails, it will dispose of the
- * SDL_RWops for you.
- *
- * @param rw SDL_RWops with sound data.
- * @param ext File extension normally associated with a data format.
- * Can usually be nil.
- * @param desired Format to convert sound data into. Can usually be nil,
- * if you don't need conversion.
- * @returns Sound_Sample pointer, which is used as a handle to several other
- * SDL_sound APIs. nil on error. If error, use
- * Sound_GetError to see what went wrong.
- *)
-function Sound_NewSample(rw: PSDL_RWops; const ext: PChar;
- desired: PSound_AudioInfo; bufferSize: Uint32): PSound_Sample;
-cdecl; external {$IFDEF __GPC__}name 'Sound_NewSample'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_NewSample}
-
-(**
- * This is identical to Sound_NewSample, but it creates an SDL_RWops for you
- * from the file located in (filename). Note that (filename) is specified in
- * platform-dependent notation. ('C:\\music\\mysong.mp3' on windows, and
- * '/home/icculus/music/mysong.mp3' or whatever on Unix, etc.)
- * Sound_NewSample's 'ext' parameter is gleaned from the contents of
- * (filename).
- *
- * @param filename file containing sound data.
- * @param desired Format to convert sound data into. Can usually be nil,
- * if you don't need conversion.
- * @param bufferSize size, in bytes, of initial read buffer.
- * @returns Sound_Sample pointer, which is used as a handle to several other
- * SDL_sound APIs. nil on error. If error, use
- * Sound_GetError to see what went wrong.
- *)
-function Sound_NewSampleFromFile(const filename: PChar; desired:
- PSound_AudioInfo; bufferSize: Uint32): PSound_Sample;
-cdecl; external {$IFDEF __GPC__}name 'Sound_NewSampleFromFile'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_NewSampleFromFile}
-
-(**
- * Dispose of a Sound_Sample pointer that was returned from Sound_NewSample.
- * This will also close/dispose of the SDL_RWops that was used at creation
- * time, so there's no need to keep a reference to that around.
- * The Sound_Sample pointer is invalid after this call, and will almost
- * certainly result in a crash if you attempt to keep using it.
- *
- * @param sample The Sound_Sample to delete.
- *)
-procedure Sound_FreeSample(sample: PSound_Sample);
-cdecl; external {$IFDEF __GPC__}name 'Sound_FreeSample'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_FreeSample}
-
-(**
- * Change the current buffer size for a sample. If the buffer size could
- * be changed, then the sample.buffer and sample.buffer_size fields will
- * reflect that. If they could not be changed, then your original sample
- * state is preserved. If the buffer is shrinking, the data at the end of
- * buffer is truncated. If the buffer is growing, the contents of the new
- * space at the end is undefined until you decode more into it or initialize
- * it yourself.
- *
- * The buffer size specified must be a multiple of the size of a single
- * sample point. So, if you want 16-bit, stereo samples, then your sample
- * po : integer size is (2 channels * 16 bits), or 32 bits per sample, which is four
- * bytes. In such a , you could specify 128 or 132 bytes for a buffer,
- * but not 129, 130, or 131 (although in reality, you'll want to specify a
- * MUCH larger buffer).
- *
- * @param sample The Sound_Sample whose buffer to modify.
- * @param new_size The desired size, in bytes, of the new buffer.
- * @returns non-zero if buffer size changed, zero on failure.
- *)
-function Sound_SetBufferSize(sample: PSound_Sample; new_size: Uint32): integer;
-cdecl; external {$IFDEF __GPC__}name 'Sound_SetBufferSize'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_SetBufferSize}
-
-(**
- * Decode more of the sound data in a Sound_Sample. It will decode at most
- * sample.buffer_size bytes into sample.buffer in the desired format, and
- * return the number of decoded bytes.
- * If sample.buffer_size bytes could not be decoded, then please refer to
- * sample.flags to determine if this was an End-of-stream or error condition.
- *
- * @param sample Do more decoding to this Sound_Sample.
- * @returns number of bytes decoded into sample.buffer. If it is less than
- * sample.buffer_size, then you should check sample.flags to see
- * what the current state of the sample is (EOF, error, read again).
- *)
-function Sound_Decode(sample: PSound_Sample): Uint32;
-cdecl; external {$IFDEF __GPC__}name 'Sound_Decode'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_Decode}
-
-(**
- * Decode the remainder of the sound data in a Sound_Sample. This will
- * dynamically allocate memory for the ENTIRE remaining sample.
- * sample.buffer_size and sample.buffer will be updated to reflect the
- * new buffer. Please refer to sample.flags to determine if the decoding
- * finished due to an End-of-stream or error condition.
- *
- * Be aware that sound data can take a large amount of memory, and that
- * this function may block for quite awhile while processing. Also note
- * that a streaming source (for example, from a SDL_RWops that is getting
- * fed from an Internet radio feed that doesn't end) may fill all available
- * memory before giving up...be sure to use this on finite sound sources
- * onlynot
- *
- * When decoding the sample in its entirety, the work is done one buffer at a
- * time. That is, sound is decoded in sample.buffer_size blocks, and
- * appended to a continually-growing buffer until the decoding completes.
- * That means that this function will need enough RAM to hold approximately
- * sample.buffer_size bytes plus the complete decoded sample at most. The
- * larger your buffer size, the less overhead this function needs, but beware
- * the possibility of paging to disk. Best to make this user-configurable if
- * the sample isn't specific and small.
- *
- * @param sample Do all decoding for this Sound_Sample.
- * @returns number of bytes decoded into sample.buffer. You should check
- * sample.flags to see what the current state of the sample is
- * (EOF, error, read again).
- *)
-function Sound_DecodeAll(sample: PSound_Sample): Uint32;
-cdecl; external {$IFDEF __GPC__}name 'Sound_DecodeAll'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_DecodeAll}
-
-(**
- * Restart a sample at the start of its waveform data, as if newly
- * created with Sound_NewSample. If successful, the next call to
- * Sound_Decode : array[ 0..All- 1 ] of will give audio data from the earliest point
- * in the stream.
- *
- * Beware that this function will fail if the SDL_RWops that feeds the
- * decoder can not be rewound via it's seek method, but this can
- * theoretically be aprocedure ed by wrapping it in some sort of buffering
- * SDL_RWops.
- *
- * This function should ONLY fail if the RWops is not seekable, or
- * SDL_sound is not initialized. Both can be controlled by the application,
- * and thus, it is up to the developer's paranoia to dictate whether this
- * function's return value need be checked at all.
- *
- * If this function fails, the state of the sample is undefined, but it
- * is still safe to call Sound_FreeSample to dispose of it.
- *
- * On success, ERROR, EOF, and EAGAIN are cleared from sample.flags. The
- * ERROR flag is set on error.
- *
- * @param sample The Sound_Sample to rewind.
- * @return nonzero on success, zero on error. Specifics of the
- * error can be gleaned from Sound_GetError.
- *)
-function Sound_Rewind(sample: PSound_Sample): integer;
-cdecl; external {$IFDEF __GPC__}name 'Sound_Rewind'{$ELSE} SDLSoundLibName{$ENDIF __GPC__};
-{$EXTERNALSYM Sound_Rewind}
-
-implementation
-
-{$IFDEF __GPC__}
- {$L sdl_sound} { link sdl.dll.a or libsdl.so or libsdl.a }
-{$ELSE}
-{$ENDIF}
-
-procedure SOUND_GETVERSION(var x: TSound_Version);
-begin
- x.major := SOUND_VER_MAJOR;
- x.minor := SOUND_VER_MINOR;
- x.patch := SOUND_VER_PATCH;
-end;
-
-end.
-