forked from asg017/sqlite-loadable-rs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscalar.rs
49 lines (43 loc) · 1.7 KB
/
scalar.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
//! cargo build --example scalar
//! sqlite3 :memory: '.read examples/test.sql'
use sqlite_loadable::prelude::*;
use sqlite_loadable::{api, define_scalar_function, Result};
// yo()
fn yo(context: *mut sqlite3_context, _values: &[*mut sqlite3_value]) -> Result<()> {
api::result_text(context, "yo")?;
Ok(())
}
// surround_rs(name)
fn surround(context: *mut sqlite3_context, values: &[*mut sqlite3_value]) -> Result<()> {
let value = api::value_text(values.get(0).expect("1st argument as name"))?;
api::result_text(context, format!("x{}x", value))?;
Ok(())
}
// add_rs(a, b)
fn add(context: *mut sqlite3_context, values: &[*mut sqlite3_value]) -> Result<()> {
let a = api::value_int(values.get(0).expect("1st argument"));
let b = api::value_int(values.get(1).expect("2nd argument"));
api::result_int(context, a + b);
Ok(())
}
// connect(seperator, string1, ...)
fn connect(context: *mut sqlite3_context, values: &[*mut sqlite3_value]) -> Result<()> {
let seperator = api::value_text(values.get(0).expect("1st argument"))?;
let strings: Vec<&str> = values
.get(1..)
.expect("more than 1 argument to be given")
.iter()
.filter_map(|v| api::value_text(v).ok())
.collect();
api::result_text(context, strings.join(seperator))?;
Ok(())
}
#[sqlite_entrypoint]
pub fn sqlite3_scalarrs_init(db: *mut sqlite3) -> Result<()> {
let flags = FunctionFlags::UTF8 | FunctionFlags::DETERMINISTIC;
define_scalar_function(db, "surround_rs", 1, surround, flags)?;
define_scalar_function(db, "connect", -1, connect, flags)?;
define_scalar_function(db, "yo_rs", 0, yo, flags)?;
define_scalar_function(db, "add_rs", 2, add, flags)?;
Ok(())
}