This file is indexed.

/usr/share/boost-build/tools/make.jam is in libboost1.49-dev 1.49.0-3.2.

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
# Copyright 2003 Dave Abrahams
# Copyright 2003 Douglas Gregor
# Copyright 2006 Rene Rivera
# Copyright 2002, 2003, 2004, 2005, 2006 Vladimir Prus
# Distributed under the Boost Software License, Version 1.0.
# (See accompanying file LICENSE_1_0.txt or http://www.boost.org/LICENSE_1_0.txt)

#  This module defines the 'make' main target rule.

import "class" : new ;
import errors : error ;
import project ;
import property ;
import property-set ;
import regex ;
import targets ;


class make-target-class : basic-target
{
    import type regex virtual-target ;
    import "class" : new ;

    rule __init__ ( name : project : sources * : requirements *
        : default-build * : usage-requirements * )
    {
        basic-target.__init__ $(name) : $(project) : $(sources) :
            $(requirements) : $(default-build) : $(usage-requirements) ;
    }

    rule construct ( name : source-targets * : property-set )
    {
        local action-name = [ $(property-set).get <action> ] ;
        # 'm' will always be set -- we add '@' ourselves in the 'make' rule
        # below.
        local m = [ MATCH ^@(.*) : $(action-name) ] ;

        local a = [ new action $(source-targets) : $(m[1]) : $(property-set) ] ;
        local t = [ new file-target $(self.name) exact : [ type.type
            $(self.name) ] : $(self.project) : $(a) ] ;
        return [ property-set.empty ] [ virtual-target.register $(t) ] ;
    }
}


# Declares the 'make' main target.
#
rule make ( target-name : sources * : generating-rule + : requirements * :
    usage-requirements * )
{
    local project = [ project.current ] ;

    # The '@' sign causes the feature.jam module to qualify rule name with the
    # module name of current project, if needed.
    local m = [ MATCH ^(@).* : $(generating-rule) ] ;
    if ! $(m)
    {
        generating-rule = @$(generating-rule) ;
    }
    requirements += <action>$(generating-rule) ;

    targets.main-target-alternative
        [ new make-target-class $(target-name) : $(project)
            : [ targets.main-target-sources $(sources) : $(target-name) ]
            : [ targets.main-target-requirements $(requirements) : $(project) ]
            : [ targets.main-target-default-build : $(project) ]
            : [ targets.main-target-usage-requirements $(usage-requirements) :
                $(project) ] ] ;
}


IMPORT $(__name__) : make : : make ;