/****************************************************************************** ** This file is part of profile-qt ** ** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies). ** All rights reserved. ** ** Redistribution and use in source and binary forms, with or without ** modification, are permitted provided that the following conditions are met: ** ** Redistributions of source code must retain the above copyright notice, ** this list of conditions and the following disclaimer. Redistributions in ** binary form must reproduce the above copyright notice, this list of ** conditions and the following disclaimer in the documentation and/or ** other materials provided with the distribution. ** ** Neither the name of Nokia Corporation nor the names of its contributors ** may be used to endorse or promote products derived from this software ** without specific prior written permission. ** ** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" ** AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, ** THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR ** PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR ** CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, ** EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, ** PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; ** OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, ** WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR ** OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ** ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ******************************************************************************/ #ifndef PROFILEVALUE_H_ # define PROFILEVALUE_H_ # ifdef __cplusplus extern "C" { # elif 0 } /* fool JED indentation ... */ # endif /* ------------------------------------------------------------------------- * * profileval_t * ------------------------------------------------------------------------- */ /** \brief shorthand */ typedef struct profileval_t profileval_t; /** \brief key value type -triplet * * Profile data entries have: name, value and type. * * The profileval_t structure is used to convey this * information from profile daemon to client applications. */ struct profileval_t { /** \brief Key string */ char *pv_key; /** \brief Value string */ char *pv_val; /** \brief Type string */ char *pv_type; }; /** * Profile value constructor. * * @param self value structure */ void profileval_ctor(profileval_t *self); /** * Profile value destructor. * * @param self value structure */ void profileval_dtor(profileval_t *self); /** * Extended profile value constructor. * * @param self value structure * @param key key string * @param val value string * @param type type string * */ void profileval_ctor_ex(profileval_t *self, const char *key, const char *val, const char *type); /** * Utility function for freeing an array of profile values. * * The vec must either be NULL or * contain valid profile value entries * and a terminator entry with NULL pv_key entry. * * @param vec array of profile values */ void profileval_free_vector(profileval_t *vec); # ifdef __cplusplus }; # endif #endif /* PROFILEVALUE_H_ */