This file is indexed.

/usr/bin/cricket-compile is in cricket 1.0.5-20.

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

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
#!/usr/bin/perl -w
# -*- perl -*-

# Cricket: a configuration, polling and data display wrapper for RRD files
#
#    Copyright (C) 1998 Jeff R. Allen and WebTV Networks, Inc.
#
#    This program 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.
#
#    This program 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 more 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., 675 Mass Ave, Cambridge, MA 02139, USA.

BEGIN {
  require '/etc/cricket/cricket-conf.pl';
}

use lib "$Common::global::gInstallRoot/lib";

use Common::Version;
use Common::global;
use Common::Log;
use Common::Options;
use Common::Util;
use Common::Map;
use Common::HandleTarget;
use ConfigTree::Node;

my $starttime = time();

Common::Options::commonOptions();

Info("Starting compile: $Common::global::gVersion");
my($nodeCt, $fileCt) = (0, 0);

$gCT = new ConfigTree::Node;
$gCT->info(\&Common::Log::Info);
$gCT->warn(\&Common::Log::Warn);
$gCT->debug(\&Common::Log::Debug);
$gCT->Base($Common::global::gConfigRoot);

if (&check_and_set_lock) {
	exit;
}
$gCT->init();
$gCT->processTree();

($nodeCt, $fileCt) = $gCT->compile();

# log summary info before exiting
$time = runTime($starttime);
Info("Processed $nodeCt nodes (in $fileCt files) in $time.");
&unlock;

exit;

sub check_and_set_lock {
	my $lockfile = $gCT->Base() . "/config.db.lock";
	if (-f $lockfile) {
		my($db_mtime) = (stat($lockfile))[9];
		# Do not recompile if another process already is busy compiling
		if ((time() - $db_mtime) < 900) {
			Warn("Skipping recompile; already in progress");
			return 1;
		} else {  
			# But warn if that other process is dead
			Warn("Forcing recompile; previous compile aborted?");
		}
	}
	open(LOCK, ">$lockfile") || die "Can't create $lockfile";
	print LOCK "$$\n";
	close LOCK;
	return 0;
}

sub unlock {
	my $lockfile = $gCT->Base() . "/config.db.lock";
	unlink $lockfile;
}