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

refactor(build script): rewrite the main build script #2319

Open
wants to merge 6 commits into
base: dev
Choose a base branch
from

Conversation

onur-ozkan
Copy link
Member

@onur-ozkan onur-ozkan commented Jan 13, 2025

Previous build script were highly unstable and relied on the MM_DATETIME and MM_VERSION files which was very annoying. These files caused cargo to invalidate the build cache, so even if you ran cargo build multiple times without changing anything, it would still rebuild because the build script triggered cache invalidation.

This PR makes the build script straightforward and more stable without causing cache invalidation. The final versioning output remains as is, but the implementation side is robust than ever.

Major effects:

  • No more cache invalidations.
  • The MM_VERSION and MM_DATETIME files are no longer needed in the project root.
  • Datetime handling is now more stable. Previously MM_DATETIME file could become outdated as it wasn't consistently updated.

Get rid of annoying file reading/writing logics

Signed-off-by: onur-ozkan <[email protected]>
Signed-off-by: onur-ozkan <[email protected]>
@onur-ozkan onur-ozkan force-pushed the cache-invalidation-fix branch from 3575651 to 5f4d0f6 Compare January 13, 2025 11:07
Copy link
Member Author

Choose a reason for hiding this comment

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

We need to revise our docs... This is extremely outdated.

@onur-ozkan onur-ozkan marked this pull request as ready for review January 13, 2025 11:31
Copy link
Member Author

Choose a reason for hiding this comment

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

Since this is re-written from scratch, I suggest you to review this by opening the file directly as the diff view will make it likely impossible to understand the logic.

Copy link
Collaborator

@shamardy shamardy left a comment

Choose a reason for hiding this comment

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

Thanks for the fix! Only one question for now. We will need to open a docs PR once this is approved, we need to inform QA that this is breaking as well (in case something depended on the old MM_VERSION/MM_DATETIME files).

Comment on lines +43 to +46
println!("cargo:rerun-if-env-changed=CARGO_PKG_VERSION");
println!("cargo:rerun-if-env-changed=KDF_BUILD_TAG");

set_build_variables().expect("Failed to set build variables");
Copy link
Collaborator

Choose a reason for hiding this comment

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

Will set_build_variables run for local builds after KDF_BUILD_TAG is set the first time?

Copy link
Member Author

Choose a reason for hiding this comment

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

It should as we have a check above cargo:rerun-if-env-changed=KDF_BUILD_TAG

Copy link
Member

@borngraced borngraced left a comment

Choose a reason for hiding this comment

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

Thanks. I tested it locally and it's clean.

// if there is MM_VERSION file, that means CI wants to put a tag to version
if !v_file.is_empty() {
version = format!("{}_{}", version, v_file.trim());
fn version_tag() -> Result<String, String> {
Copy link
Member

Choose a reason for hiding this comment

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

not important get_version_tag seems like better naming

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

Successfully merging this pull request may close these issues.

3 participants