Mercurial > minori
view dep/animia/src/fd/xnu.cc @ 187:9613d72b097e
*: multiple performance improvements
   like marking `static const` when it makes sense...
date: change old stupid heap-based method to a structure which should
      make copying the thing actually make a copy.
      also many performance-based changes, like removing the std::tie
      dependency and forward-declaring nlohmann json
*: replace every instance of QString::fromUtf8 to Strings::ToQString.
   the main difference is that our function will always convert exactly
   what is in the string, while some other times it would only convert
   up to the nearest NUL byte
| author | Paper <mrpapersonic@gmail.com> | 
|---|---|
| date | Wed, 06 Dec 2023 13:43:54 -0500 | 
| parents | e44b7c428d7c | 
| children | bc1ae1810855 | 
line wrap: on
 line source
#include "animia/fd/xnu.h" #include "animia/util/osx.h" #include "animia.h" #include <cassert> #include <string> #include <unordered_map> #include <vector> #include <memory> #include <fcntl.h> #include <libproc.h> #include <sys/sysctl.h> #include <sys/types.h> #include <sys/user.h> namespace animia::internal::xnu { bool XnuFdTools::EnumerateOpenProcesses(process_proc_t process_proc) { size_t pids_size = 512; std::unique_ptr<pid_t[]> pids; int returned_size = 0; do { pids.reset(new pid_t[pids_size]); returned_size = proc_listpids(PROC_ALL_PIDS, 0, pids.get(), pids_size * sizeof(pid_t)); if (returned_size == -1) return false; } while ((pids_size * sizeof(size_t)) < returned_size); for (int i = 0; i < pids_size; i++) { std::string result; osx::util::GetProcessName(pids[i], result); if (!process_proc({pids[i], result})) return false; } return true; } bool XnuFdTools::EnumerateOpenFiles(const std::set<pid_t>& pids, open_file_proc_t open_file_proc) { if (!open_file_proc) return false; for (const auto& pid : pids) { int bufsz = proc_pidinfo(pid, PROC_PIDLISTFDS, 0, NULL, 0); if (bufsz == -1) return false; struct proc_fdinfo* info = (struct proc_fdinfo*)malloc(bufsz); if (!info) return false; proc_pidinfo(pid, PROC_PIDLISTFDS, 0, info, bufsz); for (int i = 0; i < bufsz / sizeof(info[0]); i++) { if (info[i].proc_fdtype == PROX_FDTYPE_VNODE) { struct vnode_fdinfowithpath vnodeInfo; int sz = proc_pidfdinfo(pid, info[i].proc_fd, PROC_PIDFDVNODEPATHINFO, &vnodeInfo, PROC_PIDFDVNODEPATHINFO_SIZE); if (sz != PROC_PIDFDVNODEPATHINFO_SIZE) return false; /* this doesn't work! if (vnodeInfo.pfi.fi_openflags & O_WRONLY || vnodeInfo.pfi.fi_openflags & O_RDWR) continue; */ if (!open_file_proc({pid, vnodeInfo.pvip.vip_path})) return false; } } } return true; } } // namespace animia::internal::xnu
