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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
use std::fmt;
use serde::{Deserialize, Serialize};
use lowertest::MzReflect;
use repr::adt::numeric::{self, Numeric};
use repr::adt::system::Oid;
use repr::{strconv, ColumnType, ScalarType};
use crate::scalar::func::EagerUnaryFunc;
use crate::EvalError;
sqlfunc!(
#[sqlname = "-"]
#[preserves_uniqueness = true]
fn neg_int64(a: i64) -> i64 {
-a
}
);
sqlfunc!(
#[sqlname = "~"]
#[preserves_uniqueness = true]
fn bit_not_int64(a: i64) -> i64 {
!a
}
);
sqlfunc!(
#[sqlname = "abs"]
fn abs_int64(a: i64) -> i64 {
a.abs()
}
);
sqlfunc!(
#[sqlname = "i64tobool"]
fn cast_int64_to_bool(a: i64) -> bool {
a != 0
}
);
sqlfunc!(
#[sqlname = "i64toi16"]
#[preserves_uniqueness = true]
fn cast_int64_to_int16(a: i64) -> Result<i16, EvalError> {
i16::try_from(a).or(Err(EvalError::Int16OutOfRange))
}
);
sqlfunc!(
#[sqlname = "i64toi32"]
#[preserves_uniqueness = true]
fn cast_int64_to_int32(a: i64) -> Result<i32, EvalError> {
i32::try_from(a).or(Err(EvalError::Int32OutOfRange))
}
);
sqlfunc!(
#[sqlname = "i64tooid"]
#[preserves_uniqueness = true]
fn cast_int64_to_oid(a: i64) -> Result<Oid, EvalError> {
i32::try_from(a).map(Oid).or(Err(EvalError::OidOutOfRange))
}
);
#[derive(Ord, PartialOrd, Clone, Debug, Eq, PartialEq, Serialize, Deserialize, Hash, MzReflect)]
pub struct CastInt64ToNumeric(pub Option<u8>);
impl<'a> EagerUnaryFunc<'a> for CastInt64ToNumeric {
type Input = i64;
type Output = Result<Numeric, EvalError>;
fn call(&self, a: i64) -> Result<Numeric, EvalError> {
let mut a = Numeric::from(a);
if let Some(scale) = self.0 {
if numeric::rescale(&mut a, scale).is_err() {
return Err(EvalError::NumericFieldOverflow);
}
}
Ok(a)
}
fn output_type(&self, input: ColumnType) -> ColumnType {
ScalarType::Numeric { scale: self.0 }.nullable(input.nullable)
}
}
impl fmt::Display for CastInt64ToNumeric {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
f.write_str("i64tonumeric")
}
}
sqlfunc!(
#[sqlname = "i64tof32"]
fn cast_int64_to_float32(a: i64) -> f32 {
a as f32
}
);
sqlfunc!(
#[sqlname = "i64tof64"]
fn cast_int64_to_float64(a: i64) -> f64 {
a as f64
}
);
sqlfunc!(
#[sqlname = "i64tostr"]
#[preserves_uniqueness = true]
fn cast_int64_to_string(a: i64) -> String {
let mut buf = String::new();
strconv::format_int64(&mut buf, a);
buf
}
);