char *temp;
linepos = *line;
- if (!linepos)
+ if (linepos == NULL)
return -1;
- if (strchr(linepos, '\\')) {
- dbg("escaped characters are not supported, skip");
- return -1;
- }
-
/* skip whitespace */
while (isspace(linepos[0]))
linepos++;
static int import_program_into_env(struct udevice *udev, const char *program)
{
- char result[1024];
+ char result[2048];
size_t reslen;
if (run_program(program, udev->dev->subsystem, result, sizeof(result), &reslen, (udev_log_priority >= LOG_INFO)) != 0)
}
}
- /* if we have ATTR assignements write value to sysfs file */
+ /* if we have ATTR assignments, write value to sysfs file */
for (i = 0; i < rule->attr.count; i++) {
struct key_pair *pair = &rule->attr.keys[i];
t[0] = '\0';
for (i = 0, j = 0; s[i] != '\0'; i++) {
if (s[i] == '/') {
- memcpy(&t[j], "%2f", 3);
- j += 3;
- } else if (s[i] == '%') {
- memcpy(&t[j], "%25", 3);
- j += 3;
+ memcpy(&t[j], "\\x2f", 4);
+ j += 4;
+ } else if (s[i] == '\\') {
+ memcpy(&t[j], "\\x5c", 4);
+ j += 4;
} else {
t[j] = s[i];
j++;
size_t i, j;
for (i = 0, j = 0; s[i] != '\0'; j++) {
- if (memcmp(&s[i], "%2f", 3) == 0) {
+ if (memcmp(&s[i], "\\x2f", 4) == 0) {
s[j] = '/';
- i += 3;
- }else if (memcmp(&s[i], "%25", 3) == 0) {
- s[j] = '%';
- i += 3;
+ i += 4;
+ }else if (memcmp(&s[i], "\\x5c", 4) == 0) {
+ s[j] = '\\';
+ i += 4;
} else {
s[j] = s[i];
i++;
i++;
continue;
}
+ /* hex encoding */
+ if (str[i] == '\\' && str[i+1] == 'x') {
+ i += 2;
+ continue;
+ }
/* valid utf8 is accepted */
len = utf8_encoded_valid_unichar(&str[i]);
if (len > 1) {