This file is indexed.

/usr/share/perl5/PlSense/Symbol/Method.pm is in plsense 0.3.1-1.

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
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
package PlSense::Symbol::Method;

use parent qw{ PlSense::Symbol };
use strict;
use warnings;
use Class::Std::Storable;
use Scalar::Util qw{ weaken };
use PlSense::Logger;
{
    my %publicly_is :ATTR( :init_arg<publicly> :default(0) );
    sub set_publicly { my ($self, $publicly) = @_; $publicly_is{ident $self} = $publicly; }
    sub is_publicly { my ($self) = @_; return $publicly_is{ident $self}; }

    my %privately_is :ATTR( :init_arg<privately> :default(0) );
    sub set_privately { my ($self, $privately) = @_; $privately_is{ident $self} = $privately; }
    sub is_privately { my ($self) = @_; return $privately_is{ident $self}; }

    my %importive_is :ATTR( :init_arg<importive> :default(0) );
    sub set_importive { my ($self, $importive) = @_; $importive_is{ident $self} = $importive; }
    sub is_importive { my ($self) = @_; return $importive_is{ident $self}; }

    my %reserved_is :ATTR( :init_arg<reserved> :default(0) );
    sub set_reserved { my ($self, $reserved) = @_; $reserved_is{ident $self} = $reserved; }
    sub is_reserved { my ($self) = @_; return $reserved_is{ident $self}; }

    my %attribute_of :ATTR( :default(undef) );
    sub set_attribute { my ($self, $attribute) = @_; $attribute_of{ident $self} = $attribute; }
    sub get_attribute { my ($self) = @_; return $attribute_of{ident $self}; }

    my %module_of :ATTR( :init_arg<module> :default('') );
    sub set_module {
        my ($self, $module) = @_;
        if ( ! $module || ! $module->isa("PlSense::Symbol::Module") ) {
            logger->error("Not PlSense::Symbol::Module");
            return;
        }
        $module_of{ident $self} = $module;
        weaken $module_of{ident $self};
        $module->set_method($self->get_name, $self);
    }
    sub get_module { my ($self) = @_; return $module_of{ident $self}; }

    my %variableh_of :ATTR();
    sub set_variable {
        my ($self, $variablenm, $variable) = @_;
        if ( ! $variable || ! $variable->isa("PlSense::Symbol::Variable") ) {
            logger->error("Not PlSense::Symbol::Variable");
            return;
        }
        if ( $variablenm ne $variable->get_name() ) {
            logger->warn("Not equal key[$variablenm] and variable's name[".$variable->get_name()."]");
            return;
        }
        $variableh_of{ident $self}->{$variablenm} = $variable;
        logger->debug("Set variable of [".$self->get_fullnm()."] : $variablenm");
    }
    sub exist_variable {
        my ($self, $variablenm) = @_;
        return $variablenm && exists $variableh_of{ident $self}->{$variablenm};
    }
    sub get_variable {
        my ($self, $variablenm) = @_;
        if ( ! exists $variableh_of{ident $self}->{$variablenm} ) {
            logger->warn("Not exist variable[$variablenm] in ".$self->get_fullnm);
            return;
        }
        return $variableh_of{ident $self}->{$variablenm};
    }
    sub keys_variable {
        my ($self) = @_;
        return keys %{$variableh_of{ident $self}};
    }

    my %argumenth_of :ATTR();
    sub set_argument {
        my ($self, $idx, $variable) = @_;
        if ( ! $variable || ! $variable->isa("PlSense::Symbol::Variable") ) {
            logger->error("Not PlSense::Symbol::Variable");
            return;
        }
        $argumenth_of{ident $self}->{$idx} = $variable;
        logger->debug("Set [$idx] argument of [".$self->get_fullnm."] : ".$variable->get_fullnm);
    }
    sub get_argument {
        my ($self, $idx) = @_;
        if ( ! exists $argumenth_of{ident $self}->{$idx} ) {
            return;
        }
        return $argumenth_of{ident $self}->{$idx};
    }
    sub get_arguments {
        my ($self) = @_;
        my @ret;
        my $idx = 1;
        ARG:
        while ( exists $argumenth_of{ident $self}->{$idx} ) {
            push @ret, $argumenth_of{ident $self}->{$idx};
            $idx++;
        }
        return @ret;
    }

    sub BUILD {
        my ($class, $ident, $arg_ref) = @_;
        $class->set_type("method");
        $variableh_of{$ident} = {};
        $argumenth_of{$ident} = {};
    }

    sub START {
        my ($class, $ident, $arg_ref) = @_;
        if ( exists $arg_ref->{module} ) {
            $class->set_module($arg_ref->{module});
            logger->debug("New method : name[".$class->get_name."] module[".$class->get_module->get_name."]");
        }
        else {
            logger->debug("New method : name[".$class->get_name."]");
        }
    }

    sub get_fullnm {
        my $self = shift;
        my $module = $module_of{ident $self};
        return $module ? "&".$module->get_fullnm."::".$self->get_name
             :           "&".$self->get_name;
    }
}

1;

__END__