2 * Copyright (c) 2007, Novell Inc.
4 * This program is licensed under the BSD license, read LICENSE.BSD
5 * for further information
9 * rpms2solv - create a solv file from multiple rpms
13 #include <sys/types.h>
22 #include "repo_rpmdb.h"
23 #include "repo_solv.h"
24 #include "common_write.h"
27 fgets0(char *s, int size, FILE *stream)
50 main(int argc, char **argv)
52 const char **rpms = 0;
55 int c, i, res, nrpms = 0;
56 Pool *pool = pool_create();
61 const char *basefile = 0;
63 while ((c = getopt(argc, argv, "0b:m:")) >= 0)
82 if (!strcmp(manifest, "-"))
84 else if ((fp = fopen(manifest, "r")) == 0)
93 if (!fgets0(buf, sizeof(buf), fp))
98 if (!fgets(buf, sizeof(buf), fp))
100 if ((p = strchr(buf, '\n')) != 0)
103 rpms = solv_extend(rpms, nrpms, 1, sizeof(char *), 15);
104 rpms[nrpms++] = strdup(buf);
109 while (optind < argc)
111 rpms = solv_extend(rpms, nrpms, 1, sizeof(char *), 15);
112 rpms[nrpms++] = strdup(argv[optind++]);
114 repo = repo_create(pool, "rpms2solv");
115 repo_add_repodata(repo, 0);
117 for (i = 0; i < nrpms; i++)
119 if (repo_add_rpm(repo, rpms[i], REPO_REUSE_REPODATA|REPO_NO_INTERNALIZE))
121 fprintf(stderr, "rpms2solv: %s\n", pool_errstr(pool));
125 repo_internalize(repo);
126 tool_write(repo, basefile, 0);
128 for (c = 0; c < nrpms; c++)
129 free((char *)rpms[c]);