-
Notifications
You must be signed in to change notification settings - Fork 99
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(rust/driver/snowflake): add adbc_snowflake
crate with Go driver wrapper
#2207
Conversation
type Option = OptionConnection; | ||
|
||
fn set_option(&mut self, key: Self::Option, value: OptionValue) -> Result<()> { | ||
self.0.set_option(key, value) | ||
} | ||
|
||
fn get_option_string(&self, key: Self::Option) -> Result<String> { | ||
self.0.get_option_string(key) | ||
} | ||
|
||
fn get_option_bytes(&self, key: Self::Option) -> Result<Vec<u8>> { | ||
self.0.get_option_bytes(key) | ||
} | ||
|
||
fn get_option_int(&self, key: Self::Option) -> Result<i64> { | ||
self.0.get_option_int(key) | ||
} | ||
|
||
fn get_option_double(&self, key: Self::Option) -> Result<f64> { | ||
self.0.get_option_double(key) | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not familiar enough with Rust, but can't these just be inherited somehow from a base type instead of having to implement them here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, we should be using traits for this. Discussed before here: #1725 (comment).
I'll try to put up a PR to change these option structs to traits following the proposal in #1725 (comment).
Marking this ready for review. This already a big PR so maybe it's better to get some feedback now, and add more tests and docs in follow-up PRs. |
let _ = dotenvy::dotenv(); | ||
|
||
let use_high_precision = env::var(Self::USE_HIGH_PRECISION_ENV) | ||
.ok() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Might it make more sense to report errors and return Result<Self>
?
I re-ran CI. I'll merge this for now. Thanks @mbrobbel! |
…nv` when parsing fails (#2334) As suggested in #2207 (comment) the `Builder::from_env` methods should return a result when parsing fails.
This PR adds the
adbc_snowflake
crate to the Rust workspace. This crate provides a Snowflake ADBC driver for Rust by wrapping the Go driver, loaded by the Rust driver manager implementation. Thebuild.rs
script builds the Go driver and links it statically.