This file is indexed.

/usr/include/raul/Process.hpp is in libraul-dev 0.8.0+dfsg0-0.1+b1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/* This file is part of Raul.
 * Copyright (C) 2007-2009 David Robillard <http://drobilla.net>
 *
 * Raul is free software; you can redistribute it and/or modify it under the
 * terms of the GNU General Public License as published by the Free Software
 * Foundation; either version 2 of the License, or (at your option) any later
 * version.
 *
 * Raul is distributed in the hope that it will be useful, but WITHOUT ANY
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for details.
 *
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
 */

#ifndef RAUL_PROCESS_HPP
#define RAUL_PROCESS_HPP

#include <sys/resource.h>
#include <sys/time.h>
#include <unistd.h>

#include <iostream>
#include <string>

#include <boost/utility.hpp>

#include "raul/log.hpp"

namespace Raul {


/** A child process.
 *
 * \ingroup raul
 */
class Process : boost::noncopyable
{
public:

	/** Launch a sub process.
	 *
	 * @param command can be a typical shell command with parameters, the PATH is searched etc.
	 */
	static bool launch(const std::string& command) {
		const std::string executable = (command.find(" ") != std::string::npos)
			? command.substr(0, command.find(" "))
			: command;

        const std::string arguments = command.substr((command.find(" ") + 1));

        info << "Launching child process '" << executable << "' with arguments '"
            << arguments << "'" << std::endl;

        // Use the same double fork() trick as JACK to prevent zombie children
        const int err = fork();

        if (err == 0) {
            // (child)

            // close all nonstandard file descriptors
            struct rlimit max_fds;
            getrlimit(RLIMIT_NOFILE, &max_fds);

            for (rlim_t fd = 3; fd < max_fds.rlim_cur; ++fd)
                close(fd);

            switch (fork()) {
                case 0:
                    // (grandchild)
                    setsid();
                    execlp(executable.c_str(), arguments.c_str(), NULL);
					_exit(-1);

				case -1:
					// (second) fork failed, there is no grandchild
					_exit (-1);

					/* exit the child process here */
				default:
					_exit (0);
			}
		}

		return (err > 0);
	}

private:
	Process() {}
};


} // namespace Raul

#endif // RAUL_PROCESS_HPP