68 lines
1.7 KiB
Rust
68 lines
1.7 KiB
Rust
use crate::err::Error;
|
|
use crate::sql::id::Id;
|
|
use crate::sql::table::Table;
|
|
use crate::sql::thing::Thing;
|
|
use crate::sql::value::Value;
|
|
|
|
impl Value {
|
|
pub(crate) fn generate(self, tb: &Table, retable: bool) -> Result<Thing, Error> {
|
|
match self {
|
|
// There is a floating point number for the id field
|
|
Value::Number(id) if id.is_float() => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.as_int().into(),
|
|
}),
|
|
// There is an integer number for the id field
|
|
Value::Number(id) if id.is_int() => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.as_int().into(),
|
|
}),
|
|
// There is a string for the id field
|
|
Value::Strand(id) => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.into(),
|
|
}),
|
|
// There is an object for the id field
|
|
Value::Object(id) => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.into(),
|
|
}),
|
|
// There is an array for the id field
|
|
Value::Array(id) => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.into(),
|
|
}),
|
|
// There is a UUID for the id field
|
|
Value::Uuid(id) => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.into(),
|
|
}),
|
|
// There is no record id field
|
|
Value::None => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: Id::rand(),
|
|
}),
|
|
// There is a record id defined
|
|
Value::Thing(id) => match retable {
|
|
// Let's re-table this record id
|
|
true => Ok(Thing {
|
|
tb: tb.to_string(),
|
|
id: id.id,
|
|
}),
|
|
// Let's use the specified record id
|
|
false => match tb.0 == id.tb {
|
|
// The record is from the same table
|
|
true => Ok(id),
|
|
// The record id is from another table
|
|
false => Err(Error::IdInvalid {
|
|
value: id.to_string(),
|
|
}),
|
|
},
|
|
},
|
|
// Any other value is wrong
|
|
id => Err(Error::IdInvalid {
|
|
value: id.to_string(),
|
|
}),
|
|
}
|
|
}
|
|
}
|