mirror of
https://github.com/slint-ui/slint.git
synced 2025-10-02 22:54:36 +00:00
C++ interpreter: do the renaming invoke_callback -> invoke
This commit is contained in:
parent
16fdd0595b
commit
629a64ba89
4 changed files with 66 additions and 29 deletions
|
@ -619,7 +619,7 @@ public:
|
|||
return {};
|
||||
}
|
||||
}
|
||||
/// Invoke the specified callback declared in .slint with the given arguments
|
||||
/// Invoke the specified callback or function declared in .slint with the given arguments
|
||||
///
|
||||
/// Example: imagine the .slint file contains the given callback declaration:
|
||||
/// ```
|
||||
|
@ -628,20 +628,20 @@ public:
|
|||
/// Then one can call it with this function
|
||||
/// ```
|
||||
/// slint::Value args[] = { SharedString("Hello"), 42. };
|
||||
/// instance->invoke_callback("foo", { args, 2 });
|
||||
/// instance->invoke("foo", { args, 2 });
|
||||
/// ```
|
||||
///
|
||||
/// Returns an null optional if the callback don't exist or if the argument don't match
|
||||
/// Otherwise return the returned value from the callback, which may be an empty Value if
|
||||
/// the callback did not return a value.
|
||||
std::optional<Value> invoke_callback(std::string_view name, std::span<const Value> args) const
|
||||
std::optional<Value> invoke(std::string_view name, std::span<const Value> args) const
|
||||
{
|
||||
using namespace cbindgen_private;
|
||||
Slice<ValueOpaque> args_view { const_cast<ValueOpaque *>(
|
||||
reinterpret_cast<const ValueOpaque *>(args.data())),
|
||||
args.size() };
|
||||
ValueOpaque out;
|
||||
if (slint_interpreter_component_instance_invoke_callback(
|
||||
if (slint_interpreter_component_instance_invoke(
|
||||
inner(), slint::private_api::string_to_slice(name), args_view, &out)) {
|
||||
return Value(out);
|
||||
} else {
|
||||
|
@ -649,6 +649,13 @@ public:
|
|||
}
|
||||
}
|
||||
|
||||
/// \deprecated rename to invoke()
|
||||
[[deprecated("renamed to invoke()")]] std::optional<Value>
|
||||
invoke_callback(std::string_view name, std::span<const Value> args) const
|
||||
{
|
||||
return invoke(name, args);
|
||||
}
|
||||
|
||||
/// Set a handler for the callback with the given name.
|
||||
///
|
||||
/// A callback with that name must be defined in the document otherwise the function
|
||||
|
@ -757,9 +764,8 @@ public:
|
|||
[](void *data) { delete reinterpret_cast<F *>(data); });
|
||||
}
|
||||
|
||||
/// Invoke the specified callback declared in an exported global singleton
|
||||
std::optional<Value> invoke_global_callback(std::string_view global,
|
||||
std::string_view callback_name,
|
||||
/// Invoke the specified callback or function declared in an exported global singleton
|
||||
std::optional<Value> invoke_global(std::string_view global, std::string_view callable_name,
|
||||
std::span<const Value> args) const
|
||||
{
|
||||
using namespace cbindgen_private;
|
||||
|
@ -767,14 +773,22 @@ public:
|
|||
reinterpret_cast<const ValueOpaque *>(args.data())),
|
||||
args.size() };
|
||||
ValueOpaque out;
|
||||
if (slint_interpreter_component_instance_invoke_global_callback(
|
||||
if (slint_interpreter_component_instance_invoke_global(
|
||||
inner(), slint::private_api::string_to_slice(global),
|
||||
slint::private_api::string_to_slice(callback_name), args_view, &out)) {
|
||||
slint::private_api::string_to_slice(callable_name), args_view, &out)) {
|
||||
return Value(out);
|
||||
} else {
|
||||
return {};
|
||||
}
|
||||
}
|
||||
|
||||
/// \deprecated renamed to invoke_global
|
||||
[[deprecated("renamed to invoke_global()")]] std::optional<Value>
|
||||
invoke_global_callback(std::string_view global, std::string_view callback_name,
|
||||
std::span<const Value> args) const
|
||||
{
|
||||
return invoke_global(global, callback_name, args);
|
||||
}
|
||||
};
|
||||
|
||||
/// ComponentDefinition is a representation of a compiled component from .slint markup.
|
||||
|
@ -841,7 +855,7 @@ public:
|
|||
}
|
||||
|
||||
/// Returns a vector of strings that describe the list of public callbacks that can be invoked
|
||||
/// using ComponentInstance::invoke_callback and set using ComponentInstance::set_callback.
|
||||
/// using ComponentInstance::invoke and set using ComponentInstance::set_callback.
|
||||
slint::SharedVector<slint::SharedString> callbacks() const
|
||||
{
|
||||
slint::SharedVector<slint::SharedString> callbacks;
|
||||
|
|
|
@ -369,7 +369,7 @@ SCENARIO("Invoke callback")
|
|||
return Value(SharedString(res));
|
||||
}));
|
||||
Value args[] = { SharedString("Hello"), 42. };
|
||||
auto res = instance->invoke_callback("some_callback", args);
|
||||
auto res = instance->invoke("some_callback", args);
|
||||
REQUIRE(res.has_value());
|
||||
REQUIRE(*res->to_string() == SharedString("Hello:42_string_on_the_stack_"));
|
||||
}
|
||||
|
@ -382,7 +382,7 @@ SCENARIO("Invoke callback")
|
|||
auto instance = result->create();
|
||||
REQUIRE(!instance->set_callback("bar", [](auto) { return Value(); }));
|
||||
Value args[] = { SharedString("Hello"), 42. };
|
||||
auto res = instance->invoke_callback("bar", args);
|
||||
auto res = instance->invoke("bar", args);
|
||||
REQUIRE(!res.has_value());
|
||||
}
|
||||
}
|
||||
|
@ -505,6 +505,7 @@ SCENARIO("Global properties")
|
|||
export global The-Global := {
|
||||
property <string> the-property: "€€€";
|
||||
callback to_uppercase(string)->string;
|
||||
public function ff() -> string { return the-property; }
|
||||
}
|
||||
export Dummy := Rectangle {
|
||||
property <string> result: The-Global.to_uppercase("abc");
|
||||
|
@ -578,7 +579,7 @@ SCENARIO("Global properties")
|
|||
REQUIRE(result->to_string().value() == "ABC");
|
||||
|
||||
Value args[] = { SharedString("Hello") };
|
||||
auto res = instance->invoke_global_callback("The_Global", "to-uppercase", args);
|
||||
auto res = instance->invoke_global("The_Global", "to-uppercase", args);
|
||||
REQUIRE(res.has_value());
|
||||
REQUIRE(*res->to_string() == SharedString("HELLO"));
|
||||
}
|
||||
|
@ -588,7 +589,14 @@ SCENARIO("Global properties")
|
|||
[](auto) { return Value {}; }));
|
||||
REQUIRE(!instance->set_global_callback("The-Global", "touppercase",
|
||||
[](auto) { return Value {}; }));
|
||||
REQUIRE(!instance->invoke_global_callback("TheGlobal", "touppercase", {}));
|
||||
REQUIRE(!instance->invoke_global_callback("The-Global", "touppercase", {}));
|
||||
REQUIRE(!instance->invoke_global("TheGlobal", "touppercase", {}));
|
||||
REQUIRE(!instance->invoke_global("The-Global", "touppercase", {}));
|
||||
}
|
||||
SECTION("invoke function")
|
||||
{
|
||||
REQUIRE(instance->set_global_property("The-Global", "the-property", SharedString("&&&")));
|
||||
auto res = instance->invoke_global("The_Global", "ff", {});
|
||||
REQUIRE(res.has_value());
|
||||
REQUIRE(*res->to_string() == SharedString("&&&"));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1006,7 +1006,7 @@ impl ComponentInstance {
|
|||
.borrow()
|
||||
.lookup_property(callable_name)
|
||||
.property_type,
|
||||
i_slint_compiler::langtype::Type::Function { .. }
|
||||
LangType::Function { .. }
|
||||
) {
|
||||
g.as_ref()
|
||||
.eval_function(callable_name, args.iter().cloned().collect())
|
||||
|
@ -1126,12 +1126,14 @@ pub enum InvokeError {
|
|||
#[error("no such callback or function")]
|
||||
NoSuchCallable,
|
||||
}
|
||||
/// deprecated alias to [`InvokeError`]
|
||||
#[deprecated(note = "Renamed to InvokeError")]
|
||||
type InvokeCallbackError = InvokeError;
|
||||
pub type InvokeCallbackError = InvokeError;
|
||||
impl InvokeError {
|
||||
/// deprecated alias to [`InvokeCallbackError::NoSuchCallback`]
|
||||
#[deprecated(note = "Renamed NoSuchCallable")]
|
||||
#[allow(non_upper_case_globals)]
|
||||
const NoSuchCallback: Self = Self::NoSuchCallable;
|
||||
pub const NoSuchCallback: Self = Self::NoSuchCallable;
|
||||
}
|
||||
|
||||
/// Enters the main event loop. This is necessary in order to receive
|
||||
|
|
|
@ -351,11 +351,11 @@ pub extern "C" fn slint_interpreter_component_instance_set_property(
|
|||
.is_ok()
|
||||
}
|
||||
|
||||
/// Invoke a callback.
|
||||
/// Invoke a callback or function
|
||||
/// The `out` parameter must be uninitialized. If this function returns true, the out will be initialized
|
||||
/// to the resulting value. If this function returns false, out is unchanged
|
||||
#[no_mangle]
|
||||
pub unsafe extern "C" fn slint_interpreter_component_instance_invoke_callback(
|
||||
pub unsafe extern "C" fn slint_interpreter_component_instance_invoke(
|
||||
inst: &ErasedComponentBox,
|
||||
name: Slice<u8>,
|
||||
args: Slice<ValueOpaque>,
|
||||
|
@ -364,7 +364,7 @@ pub unsafe extern "C" fn slint_interpreter_component_instance_invoke_callback(
|
|||
let args = std::mem::transmute::<Slice<ValueOpaque>, Slice<Value>>(args);
|
||||
generativity::make_guard!(guard);
|
||||
let comp = inst.unerase(guard);
|
||||
match comp.description().invoke_callback(
|
||||
match comp.description().invoke(
|
||||
comp.borrow(),
|
||||
&normalize_identifier(std::str::from_utf8(&name).unwrap()),
|
||||
args.as_slice(),
|
||||
|
@ -507,28 +507,41 @@ pub unsafe extern "C" fn slint_interpreter_component_instance_set_global_callbac
|
|||
.is_ok()
|
||||
}
|
||||
|
||||
/// Invoke a global callback.
|
||||
/// Invoke a global callback or function.
|
||||
/// The `out` parameter must be uninitialized. If this function returns true, the out will be initialized
|
||||
/// to the resulting value. If this function returns false, out is unchanged
|
||||
#[no_mangle]
|
||||
pub unsafe extern "C" fn slint_interpreter_component_instance_invoke_global_callback(
|
||||
pub unsafe extern "C" fn slint_interpreter_component_instance_invoke_global(
|
||||
inst: &ErasedComponentBox,
|
||||
global: Slice<u8>,
|
||||
callback_name: Slice<u8>,
|
||||
callable_name: Slice<u8>,
|
||||
args: Slice<ValueOpaque>,
|
||||
out: *mut ValueOpaque,
|
||||
) -> bool {
|
||||
let args = std::mem::transmute::<Slice<ValueOpaque>, Slice<Value>>(args);
|
||||
generativity::make_guard!(guard);
|
||||
let comp = inst.unerase(guard);
|
||||
let callable_name = std::str::from_utf8(&callable_name).unwrap();
|
||||
match comp
|
||||
.description()
|
||||
.get_global(comp.borrow(), &normalize_identifier(std::str::from_utf8(&global).unwrap()))
|
||||
.and_then(|g| {
|
||||
g.as_ref().invoke_callback(
|
||||
&normalize_identifier(std::str::from_utf8(&callback_name).unwrap()),
|
||||
args.as_slice(),
|
||||
if matches!(
|
||||
comp.description()
|
||||
.original
|
||||
.root_element
|
||||
.borrow()
|
||||
.lookup_property(callable_name)
|
||||
.property_type,
|
||||
i_slint_compiler::langtype::Type::Function { .. }
|
||||
) {
|
||||
g.as_ref().eval_function(
|
||||
&normalize_identifier(callable_name),
|
||||
args.as_slice().iter().cloned().collect(),
|
||||
)
|
||||
} else {
|
||||
g.as_ref().invoke_callback(&normalize_identifier(callable_name), args.as_slice())
|
||||
}
|
||||
}) {
|
||||
Ok(val) => {
|
||||
std::ptr::write(out as *mut Value, val);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue