GSP
Quick Navigator

Search Site

Unix VPS
A - Starter
B - Basic
C - Preferred
D - Commercial
MPS - Dedicated
Previous VPSs
* Sign Up! *

Support
Contact Us
Online Help
Handbooks
Domain Status
Man Pages

FAQ
Virtual Servers
Pricing
Billing
Technical

Network
Facilities
Connectivity
Topology Map

Miscellaneous
Server Agreement
Year 2038
Credits
 

USA Flag

 

 

Man Pages


Manual Reference Pages  -  STRVARS (3)

NAME

strvars - expand variables in string

CONTENTS

Synopsis
Description
Example
Author

SYNOPSIS

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

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.

RETURN VALUE

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

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);

SEE ALSO

publib(3), getenv(3)

AUTHOR

Lars Wirzenius (lars.wirzenius@helsinki.fi)
Search for    or go to Top of page |  Section 3 |  Main Index


Publib STRVARS (3) C Programmer's Manual

Powered by GSP Visit the GSP FreeBSD Man Page Interface.
Output converted with manServer 1.07.