Commit 84a38b9c authored by Brenden Blanco's avatar Brenden Blanco Committed by GitHub

Merge pull request #1170 from palmtenor/filedesc

Move FileDesc to separated header file and install
parents b493aa6c 30591ebc
...@@ -67,7 +67,9 @@ target_link_libraries(bcc-static b_frontend clang_frontend bcc-loader-static ${c ...@@ -67,7 +67,9 @@ target_link_libraries(bcc-static b_frontend clang_frontend bcc-loader-static ${c
install(TARGETS bcc-shared LIBRARY COMPONENT libbcc install(TARGETS bcc-shared LIBRARY COMPONENT libbcc
DESTINATION ${CMAKE_INSTALL_LIBDIR}) DESTINATION ${CMAKE_INSTALL_LIBDIR})
install(FILES bpf_common.h bpf_module.h bcc_syms.h bcc_exception.h libbpf.h perf_reader.h BPF.h BPFTable.h shared_table.h table_desc.h table_storage.h COMPONENT libbcc install(FILES bpf_common.h bpf_module.h bcc_syms.h bcc_exception.h file_desc.h
libbpf.h perf_reader.h BPF.h BPFTable.h shared_table.h
table_desc.h table_storage.h COMPONENT libbcc
DESTINATION include/bcc) DESTINATION include/bcc)
install(DIRECTORY compat/linux/ COMPONENT libbcc install(DIRECTORY compat/linux/ COMPONENT libbcc
DESTINATION include/bcc/compat/linux DESTINATION include/bcc/compat/linux
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
*/ */
#include <fstream> #include <fstream>
#include <sstream> #include <sstream>
#include <unistd.h>
#include "common.h" #include "common.h"
...@@ -49,37 +48,4 @@ std::vector<int> get_possible_cpus() { ...@@ -49,37 +48,4 @@ std::vector<int> get_possible_cpus() {
return read_cpu_range("/sys/devices/system/cpu/possible"); return read_cpu_range("/sys/devices/system/cpu/possible");
} }
FileDesc::FileDesc(int fd) : fd_(fd) {}
FileDesc::FileDesc(FileDesc &&that) : fd_(-1) { *this = std::move(that); }
FileDesc::~FileDesc() {
if (fd_ >= 0)
::close(fd_);
}
FileDesc &FileDesc::operator=(int fd) {
if (fd_ >= 0)
::close(fd_);
fd_ = fd;
return *this;
}
FileDesc &FileDesc::operator=(FileDesc &&that) {
if (fd_ >= 0)
::close(fd_);
fd_ = that.fd_;
that.fd_ = -1;
return *this;
}
FileDesc FileDesc::dup() const {
int dup_fd = ::dup(fd_);
return FileDesc(dup_fd);
}
FileDesc::operator int() { return fd_; }
FileDesc::operator int() const { return fd_; }
} // namespace ebpf } // namespace ebpf
...@@ -17,8 +17,6 @@ ...@@ -17,8 +17,6 @@
#pragma once #pragma once
#include <memory> #include <memory>
#include <string>
#include <tuple>
#include <vector> #include <vector>
namespace ebpf { namespace ebpf {
...@@ -33,27 +31,4 @@ std::vector<int> get_online_cpus(); ...@@ -33,27 +31,4 @@ std::vector<int> get_online_cpus();
std::vector<int> get_possible_cpus(); std::vector<int> get_possible_cpus();
/// FileDesc is a helper class for managing open file descriptors. Copy is
/// disallowed (call dup instead), and cleanup happens automatically.
class FileDesc {
public:
explicit FileDesc(int fd = -1);
FileDesc(FileDesc &&that);
FileDesc(const FileDesc &that) = delete;
~FileDesc();
FileDesc &operator=(int fd);
FileDesc &operator=(FileDesc &&that);
FileDesc &operator=(const FileDesc &that) = delete;
operator int();
operator int() const;
FileDesc dup() const;
private:
int fd_;
};
} // namespace ebpf } // namespace ebpf
/*
* Copyright (c) 2017 Facebook, Inc.
*
* 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.
*/
#pragma once
#include <unistd.h>
namespace ebpf {
/// FileDesc is a helper class for managing open file descriptors. Copy is
/// disallowed (call dup instead), and cleanup happens automatically.
class FileDesc {
public:
explicit FileDesc(int fd = -1) : fd_(fd) {}
FileDesc(FileDesc &&that) : fd_(-1) { *this = std::move(that); }
FileDesc(const FileDesc &that) = delete;
~FileDesc() {
if (fd_ >= 0)
::close(fd_);
}
FileDesc &operator=(int fd) {
if (fd_ >= 0)
::close(fd_);
fd_ = fd;
return *this;
}
FileDesc &operator=(FileDesc &&that) {
if (fd_ >= 0)
::close(fd_);
fd_ = that.fd_;
that.fd_ = -1;
return *this;
}
FileDesc &operator=(const FileDesc &that) = delete;
FileDesc dup() const {
int dup_fd = ::dup(fd_);
return FileDesc(dup_fd);
}
operator int() { return fd_; }
operator int() const { return fd_; }
private:
int fd_;
};
} // namespace ebpf
...@@ -33,8 +33,8 @@ ...@@ -33,8 +33,8 @@
#include <llvm/IR/Module.h> #include <llvm/IR/Module.h>
#include "bcc_exception.h" #include "bcc_exception.h"
#include "common.h"
#include "codegen_llvm.h" #include "codegen_llvm.h"
#include "file_desc.h"
#include "lexer.h" #include "lexer.h"
#include "libbpf.h" #include "libbpf.h"
#include "linux/bpf.h" #include "linux/bpf.h"
......
...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
#include <unordered_set> #include <unordered_set>
#include <vector> #include <vector>
#include "common.h" #include "file_desc.h"
class ProcStat { class ProcStat {
std::string procfs_; std::string procfs_;
......
...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
#include <string> #include <string>
#include "bcc_exception.h" #include "bcc_exception.h"
#include "common.h" #include "file_desc.h"
namespace clang { namespace clang {
class ASTContext; class ASTContext;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment