summaryrefslogtreecommitdiff
path: root/libcutl/cutl/fs/auto-remove.cxx
diff options
context:
space:
mode:
authorJörg Frings-Fürst <debian@jff.email>2025-05-02 07:42:02 +0200
committerJörg Frings-Fürst <debian@jff.email>2025-05-02 07:42:02 +0200
commitfc486627a4ecbae797fa6856d8a9204ea85f4db8 (patch)
treeff3dae4c0e5d980d8e2da4fc6256ae839269bbcd /libcutl/cutl/fs/auto-remove.cxx
parent1c188393cd2e271ed2581471b601fb5960777fd8 (diff)
parentecba0bbd9947036dd82f16ab95252f8db445e149 (diff)
Merge tag 'debian/4.0.0-10' into developdevelop
Bugfix release
Diffstat (limited to 'libcutl/cutl/fs/auto-remove.cxx')
-rw-r--r--libcutl/cutl/fs/auto-remove.cxx37
1 files changed, 37 insertions, 0 deletions
diff --git a/libcutl/cutl/fs/auto-remove.cxx b/libcutl/cutl/fs/auto-remove.cxx
new file mode 100644
index 0000000..c790c29
--- /dev/null
+++ b/libcutl/cutl/fs/auto-remove.cxx
@@ -0,0 +1,37 @@
+// file : cutl/fs/auto-remove.cxx
+// copyright : Copyright (c) 2009-2013 Code Synthesis Tools CC
+// license : MIT; see accompanying LICENSE file
+
+#include <cstdio> // std::remove
+#include <cerrno>
+
+#include <cutl/fs/auto-remove.hxx>
+
+namespace cutl
+{
+ namespace fs
+ {
+ auto_remove::
+ ~auto_remove ()
+ {
+ if (!canceled_)
+ {
+ if (std::remove (path_.string ().c_str ()) == -1)
+ throw error (errno);
+ }
+ }
+
+ auto_removes::
+ ~auto_removes ()
+ {
+ if (!canceled_)
+ {
+ for (paths::iterator i (paths_.begin ()); i != paths_.end (); ++i)
+ {
+ if (std::remove (i->string ().c_str ()) == -1)
+ throw error (errno);
+ }
+ }
+ }
+ }
+}