summaryrefslogtreecommitdiff
path: root/pkgtools/pkglint/files/lintpkgsrc.0
blob: dd2bba2b41f4e300c637afbab1061a6d84cfdb5c (plain)
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
132
133
134
135
136
137
138
LINTPKGSRC(1)               NetBSD Reference Manual              LINTPKGSRC(1)

NNAAMMEE
     lliinnttppkkggssrrcc - verifier for the pkgsrc tree

SSYYNNOOPPSSIISS
     lliinnttppkkggssrrcc [--BBDDLLOORRSSVVddhhiillmmoopprruu] [--EE _f_i_l_e] [--gg _p_k_g_s_r_c_m_a_p] [--II _f_i_l_e] [--KK
                _P_A_C_K_A_G_E_S] [--MM _D_I_S_T_D_I_R] [--PP _P_K_G_S_R_C_D_I_R] [_m_a_k_e_f_i_l_e _._._.]

DDEESSCCRRIIPPTTIIOONN
     lliinnttppkkggssrrcc tries to verify the entire contents of the pkgsrc tree.
     lliinnttppkkggssrrcc uses simple regular-expression matching for verifying files
     that make up a pkgsrc directory.  Note that it does NOT implement com-
     plete Makefile parser.

   OOppttiioonnss

     --BB            List packages marked as BROKEN.

     --DD _p_a_t_h_s      Parse Makefiles and output contents (useful for debugging).

     --dd            Extract the `DEPENDS' listing from each pkgsrc package
                   Makefile, then verify the version specified in each DEPEND
                   correctly matches a current pkgsrc package.

     --EE _f_i_l_e       Exports the internal database generated from the pkgsrc
                   Makefiles to a file for faster loading at a later time.
                   Note that some of the stored data is, in all likelihood,
                   dependent on the architecture and operating system of the
                   machine where it is generated.  However, the database does
                   make the task of, eg, checking for out of date packages on
                   a set of similarly configured machines (in the absence of
                   extra copies of the pkgsrc tree) both quick and possible.

     --gg _p_k_g_s_r_c_m_a_p  Generate pkgsrcmap file containing an entry for each pack-
                   age of `pkgname pkgdir pkgver'.

     --hh            Basic help and usage.

     --II _f_i_l_e       Imports the data to construct the internal database for
                   checking the installed versions of packages, among other
                   things, against the current version found in pkgsrc.  This
                   database provides most or all of the data required for run-
                   ning lliinnttppkkggssrrcc with any combination of --BB, --OO, --RR, --SS, --VV,
                   --dd, --gg, --ii, --pp, or --uu.

     --ii            Check the version of each installed package against the
                   current version in pkgsrc.

     --KK _P_A_C_K_A_G_E_S   Override binary packages base directory, normally set from
                   _/_e_t_c_/_m_k_._c_o_n_f or defaulted to _$_{_P_K_G_S_R_C_D_I_R_}_/_p_a_c_k_a_g_e_s.

                   Note: lintpkgsrc treats _P_A_C_K_A_G_E_S slightly differently to
                   the pkgsrc build system.  --pp, --RR and --VV check for binary
                   packages in any depth of PACKAGES subdirs - this allows
                   packages for all architectures/OS versions to be checked
                   simultaneously with an _/_e_t_c_/_m_k_._c_o_n_f construct of the form:

                   .ifdef LINTPKGSRC
                   PACKAGES=${PKGSRCDIR}/packages
                   .else
                   PACKAGES=${PKGSRCDIR}/packages/${OS_VERSION}/${MACHINE_ARCH}
                   .endif

                   Which would be an alternative to --KK.

     --LL            List the filenames of Makefiles as they are parsed (for de-
                   bugging).

     --ll            Run pkglint(1) on every package in pkgsrc.

     --MM _D_I_S_T_D_I_R    Set directory for distfiles, defaults to
                   _$_{_P_K_G_S_R_C_D_I_R_}_/_d_i_s_t_f_i_l_e_s.

     --mm            For each current distfile, verify its checksum against the
                   appropriate package's distinfo file. Also report if any
                   package's distinfo file references the same distfile with a
                   different distinfo checksum.

     --OO            Report any binary packages in any subdirs of _P_A_C_K_A_G_E_S, for
                   whom the source Makefile lists _O_S_V_E_R_S_I_O_N___S_P_E_C_I_F_I_C.  This is
                   intended to help those making binary packages available for
                   ftp.

     --oo            Report any old distfiles (not referenced by any package's
                   distinfo file).

     --PP _P_K_G_S_R_C_D_I_R  Set base of pkgsrc tree, normally set from _/_e_t_c_/_m_k_._c_o_n_f or
                   defaulted to _/_u_s_r_/_p_k_g_s_r_c.

     --pp            Report any old binary packages in any subdirs of _P_A_C_K_A_G_E_S.

     --RR            Report any binary packages in any subdirs of _P_A_C_K_A_G_E_S, for
                   whom the source Makefile lists _N_O___B_I_N___O_N___F_T_P or _R_E_S_T_R_I_C_T_E_D.
                   This is intended to help those making binary packages
                   available for ftp.

     --rr            Remove distfiles which are not referenced from any pack-
                   age's distinfo file, or have an incorrect checksum (usually
                   due to an interrupted download), and any old binary pack-
                   ages. To remove any given type, additionally specify the
                   --oo, --mm, or --pp flags respectively.

     --SS            List packages missing from category _S_U_B_D_I_R lists.

     --uu            As --ii plus for mismatched packages, display REQUIRED de-
                   tails and run `@MAKE@ fetch-list | sh' to ensure all the
                   distfiles needed for the latest version are present.

                   Warning: The behaviour of this command may change in a lat-
                   er version.

     --VV            List any prebuilt packages in any subdirs of _P_A_C_K_A_G_E_S with
                   known vulnerabilities, based on the data in
                   _$_{_P_K_G_S_R_C_D_I_R_}_/_d_i_s_t_f_i_l_e_s_/_p_k_g_-_v_u_l_n_e_r_a_b_i_l_i_t_i_e_s.

EENNVVIIRROONNMMEENNTT
     PKGLINT_FLAGS are the flags passed to pkglint(1) when lliinnttppkkggssrrcc is in-
     voked with the --ll option.

AAUUTTHHOORRSS
     David Brownlee <abs@netbsd.org>

BBUUGGSS
     The --RR, --VV, and --pp options default to using _P_A_C_K_A_G_E_S as the base directo-
     ry from which to search for binary packages. If this includes OS or ar-
     chitecture information then packages for other OS/architecture combina-
     tions will be missed.  In this case _P_A_C_K_A_G_E_S can be overridden with --KK or
     set conditionally in _/_e_t_c_/_m_k_._c_o_n_f based on the value of _L_I_N_T_P_K_G_S_R_C.

     The `Makefile parsing' algorithm used to obtain package versions and DE-
     PENDS information is geared towards speed rather than perfection, though
     it has got somewhat better over time, it only parses the simplest Make-
     file conditionals. (a == b, no && etc).

     Potentially others, but non serious to date.

                                April 19, 1999                               3