From b25a9bf69cd55348f51f4bdfa30fb476c0da977b Mon Sep 17 00:00:00 2001 From: Josh Coalson Date: Thu, 13 Jun 2002 05:34:01 +0000 Subject: [PATCH] update for 1.0.3 release --- doc/comparison.html | 352 ++++++++++++++++++++++++------------------------- doc/developers.html | 4 +- doc/documentation.html | 69 ++++++---- doc/download.html | 5 +- doc/features.html | 5 +- doc/index.html | 5 +- 6 files changed, 229 insertions(+), 211 deletions(-) diff --git a/doc/comparison.html b/doc/comparison.html index 57c2fca..2e623b5 100644 --- a/doc/comparison.html +++ b/doc/comparison.html @@ -77,15 +77,15 @@ - - + - + - + - + - + - + - + - + - +

- The purpose of the comparison page is not only to show how compression ratios and encoding times using the flac reference encoder compare to other lossless encoders, but also to compare features (for example, some coders archive only and files must be uncompressed completely before playback can start). Keep a few things in mind: + The purpose of the comparison page is not only to show how compression ratios and encoding/decoding times using the flac reference encoder compare to other lossless encoders, but also to compare features (for example, some coders archive only and files must be uncompressed completely before playback can start). Keep a few things in mind:

  • - As far as I know, only three of the lossless encoders out there (Bonk, flac and Kexis) are truly free (source code for Shorten is available but the license is more restrictive). Most others give out free binaries, but without access to the source, you are leaving your data to the whim of the maintainer for eternity; you have no way to port the program to another OS or fix it if it breaks. This can be a serious drawback unless the format has world-class clout (like MP3). + As far as I know, only three of the lossless encoders out there (Bonk, flac and Kexis) are truly free (source code for Shorten and Monkey's Audio is available but the licenses are more restrictive). Most others give out free binaries, but without access to the source, you are leaving your data to the whim of the maintainer for eternity; you have no way to port the program to another OS or fix it if it breaks. This can be a serious drawback unless the format has world-class clout (like MP3).
  • - The compression ratios and times are representative only of the reference encoder. They are not indicative of the limits of all FLAC encoders or the FLAC format itself since the format is open and extensible, and anyone is free to write a better FLAC encoder. And it is almost certain that the reference encoder itself will improve. + The compression ratios and times for flac are representative only of the reference encoder. They are not indicative of the limits of all FLAC encoders or the FLAC format itself since the format is open and extensible, and anyone is free to write a better FLAC encoder. And it is almost certain that the reference encoder itself will improve.
  • Since FLAC supports streaming, it is at a slight disadvantage to the formats that don't because they don't have the extra overhead of all those frame headers. @@ -507,13 +507,12 @@ The first table is a summary of results on all input tracks. The remaining tables show the results of the encoders on each track. The summary table has more modes, whereas the individual tables have just the interesting ones.

    - In the summary table, entries are sorted by weighted compression ratio, which is the average of the ratios for each track; this keeps long tracks from having more influence than short ones. In the individual tables, this is the same as the straight compression ratio, which is compressed size / uncompressed size. + In the summary table, entries are sorted by average compression ratio, which is the average of the ratios for each track; this keeps long tracks from having more influence than short ones. In the individual tables, this is the same as the straight compression ratio, which is compressed size / uncompressed size.

    Some interesting things to note:

    • flac -5 is right in the middle with respect to compression, relatively fast on the encoding range, and one of the fastest decoding. This is about what you would expect; FLAC is designed to put most of the processing on the encoding side, which is only done once, whereas the adaptive codecs take as long to decode as encode. FLAC is more suited in this way for playback on low-power devices and is one of the reasons it is the only lossless codec with any kind of hardware support.
    • -
    • Uniformity between unweighted and weighted ratio means the codec performs the same across genres.
    • LPAC quality settings are not too stable with -r (which allows seeking during playback) turned on.
    • RKAU also has a tendency to get bigger in the 'high' mode.
    • Another ironic fact is that the encoders that are patented or cost money turn out to be the worst by most measures. SPS is so archane and crippled that I gave up trying to put together results for it after one track.
    • @@ -539,31 +538,30 @@ Compressed
      size
- Compression
ratio
+ Overall
compression
ratio
- Weighted
ratio
+ Average
compression
ratio
Monkey's Audio 3.96 (extra high)26:52.0728:44.55386.96 MB0.49580.5119
optimFROG 4.21 (mode 1 @ 4x)24:19.5825:37.44389.04 MB0.49840.5151
optimFROG 4.21 (mode 1 @ 4x)24:19.5825:37.44389.04 MB0.49840.5151
Monkey's Audio 3.96 (high)13:59.0715:30.69391.76 MB0.50190.5179
optimFROG 4.21 (mode 0 @ 4x)16:34.9617:57.28394.69 MB0.50560.5223
optimFROG 4.21 (mode 0 @ 4x)16:34.9617:57.28394.69 MB0.50560.5223
Monkey's Audio 3.96 (normal)11:42.3413:11.29395.04 MB0.50610.5223
RKAU 1.07 (normal)53:46.7423:31.10395.71 MB0.50700.5229
RKAU 1.07 (normal)53:46.7423:31.10395.71 MB0.50700.5229
RKAU 1.07 (fast)26:35.3420:13.22399.25 MB0.51150.5262
LPAC 1.40 (-r, medium)18:52.7910:43.32403.52 MB0.51700.5319
LPAC 1.40 (-r, medium)18:52.7910:43.32403.52 MB0.51700.5319
Monkey's Audio 3.96 (fast)9:05.5910:51.09401.63 MB0.51450.5327
flac 1.0.3 (-5, default)13:26.747:19.04413.43 MB0.52970.5458
flac 1.0.3 (-5, default)13:26.747:19.04413.43 MB0.52970.5458
flac 1.0.3 (-3)10:07.347:14.68419.26 MB0.53710.5543
Bonk 0.536:56.3627:09.35418.65 MB0.53640.5543
Bonk 0.536:56.3627:09.35418.65 MB0.53640.5543
WavPack 3.91 (high)7:15.37?418.09 MB0.53560.5556
Ogg Squish 0.98??431.08 MB0.55220.5714
Ogg Squish 0.98??431.08 MB0.55220.5714
Shorten 3.2a (-p0 -b256, default)9:44.486:31.74433.56 MB0.55550.5729
Kexis 0.2.217:49.0614:53.90434.33 MB0.55640.5750
Kexis 0.2.217:49.0614:53.90434.33 MB0.55640.5750
WaveZIP8:41.72?452.95 MB0.58020.5986
RIFF WAVE  780.56 MB1.00001.0000
RIFF WAVE  780.56 MB1.00001.0000

@@ -587,49 +585,49 @@ Compressed
size
- Compression
ratio
+ Overall
compression
ratio
- Weighted
ratio
+ Average
compression
ratio
optimFROG 4.21 (mode 4 @ 2x)183:05.29184:13.42386.13 MB0.49470.5105 - optimFROG 4.21 (mode 4 @ 1x)338:34.96339:23.24386.22 MB0.49480.5105 + optimFROG 4.21 (mode 4 @ 1x)338:34.96339:23.24386.22 MB0.49480.5105 optimFROG 4.21 (mode 4 @ 4x)105:15.85106:36.23386.21 MB0.49480.5107 - optimFROG 4.21 (mode 3 @ 2x)92:48.7993:49.75386.52 MB0.49520.5110 + optimFROG 4.21 (mode 3 @ 2x)92:48.7993:49.75386.52 MB0.49520.5110 optimFROG 4.21 (mode 3 @ 1x)161:51.00162:10.62386.55 MB0.49520.5110 - optimFROG 4.21 (mode 3 @ 4x)58:18.4059:30.51386.71 MB0.49540.5114 + optimFROG 4.21 (mode 3 @ 4x)58:18.4059:30.51386.71 MB0.49540.5114 Monkey's Audio 3.96 (extra high)26:52.0728:44.55386.96 MB0.49580.5119 - optimFROG 4.21 (mode 2 @ 1x)68:22.5869:29.50387.71 MB0.49670.5128 + optimFROG 4.21 (mode 2 @ 1x)68:22.5869:29.50387.71 MB0.49670.5128 optimFROG 4.21 (mode 2 @ 2x)44:17.5545:31.33387.72 MB0.49670.5129 - optimFROG 4.21 (mode 2 @ 4x)32:16.8533:30.92387.93 MB0.49700.5133 + optimFROG 4.21 (mode 2 @ 4x)32:16.8533:30.92387.93 MB0.49700.5133 optimFROG 4.21 (mode 1 @ 1x)43:00.9144:13.07388.71 MB0.49800.5146 - optimFROG 4.21 (mode 1 @ 2x)30:35.0031:50.50388.81 MB0.49810.5147 + optimFROG 4.21 (mode 1 @ 2x)30:35.0031:50.50388.81 MB0.49810.5147 optimFROG 4.21 (mode 1 @ 4x)24:19.5825:37.44389.04 MB0.49840.5151 - Monkey's Audio 3.96 (high)13:59.0715:30.69391.76 MB0.50190.5179 + Monkey's Audio 3.96 (high)13:59.0715:30.69391.76 MB0.50190.5179 optimFROG 4.21 (mode 0 @ 1x)20:51.2122:08.44394.35 MB0.50520.5218 - optimFROG 4.21 (mode 0 @ 2x)17:59.8619:20.53394.48 MB0.50540.5220 + optimFROG 4.21 (mode 0 @ 2x)17:59.8619:20.53394.48 MB0.50540.5220 optimFROG 4.21 (mode 0 @ 4x)16:34.9617:57.28394.69 MB0.50560.5223 - Monkey's Audio 3.96 (normal)11:42.3413:11.29395.04 MB0.50610.5223 + Monkey's Audio 3.96 (normal)11:42.3413:11.29395.04 MB0.50610.5223 RKAU 1.07 (normal)53:46.7423:31.10395.71 MB0.50700.5229 - RKAU 1.07 (high)136:56.6227:55.98395.89 MB0.50720.5235 + RKAU 1.07 (high)136:56.6227:55.98395.89 MB0.50720.5235 RKAU 1.07 (fast)26:35.3420:13.22399.25 MB0.51150.5262 - LPAC 1.40 (-r, medium)18:52.7910:43.32403.52 MB0.51700.5319 + LPAC 1.40 (-r, medium)18:52.7910:43.32403.52 MB0.51700.5319 LPAC 1.40 (-r, extra high)30:30.9312:20.26404.08 MB0.51770.5322 - LPAC 1.40 (-r, high)24:56.5611:51.64404.03 MB0.51760.5323 + LPAC 1.40 (-r, high)24:56.5611:51.64404.03 MB0.51760.5323 Monkey's Audio 3.96 (fast)9:05.5910:51.09401.63 MB0.51450.5327 - flac 1.0.3 (-8)55:49.517:25.36411.85 MB0.52760.5436 + flac 1.0.3 (-8)55:49.517:25.36411.85 MB0.52760.5436 flac 1.0.3 (-5, default)13:26.747:19.04413.43 MB0.52970.5458 - flac 1.0.3 (-3)10:07.347:14.68419.26 MB0.53710.5543 + flac 1.0.3 (-3)10:07.347:14.68419.26 MB0.53710.5543 Bonk 0.536:56.3627:09.35418.65 MB0.53640.5543 - WavPack 3.91 (high)7:15.37?418.09 MB0.53560.5556 + WavPack 3.91 (high)7:15.37?418.09 MB0.53560.5556 flac 1.0.3 (-1)8:55.947:22.51432.29 MB0.55380.5704 - Ogg Squish 0.98??431.08 MB0.55220.5714 + Ogg Squish 0.98??431.08 MB0.55220.5714 Shorten 3.2a (-p0 -b256, default)9:44.486:31.74433.56 MB0.55550.5729 - Kexis 0.2.217:49.0614:53.90434.33 MB0.55640.5750 + Kexis 0.2.217:49.0614:53.90434.33 MB0.55640.5750 Shorten 3.2a (-p8 -b2048)12:00.047:25.12438.86 MB0.56220.5810 - WaveZIP8:41.72?452.95 MB0.58020.5986 + WaveZIP8:41.72?452.95 MB0.58020.5986 RIFF WAVE  780.56 MB1.00001.0000 @@ -666,25 +664,25 @@ Monkey's Audio 3.96 (extra high)2:05.362:13.4443.24 MB0.7395 - optimFROG 4.21 (mode 1 @ 4x)1:53.282:00.4543.26 MB0.7398 + optimFROG 4.21 (mode 1 @ 4x)1:53.282:00.4543.26 MB0.7398 optimFROG 4.21 (mode 4 @ 1x)25:32.4125:38.1543.26 MB0.7398 - Monkey's Audio 3.96 (high)1:07.921:13.2043.39 MB0.7421 + Monkey's Audio 3.96 (high)1:07.921:13.2043.39 MB0.7421 optimFROG 4.21 (mode 0 @ 4x)1:17.951:25.6743.42 MB0.7426 - Monkey's Audio 3.96 (normal)0:57.041:03.3743.48 MB0.7436 + Monkey's Audio 3.96 (normal)0:57.041:03.3743.48 MB0.7436 RKAU 1.07 (normal)1:57.681:33.3843.81 MB0.7493 - Monkey's Audio 3.96 (fast)0:44.330:51.2243.97 MB0.7520 + Monkey's Audio 3.96 (fast)0:44.330:51.2243.97 MB0.7520 LPAC 1.40 (-r, normal)1:27.610:56.1844.12 MB0.7545 - flac 1.0.3 (-8)4:20.410:37.8644.33 MB0.7581 + flac 1.0.3 (-8)4:20.410:37.8644.33 MB0.7581 Bonk 0.52:56.032:11.5844.35 MB0.7585 - flac 1.0.3 (-5, default)1:03.870:37.5544.40 MB0.7594 + flac 1.0.3 (-5, default)1:03.870:37.5544.40 MB0.7594 Shorten 3.2a (-p8 -b2048)0:58.810:37.6344.75 MB0.7654 - flac 1.0.3 (-3)0:48.520:37.2244.78 MB0.7658 + flac 1.0.3 (-3)0:48.520:37.2244.78 MB0.7658 WavPack 3.91 (high)0:35.86?45.14 MB0.7720 - Ogg Squish 0.98??45.17 MB0.7725 + Ogg Squish 0.98??45.17 MB0.7725 Pegasus-SPS4:45.00?45.40 MB0.7765 - Kexis 0.2.21:24.831:10.9346.52 MB0.7956 + Kexis 0.2.21:24.831:10.9346.52 MB0.7956 flac 1.0.3 (-1)0:44.070:37.7746.64 MB0.7977 - Shorten 3.2a (-p0 -b256, default)0:47.750:32.5646.68 MB0.7984 + Shorten 3.2a (-p0 -b256, default)0:47.750:32.5646.68 MB0.7984 WaveZIP0:38.99?47.22 MB0.8077   @@ -695,25 +693,25 @@ LPAC 1.40 (-r, normal)0:40.760:21.2114.77 MB0.5298 - flac 1.0.3 (-8)1:58.900:17.3315.01 MB0.5384 + flac 1.0.3 (-8)1:58.900:17.3315.01 MB0.5384 optimFROG 4.21 (mode 1 @ 4x)0:53.390:55.5215.01 MB0.5385 - optimFROG 4.21 (mode 4 @ 1x)12:02.5412:03.7615.02 MB0.5390 + optimFROG 4.21 (mode 4 @ 1x)12:02.5412:03.7615.02 MB0.5390 flac 1.0.3 (-5, default)0:29.560:15.5715.11 MB0.5423 - optimFROG 4.21 (mode 0 @ 4x)0:36.810:39.1915.13 MB0.5429 + optimFROG 4.21 (mode 0 @ 4x)0:36.810:39.1915.13 MB0.5429 RKAU 1.07 (normal)0:54.820:42.7115.15 MB0.5435 - Monkey's Audio 3.96 (extra high)0:58.521:01.8115.25 MB0.5471 + Monkey's Audio 3.96 (extra high)0:58.521:01.8115.25 MB0.5471 Monkey's Audio 3.96 (high)0:30.880:33.5515.34 MB0.5505 - Monkey's Audio 3.96 (normal)0:25.450:28.3715.35 MB0.5509 + Monkey's Audio 3.96 (normal)0:25.450:28.3715.35 MB0.5509 flac 1.0.3 (-3)0:22.290:15.2915.43 MB0.5537 - Monkey's Audio 3.96 (fast)0:19.850:22.9015.58 MB0.5592 + Monkey's Audio 3.96 (fast)0:19.850:22.9015.58 MB0.5592 Shorten 3.2a (-p0 -b256, default)0:21.160:13.5515.78 MB0.5662 - Shorten 3.2a (-p8 -b2048)0:26.820:16.7516.21 MB0.5818 + Shorten 3.2a (-p8 -b2048)0:26.820:16.7516.21 MB0.5818 flac 1.0.3 (-1)0:19.920:15.6716.38 MB0.5879 - Bonk 0.51:22.011:00.1216.73 MB0.6003 + Bonk 0.51:22.011:00.1216.73 MB0.6003 Ogg Squish 0.98??17.03 MB0.6112 - WavPack 3.91 (high)0:10.55?17.13 MB0.6148 + WavPack 3.91 (high)0:10.55?17.13 MB0.6148 Kexis 0.2.20:38.720:32.2517.40 MB0.6242 - WaveZIP0:17.55?17.89 MB0.6420 + WaveZIP0:17.55?17.89 MB0.6420   @@ -723,25 +721,25 @@ optimFROG 4.21 (mode 4 @ 1x)27:58.2828:01.8737.96 MB0.5907 - optimFROG 4.21 (mode 1 @ 4x)2:03.432:09.2738.15 MB0.5937 + optimFROG 4.21 (mode 1 @ 4x)2:03.432:09.2738.15 MB0.5937 Monkey's Audio 3.96 (extra high)2:14.702:24.3038.23 MB0.5950 - Monkey's Audio 3.96 (high)1:09.821:18.0938.42 MB0.5979 + Monkey's Audio 3.96 (high)1:09.821:18.0938.42 MB0.5979 Monkey's Audio 3.96 (normal)0:58.691:07.0238.59 MB0.6005 - optimFROG 4.21 (mode 0 @ 4x)1:24.441:30.9738.68 MB0.6020 + optimFROG 4.21 (mode 0 @ 4x)1:24.441:30.9738.68 MB0.6020 Monkey's Audio 3.96 (fast)0:46.500:55.4139.18 MB0.6098 - RKAU 1.07 (normal)2:16.001:41.8439.42 MB0.6135 + RKAU 1.07 (normal)2:16.001:41.8439.42 MB0.6135 LPAC 1.40 (-r, normal)1:38.010:57.5640.25 MB0.6263 - flac 1.0.3 (-8)4:39.650:38.2540.88 MB0.6363 + flac 1.0.3 (-8)4:39.650:38.2540.88 MB0.6363 Bonk 0.53:07.202:21.2840.98 MB0.6378 - flac 1.0.3 (-5, default)1:08.270:38.8141.04 MB0.6387 + flac 1.0.3 (-5, default)1:08.270:38.8141.04 MB0.6387 WavPack 3.91 (high)0:37.51?41.51 MB0.6461 - flac 1.0.3 (-3)0:51.780:38.5441.74 MB0.6496 + flac 1.0.3 (-3)0:51.780:38.5441.74 MB0.6496 Ogg Squish 0.98??42.27 MB0.6578 - flac 1.0.3 (-1)0:46.190:41.1842.70 MB0.6646 + flac 1.0.3 (-1)0:46.190:41.1842.70 MB0.6646 Kexis 0.2.21:30.091:16.2942.75 MB0.6652 - Shorten 3.2a (-p8 -b2048)1:02.420:37.8443.06 MB0.6701 + Shorten 3.2a (-p8 -b2048)1:02.420:37.8443.06 MB0.6701 Shorten 3.2a (-p0 -b256, default)0:51.290:34.5943.18 MB0.6721 - WaveZIP0:42.84?44.52 MB0.6930 + WaveZIP0:42.84?44.52 MB0.6930   @@ -751,25 +749,25 @@ Monkey's Audio 3.96 (extra high)1:10.941:15.9222.95 MB0.6876 - optimFROG 4.21 (mode 4 @ 1x)14:34.2814:37.6922.95 MB0.6877 + optimFROG 4.21 (mode 4 @ 1x)14:34.2814:37.6922.95 MB0.6877 Monkey's Audio 3.96 (high)0:37.630:41.3423.19 MB0.6948 - Monkey's Audio 3.96 (normal)0:31.710:34.8723.26 MB0.6968 + Monkey's Audio 3.96 (normal)0:31.710:34.8723.26 MB0.6968 optimFROG 4.21 (mode 1 @ 4x)1:03.961:08.8523.31 MB0.6984 - RKAU 1.07 (normal)1:09.710:56.6623.34 MB0.6993 + RKAU 1.07 (normal)1:09.710:56.6623.34 MB0.6993 LPAC 1.40 (-r, normal)1:05.380:36.2023.53 MB0.7050 - optimFROG 4.21 (mode 0 @ 4x)0:44.140:48.7123.95 MB0.7176 + optimFROG 4.21 (mode 0 @ 4x)0:44.140:48.7123.95 MB0.7176 flac 1.0.3 (-8)2:27.820:22.1524.18 MB0.7244 - Monkey's Audio 3.96 (fast)0:25.050:28.9924.20 MB0.7250 + Monkey's Audio 3.96 (fast)0:25.050:28.9924.20 MB0.7250 flac 1.0.3 (-5, default)0:36.190:21.0024.30 MB0.7281 - Bonk 0.51:40.381:14.5824.36 MB0.7297 + Bonk 0.51:40.381:14.5824.36 MB0.7297 Shorten 3.2a (-p8 -b2048)0:33.740:22.4725.12 MB0.7526 - flac 1.0.3 (-3)0:28.290:20.8225.16 MB0.7539 + flac 1.0.3 (-3)0:28.290:20.8225.16 MB0.7539 Ogg Squish 0.98??25.23 MB0.7558 - WavPack 3.91 (high)0:20.50?25.33 MB0.7589 + WavPack 3.91 (high)0:20.50?25.33 MB0.7589 Kexis 0.2.20:47.130:40.6726.03 MB0.7799 - flac 1.0.3 (-1)0:24.950:22.7026.09 MB0.7818 + flac 1.0.3 (-1)0:24.950:22.7026.09 MB0.7818 Shorten 3.2a (-p0 -b256, default)0:28.200:20.4626.61 MB0.7972 - WaveZIP0:22.25?26.89 MB0.8058 + WaveZIP0:22.25?26.89 MB0.8058   @@ -779,25 +777,25 @@ optimFROG 4.21 (mode 4 @ 1x)16:51.8216:54.3421.24 MB0.5433 - optimFROG 4.21 (mode 1 @ 4x)1:14.291:18.0621.36 MB0.5464 + optimFROG 4.21 (mode 1 @ 4x)1:14.291:18.0621.36 MB0.5464 Monkey's Audio 3.96 (extra high)1:21.381:27.2821.54 MB0.5509 - Monkey's Audio 3.96 (high)0:42.540:47.4121.75 MB0.5563 + Monkey's Audio 3.96 (high)0:42.540:47.4121.75 MB0.5563 Monkey's Audio 3.96 (normal)0:35.450:39.6521.84 MB0.5586 - optimFROG 4.21 (mode 0 @ 4x)0:51.390:54.9721.89 MB0.5598 + optimFROG 4.21 (mode 0 @ 4x)0:51.390:54.9721.89 MB0.5598 Monkey's Audio 3.96 (fast)0:28.230:33.2122.16 MB0.5668 - RKAU 1.07 (normal)1:21.181:01.6022.80 MB0.5833 + RKAU 1.07 (normal)1:21.181:01.6022.80 MB0.5833 LPAC 1.40 (-r, normal)1:01.110:33.7923.25 MB0.5948 - Bonk 0.51:53.411:23.5223.35 MB0.5972 + Bonk 0.51:53.411:23.5223.35 MB0.5972 flac 1.0.3 (-8)2:48.450:23.4723.45 MB0.5997 - flac 1.0.3 (-5, default)0:41.000:23.5923.55 MB0.6025 + flac 1.0.3 (-5, default)0:41.000:23.5923.55 MB0.6025 Ogg Squish 0.98??24.11 MB0.6167 - WavPack 3.91 (high)0:22.50?24.22 MB0.6196 + WavPack 3.91 (high)0:22.50?24.22 MB0.6196 flac 1.0.3 (-3)0:31.650:22.2724.32 MB0.6220 - Shorten 3.2a (-p8 -b2048)0:37.490:22.9324.72 MB0.6323 + Shorten 3.2a (-p8 -b2048)0:37.490:22.9324.72 MB0.6323 Kexis 0.2.20:54.260:45.6424.80 MB0.6345 - flac 1.0.3 (-1)0:27.510:22.7224.81 MB0.6347 + flac 1.0.3 (-1)0:27.510:22.7224.81 MB0.6347 Shorten 3.2a (-p0 -b256, default)0:29.710:18.9225.34 MB0.6481 - WaveZIP0:28.05?25.95 MB0.6638 + WaveZIP0:28.05?25.95 MB0.6638   @@ -807,25 +805,25 @@ optimFROG 4.21 (mode 4 @ 1x)19:40.5319:44.4729.43 MB0.6517 - optimFROG 4.21 (mode 1 @ 4x)1:26.641:32.2329.58 MB0.6550 + optimFROG 4.21 (mode 1 @ 4x)1:26.641:32.2329.58 MB0.6550 Monkey's Audio 3.96 (extra high)1:35.651:42.1129.65 MB0.6567 - optimFROG 4.21 (mode 0 @ 4x)0:59.591:05.2929.78 MB0.6595 + optimFROG 4.21 (mode 0 @ 4x)0:59.591:05.2929.78 MB0.6595 Monkey's Audio 3.96 (high)0:50.170:56.4029.85 MB0.6610 - Monkey's Audio 3.96 (normal)0:42.270:47.7429.97 MB0.6637 + Monkey's Audio 3.96 (normal)0:42.270:47.7429.97 MB0.6637 Monkey's Audio 3.96 (fast)0:33.460:39.2230.30 MB0.6710 - RKAU 1.07 (normal)1:37.851:12.1530.34 MB0.6719 + RKAU 1.07 (normal)1:37.851:12.1530.34 MB0.6719 Bonk 0.52:13.341:39.4430.64 MB0.6785 - flac 1.0.3 (-8)3:18.770:28.5730.75 MB0.6811 + flac 1.0.3 (-8)3:18.770:28.5730.75 MB0.6811 LPAC 1.40 (-r, normal)1:14.080:44.6430.81 MB0.6823 - flac 1.0.3 (-5, default)0:48.110:27.8430.85 MB0.6833 + flac 1.0.3 (-5, default)0:48.110:27.8430.85 MB0.6833 WavPack 3.91 (high)0:26.73?30.91 MB0.6845 - Ogg Squish 0.98??31.06 MB0.6879 + Ogg Squish 0.98??31.06 MB0.6879 flac 1.0.3 (-3)0:37.460:27.8031.63 MB0.7005 - flac 1.0.3 (-1)0:32.550:27.4231.99 MB0.7085 + flac 1.0.3 (-1)0:32.550:27.4231.99 MB0.7085 Shorten 3.2a (-p8 -b2048)0:44.760:27.4831.76 MB0.7034 - Kexis 0.2.21:03.910:53.5431.86 MB0.7056 + Kexis 0.2.21:03.910:53.5431.86 MB0.7056 Shorten 3.2a (-p0 -b256, default)0:35.740:23.6432.47 MB0.7191 - WaveZIP0:29.42?33.02 MB0.7313 + WaveZIP0:29.42?33.02 MB0.7313   @@ -835,25 +833,25 @@ optimFROG 4.21 (mode 4 @ 1x)22:59.0523:02.9833.93 MB0.6399 - optimFROG 4.21 (mode 1 @ 4x)1:42.281:47.5533.96 MB0.6405 + optimFROG 4.21 (mode 1 @ 4x)1:42.281:47.5533.96 MB0.6405 Monkey's Audio 3.96 (extra high)1:51.772:00.3734.14 MB0.6441 - Monkey's Audio 3.96 (high)0:58.451:04.5934.29 MB0.6468 + Monkey's Audio 3.96 (high)0:58.451:04.5934.29 MB0.6468 optimFROG 4.21 (mode 0 @ 4x)1:10.301:15.9934.29 MB0.6468 - Monkey's Audio 3.96 (normal)0:49.320:56.8934.42 MB0.6493 + Monkey's Audio 3.96 (normal)0:49.320:56.8934.42 MB0.6493 RKAU 1.07 (normal)1:50.801:24.9834.60 MB0.6527 - LPAC 1.40 (-r, normal)1:25.160:48.6734.84 MB0.6572 + LPAC 1.40 (-r, normal)1:25.160:48.6734.84 MB0.6572 Bonk 0.52:35.361:56.2034.96 MB0.6595 - Monkey's Audio 3.96 (fast)0:38.750:46.8034.99 MB0.6601 + Monkey's Audio 3.96 (fast)0:38.750:46.8034.99 MB0.6601 flac 1.0.3 (-8)3:53.210:32.0835.00 MB0.6602 - flac 1.0.3 (-5, default)0:57.280:32.2735.17 MB0.6634 + flac 1.0.3 (-5, default)0:57.280:32.2735.17 MB0.6634 flac 1.0.3 (-3)0:42.710:32.5635.37 MB0.6672 - Shorten 3.2a (-p8 -b2048)0:51.440:33.0235.40 MB0.6677 + Shorten 3.2a (-p8 -b2048)0:51.440:33.0235.40 MB0.6677 WavPack 3.91 (high)0:31.05?35.60 MB0.6715 - Ogg Squish 0.98??35.74 MB0.6742 + Ogg Squish 0.98??35.74 MB0.6742 Shorten 3.2a (-p0 -b256, default)0:41.140:28.9136.42 MB0.6870 - flac 1.0.3 (-1)0:38.470:30.6636.56 MB0.6896 + flac 1.0.3 (-1)0:38.470:30.6636.56 MB0.6896 Kexis 0.2.21:13.871:02.9036.64 MB0.6911 - WaveZIP0:35.77?37.13 MB0.7004 + WaveZIP0:35.77?37.13 MB0.7004   @@ -863,25 +861,25 @@ optimFROG 4.21 (mode 4 @ 1x)8:22.428:23.326.82 MB0.3274 - Monkey's Audio 3.96 (extra high)0:39.930:41.696.85 MB0.3289 + Monkey's Audio 3.96 (extra high)0:39.930:41.696.85 MB0.3289 optimFROG 4.21 (mode 1 @ 4x)0:36.570:38.267.09 MB0.3406 - Monkey's Audio 3.96 (high)0:21.220:23.047.16 MB0.3437 + Monkey's Audio 3.96 (high)0:21.220:23.047.16 MB0.3437 RKAU 1.07 (normal)0:40.670:28.527.18 MB0.3451 - optimFROG 4.21 (mode 0 @ 4x)0:24.980:26.377.21 MB0.3462 + optimFROG 4.21 (mode 0 @ 4x)0:24.980:26.377.21 MB0.3462 LPAC 1.40 (-r, normal)0:29.010:15.117.33 MB0.3520 - Monkey's Audio 3.96 (normal)0:18.190:19.547.44 MB0.3575 + Monkey's Audio 3.96 (normal)0:18.190:19.547.44 MB0.3575 Monkey's Audio 3.96 (fast)0:13.700:15.727.64 MB0.3671 - flac 1.0.3 (-8)1:21.110:09.727.68 MB0.3691 + flac 1.0.3 (-8)1:21.110:09.727.68 MB0.3691 flac 1.0.3 (-5, default)0:19.970:09.777.71 MB0.3702 - flac 1.0.3 (-3)0:15.090:10.097.77 MB0.3733 + flac 1.0.3 (-3)0:15.090:10.097.77 MB0.3733 Bonk 0.50:55.920:40.237.83 MB0.3762 - WavPack 3.91 (high)0:11.42?7.89 MB0.3791 + WavPack 3.91 (high)0:11.42?7.89 MB0.3791 flac 1.0.3 (-1)0:13.180:09.788.12 MB0.3901 - Ogg Squish 0.98??8.15 MB0.3914 + Ogg Squish 0.98??8.15 MB0.3914 Shorten 3.2a (-p0 -b256, default)0:13.810:08.888.19 MB0.3932 - Shorten 3.2a (-p8 -b2048)0:17.450:10.308.29 MB0.3983 + Shorten 3.2a (-p8 -b2048)0:17.450:10.308.29 MB0.3983 Kexis 0.2.20:26.780:21.908.52 MB0.4091 - WaveZIP0:13.11?8.72 MB0.4193 + WaveZIP0:13.11?8.72 MB0.4193   @@ -891,25 +889,25 @@ Monkey's Audio 3.96 (extra high)1:54.092:01.7220.47 MB0.3642 - optimFROG 4.21 (mode 4 @ 1x)24:26.9924:29.3620.62 MB0.3671 + optimFROG 4.21 (mode 4 @ 1x)24:26.9924:29.3620.62 MB0.3671 Monkey's Audio 3.96 (high)0:58.141:06.4520.80 MB0.3702 - optimFROG 4.21 (mode 1 @ 4x)1:42.571:47.4820.93 MB0.3725 + optimFROG 4.21 (mode 1 @ 4x)1:42.571:47.4820.93 MB0.3725 Monkey's Audio 3.96 (normal)0:48.610:54.7321.14 MB0.3763 - optimFROG 4.21 (mode 0 @ 4x)1:09.171:13.1421.23 MB0.3779 + optimFROG 4.21 (mode 0 @ 4x)1:09.171:13.1421.23 MB0.3779 RKAU 1.07 (normal)1:52.651:25.3921.30 MB0.3791 - Monkey's Audio 3.96 (fast)0:37.300:44.7921.54 MB0.3835 + Monkey's Audio 3.96 (fast)0:37.300:44.7921.54 MB0.3835 LPAC 1.40 (-r, normal)1:20.840:42.7321.96 MB0.3909 - WavPack 3.91 (high)0:30.03?22.30 MB0.3969 + WavPack 3.91 (high)0:30.03?22.30 MB0.3969 flac 1.0.3 (-8)3:57.240:28.2622.61 MB0.4024 - flac 1.0.3 (-5, default)0:56.470:28.3122.67 MB0.4036 + flac 1.0.3 (-5, default)0:56.470:28.3122.67 MB0.4036 Bonk 0.52:33.531:51.9423.18 MB0.4125 - flac 1.0.3 (-3)0:41.660:27.6323.21 MB0.4131 + flac 1.0.3 (-3)0:41.660:27.6323.21 MB0.4131 flac 1.0.3 (-1)0:36.760:29.5423.36 MB0.4158 - Kexis 0.2.21:15.051:03.8623.42 MB0.4168 + Kexis 0.2.21:15.051:03.8623.42 MB0.4168 Shorten 3.2a (-p0 -b256, default)0:39.960:27.3623.71 MB0.4221 - Ogg Squish 0.98??24.12 MB0.4293 + Ogg Squish 0.98??24.12 MB0.4293 Shorten 3.2a (-p8 -b2048)0:49.060:29.9425.59 MB0.4554 - WaveZIP0:36.60?25.84 MB0.4600 + WaveZIP0:36.60?25.84 MB0.4600   @@ -919,25 +917,25 @@ optimFROG 4.21 (mode 4 @ 1x)43:21.8843:26.1833.58 MB0.3335 - Monkey's Audio 3.96 (extra high)3:21.333:35.9133.72 MB0.3349 + Monkey's Audio 3.96 (extra high)3:21.333:35.9133.72 MB0.3349 optimFROG 4.21 (mode 1 @ 4x)3:00.573:08.1933.83 MB0.3360 - optimFROG 4.21 (mode 0 @ 4x)2:00.852:09.5234.14 MB0.3390 + optimFROG 4.21 (mode 0 @ 4x)2:00.852:09.5234.14 MB0.3390 Monkey's Audio 3.96 (high)1:43.171:55.3134.23 MB0.3400 - Monkey's Audio 3.96 (normal)1:26.191:35.9034.66 MB0.3442 + Monkey's Audio 3.96 (normal)1:26.191:35.9034.66 MB0.3442 RKAU 1.07 (normal)3:08.702:26.1735.21 MB0.3496 - LPAC 1.40 (-r, normal)2:06.211:11.9235.27 MB0.3502 + LPAC 1.40 (-r, normal)2:06.211:11.9235.27 MB0.3502 Monkey's Audio 3.96 (fast)1:06.281:18.5635.43 MB0.3518 - WavPack 3.91 (high)0:53.49?37.44 MB0.3718 + WavPack 3.91 (high)0:53.49?37.44 MB0.3718 flac 1.0.3 (-8)6:57.760:51.4538.07 MB0.3781 - flac 1.0.3 (-5, default)1:39.780:49.4738.17 MB0.3791 + flac 1.0.3 (-5, default)1:39.780:49.4738.17 MB0.3791 flac 1.0.3 (-3)1:13.490:49.5138.50 MB0.3824 - flac 1.0.3 (-1)1:04.890:53.2539.30 MB0.3903 + flac 1.0.3 (-1)1:04.890:53.2539.30 MB0.3903 Shorten 3.2a (-p0 -b256, default)1:10.570:50.0039.49 MB0.3921 - Kexis 0.2.22:12.391:49.0039.89 MB0.3962 + Kexis 0.2.22:12.391:49.0039.89 MB0.3962 Bonk 0.54:33.713:19.3840.31 MB0.4003 - Ogg Squish 0.98??41.86 MB0.4157 + Ogg Squish 0.98??41.86 MB0.4157 WaveZIP1:05.60?43.67 MB0.4337 - Shorten 3.2a (-p8 -b2048)1:26.840:53.1945.34 MB0.4502 + Shorten 3.2a (-p8 -b2048)1:26.840:53.1945.34 MB0.4502   @@ -947,25 +945,25 @@ Monkey's Audio 3.96 (extra high)0:55.830:59.5210.25 MB0.3734 - optimFROG 4.21 (mode 4 @ 1x)11:56.2411:58.7710.34 MB0.3764 + optimFROG 4.21 (mode 4 @ 1x)11:56.2411:58.7710.34 MB0.3764 optimFROG 4.21 (mode 1 @ 4x)0:50.070:53.4910.41 MB0.3790 - Monkey's Audio 3.96 (high)0:28.520:31.3210.47 MB0.3812 + Monkey's Audio 3.96 (high)0:28.520:31.3210.47 MB0.3812 optimFROG 4.21 (mode 0 @ 4x)0:34.060:38.7010.53 MB0.3833 - Monkey's Audio 3.96 (normal)0:23.700:27.6110.59 MB0.3854 + Monkey's Audio 3.96 (normal)0:23.700:27.6110.59 MB0.3854 LPAC 1.40 (-r, normal)0:34.910:20.0110.74 MB0.3911 - RKAU 1.07 (normal)0:54.460:41.5410.88 MB0.3963 + RKAU 1.07 (normal)0:54.460:41.5410.88 MB0.3963 Monkey's Audio 3.96 (fast)0:18.530:21.8010.94 MB0.3982 - WavPack 3.91 (high)0:14.46?11.38 MB0.4145 + WavPack 3.91 (high)0:14.46?11.38 MB0.4145 flac 1.0.3 (-8)1:54.970:13.6811.69 MB0.4255 - flac 1.0.3 (-5, default)0:27.350:14.0611.71 MB0.4264 + flac 1.0.3 (-5, default)0:27.350:14.0611.71 MB0.4264 flac 1.0.3 (-3)0:20.430:14.5911.73 MB0.4273 - flac 1.0.3 (-1)0:17.240:14.1711.86 MB0.4318 + flac 1.0.3 (-1)0:17.240:14.1711.86 MB0.4318 Shorten 3.2a (-p0 -b256, default)0:19.200:11.8912.05 MB0.4386 - Kexis 0.2.20:36.700:30.2612.14 MB0.4419 + Kexis 0.2.20:36.700:30.2612.14 MB0.4419 Bonk 0.51:15.450:55.0712.86 MB0.4684 - WaveZIP0:18.75?13.08 MB0.4765 + WaveZIP0:18.75?13.08 MB0.4765 Ogg Squish 0.98??13.31 MB0.4845 - Shorten 3.2a (-p8 -b2048)0:24.430:14.3214.40 MB0.5242 + Shorten 3.2a (-p8 -b2048)0:24.430:14.3214.40 MB0.5242   @@ -975,25 +973,25 @@ Monkey's Audio 3.96 (extra high)0:33.990:35.536.80 MB0.4145 - optimFROG 4.21 (mode 4 @ 1x)7:08.777:09.526.87 MB0.4190 + optimFROG 4.21 (mode 4 @ 1x)7:08.777:09.526.87 MB0.4190 Monkey's Audio 3.96 (high)0:17.470:19.116.94 MB0.4230 - optimFROG 4.21 (mode 1 @ 4x)0:30.470:31.956.98 MB0.4255 + optimFROG 4.21 (mode 1 @ 4x)0:30.470:31.956.98 MB0.4255 Monkey's Audio 3.96 (normal)0:14.840:16.177.02 MB0.4284 - RKAU 1.07 (normal)0:37.090:26.567.05 MB0.4297 + RKAU 1.07 (normal)0:37.090:26.567.05 MB0.4297 optimFROG 4.21 (mode 0 @ 4x)0:20.680:22.067.07 MB0.4310 - Monkey's Audio 3.96 (fast)0:11.390:12.957.19 MB0.4384 + Monkey's Audio 3.96 (fast)0:11.390:12.957.19 MB0.4384 LPAC 1.40 (-r, normal)0:29.990:14.337.21 MB0.4397 - WavPack 3.91 (high)0:09.23?7.35 MB0.4481 + WavPack 3.91 (high)0:09.23?7.35 MB0.4481 flac 1.0.3 (-8)1:09.870:08.227.37 MB0.4497 - flac 1.0.3 (-5, default)0:16.580:08.137.40 MB0.4512 + flac 1.0.3 (-5, default)0:16.580:08.137.40 MB0.4512 flac 1.0.3 (-3)0:12.150:08.477.43 MB0.4529 - Bonk 0.50:45.590:32.637.46 MB0.4548 + Bonk 0.50:45.590:32.637.46 MB0.4548 Shorten 3.2a (-p0 -b256, default)0:11.670:07.177.48 MB0.4564 - Kexis 0.2.20:22.060:18.627.50 MB0.4572 + Kexis 0.2.20:22.060:18.627.50 MB0.4572 flac 1.0.3 (-1)0:10.740:08.207.52 MB0.4590 - Ogg Squish 0.98??7.74 MB0.4723 + Ogg Squish 0.98??7.74 MB0.4723 WaveZIP0:10.56?7.83 MB0.4781 - Shorten 3.2a (-p8 -b2048)0:14.290:09.078.20 MB0.5004 + Shorten 3.2a (-p8 -b2048)0:14.290:09.078.20 MB0.5004   @@ -1003,25 +1001,25 @@ Monkey's Audio 3.96 (extra high)0:50.720:54.2012.15 MB0.5006 - optimFROG 4.21 (mode 4 @ 1x)10:34.7510:36.8312.17 MB0.5015 + optimFROG 4.21 (mode 4 @ 1x)10:34.7510:36.8312.17 MB0.5015 Monkey's Audio 3.96 (high)0:26.360:28.5212.25 MB0.5048 - RKAU 1.07 (normal)0:57.640:41.3912.25 MB0.5049 + RKAU 1.07 (normal)0:57.640:41.3912.25 MB0.5049 optimFROG 4.21 (mode 1 @ 4x)0:45.200:48.4512.43 MB0.5121 - Monkey's Audio 3.96 (normal)0:21.810:24.3312.47 MB0.5139 + Monkey's Audio 3.96 (normal)0:21.810:24.3312.47 MB0.5139 LPAC 1.40 (-r, normal)0:45.660:23.2912.62 MB0.5200 - optimFROG 4.21 (mode 0 @ 4x)0:31.030:33.6912.63 MB0.5207 + optimFROG 4.21 (mode 0 @ 4x)0:31.030:33.6912.63 MB0.5207 Bonk 0.51:08.180:49.7012.71 MB0.5237 - Monkey's Audio 3.96 (fast)0:16.910:20.6012.80 MB0.5277 + Monkey's Audio 3.96 (fast)0:16.910:20.6012.80 MB0.5277 flac 1.0.3 (-8)1:45.270:14.2212.82 MB0.5285 - flac 1.0.3 (-5, default)0:24.980:13.9412.92 MB0.5324 + flac 1.0.3 (-5, default)0:24.980:13.9412.92 MB0.5324 flac 1.0.3 (-3)0:19.000:13.1612.98 MB0.5348 - WavPack 3.91 (high)0:13.72?13.06 MB0.5384 + WavPack 3.91 (high)0:13.72?13.06 MB0.5384 Kexis 0.2.20:33.430:28.1113.30 MB0.5481 - Shorten 3.2a (-p0 -b256, default)0:17.800:11.4613.32 MB0.5489 + Shorten 3.2a (-p0 -b256, default)0:17.800:11.4613.32 MB0.5489 flac 1.0.3 (-1)0:17.290:14.5313.34 MB0.5499 - Ogg Squish 0.98??13.41 MB0.5528 + Ogg Squish 0.98??13.41 MB0.5528 Shorten 3.2a (-p8 -b2048)0:22.300:13.8713.42 MB0.5531 - WaveZIP0:16.37?13.72 MB0.5655 + WaveZIP0:16.37?13.72 MB0.5655   @@ -1031,25 +1029,25 @@ Monkey's Audio 3.96 (extra high)7:17.867:50.7591.73 MB0.4295 - optimFROG 4.21 (mode 4 @ 1x)93:05.0093:16.0092.05 MB0.4310 + optimFROG 4.21 (mode 4 @ 1x)93:05.0093:16.0092.05 MB0.4310 optimFROG 4.21 (mode 1 @ 4x)6:36.866:57.6992.76 MB0.4343 - Monkey's Audio 3.96 (high)3:46.784:12.3693.69 MB0.4387 + Monkey's Audio 3.96 (high)3:46.784:12.3693.69 MB0.4387 optimFROG 4.21 (mode 0 @ 4x)4:29.574:53.0194.74 MB0.4436 - Monkey's Audio 3.96 (normal)3:09.073:35.1094.81 MB0.4439 + Monkey's Audio 3.96 (normal)3:09.073:35.1094.81 MB0.4439 Monkey's Audio 3.96 (fast)2:25.312:58.9295.70 MB0.4481 - RKAU 1.07 (normal)7:16.095:30.3395.91 MB0.4490 + RKAU 1.07 (normal)7:16.095:30.3395.91 MB0.4490 LPAC 1.40 (-r, normal)4:34.062:37.6896.84 MB0.4534 - flac 1.0.3 (-8)15:16.082:00.1098.01 MB0.4589 + flac 1.0.3 (-8)15:16.082:00.1098.01 MB0.4589 flac 1.0.3 (-5, default)3:37.331:58.7398.41 MB0.4608 - WavPack 3.91 (high)1:58.32?98.82 MB0.4627 + WavPack 3.91 (high)1:58.32?98.82 MB0.4627 Bonk 0.59:56.257:13.6898.94 MB0.4633 - flac 1.0.3 (-3)2:42.821:56.7399.21 MB0.4645 + flac 1.0.3 (-3)2:42.821:56.7399.21 MB0.4645 Ogg Squish 0.98??101.88 MB0.4770 - Shorten 3.2a (-p8 -b2048)3:10.191:56.31102.60 MB0.4804 + Shorten 3.2a (-p8 -b2048)3:10.191:56.31102.60 MB0.4804 Shorten 3.2a (-p0 -b256, default)2:36.481:42.35102.84 MB0.4815 - Kexis 0.2.24:49.843:59.93103.57 MB0.4849 + Kexis 0.2.24:49.843:59.93103.57 MB0.4849 flac 1.0.3 (-1)2:22.181:54.92103.59 MB0.4850 - WaveZIP2:25.86?107.47 MB0.5032 + WaveZIP2:25.86?107.47 MB0.5032

diff --git a/doc/developers.html b/doc/developers.html index 906a6c9..09fd049 100644 --- a/doc/developers.html +++ b/doc/developers.html @@ -146,13 +146,13 @@

FLAC is open to third-party developers who want to add support for FLAC into their programs. All the necessary functionality is contained the library libFLAC which is licensed under the LGPL. The relevant documentation here is:

- There also are several examples in the FLAC code base of the use of libFLAC that may also be helpful. Visit the download page for instructions on how to get the source. + There also are several examples in the FLAC code base of the use of libFLAC and libFLAC++ that may also be helpful. Visit the download page for instructions on how to get the source.

diff --git a/doc/documentation.html b/doc/documentation.html index f0c42c1..34a17b2 100644 --- a/doc/documentation.html +++ b/doc/documentation.html @@ -84,6 +84,7 @@
  • metaflac - the usage of the command-line FLAC metadata editor metaflac.
  • plugins - documentation for the various input plugins.
  • libFLAC API - for developers who want to add FLAC support to their programs.
  • +
  • libFLAC++ API - the documentation for object layer around libFLAC.
  • bugs - known bugs.
  • How to add FLAC support to the Monkey's Audio GUI
  • @@ -737,18 +738,10 @@ @@ -757,6 +750,7 @@

    - metaflac is the command-line .flac file metadata editor. Right now it just lists the contents of all metadata blocks in a .flac file, but soon it will allow you to insert, delete, and edit blocks. + metaflac is the command-line .flac file metadata editor. You can use it to list the contents of blocks, delete or insert blocks, and manage padding.

    - Currently metaflac can be invoked only one way: -

      -
    • - Listing: metaflac [-v] inputfile -
    • -
    -

    -

    - inputfile may be "-" for stdin. If -v is used, you will get verbose output. + The documentation for metaflac is currently being rewritten, but the usage screen should explain it pretty well. Do metaflac --help to see the full usage.

    + +
    @@ -836,7 +830,10 @@ +

    - The FLAC library libFLAC is a C implementation of reference encoders and decoders. By linking against libFLAC and writing a little code, it is relatively easy to add FLAC support to another program. The library is licensed under the LGPL. Complete source code of libFLAC as well as the command-line encoder and plugins is available and is a useful source of examples. + The FLAC library libFLAC is a C implementation of reference encoders and decoders, and a metadata interface. By linking against libFLAC and writing a little code, it is relatively easy to add FLAC support to another program. The library is licensed under the LGPL. Complete source code of libFLAC as well as the command-line encoder and plugins is available and is a useful source of examples. +

    +

    + There is also a C++ object wrapper around libFLAC called libFLAC++; see the documentation below.

    libFLAC usually only requires the standard C library and C math library. In particular, threading is not used so there is no dependency on a thread library. However, libFLAC does not use global variables and should be thread-safe. @@ -845,13 +842,16 @@ The libFLAC interface is described in the public header files in the include/FLAC directory. The public headers and the compiled library are all that is needed to compile and link against the library. Note that none of the code in src/libFLAC/, including the private header files in src/libFLAC/include/ is required.

    - The basic usage of libFLAC is as follows: + Aside from encoders and decoders, libFLAC provides a powerful metadata interface for manipulating metadata in FLAC files. It allows the user to add, delete, and modify FLAC metadata blocks and it can automatically take advantage of PADDING blocks to avoid rewriting the entire FLAC file when changing the size of the metadata. The documentation for the metadata interface is currently being rewritten but there are extensive usage comments in the header file include/FLAC/metadata.h. +

    +

    + The basic usage of a libFLAC encoder or decoder is as follows:

    1. The program creates an instance of a decoder or encoder using *_new().
    2. The program sets the parameters of the instance and callbacks for reading, writing, error reporting, and metadata reporting using *_set_*() functions.
    3. The program initializes the instance to validate the parameters and prepare for decoding/encoding using *_init().
    4. The program calls *_process_*() functions to encode or decode data, which subsequently calls the callbacks.
    5. -
    6. The program finishes the instance with *_finish(), which flushes the input and output.
    7. +
    8. The program finishes the instance with *_finish(), which flushes the input and output and resets the encoder/decoder to the unitialized state.
    9. The instance may be used again or deleted with *_delete().

    @@ -875,12 +875,12 @@
    • Read callback - This function will be called when the decoder needs more input data. The address of the buffer to be filled is supplied, along with the number of bytes the buffer can hold. The callback may choose to supply less data and modify the byte count but must be careful not to overflow the buffer. The callback then returns a status code chosen from FLAC__StreamDecoderReadStatus.
    • Write callback - This function will be called when the decoder has decoded a single frame of data. The decoder will pass the frame metadata as well as an array of pointers (one for each channel) pointing to the decoded audio.
    • -
    • Metadata callback - This function will be called when the decoder has decoded a metadata block. There will always be one STREAMINFO block per stream, followed by zero or more other metadata blocks. These will be supplied by the decoder in the same order as they appear in the stream and always before the first audio frame. The metadata block that is passed in must not be modified, and it doesn't live beyond the callback, so you should make a copy of it with FLAC__metadata_object_clone() if you will need it elsewhere.
    • +
    • Metadata callback - This function will be called when the decoder has decoded a metadata block. There will always be one STREAMINFO block per stream, followed by zero or more other metadata blocks. These will be supplied by the decoder in the same order as they appear in the stream and always before the first audio frame (i.e. write callback). The metadata block that is passed in must not be modified, and it doesn't live beyond the callback, so you should make a copy of it with FLAC__metadata_object_clone() if you will need it elsewhere. Since metadata blocks can potentially be large, you can instruct the decoder to pass or filter blocks with FLAC__stream_decoder_set_metadata_*() calls.
    • Error callback - This function will be called whenever an error occurs during decoding.

    - Once the decoder is initialized, the program will call one of several functions to stimulate the decoding process: + Once the decoder is initialized, your program will call one of several functions to start the decoding process:

    • FLAC__stream_decoder_process_whole_stream() - Tells the decoder to start and continue processing the stream until the read callback says FLAC__STREAM_DECODER_READ_END_OF_STREAM or FLAC__STREAM_DECODER_READ_ABORT.
    • FLAC__stream_decoder_process_metadata() - Tells the decoder to start processing the stream and stop upon reaching the first audio frame.
    • @@ -948,9 +948,7 @@
    • min_residual_partition_order, max_residual_partition_order - 0 to estimate Rice parameter based on residual variance; > 0 to partition the residual and use parameter for each based on mean; min_residual_partition_order and max_residual_partition_order specify the min and max Rice partition order.
    • rice_parameter_search_dist - 0 to try only calculated parameter k; else try all [k-rice_parameter_search_dist..k+rice_parameter_search_dist] parameters and use the best.
    • total_samples_estimate - May be set to 0 if unknown. Otherwise, set this to the number of samples to be encoded. This will allow the STREAMINFO block to be more accurate during the first pass in the event that the encoder can't seek back to the beginning of the output file to write the updated STREAMINFO block.
    • -
    • seek_table - Optional seek table to prepend; NULL implies no seek table.
    • -
    • padding - Length of PADDING block to add (goes after seek table); -1 implies do not add a PADDING block. Remember that this is length of the padding; the length of the overall PADDING block will be 4 bytes larger because of the metadata block header.
    • -
    • last_metadata_is_last - The value the encoder will use for the 'is_last' flag of the last metadata block it writes. In normal usage you would set this to true, but if you will be manually inserting more metadata blocks between the time of the first write callback (when the encoder sends the fLaC header and metadata) and the time actual audio encoding starts then set this to false.
    • +
    • metadata - Optional array of pointers to metadata blocks to be written; NULL implies no metadata. The STREAMINFO block is always written automatically and must not be present in the array of pointers.

    @@ -981,13 +979,35 @@ METADATA

    - For programs that write their own APPLICATION metadata, it is advantageous to instruct the encoder to write a PADDING block of the correct size, so that instead of rewriting the whole stream after encoding, the program can just overwrite the PADDING block. If only the maximum size of the APPLICATION block is known, the program can write a slightly larger padding block, then split it after encoding into an APPLICATION block and a PADDING block. + For programs that write their own metadata, but that do not know the actual metadata until after encoding, it is advantageous to instruct the encoder to write a PADDING block of the correct size, so that instead of rewriting the whole stream after encoding, the program can just overwrite the PADDING block. If only the maximum size of the metadata is known, the program can write a slightly larger padding block, then split it after encoding.

    - In the case where the size of the APPLICATION block data is known ahead of time, the required size of the padding block can be easily calculated. If the APPLICATION block data length in bytes (not including the APPLICATION metadata block header) is N bytes, the size given to the FLAC__StreamEncoder instance before initialization is simply N+4. This accounts for the extra space needed to store the APPLICATION ID. + Make sure you understand how lengths are calculated. All FLAC metadata blocks have a 4 byte header which contains the type and length. This length does not include the 4 bytes of the header. See the format page for the specification of metadata blocks and their lengths.

    +
    +
    +
    +
    + + + +
    +
    + + +
    + libFLAC++ +
    +
    + + @@ -1017,10 +1037,7 @@

    • - Encoding/decoding with flac through pipes on Windows, using the binary distribution, will corrupt piped data. This has been fixed in CVS. This bug does not occur if you are compiling the source using Cygwin. Use the -V option on Windows to verify that pipes are working in your configuration. -
    • -
    • - If you build flac from sources without Ogg support, or are using a binary built without Ogg support, encoding may yield a FLAC file with an invalid seek table. The 1.0.2 binary releases, except the Darwin release, do not have this problem, since they are built with Ogg support. This bug has been fixed in CVS. This will not affect the integrity of the audio data, but may increase the seek time during playback. You can use metaflac to verify the integrity of existing files' seek tables. + There are no known bugs.
    • @@ -1059,7 +1076,7 @@

    - If you like this little hack, make sure to ask Matt (the author) to add FLAC support officially! Also, other front-ends may be wedged in the same way; if you have one in mind, post it to the flac-dev mailing list. + Other front-ends may be wedged in the same way; if you have one in mind, post it to the flac-dev mailing list.

    diff --git a/doc/download.html b/doc/download.html index 6edaf88..b1eaa6d 100644 --- a/doc/download.html +++ b/doc/download.html @@ -111,8 +111,9 @@
  • Windows
  • diff --git a/doc/features.html b/doc/features.html index cdae8dd..8ca9c48 100644 --- a/doc/features.html +++ b/doc/features.html @@ -82,13 +82,14 @@

    • the stream format
    • -
    • libFLAC, a library which implements reference encoders and decoders
    • +
    • libFLAC, a library of reference encoders and decoders, and a metadata interface
    • +
    • libFLAC++, an object wrapper around libFLAC
    • flac, a command-line wrapper around libFLAC to encode and decode .flac files
    • input plugins for various music players (Winamp, XMMS, and more in the works)

    - "Free" means that the specification of the stream format is in the public domain (the FLAC project reserves the right to set the FLAC specification and certify compliance), and that neither the FLAC format nor any of the implemented encoding/decoding methods are covered by any patent. It also means that the source for libFLAC is available under the LGPL and the sources for flac and the plugins are available under the GPL. + "Free" means that the specification of the stream format is in the public domain (the FLAC project reserves the right to set the FLAC specification and certify compliance), and that neither the FLAC format nor any of the implemented encoding/decoding methods are covered by any patent. It also means that the sources for libFLAC and libFLAC++ are available under the LGPL and the sources for flac and the plugins are available under the GPL.

    FLAC compiles on many platforms: most Unixes (Linux, *BSD, Solaris, OS X), Windows, BeOS, and OS/2. There are build systems for autoconf/automake, MSVC, Watcom C, and Project Builder. diff --git a/doc/index.html b/doc/index.html index e98e333..9486334 100644 --- a/doc/index.html +++ b/doc/index.html @@ -106,13 +106,14 @@

    • the stream format
    • -
    • libFLAC, which implements reference encoders and decoders
    • +
    • libFLAC, a library of reference encoders and decoders, and a metadata interface
    • +
    • libFLAC++, an object wrapper around libFLAC
    • flac, a command-line wrapper around libFLAC to encode and decode .flac files
    • input plugins for various music players (Winamp, XMMS, and more in the works)

    - "Free" means that the specification of the stream format is in the public domain (the FLAC project reserves the right to set the FLAC specification and certify compliance), and that neither the FLAC format nor any of the implemented encoding/decoding methods are covered by any patent. It also means that the source for libFLAC is available under the LGPL and the sources for flac and the plugins are available under the GPL. + "Free" means that the specification of the stream format is in the public domain (the FLAC project reserves the right to set the FLAC specification and certify compliance), and that neither the FLAC format nor any of the implemented encoding/decoding methods are covered by any patent. It also means that the sources for libFLAC and libFLAC++ are available under the LGPL and the sources for flac and the plugins are available under the GPL.

    FLAC compiles on many platforms: most Unixes (Linux, *BSD, Solaris, OS X), Windows, BeOS, and OS/2. There are build systems for autoconf/automake, MSVC, Watcom C, and Project Builder. -- 2.7.4

  • - In the case where only the maximum size is known, say, to be N bytes, the required padding size would be N+8. Four for the APPLICATION ID as before, and four for the extra PADDING block that will fill up the remainder. At the end of the encoding, when the APPLICATION block data length is known, say, to be M bytes, the original PADDING block would be overwritten with the APPLICATION block and a PADDING block of size N-M. + libFLAC++ is a C++ object wrapper around libFLAC. It provides classed for the encoders and decoders as well as the metadata interface. +

    +

    + The documentation for libFLAC++ is currently being rewritten. As a wrapper it is actually quite simple. The method names and semantics generally follow those in the C layer and comments in the header files specify where there are differences.