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

feat(git/deps): allow controlling git dependencies #19

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

tiagolobocastro
Copy link

Allows modification of the git dependency which causes rebuilds as it might not be desired in all usecases.
By defaults we keep existing behaviour.

Signed-off-by: Tiago Castro [email protected]

Allows modification of the git dependency which causes rebuilds as it might not be desired
in all usecases.
By defaults we keep existing behaviour.

Signed-off-by: Tiago Castro <[email protected]>
@tiagolobocastro
Copy link
Author

@de-vri-es would this be of interest? Thank you

tiagolobocastro added a commit to openebs/mayastor-dependencies that referenced this pull request Feb 9, 2023
Added git dependencies:
fusion-engineering/rust-git-version#19

This allows us to avoid rebuilds when staging changes.

Also added another feature to avoid rebuilds altogether.
Eg: if git versions are specified via env variable then we don't need to use git
from within the rust-build at all. This is fine for most dev setups if we don't
care about versions locally testing.

Signed-off-by: Tiago Castro <[email protected]>
tiagolobocastro added a commit to openebs/mayastor-dependencies that referenced this pull request Feb 9, 2023
Added git dependencies:
fusion-engineering/rust-git-version#19

This allows us to avoid rebuilds when staging changes.

Also added another feature to avoid rebuilds altogether.
Eg: if git versions are specified via env variable then we don't need to use git
from within the rust-build at all. This is fine for most dev setups if we don't
care about versions locally testing.

Signed-off-by: Tiago Castro <[email protected]>
tiagolobocastro added a commit to openebs/mayastor-dependencies that referenced this pull request Feb 10, 2023
Added git dependencies:
fusion-engineering/rust-git-version#19

This allows us to avoid rebuilds when staging changes.

Also added another feature to avoid rebuilds altogether.
Eg: if git versions are specified via env variable then we don't need to use git
from within the rust-build at all. This is fine for most dev setups if we don't
care about versions locally testing.

Signed-off-by: Tiago Castro <[email protected]>
tiagolobocastro added a commit to openebs/mayastor-dependencies that referenced this pull request Feb 10, 2023
Added git dependencies:
fusion-engineering/rust-git-version#19

This allows us to avoid rebuilds when staging changes.

Also added another feature to avoid rebuilds altogether.
Eg: if git versions are specified via env variable then we don't need to use git
from within the rust-build at all. This is fine for most dev setups if we don't
care about versions locally testing.

Signed-off-by: Tiago Castro <[email protected]>
tiagolobocastro added a commit to openebs/mayastor-dependencies that referenced this pull request Feb 10, 2023
Added git dependencies:
fusion-engineering/rust-git-version#19

This allows us to avoid rebuilds when staging changes.

Also added another feature to avoid rebuilds altogether.
Eg: if git versions are specified via env variable then we don't need to use git
from within the rust-build at all. This is fine for most dev setups if we don't
care about versions locally testing.

Signed-off-by: Tiago Castro <[email protected]>
@hoijui

This comment was marked as resolved.

@de-vri-es
Copy link
Collaborator

Could you elaborate a bit on the use case for this? I can't think of a reason why you wouldn't want a rebuild after the git information changed.

@tiagolobocastro
Copy link
Author

Could you elaborate a bit on the use case for this? I can't think of a reason why you wouldn't want a rebuild after the git information changed.

Let's see, haven't look at this for a while but IIRC because index is added, staging changes causes rebuilds to happen which was the initial thing I was trying to avoid, as staging a file doesn't change the current sha but it does trigger a rebuild as is!

More specifically for our use case, for dev builds we're not so picky about the the commit sha anyway, even if it gets slightly wrong we don't care too much as we have separate image build procedure via nix when we want correct commit/tag with correct build dependencies etc.

@de-vri-es
Copy link
Collaborator

Let's see, haven't look at this for a while but IIRC because index is added, staging changes causes rebuilds to happen which was the initial thing I was trying to avoid, as staging a file doesn't change the current sha but it does trigger a rebuild as is!

I'm not sure why we added the index actually. Staged changes are still dirty changes, so I'd think HEAD should be enough.. But I want to verify this more before making any decisions based on this.

More specifically for our use case, for dev builds we're not so picky about the the commit sha anyway, even if it gets slightly wrong we don't care too much as we have separate image build procedure via nix when we want correct commit/tag with correct build dependencies etc.

Hmm. The macro should still function correctly, even if some class of problems doesn't matter for some cases where everything gets built in a controlled manner.

I'm not convinced there is enough reason to add a knob to tweak this. In particular, letting the user specify what files to depend on is too complicated. If there is something simpler that makes sense we could consider including it. But for now I'm inclined not to add any customization of the git files to depend on.

I'm open for discussion on why we add a dependency on the index though.

@de-vri-es
Copy link
Collaborator

For reference: we need to rebuild if the index changes, otherwise doing the following will not result in reporting a dirty build:

  • build your project
  • change a file that doesn't trigger a rebuild
  • stage it
  • build again (would not actually rebuild, since only the index changed since the last build)

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.

3 participants