dpkg-db.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  1. /*
  2. * libdpkg - Debian packaging suite library routines
  3. * dpkg-db.h - declarations for in-core package database management
  4. *
  5. * Copyright © 1994,1995 Ian Jackson <ian@chiark.greenend.org.uk>
  6. * Copyright © 2000,2001 Wichert Akkerman
  7. *
  8. * This is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as
  10. * published by the Free Software Foundation; either version 2,
  11. * or (at your option) any later version.
  12. *
  13. * This is distributed in the hope that it will be useful, but
  14. * WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. */
  21. #ifndef LIBDPKG_DPKG_DB_H
  22. #define LIBDPKG_DPKG_DB_H
  23. #include <sys/types.h>
  24. #include <stdbool.h>
  25. #include <stdio.h>
  26. #include <dpkg/macros.h>
  27. #include <dpkg/varbuf.h>
  28. DPKG_BEGIN_DECLS
  29. struct versionrevision {
  30. unsigned long epoch;
  31. const char *version;
  32. const char *revision;
  33. };
  34. enum deptype {
  35. dep_suggests,
  36. dep_recommends,
  37. dep_depends,
  38. dep_predepends,
  39. dep_breaks,
  40. dep_conflicts,
  41. dep_provides,
  42. dep_replaces,
  43. dep_enhances
  44. };
  45. enum depverrel {
  46. dvrf_earlier= 0001,
  47. dvrf_later= 0002,
  48. dvrf_strict= 0010,
  49. dvrf_orequal= 0020,
  50. dvrf_builtup= 0100,
  51. dvr_none= 0200,
  52. dvr_earlierequal= dvrf_builtup | dvrf_earlier | dvrf_orequal,
  53. dvr_earlierstrict= dvrf_builtup | dvrf_earlier | dvrf_strict,
  54. dvr_laterequal= dvrf_builtup | dvrf_later | dvrf_orequal,
  55. dvr_laterstrict= dvrf_builtup | dvrf_later | dvrf_strict,
  56. dvr_exact= 0400
  57. };
  58. struct dependency {
  59. struct pkginfo *up;
  60. struct dependency *next;
  61. struct deppossi *list;
  62. enum deptype type;
  63. };
  64. struct deppossi {
  65. struct dependency *up;
  66. struct pkginfo *ed;
  67. struct deppossi *next, *nextrev, *backrev;
  68. struct versionrevision version;
  69. enum depverrel verrel;
  70. int cyclebreak;
  71. };
  72. struct arbitraryfield {
  73. struct arbitraryfield *next;
  74. const char *name;
  75. const char *value;
  76. };
  77. struct conffile {
  78. struct conffile *next;
  79. const char *name;
  80. const char *hash;
  81. int obsolete;
  82. };
  83. struct filedetails {
  84. struct filedetails *next;
  85. const char *name;
  86. const char *msdosname;
  87. const char *size;
  88. const char *md5sum;
  89. };
  90. struct pkginfoperfile { /* pif */
  91. int valid;
  92. struct dependency *depends;
  93. struct deppossi *depended;
  94. int essential; /* The `essential' flag, 1=yes, 0=no (absent) */
  95. const char *description;
  96. const char *maintainer;
  97. const char *source;
  98. const char *architecture;
  99. const char *installedsize;
  100. const char *origin;
  101. const char *bugs;
  102. struct versionrevision version;
  103. struct conffile *conffiles;
  104. struct arbitraryfield *arbs;
  105. };
  106. struct trigpend {
  107. /* Node indicates that parent's Triggers-Pending mentions name. */
  108. /* NB that these nodes do double duty: after they're removed from
  109. * a package's trigpend list, references may be preserved by the
  110. * trigger cycle checker (see trigproc.c).
  111. */
  112. struct trigpend *next;
  113. const char *name;
  114. };
  115. struct trigaw {
  116. /* Node indicates that aw's Triggers-Awaited mentions pend. */
  117. struct pkginfo *aw, *pend;
  118. struct trigaw *nextsamepend;
  119. struct {
  120. struct trigaw *next, *back;
  121. } sameaw;
  122. };
  123. struct perpackagestate; /* dselect and dpkg have different versions of this */
  124. struct pkginfo { /* pig */
  125. struct pkginfo *next;
  126. const char *name;
  127. enum pkgwant {
  128. want_unknown, want_install, want_hold, want_deinstall, want_purge,
  129. want_sentinel /* Not allowed except as special sentinel value
  130. in some places */
  131. } want;
  132. enum pkgeflag {
  133. eflag_ok = 0,
  134. eflag_reinstreq = 1,
  135. } eflag; /* Bitmask. */
  136. enum pkgstatus {
  137. stat_notinstalled,
  138. stat_configfiles,
  139. stat_halfinstalled,
  140. stat_unpacked,
  141. stat_halfconfigured,
  142. stat_triggersawaited,
  143. stat_triggerspending,
  144. stat_installed
  145. } status;
  146. enum pkgpriority {
  147. pri_required,
  148. pri_important,
  149. pri_standard,
  150. pri_optional,
  151. pri_extra,
  152. pri_other, pri_unknown, pri_unset=-1
  153. } priority;
  154. const char *otherpriority;
  155. const char *section;
  156. struct versionrevision configversion;
  157. struct filedetails *files;
  158. struct pkginfoperfile installed;
  159. struct pkginfoperfile available;
  160. struct perpackagestate *clientdata;
  161. enum { white, gray, black } color; /* used during cycle detection */
  162. struct {
  163. /* ->aw == this */
  164. struct trigaw *head, *tail;
  165. } trigaw;
  166. /* ->pend == this, non-NULL for us when Triggers-Pending. */
  167. struct trigaw *othertrigaw_head;
  168. struct trigpend *trigpend_head;
  169. };
  170. /*** from lock.c ***/
  171. void lockdatabase(const char *admindir);
  172. void unlockdatabase(void);
  173. /*** from dbmodify.c ***/
  174. enum modstatdb_rw {
  175. /* Those marked with \*s*\ are possible returns from modstatdb_init. */
  176. msdbrw_readonly/*s*/, msdbrw_needsuperuserlockonly/*s*/,
  177. msdbrw_writeifposs,
  178. msdbrw_write/*s*/, msdbrw_needsuperuser,
  179. /* Now some optional flags: */
  180. msdbrw_flagsmask= ~077,
  181. /* flags start at 0100 */
  182. msdbrw_noavail= 0100,
  183. };
  184. enum modstatdb_rw modstatdb_init(const char *admindir, enum modstatdb_rw reqrwflags);
  185. void modstatdb_note(struct pkginfo *pkg);
  186. void modstatdb_note_ifwrite(struct pkginfo *pkg);
  187. void modstatdb_checkpoint(void);
  188. void modstatdb_shutdown(void);
  189. /* Initialised by modstatdb_init. */
  190. extern char *statusfile, *availablefile;
  191. extern char *triggersdir, *triggersfilefile, *triggersnewfilefile;
  192. const char *pkgadminfile(struct pkginfo *pkg, const char *whichfile);
  193. /*** from trigdeferred.l ***/
  194. enum trigdef_updateflags {
  195. tduf_nolockok = 001,
  196. tduf_write = 002,
  197. tduf_nolock = 003,
  198. /* Should not be set unless _write is. */
  199. tduf_writeifempty = 010,
  200. tduf_writeifenoent = 020,
  201. };
  202. struct trigdefmeths {
  203. void (*trig_begin)(const char *trig);
  204. void (*package)(const char *awname);
  205. void (*trig_end)(void);
  206. };
  207. extern const struct trigdefmeths *trigdef;
  208. extern FILE *trig_new_deferred;
  209. /* Return values:
  210. * -1 Lock ENOENT with O_CREAT (directory does not exist)
  211. * -2 Unincorp empty, tduf_writeifempty unset
  212. * -3 Unincorp ENOENT, tduf_writeifenoent unset
  213. * 1 Unincorp ENOENT, tduf_writeifenoent set } caller must call
  214. * 2 ok } trigdef_update_done!
  215. */
  216. int trigdef_update_start(enum trigdef_updateflags uf, const char *admindir);
  217. int trigdef_yylex(void);
  218. void trigdef_process_done(void);
  219. /*** hooks for more sophisticated processing in dpkg proper ***/
  220. /* We do things like this so we can get most of the trigger tracking
  221. * in dpkg-query, dselect, and so on, but avoid the transitional
  222. * processing and deferred trigproc queue management other than when
  223. * we're actually doing real package management work. */
  224. struct trigfileint {
  225. struct pkginfo *pkg;
  226. struct filenamenode *fnn;
  227. struct trigfileint *samefile_next;
  228. struct {
  229. struct trigfileint *next, *back;
  230. } inoverall;
  231. };
  232. struct trig_hooks {
  233. /* The first two are normally NULL.
  234. * If non-NULL, we're dpkg proper and we might need to invent trigger
  235. * activations as the first run of a triggers-supporting dpkg.
  236. */
  237. void (*enqueue_deferred)(struct pkginfo *pend);
  238. void (*transitional_activate)(enum modstatdb_rw cstatus);
  239. struct filenamenode *(*namenode_find)(const char *filename, int nonew);
  240. struct trigfileint **(*namenode_interested)(struct filenamenode *fnn);
  241. /* Returns a pointer from nfmalloc. */
  242. const char *(*namenode_name)(struct filenamenode *fnn);
  243. };
  244. extern struct trig_hooks trigh;
  245. #define TRIGHOOKS_DEFINE_NAMENODE_ACCESSORS \
  246. static struct trigfileint **th_nn_interested(struct filenamenode *fnn) \
  247. { return &fnn->trig_interested; } \
  248. static const char *th_nn_name(struct filenamenode *fnn) \
  249. { return fnn->name; }
  250. /*** from triglib.c ***/
  251. void trig_file_activate_byname(const char *trig, struct pkginfo *aw);
  252. void trig_file_activate(struct filenamenode *trig, struct pkginfo *aw);
  253. int trig_note_pend_core(struct pkginfo *pend, const char *trig /*not copied!*/);
  254. int trig_note_pend(struct pkginfo *pend, const char *trig /*not copied!*/);
  255. int trig_note_aw(struct pkginfo *pend, struct pkginfo *aw);
  256. void trig_clear_awaiters(struct pkginfo *notpend);
  257. void trig_enqueue_awaited_pend(struct pkginfo *pend);
  258. void trig_fixup_awaiters(enum modstatdb_rw cstatus);
  259. void trig_file_interests_ensure(void);
  260. void trig_file_interests_save(void);
  261. void trig_cicb_interest_delete(const char *trig, void *user);
  262. void trig_cicb_interest_add(const char *trig, void *user);
  263. typedef void trig_parse_cicb(const char *trig, void *user);
  264. void trig_parse_ci(const char *file, trig_parse_cicb *interest,
  265. trig_parse_cicb *activate, void *user);
  266. /* Called by process_archive. */
  267. void trig_cicb_statuschange_activate(const char *trig, void *user);
  268. void trig_incorporate(enum modstatdb_rw cstatus, const char *admindir);
  269. const char *illegal_triggername(const char *p);
  270. /*** from database.c ***/
  271. struct pkginfo *findpackage(const char *name);
  272. void blankpackage(struct pkginfo *pp);
  273. void blankpackageperfile(struct pkginfoperfile *pifp);
  274. void blankversion(struct versionrevision*);
  275. bool informative(struct pkginfo *pkg, struct pkginfoperfile *info);
  276. int countpackages(void);
  277. void resetpackages(void);
  278. struct pkgiterator *iterpkgstart(void);
  279. struct pkginfo *iterpkgnext(struct pkgiterator*);
  280. void iterpkgend(struct pkgiterator*);
  281. void hashreport(FILE*);
  282. /*** from parse.c ***/
  283. enum parsedbflags {
  284. pdb_recordavailable =001, /* Store in `available' in-core structures, not `status' */
  285. pdb_rejectstatus =002, /* Throw up an error if `Status' encountered */
  286. pdb_weakclassification=004, /* Ignore priority/section info if we already have any */
  287. pdb_ignorefiles =010, /* Ignore files info if we already have them */
  288. pdb_ignoreolder =020 /* Ignore packages with older versions already read */
  289. };
  290. const char *illegal_packagename(const char *p, const char **ep);
  291. int parsedb(const char *filename, enum parsedbflags, struct pkginfo **donep,
  292. FILE *warnto, int *warncount);
  293. void copy_dependency_links(struct pkginfo *pkg,
  294. struct dependency **updateme,
  295. struct dependency *newdepends,
  296. int available);
  297. /*** from parsehelp.c ***/
  298. struct namevalue {
  299. const char *name;
  300. int value, length;
  301. };
  302. extern const struct namevalue booleaninfos[];
  303. extern const struct namevalue priorityinfos[];
  304. extern const struct namevalue statusinfos[];
  305. extern const struct namevalue eflaginfos[];
  306. extern const struct namevalue wantinfos[];
  307. int informativeversion(const struct versionrevision *version);
  308. enum versiondisplayepochwhen { vdew_never, vdew_nonambig, vdew_always };
  309. void varbufversion(struct varbuf*, const struct versionrevision*,
  310. enum versiondisplayepochwhen);
  311. const char *parseversion(struct versionrevision *rversion, const char*);
  312. const char *versiondescribe(const struct versionrevision*,
  313. enum versiondisplayepochwhen);
  314. /*** from dump.c ***/
  315. void writerecord(FILE*, const char*,
  316. const struct pkginfo*, const struct pkginfoperfile*);
  317. void writedb(const char *filename, int available, int mustsync);
  318. void varbufrecord(struct varbuf*, const struct pkginfo*, const struct pkginfoperfile*);
  319. void varbufdependency(struct varbuf *vb, struct dependency *dep);
  320. /* NB THE VARBUF MUST HAVE BEEN INITIALISED AND WILL NOT BE NULL-TERMINATED */
  321. /*** from vercmp.c ***/
  322. bool versionsatisfied(struct pkginfoperfile *it, struct deppossi *against);
  323. bool versionsatisfied3(const struct versionrevision *it,
  324. const struct versionrevision *ref,
  325. enum depverrel verrel);
  326. int versioncompare(const struct versionrevision *version,
  327. const struct versionrevision *refversion);
  328. bool epochsdiffer(const struct versionrevision *a,
  329. const struct versionrevision *b);
  330. /*** from nfmalloc.c ***/
  331. void *nfmalloc(size_t);
  332. char *nfstrsave(const char*);
  333. char *nfstrnsave(const char*, size_t);
  334. void nffreeall(void);
  335. /*** from showpkg.c ***/
  336. struct lstitem;
  337. struct lstitem* parseformat(const char* fmt);
  338. void freeformat(struct lstitem* head);
  339. void show1package(const struct lstitem* head, struct pkginfo *pkg);
  340. DPKG_END_DECLS
  341. #endif /* LIBDPKG_DPKG_DB_H */