Query: strvars
OS: debian
Section: 3pub
Format: Original Unix Latex Style Formatted with HTML and a Horizontal Scroll Bar
STRVARS(3pub) C Programmer's Manual STRVARS(3pub)NAMEstrvars - expand variables in stringSYNOPSIS#include <publib.h> int strvars(char **res, const char *str, char *(*expand)(const char *));DESCRIPTIONstrvars will replaces references to variables in the string str with the values of the variables. A reference to a variable is of the form $(foo) or $x (where x is a single character, but not $). A dollar sign is expressed in the string as $$, and will be converted to $ in the output. Memory for the expanded string is allocated dynamically, and *res is set to point to it. The values of the variables are fetched using the function expand. It is given the name of the variable as its argument, and must return a pointer to the value, or NULL if that variable doesn't exist.RETURN VALUEstrvars will return 0 if successful, or NULL if an error occured (malformed input string, result too big, or unknown variable).EXAMPLETo replace references to environment variables, one would the following. #include <publib.h> #include <stdlib.h> char line[1024]; char *res; if (strvars(&res, line, getenv) == NULL) errormsg(1, 0, "strvars failed"); printf("res = <%s> ", res);SEE ALSOpublib(3), getenv(3)AUTHORLars Wirzenius (lars.wirzenius@helsinki.fi) Publib C Programmer's Manual STRVARS(3pub)