// Copyright 2019 The MediaPipe Authors. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // // Declares DeletingFile. #ifndef MEDIAPIPE_FRAMEWORK_FORMATS_DELETING_FILE_H_ #define MEDIAPIPE_FRAMEWORK_FORMATS_DELETING_FILE_H_ #include namespace mediapipe { // A DeletingFile conveys the path to a file and takes care of cleanup // (generally deletion of a file if it is a local temporary). class DeletingFile { public: DeletingFile(const DeletingFile&) = delete; DeletingFile& operator=(const DeletingFile&) = delete; // Provide the path to the file and whether the file should be deleted // when this object is destroyed. DeletingFile(const std::string& path, bool delete_on_destruction); // Takes care of cleaning up the file (deletes it if // delete_on_destruction was true on construction, otherwise leaves // it alone). virtual ~DeletingFile(); // Return the path to the file. const std::string& Path() const; private: std::string path_; bool delete_on_destruction_; }; } // namespace mediapipe #endif // MEDIAPIPE_FRAMEWORK_FORMATS_DELETING_FILE_H_