razor.h
author Dan Winship <danw@gnome.org>
Tue Mar 11 18:12:02 2008 -0400 (2008-03-11)
changeset 167 28e203d118c7
parent 147 c3eab84160e5
child 169 2d0ad2111cb0
permissions -rw-r--r--
move the initialization of the root entry name to razor_set_create
krh@27
     1
#ifndef _RAZOR_H_
krh@27
     2
#define _RAZOR_H_
krh@27
     3
krh@43
     4
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
krh@43
     5
krh@43
     6
struct razor_set;
krh@92
     7
struct razor_package;
krh@92
     8
struct razor_property;
krh@43
     9
krh@66
    10
enum razor_property_type {
krh@66
    11
	RAZOR_PROPERTY_REQUIRES,
krh@66
    12
	RAZOR_PROPERTY_PROVIDES,
krh@66
    13
	RAZOR_PROPERTY_CONFLICTS,
krh@66
    14
	RAZOR_PROPERTY_OBSOLETES
krh@66
    15
};
krh@66
    16
danw@109
    17
enum razor_version_relation {
danw@109
    18
	RAZOR_VERSION_LESS,
danw@109
    19
	RAZOR_VERSION_LESS_OR_EQUAL,
danw@109
    20
	RAZOR_VERSION_EQUAL,
danw@109
    21
	RAZOR_VERSION_GREATER_OR_EQUAL,
danw@109
    22
	RAZOR_VERSION_GREATER
danw@109
    23
};
danw@137
    24
extern const char * const razor_version_relations[];
danw@109
    25
krh@91
    26
struct razor_set *razor_set_create(void);
krh@43
    27
struct razor_set *razor_set_open(const char *filename);
krh@43
    28
void razor_set_destroy(struct razor_set *set);
krh@43
    29
int razor_set_write(struct razor_set *set, const char *filename);
krh@43
    30
krh@92
    31
struct razor_package *
krh@92
    32
razor_set_get_package(struct razor_set *set, const char *package);
krh@92
    33
krh@92
    34
struct razor_package_iterator;
krh@92
    35
struct razor_package_iterator *
krh@92
    36
razor_package_iterator_create(struct razor_set *set);
krh@101
    37
struct razor_package_iterator *
krh@101
    38
razor_package_iterator_create_for_property(struct razor_set *set,
krh@101
    39
					   struct razor_property *property);
krh@102
    40
struct razor_package_iterator *
krh@102
    41
razor_package_iterator_create_for_file(struct razor_set *set,
krh@102
    42
				       const char *filename);
krh@92
    43
krh@92
    44
int razor_package_iterator_next(struct razor_package_iterator *pi,
krh@92
    45
				struct razor_package **package,
krh@92
    46
				const char **name, const char **version);
krh@92
    47
void razor_package_iterator_destroy(struct razor_package_iterator *pi);
krh@92
    48
krh@92
    49
struct razor_property_iterator;
krh@92
    50
struct razor_property_iterator *
krh@92
    51
razor_property_iterator_create(struct razor_set *set,
krh@92
    52
			       struct razor_package *package);
krh@92
    53
int razor_property_iterator_next(struct razor_property_iterator *pi,
krh@92
    54
				 struct razor_property **property,
danw@109
    55
				 const char **name,
danw@109
    56
				 enum razor_version_relation *relation,
danw@109
    57
				 const char **version,
krh@92
    58
				 enum razor_property_type *type);
krh@92
    59
void
krh@92
    60
razor_property_iterator_destroy(struct razor_property_iterator *pi);
krh@92
    61
krh@49
    62
void razor_set_list_files(struct razor_set *set, const char *prefix);
krh@56
    63
void razor_set_list_package_files(struct razor_set *set, const char *name);
krh@43
    64
krh@43
    65
void razor_set_list_unsatisfied(struct razor_set *set);
krh@43
    66
krh@44
    67
typedef void (*razor_package_callback_t)(const char *name,
krh@44
    68
					 const char *old_version,
krh@44
    69
					 const char *new_version,
krh@44
    70
					 void *data);
krh@44
    71
void
krh@44
    72
razor_set_diff(struct razor_set *set, struct razor_set *upstream,
krh@44
    73
	       razor_package_callback_t callback, void *data);
krh@44
    74
danw@137
    75
/* Package transactions */
danw@137
    76
danw@137
    77
enum razor_transaction_package_state {
danw@137
    78
	/* Basic states */
danw@145
    79
	RAZOR_PACKAGE_INSTALL,
danw@154
    80
	RAZOR_PACKAGE_FORCED_UPDATE,
danw@145
    81
	RAZOR_PACKAGE_REMOVE,
danw@154
    82
	RAZOR_PACKAGE_OBSOLETED,
danw@137
    83
danw@137
    84
	/* Error states */
danw@145
    85
danw@145
    86
	/* Package requested for install does not exist */
danw@145
    87
	RAZOR_PACKAGE_INSTALL_UNAVAILABLE,
danw@145
    88
	/* Package requested for removal does not exist */
danw@145
    89
	RAZOR_PACKAGE_REMOVE_NOT_INSTALLED,
danw@145
    90
	/* No newer version of package is available */
danw@145
    91
	RAZOR_PACKAGE_UP_TO_DATE,
danw@145
    92
	/* Package marked for both install and remove */
danw@145
    93
	RAZOR_PACKAGE_CONTRADICTION,
danw@145
    94
	/* Package would add a conflict with an already-installed package */
danw@145
    95
	RAZOR_PACKAGE_NEW_CONFLICT,
danw@145
    96
	/* Already-installed package has a conflict against this package */
danw@145
    97
	RAZOR_PACKAGE_OLD_CONFLICT,
danw@145
    98
	/* Requirement of to-be-installed package can't be satisfied */
danw@154
    99
	RAZOR_PACKAGE_UNSATISFIABLE,
danw@137
   100
};
danw@137
   101
danw@137
   102
struct razor_transaction_package {
danw@147
   103
	const char *name, *old_version, *new_version;
danw@147
   104
	struct razor_package *old_package, *new_package;
danw@137
   105
	enum razor_transaction_package_state state;
danw@137
   106
danw@145
   107
	/* dep_package is the name of the package that resulted in
danw@145
   108
	 * this entry being created (or NULL if the user requested the
danw@145
   109
	 * install/remove), with the other dep_ fields providing
danw@145
   110
	 * additional information.
danw@145
   111
	 *
danw@145
   112
	 * For INSTALL, if dep_type is REQUIRES, then dep_package
danw@145
   113
	 * required something that this package provides. If dep_type
danw@145
   114
	 * is CONFLICTS, then dep_package is a package that conflicted
danw@145
   115
	 * with an older version of this package, forcing an upgrade.
danw@145
   116
	 *
danw@145
   117
	 * For REMOVE, if dep_type is REQUIRES, then dep_package is a
danw@145
   118
	 * package that is being removed. If dep_type is OBSOLETES,
danw@145
   119
	 * then dep_package is a package that obsoletes this one.
danw@145
   120
	 *
danw@145
   121
	 * For OLD_CONFLICT or NEW_CONFLICT, dep_package is an
danw@145
   122
	 * existing package that conflicts with this one. The
danw@145
   123
	 * conflicting property comes from the already-installed
danw@145
   124
	 * package for OLD_CONFLICT, or the to-be-installed package
danw@145
   125
	 * for NEW_CONFLICT.
danw@145
   126
	 *
danw@145
   127
	 * For UNSATISFIABLE, the dep_ fields are as for an INSTALL,
danw@145
   128
	 * but the name field will be NULL.
danw@145
   129
	 */
danw@145
   130
	const char *dep_package;
danw@145
   131
	enum razor_property_type dep_type;
danw@145
   132
	const char *dep_property;
danw@145
   133
	enum razor_version_relation dep_relation;
danw@145
   134
	const char *dep_version;
danw@137
   135
};
danw@137
   136
danw@137
   137
struct razor_transaction {
danw@137
   138
	int package_count, errors;
danw@137
   139
	struct razor_transaction_package *packages;
danw@137
   140
danw@137
   141
	struct razor_set *system, *upstream;
danw@137
   142
};
danw@137
   143
danw@137
   144
struct razor_transaction *
danw@137
   145
razor_transaction_create(struct razor_set *system, struct razor_set *upstream,
danw@137
   146
			 int update_count, const char **update_packages,
danw@137
   147
			 int remove_count, const char **remove_packages);
danw@137
   148
void razor_transaction_describe(struct razor_transaction *trans);
danw@137
   149
struct razor_set *razor_transaction_run(struct razor_transaction *trans);
danw@137
   150
void razor_transaction_destroy(struct razor_transaction *trans);
krh@44
   151
krh@44
   152
/* Importer interface; for building a razor set from external sources,
krh@44
   153
 * like yum, rpmdb or razor package files. */
krh@44
   154
krh@30
   155
struct razor_importer;
krh@77
   156
struct razor_rpm;
krh@27
   157
krh@30
   158
struct razor_importer *razor_importer_new(void);
krh@75
   159
void razor_importer_destroy(struct razor_importer *importer);
krh@30
   160
void razor_importer_begin_package(struct razor_importer *importer,
danw@143
   161
				  const char *name, const char *version);
krh@66
   162
void razor_importer_add_property(struct razor_importer *importer,
danw@109
   163
				 const char *name,
danw@109
   164
				 enum razor_version_relation relation,
danw@109
   165
				 const char *version,
krh@66
   166
				 enum razor_property_type type);
krh@46
   167
void razor_importer_add_file(struct razor_importer *importer,
krh@46
   168
			     const char *name);
krh@30
   169
void razor_importer_finish_package(struct razor_importer *importer);
krh@75
   170
krh@75
   171
int razor_importer_add_rpm(struct razor_importer *importer,
krh@77
   172
			   struct razor_rpm *rpm);
krh@75
   173
krh@30
   174
struct razor_set *razor_importer_finish(struct razor_importer *importer);
krh@27
   175
danw@143
   176
void razor_build_evr(char *evr_buf, int size, const char *epoch,
danw@143
   177
		     const char *version, const char *release);
danw@143
   178
krh@70
   179
struct razor_set *razor_set_create_from_yum(void);
krh@28
   180
struct razor_set *razor_set_create_from_rpmdb(void);
krh@27
   181
krh@74
   182
/* RPM functions */
krh@77
   183
krh@77
   184
struct razor_rpm *razor_rpm_open(const char *filename);
krh@77
   185
int razor_rpm_install(struct razor_rpm *rpm, const char *root);
krh@77
   186
int razor_rpm_close(struct razor_rpm *rpm);
krh@74
   187
krh@27
   188
#endif /* _RAZOR_H_ */