#include <unistd.h>
#include <limits.h>
#include <fcntl.h>
+#include <ctype.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
STATE_ARCH, // 6
STATE_SUMMARY, // 7
STATE_DESCRIPTION, // 8
- STATE_UPDATEREPOKEY, // 9
+ STATE_UPDATEREPOKEY, // 9 should go away
+ STATE_CPENAME, // 9
STATE_URLS, // 10
STATE_URL, // 11
STATE_RUNTIMECONFIG, // 12
{ STATE_PRODUCT, "runtimeconfig", STATE_RUNTIMECONFIG, 0 },
{ STATE_PRODUCT, "linguas", STATE_LINGUAS, 0 },
{ STATE_PRODUCT, "updaterepokey", STATE_UPDATEREPOKEY, 1 },
+ { STATE_PRODUCT, "cpename", STATE_CPENAME, 1 },
{ STATE_URLS, "url", STATE_URL, 1 },
{ STATE_LINGUAS, "lang", STATE_LANG, 0 },
{ STATE_REGISTER, "flavor", STATE_FLAVOR, 1 },
}
pd->depth++;
- if (!(sw = pd->swtab[pd->state])) /* no statetable -> no substates */
+ if (!pd->swtab[pd->state]) /* no statetable -> no substates */
{
#if 0
- fprintf(stderr, "into unknown: [?]%s (from: ?, state %d)\n", name, pd->state);
+ fprintf(stderr, "into unknown: %s (from: %d)\n", name, pd->state);
#endif
return;
}
- for (; sw->from == pd->state; sw++) /* find name in statetable */
+ for (sw = pd->swtab[pd->state]; sw->from == pd->state; sw++) /* find name in statetable */
if (!strcmp(sw->ename, name))
break;
if (sw->from != pd->state)
{
#if 0
- fprintf(stderr, "into unknown: [%d]%s (from: %d, state %d)\n", sw->to, name, sw->from, pd->state);
- exit( 1 );
+ fprintf(stderr, "into unknown: %s (from: %d)\n", name, pd->state);
#endif
return;
}
printf("%s\n", pd->content);
}
break;
+ case STATE_CPENAME:
+ if (pd->content)
+ repodata_set_str(pd->data, pd->handle, SOLVABLE_CPE_NAME, pd->content);
default:
break;
}
pd->ctime = 0;
}
- XML_Parser parser = XML_ParserCreate(NULL);
- XML_SetUserData(parser, pd);
- XML_SetElementHandler(parser, startElement, endElement);
- XML_SetCharacterDataHandler(parser, characterData);
-
- for (;;)
+ if (code11)
{
- l = fread(buf, 1, sizeof(buf), fp);
- if (XML_Parse(parser, buf, l, l == 0) == XML_STATUS_ERROR)
+ XML_Parser parser = XML_ParserCreate(NULL);
+ XML_SetUserData(parser, pd);
+ XML_SetElementHandler(parser, startElement, endElement);
+ XML_SetCharacterDataHandler(parser, characterData);
+
+ for (;;)
{
- fprintf(stderr, "repo_products: %s at line %u:%u\n", XML_ErrorString(XML_GetErrorCode(parser)), (unsigned int)XML_GetCurrentLineNumber(parser), (unsigned int)XML_GetCurrentColumnNumber(parser));
- exit(1);
+ l = fread(buf, 1, sizeof(buf), fp);
+ if (XML_Parse(parser, buf, l, l == 0) == XML_STATUS_ERROR)
+ {
+ fprintf(stderr, "repo_products: %s at line %u:%u\n", XML_ErrorString(XML_GetErrorCode(parser)), (unsigned int)XML_GetCurrentLineNumber(parser), (unsigned int)XML_GetCurrentColumnNumber(parser));
+ exit(1);
+ }
+ if (l == 0)
+ break;
}
- if (l == 0)
- break;
+ XML_ParserFree(parser);
}
- XML_ParserFree(parser);
+ else
+ {
+ Id name = 0;
+ Id arch = 0;
+ Id version = 0;
+ int lnum = 0; /* line number */
+ char *ptr, *ptr1;
+ /* parse /etc/<xyz>-release file */
+ while (fgets(buf, sizeof(buf), fp))
+ {
+ /* remove trailing \n */
+ int l = strlen(buf);
+ if (*(buf + l - 1) == '\n')
+ {
+ --l;
+ *(buf + l) = 0;
+ }
+ ++lnum;
+
+ if (lnum == 1)
+ {
+ /* 1st line, <name> [(<arch>)] */
+ ptr = strchr(buf, '(');
+ if (ptr)
+ {
+ ptr1 = ptr - 1;
+ *ptr++ = 0;
+ }
+ else
+ ptr1 = buf + l - 1;
+
+ /* track back until non-blank, non-digit */
+ while (ptr1 > buf
+ && (*ptr1 == ' ' || isdigit(*ptr1) || *ptr1 == '.'))
+ --ptr1;
+ *(++ptr1) = 0;
+ name = str2id(pd->pool, join2("product", ":", buf), 1);
+
+ if (ptr)
+ {
+ /* have arch */
+ char *ptr1 = strchr(ptr, ')');
+ if (ptr1)
+ {
+ *ptr1 = 0;
+ /* downcase arch */
+ ptr1 = ptr;
+ while (*ptr1)
+ {
+ if (isupper(*ptr1)) *ptr1 = tolower(*ptr1);
+ ++ptr1;
+ }
+ arch = str2id(pd->pool, ptr, 1);
+ }
+ }
+ }
+ else if (strncmp(buf, "VERSION", 7) == 0)
+ {
+ ptr = strchr(buf+7, '=');
+ if (ptr)
+ {
+ while (*++ptr == ' ');
+ version = makeevr(pd->pool, ptr);
+ }
+ }
+ }
+ if (name)
+ {
+ Solvable *s = pd->solvable = pool_id2solvable(pd->pool, repo_add_solvable(pd->repo));
+ s->name = name;
+ if (version)
+ s->evr = version;
+ if (arch)
+ s->arch = arch;
+ if (s->arch != ARCH_SRC && s->arch != ARCH_NOSRC)
+ s->provides = repo_addid_dep(pd->repo, s->provides, rel2id(pd->pool, s->name, s->evr, REL_EQ, 1), 0);
+ }
+ }
+ return;
}
+
/*
* parse dir looking for files ending in suffix
*/