satsolver  0.17.2
transaction.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2007-2009, Novell Inc.
3  *
4  * This program is licensed under the BSD license, read LICENSE.BSD
5  * for further information
6  */
7 
8 /*
9  * transaction.h
10  *
11  */
12 
13 #ifndef SATSOLVER_TRANSACTION_H
14 #define SATSOLVER_TRANSACTION_H
15 
16 #ifdef __cplusplus
17 extern "C" {
18 #endif
19 
20 #include "pooltypes.h"
21 #include "queue.h"
22 #include "bitmap.h"
23 
24 struct _Pool;
25 struct _DUChanges;
27 
28 typedef struct _Transaction {
29  struct _Pool *pool; /* back pointer to pool */
30 
31  Queue steps; /* the transaction steps */
32 
37 
39 
40 } Transaction;
41 
42 
43 /* step types */
44 #define SOLVER_TRANSACTION_IGNORE 0x00
45 
46 #define SOLVER_TRANSACTION_ERASE 0x10
47 #define SOLVER_TRANSACTION_REINSTALLED 0x11
48 #define SOLVER_TRANSACTION_DOWNGRADED 0x12
49 #define SOLVER_TRANSACTION_CHANGED 0x13
50 #define SOLVER_TRANSACTION_UPGRADED 0x14
51 #define SOLVER_TRANSACTION_OBSOLETED 0x15
52 
53 #define SOLVER_TRANSACTION_INSTALL 0x20
54 #define SOLVER_TRANSACTION_REINSTALL 0x21
55 #define SOLVER_TRANSACTION_DOWNGRADE 0x22
56 #define SOLVER_TRANSACTION_CHANGE 0x23
57 #define SOLVER_TRANSACTION_UPGRADE 0x24
58 #define SOLVER_TRANSACTION_OBSOLETES 0x25
59 
60 #define SOLVER_TRANSACTION_MULTIINSTALL 0x30
61 #define SOLVER_TRANSACTION_MULTIREINSTALL 0x31
62 
63 #define SOLVER_TRANSACTION_MAXTYPE 0x3f
64 
65 /* modes */
66 #define SOLVER_TRANSACTION_SHOW_ACTIVE (1 << 0)
67 #define SOLVER_TRANSACTION_SHOW_ALL (1 << 1)
68 #define SOLVER_TRANSACTION_SHOW_OBSOLETES (1 << 2)
69 #define SOLVER_TRANSACTION_SHOW_MULTIINSTALL (1 << 3)
70 #define SOLVER_TRANSACTION_CHANGE_IS_REINSTALL (1 << 4)
71 #define SOLVER_TRANSACTION_MERGE_VENDORCHANGES (1 << 5)
72 #define SOLVER_TRANSACTION_MERGE_ARCHCHANGES (1 << 6)
73 
74 #define SOLVER_TRANSACTION_RPM_ONLY (1 << 7)
75 
76 /* extra classifications */
77 #define SOLVER_TRANSACTION_ARCHCHANGE 0x100
78 #define SOLVER_TRANSACTION_VENDORCHANGE 0x101
79 
80 /* order flags */
81 #define SOLVER_TRANSACTION_KEEP_ORDERDATA (1 << 0)
82 
83 extern void transaction_init(Transaction *trans, struct _Pool *pool);
84 extern void transaction_init_clone(Transaction *trans, Transaction *srctrans);
85 extern void transaction_free(Transaction *trans);
86 extern void transaction_free_orderdata(Transaction *trans);
87 extern void transaction_calculate(Transaction *trans, Queue *decisionq, Map *noobsmap);
88 
89 /* if p is installed, returns with pkg(s) obsolete p */
90 /* if p is not installed, returns with pkg(s) we obsolete */
91 extern Id transaction_obs_pkg(Transaction *trans, Id p);
92 extern void transaction_all_obs_pkgs(Transaction *trans, Id p, Queue *pkgs);
93 
94 /* return step type of a transaction element */
95 extern Id transaction_type(Transaction *trans, Id p, int mode);
96 
97 /* return sorted collection of all step types */
98 /* classify_pkgs can be used to return all packages of a type */
99 extern void transaction_classify(Transaction *trans, int mode, Queue *classes);
100 extern void transaction_classify_pkgs(Transaction *trans, int mode, Id type, Id from, Id to, Queue *pkgs);
101 
102 /* return all packages that will be installed after the transaction is run*/
103 /* The new packages are put at the head of the queue, the number of new
104  packages is returned */
105 extern int transaction_installedresult(Transaction *trans, Queue *installedq);
106 
108 void transaction_calc_duchanges(Transaction *trans, struct _DUChanges *mps, int nmps);
109 
110 /* order a transaction */
111 extern void transaction_order(Transaction *trans, int flags);
112 
113 /* roll your own order funcion:
114  * add pkgs free for installation to queue choices after chosen was
115  * installed. start with chosen = 0
116  * needs an ordered transaction created with SOLVER_TRANSACTION_KEEP_ORDERDATA */
117 extern int transaction_order_add_choices(Transaction *trans, Id chosen, Queue *choices);
118 /* add obsoleted packages into transaction steps */
119 extern void transaction_add_obsoleted(Transaction *trans);
120 
121 /* debug function, report problems found in the order */
122 extern void transaction_check_order(Transaction *trans);
123 
124 
125 #ifdef __cplusplus
126 }
127 #endif
128 
129 #endif