sandboxed-api/sandboxed_api/sandbox2/util/file_helpers.cc
Christian Blichmann f6c3db4c6e Replace sapi::Status with absl::Status
PiperOrigin-RevId: 297614681
Change-Id: I89fe1357a172ed4d28df6dd84b80fee364ce1c14
2020-02-27 09:24:12 -08:00

59 lines
1.9 KiB
C++

// Copyright 2019 Google LLC
//
// 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.
#include "sandboxed_api/sandbox2/util/file_helpers.h"
#include <fstream>
#include <sstream>
#include "absl/status/status.h"
#include "absl/strings/str_cat.h"
namespace sandbox2 {
namespace file {
const Options& Defaults() {
static auto* instance = new Options{};
return *instance;
}
absl::Status GetContents(absl::string_view path, std::string* output,
const file::Options& options) {
std::ifstream in_stream{std::string(path), std::ios_base::binary};
std::ostringstream out_stream;
out_stream << in_stream.rdbuf();
if (!in_stream || !out_stream) {
return absl::UnknownError(absl::StrCat("Error during read: ", path));
}
*output = out_stream.str();
return absl::OkStatus();
}
absl::Status SetContents(absl::string_view path, absl::string_view content,
const file::Options& options) {
std::ofstream out_stream(std::string(path),
std::ios_base::trunc | std::ios_base::binary);
if (!out_stream) {
return absl::UnknownError(absl::StrCat("Failed to open file: ", path));
}
out_stream.write(content.data(), content.size());
if (!out_stream) {
return absl::UnknownError(absl::StrCat("Error during write: ", path));
}
return absl::OkStatus();
}
} // namespace file
} // namespace sandbox2