libxbps: new func xbps_array_replace_dict_by_name(array, dict, pkgname)
This function replaces a dictionary in an array matched by pkgname, with the dictionary passed in as 2nd argument.
This commit is contained in:
parent
8fa21753b1
commit
0a041cdd2e
@ -55,7 +55,7 @@
|
|||||||
*/
|
*/
|
||||||
#define XBPS_PKGINDEX_VERSION "1.2"
|
#define XBPS_PKGINDEX_VERSION "1.2"
|
||||||
|
|
||||||
#define XBPS_API_VERSION "20111017-2"
|
#define XBPS_API_VERSION "20111019"
|
||||||
#define XBPS_VERSION "0.10.0"
|
#define XBPS_VERSION "0.10.0"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1014,6 +1014,21 @@ bool xbps_remove_string_from_array(prop_array_t array, const char *str);
|
|||||||
*/
|
*/
|
||||||
bool xbps_remove_pkgname_from_array(prop_array_t array, const char *name);
|
bool xbps_remove_pkgname_from_array(prop_array_t array, const char *name);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Replaces a dictionary with another dictionary in \a dict, in the
|
||||||
|
* array \array by matching its "pkgname" object with \a pkgname.
|
||||||
|
*
|
||||||
|
* @param[in] array Proplib array where to look for.
|
||||||
|
* @param[in] dict Proplib dictionary to be added in \a array.
|
||||||
|
* @param[in] pkgname Package name to be matched.
|
||||||
|
*
|
||||||
|
* @return 0 on success, EINVAL if dictionary couldn't be set in
|
||||||
|
* array or ENOENT if no match.
|
||||||
|
*/
|
||||||
|
int xbps_array_replace_dict_by_name(prop_array_t array,
|
||||||
|
prop_dictionary_t dict,
|
||||||
|
const char *pkgname);
|
||||||
|
|
||||||
/*@}*/
|
/*@}*/
|
||||||
|
|
||||||
/** @addtogroup purge */
|
/** @addtogroup purge */
|
||||||
|
40
lib/plist.c
40
lib/plist.c
@ -43,7 +43,7 @@ bool
|
|||||||
xbps_add_obj_to_dict(prop_dictionary_t dict, prop_object_t obj,
|
xbps_add_obj_to_dict(prop_dictionary_t dict, prop_object_t obj,
|
||||||
const char *key)
|
const char *key)
|
||||||
{
|
{
|
||||||
assert(dict != NULL);
|
assert(prop_object_type(dict) == PROP_TYPE_DICTIONARY);
|
||||||
assert(obj != NULL);
|
assert(obj != NULL);
|
||||||
assert(key != NULL);
|
assert(key != NULL);
|
||||||
|
|
||||||
@ -60,7 +60,7 @@ xbps_add_obj_to_dict(prop_dictionary_t dict, prop_object_t obj,
|
|||||||
bool
|
bool
|
||||||
xbps_add_obj_to_array(prop_array_t array, prop_object_t obj)
|
xbps_add_obj_to_array(prop_array_t array, prop_object_t obj)
|
||||||
{
|
{
|
||||||
assert(array != NULL);
|
assert(prop_object_type(array) == PROP_TYPE_ARRAY);
|
||||||
assert(obj != NULL);
|
assert(obj != NULL);
|
||||||
|
|
||||||
if (!prop_array_add(array, obj)) {
|
if (!prop_array_add(array, obj)) {
|
||||||
@ -83,7 +83,7 @@ xbps_callback_array_iter(prop_array_t array,
|
|||||||
int rv = 0;
|
int rv = 0;
|
||||||
bool loop_done = false;
|
bool loop_done = false;
|
||||||
|
|
||||||
assert(array != NULL);
|
assert(prop_object_type(array) == PROP_TYPE_ARRAY);
|
||||||
assert(fn != NULL);
|
assert(fn != NULL);
|
||||||
|
|
||||||
iter = prop_array_iterator(array);
|
iter = prop_array_iterator(array);
|
||||||
@ -111,7 +111,7 @@ xbps_callback_array_iter_in_dict(prop_dictionary_t dict,
|
|||||||
int rv = 0;
|
int rv = 0;
|
||||||
bool cbloop_done = false;
|
bool cbloop_done = false;
|
||||||
|
|
||||||
assert(dict != NULL);
|
assert(prop_object_type(dict) == PROP_TYPE_DICTIONARY);
|
||||||
assert(key != NULL);
|
assert(key != NULL);
|
||||||
assert(fn != NULL);
|
assert(fn != NULL);
|
||||||
|
|
||||||
@ -142,7 +142,7 @@ xbps_callback_array_iter_reverse_in_dict(prop_dictionary_t dict,
|
|||||||
bool cbloop_done = false;
|
bool cbloop_done = false;
|
||||||
unsigned int cnt = 0;
|
unsigned int cnt = 0;
|
||||||
|
|
||||||
assert(dict != NULL);
|
assert(prop_object_type(dict) == PROP_TYPE_DICTIONARY);
|
||||||
assert(key != NULL);
|
assert(key != NULL);
|
||||||
assert(fn != NULL);
|
assert(fn != NULL);
|
||||||
|
|
||||||
@ -170,7 +170,7 @@ xbps_array_iter_from_dict(prop_dictionary_t dict, const char *key)
|
|||||||
{
|
{
|
||||||
prop_array_t array;
|
prop_array_t array;
|
||||||
|
|
||||||
assert(dict != NULL);
|
assert(prop_object_type(dict) == PROP_TYPE_DICTIONARY);
|
||||||
assert(key != NULL);
|
assert(key != NULL);
|
||||||
|
|
||||||
array = prop_dictionary_get(dict, key);
|
array = prop_dictionary_get(dict, key);
|
||||||
@ -182,6 +182,34 @@ xbps_array_iter_from_dict(prop_dictionary_t dict, const char *key)
|
|||||||
return prop_array_iterator(array);
|
return prop_array_iterator(array);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
xbps_array_replace_dict_by_name(prop_array_t array,
|
||||||
|
prop_dictionary_t dict,
|
||||||
|
const char *pkgname)
|
||||||
|
{
|
||||||
|
prop_object_t obj;
|
||||||
|
size_t i;
|
||||||
|
const char *curpkgname;
|
||||||
|
|
||||||
|
assert(prop_object_type(array) == PROP_TYPE_ARRAY);
|
||||||
|
assert(prop_object_type(dict) == PROP_TYPE_DICTIONARY);
|
||||||
|
assert(pkgname != NULL);
|
||||||
|
|
||||||
|
for (i = 0; i < prop_array_count(array); i++) {
|
||||||
|
obj = prop_array_get(array, i);
|
||||||
|
prop_dictionary_get_cstring_nocopy(obj, "pkgname", &curpkgname);
|
||||||
|
if (strcmp(curpkgname, pkgname) == 0) {
|
||||||
|
/* pkgname match, we know the index */
|
||||||
|
if (!prop_array_set(array, i, dict))
|
||||||
|
return EINVAL;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* no match */
|
||||||
|
return ENOENT;
|
||||||
|
}
|
||||||
|
|
||||||
prop_dictionary_t
|
prop_dictionary_t
|
||||||
xbps_dictionary_from_metadata_plist(const char *pkgname,
|
xbps_dictionary_from_metadata_plist(const char *pkgname,
|
||||||
const char *plist)
|
const char *plist)
|
||||||
|
Loading…
Reference in New Issue
Block a user