Skip to content
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

Array curve #1724

Merged
merged 13 commits into from
Jan 19, 2025
Merged

Array curve #1724

merged 13 commits into from
Jan 19, 2025

Conversation

jere8184
Copy link
Contributor

@jere8184 jere8184 commented Dec 3, 2024

Closes #1678

@heinezen heinezen marked this pull request as draft December 3, 2024 21:38
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/CMakeLists.txt Outdated Show resolved Hide resolved
libopenage/curve/array.cpp Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
@jere8184
Copy link
Contributor Author

is there any chance array curve should be an array of base curves instead of an array of key frame containers?

@heinezen
Copy link
Member

is there any chance array curve should be an array of base curves instead of an array of key frame containers?

The base curves would have a bunch of duplicate info that we would want to avoid, e.g. they would all have shared pointer to the event loop, their own IDs, and ID strings. Basically, the curve array container should only have this information once.

libopenage/curve/array.h Outdated Show resolved Hide resolved
@heinezen
Copy link
Member

would making the base curves store references to these shared fields solve this issue?

Then the IDs wouldn't be unique which would be a problem for the event system. Since all curves are event entities, duplicating the information would either lead to all contained curves being updated or worse, only one curve being tracked by the event loop. It would also be a waste of space, since we have to store a bunch of redundant data which is what we want to avoid with a dedicated Array class.

Also, BaseCurve is an interface and should not be instantiated. It doesn't make sense to use it as a container because KeyframeContainer mostly fulfills that jopb already.

@jere8184 jere8184 marked this pull request as ready for review December 15, 2024 22:31
@jere8184 jere8184 force-pushed the array_curve branch 4 times, most recently from f68ec30 to 0e637b0 Compare December 21, 2024 18:57
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/tests/curve_types.cpp Outdated Show resolved Hide resolved
libopenage/curve/tests/curve_types.cpp Outdated Show resolved Hide resolved
libopenage/curve/tests/curve_types.cpp Outdated Show resolved Hide resolved
libopenage/curve/tests/curve_types.cpp Outdated Show resolved Hide resolved
libopenage/curve/tests/curve_types.cpp Outdated Show resolved Hide resolved
@heinezen
Copy link
Member

Some additional remarks:

  1. You should really try to comment your code more (i.e. docstrings and member descriptions). It gets much harder to review your code if I also have to find out the purpose of your methods/members.
  2. You should also document the new array curve type in the docs: https://github.com/SFTtech/openage/blob/master/doc/code/curves.md
  3. The code looks very good so far, although I might have a few enhancement ideas after integrating the current review comments ^^

@jere8184
Copy link
Contributor Author

  • You should really try to comment your code more (i.e. docstrings and member descriptions). It gets much harder to review your code if I also have to find out the purpose of your methods/members.
  • You should also document the new array curve type in the docs: https://github.com/SFTtech/openage/blob/master/doc/code/curves.md
  • The code looks very good so far, although I might have a few enhancement ideas after integrating the current review comments ^^

alright, currently implementing the changes, really appreciate all the feedback.

@jere8184 jere8184 force-pushed the array_curve branch 3 times, most recently from 22d7740 to dda1518 Compare December 27, 2024 11:05
Copy link
Member

@heinezen heinezen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I found everything I wanted to comment on :D

libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
}

// Array::Iterator is used to iterate over KeyframeContainers contained in a curve at a given time.
class Iterator {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a reason why this class doesn't implement CurveIterator and uses a different strategy for iterating?

Copy link
Contributor Author

@jere8184 jere8184 Jan 3, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One reason would be that std::_Array_const_iterator doesn't have base as a member, which is referred to in iterator.h line:95, and thus unable to inherit from CurveIterator

But to be honest when the choice was made it was arbitrary.

libopenage/curve/array.h Outdated Show resolved Hide resolved
libopenage/curve/array.h Outdated Show resolved Hide resolved
@jere8184 jere8184 force-pushed the array_curve branch 2 times, most recently from 0694bd0 to 7cb1da0 Compare January 9, 2025 16:06
@TheJJ TheJJ added the kevin-rebuild-pl0x instruct kevin to rebuild this pull request label Jan 14, 2025
@SFTbot SFTbot removed the kevin-rebuild-pl0x instruct kevin to rebuild this pull request label Jan 14, 2025
@heinezen
Copy link
Member

I'm going to do a few tests today and then see if we can merge :)

return this->containers.at(index).get(frame_index).make_pair();

// update the hint
this->last_elements[index] = frame_index;
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

out of interest what was wrong with the origonal implementation?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nothing in particular. Your code still worked and was fine, in case you wondered about that.

The main motvation for this change was to change the type of the local variable hint from size_t to auto because I got some compiler hints about that. I think these were caused by me changing the element type in the last_elements to be KeyframeContainer<T>::elem_ptr so that it's more explicit. However, that means that the compiler has to deduce more layers of typedefs and check if they are compatible to size_t and that can apparently be a bit wonky when using the member in code, especially in templates. I could have declared hint as KeyframeContainer<T>::elem_ptr too, but changing the type to auto lets the compiler do this automatically and is much shorter to write.

@heinezen
Copy link
Member

I added a few more tests and fixed the docs.

@heinezen heinezen enabled auto-merge January 19, 2025 15:13
@heinezen heinezen merged commit 6d9d8d7 into SFTtech:master Jan 19, 2025
12 of 13 checks passed
@heinezen
Copy link
Member

Thanks again for tackling this one :)

@jere8184
Copy link
Contributor Author

Thanks again for tackling this one :)

No worries, thanks for the help.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Array Curve container
4 participants