logo
Free, unlimited AI code reviews that run on commit
git-lrc git-lrc GitHub Install Now We'd appreciate a star git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt git-lrc - Free, unlimited AI code reviews that run on commit | Product Hunt

strvars - expand variables in string

Author

       Lars Wirzenius (lars.wirzenius@helsinki.fi)

Publib                                        C Programmer's Manual                                STRVARS(3pub)

Description

strvars  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.

Example

       To 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>\n", res);

Name

       strvars - expand variables in string

Return Value

strvars  will  return  0  if successful, or NULL if an error occurred (malformed input string, result too
       big, or unknown variable).

See Also

publib(3), getenv(3)

Synopsis

       #include <publib.h>
       int strvars(char **res, const char *str, char *(*expand)(const char *));

See Also