4 /** \ingroup rpmdep rpmtrans
6 * Structure(s) used for dependency tag sets.
10 extern int _rpmds_debug;
12 #if defined(_RPMDS_INTERNAL)
14 * A package dependency set.
17 int i; /*!< Element index. */
20 const char * Type; /*!< Tag name. */
22 const char * DNEVR; /*!< Formatted dependency string. */
24 rpmTag tagN; /*!< Header tag. */
25 /*@refcounted@*/ /*@null@*/
26 Header h; /*!< Header for dependency set (or NULL) */
29 const char ** N; /*!< Name. */
31 const char ** EVR; /*!< Epoch-Version-Release. */
33 int_32 * Flags; /*!< Flags identifying context/comparison. */
34 rpmTagType Nt, EVRt, Ft; /*!< Tag data types. */
35 int_32 Count; /*!< No. of elements */
36 /*@refs@*/ int nrefs; /*!< Reference count. */
38 #endif /* _RPMDS_INTERNAL */
45 * Unreference a dependency set instance.
46 * @param ds dependency set
50 /*@unused@*/ /*@null@*/
51 rpmds rpmdsUnlink (/*@killref@*/ /*@only@*/ /*@null@*/ rpmds ds,
52 /*@null@*/ const char * msg)
55 /** @todo Remove debugging entry from the ABI. */
58 rpmds XrpmdsUnlink (/*@killref@*/ /*@only@*/ /*@null@*/ rpmds ds,
59 /*@null@*/ const char * msg, const char * fn, unsigned ln)
62 #define rpmdsUnlink(_ds, _msg) XrpmdsUnlink(_ds, _msg, __FILE__, __LINE__)
65 * Reference a dependency set instance.
66 * @param ds dependency set
68 * @return new dependency set reference
71 rpmds rpmdsLink (/*@null@*/ rpmds ds, /*@null@*/ const char * msg)
74 /** @todo Remove debugging entry from the ABI. */
75 rpmds XrpmdsLink (/*@null@*/ rpmds ds, /*@null@*/ const char * msg,
76 const char * fn, unsigned ln)
78 #define rpmdsLink(_ds, _msg) XrpmdsLink(_ds, _msg, __FILE__, __LINE__)
81 * Destroy a dependency set.
82 * @param ds dependency set
86 rpmds rpmdsFree(/*@killref@*/ /*@only@*/ /*@null@*/ rpmds ds)
89 * Create and load a dependency set.
91 * @param tagN type of dependency
92 * @param scareMem Use pointers to refcounted header memory?
93 * @return new dependency set
96 rpmds rpmdsNew(Header h, rpmTag tagN, int scareMem)
100 * Return new formatted dependency string.
101 * @param dspfx formatted dependency string prefix
102 * @param ds dependency set
103 * @return new formatted dependency (malloc'ed)
106 char * rpmdsNewDNEVR(const char * dspfx, const rpmds ds)
110 * Create, load and initialize a dependency for this header.
112 * @param tagN type of dependency
113 * @param Flags comparison flags
114 * @return new dependency set
117 rpmds rpmdsThis(Header h, rpmTag tagN, int_32 Flags)
121 * Create, load and initialize a dependency set of size 1.
122 * @param tagN type of dependency
124 * @param EVR epoch:version-release
125 * @param Flags comparison flags
126 * @return new dependency set
129 rpmds rpmdsSingle(rpmTag tagN, const char * N, const char * EVR, int_32 Flags)
133 * Return dependency set count.
134 * @param ds dependency set
135 * @return current count
137 int rpmdsCount(/*@null@*/ const rpmds ds)
141 * Return dependency set index.
142 * @param ds dependency set
143 * @return current index
145 int rpmdsIx(/*@null@*/ const rpmds ds)
149 * Set dependency set index.
150 * @param ds dependency set
151 * @param ix new index
152 * @return current index
154 int rpmdsSetIx(/*@null@*/ rpmds ds, int ix)
158 * Return current formatted dependency string.
159 * @param ds dependency set
160 * @return current dependency DNEVR, NULL on invalid
162 /*@observer@*/ /*@null@*/
163 const char * rpmdsDNEVR(/*@null@*/ const rpmds ds)
167 * Return current dependency name.
168 * @param ds dependency set
169 * @return current dependency name, NULL on invalid
171 /*@observer@*/ /*@null@*/
172 const char * rpmdsN(/*@null@*/ const rpmds ds)
176 * Return current dependency epoch-version-release.
177 * @param ds dependency set
178 * @return current dependency EVR, NULL on invalid
180 /*@observer@*/ /*@null@*/
181 const char * rpmdsEVR(/*@null@*/ const rpmds ds)
185 * Return current dependency flags.
186 * @param ds dependency set
187 * @return current dependency flags, 0 on invalid
189 int_32 rpmdsFlags(/*@null@*/ const rpmds ds)
193 * Return current dependency type.
194 * @param ds dependency set
195 * @return current dependency type, 0 on invalid
197 rpmTag rpmdsTagN(/*@null@*/ const rpmds ds)
201 * Notify of results of dependency match.
202 * @param ds dependency set
203 * @param where where dependency was resolved (or NULL)
204 * @param rc 0 == YES, otherwise NO
206 /*@-globuse@*/ /* FIX: rpmMessage annotation is a lie */
207 void rpmdsNotify(/*@null@*/ rpmds ds, /*@null@*/ const char * where, int rc)
208 /*@globals fileSystem @*/
209 /*@modifies fileSystem @*/;
213 * Return next dependency set iterator index.
214 * @param ds dependency set
215 * @return dependency set iterator index, -1 on termination
217 int rpmdsNext(/*@null@*/ rpmds ds)
221 * Initialize dependency set iterator.
222 * @param ds dependency set
223 * @return dependency set
226 rpmds rpmdsInit(/*@null@*/ rpmds ds)
230 * Compare two versioned dependency ranges, looking for overlap.
231 * @param A 1st dependency
232 * @param B 2nd dependency
233 * @return 1 if dependencies overlap, 0 otherwise
235 int rpmdsCompare(const rpmds A, const rpmds B)
239 * Report a Requires: or Conflicts: dependency problem.
240 * @param ps transaction set problems
241 * @param pkgNEVR package name/epoch/version/release
242 * @param ds dependency set
243 * @param suggestedKeys
245 void rpmdsProblem(/*@null@*/ rpmps ps, const char * pkgNEVR, const rpmds ds,
246 /*@only@*/ /*@null@*/ const fnpyKey * suggestedKeys)
250 * Compare package provides dependencies from header with a single dependency.
252 * @param req dependency set
254 int rangeMatchesDepFlags (Header h, const rpmds req)
258 * Compare package name-version-release from header with a single dependency.
259 * @deprecated Remove from API when obsoletes is correctly implemented.
261 * @param req dependency
262 * @return 1 if dependency overlaps, 0 otherwise
264 int headerMatchesDepFlags(const Header h, const rpmds req)