diff options
author | peter <peter@3ad0048d-3df7-0310-abae-a5850022a9f2> | 2008-02-02 15:48:09 +0000 |
---|---|---|
committer | peter <peter@3ad0048d-3df7-0310-abae-a5850022a9f2> | 2008-02-02 15:48:09 +0000 |
commit | c8845dfe5ca36797bebc57bcc37aae6a8e94444a (patch) | |
tree | a815946b5827956fef96fe9548e4a9c4d1e1b7d7 /packages/extra/sdl/sdl_sound.pas | |
parent | d7617abfb24ee7c360c3d123e1e9b2b5cc800a5d (diff) | |
download | fpc-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.pas | 562 |
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. - |