Use Windows KTM (atomic transactions) where supported.
Increment current header version to 2
2 * Copyright (C) 2008 Kristian Høgsberg <krh@redhat.com>
3 * Copyright (C) 2008 Red Hat, Inc
4 * Copyright (C) 2009, 2011 J. Ali Harlow <ali@juiblex.co.uk>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
28 #include <sys/types.h>
37 #include "razor-internal.h"
41 provider_satisfies_requirement(struct razor_property *provider,
42 const char *provider_strings,
47 const char *provided = &provider_strings[provider->version];
52 if (flags & RAZOR_PROPERTY_LESS)
58 cmp = razor_versioncmp(provided, required);
60 switch (flags & RAZOR_PROPERTY_RELATION_MASK) {
61 case RAZOR_PROPERTY_LESS:
64 case RAZOR_PROPERTY_LESS | RAZOR_PROPERTY_EQUAL:
67 /* fall through: FIXME, make sure this is correct */
69 case RAZOR_PROPERTY_EQUAL:
73 /* "foo == 1.1" is satisfied by "foo 1.1-2" */
74 len = strlen(required);
75 if (!strncmp(required, provided, len) && provided[len] == '-')
79 case RAZOR_PROPERTY_GREATER | RAZOR_PROPERTY_EQUAL:
82 case RAZOR_PROPERTY_GREATER:
86 /* shouldn't happen */
90 #define TRANS_PACKAGE_PRESENT 1
91 #define TRANS_PACKAGE_UPDATE 2
92 #define TRANS_PROPERTY_SATISFIED 0x80000000
94 struct transaction_set {
95 struct razor_set *set;
100 struct razor_transaction {
101 int package_count, errors;
102 struct transaction_set system, upstream;
104 struct razor_merger *merger;
108 transaction_set_init(struct transaction_set *ts, struct razor_set *set)
112 ts->set = razor_set_ref(set);
113 count = set->packages.size / sizeof (struct razor_package);
114 ts->packages = zalloc(count * sizeof *ts->packages);
115 count = set->properties.size / sizeof (struct razor_property);
116 ts->properties = zalloc(count * sizeof *ts->properties);
120 transaction_set_release(struct transaction_set *ts)
122 razor_set_unref(ts->set);
124 free(ts->properties);
128 transaction_set_install_package(struct transaction_set *ts,
129 struct razor_package *package)
131 struct razor_package *pkgs;
135 pkgs = ts->set->packages.data;
137 if (ts->packages[i] == TRANS_PACKAGE_PRESENT)
140 ts->packages[i] = TRANS_PACKAGE_PRESENT;
142 prop = list_first(&package->properties, &ts->set->property_pool);
144 ts->properties[prop->data]++;
145 prop = list_next(prop);
150 transaction_set_remove_package(struct transaction_set *ts,
151 struct razor_package *package)
153 struct razor_package *pkgs;
157 pkgs = ts->set->packages.data;
159 if (ts->packages[i] == 0)
164 prop = list_first(&package->properties, &ts->set->property_pool);
166 ts->properties[prop->data]--;
167 prop = list_next(prop);
171 RAZOR_EXPORT struct razor_transaction *
172 razor_transaction_create(struct razor_set *system, struct razor_set *upstream)
174 struct razor_transaction *trans;
175 struct razor_package *p, *spkgs, *pend;
177 trans = zalloc(sizeof *trans);
178 transaction_set_init(&trans->system, system);
179 transaction_set_init(&trans->upstream, upstream);
181 spkgs = trans->system.set->packages.data;
182 pend = trans->system.set->packages.data +
183 trans->system.set->packages.size;
184 for (p = spkgs; p < pend; p++)
185 transaction_set_install_package(&trans->system, p);
191 razor_transaction_install_package(struct razor_transaction *trans,
192 struct razor_package *package)
194 assert (trans != NULL);
195 assert (package != NULL);
197 transaction_set_install_package(&trans->upstream, package);
202 razor_transaction_remove_package(struct razor_transaction *trans,
203 struct razor_package *package)
205 assert (trans != NULL);
206 assert (package != NULL);
208 transaction_set_remove_package(&trans->system, package);
213 razor_transaction_update_package(struct razor_transaction *trans,
214 struct razor_package *package)
216 struct razor_package *spkgs, *upkgs, *end;
218 assert (trans != NULL);
219 assert (package != NULL);
221 spkgs = trans->system.set->packages.data;
222 upkgs = trans->upstream.set->packages.data;
223 end = trans->system.set->packages.data +
224 trans->system.set->packages.size;
225 if (spkgs <= package && package < end)
226 trans->system.packages[package - spkgs] |= TRANS_PACKAGE_UPDATE;
228 trans->upstream.packages[package - upkgs] |= TRANS_PACKAGE_UPDATE;
232 struct razor_property *p, *start, *end;
238 prop_iter_init(struct prop_iter *pi, struct transaction_set *ts)
240 pi->p = ts->set->properties.data;
241 pi->start = ts->set->properties.data;
242 pi->end = ts->set->properties.data + ts->set->properties.size;
243 pi->pool = ts->set->string_pool.data;
244 pi->present = ts->properties;
248 prop_iter_next(struct prop_iter *pi, uint32_t flags, struct razor_property **p)
250 while (pi->p < pi->end) {
251 if ((pi->present[pi->p - pi->start] & ~TRANS_PROPERTY_SATISFIED) &&
252 (pi->p->flags & RAZOR_PROPERTY_TYPE_MASK) == flags) {
262 static struct razor_property *
263 prop_iter_seek_to(struct prop_iter *pi,
264 uint32_t flags, const char *match)
268 while (pi->p < pi->end && strcmp(&pi->pool[pi->p->name], match) < 0)
271 if (pi->p == pi->end || strcmp(&pi->pool[pi->p->name], match) > 0)
275 while (pi->p < pi->end &&
276 pi->p->name == name &&
277 (pi->p->flags & RAZOR_PROPERTY_TYPE_MASK) != flags)
280 if (pi->p == pi->end || pi->p->name != name)
286 /* Remove packages from set that provide any of the matching (same
287 * name and type) providers from ppi onwards that match the
288 * requirement that rpi points to. */
290 remove_matching_providers(struct razor_transaction *trans,
291 struct prop_iter *ppi,
295 struct razor_property *p;
296 struct razor_package *pkg, *pkgs;
297 struct razor_package_iterator pkg_iter;
298 struct razor_set *set;
302 if (ppi->present == trans->system.properties)
303 set = trans->system.set;
305 set = trans->upstream.set;
307 pkgs = (struct razor_package *) set->packages.data;
308 type = ppi->p->flags & RAZOR_PROPERTY_TYPE_MASK;
311 p->name == ppi->p->name &&
312 (p->flags & RAZOR_PROPERTY_TYPE_MASK) == type;
314 if (!ppi->present[p - ppi->start])
316 if (!provider_satisfies_requirement(p, ppi->pool,
320 razor_package_iterator_init_for_property(&pkg_iter, set, p);
321 while (razor_package_iterator_next(&pkg_iter, &pkg,
322 RAZOR_DETAIL_NAME, &n,
323 RAZOR_DETAIL_VERSION, &v,
324 RAZOR_DETAIL_LAST)) {
326 fprintf(stderr, "removing %s-%s\n", n, v);
328 razor_transaction_remove_package(trans, pkg);
334 flag_matching_providers(struct razor_transaction *trans,
335 struct prop_iter *ppi,
336 struct razor_property *r,
337 struct prop_iter *rpi,
340 struct razor_property *p;
341 struct razor_package *pkg, *pkgs;
342 struct razor_package_iterator pkg_iter;
343 struct razor_set *set;
344 const char *name, *version;
345 uint32_t *flags, type;
347 if (ppi->present == trans->system.properties) {
348 set = trans->system.set;
349 flags = trans->system.packages;
351 set = trans->upstream.set;
352 flags = trans->upstream.packages;
355 pkgs = (struct razor_package *) set->packages.data;
356 type = ppi->p->flags & RAZOR_PROPERTY_TYPE_MASK;
359 p->name == ppi->p->name &&
360 (p->flags & RAZOR_PROPERTY_TYPE_MASK) == type;
362 if (!ppi->present[p - ppi->start])
364 if (!provider_satisfies_requirement(p, ppi->pool,
366 &rpi->pool[r->version]))
369 razor_package_iterator_init_for_property(&pkg_iter, set, p);
370 while (razor_package_iterator_next(&pkg_iter, &pkg,
371 RAZOR_DETAIL_NAME, &name,
372 RAZOR_DETAIL_VERSION, &version,
373 RAZOR_DETAIL_LAST)) {
376 fprintf(stderr, "flagging %s-%s for providing %s matching %s %s\n",
380 rpi->pool + r->version);
382 flags[pkg - pkgs] |= flag;
387 static struct razor_package *
388 pick_matching_provider(struct razor_set *set,
389 struct prop_iter *ppi,
393 struct razor_property *p;
394 struct razor_package *pkgs;
398 /* This is where we decide which pkgs to pull in to satisfy a
399 * requirement. There may be several different providers
400 * (different versions) and each version of a provider may
401 * come from a number of packages. We pick the first package
402 * from the first provider that matches. */
404 pkgs = set->packages.data;
405 type = ppi->p->flags & RAZOR_PROPERTY_TYPE_MASK;
408 p->name == ppi->p->name &&
409 (p->flags & RAZOR_PROPERTY_TYPE_MASK) == type &&
410 ppi->present[p - ppi->start] == 0;
412 if (!provider_satisfies_requirement(p, ppi->pool,
416 i = list_first(&p->packages, &set->package_pool);
418 return &pkgs[i->data];
425 remove_obsoleted_packages(struct razor_transaction *trans)
427 struct razor_property *up;
428 struct razor_package *spkgs;
429 struct prop_iter spi, upi;
431 spkgs = trans->system.set->packages.data;
432 prop_iter_init(&spi, &trans->system);
433 prop_iter_init(&upi, &trans->upstream);
435 while (prop_iter_next(&upi, RAZOR_PROPERTY_OBSOLETES, &up)) {
436 if (!prop_iter_seek_to(&spi, RAZOR_PROPERTY_PROVIDES,
437 &upi.pool[up->name]))
439 remove_matching_providers(trans, &spi, up->flags,
440 &upi.pool[up->version]);
445 any_provider_satisfies_requirement(struct prop_iter *ppi,
449 struct razor_property *p;
452 type = ppi->p->flags & RAZOR_PROPERTY_TYPE_MASK;
455 p->name == ppi->p->name &&
456 (p->flags & RAZOR_PROPERTY_TYPE_MASK) == type;
458 if (ppi->present[p - ppi->start] > 0 &&
459 provider_satisfies_requirement(p, ppi->pool,
468 clear_requires_flags(struct transaction_set *ts)
470 struct razor_property *p;
475 count = ts->set->properties.size / sizeof *p;
476 p = ts->set->properties.data;
477 pool = ts->set->string_pool.data;
478 for (i = 0; i < count; i++) {
479 ts->properties[i] &= ~TRANS_PROPERTY_SATISFIED;
480 sub = strchr(&pool[p[i].name], '(');
481 if (sub && sub[strlen(sub) - 1] == ')') {
482 sub = strdup(sub + 1);
483 sub[strlen(sub) - 1] = '\0';
484 if (strncmp(&pool[p[i].name], "rpmlib(", 7) == 0)
485 ts->properties[i] |= TRANS_PROPERTY_SATISFIED;
486 if (strncmp(&pool[p[i].name], "lua(", 4) == 0 &&
487 razor_get_lua_loader(sub) &&
488 p[i].flags & RAZOR_PROPERTY_SCRIPT_MASK)
489 ts->properties[i] |= TRANS_PROPERTY_SATISFIED;
496 mark_satisfied_requires(struct razor_transaction *trans,
497 struct transaction_set *rts,
498 struct transaction_set *pts)
500 struct prop_iter rpi, ppi;
501 struct razor_property *rp;
503 prop_iter_init(&rpi, rts);
504 prop_iter_init(&ppi, pts);
506 while (prop_iter_next(&rpi, RAZOR_PROPERTY_REQUIRES, &rp)) {
507 if (!prop_iter_seek_to(&ppi, RAZOR_PROPERTY_PROVIDES,
508 &rpi.pool[rp->name]))
511 if (any_provider_satisfies_requirement(&ppi, rp->flags,
512 &rpi.pool[rp->version]))
513 rpi.present[rp - rpi.start] |= TRANS_PROPERTY_SATISFIED;
518 mark_all_satisfied_requires(struct razor_transaction *trans)
520 clear_requires_flags(&trans->system);
521 clear_requires_flags(&trans->upstream);
522 mark_satisfied_requires(trans, &trans->system, &trans->system);
523 mark_satisfied_requires(trans, &trans->system, &trans->upstream);
524 mark_satisfied_requires(trans, &trans->upstream, &trans->system);
525 mark_satisfied_requires(trans, &trans->upstream, &trans->upstream);
529 update_unsatisfied_packages(struct razor_transaction *trans)
531 struct razor_package *spkgs, *pkg;
532 struct razor_property *sp;
533 struct prop_iter spi;
534 struct razor_package_iterator pkg_iter;
537 spkgs = trans->system.set->packages.data;
538 prop_iter_init(&spi, &trans->system);
540 while (prop_iter_next(&spi, RAZOR_PROPERTY_REQUIRES, &sp)) {
541 if (spi.present[sp - spi.start] & TRANS_PROPERTY_SATISFIED)
544 razor_package_iterator_init_for_property(&pkg_iter,
547 while (razor_package_iterator_next(&pkg_iter, &pkg,
548 RAZOR_DETAIL_NAME, &name,
549 RAZOR_DETAIL_LAST)) {
551 fprintf(stderr, "updating %s because %s %s %s "
553 name, spi.pool + sp->name,
554 razor_property_relation_to_string(sp),
555 spi.pool + sp->version);
557 trans->system.packages[pkg - spkgs] |=
558 TRANS_PACKAGE_UPDATE;
564 razor_transaction_update_all(struct razor_transaction *trans)
566 struct razor_package *p;
569 assert (trans != NULL);
571 count = trans->system.set->packages.size / sizeof *p;
572 for (i = 0; i < count; i++)
573 trans->system.packages[i] |= TRANS_PACKAGE_UPDATE;
577 update_conflicted_packages(struct razor_transaction *trans)
579 struct razor_package *pkg, *spkgs;
580 struct razor_property *up, *sp;
581 struct prop_iter spi, upi;
582 struct razor_package_iterator pkg_iter;
583 const char *name, *version;
585 spkgs = trans->system.set->packages.data;
586 prop_iter_init(&spi, &trans->system);
587 prop_iter_init(&upi, &trans->upstream);
589 while (prop_iter_next(&spi, RAZOR_PROPERTY_CONFLICTS, &sp)) {
590 if (!prop_iter_seek_to(&upi, RAZOR_PROPERTY_PROVIDES,
591 &spi.pool[sp->name]))
594 if (!any_provider_satisfies_requirement(&upi, sp->flags,
595 &spi.pool[sp->version]))
598 razor_package_iterator_init_for_property(&pkg_iter,
601 while (razor_package_iterator_next(&pkg_iter, &pkg,
602 RAZOR_DETAIL_NAME, &name,
603 RAZOR_DETAIL_VERSION, &version,
604 RAZOR_DETAIL_LAST)) {
606 fprintf(stderr, "updating %s %s because it "
607 "conflicts with %s\n",
608 name, version, spi.pool + sp->name);
610 trans->system.packages[pkg - spkgs] |=
611 TRANS_PACKAGE_UPDATE;
615 prop_iter_init(&spi, &trans->system);
616 prop_iter_init(&upi, &trans->upstream);
618 while (prop_iter_next(&upi, RAZOR_PROPERTY_CONFLICTS, &up)) {
619 sp = prop_iter_seek_to(&spi, RAZOR_PROPERTY_PROVIDES,
620 &upi.pool[upi.p->name]);
623 flag_matching_providers(trans, &spi, up, &upi,
624 TRANS_PACKAGE_UPDATE);
629 pull_in_requirements(struct razor_transaction *trans,
630 struct prop_iter *rpi, struct prop_iter *ppi)
632 struct razor_property *rp, *pp;
633 struct razor_package *pkg, *upkgs;
635 upkgs = trans->upstream.set->packages.data;
636 while (prop_iter_next(rpi, RAZOR_PROPERTY_REQUIRES, &rp)) {
637 if (rpi->present[rp - rpi->start] & TRANS_PROPERTY_SATISFIED)
640 pp = prop_iter_seek_to(ppi, RAZOR_PROPERTY_PROVIDES,
641 &rpi->pool[rp->name]);
644 pkg = pick_matching_provider(trans->upstream.set,
646 &rpi->pool[rp->version]);
650 rpi->present[rp - rpi->start] |= TRANS_PROPERTY_SATISFIED;
653 fprintf(stderr, "pulling in %s-%s.%s which provides %s %s %s "
654 "to satisfy %s %s %s\n",
655 ppi->pool + pkg->name,
656 ppi->pool + pkg->version,
657 ppi->pool + pkg->arch,
658 ppi->pool + pp->name,
659 razor_property_relation_to_string(pp),
660 ppi->pool + pp->version,
661 &rpi->pool[rp->name],
662 razor_property_relation_to_string(rp),
663 &rpi->pool[rp->version]);
666 trans->upstream.packages[pkg - upkgs] |= TRANS_PACKAGE_UPDATE;
671 pull_in_all_requirements(struct razor_transaction *trans)
673 struct prop_iter rpi, ppi;
675 prop_iter_init(&rpi, &trans->system);
676 prop_iter_init(&ppi, &trans->upstream);
677 pull_in_requirements(trans, &rpi, &ppi);
679 prop_iter_init(&rpi, &trans->upstream);
680 prop_iter_init(&ppi, &trans->upstream);
681 pull_in_requirements(trans, &rpi, &ppi);
685 flush_scheduled_system_updates(struct razor_transaction *trans)
687 struct razor_package_iterator *pi;
688 struct razor_package *p, *pkg, *spkgs;
689 struct prop_iter ppi;
690 const char *name, *version;
692 spkgs = trans->system.set->packages.data;
693 pi = razor_package_iterator_create(trans->system.set);
694 prop_iter_init(&ppi, &trans->upstream);
696 while (razor_package_iterator_next(pi, &p,
697 RAZOR_DETAIL_NAME, &name,
698 RAZOR_DETAIL_VERSION, &version,
699 RAZOR_DETAIL_LAST)) {
700 if (!(trans->system.packages[p - spkgs] & TRANS_PACKAGE_UPDATE))
703 if (!prop_iter_seek_to(&ppi, RAZOR_PROPERTY_PROVIDES, name))
706 if (any_provider_satisfies_requirement(&ppi,
707 RAZOR_PROPERTY_GREATER,
709 razor_transaction_remove_package(trans, p);
713 pkg = pick_matching_provider(trans->upstream.set, &ppi,
714 RAZOR_PROPERTY_GREATER, version);
718 razor_transaction_remove_package(trans, p);
719 razor_transaction_install_package(trans, pkg);
722 razor_package_iterator_destroy(pi);
726 flush_scheduled_upstream_updates(struct razor_transaction *trans)
728 struct razor_package_iterator *pi;
729 struct razor_package *p, *upkgs;
730 struct prop_iter spi;
731 const char *name, *version;
733 upkgs = trans->upstream.set->packages.data;
734 pi = razor_package_iterator_create(trans->upstream.set);
735 prop_iter_init(&spi, &trans->system);
737 while (razor_package_iterator_next(pi, &p,
738 RAZOR_DETAIL_NAME, &name,
739 RAZOR_DETAIL_VERSION, &version,
740 RAZOR_DETAIL_LAST)) {
741 if (!(trans->upstream.packages[p - upkgs] & TRANS_PACKAGE_UPDATE))
744 if (prop_iter_seek_to(&spi, RAZOR_PROPERTY_PROVIDES, name))
745 remove_matching_providers(trans,
749 razor_transaction_install_package(trans, p);
751 fprintf(stderr, "installing %s-%s\n", name, version);
757 razor_transaction_resolve(struct razor_transaction *trans)
761 flush_scheduled_system_updates(trans);
762 flush_scheduled_upstream_updates(trans);
764 while (last < trans->changes) {
765 last = trans->changes;
766 remove_obsoleted_packages(trans);
767 mark_all_satisfied_requires(trans);
768 update_unsatisfied_packages(trans);
769 update_conflicted_packages(trans);
770 pull_in_all_requirements(trans);
771 flush_scheduled_system_updates(trans);
772 flush_scheduled_upstream_updates(trans);
775 return trans->changes;
779 describe_unsatisfied(struct razor_set *set, struct razor_property *rp)
781 struct razor_package_iterator pi;
782 struct razor_package *pkg;
783 const char *name, *version, *arch, *pool;
785 pool = set->string_pool.data;
786 if (pool[rp->version] == '\0') {
787 razor_package_iterator_init_for_property(&pi, set, rp);
788 while (razor_package_iterator_next(&pi, &pkg,
789 RAZOR_DETAIL_NAME, &name,
790 RAZOR_DETAIL_VERSION, &version,
791 RAZOR_DETAIL_ARCH, &arch,
793 fprintf(stderr, "%s is needed by %s-%s.%s\n",
795 name, version, arch);
797 razor_package_iterator_init_for_property(&pi, set, rp);
798 while (razor_package_iterator_next(&pi, &pkg,
799 RAZOR_DETAIL_NAME, &name,
800 RAZOR_DETAIL_VERSION, &version,
801 RAZOR_DETAIL_ARCH, &arch,
803 fprintf(stderr, "%s %s %s is needed by %s-%s.%s\n",
805 razor_property_relation_to_string(rp),
807 name, version, arch);
812 razor_transaction_describe(struct razor_transaction *trans)
814 struct prop_iter rpi;
815 struct razor_property *rp;
818 flush_scheduled_system_updates(trans);
819 flush_scheduled_upstream_updates(trans);
820 mark_all_satisfied_requires(trans);
823 prop_iter_init(&rpi, &trans->system);
824 while (prop_iter_next(&rpi, RAZOR_PROPERTY_REQUIRES, &rp)) {
825 if (!(rpi.present[rp - rpi.start] & TRANS_PROPERTY_SATISFIED)) {
826 describe_unsatisfied(trans->system.set, rp);
831 prop_iter_init(&rpi, &trans->upstream);
832 while (prop_iter_next(&rpi, RAZOR_PROPERTY_REQUIRES, &rp)) {
833 if (!(rpi.present[rp - rpi.start] & TRANS_PROPERTY_SATISFIED)) {
834 describe_unsatisfied(trans->upstream.set, rp);
843 razor_transaction_unsatisfied_property(struct razor_transaction *trans,
849 struct razor_property *p;
851 prop_iter_init(&pi, &trans->system);
852 while (prop_iter_next(&pi, flags & RAZOR_PROPERTY_TYPE_MASK, &p)) {
853 if (!(trans->system.properties[p - pi.start] & TRANS_PROPERTY_SATISFIED) &&
855 strcmp(&pi.pool[p->name], name) == 0 &&
856 strcmp(&pi.pool[p->version], version) == 0)
861 prop_iter_init(&pi, &trans->upstream);
862 while (prop_iter_next(&pi, flags & RAZOR_PROPERTY_TYPE_MASK, &p)) {
863 if (!(trans->upstream.properties[p - pi.start] & TRANS_PROPERTY_SATISFIED) &&
865 strcmp(&pi.pool[p->name], name) == 0 &&
866 strcmp(&pi.pool[p->version], version) == 0)
874 RAZOR_EXPORT struct razor_set *
875 razor_transaction_commit(struct razor_transaction *trans)
877 struct razor_package *u, *uend, *upkgs, *s, *send, *spkgs;
881 s = trans->system.set->packages.data;
882 spkgs = trans->system.set->packages.data;
883 send = trans->system.set->packages.data +
884 trans->system.set->packages.size;
885 spool = trans->system.set->string_pool.data;
887 u = trans->upstream.set->packages.data;
888 upkgs = trans->upstream.set->packages.data;
889 uend = trans->upstream.set->packages.data +
890 trans->upstream.set->packages.size;
891 upool = trans->upstream.set->string_pool.data;
893 trans->merger = razor_merger_create(trans->system.set,
894 trans->upstream.set);
895 while (s < send || u < uend) {
896 if (s < send && u < uend)
897 cmp = strcmp(&spool[s->name], &upool[u->name]);
904 if (trans->system.packages[s - spkgs] & TRANS_PACKAGE_PRESENT)
905 razor_merger_add_package(trans->merger, s);
907 } else if (cmp == 0) {
908 if (trans->system.packages[s - spkgs] & TRANS_PACKAGE_PRESENT)
909 razor_merger_add_package(trans->merger, s);
910 if (trans->upstream.packages[u - upkgs] & TRANS_PACKAGE_PRESENT)
911 razor_merger_add_package(trans->merger, u);
916 if (trans->upstream.packages[u - upkgs] & TRANS_PACKAGE_PRESENT)
917 razor_merger_add_package(trans->merger, u);
922 return razor_merger_commit(trans->merger);
926 razor_transaction_fixup_package(struct razor_transaction *trans,
927 struct razor_package *package,
928 struct razor_rpm *rpm)
930 const char *preunprog, *preun, *postunprog, *postun;
932 razor_rpm_get_details(rpm,
933 RAZOR_DETAIL_PREUNPROG, &preunprog,
934 RAZOR_DETAIL_PREUN, &preun,
935 RAZOR_DETAIL_POSTUNPROG, &postunprog,
936 RAZOR_DETAIL_POSTUN, &postun,
939 razor_merger_package_add_script(trans->merger, package,
940 RAZOR_PROPERTY_PREUN,
942 razor_merger_package_add_script(trans->merger, package,
943 RAZOR_PROPERTY_POSTUN,
948 razor_transaction_destroy(struct razor_transaction *trans)
950 assert (trans != NULL);
953 razor_merger_destroy(trans->merger);
954 transaction_set_release(&trans->system);
955 transaction_set_release(&trans->upstream);