#include <glibmm/fileutils.h>
#include <glibmm/miscutils.h>
-#include <pbd/filesystem.h>
-#include <pbd/error.h>
-#include <pbd/compose.h>
+#include "pbd/filesystem.h"
+#include "pbd/error.h"
+#include "pbd/compose.h"
#include "i18n.h"
+using namespace std;
+
namespace PBD {
namespace sys {
return *this;
}
+string
+path::leaf () const
+{
+ return Glib::path_get_basename(m_path);
+}
+
path
path::branch_path () const
{
return true;
}
+void
+rename (const path & from_path, const path & to_path)
+{
+ // g_rename is a macro that evaluates to ::rename on
+ // POSIX systems, without the global namespace qualifier
+ // it would evaluate to a recursive call(if it compiled)
+ if ( ::g_rename( from_path.to_string().c_str(),
+ to_path.to_string().c_str() ) == -1 )
+ {
+ throw filesystem_error(g_strerror(errno), errno);
+ }
+}
+
+// XXX character encoding.
void
copy_file(const path & from_path, const path & to_path)
{
- // this implementation could use mucho memory
- // for big files.
std::ifstream in(from_path.to_string().c_str());
std::ofstream out(to_path.to_string().c_str());
out << in.rdbuf();
if (!in || !out) {
+ remove (to_path);
throw filesystem_error(string_compose(_("Could not copy existing file %1 to %2"),
from_path.to_string(), to_path.to_string()));
- remove (to_path);
}
}
string
basename (const path & p)
{
- string base = Glib::path_get_basename (p.to_string());
+ string base(p.leaf());
string::size_type n = base.rfind ('.');
return base.substr (0, n);
}
+string
+extension (const path & p)
+{
+ string base(p.leaf());
+
+ string::size_type n = base.rfind ('.');
+
+ if (n != string::npos)
+ {
+ return base.substr(n);
+ }
+
+ return string();
+
+}
+
} // namespace sys
} // namespace PBD