no dot prefix for VST cache files on windows.
[ardour.git] / libs / ardour / sndfile_helpers.cc
index 057efff48c4751bbc302942d93c166d37cbac831..2e618e043bb3b5cba8f52a297ff9ab5a1f00373c 100644 (file)
 
 */
 
+#ifndef COMPILER_MSVC
+#include <strings.h>
+#endif
 #include <map>
-#include <vector>
-
-#include "pbd/convert.h"
 
 #include <sndfile.h>
 #include "ardour/sndfile_helpers.h"
@@ -81,7 +81,7 @@ int sndfile_bitdepth_formats[SNDFILE_BITDEPTH_FORMATS] = {
 
 const char * const sndfile_endian_formats_strings[SNDFILE_ENDIAN_FORMATS+1] = {
        N_("Little-endian (Intel)"),
-       N_("Big-endian (Mac)"),
+       N_("Big-endian (PowerPC)"),
        0
 };
 
@@ -91,55 +91,32 @@ int sndfile_endian_formats[SNDFILE_ENDIAN_FORMATS] = {
 };
 
 int
-sndfile_header_format_from_string (string str)
+sndfile_header_format_by_index (int index)
 {
-       for (int n = 0; sndfile_header_formats_strings[n]; ++n) {
-               if (str == sndfile_header_formats_strings[n]) {
-                       return sndfile_header_formats[n];
-               }
+        if (index >= 0 && index < SNDFILE_HEADER_FORMATS) {
+                return sndfile_header_formats[index];
        }
        return -1;
 }
 
 int
-sndfile_bitdepth_format_from_string (string str)
+sndfile_bitdepth_format_by_index (int index)
 {
-       for (int n = 0; sndfile_bitdepth_formats_strings[n]; ++n) {
-               if (str == sndfile_bitdepth_formats_strings[n]) {
-                       return sndfile_bitdepth_formats[n];
-               }
+        if (index >= 0 && index < SNDFILE_BITDEPTH_FORMATS) {
+                return sndfile_bitdepth_formats[index];
        }
        return -1;
 }
 
 int
-sndfile_endian_format_from_string (string str)
+sndfile_endian_format_by_index (int index)
 {
-       for (int n = 0; sndfile_endian_formats_strings[n]; ++n) {
-               if (str == sndfile_endian_formats_strings[n]) {
-                       return sndfile_endian_formats[n];
-               }
+        if (index >= 0 && index < SNDFILE_ENDIAN_FORMATS) {
+                return sndfile_endian_formats[index];
        }
        return -1;
 }
 
-string
-sndfile_file_ending_from_string (string str)
-{
-       static vector<string> file_endings;
-
-       if (file_endings.empty()) {
-               file_endings = I18N((const char **) sndfile_file_endings_strings);
-       }
-
-       for (int n = 0; sndfile_header_formats_strings[n]; ++n) {
-               if (str == sndfile_header_formats_strings[n]) {
-                       return file_endings[n];
-               }
-       }
-       return 0;
-}
-
 int
 sndfile_data_width (int format)
 {
@@ -177,6 +154,16 @@ sndfile_major_format(int format)
                        sf_command (0, SFC_GET_FORMAT_MAJOR,
                                        &format_info, sizeof (format_info));
                        m[format_info.format & SF_FORMAT_TYPEMASK] = format_info.name;
+
+                        /* normalize a couple of names rather than use what libsndfile gives us */
+
+                        if (strncasecmp (format_info.name, "OGG", 3) == 0) {
+                                m[format_info.format & SF_FORMAT_TYPEMASK] = "Ogg";
+                        } else if (strncasecmp (format_info.name, "WAV", 3) == 0) {
+                                m[format_info.format & SF_FORMAT_TYPEMASK] = "WAV";
+                        } else {
+                                m[format_info.format & SF_FORMAT_TYPEMASK] = format_info.name;
+                        }
                }
        }