Hello,

I have a project for which some machines have only a subset of features set. Currently, I write

cargo run --no-default-features --features "toto,titi" --bin my_bin

This is a bit cumbersome and I sometimes forget the --no-default-features --features part. I was wondering if there is a local config file that I could put in the directory to instruct cargo to use this particular subset of features. I guess this should be in the documentation, but I didn’t find it.

  • fnmain@programming.dev
    link
    fedilink
    arrow-up
    4
    arrow-down
    1
    ·
    edit-2
    8 months ago

    The way I can think of to do this is to make a program called cargo-build-env which reads a file of your choosing with the features and executes cargo, then place that binary in your ~/.cargo/bin directory. Then you can run cargo build-env to build your program

    The program can be in any language as long as it’s executable, including shell script

    • sugar_in_your_tea@sh.itjust.works
      link
      fedilink
      arrow-up
      3
      ·
      edit-2
      8 months ago

      Yeah, a simple bash script should do. Such as:

      #!/usr/bin/env bash
      
      BUILD_FEATURES=${BUILD_FEATURES:=default}
      
      cargo run --no-default-features --features "${BUILD_FEATURES}" --bin my_bin
      

      Then just set a BUILD_FEATURES env var.

  • TehPers@beehaw.org
    link
    fedilink
    English
    arrow-up
    4
    arrow-down
    1
    ·
    8 months ago

    A couple options come to mind to me:

    1. Only have default features that every platform will support. This way you don’t need to opt-out, instead you always opt-in per platform.
    2. Use other conditions in cfg more. If your features are conditional based on OS, architecture, CPU features, etc then you probably are better off using conditions other than feature. See the reference for more information.
    3. Use a separate build script. Cargo doesn’t scale well by itself for larger projects, so separate scripts which run cargo are common. You could use Makefile, shell scripts, or even look into tools like cargo-make and just. From there, you can do platform-specific build logic or even read variables from a .env like you mentioned you wanted.
    • japps13OPA
      link
      fedilink
      arrow-up
      1
      ·
      8 months ago

      Going opt-in instead of opt-out does not change the fact that I would still have to toggle the features manually. To be more specific, my use case is that I have a program to control cameras in my lab. But not all computers have the libraries for all cameras. So, every supported library can be enable/disable using a feature But the program being still in active development, I am frequently using cargo run, cargo check, cargo install, on different computers with different libraries installed. What would be convenient would be to have a configuration file on each computer, specifying that we will build only for PCO camera on this computer, only for Photometrics camera on this one, only Ximea and PCO on this one, instead of having to remember to toggle the relevant features every time. A shell script is not very convenient because I use different commands, run, check, install etc.

      • TehPers@beehaw.org
        link
        fedilink
        English
        arrow-up
        2
        ·
        8 months ago

        You should look at the tools I linked. cargo-make would just change your flow to cargo make run, cargo make check, etc. and just has similar benefits. You’d handle the computer-specific logic in there, using a .env per computer if you want.

        • japps13OPA
          link
          fedilink
          arrow-up
          2
          ·
          8 months ago

          Ok, I’ll look into that then. Thanks.