mmastrac16 hours ago | | | parent | | on: 47756321
Can you (err... buildcache) cache Rust proc-macros? I've been battling this with sccache and I'm now maintaining a 10-patch deep stack for the next.js build CI.

Windows builds were ridiculously poor on cache hits rates too because of non-determinism that was not able to figure out.

I'd be happy to test it out.

estebank16 hours ago | | | parent | | on: 47759018
There was an experimental PR that treats proc macros as idempotent with the corresponding colpike speed up. I don't know what happened with it, and stabilization required a lot of design work to not break backcompat. But this is something in the team's radar.
Would it be possible to do somethign like editions for proc macros, or have crates establish "this is a v2 proc macro" or something? There are a lot of things I'd love to see change in a v2 but it'd all be breaking.
estebank12 hours ago | | | parent | | on: 47759488
Yes, I think here are workable designs.
mmastrac15 hours ago | | | parent | | on: 47759101
Do you have a link for this one? Would love to see it.
estebank12 hours ago | | | parent | | on: 47759511
This is not the one I remember but another one that does part of what I'm describing.

https://github.com/rust-lang/rust/pull/145354

NooneAtAll314 hours ago | | | parent | | on: 47759101
what do you mean by idempotent and colpike?
estebank12 hours ago | | | parent | | on: 47759663
Idempotent as in if the token stream in the input doesn't change, the cached result of the previous macro expansion is used during incremental, instead of being pessimistic and rerunning the macro.

Colpike as in compile typo.

evmar14 hours ago | | | parent | | on: 47756321
I’m not too familiar with Firefox builds. Why are clobber builds common? At first glance it seems weird to add a cache around your build system vs fixing your build system.
jagged-chisel13 hours ago | | | parent | | on: 47759960
Define “fixing.” If you’re building on ephemeral containers, an external cache is necessary for files that don’t change.
mbitsnbites8 hours ago | | | parent | | on: 47759960
Though I'm not actively working with Firefox so can't speak for their use cases, one important use case for clobber builds is CI.

I'm the author of BuildCache, and where I work we make thousands of clobber builds every day in our CI. Caching helps tremendously for keeping build times short.

There are a few use cases for local development too. For instance if you switch between git branches you may have to make near full rebuilds (e.g. in C++ if some header file is touched that gets included by many files).

Another advantage as a local dev is that you can tap into the central CI cache and when you pull the latest trunk and build it, chances are that the CI system has already built that version (e.g. as part of a merge gate) so you will get cache hits.

evmar7 hours ago | | | parent | | on: 47761887
I see, I might be confused by the terminology. "clobber" to me suggests intentionally trying to throw away cached results (clobbering what you have), but it sounds like you might just use it to mean builds where you don't have any existing build state already present.
secondcoming7 hours ago | | | parent | | on: 47759960
What even is a 'clobber build'?
__farre__7 hours ago | | | parent | | on: 47762294
Sorry for being unclear. I'm using Firefox build system lingo without explanations. It's from the command `./mach clobber`, which is similar but not the same as `make clean`. I use 'clobber build' as "a build with no existing build state" and the qualifiers "cold" and "warm" to indicate if cache is empty or filled.
secondcoming3 hours ago | | | parent | | on: 47762672
Ah ok, thanks
allenrb15 hours ago | | | parent | | on: 47756321
I guess “purge 17% of the code” is not the correct answer?
yjftsjthsd-h7 hours ago | | | parent | | on: 47759151
If you can remove 17% of your code, or even just avoid building it, yeah you probably should. That can be a really rough tradeoff though. (And the sibling comment is also right that deleting 17% of code != 17% faster builds, though I could see it being higher or lower)
eru9 hours ago | | | parent | | on: 47759151
Only if your build scales linearly. Otherwise, it might be a different percentage.
K0IN17 hours ago | | | parent | | on: 47756321
wow, 17% is impressive with such an easy fix. i wonder if we could just build this as a separate project and pull the webidl files as a dependency.
rtpg13 hours ago | | | parent | | on: 47758051
managing deps as a separate project introduces a lot of day-to-day annoyances, especially if the files are actually changed decently often.
Devorlon18 hours ago | | | parent | | on: 47756321
Why compile code when ccache faster
amelius17 hours ago | | | parent | | on: 47757529
Does ccache fetch compiled code from a central server using checksums?
fishgoesblub15 hours ago | | | parent | | on: 47758058
buildcache, the program the post is about can use a remote server for storing the cache.
mbitsnbites9 hours ago | | | parent | | on: 47759201
And a local cache (kind of level 1 and level 2 caches)
sccache can, but most of us don't have access to an sccache instance: https://github.com/mozilla/sccache
firesteelrain12 hours ago | | | parent | | on: 47758423
We use sccache on prem with MinIO.
mmastrac14 hours ago | | | parent | | on: 47758423
sccache is pretty easy to set up and you can back it with S3, memcache, redis, etc.
mbitsnbites8 hours ago | | | parent | | on: 47759758
Same with BuildCache, except you also get a fast local cache so you effectively have an L1 and an L2 cache.

In fact, since you also have super fast "direct mode" caching that bypasses the preprocessor (like ccache but unlike sccache), BuildCache really has three logical levels of cache: direct, preprocessor and remote (S3, redis, ...).

shevy-java17 hours ago | | | parent | | on: 47756321
So ... perhaps Mozilla should focus on user share dropping.

I understand that speed is relevant, but focusing on that strategy does not really work when dinosaur-like extinction is around the corner.

sfink10 hours ago | | | parent | | on: 47758372
Aw shucks, we never thought of that. Here we were, dedicating every one of our developers to speeding up the build, and we never thought to increase our user share instead. In retrospect, that was pretty dumb! Ok, sorry, we'll get right on that.

Seriously, what is with the trend of assuming that anything anyone in a project does, it is assumed that it has been the main goal of the project and all other objectives have been abandoned? "Firefox's frontend designers are doing frontend design work instead of implementing WebUSB which would immediately reverse their declining user share trend and make billions of dollars worth of donations! What are they thinking?!!"

(I'm gonna get a lot of hate for this post, aren't I?)

__farre__10 hours ago | | | parent | | on: 47758372
Post author here. I should've expected these comments, which makes me want to clarify a couple of things.

1. Just because I'm a dev at Mozilla and I got support for buildcache landed in the Firefox repo doesn't make this a Mozilla project. I do this on my own time to help me be more efficient when I actually work.

2. I mainly do this because it's fun. Including the blogging.

3. Sccache is still the compiler cache we're officially developing at Mozilla

tadfisher16 hours ago | | | parent | | on: 47758372
I will just say this: it is unfortunate that you have chosen not to engage with the content of the article.
mbitsnbites9 hours ago | | | parent | | on: 47758372
For what it's worth, browser uptake is largely dictated by the browser being default shipped with some major OS. Very few users make an active choice (statistically speaking).

Safari is popular because it ships with iOS and macOS.

Edge (previously IE) is popular because it ships with Windows.

Chrome, however, is popular for several reasons. One reason is that it ships with Android and ChromeOS, but before that Google had a very aggressive multi-channel campaign where they pushed it with large banners on Google search (everyone used Google) and they made deals with Windows AV vendors so that when a user installed anti-virus on their computer Chrome was automatically installed and made the default browser. Another reason is that Google has consistently develeoped Chrome together with their web services, so things like search, maps, gmail, docs etc tend to work best in Chrome.

The only default channels that Firefox has, that I'm aware of, are verious Linux distros, and they have a pretty thin market slice.

Obviously it'll make the developer more efficient to spend more time twiddling his thumbs waiting for his code to compile rather than creating a simple build performance win that allows him to, you know, spend more time improving Firefox. Not to mention all the other developers who stand to benefit from faster builds.