Gentoo Forums
Gentoo Forums
Gentoo Forums
Quick Search: in
Ebuild runtime dependencies for Binary Package installations
View unanswered posts
View posts from last 24 hours

 
Reply to topic    Gentoo Forums Forum Index Portage & Programming
View previous topic :: View next topic  
Author Message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Fri Jan 03, 2025 1:33 pm    Post subject: Ebuild runtime dependencies for Binary Package installations Reply with quote

Hello!

I'm new to Gentoo and Portage and trying to do the following:

I'd like to install specific packages from the Binary Package Host for the reason you'd expect, to avoid long & often compile times for frequently updated applications.

However, I'd still like to install the runtime dependencies for the package from the ebuild host, i.e. compile them from source (and all of their dependencies) since they tend to be small. This is quite similar to the behaviour of installing www-client/firefox-bin from the ebuild repository which compiles its runtime dependencies from source, but still installs firefox as a binary package.

Including the --getbinpkg option forces all runtime dependencies to be installed from source. I've tried to just compile dependencies by combining the --only-deps and the --with-bdeps=n options, but it still tries to install the build dependencies.

For example, let's say I want to install dev-qt/qtwebengine, of which a build (but not runtime) dependency is net-libs/nodejs, How could I install all of the runtime dependencies of qtwebengine as ebuilds without installing the build dependencies (e.g. nodejs) and then install the binary package? Ideally without adding all of the runtime dependencies to the world set.

I've tried to search the forums for an answer to this question but have so far come up empty. I'm also open to advice on why this might be non-adviseable thing to do in general.

Thanks in advance!
Back to top
View user's profile Send private message
Genone
Retired Dev
Retired Dev


Joined: 14 Mar 2003
Posts: 9625
Location: beyond the rim

PostPosted: Fri Jan 03, 2025 2:26 pm    Post subject: Reply with quote

I don't think that is possible without specifying all packages you want to be installed manually (you could use --oneshot to avoid adding them to world if that is your main concern) with the current implementation of binary package support. Wouldn't even know how to define a user interface for this without adding a new option dedicated to this very specific use case.

It might be doable by creating a custom package set class, but I doubt you want to get into portage programming for this.
Back to top
View user's profile Send private message
NeddySeagoon
Administrator
Administrator


Joined: 05 Jul 2003
Posts: 54744
Location: 56N 3W

PostPosted: Fri Jan 03, 2025 2:44 pm    Post subject: Reply with quote

theskyentist,

Welcome to Gentoo.

I not sure I understand completely,
You want to install the run time dependences of a package using portage, than the package itself from the binhost.
You do not want the build time dependences of the package you will install from the the binhost.

Here is where my confusion comes in ...
Code:
--with-bdeps=n
prevents ALL build time dependences from being built, even build time dependences of the packages you want to build.

Maybe a worked example would help find a way forward?
_________________
Regards,

NeddySeagoon

Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail.
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 23030

PostPosted: Fri Jan 03, 2025 2:49 pm    Post subject: Reply with quote

As part of that worked example, I would like to see the emerge --pretend --verbose output of the commands you ran that you hoped would work, but did not. It seems strange to me that --only-deps --getbinpkg --with-bdeps=n would not do what you want, though I have never tried to replicate your workflow. Perhaps someone more familiar with the binpkg mechanics knows a reason why that should not work. I'd also like to see what happens if you use --only-deps --getbinpkgonly --with-bdeps=n, since that should force Portage to use binpkgs or explain why it cannot. There are reasons it might refuse, such as USE flag mismatches or absence of compatible versions, which I think it will show when --getbinpkgonly forbids it falling back to building from source.
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Sat Jan 04, 2025 11:36 am    Post subject: Reply with quote

Hey everyone,

Thanks for the quick replies! I'm happy to provide a worked example.

I'm specifically looking at QTWebEngine.

Taking at look at the ebuild for this package, it lists nodeJS as a build dependency.

Code:
BDEPEND="
   $(python_gen_any_dep 'dev-python/html5lib[${PYTHON_USEDEP}]')
   dev-util/gperf
   net-libs/nodejs[ssl]
   sys-devel/bison
   sys-devel/flex
"


So when I run: emerge -pavt dev-qt/qtwebengine --with-bdeps=n

I get the following:
Code:
[ebuild  N     ] dev-qt/qtwebengine-6.8.1:6/6.8.1::gentoo  USE="alsa jumbo-build opengl qml system-icu vulkan widgets -accessibility -bindist -custom-cflags -designer -geolocation -kerberos -pdfium -pulseaudio -screencast -test -vaapi -webdriver" 0 KiB
[ebuild  N     ]  dev-python/html5lib-1.1-r2::gentoo  USE="-test" PYTHON_TARGETS="python3_12 (-pypy3) -python3_10 -python3_11 -python3_13" 0 KiB
[ebuild  N     ]   dev-python/webencodings-0.5.1-r2::gentoo  USE="-test" PYTHON_TARGETS="python3_12 (-pypy3) -python3_10 -python3_11 -python3_13" 0 KiB
[ebuild  N     ]   dev-python/six-1.17.0::gentoo  USE="-doc -test" PYTHON_TARGETS="python3_12 (-pypy3) -python3_10 -python3_11 -python3_13 (-python3_13t)" 0 KiB
[ebuild  N     ]  net-libs/nodejs-22.4.1-r1:0/22::gentoo  USE="icu npm snapshot ssl system-icu system-ssl -corepack -debug -doc -inspector (-lto) -pax-kernel -test" CPU_FLAGS_X86="sse2" 0 KiB
[ebuild  N     ]   net-libs/ngtcp2-1.7.0::gentoo  USE="gnutls ssl (-openssl) -static-libs -test" ABI_X86="(64) -32 (-x32)" 0 KiB
[ebuild  N     ]   dev-libs/simdjson-3.11.0:0/24::gentoo  USE="all-impls -test -tools" 0 KiB
[ebuild  N     ]  dev-qt/qtwebchannel-6.8.1:6/6.8.1::gentoo  USE="qml -test" 0 KiB
[ebuild  N     ]  dev-libs/libevent-2.1.12-r1:0/2.1-7::gentoo  USE="clock-gettime ssl -debug -malloc-replacement -static-libs -test -verbose-debug -verify-sig" ABI_X86="(64) -32 (-x32)" 0 KiB
[ebuild  N     ]  app-arch/snappy-1.1.10-r1:0/1.1::gentoo  USE="-test" ABI_X86="(64) -32 (-x32)" CPU_FLAGS_X86="avx avx2" 0 KiB


Note that nodeJS is still being merged. This is only because it is a dependency of qtwebengine, I've gone through and checked the dependencies of all other requested packages to emerge and none of them would merge nodeJS.

I'm unclear as to why with-bdeps=n seems to still include nodeJS.

I would have expected the following workflow to work for me:
emerge --ask --only-deps --with-bdeps=n dev-qt/qtwebengine (fetch & compile runtime dependencies)
emerge --ask --getbinpkg dev-qt/qtwebengine (install just the pre-compiled binary since all run-time dependencies are already merged)
But the first step appears to still bring in at least one build dependency.

Thanks again for taking the time to look at this!
Back to top
View user's profile Send private message
NeddySeagoon
Administrator
Administrator


Joined: 05 Jul 2003
Posts: 54744
Location: 56N 3W

PostPosted: Sat Jan 04, 2025 1:05 pm    Post subject: Reply with quote

theskyentist,

Code:
emerge -pavt dev-qt/qtwebengine --with-bdeps=n
explicitly builds qtwebengine.

Code:
[ebuild  N     ] dev-qt/qtwebengine-6.8.1:6/6.8.1::gentoo
it's flagged as New too.
Without the colour, I can't see if its a binary or not but I suspect not.

Code:
emerge --ask --only-deps --with-bdeps=n dev-qt/qtwebengine

There is no - in the middle of --onlydeps.
Is that just in your post?
I get ...
Code:
emerge: error: unrecognized arguments: --only-deps

_________________
Regards,

NeddySeagoon

Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail.
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Sat Jan 04, 2025 3:47 pm    Post subject: Reply with quote

NeddySeagoon,

You're correct,

Code:
emerge -pavt


would attempt to build qtwebengine. My understanding is that adding --with-bdeps=n would not pull in build dependencies (likely causing a build failure in many cases, hence why it defaults to yes for installation actions). Therefore combining this with the --onlydeps flag (apologizes for the typo there) would hopefully compile all run-time dependencies for qtwebengine and then allow me to only fetch the binary package itself.

The displayed behavior however does not appear to be the case, where build dependencies are still attempted to be merged (e.g. nodeJS in the example I provided). I've also tried:
emerge -avtp dev-qt/qtwebengine --with-bdeps-auto=n --with-bdeps=n --onlydeps

And this still wants to merge nodeJS, which is a build dependency and not a run-time dependency (assuming I am understanding the ebuild correctly.

Hopefully this clarifies the situation.
Back to top
View user's profile Send private message
John R. Graham
Administrator
Administrator


Joined: 08 Mar 2005
Posts: 10709
Location: Somewhere over Atlanta, Georgia

PostPosted: Sat Jan 04, 2025 4:35 pm    Post subject: Reply with quote

theskyentist,

I think you're misunderstanding what --with-bdeps=n does. It doesn't keep any given package from being a build-time dependency. If a package is a build-time dependency of what you're asking to be built—and it's not currently installed—then regardless of the state of the --with-bdeps option, it will be installed because it's needed in order to build the package that you've asked to build. That's what being a build-time dependency means.

What --with-bdeps actually does is it prevents the build-time dependencies from being updated when an update that's not strictly necessary for the specified package to be built is available.

- John
_________________
I can confirm that I have received between 0 and 499 National Security Letters.
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 23030

PostPosted: Sat Jan 04, 2025 4:55 pm    Post subject: Reply with quote

NeddySeagoon wrote:
Code:
[ebuild  N     ] dev-qt/qtwebengine-6.8.1:6/6.8.1::gentoo
Without the colour, I can't see if its a binary or not but I suspect not.
If OP had managed to request a binary package, it would read
Code:
[binary  N   ] ...
For me, using glibc as an example:
Code:
# emerge -p sys-libs/glibc

These are the packages that would be merged, in order:

[ebuild   R    ] sys-libs/glibc-2.40-r5:2.2
# emerge -pk sys-libs/glibc

These are the packages that would be merged, in order:

[binary   R    ] sys-libs/glibc-2.40-r5:2.2
theskyentist wrote:

The displayed behavior however does not appear to be the case, where build dependencies are still attempted to be merged (e.g. nodeJS in the example I provided). I've also tried:
emerge -avtp dev-qt/qtwebengine --with-bdeps-auto=n --with-bdeps=n --onlydeps

And this still wants to merge nodeJS, which is a build dependency and not a run-time dependency (assuming I am understanding the ebuild correctly.
What was the full output of the command that tried to build nodejs? Since you have --tree enabled, we can check use that to check whether some package that you are building has its own dependency on nodejs.
Back to top
View user's profile Send private message
Genone
Retired Dev
Retired Dev


Joined: 14 Mar 2003
Posts: 9625
Location: beyond the rim

PostPosted: Sun Jan 05, 2025 4:25 am    Post subject: Reply with quote

theskyentist wrote:

So when I run: emerge -pavt dev-qt/qtwebengine --with-bdeps=n

I get the following:
Code:
[ebuild  N     ] dev-qt/qtwebengine-6.8.1:6/6.8.1::gentoo  USE="alsa jumbo-build opengl qml system-icu vulkan widgets -accessibility -bindist -custom-cflags -designer -geolocation -kerberos -pdfium -pulseaudio -screencast -test -vaapi -webdriver" 0 KiB
[ebuild  N     ]  dev-python/html5lib-1.1-r2::gentoo  USE="-test" PYTHON_TARGETS="python3_12 (-pypy3) -python3_10 -python3_11 -python3_13" 0 KiB
[ebuild  N     ]   dev-python/webencodings-0.5.1-r2::gentoo  USE="-test" PYTHON_TARGETS="python3_12 (-pypy3) -python3_10 -python3_11 -python3_13" 0 KiB
[ebuild  N     ]   dev-python/six-1.17.0::gentoo  USE="-doc -test" PYTHON_TARGETS="python3_12 (-pypy3) -python3_10 -python3_11 -python3_13 (-python3_13t)" 0 KiB
[ebuild  N     ]  net-libs/nodejs-22.4.1-r1:0/22::gentoo  USE="icu npm snapshot ssl system-icu system-ssl -corepack -debug -doc -inspector (-lto) -pax-kernel -test" CPU_FLAGS_X86="sse2" 0 KiB
[ebuild  N     ]   net-libs/ngtcp2-1.7.0::gentoo  USE="gnutls ssl (-openssl) -static-libs -test" ABI_X86="(64) -32 (-x32)" 0 KiB
[ebuild  N     ]   dev-libs/simdjson-3.11.0:0/24::gentoo  USE="all-impls -test -tools" 0 KiB
[ebuild  N     ]  dev-qt/qtwebchannel-6.8.1:6/6.8.1::gentoo  USE="qml -test" 0 KiB
[ebuild  N     ]  dev-libs/libevent-2.1.12-r1:0/2.1-7::gentoo  USE="clock-gettime ssl -debug -malloc-replacement -static-libs -test -verbose-debug -verify-sig" ABI_X86="(64) -32 (-x32)" 0 KiB
[ebuild  N     ]  app-arch/snappy-1.1.10-r1:0/1.1::gentoo  USE="-test" ABI_X86="(64) -32 (-x32)" CPU_FLAGS_X86="avx avx2" 0 KiB


Note that nodeJS is still being merged. This is only because it is a dependency of qtwebengine, I've gone through and checked the dependencies of all other requested packages to emerge and none of them would merge nodeJS.

I'm unclear as to why with-bdeps=n seems to still include nodeJS.


Because you effectively requested to build qtwebengine from source, so nodeJS is required. --with-bdeps is intended to control inclusion of build dependencies in the dependency graph when they are not strictly required (when they are already satisfied, but could be updated), it has no effect in this case. As said, I don't think what you want to do is possible atm as the options for selecting binary packages work on a global basis, so when you're selecting the binary package of qtwebengine you will also get the binary package for the dependencies when available. And when selecting the ebuild version you will always get the build dependencies as well.
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Sun Jan 05, 2025 10:38 am    Post subject: Reply with quote

@Genone and @John R. Graham

I was definitely wrong about the behaviour of --with-bdeps, so I appreciate the clarification on the usage of that option, it seems like that is therefore not the way to go for attempting to do what I am trying to achieve.

@Hu is correct that running emerge -avtG dev-qt/qtwebengine --binpkg-respect-use=n would yield a binary package installation, but the runtime dependencies would also be installed from the binary host:

Code:
[binary  N     ] dev-qt/qtwebengine-6.8.1-r1-3:6/6.8.1::gentoo  USE="alsa bindist jumbo-build opengl pulseaudio qml system-icu vulkan widgets -accessibility -custom-cflags -designer -geolocation -kerberos -pdfium -screencast -test -vaapi -webdriver" 72,820 KiB
[binary  N     ]  dev-libs/libevent-2.1.12-r1-2:0/2.1-7::gentoo  USE="clock-gettime ssl -debug -malloc-replacement -static-libs -test -verbose-debug -verify-sig" ABI_X86="(64) -32 (-x32)" 340 KiB
[binary  N     ]  dev-qt/qtwebchannel-6.8.1-1:6/6.8.1::gentoo  USE="qml -test" 150 KiB
[binary  N     ]  app-arch/snappy-1.1.10-r1-1:0/1.1::gentoo  USE="-test" ABI_X86="(64) -32 (-x32)" CPU_FLAGS_X86="-avx -avx2" 70 KiB


I think @Genone's original suggestion to --oneshot the required packages (thereby not polluting the world set with dependencies that may be removed at a later date) is probably the best way forward. After these discussions there appear to be two strategies in mind:

Install all dependencies (including build+run), install binary package, clean dependencies.
emerge --avt dev-qt/qtwebengine --onlydeps #install build+run dependencies
emerge --avtG dev-qt/qtwebengine --binpkg-respect-use=n #install binary package
emerge --depclean #clean build dependencies

Install only runtime dependencies with oneshot, install binary package
emerge --avt dev-libs/libevent dev-qt/qtwebchannel app-arch/snappy --oneshot #install runtime dependencies but dont add to world
emerge --avtG dev-qt/qtwebengine --binpkg-respect-use=n # install binary package

The second is clearly more work but avoid installing unnecessary packages in the short term, and could likely be scripted.

Are there other options I should consider or are there clear flaws with the process I've outlined?

Thanks again for everyone's time and attention on this!
Back to top
View user's profile Send private message
NeddySeagoon
Administrator
Administrator


Joined: 05 Jul 2003
Posts: 54744
Location: 56N 3W

PostPosted: Sun Jan 05, 2025 11:25 am    Post subject: Reply with quote

theskyentist,

You could write a set or several sets listing build time dependencies.
That will aid scripting. Call them set1 and set2.
emerge @set1 will build and install the list in set1 and add @set1 to world.

emerge @set2 -1G will install set2 from the binhost and not list it in world.

It's not a new idea but it may help your scripting.
_________________
Regards,

NeddySeagoon

Computer users fall into two groups:-
those that do backups
those that have never had a hard drive fail.
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Sun Jan 05, 2025 1:27 pm    Post subject: Reply with quote

@NeddySeagoon

Thanks for the advice! I'll try to work on a script and/or portage sets that attempts to achieve the desired behavior. Hopefully it works out!

Thanks again for everyone's help :-)
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Tue Jan 07, 2025 6:47 pm    Post subject: Reply with quote

Okay folks, here's what I've come up with:

Two scripts, one to install all packages in my @binary set, and one two update and then depclean (though the later could of course be separated)

Code:
#!/bin/bash

# Binary Set
BINARY_SET="/etc/portage/sets/binary"

# Iterate over each package in the file
while IFS= read -r package; do
  [[ -z "$package" || "$package" =~ ^# ]] && continue

  echo "Processing package: $package"

  # Getting run-time dependencies
  dependencies=$(emerge -pog --binpkg-respect-use=y "$package" | grep -E '^\[(ebuild|binary)' | while read -r line; do
    # If it's an ebuild, get the whole slotname
    if [[ $line == \[ebuild* ]]; then
      echo "$line" | awk -F'] ' '{print "=" $2}' | awk '{print $1}'
    # If its a binary, trim the last bit off
    elif [[ $line == \[binary* ]]; then
      echo "$line" | awk -F'] ' '{print "=" $2}' | awk '{print $1}' | sed 's/-[^-]*$//'
    fi
  done | tr '\n' ' ')

  # Output the variable for verification
  echo "$package dependencies: $dependencies"

  # Dependency array
  read -r -a dep_array <<< "$dependencies"


  # Install dependencies
  if [[ ${#dep_array[@]} -gt 0 ]]; then
    sudo emerge -a1 "${dep_array[@]}" < /dev/tty > /dev/tty 2> /dev/tty
    if [[ $? -ne 0 ]]; then
      echo "Failed to install dependencies for $package. Skipping..."
      continue
    fi
  fi

  # Install the binary package
  sudo emerge -aG1 "$package" < /dev/tty > /dev/tty 2> /dev/tty
  if [[ $? -ne 0 ]]; then
    echo "Failed to install binary package: $package"
    continue
  fi

done < "$BINARY_SET"


Code:
#!/bin/bash

# Binary Set
BINARY_SET="/etc/portage/sets/binary"

# Initialize the exclude packages list
exclude_packages=""

# Iterate through each package in the binary file
while IFS= read -r package; do
  # Skip empty lines and comments
  if [[ -z "$package" || "$package" == \#* ]]; then
    continue
  fi
  # Add the package to the exclude list
  exclude_packages+="--exclude=$package "
done < "$BINARY_SET"

# Update the world set but ignore binary packages
sudo emerge -auDN @world $exclude_packages < /dev/tty > /dev/tty 2> /dev/tty

# Update the binary set
sudo emerge -auGN @binary < /dev/tty > /dev/tty 2> /dev/tty

# Depclean but ignore the ignore binary packages
sudo emerge -a --depclean $exclude_packages < /dev/tty > /dev/tty 2> /dev/tty


I'm no bash scripter, but I hope this helps someone else trying to achieve the same ends as me!
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2643

PostPosted: Tue Jan 07, 2025 7:19 pm    Post subject: Reply with quote

theskyentist wrote:

However, I'd still like to install the runtime dependencies for the package from the ebuild host, i.e. compile them from source (and all of their dependencies) since they tend to be small.


That gives you nothing. Better go full binary.

If you so much insist on building it, run a source build and terminate it when it gets to the big package. The add --getbinpkg and install it from binary package. Don't forget that terminated ebuilds do not clean their corresponding /var/tmp/portage content.

Do not use --binpkg-respect-use=n, rather adjust your use flags to match the emerge suggestions about skipped binary packages at the bottom.

Best Regards,
Georgi
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Tue Jan 07, 2025 8:07 pm    Post subject: Reply with quote

Georgi,

Could you explain what you mean in terms of "gives you nothing"? Is this in reference to performance or some other metric? I'm definitely interested in the pros/cons of the approach.

I think that the approach you outlined is what I tried to replicate with my scripts, that also hopefully doesn't involve manually cancelling the source build and clearing caches.

Cheers!
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2643

PostPosted: Tue Jan 07, 2025 8:13 pm    Post subject: Reply with quote

theskyentist wrote:
Georgi,

Could you explain what you mean in terms of "gives you nothing"? Is this in reference to performance or some other metric? I'm definitely interested in the pros/cons of the approach.


The binhosts contain binaries build for x86_64 v2 and v3. Even some recent Intel processors don't have v4 because of the E-cores. The difference between v3 and v4 is only some vector operations instruction extensions. You gain literally nothing by compiling anything yourself unless you use those instructions in particular.

Best Regards,
Georgi
Back to top
View user's profile Send private message
Hu
Administrator
Administrator


Joined: 06 Mar 2007
Posts: 23030

PostPosted: Tue Jan 07, 2025 8:35 pm    Post subject: Reply with quote

OP: could you explain what benefit you expect to gain if your scripts work as intended? I understand you would build runtime dependencies locally, but why do you think that is worthwhile? Typically, people focus more on making specific packages build locally because they want to carry patches that the binhost does not, or pick USE flags that it does not.
Back to top
View user's profile Send private message
theskyentist
n00b
n00b


Joined: 03 Jan 2025
Posts: 8

PostPosted: Tue Jan 07, 2025 9:03 pm    Post subject: Reply with quote

One of my main motivations for Gentoo was to gain experience with compiling the linux kernel and system packages in general. I therefore want to adhere to a strategy of compile as much as possible, because it let's me get into the weeds of it. At the same time, the machine I'm running Gentoo on is a laptop (with an AMD CPU capable of v4) so it's while it's fine to compile 99% of the packages on the system, compiling a few of the heaviest packages (e.g. firefox, qtwebengine as a dependency) benefits me greatly. To my understanding, this is why there exist dedicated "-bin" packages. My goal here is, I suppose, to try and recreate this behaviour for any arbitrary package. I don't necessary hope to get the utmost performance by compiling all run-time dependencies myself, but rather as a way to see if I can accomplish something. Half of the fun is in find the solution :-)
Back to top
View user's profile Send private message
logrusx
Advocate
Advocate


Joined: 22 Feb 2018
Posts: 2643

PostPosted: Tue Jan 07, 2025 9:21 pm    Post subject: Reply with quote

theskyentist wrote:
One of my main motivations for Gentoo was to gain experience with compiling the linux kernel and system packages in general. I therefore want to adhere to a strategy of compile as much as possible, because it let's me get into the weeds of it.


You won't. Everything is already taken care of, all you can do is watch the output. If you want to compile the linux kernel, you can. It doesn't matter if other packages are installed from the binhost. If you want to learn how to compile sources, do that manually. Also you can read the devmanual.

theskyentist wrote:
At the same time, the machine I'm running Gentoo on is a laptop (with an AMD CPU capable of v4) so it's while it's fine to compile 99% of the packages on the system, a few of the heaviest packages (e.g. firefox, qtwebengine as a dependency). To my understanding, this is why there exist dedicated "-bin" packages.


Packages ending in -bin are pre official binhost solution to this problem as well as pre-compiled kernels as well as packages for software provided in binary only or produced by upstream binaries. For example firefox-bin contains upstream binaries. A package I maintain in my overlay - freeplane-bin is produced from upstream binaries because I don't want to deal with gradle or manually compile and package a java application. The -bin suffix is a way to indicate this particular ebuild downloads and installs binaries, rather than compiling sources.

theskyentist wrote:
My goal here is, I suppose, to try and recreate this behaviour for any arbitrary package. I don't necessary hope to get the utmost performance by compiling all run-time dependencies myself, but rather as a way to see if I can accomplish something. Half of the fun is in find the solution :-)


I'm not sure what behavior you're talking about.

Best Regards,
Georgi
Back to top
View user's profile Send private message
Display posts from previous:   
Reply to topic    Gentoo Forums Forum Index Portage & Programming All times are GMT
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum