- add_rule_key(rule, &rule->owner, operation, value);
- continue;
- }
-
- if (strcasecmp(key, "GROUP") == 0) {
- valid = 1;
- if (rules->resolve_names && (!strchr(value, '$') && !strchr(value, '%'))) {
- char *endptr;
- strtoul(value, &endptr, 10);
- if (endptr[0] != '\0') {
- char group[32];
- gid_t gid = lookup_group(rules->udev, value);
- dbg(rules->udev, "replacing groupname='%s' by id=%i\n", value, gid);
- sprintf(group, "%u", (unsigned int) gid);
- add_rule_key(rule, &rule->group, operation, group);
- continue;
- }
- }
-
- add_rule_key(rule, &rule->group, operation, value);
- continue;
- }
-
- if (strcasecmp(key, "MODE") == 0) {
- add_rule_key(rule, &rule->mode, operation, value);
- valid = 1;
- continue;
- }
-
- if (strcasecmp(key, "OPTIONS") == 0) {
- const char *pos;
-
- if (strstr(value, "last_rule") != NULL) {
- dbg(rules->udev, "last rule to be applied\n");
- rule->last_rule = 1;
- }
- if (strstr(value, "ignore_device") != NULL) {
- dbg(rules->udev, "device should be ignored\n");
- rule->ignore_device = 1;
- }
- if (strstr(value, "ignore_remove") != NULL) {
- dbg(rules->udev, "remove event should be ignored\n");
- rule->ignore_remove = 1;
- }
- pos = strstr(value, "link_priority=");
- if (pos != NULL) {
- rule->link_priority = atoi(&pos[strlen("link_priority=")]);
- dbg(rules->udev, "link priority=%i\n", rule->link_priority);
- }
- pos = strstr(value, "event_timeout=");
- if (pos != NULL) {
- rule->event_timeout = atoi(&pos[strlen("event_timeout=")]);
- dbg(rules->udev, "event timout=%i\n", rule->event_timeout);
- }
- pos = strstr(value, "string_escape=");
- if (pos != NULL) {
- pos = &pos[strlen("string_escape=")];
- if (strncmp(pos, "none", strlen("none")) == 0)
- rule->string_escape = ESCAPE_NONE;
- else if (strncmp(pos, "replace", strlen("replace")) == 0)
- rule->string_escape = ESCAPE_REPLACE;
- }
- if (strstr(value, "all_partitions") != NULL) {
- dbg(rules->udev, "creation of partition nodes requested\n");
- rule->partitions = DEFAULT_FAKE_PARTITIONS_COUNT;
- }
- valid = 1;
- continue;
- }
-
- err(rules->udev, "unknown key '%s' in %s:%u\n", key, filename, lineno);
- }
-
- if (physdev && rule->wait_for.operation == KEY_OP_UNSET)
- err(rules->udev, "PHYSDEV* values are deprecated and will be removed from a future kernel, \n"
- "please fix it in %s:%u", filename, lineno);
-
- /* skip line if not any valid key was found */
- if (!valid)
- goto invalid;
-
- /* grow buffer and add rule */
- rule_size = sizeof(struct udev_rule) + rule->bufsize;
- padding = (sizeof(size_t) - rule_size % sizeof(size_t)) % sizeof(size_t);
- dbg(rules->udev, "add %zi padding bytes\n", padding);
- rule_size += padding;
- rule->bufsize += padding;
-
- rules->buf = realloc(rules->buf, rules->bufsize + rule_size);
- if (!rules->buf) {
- err(rules->udev, "realloc failed\n");
- goto exit;
- }
- dbg(rules->udev, "adding rule to offset %zi\n", rules->bufsize);
- memcpy(rules->buf + rules->bufsize, rule, rule_size);
- rules->bufsize += rule_size;
-exit:
- return 0;
-
-invalid:
- err(rules->udev, "invalid rule '%s:%u'\n", filename, lineno);
- return -1;
-}
-
-static int parse_file(struct udev_rules *rules, const char *filename)