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

Pepsi Maxi 🥤 #1486

Open
wants to merge 63 commits into
base: main
Choose a base branch
from
Open

Pepsi Maxi 🥤 #1486

wants to merge 63 commits into from

Conversation

schmidma
Copy link
Member

@schmidma schmidma commented Nov 3, 2024

Why? What?

I'm excited to announce Pepsi Max, the effervescently revamped version of our command line tool that works hand in hand with the mighty "hulk" robotics framework. While the original Pepsi version had all the right ingredients, this rework brings them together with modern flair and clarity—without adding any extra calories, of course!

Here's what's bubbling up in Pepsi Max:

  • No More Recompiles for Config Changes: I’ve ditched the hard-coded constants in favor of a hulk.toml configuration file. Now, adjusting settings like the OS_VERSION of NAO is as easy as opening a can, with no need for recompiling or re-releasing a new version of Pepsi. Just pop, fizz, and go!

  • Standardized Directory Locations: All SDKs and necessary artifacts are now following best practices and residing in XDG data directories, leaving behind the outdated hard-coded user home locations. Think of it as tidying up the fridge for maximum refreshment!

  • Repository Crate Overhaul: Say goodbye to the spaghetti code! The repository crate has undergone a major cleanup, moving to a module structure with well-documented code. This creates a solid, general-purpose library for interacting with the hulk repository—now that's refreshing!

  • Dynamic Repository Root Detection: The search for the repository root is now done dynamically at runtime. I’m looking for a directory with a hulk.toml or using the HULK_DEFAULT_ROOT environment variable. This means running Pepsi is now as spontaneous as reaching for your favorite soft drink.

Pepsi Max is like opening a fizzing can of productivity with the sleekness of modern coding practices. By aligning this tool with current standards, I've made it easier to read, maintain, and enjoy—just like a thirst-quenching beverage should be.

Looking forward to your thoughts and feedback on this fizzy new take. I hope Pepsi Max will truly refresh your development experience and keep your workflow bubbling!

ToDo / Known Issues

  • needs some intensive testing
  • checking back with the team for preferences on logging and UX

Ideas for Next Iterations (Not This PR)

  • Remove the dependency to have pepsi installed on the remote host for remote compilation. Currently, the only reason is to install an SDK. We could move this process to some external bash script, which allows to drop pepsi on the remote machine
  • Make linux container image generic over SDK/native by modifying entry point; source SDK in the entry point, not manually, when invoking docker/podman via pepsi. This allows to only pass the cargo command, and select the correct cargo
  • we may want to instruct curl to attempt continuing aborted downloads with --continue-at -.
  • globbing for **/{manifest}/Cargo.toml instead of manually defined aliases for manifests
  • Evaluate compile time performance for different codegen-units

How to Test

Extensive use of pepsi... Nearly every command was touched :(

@schmidma schmidma mentioned this pull request Nov 3, 2024
@schmidma schmidma force-pushed the pepsi-max branch 5 times, most recently from 129b02c to 4c356bb Compare November 3, 2024 21:38
@knoellle knoellle self-assigned this Nov 4, 2024
@knoellle knoellle removed their assignment Nov 21, 2024
@schmidma schmidma force-pushed the pepsi-max branch 2 times, most recently from 8486f75 to a3db57f Compare December 17, 2024 15:47
@julianschuler julianschuler force-pushed the pepsi-max branch 7 times, most recently from aad668b to 7548b59 Compare January 10, 2025 22:39
@oleflb oleflb changed the title Pepsi Max 🥤 Pepsi Maxi 🥤 Jan 12, 2025
Cargo.toml Show resolved Hide resolved
services/aliveness/Cargo.toml Show resolved Hide resolved
crates/nao/src/lib.rs Outdated Show resolved Hide resolved
crates/repository/src/cargo.rs Show resolved Hide resolved
crates/repository/src/cargo.rs Outdated Show resolved Hide resolved
crates/nao/src/lib.rs Outdated Show resolved Hide resolved
tools/pepsi/src/ping.rs Show resolved Hide resolved
tools/pepsi/src/post_game.rs Outdated Show resolved Hide resolved
tools/pepsi/src/pre_game.rs Outdated Show resolved Hide resolved
tools/pepsi/src/pre_game.rs Outdated Show resolved Hide resolved
tools/pepsi/src/cargo.rs Outdated Show resolved Hide resolved
Comment on lines +126 to +129
let data_home = get_data_home().wrap_err("failed to get data home")?;
let environment_file = &data_home.join(format!(
"sdk/{version}/environment-setup-corei7-64-aldebaran-linux"
));
Copy link
Contributor

Choose a reason for hiding this comment

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

This goes kaputt when building remotely. We have to use the data home on the remote which we'd either need to retrieve first or use shell magic to implement the logic from get_data_home right inside the command we're building here.

Copy link
Member Author

Choose a reason for hiding this comment

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

uff... What way do you suggest to fix that?

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

Successfully merging this pull request may close these issues.

3 participants