This file is indexed.

/usr/lib/python2.7/dist-packages/pyferret/ferfmrcvar.py is in python-ferret 7.3-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
''' Represents a Ferret variable that is part of a forecast-model-run collection '''

import pyferret

_fmrc_var_qualifier = '__new_fmrc_variable__'

class FerFMRCVar(pyferret.FerVar):
    '''
    A Ferret variable (and thus, a FerVar) that is part of a FerFMRCDSet (forecast-
    model-run collection dataset).  Such a Ferret variable has restrictions on the 
    time and forecast axes, and has special transformations to better view the 
    quality of the forecast represented by this variable.
    '''

    def __init__(self, fvar, qual):
        '''
        Create from the given FerVar that is part of a FerFMRCDSet (forecast-model-run 
        collection dataset).  FerFMRCVar objects should only be created by a FerFMRCDSet 
        object; this constructor should never be called directly.  The FerFMRCVar object
        returned should replace the given FerVar.
        '''
        super(FerFMRCVar, self).__init__(defn=fvar._definition, title=fvar._title)
        if (qual != _fmrc_var_qualifier) or (not fvar._varname) or \
           (not fvar._dsetname) or (not fvar._definition) or (not fvar._isfilevar):
            raise  ValueError('FerFMRCVar objects should only be created by FerFMRCDSet objects')
        self._markasknownvar(fvar._varname, fvar._dsetname, True)

    def __repr__(self):
        '''
        Representation of this FerFMRCVar
        '''
        infostr = "FerFMRCVar(varname='%s', dsetname='%s', title = '%s', defn='%s')" \
                  % (self._varname, self._dsetname, self._title, self._definition)
        return infostr

    # Note: Just use the __cmp__, __eq__, and __ne__ methods inherited from FerVar.
    #       No need to make these orbjects appear to be different from a FerVar.

    def diagform(self):
        '''
        Returns an anonymous FerVar that is the transformation of this FerFMRCVar 
        to a "diagonal" form, where the T (time) axis is the date forecasted and 
        the F (forecast) axis is the date the forecast was made.
        '''
        if (not self._varname) or (not self._dsetname):
            raise ValueError('Invalid FerFMRCVar object')
        # TF_TIMES is an automatically generated variable for FMRC datasets in Ferret
        # TF_CAL_T is an automatically generated axis for FMRC datasets in Ferret
        diagdefn = '%s[gt(TF_TIMES)=TF_CAL_T]' % self._varname
        title = self._title + ' (diag form)'
        diagvar = pyferret.FerVar(defn=diagdefn, title=title)
        diagvar._requires.add(self._varname.upper())
        diagvar._requires.add("TF_TIMES")
        return diagvar

    def leadform(self):
        '''
        Returns an anonymous FerVar that is the transformation of this FerFMRCVar 
        to the "lead" form, where the T (time) axis is the date forecasted and 
        the F (forecast) axis is the lead time for the date forecasted (forecasted
        time minus time that the forecast was made).
        '''
        if (not self._varname) or (not self._dsetname):
            raise ValueError('Invalid FerFMRCVar object')
        # TF_TIMES is an automatically generated variable for FMRC datasets in Ferret
        # TF_CAL_T is an automatically generated axis for FMRC datasets in Ferret
        # TF_LAG_F is an automatically generated axis for FMRC datasets in Ferret
        leaddefn = '%s[gt(TF_TIMES)=TF_CAL_T,gf(TF_TIMES)=TF_LAG_F]' % self._varname
        title = self._title + ' (lead form)'
        leadvar = pyferret.FerVar(defn=leaddefn, title=title)
        leadvar._requires.add(self._varname.upper())
        leadvar._requires.add("TF_TIMES")
        return leadvar