extern "C" {
#endif
+#include <stdio.h>
+
#include "pooltypes.h"
#include "poolid.h"
#include "solvable.h"
+#include "bitmap.h"
#include "queue.h"
#include "strpool.h"
-// see initpool_data[] in pool.c
-
/* well known ids */
-#define ID_NULL STRID_NULL
-#define ID_EMPTY STRID_EMPTY
-#define SOLVABLE_NAME 2
-#define SOLVABLE_ARCH 3
-#define SOLVABLE_EVR 4
-#define SOLVABLE_VENDOR 5
-#define SOLVABLE_PROVIDES 6
-#define SOLVABLE_OBSOLETES 7
-#define SOLVABLE_CONFLICTS 8
-#define SOLVABLE_REQUIRES 9
-#define SOLVABLE_RECOMMENDS 10
-#define SOLVABLE_SUGGESTS 11
-#define SOLVABLE_SUPPLEMENTS 12
-#define SOLVABLE_ENHANCES 13
-#define SOLVABLE_FRESHENS 14
-#define RPM_RPMDBID 15
-#define SOLVABLE_PREREQMARKER 16 // normal requires before this, prereqs after this
-#define SOLVABLE_FILEMARKER 17 // normal provides before this, generated file provides after this
-#define NAMESPACE_INSTALLED 18
-#define NAMESPACE_MODALIAS 19
-#define SYSTEM_SYSTEM 20
-#define ARCH_SRC 21
-#define ARCH_NOSRC 22
-#define ARCH_NOARCH 23
-#define REPODATA_EXTERNAL 24
-#define REPODATA_KEYS 25
-#define REPODATA_LOCATION 26
-
-#define ID_NUM_INTERNAL 27
-
+#include "knownid.h"
/* well known solvable */
#define SYSTEMSOLVABLE 1
/* how many strings to maintain (round robin) */
-#define DEP2STRBUF 16
+#define POOL_TMPSPACEBUF 16
//-----------------------------------------------
struct _Repo;
+struct _Repodata;
+struct _Repokey;
+struct _KeyValue;
+
+typedef struct _Repopos {
+ struct _Repo *repo;
+ Id solvid;
+ Id repodataid;
+ Id schema;
+ Id dp;
+} Repopos;
struct _Pool {
struct _Stringpool ss;
- Reldep *rels; // table of rels: Id -> Reldep
- int nrels; // number of unique rels
- Hashtable relhashtbl; // hash table: (name,evr,op ->) Hash -> Id
+ Reldep *rels; /* table of rels: Id -> Reldep */
+ int nrels; /* number of unique rels */
+ Hashtable relhashtbl; /* hashtable: (name,evr,op)Hash -> Id */
Hashmask relhashmask;
struct _Repo **repos;
int nrepos;
+ struct _Repo *installed; /* packages considered installed */
+
Solvable *solvables;
int nsolvables;
- int promoteepoch; /* 0/1 */
+ const char **languages;
+ int nlanguages;
+ Id *languagecache;
+ int languagecacheother;
+
+ /* flags to tell the library how the installed rpm works */
+ int promoteepoch; /* true: missing epoch is replaced by epoch of dependency */
+ int obsoleteusesprovides; /* true: obsoletes are matched against provides, not names */
+ int implicitobsoleteusesprovides; /* true: implicit obsoletes due to same name are matched against provides, not names */
+ int novirtualconflicts; /* true: conflicts on names, not on provides */
+ int allowselfconflicts; /* true: packages which conflict with itself are installable */
Id *id2arch; /* map arch ids to scores */
Id lastarch; /* last valid entry in id2arch */
Offset whatprovidesdataoff; /* next free slot within whatprovidesdata */
int whatprovidesdataleft; /* number of 'free slots' within whatprovidesdata */
+ /* If nonzero, then consider only the solvables with Ids set in this
+ bitmap for solving. If zero, consider all solvables. */
+ Map *considered;
+
Id (*nscallback)(struct _Pool *, void *data, Id name, Id evr);
void *nscallbackdata;
- /* our dep2str string space */
- char *dep2strbuf[DEP2STRBUF];
- int dep2strlen[DEP2STRBUF];
- int dep2strn;
+ /* our tmp space string space */
+ char *tmpspacebuf[POOL_TMPSPACEBUF];
+ int tmpspacelen[POOL_TMPSPACEBUF];
+ int tmpspacen;
/* debug mask and callback */
int debugmask;
void (*debugcallback)(struct _Pool *, void *data, int type, const char *str);
void *debugcallbackdata;
+
+ /* load callback */
+ FILE * (*loadcallback)(struct _Pool *, struct _Repodata *, void *);
+ void *loadcallbackdata;
+
+ /* search position */
+ Repopos pos;
};
#define SAT_FATAL (1<<0)
#define SAT_DEBUG_RESULT (1<<10)
#define SAT_DEBUG_JOB (1<<11)
#define SAT_DEBUG_SCHUBI (1<<12)
+#define SAT_DEBUG_SOLVER (1<<13)
+#define SAT_DEBUG_TRANSACTION (1<<14)
-#define TYPE_VOID 0
-#define TYPE_ID 1
-#define TYPE_IDARRAY 2
-#define TYPE_STR 3
-#define TYPE_U32 4
-#define TYPE_REL_IDARRAY 5
-
-#define TYPE_ATTR_INT 6
-#define TYPE_ATTR_CHUNK 7
-#define TYPE_ATTR_STRING 8
-#define TYPE_ATTR_INTLIST 9
-#define TYPE_ATTR_LOCALIDS 10
-
-#define TYPE_COUNT_NAMED 11
-#define TYPE_COUNTED 12
-#define TYPE_ATTR_TYPE_MAX 12
-
-#define TYPE_IDVALUEARRAY 13
-#define TYPE_IDVALUEVALUEARRAY 14
+#define SAT_DEBUG_TO_STDERR (1<<30)
//-----------------------------------------------
#define REL_OR 17
#define REL_WITH 18
#define REL_NAMESPACE 19
+#define REL_ARCH 20
+#define REL_FILECONFLICT 21
#if !defined(__GNUC__) && !defined(__attribute__)
# define __attribute__(x)
extern void pool_debug(Pool *pool, int type, const char *format, ...) __attribute__((format(printf, 3, 4)));
+extern char *pool_alloctmpspace(Pool *pool, int len);
+
+extern void pool_set_installed(Pool *pool, struct _Repo *repo);
+
/**
* Solvable management
*/
extern Id pool_add_solvable_block(Pool *pool, int count);
extern void pool_free_solvable_block(Pool *pool, Id start, int count, int reuseids);
-static inline Solvable *pool_id2solvable(Pool *pool, Id p)
+static inline Solvable *pool_id2solvable(const Pool *pool, Id p)
{
return pool->solvables + p;
}
+
extern const char *solvable2str(Pool *pool, Solvable *s);
+static inline const char *solvid2str(Pool *pool, Id p)
+{
+ return solvable2str(pool, pool->solvables + p);
+}
+
+void pool_set_languages(Pool *pool, const char **languages, int nlanguages);
+Id pool_id2langid(Pool *pool, Id id, const char *lang, int create);
+
+Id solvable_lookup_id(Solvable *s, Id keyname);
+unsigned int solvable_lookup_num(Solvable *s, Id keyname, unsigned int notfound);
+const char *solvable_lookup_str(Solvable *s, Id keyname);
+const char *solvable_lookup_str_poollang(Solvable *s, Id keyname);
+const char *solvable_lookup_str_lang(Solvable *s, Id keyname, const char *lang);
+int solvable_lookup_bool(Solvable *s, Id keyname);
+int solvable_lookup_void(Solvable *s, Id keyname);
+char * solvable_get_location(Solvable *s, unsigned int *medianrp);
+const unsigned char *solvable_lookup_bin_checksum(Solvable *s, Id keyname, Id *typep);
+const char *solvable_lookup_checksum(Solvable *s, Id keyname, Id *typep);
+int solvable_identical(Solvable *s1, Solvable *s2);
+Id solvable_selfprovidedep(Solvable *s);
+
+int solvable_trivial_installable_map(Solvable *s, Map *installedmap, Map *conflictsmap);
+int solvable_trivial_installable_repo(Solvable *s, struct _Repo *installed);
+int solvable_trivial_installable_queue(Solvable *s, Queue *installed);
+
+void pool_create_state_maps(Pool *pool, Queue *installed, Map *installedmap, Map *conflictsmap);
+
+int pool_match_nevr_rel(Pool *pool, Solvable *s, Id d);
+int pool_match_dep(Pool *pool, Id d1, Id d2);
+
+static inline int pool_match_nevr(Pool *pool, Solvable *s, Id d)
+{
+ if (!ISRELDEP(d))
+ return d == s->name;
+ else
+ return pool_match_nevr_rel(pool, s, d);
+}
/**
* Prepares a pool for solving
*/
extern void pool_createwhatprovides(Pool *pool);
+extern void pool_addfileprovides(Pool *pool);
+extern void pool_addfileprovides_ids(Pool *pool, struct _Repo *installed, Id **idp);
extern void pool_freewhatprovides(Pool *pool);
extern Id pool_queuetowhatprovides(Pool *pool, Queue *q);
return 0;
if (pool->id2arch && (s->arch > pool->lastarch || !pool->id2arch[s->arch]))
return 0;
+ if (pool->considered)
+ {
+ Id id = s - pool->solvables;
+ if (!MAPTST(pool->considered, id))
+ return 0;
+ }
return 1;
}
-extern Id *pool_addrelproviders(Pool *pool, Id d);
+extern Id pool_addrelproviders(Pool *pool, Id d);
-static inline Id *pool_whatprovides(Pool *pool, Id d)
+static inline Id pool_whatprovides(Pool *pool, Id d)
{
Id v;
if (!ISRELDEP(d))
- return pool->whatprovidesdata + pool->whatprovides[d];
+ return pool->whatprovides[d];
v = GETRELID(d);
if (pool->whatprovides_rel[v])
- return pool->whatprovidesdata + pool->whatprovides_rel[v];
+ return pool->whatprovides_rel[v];
return pool_addrelproviders(pool, d);
}
+static inline Id *pool_whatprovides_ptr(Pool *pool, Id d)
+{
+ Id off = pool_whatprovides(pool, d);
+ return pool->whatprovidesdata + off;
+}
+
extern void pool_setdebuglevel(Pool *pool, int level);
static inline void pool_setdebugcallback(Pool *pool, void (*debugcallback)(struct _Pool *, void *data, int type, const char *str), void *debugcallbackdata)
pool->debugmask = mask;
}
+static inline void pool_setloadcallback(Pool *pool, FILE *(*cb)(struct _Pool *, struct _Repodata *, void *), void *loadcbdata)
+{
+ pool->loadcallback = cb;
+ pool->loadcallbackdata = loadcbdata;
+}
+
+/* search the pool. the following filters are available:
+ * p - search just this solvable
+ * key - search only this key
+ * match - key must match this string
+ */
+void pool_search(Pool *pool, Id p, Id key, const char *match, int flags, int (*callback)(void *cbdata, Solvable *s, struct _Repodata *data, struct _Repokey *key, struct _KeyValue *kv), void *cbdata);
+
+void pool_clear_pos(Pool *pool);
+
+
+typedef struct _duchanges {
+ const char *path;
+ int kbytes;
+ int files;
+} DUChanges;
+
+void pool_calc_duchanges(Pool *pool, Map *installedmap, DUChanges *mps, int nmps);
+int pool_calc_installsizechange(Pool *pool, Map *installedmap);
+void pool_trivial_installable(Pool *pool, Map *installedmap, Queue *pkgs, Queue *res);
+void pool_trivial_installable_noobsoletesmap(Pool *pool, Map *installedmap, Queue *pkgs, Queue *res, Map *noobsoletesmap);
+
+const char *pool_lookup_str(Pool *pool, Id entry, Id keyname);
+Id pool_lookup_id(Pool *pool, Id entry, Id keyname);
+unsigned int pool_lookup_num(Pool *pool, Id entry, Id keyname, unsigned int notfound);
+int pool_lookup_void(Pool *pool, Id entry, Id keyname);
+const unsigned char *pool_lookup_bin_checksum(Pool *pool, Id entry, Id keyname, Id *typep);
+const char *pool_lookup_checksum(Pool *pool, Id entry, Id keyname, Id *typep);
+
+void pool_add_fileconflicts_deps(Pool *pool, Queue *conflicts);
+
+
+
/* loop over all providers of d */
#define FOR_PROVIDES(v, vp, d) \
- for (vp = pool_whatprovides(pool, d) ; (v = *vp++) != 0; )
+ for (vp = pool_whatprovides(pool, d) ; (v = pool->whatprovidesdata[vp++]) != 0; )
+
+/* loop over all repositories */
+/* note that idx is not the repoid */
+#define FOR_REPOS(idx, r) \
+ for (idx = 0; idx < pool->nrepos; idx++) \
+ if ((r = pool->repos[idx]) != 0)
+
#define POOL_DEBUG(type, ...) do {if ((pool->debugmask & (type)) != 0) pool_debug(pool, (type), __VA_ARGS__);} while (0)
#define IF_POOLDEBUG(type) if ((pool->debugmask & (type)) != 0)