Skeleton tests for BBT_Time.
[ardour.git] / libs / ardour / sndfile_helpers.cc
index b308a74c36cf6ff93f63a540042a2a605822eda7..057efff48c4751bbc302942d93c166d37cbac831 100644 (file)
@@ -1,10 +1,29 @@
+/*
+    Copyright (C) 2000-2007 Paul Davis
+
+    This program is free software; you can redistribute it and/or modify
+    it under the terms of the GNU General Public License as published by
+    the Free Software Foundation; either version 2 of the License, or
+    (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU General Public License for more details.
+
+    You should have received a copy of the GNU General Public License
+    along with this program; if not, write to the Free Software
+    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+*/
+
 #include <map>
 #include <vector>
 
-#include <pbd/convert.h>
+#include "pbd/convert.h"
 
 #include <sndfile.h>
-#include <ardour/sndfile_helpers.h>
+#include "ardour/sndfile_helpers.h"
 
 #include "i18n.h"
 
@@ -14,41 +33,41 @@ using namespace std;
 const char * const sndfile_header_formats_strings[SNDFILE_HEADER_FORMATS+1] = {
        N_("WAV"),
        N_("AIFF"),
-       N_("raw (no header)"),
-       N_("PAF (Ensoniq Paris)"),
-       N_("AU (Sun/NeXT)"),
-       N_("IRCAM"),
+       N_("CAF"),
        N_("W64 (64 bit WAV)"),
+       N_("FLAC"),
+       N_("Ogg/Vorbis"),
+       N_("raw (no header)"),
        0
 };
 
 const char* const sndfile_file_endings_strings[SNDFILE_HEADER_FORMATS+1] = {
        N_(".wav"),
        N_(".aiff"),
-       N_(".raw"),
-       N_(".paf"),
-       N_(".au"),
-       N_(".ircam"),
+       N_(".caf"),
        N_(".w64"),
+       N_(".flac"),
+       N_(".ogg"),
+       N_(".raw"),
        0
 };
 
 int sndfile_header_formats[SNDFILE_HEADER_FORMATS] = {
        SF_FORMAT_WAV,
        SF_FORMAT_AIFF,
-       SF_FORMAT_RAW,
-       SF_FORMAT_PAF,
-       SF_FORMAT_AU,
-       SF_FORMAT_IRCAM,
-       SF_FORMAT_W64
+       SF_FORMAT_CAF,
+       SF_FORMAT_W64,
+       SF_FORMAT_FLAC,
+       SF_FORMAT_OGG,
+       SF_FORMAT_RAW
 };
 
 const char * const sndfile_bitdepth_formats_strings[SNDFILE_BITDEPTH_FORMATS+1] = {
-       N_("16 bit"),
-       N_("24 bit"),
-       N_("32 bit"),
-       N_("8 bit"),
-       N_("float"),
+       N_("Signed 16 bit PCM"),
+       N_("Signed 24 bit PCM"),
+       N_("Signed 32 bit PCM"),
+       N_("Signed 8 bit PCM"),
+       N_("32 bit float"),
        0
 };
 
@@ -110,7 +129,7 @@ sndfile_file_ending_from_string (string str)
        static vector<string> file_endings;
 
        if (file_endings.empty()) {
-               file_endings = PBD::internationalize((const char **) sndfile_file_endings_strings);
+               file_endings = I18N((const char **) sndfile_file_endings_strings);
        }
 
        for (int n = 0; sndfile_header_formats_strings[n]; ++n) {
@@ -144,7 +163,7 @@ sndfile_data_width (int format)
        }
 }
 
-string 
+string
 sndfile_major_format(int format)
 {
        static map<int, string> m;
@@ -155,12 +174,12 @@ sndfile_major_format(int format)
                sf_command(0, SFC_GET_FORMAT_MAJOR_COUNT, &count, sizeof (int));
                for (int i = 0; i < count; ++i){
                        format_info.format = i;
-                       sf_command (0, SFC_GET_FORMAT_MAJOR, 
+                       sf_command (0, SFC_GET_FORMAT_MAJOR,
                                        &format_info, sizeof (format_info));
                        m[format_info.format & SF_FORMAT_TYPEMASK] = format_info.name;
                }
        }
-       
+
        map<int, string>::iterator p = m.find(format & SF_FORMAT_TYPEMASK);
        if(p != m.end()){
                return m[format & SF_FORMAT_TYPEMASK];
@@ -180,12 +199,12 @@ sndfile_minor_format(int format)
                sf_command(0, SFC_GET_FORMAT_SUBTYPE_COUNT, &count, sizeof (int));
                for (int i = 0; i < count; ++i){
                        format_info.format = i;
-                       sf_command (0, SFC_GET_FORMAT_SUBTYPE, 
+                       sf_command (0, SFC_GET_FORMAT_SUBTYPE,
                                        &format_info, sizeof (format_info));
                        m[format_info.format & SF_FORMAT_SUBMASK] = format_info.name;
                }
        }
-       
+
        map<int, string>::iterator p = m.find(format & SF_FORMAT_SUBMASK);
        if(p != m.end()){
                return m[format & SF_FORMAT_SUBMASK];