Details
Diff Detail
Event Timeline
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
90 | I guess it's supposed to be the type to which we cast, while the arg's type would be the type from which we cast? | |
285–287 | This function looks as if it begs to be reused from some other place, but i didn't immediately find a ready-made way to do this, which is surprising. | |
300 | return None;. | |
414–416 | No idea, but, as a bit of brainstorming, Objective-C++ sometimes seems to treat blocks and lambdas similarly, eg. CK_CopyAndAutoreleaseBlockObject cast kind casts from lambdas to blocks. So i'm probably curious if passing a block is possible here (which goes in the opposite direction). | |
430–433 | Just to make sure i understand - the name of the once-token must be std::once_flag, while the name of the field we're looking for is unspecified. So we wouldn't necessarily find the field called __state inside the function in the real-world code. Same for the possible values of this field and their meanings. Could you comment that we're trying to match popular implementation(s) of once_flag? And if you're seeing potential better approaches. | |
700 | I think we have to check that this is in namespace std::, otherwise it might be a different function. |
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
90 | But in most cases we don't actually change the type, | |
285–287 | yeah we've talked about that with Devin. |
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
430–433 |
It seems we would, from libc++ header: struct _LIBCPP_TEMPLATE_VIS once_flag { _LIBCPP_INLINE_VISIBILITY _LIBCPP_CONSTEXPR once_flag() _NOEXCEPT : __state_(0) {} private: once_flag(const once_flag&); // = delete; once_flag& operator=(const once_flag&); // = delete; unsigned long __state_; #ifndef _LIBCPP_CXX03_LANG template<class _Callable, class... _Args> friend void call_once(once_flag&, _Callable&&, _Args&&...); #else // _LIBCPP_CXX03_LANG template<class _Callable> friend void call_once(once_flag&, _Callable&); template<class _Callable> friend void call_once(once_flag&, const _Callable&); #endif // _LIBCPP_CXX03_LANG }; Though other implementation might try to put more stuff into the .cpp file. |
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
414–416 | shockingly, blocks work. |
Checked for std:: namespace, left a comment that we are assuming libc++ implementation.
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
430–433 | Added a comment that we are assuming libc++ implementation. |
Some comments in line. Also, don't forget to run git clang-format on your changes to fix the indention and '*' placement for pointers.
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
28 | We should probably follow the convention the rest of the analyzer uses have this be camel case ("BodyFarm"). | |
53 | There a bunch of whitespace-only changes here. (Probably clang-format or your editor removed spaces on empty lines?) We generally try to avoid whitespace-only changes since they obscure the history of a commit. | |
285 | Why does findMember() return an optional of a pointer type? What is the meaning of 'Some(nullptr)' to the caller? Can the method just return NamedDecl * instead? | |
285–287 | I'm a bit uncomfortable with returning just the first found member for member functions. Since member functions are often overloaded, anyone who uses this API in the future to find a member function will almost certainly be using it incorrectly. What do you think about restricting it to only find fields? | |
301 | Do we need to look up in the bases? There don't seem to be tests for this code. Should it be removed? | |
360 | It seems quite sketchy to me that create_call_once_lambda_call() mutates one of its reference parameters. It is also inserting at the beginning of a vector, which is expensive. Can you create the CallArgs vector in the caller and pass in an immutable llvm::ArrayRef to it instead? This is more idiomatic and will prevent surprises on the part of future callers from unexpected mutation. | |
403 | To be idiomatic, CallArgs should probably be an llvm::SmallVector. This will avoid a heap allocation. |
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
360 |
Yes, I have taken that into consideration (though realistically speaking we are talking about an array with a couple of elements, in a function called once per analysis).
Did you mean "callee" instead of "caller"? Yes, but from my understanding that would result in more code, and be less efficient than the current implementation (even though performance does not particularly matter in this case).
Why is it unexpected though? It is a mutable datastructure passed by reference, it is quite idiomatic to write into those. |
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
28 | I have only found two files with DEBUG_TYPE in the analyzer, however. | |
53 | Can't see any now? | |
285 | OK that depends on the style, let's change it to be more consistent with body generation. | |
285–287 | OK let's restrict it to fields. | |
301 | Good point, I've cargo-culted it from another file without realizing. | |
403 | ok |
Ok. Looks fine to me. Just make sure to check out the raw diff for whitespace changes. I suspect your viewer is hiding them from you.
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
53 | Make sure to look at the raw diff. I still see them. | |
360 | I'm not convinced the mutation is needed and I think you can rewrite it without it. I won't block this patch on that though. |
lib/Analysis/BodyFarm.cpp | ||
---|---|---|
360 | Generally, in LLVM codebase it's preferable to use immutable data structures wherever possible. That makes code safer and easier to understand. |
We should probably follow the convention the rest of the analyzer uses have this be camel case ("BodyFarm").