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
|
# Copyright 2007 Robert ("Bob") Igo of StormLogic, LLC and mythic.tv.
#
# 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 3 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, see <http://www.gnu.org/licenses/>.
package Tweaker::Definitions;
use List::Member;
use Log::Log4perl qw(:easy);
# To install the above modules:
# --
# sudo cpan install List::Member
# Recommendation Levels
my $bottom = -200; # a reserved value, under which no recommendationlevel can go
my $not_available = -100;
my $unsupported = -99;
my $inadvisable = -50;
my $optional = 0;
my $recommended = 100;
# Interactivity Levels
my $guided = "guided";
my $minimal = "minimal";
# Special variables
my $null = "null"; # reserved as the script name for special Tweaks that define Tweaker behavior
my %global_variable_hash = (
"bottom" => $bottom,
"not available" => $not_available,
"unsupported" => $unsupported,
"inadvisable" => $inadvisable,
"optional" => $optional,
"recommended" => $recommended,
"guided" => $guided,
"minimal" => $minimal,
"null" => $null
);
sub get_global_variable_value {
my ($variable) = @_;
my @known_variables = keys %global_variable_hash;
if (member($variable, @known_variables) + 1) {
if ($global_variable_hash{$variable}) {
return $global_variable_hash{$variable};
}
} else {
my $logger = get_logger();
$logger->error("No Tweaker Definition for variable named $variable");
return $bottom;
}
}
1;
|