Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/common/lib/libppath Update for proplib(3) API changes.
details: https://anonhg.NetBSD.org/src/rev/cdeeb7622b50
branches: trunk
changeset: 1010795:cdeeb7622b50
user: thorpej <thorpej%NetBSD.org@localhost>
date: Sat Jun 06 22:28:07 2020 +0000
description:
Update for proplib(3) API changes.
diffstat:
common/lib/libppath/ppath.c | 58 +++++++++++++++++++++++++++-----------------
1 files changed, 35 insertions(+), 23 deletions(-)
diffs (193 lines):
diff -r ecb1181f3cf8 -r cdeeb7622b50 common/lib/libppath/ppath.c
--- a/common/lib/libppath/ppath.c Sat Jun 06 22:26:47 2020 +0000
+++ b/common/lib/libppath/ppath.c Sat Jun 06 22:28:07 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ppath.c,v 1.4 2012/12/29 20:08:23 christos Exp $ */
+/* $NetBSD: ppath.c,v 1.5 2020/06/06 22:28:07 thorpej Exp $ */
/*-
* Copyright (c) 2011 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: ppath.c,v 1.4 2012/12/29 20:08:23 christos Exp $");
+__RCSID("$NetBSD: ppath.c,v 1.5 2020/06/06 22:28:07 thorpej Exp $");
#ifdef _KERNEL
#include <sys/systm.h>
@@ -412,7 +412,7 @@
ppath_create_string(prop_object_t o, const ppath_t *p, const char *s)
{
return ppath_create_object_and_release(o, p,
- prop_string_create_cstring(s));
+ prop_string_create_copy(s));
}
int
@@ -420,21 +420,21 @@
const void *data, size_t size)
{
return ppath_create_object_and_release(o, p,
- prop_data_create_data(data, size));
+ prop_data_create_copy(data, size));
}
int
ppath_create_uint64(prop_object_t o, const ppath_t *p, uint64_t u)
{
return ppath_create_object_and_release(o, p,
- prop_number_create_unsigned_integer(u));
+ prop_number_create_unsigned(u));
}
int
ppath_create_int64(prop_object_t o, const ppath_t *p, int64_t i)
{
return ppath_create_object_and_release(o, p,
- prop_number_create_integer(i));
+ prop_number_create_signed(i));
}
int
@@ -746,14 +746,14 @@
const void *data, size_t size)
{
return ppath_copyset_object_and_release(o, op, p,
- prop_data_create_data(data, size));
+ prop_data_create_copy(data, size));
}
int
ppath_set_data(prop_object_t o, const ppath_t *p, const void *data, size_t size)
{
return ppath_set_object_and_release(o, p,
- prop_data_create_data(data, size));
+ prop_data_create_copy(data, size));
}
int
@@ -767,7 +767,7 @@
return rc;
if (datap != NULL)
- *datap = prop_data_data_nocopy(v);
+ *datap = prop_data_value(v);
if (sizep != NULL)
*sizep = prop_data_size(v);
@@ -783,10 +783,16 @@
if ((rc = ppath_get_object_of_type(o, p, &v, PROP_TYPE_DATA)) != 0)
return rc;
- if (datap != NULL)
- *datap = prop_data_data(v);
+ const size_t data_size = prop_data_size(v);
+
+ if (datap != NULL) {
+ void *buf = ppath_alloc(data_size);
+ if (buf != NULL)
+ (void) prop_data_copy_value(v, buf, data_size);
+ *datap = buf;
+ }
if (sizep != NULL)
- *sizep = prop_data_size(v);
+ *sizep = data_size;
return 0;
}
@@ -802,14 +808,14 @@
int64_t i)
{
return ppath_copyset_object_and_release(o, op, p,
- prop_number_create_integer(i));
+ prop_number_create_signed(i));
}
int
ppath_set_int64(prop_object_t o, const ppath_t *p, int64_t i)
{
return ppath_set_object_and_release(o, p,
- prop_number_create_integer(i));
+ prop_number_create_signed(i));
}
int
@@ -825,7 +831,7 @@
return EFTYPE;
if (ip != NULL)
- *ip = prop_number_integer_value(v);
+ *ip = prop_number_signed_value(v);
return 0;
}
@@ -841,14 +847,14 @@
const char *s)
{
return ppath_copyset_object_and_release(o, op, p,
- prop_string_create_cstring(s));
+ prop_string_create_copy(s));
}
int
ppath_set_string(prop_object_t o, const ppath_t *p, const char *s)
{
return ppath_set_object_and_release(o, p,
- prop_string_create_cstring(s));
+ prop_string_create_copy(s));
}
int
@@ -861,7 +867,7 @@
return rc;
if (sp != NULL)
- *sp = prop_string_cstring_nocopy(v);
+ *sp = prop_string_value(v);
return 0;
}
@@ -875,8 +881,14 @@
if ((rc = ppath_get_object_of_type(o, p, &v, PROP_TYPE_STRING)) != 0)
return rc;
- if (sp != NULL)
- *sp = prop_string_cstring(v);
+ const size_t string_size = prop_string_size(v);
+
+ if (sp != NULL) {
+ char *cp = ppath_alloc(string_size + 1);
+ if (cp != NULL)
+ (void)prop_string_copy_value(v, cp, string_size + 1);
+ *sp = cp;
+ }
return 0;
}
@@ -892,14 +904,14 @@
uint64_t u)
{
return ppath_copyset_object_and_release(o, op, p,
- prop_number_create_unsigned_integer(u));
+ prop_number_create_unsigned(u));
}
int
ppath_set_uint64(prop_object_t o, const ppath_t *p, uint64_t u)
{
return ppath_set_object_and_release(o, p,
- prop_number_create_unsigned_integer(u));
+ prop_number_create_unsigned(u));
}
int
@@ -915,7 +927,7 @@
return EFTYPE;
if (up != NULL)
- *up = prop_number_unsigned_integer_value(v);
+ *up = prop_number_unsigned_value(v);
return 0;
}
Home |
Main Index |
Thread Index |
Old Index