xerror();
return FALSE;
}
+
+ if (nextkey - ptr > 1) {
+ --nextkey;
+ /* Clear trailing ; or / */
+ if (*nextkey == ';' || (*nextkey == '/' && *(nextkey - 1) != ':'))
+ *(*envcpy + (nextkey - ptr)) = '\0';
+ }
+
ptr = *envcpy;
nextkey = ptr;
return FALSE;
if (*++ptr == '\0')
return FALSE;
+ if (*ptr == ';') /* Empty location */
+ return FALSE;
kvarr[i].val = ptr;
++i;
}
++ptr;
}
- if (i < maxitems) {
- if (kvarr[i - 1].val && *kvarr[i - 1].val == '\0')
- return FALSE;
- kvarr[i].key = '\0';
- }
+ maxitems = i;
+
+ if (kvarr[i - 1].val && *kvarr[i - 1].val == '\0')
+ return FALSE;
for (i = 0; i < maxitems && kvarr[i].key; ++i)
if (strlen(kvarr[i].val) >= PATH_MAX)
{
int r = 0;
+ if (!kvarr)
+ return NULL;
+
for (; kvarr[r].key && r < max; ++r) {
if (kvarr[r].key == key) {
if (!path)
fprintf(fp, "\nVOLUME: %s of ", coolsize(get_fs_info(path, FREE)));
fprintf(fp, "%s free\n\n", coolsize(get_fs_info(path, CAPACITY)));
- if (bookmark[0].val) {
+ if (bookmark) {
fprintf(fp, "BOOKMARKS\n");
printkv(bookmark, fp, maxbm);
fprintf(fp, "\n");
}
- if (plug[0].val) {
+ if (plug) {
fprintf(fp, "PLUGIN KEYS\n");
printkv(plug, fp, maxplug);
fprintf(fp, "\n");