cc [ flag… ] file… –lscf [ library… ]
#include <libscf.h>
ssize_t scf_tmpl_pg_name(const scf_pg_tmpl_t *pg_tmpl,
     char **out);
ssize_t scf_tmpl_pg_type(const scf_pg_tmpl_t *pg_tmpl,
     char **out);
ssize_t scf_tmpl_pg_target(const scf_pg_tmpl_t *pg_tmpl,
     char **out);
int scf_tmpl_pg_required(const scf_pg_tmpl_t *pg_tmpl,
     uint8_t *out)
ssize_t scf_tmpl_pg_common_name(const scf_pg_tmpl_t *pg_tmpl,
     char * locale, char **out);
ssize_t scf_tmpl_pg_description(const scf_pg_tmpl_t *pg_tmpl,
     char * locale, char **out);
These functions retrieve the metadata about a specific property group. They require that the template for the property group has already been located by one of the scf_tmpl_pg_create(3SCF) suite of functions.
The scf_tmpl_pg_name() function retrieves the name of the property group template and place it in *out. If the property group name is implicitly wildcarded (see smf_template(5)) in the template, this function will return a string containing SCF_TMPL_WILDCARD (“*”) in *out. The caller is responsible for freeing the *out buffer on success.
The scf_tmpl_pg_type() function will retrieve the type of the property group template and place it in *out. If the property group type is implicitly wildcarded (see smf_template(5)) in the template, this function will return a string containing SCF_TMPL_WILDCARD (“*”) in *out. The caller is responsible for freeing the *out buffer on success.
The scf_tmpl_pg_target() function will retrieve the target of the property group template and place it in *out. The caller is responsible for freeing the *out buffer on success.
The scf_tmpl_pg_required() function will determine whether the property group is required and place the result of that check in *out. If required is unset, out will be the default value of 0. If the property is explicitly set to required, out will be 1.
The scf_tmpl_pg_common_name() function will retrieve the property group's localized common name as currently templated and place it in *out. A locale (as described in setlocale(3C)) may be specified, or if the supplied locale is NULL, the current locale will be used. If a common_name in the specified locale is not found, the function will also look for a common_name in the C locale. Some templates will not specify the property group common name. The caller is responsible for freeing the *out buffer on success.
The scf_tmpl_pg_description() function will retrieve the property group's localized description as currently templated and place it in *out. A locale (as described in setlocale(3C)) may be specified, or if the supplied locale is NULL, the current locale will be used. If a description in the specified locale is not found, the function will also look for a description in the C locale. Some templates will not specify the property group description. The caller is responsible for freeing the *out buffer on success.
Upon successful completion, scf_tmpl_pg_name(), scf_tmpl_pg_common_name(), scf_tmpl_pg_description(), scf_tmpl_pg_target(), and scf_tmpl_pg_type() return the length of the string written, not including the terminating null byte. Otherwise, they return -1.
Upon successful completion, scf_tmpl_pg_required() returns 0. Otherwise, it returns -1.
The scf_tmpl_pg_name(), scf_tmpl_pg_common_name(), scf_tmpl_pg_description(), scf_tmpl_pg_required(), scf_tmpl_pg_target(), and scf_tmpl_pg_type() functions will fail if:
The storage mechanism that the repository server (svc.configd(1M)) chose for the operation denied access.
The connection to the repository was lost.
The template property group has been deleted.
The handle passed in has been destroyed.
An internal error occurred.
There is not enough memory to populate the scf_pg_tmpl_t.
The server does not have adequate resources to complete the request.
The handle is not currently bound.
The template could not be read due to access restrictions.
The template data is invalid.
The scf_tmpl_pg_common_name() and scf_tmpl_pg_description() functions will fail if:
The property does not exist or exists and has no value.
The locale string is too long.
See attributes(5) for descriptions of the following attributes:
| 
 | 
svc.configd(1M), scf_tmpl_pg_create(3SCF), setlocale(3C), attributes (5), smf_template(5)