diff options
author | Jörg Frings-Fürst <debian@jff.email> | 2025-05-02 07:42:02 +0200 |
---|---|---|
committer | Jörg Frings-Fürst <debian@jff.email> | 2025-05-02 07:42:02 +0200 |
commit | fc486627a4ecbae797fa6856d8a9204ea85f4db8 (patch) | |
tree | ff3dae4c0e5d980d8e2da4fc6256ae839269bbcd /libcutl/cutl/fs/auto-remove.cxx | |
parent | 1c188393cd2e271ed2581471b601fb5960777fd8 (diff) | |
parent | ecba0bbd9947036dd82f16ab95252f8db445e149 (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.cxx | 37 |
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); + } + } + } + } +} |