timemory 3.3.0
Modular C++ Toolkit for Performance Analysis and Logging. Profiling API and Tools for C, C++, CUDA, Fortran, and Python. The C++ template API is essentially a framework to creating tools: it is designed to provide a unifying interface for recording various performance measurements alongside data logging and interfaces to other tools.
popen.hpp
Go to the documentation of this file.
1// MIT License
2//
3// Copyright (c) 2020, The Regents of the University of California,
4// through Lawrence Berkeley National Laboratory (subject to receipt of any
5// required approvals from the U.S. Dept. of Energy). All rights reserved.
6//
7// Permission is hereby granted, free of charge, to any person obtaining a copy
8// of this software and associated documentation files (the "Software"), to deal
9// in the Software without restriction, including without limitation the rights
10// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11// copies of the Software, and to permit persons to whom the Software is
12// furnished to do so, subject to the following conditions:
13//
14// The above copyright notice and this permission notice shall be included in all
15// copies or substantial portions of the Software.
16//
17// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23// SOFTWARE.
24//
25
26#pragma once
27
30
31#if !defined(TIMEMORY_WINDOWS)
32
33# include <cerrno>
34# include <cstdio>
35# include <cstdlib>
36# include <cstring>
37# include <ctime>
38# include <fcntl.h>
39# include <grp.h>
40# include <limits>
41# include <ostream>
42# include <paths.h>
43# include <sstream>
44# include <string>
45# include <sys/param.h>
46# include <sys/stat.h>
47# include <sys/types.h>
48# include <sys/wait.h>
49# include <unistd.h>
50# include <vector>
51
52namespace tim
53{
54namespace popen
55{
56//
58using strvec_t = std::vector<string_t>;
59//
61{
62 FILE* read_fd = nullptr;
63 FILE* write_fd = nullptr;
64 pid_t child_pid;
66};
67//
69popen(const char* path, char** argv = nullptr, char** envp = nullptr);
70//
73//
75fork();
76//
79//
81open_devnull(int fd);
82//
84drop_privileges(int permanent);
85//
86TIMEMORY_UTILITY_LINKAGE(void) // NOLINT
88//
91//
93flush_output(std::ostream& os, TIMEMORY_PIPE* proc, int max_counter = 0);
94//
95//--------------------------------------------------------------------------------------//
96//
97} // namespace popen
98} // namespace tim
99
100# if !defined(TIMEMORY_UTILITY_SOURCE) && !defined(TIMEMORY_USE_UTILITY_EXTERN)
102# endif
103
104#endif
STL namespace.
::tim::statistics< Tp > max(::tim::statistics< Tp > lhs, const Tp &rhs)
Definition: statistics.hpp:320
TIMEMORY_UTILITY_LINKAGE(TIMEMORY_PIPE *) popen(const char *path
char char ** envp
Definition: popen.hpp:69
void drop_privileges(int permanent)
Definition: popen.cpp:75
TIMEMORY_PIPE * popen(const char *path, char **argv, char **envp)
Definition: popen.cpp:229
int max_counter
Definition: popen.hpp:90
void restore_privileges()
Definition: popen.cpp:148
std::ostream & flush_output(std::ostream &os, TIMEMORY_PIPE *proc, int max_counter)
Definition: popen.cpp:426
std::vector< string_t > strvec_t
Definition: popen.hpp:58
void sanitize_files()
Definition: popen.cpp:181
int open_devnull(int fd)
Definition: popen.cpp:165
std::string string_t
Definition: popen.hpp:57
int pclose(TIMEMORY_PIPE *p)
Definition: popen.cpp:327
strvec_t read_fork(TIMEMORY_PIPE *proc, int max_counter)
Definition: popen.cpp:385
pid_t fork()
Definition: popen.cpp:208
char ** argv
Definition: popen.hpp:69
Definition: kokkosp.cpp:39
tim::mpl::apply< std::string > string
Definition: macros.hpp:53
const std::string std::ostream * os