char *
-context_find (char *str)
+context_find (const char *str)
{
struct node *np;
return NULL;
}
+
+
+/*
+ * Helper function to search first, if subtype is non-NULL, for
+ * invoname-string-type/subtype and then, if not yet found,
+ * invoname-string-type. If entry is found but is empty, it is
+ * treated as not found.
+ */
+char *
+context_find_by_type (const char *string, const char *type,
+ const char *subtype) {
+ char *value = NULL;
+
+ if (subtype) {
+ char *cp;
+
+ cp = concat (invo_name, "-", string, "-", type, "/", subtype, NULL);
+ if ((value = context_find (cp)) != NULL && *value == '\0') value = NULL;
+ free (cp);
+ }
+
+ if (value == NULL) {
+ char *cp;
+
+ cp = concat (invo_name, "-", string, "-", type, NULL);
+ if ((value = context_find (cp)) != NULL && *value == '\0') value = NULL;
+ free (cp);
+ }
+
+ return value;
+}