chromium/third_party/mediapipe/src/mediapipe/framework/formats/deleting_file.h

// 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 <string>

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;

  // DeletingFile is movable. The moved-from object remains in valid but
  // unspecified state and will not perform any operations on destruction.
  DeletingFile(DeletingFile&& other);
  DeletingFile& operator=(DeletingFile&& other);

  // 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_