#include "pool.h"
#include "repo_solv.h"
+#ifdef SUSE
+#include "repo_autopattern.h"
+#endif
#include "common_write.h"
static void
exit(0);
}
-static FILE *
+static int
loadcallback (Pool *pool, Repodata *data, void *vdata)
{
- FILE *fp = 0;
- const char *location = repodata_lookup_str(data, REPOENTRY_META, REPOSITORY_LOCATION);
- if (location)
+ FILE *fp;
+ const char *location = repodata_lookup_str(data, SOLVID_META, REPOSITORY_LOCATION);
+ int r;
+
+ if (!location)
+ return 0;
+ fprintf(stderr, "Loading SOLV file %s\n", location);
+ fp = fopen (location, "r");
+ if (!fp)
{
- fprintf(stderr, "Loading SOLV file %s\n", location);
- fp = fopen (location, "r");
- if (!fp)
- perror(location);
+ perror(location);
+ return 0;
}
- return fp;
+ r = repo_add_solv(data->repo, fp, REPO_USE_LOADING|REPO_LOCALPOOL);
+ fclose(fp);
+ return r ? 0 : 1;
}
int
Repo *repo;
const char *basefile = 0;
int with_attr = 0;
+#ifdef SUSE
+ int add_auto = 0;
+#endif
int c;
pool = pool_create();
repo = repo_create(pool, "<mergesolv>");
- while ((c = getopt(argc, argv, "ahb:")) >= 0)
+ while ((c = getopt(argc, argv, "ahb:X")) >= 0)
{
switch (c)
{
case 'b':
basefile = optarg;
break;
+ case 'X':
+#ifdef SUSE
+ add_auto = 1;
+#endif
+ break;
default:
+ usage();
exit(1);
}
}
perror(argv[optind]);
exit(1);
}
- repo_add_solv(repo, fp);
+ if (repo_add_solv(repo, fp, 0))
+ {
+ fprintf(stderr, "repo %s: %s\n", argv[optind], pool_errstr(pool));
+ exit(1);
+ }
fclose(fp);
}
+#ifdef SUSE
+ if (add_auto)
+ repo_add_autopattern(repo, 0);
+#endif
tool_write(repo, basefile, 0);
pool_free(pool);
return 0;