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 ('.');
string
extension (const path & p)
{
- string base = Glib::path_get_basename (p.to_string());
+ string base(p.leaf());
string::size_type n = base.rfind ('.');