4 /** \ingroup rpmdep rpmtrans
6 * Structure(s) used for dependency tag sets.
15 extern int _rpmds_debug;
22 extern int _rpmds_nopromote;
25 #if defined(_RPMDS_INTERNAL)
27 * A package dependency set.
30 int i; /*!< Element index. */
33 const char * Type; /*!< Tag name. */
35 const char * DNEVR; /*!< Formatted dependency string. */
37 rpmTag tagN; /*!< Header tag. */
38 /*@refcounted@*/ /*@null@*/
39 Header h; /*!< Header for dependency set (or NULL) */
42 const char ** N; /*!< Name. */
44 const char ** EVR; /*!< Epoch-Version-Release. */
46 int_32 * Flags; /*!< Flags identifying context/comparison. */
47 rpmTagType Nt, EVRt, Ft; /*!< Tag data types. */
48 int_32 Count; /*!< No. of elements */
49 int nopromote; /*!< Don't promote Epoch: in rpmdsCompare()? */
51 int nrefs; /*!< Reference count. */
53 #endif /* _RPMDS_INTERNAL */
60 * Unreference a dependency set instance.
61 * @param ds dependency set
65 /*@unused@*/ /*@null@*/
66 rpmds rpmdsUnlink (/*@killref@*/ /*@only@*/ /*@null@*/ rpmds ds,
67 /*@null@*/ const char * msg)
70 /** @todo Remove debugging entry from the ABI. */
73 rpmds XrpmdsUnlink (/*@killref@*/ /*@only@*/ /*@null@*/ rpmds ds,
74 /*@null@*/ const char * msg, const char * fn, unsigned ln)
77 #define rpmdsUnlink(_ds, _msg) XrpmdsUnlink(_ds, _msg, __FILE__, __LINE__)
80 * Reference a dependency set instance.
81 * @param ds dependency set
83 * @return new dependency set reference
85 /*@unused@*/ /*@newref@*/
86 rpmds rpmdsLink (/*@null@*/ rpmds ds, /*@null@*/ const char * msg)
89 /** @todo Remove debugging entry from the ABI. */
91 rpmds XrpmdsLink (/*@null@*/ rpmds ds, /*@null@*/ const char * msg,
92 const char * fn, unsigned ln)
94 #define rpmdsLink(_ds, _msg) XrpmdsLink(_ds, _msg, __FILE__, __LINE__)
97 * Destroy a dependency set.
98 * @param ds dependency set
102 rpmds rpmdsFree(/*@killref@*/ /*@only@*/ /*@null@*/ rpmds ds)
105 * Create and load a dependency set.
107 * @param tagN type of dependency
108 * @param scareMem Use pointers to refcounted header memory?
109 * @return new dependency set
112 rpmds rpmdsNew(Header h, rpmTag tagN, int scareMem)
116 * Return new formatted dependency string.
117 * @param dspfx formatted dependency string prefix
118 * @param ds dependency set
119 * @return new formatted dependency (malloc'ed)
122 char * rpmdsNewDNEVR(const char * dspfx, const rpmds ds)
126 * Create, load and initialize a dependency for this header.
128 * @param tagN type of dependency
129 * @param Flags comparison flags
130 * @return new dependency set
133 rpmds rpmdsThis(Header h, rpmTag tagN, int_32 Flags)
137 * Create, load and initialize a dependency set of size 1.
138 * @param tagN type of dependency
140 * @param EVR epoch:version-release
141 * @param Flags comparison flags
142 * @return new dependency set
145 rpmds rpmdsSingle(rpmTag tagN, const char * N, const char * EVR, int_32 Flags)
149 * Return dependency set count.
150 * @param ds dependency set
151 * @return current count
153 int rpmdsCount(/*@null@*/ const rpmds ds)
157 * Return dependency set index.
158 * @param ds dependency set
159 * @return current index
161 int rpmdsIx(/*@null@*/ const rpmds ds)
165 * Set dependency set index.
166 * @param ds dependency set
167 * @param ix new index
168 * @return current index
170 int rpmdsSetIx(/*@null@*/ rpmds ds, int ix)
174 * Return current formatted dependency string.
175 * @param ds dependency set
176 * @return current dependency DNEVR, NULL on invalid
178 /*@observer@*/ /*@null@*/
179 extern const char * rpmdsDNEVR(/*@null@*/ const rpmds ds)
183 * Return current dependency name.
184 * @param ds dependency set
185 * @return current dependency name, NULL on invalid
187 /*@observer@*/ /*@null@*/
188 extern const char * rpmdsN(/*@null@*/ const rpmds ds)
192 * Return current dependency epoch-version-release.
193 * @param ds dependency set
194 * @return current dependency EVR, NULL on invalid
196 /*@observer@*/ /*@null@*/
197 extern const char * rpmdsEVR(/*@null@*/ const rpmds ds)
201 * Return current dependency flags.
202 * @param ds dependency set
203 * @return current dependency flags, 0 on invalid
205 int_32 rpmdsFlags(/*@null@*/ const rpmds ds)
209 * Return current dependency type.
210 * @param ds dependency set
211 * @return current dependency type, 0 on invalid
213 rpmTag rpmdsTagN(/*@null@*/ const rpmds ds)
217 * Return current "Don't promote Epoch:" flag.
219 * This flag controls for Epoch: promotion when a dependency set is
220 * compared. If the flag is set (for already installed packages), then
221 * an unspecified value will be treated as Epoch: 0. Otherwise (for added
222 * packages), the Epoch: portion of the comparison is skipped if the value
223 * is not specified, i.e. an unspecified Epoch: is assumed to be equal
224 * in dependency comparisons.
226 * @param ds dependency set
227 * @return current "Don't promote Epoch:" flag
229 int rpmdsNoPromote(/*@null@*/ const rpmds ds)
233 * Set "Don't promote Epoch:" flag.
234 * @param ds dependency set
235 * @return previous "Don't promote Epoch:" flag
237 int rpmdsSetNoPromote(/*@null@*/ const rpmds ds, int nopromote)
241 * Notify of results of dependency match.
242 * @param ds dependency set
243 * @param where where dependency was resolved (or NULL)
244 * @param rc 0 == YES, otherwise NO
246 /*@-globuse@*/ /* FIX: rpmMessage annotation is a lie */
247 void rpmdsNotify(/*@null@*/ rpmds ds, /*@null@*/ const char * where, int rc)
248 /*@globals fileSystem @*/
249 /*@modifies fileSystem @*/;
253 * Return next dependency set iterator index.
254 * @param ds dependency set
255 * @return dependency set iterator index, -1 on termination
257 int rpmdsNext(/*@null@*/ rpmds ds)
261 * Initialize dependency set iterator.
262 * @param ds dependency set
263 * @return dependency set
266 rpmds rpmdsInit(/*@null@*/ rpmds ds)
270 * Compare two versioned dependency ranges, looking for overlap.
271 * @param A 1st dependency
272 * @param B 2nd dependency
273 * @return 1 if dependencies overlap, 0 otherwise
275 int rpmdsCompare(const rpmds A, const rpmds B)
279 * Report a Requires: or Conflicts: dependency problem.
280 * @param ps transaction set problems
281 * @param pkgNEVR package name/epoch/version/release
282 * @param ds dependency set
283 * @param suggestedKeys filename or python object address
284 * @param adding dependency problem is from added package set?
286 void rpmdsProblem(/*@null@*/ rpmps ps, const char * pkgNEVR, const rpmds ds,
287 /*@only@*/ /*@null@*/ const fnpyKey * suggestedKeys,
292 * Compare package provides dependencies from header with a single dependency.
294 * @param req dependency set
295 * @param nopromote Don't promote Epoch: in comparison?
296 * @return 1 if any dependency overlaps, 0 otherwise
298 int rpmdsAnyMatchesDep (const Header h, const rpmds req, int nopromote)
302 * Compare package name-version-release from header with a single dependency.
303 * @deprecated Remove from API when obsoletes is correctly implemented.
305 * @param req dependency set
306 * @param nopromote Don't promote Epoch: in comparison?
307 * @return 1 if dependency overlaps, 0 otherwise
309 int rpmdsNVRMatchesDep(const Header h, const rpmds req, int nopromote)