/* * Copyright (C) 2017 The Android Open Source Project * * 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. */ #ifndef NETUTILS_UNIQUEFD_H #define NETUTILS_UNIQUEFD_H #include <unistd.h> #include <ostream> #include "netdutils/Fd.h" namespace android { namespace netdutils { // Stricter unique_fd implementation that: // *) Does not implement release() // *) Does not implicitly cast to int // *) Uses a strongly typed wrapper (Fd) for the underlying file descriptor // // Users of UniqueFd should endeavor to treat this as a completely // opaque object. The only code that should interpret the wrapped // value is in Syscalls.h class UniqueFd { public: UniqueFd() = default; UniqueFd(Fd fd) : mFd(fd) {} ~UniqueFd() { reset(); } // Disallow copy UniqueFd(const UniqueFd&) = delete; UniqueFd& operator=(const UniqueFd&) = delete; // Allow move UniqueFd(UniqueFd&& other) { std::swap(mFd, other.mFd); } UniqueFd& operator=(UniqueFd&& other) { std::swap(mFd, other.mFd); return *this; } // Cleanup any currently owned Fd, replacing it with the optional // parameter fd void reset(Fd fd = Fd()); // Implict cast to Fd const operator Fd() const { return mFd; } private: Fd mFd; }; std::ostream& operator<<(std::ostream& os, const UniqueFd& fd); } // namespace netdutils } // namespace android #endif /* NETUTILS_UNIQUEFD_H */