For sfdb stuff, use glib file functions in preference to ANSI or libsndfile handling. On Windows, we need functions which understand UTF-8 (so that we'll be able to import sound files, even in a non-English locale).
This commit is contained in:
John Emmas 2015-07-16 12:45:49 +01:00 committed by Robin Gareus
parent 93b90396d2
commit 1a619472ca
3 changed files with 24 additions and 8 deletions

View file

@ -29,7 +29,6 @@
#include <unistd.h> #include <unistd.h>
#include <limits.h> #include <limits.h>
#include <sys/stat.h>
#include <gtkmm/box.h> #include <gtkmm/box.h>
#include <gtkmm/stock.h> #include <gtkmm/stock.h>
@ -1255,8 +1254,8 @@ SoundFileBrowser::get_paths ()
vector<string>::iterator i; vector<string>::iterator i;
for (i = filenames.begin(); i != filenames.end(); ++i) { for (i = filenames.begin(); i != filenames.end(); ++i) {
struct stat buf; GStatBuf buf;
if ((!stat((*i).c_str(), &buf)) && S_ISREG(buf.st_mode)) { if ((!g_stat((*i).c_str(), &buf)) && S_ISREG(buf.st_mode)) {
results.push_back (*i); results.push_back (*i);
} }
} }
@ -1590,7 +1589,7 @@ SoundFileOmega::check_link_status (const Session* s, const vector<string>& paths
std::string tmpdir(Glib::build_filename (s->session_directory().sound_path(), "linktest")); std::string tmpdir(Glib::build_filename (s->session_directory().sound_path(), "linktest"));
bool ret = false; bool ret = false;
if (mkdir (tmpdir.c_str(), 0744)) { if (g_mkdir (tmpdir.c_str(), 0744)) {
if (errno != EEXIST) { if (errno != EEXIST) {
return false; return false;
} }
@ -1614,7 +1613,7 @@ SoundFileOmega::check_link_status (const Session* s, const vector<string>& paths
ret = true; ret = true;
out: out:
rmdir (tmpdir.c_str()); g_rmdir (tmpdir.c_str());
return ret; return ret;
#endif #endif
} }

View file

@ -24,6 +24,9 @@
#include "pbd/error.h" #include "pbd/error.h"
#include "ardour/sndfileimportable.h" #include "ardour/sndfileimportable.h"
#include <fcntl.h>
#include <glib/gstdio.h>
using namespace ARDOUR; using namespace ARDOUR;
using namespace std; using namespace std;
@ -67,8 +70,12 @@ SndFileImportableSource::get_timecode_info (SNDFILE* sf, SF_BROADCAST_INFO* binf
SndFileImportableSource::SndFileImportableSource (const string& path) SndFileImportableSource::SndFileImportableSource (const string& path)
{ {
int fd;
if ((-1) == (fd = g_open (path.c_str(), O_RDONLY, 0664)))
throw failed_constructor();
memset(&sf_info, 0 , sizeof(sf_info)); memset(&sf_info, 0 , sizeof(sf_info));
in.reset( sf_open(path.c_str(), SFM_READ, &sf_info), sf_close); in.reset( sf_open_fd(fd, SFM_READ, &sf_info, true), sf_close);
if (!in) throw failed_constructor(); if (!in) throw failed_constructor();
SF_BROADCAST_INFO binfo; SF_BROADCAST_INFO binfo;

View file

@ -28,6 +28,8 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <glib/gstdio.h>
#ifdef PLATFORM_WINDOWS #ifdef PLATFORM_WINDOWS
#include <glibmm/convert.h> #include <glibmm/convert.h>
#endif #endif
@ -39,6 +41,8 @@
#include "ardour/utils.h" #include "ardour/utils.h"
#include "ardour/session.h" #include "ardour/session.h"
#include <fcntl.h>
#include "i18n.h" #include "i18n.h"
using namespace std; using namespace std;
@ -921,11 +925,17 @@ SndFileSource::get_soundfile_info (const string& path, SoundFileInfo& info, stri
SNDFILE *sf; SNDFILE *sf;
SF_INFO sf_info; SF_INFO sf_info;
BroadcastInfo binfo; BroadcastInfo binfo;
char errbuf[1024];
int fd;
sf_info.format = 0; // libsndfile says to clear this before sf_open(). sf_info.format = 0; // libsndfile says to clear this before sf_open().
if ((sf = sf_open (const_cast<char*>(path.c_str()), SFM_READ, &sf_info)) == 0) { if ((-1) == (fd = g_open (path.c_str(), O_RDONLY, 0664))) {
char errbuf[256]; sprintf (errbuf, "SndFileSource::get_soundfile_info - cannot open file \"%s\"", path.c_str());
return false;
}
if ((sf = sf_open_fd (fd, SFM_READ, &sf_info, true)) == 0) {
error_msg = sf_error_str (0, errbuf, sizeof (errbuf) - 1); error_msg = sf_error_str (0, errbuf, sizeof (errbuf) - 1);
return false; return false;
} }