mirror of
https://github.com/GothenburgBitFactory/taskwarrior.git
synced 2025-06-26 10:54:26 +02:00
use Uda instead of UDA
This commit is contained in:
parent
51a854cfef
commit
ad464c4779
5 changed files with 56 additions and 56 deletions
|
@ -400,7 +400,7 @@ static void test_task_udas(void) {
|
||||||
tc_task_to_mut(task, rep);
|
tc_task_to_mut(task, rep);
|
||||||
|
|
||||||
TCString *value;
|
TCString *value;
|
||||||
TCUDAList udas;
|
TCUdaList udas;
|
||||||
|
|
||||||
TEST_ASSERT_NULL(tc_task_get_uda(task, tc_string_borrow("ns"), tc_string_borrow("u1")));
|
TEST_ASSERT_NULL(tc_task_get_uda(task, tc_string_borrow("ns"), tc_string_borrow("u1")));
|
||||||
TEST_ASSERT_NULL(tc_task_get_legacy_uda(task, tc_string_borrow("leg1")));
|
TEST_ASSERT_NULL(tc_task_get_legacy_uda(task, tc_string_borrow("leg1")));
|
||||||
|
|
|
@ -29,7 +29,7 @@ pub(crate) mod types {
|
||||||
pub(crate) use crate::status::TCStatus;
|
pub(crate) use crate::status::TCStatus;
|
||||||
pub(crate) use crate::string::{TCString, TCStringList};
|
pub(crate) use crate::string::{TCString, TCStringList};
|
||||||
pub(crate) use crate::task::{TCTask, TCTaskList};
|
pub(crate) use crate::task::{TCTask, TCTaskList};
|
||||||
pub(crate) use crate::uda::{TCUDAList, TCUDA, UDA};
|
pub(crate) use crate::uda::{TCUda, TCUdaList, Uda};
|
||||||
pub(crate) use crate::uuid::{TCUuid, TCUuidList};
|
pub(crate) use crate::uuid::{TCUuid, TCUuidList};
|
||||||
pub(crate) use crate::workingset::TCWorkingSet;
|
pub(crate) use crate::workingset::TCWorkingSet;
|
||||||
}
|
}
|
||||||
|
|
|
@ -404,40 +404,40 @@ pub unsafe extern "C" fn tc_task_get_legacy_uda<'a>(
|
||||||
///
|
///
|
||||||
/// Legacy UDAs are represented with an empty string in the ns field.
|
/// Legacy UDAs are represented with an empty string in the ns field.
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub unsafe extern "C" fn tc_task_get_udas(task: *mut TCTask) -> TCUDAList {
|
pub unsafe extern "C" fn tc_task_get_udas(task: *mut TCTask) -> TCUdaList {
|
||||||
wrap(task, |task| {
|
wrap(task, |task| {
|
||||||
let vec: Vec<TCUDA> = task
|
let vec: Vec<TCUda> = task
|
||||||
.get_udas()
|
.get_udas()
|
||||||
.map(|((ns, key), value)| {
|
.map(|((ns, key), value)| {
|
||||||
TCUDA::return_val(UDA {
|
TCUda::return_val(Uda {
|
||||||
ns: Some(ns.into()),
|
ns: Some(ns.into()),
|
||||||
key: key.into(),
|
key: key.into(),
|
||||||
value: value.into(),
|
value: value.into(),
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.collect();
|
.collect();
|
||||||
TCUDAList::return_val(vec)
|
TCUdaList::return_val(vec)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get all UDAs for this task.
|
/// Get all UDAs for this task.
|
||||||
///
|
///
|
||||||
/// All TCUDAs in this list have a NULL ns field. The entire UDA key is
|
/// All TCUdas in this list have a NULL ns field. The entire UDA key is
|
||||||
/// included in the key field.
|
/// included in the key field.
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub unsafe extern "C" fn tc_task_get_legacy_udas(task: *mut TCTask) -> TCUDAList {
|
pub unsafe extern "C" fn tc_task_get_legacy_udas(task: *mut TCTask) -> TCUdaList {
|
||||||
wrap(task, |task| {
|
wrap(task, |task| {
|
||||||
let vec: Vec<TCUDA> = task
|
let vec: Vec<TCUda> = task
|
||||||
.get_legacy_udas()
|
.get_legacy_udas()
|
||||||
.map(|(key, value)| {
|
.map(|(key, value)| {
|
||||||
TCUDA::return_val(UDA {
|
TCUda::return_val(Uda {
|
||||||
ns: None,
|
ns: None,
|
||||||
key: key.into(),
|
key: key.into(),
|
||||||
value: value.into(),
|
value: value.into(),
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.collect();
|
.collect();
|
||||||
TCUDAList::return_val(vec)
|
TCUdaList::return_val(vec)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
use crate::traits::*;
|
use crate::traits::*;
|
||||||
use crate::types::*;
|
use crate::types::*;
|
||||||
|
|
||||||
/// TCUDA contains the details of a UDA.
|
/// TCUda contains the details of a UDA.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct TCUDA {
|
pub struct TCUda {
|
||||||
/// Namespace of the UDA. For legacy UDAs, this is NULL.
|
/// Namespace of the UDA. For legacy UDAs, this is NULL.
|
||||||
pub ns: *mut TCString<'static>,
|
pub ns: *mut TCString<'static>,
|
||||||
/// UDA key. Must not be NULL.
|
/// UDA key. Must not be NULL.
|
||||||
|
@ -12,17 +12,17 @@ pub struct TCUDA {
|
||||||
pub value: *mut TCString<'static>,
|
pub value: *mut TCString<'static>,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) struct UDA {
|
pub(crate) struct Uda {
|
||||||
pub ns: Option<TCString<'static>>,
|
pub ns: Option<TCString<'static>>,
|
||||||
pub key: TCString<'static>,
|
pub key: TCString<'static>,
|
||||||
pub value: TCString<'static>,
|
pub value: TCString<'static>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl PassByValue for TCUDA {
|
impl PassByValue for TCUda {
|
||||||
type RustType = UDA;
|
type RustType = Uda;
|
||||||
|
|
||||||
unsafe fn from_ctype(self) -> Self::RustType {
|
unsafe fn from_ctype(self) -> Self::RustType {
|
||||||
UDA {
|
Uda {
|
||||||
ns: if self.ns.is_null() {
|
ns: if self.ns.is_null() {
|
||||||
None
|
None
|
||||||
} else {
|
} else {
|
||||||
|
@ -42,8 +42,8 @@ impl PassByValue for TCUDA {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn as_ctype(uda: UDA) -> Self {
|
fn as_ctype(uda: Uda) -> Self {
|
||||||
TCUDA {
|
TCUda {
|
||||||
// SAFETY: caller assumes ownership of this value
|
// SAFETY: caller assumes ownership of this value
|
||||||
ns: if let Some(ns) = uda.ns {
|
ns: if let Some(ns) = uda.ns {
|
||||||
unsafe { ns.return_ptr() }
|
unsafe { ns.return_ptr() }
|
||||||
|
@ -58,9 +58,9 @@ impl PassByValue for TCUDA {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Default for TCUDA {
|
impl Default for TCUda {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
TCUDA {
|
TCUda {
|
||||||
ns: std::ptr::null_mut(),
|
ns: std::ptr::null_mut(),
|
||||||
key: std::ptr::null_mut(),
|
key: std::ptr::null_mut(),
|
||||||
value: std::ptr::null_mut(),
|
value: std::ptr::null_mut(),
|
||||||
|
@ -68,27 +68,27 @@ impl Default for TCUDA {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// TCUDAList represents a list of UDAs.
|
/// TCUdaList represents a list of UDAs.
|
||||||
///
|
///
|
||||||
/// The content of this struct must be treated as read-only.
|
/// The content of this struct must be treated as read-only.
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct TCUDAList {
|
pub struct TCUdaList {
|
||||||
/// number of UDAs in items
|
/// number of UDAs in items
|
||||||
len: libc::size_t,
|
len: libc::size_t,
|
||||||
|
|
||||||
/// total size of items (internal use only)
|
/// total size of items (internal use only)
|
||||||
_capacity: libc::size_t,
|
_capacity: libc::size_t,
|
||||||
|
|
||||||
/// array of UDAs. These remain owned by the TCUDAList instance and will be freed by
|
/// array of UDAs. These remain owned by the TCUdaList instance and will be freed by
|
||||||
/// tc_uda_list_free. This pointer is never NULL for a valid TCUDAList.
|
/// tc_uda_list_free. This pointer is never NULL for a valid TCUdaList.
|
||||||
items: *const TCUDA,
|
items: *const TCUda,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl CList for TCUDAList {
|
impl CList for TCUdaList {
|
||||||
type Element = TCUDA;
|
type Element = TCUda;
|
||||||
|
|
||||||
unsafe fn from_raw_parts(items: *const Self::Element, len: usize, cap: usize) -> Self {
|
unsafe fn from_raw_parts(items: *const Self::Element, len: usize, cap: usize) -> Self {
|
||||||
TCUDAList {
|
TCUdaList {
|
||||||
len,
|
len,
|
||||||
_capacity: cap,
|
_capacity: cap,
|
||||||
items,
|
items,
|
||||||
|
@ -100,25 +100,25 @@ impl CList for TCUDAList {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Free a TCUDA instance. The instance, and the TCStrings it contains, must not be used
|
/// Free a TCUda instance. The instance, and the TCStrings it contains, must not be used
|
||||||
/// after this call.
|
/// after this call.
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub unsafe extern "C" fn tc_uda_free(tcuda: *mut TCUDA) {
|
pub unsafe extern "C" fn tc_uda_free(tcuda: *mut TCUda) {
|
||||||
debug_assert!(!tcuda.is_null());
|
debug_assert!(!tcuda.is_null());
|
||||||
// SAFETY:
|
// SAFETY:
|
||||||
// - *tcuda is a valid TCUDA (caller promises to treat it as read-only)
|
// - *tcuda is a valid TCUda (caller promises to treat it as read-only)
|
||||||
let uda = unsafe { TCUDA::take_val_from_arg(tcuda, TCUDA::default()) };
|
let uda = unsafe { TCUda::take_val_from_arg(tcuda, TCUda::default()) };
|
||||||
drop(uda);
|
drop(uda);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Free a TCUDAList instance. The instance, and all TCUDAs it contains, must not be used after
|
/// Free a TCUdaList instance. The instance, and all TCUdas it contains, must not be used after
|
||||||
/// this call.
|
/// this call.
|
||||||
///
|
///
|
||||||
/// When this call returns, the `items` pointer will be NULL, signalling an invalid TCUDAList.
|
/// When this call returns, the `items` pointer will be NULL, signalling an invalid TCUdaList.
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub unsafe extern "C" fn tc_uda_list_free(tcudas: *mut TCUDAList) {
|
pub unsafe extern "C" fn tc_uda_list_free(tcudas: *mut TCUdaList) {
|
||||||
// SAFETY:
|
// SAFETY:
|
||||||
// - tcudas is not NULL and points to a valid TCUDAList (caller is not allowed to
|
// - tcudas is not NULL and points to a valid TCUdaList (caller is not allowed to
|
||||||
// modify the list)
|
// modify the list)
|
||||||
// - caller promises not to use the value after return
|
// - caller promises not to use the value after return
|
||||||
unsafe { drop_value_list(tcudas) }
|
unsafe { drop_value_list(tcudas) }
|
||||||
|
@ -130,7 +130,7 @@ mod test {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn empty_list_has_non_null_pointer() {
|
fn empty_list_has_non_null_pointer() {
|
||||||
let tcudas = TCUDAList::return_val(Vec::new());
|
let tcudas = TCUdaList::return_val(Vec::new());
|
||||||
assert!(!tcudas.items.is_null());
|
assert!(!tcudas.items.is_null());
|
||||||
assert_eq!(tcudas.len, 0);
|
assert_eq!(tcudas.len, 0);
|
||||||
assert_eq!(tcudas._capacity, 0);
|
assert_eq!(tcudas._capacity, 0);
|
||||||
|
@ -138,7 +138,7 @@ mod test {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn free_sets_null_pointer() {
|
fn free_sets_null_pointer() {
|
||||||
let mut tcudas = TCUDAList::return_val(Vec::new());
|
let mut tcudas = TCUdaList::return_val(Vec::new());
|
||||||
// SAFETY: testing expected behavior
|
// SAFETY: testing expected behavior
|
||||||
unsafe { tc_uda_list_free(&mut tcudas) };
|
unsafe { tc_uda_list_free(&mut tcudas) };
|
||||||
assert!(tcudas.items.is_null());
|
assert!(tcudas.items.is_null());
|
||||||
|
|
|
@ -268,9 +268,9 @@ typedef struct TCStringList {
|
||||||
} TCStringList;
|
} TCStringList;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TCUDA contains the details of a UDA.
|
* TCUda contains the details of a UDA.
|
||||||
*/
|
*/
|
||||||
typedef struct TCUDA {
|
typedef struct TCUda {
|
||||||
/**
|
/**
|
||||||
* Namespace of the UDA. For legacy UDAs, this is NULL.
|
* Namespace of the UDA. For legacy UDAs, this is NULL.
|
||||||
*/
|
*/
|
||||||
|
@ -283,14 +283,14 @@ typedef struct TCUDA {
|
||||||
* Content of the UDA. Must not be NULL.
|
* Content of the UDA. Must not be NULL.
|
||||||
*/
|
*/
|
||||||
struct TCString *value;
|
struct TCString *value;
|
||||||
} TCUDA;
|
} TCUda;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* TCUDAList represents a list of UDAs.
|
* TCUdaList represents a list of UDAs.
|
||||||
*
|
*
|
||||||
* The content of this struct must be treated as read-only.
|
* The content of this struct must be treated as read-only.
|
||||||
*/
|
*/
|
||||||
typedef struct TCUDAList {
|
typedef struct TCUdaList {
|
||||||
/**
|
/**
|
||||||
* number of UDAs in items
|
* number of UDAs in items
|
||||||
*/
|
*/
|
||||||
|
@ -300,11 +300,11 @@ typedef struct TCUDAList {
|
||||||
*/
|
*/
|
||||||
size_t _capacity;
|
size_t _capacity;
|
||||||
/**
|
/**
|
||||||
* array of UDAs. These remain owned by the TCUDAList instance and will be freed by
|
* array of UDAs. These remain owned by the TCUdaList instance and will be freed by
|
||||||
* tc_uda_list_free. This pointer is never NULL for a valid TCUDAList.
|
* tc_uda_list_free. This pointer is never NULL for a valid TCUdaList.
|
||||||
*/
|
*/
|
||||||
const struct TCUDA *items;
|
const struct TCUda *items;
|
||||||
} TCUDAList;
|
} TCUdaList;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
@ -612,15 +612,15 @@ struct TCString *tc_task_get_legacy_uda(struct TCTask *task, struct TCString *ke
|
||||||
*
|
*
|
||||||
* Legacy UDAs are represented with an empty string in the ns field.
|
* Legacy UDAs are represented with an empty string in the ns field.
|
||||||
*/
|
*/
|
||||||
struct TCUDAList tc_task_get_udas(struct TCTask *task);
|
struct TCUdaList tc_task_get_udas(struct TCTask *task);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get all UDAs for this task.
|
* Get all UDAs for this task.
|
||||||
*
|
*
|
||||||
* All TCUDAs in this list have a NULL ns field. The entire UDA key is
|
* All TCUdas in this list have a NULL ns field. The entire UDA key is
|
||||||
* included in the key field.
|
* included in the key field.
|
||||||
*/
|
*/
|
||||||
struct TCUDAList tc_task_get_legacy_udas(struct TCTask *task);
|
struct TCUdaList tc_task_get_legacy_udas(struct TCTask *task);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set a mutable task's status.
|
* Set a mutable task's status.
|
||||||
|
@ -735,18 +735,18 @@ void tc_task_free(struct TCTask *task);
|
||||||
void tc_task_list_free(struct TCTaskList *tctasks);
|
void tc_task_list_free(struct TCTaskList *tctasks);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Free a TCUDA instance. The instance, and the TCStrings it contains, must not be used
|
* Free a TCUda instance. The instance, and the TCStrings it contains, must not be used
|
||||||
* after this call.
|
* after this call.
|
||||||
*/
|
*/
|
||||||
void tc_uda_free(struct TCUDA *tcuda);
|
void tc_uda_free(struct TCUda *tcuda);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Free a TCUDAList instance. The instance, and all TCUDAs it contains, must not be used after
|
* Free a TCUdaList instance. The instance, and all TCUdas it contains, must not be used after
|
||||||
* this call.
|
* this call.
|
||||||
*
|
*
|
||||||
* When this call returns, the `items` pointer will be NULL, signalling an invalid TCUDAList.
|
* When this call returns, the `items` pointer will be NULL, signalling an invalid TCUdaList.
|
||||||
*/
|
*/
|
||||||
void tc_uda_list_free(struct TCUDAList *tcudas);
|
void tc_uda_list_free(struct TCUdaList *tcudas);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new, randomly-generated UUID.
|
* Create a new, randomly-generated UUID.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue