- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 253
Implements Defaut parameters #1213
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
base: master
Are you sure you want to change the base?
Conversation
| I gave a good look at the code and it wouldn't be easy to make  Just having SignatureInfo carry  There's also the problem of removing the  | 
| So one way to tackle this would be to add a 
 | 
| Should I ping you for these sort of things ? I don't want to be a bother @Bromeon | 
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.
Thanks a lot!
I gave a good look at the code and it wouldn't be easy to make
SignatureInfo::into_signature_infofaillible, it's used a lot in context where an error is not expected
Good point. Maybe the default parameter detection shouldn't happen inside this function? That is, make another function extract_default_params(), and use the result of that alongside the into_signature_info() result -- or pass the former into the latter.
let default_params = parse_default_params(&signature);
let signature_info =
    into_signature_info(signature.clone(), class_name, gd_self_parameter.is_some());
// or:
let default_params = parse_default_params(&signature);
let signature_info =
    into_signature_info(signature.clone(), class_name, gd_self_parameter.is_some(), Some(default_params));Should I ping you for these sort of things ? I don't want to be a bother @Bromeon
Not necessary, I get notifications on all comments. Either way, I'll review depending on time and not on how often someone writes an answer 😉
| fn extract_default_parameters(sig_info: &SignatureInfo) -> ParseResult<Vec<TokenStream>> { | ||
| let mut res = vec![]; | ||
| let mut allowed = true; | ||
| for pd in sig_info.param_defaults.iter().rev() { | ||
| match pd { | ||
| Some(tk) if allowed => { | ||
| res.push(tk.clone()); // toreview: if we really care about it, we can use &mut sig_info and mem::take() as we don't use this later | ||
| } | ||
| None if allowed => { | ||
| allowed = false; | ||
| } | ||
| Some(tk) if !allowed => { | ||
| return bail!( | ||
| tk, | ||
| "opt arguments are only allowed at the end of the argument list." | ||
| ); | ||
| } | ||
| _ => (), | ||
| } | ||
| } | ||
| res.reverse(); | ||
| Ok(res) | ||
| } | 
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.
You could iterate forward, set a flag must_be_default to true on the first encounter, and then fail if any subsequent parameter is not a default.
And please exhaustively handle all cases, without _. The if !allowed isn't needed after a if allowed for the same condition, as it's implied. If you match on (default, must_be_default) instead of only default, you can be more explicit and the compiler will get it.
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'll exhaustively handle all cases, However i think it's cleaner and clearer code with the vector being reversed as you don't have to keep a variable to bail on the right span.
If it's about performance, I doubt a signature function will get long enough that it matters.
If you insist though I'll do you it your way!
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'll exhaustively handle all cases, However i think it's cleaner and clearer code with the vector being reversed as you don't have to keep a variable to bail on the right span.
You currently have allowed, how is that different?
Not needing to reverse twice is not only faster, but also simpler -- I don't see why you'd choose extra unnecessary operations 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.
You should be able to just do something like:
sig_info.param_defaults
    .iter()
    .skip_while(|pd| pd.is_none())
    .cloned()
    .collect::<Option<Vec<_>>>()
    .some_or_else(...)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.
The resulting vector needs to have an element for each parameter, not just the default ones. Maybe there's a clever way to do this in functional style, but having a mutable bool flag + for loop seems like it's more readable.
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.
The resulting vector needs to have an element for each parameter, not just the default ones.
That is not what the function is doing, though. It only pushes Some(...) values to the Vec that are allowed. None values are being omitted from the new Vec
60de95f    to
    3f946c5      
    Compare
  
    | 
 That's a relief, I have a tendency to yap too much! | 
3f946c5    to
    b17558a      
    Compare
  
    | API docs are being generated and will be shortly available at: https://godot-rust.github.io/docs/gdext/pr-1213 | 
| If you want the args to implement AsArg I could add call to a dummy noop function that only accepts T: AsArg or did you have something in mind? like what's the point of this request so i can satisfy it the best? | 
b17558a    to
    fe9e7a6      
    Compare
  
    fe9e7a6    to
    f24ec87      
    Compare
  
    | Next order of business, change make_method_registration make_varcall_fn can be changed cause it's only used here Then change in_varcall logics ( | 
| 
 No, you'll need the trait to convert the argument to an actual  | 
| 
 Regardless, a quick test using  This is (perhaps unsurprisingly) turning to be much more involved than what I anticipated. Apparently I have a null pointer that is dereferenced somewhere in  | 
| Just pushed b26d072 which is not a real commit and more the start of a discussion. Turns out, it's not as I thought godot itself that crashes but the rust side: 
 Where do we go from there? We could 
 Whatever the path, it'll take more time than i originally thought which is no big deal for now, hopefully I don't run out of free time before this is done Feedback wanted and appreciated! | 
| 
 I'd assume we'd be setting  
 I'm not entirely sure how you'd do that? Like isn't the default argument count a dynamic argument, so you can't really use the trait system to dispatch based on it. | 
| @astrale-sharp any update? 🙂 | 
| 
 Hey, well yea, I'm kind of waiting for your input for the way to proceed (see my previous comment)! | 
| 
 lilizoey already responded to this, but I'll add my 2c: Can we not reuse  gdext/godot-core/src/meta/param_tuple/impls.rs Lines 91 to 105 in c382e6b 
 Maybe we can extend this to return  | 
| @astrale-sharp there has been basically no update from you since 3 weeks, are you still interested? It's totally fine if you don't have the time right now, but then we could hand this over to someone else or pick up again in the future, rather than letting it go stale 🙂 | 
| Still interested but it's harder to find the time these days, it should be better in a few day, we'll see then! | 
| Covid isn't treating me very nicely so you can expect I'll be out for some time | 
779c043    to
    ddc5b76      
    Compare
  
    | @astrale-sharp last commit was almost two months ago, can you please decide if you're still interested in this or would prefer to abandon/hand over the PR? If the former, we'll need to collaborate a bit more actively (at least multiple times per week), otherwise it will drag forever and every reviewer will constantly lose the context from previous updates. Thanks 🙂 | 
Closes #381
The question here is, i don't want to modify into_signature_info because it's used in more than one place where it doesn't need to be faillible.
But copying the function just to add in the default parameters parsing is ugly code wise.
i guess FunctionDef could just contain the unparsed unfaillible info of parameters and the parsing could just be done in register_method_registration but that info will only be used there whereas FunctionDef is used all over the place, still the best option imho