-
Notifications
You must be signed in to change notification settings - Fork 78
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
Platform Commonalities: e.g. Apple, POSIX, etc. #37
Comments
@gregestren, is this the right place for issues like this, or should I have filed on the main Bazel repo? |
Interesting (and sorry I missed this the first time around). I think this is the right repo to discuss this and my intuition is this could be a good fit. I'd like to discuss this with the configurability team so I'll add it to their sync agenda and report back after our next sync. |
Thanks for being so great to work with, @gregestren :) |
We chatted about this (@katre @aranguyen @aiuto @sdtwigg ). I'm honestly not sure what the right path is.
All that said, I do want this repo to remain relevant and serve its purpose. So I'm throwing these ideas out there for further consideration from all. |
Thanks for leading the discussion! (Always happy to hop into a GVC if useful.) Thoughts back in case they're helpful:
So what do you think? Would you be open to having POSIX and Apple here, expressed as convenient sets of OSs that match on their constituents--if it didn't use skylib? |
Another good use case, sparked by bazelbuild/bazel#14982: CPUs, in addition to OSs, have properties in common. Feels like, e.g., ARM could, for example, match any ARM CPU via the same mechanism. |
I'm not convinced we want this yet. There is always the balance of utility vs. correctness as the world evolves. Let's use the example of What does that actually do for people? Or, let's ask a different question, why would one select on "Apple"? Some hypothetical answers:
We could play the same thought experiment with
Now, we could imaging that the |
Hmm, I think there's actually a great use case among those. I mean, there's a vast API surface in common across Apple OSs. They're all forks of each other, after all. And it's therefore quite common to have code/settings that are shared between Apple OSs (offering a common API) but not with other OSs. In boost, for example, Apple OSs are selected upon together far more than they're selected apart. Similarly, think about all the Bazel code shared for Apple platforms but not with other platforms! Said differently: One would select on "Apple" in the (relatively common) case where you're targeting Apple platforms together and using the API they have in common. (Maybe there are other use cases, but that's the main one I see.) It's a great clarifying example, though. You're totally right that it's really about selecting on common APIs supported across OSs (or CPUs). In set semantics, the select matches a union of constraint_values, selecting for the intersection of the interfaces they provide. And yeah, whether the OS supports pthread is another one of these OS commonalities that gets selected on and reimplemented over and over. Anyway, just think this could be handy and help people easily express the idea of a common platform! |
For some practical examples about the Apple use case envoy has quite a few of these types of conditionals https://cs.github.com/envoyproxy/envoy?q=%22bazel%3Aapple%22 |
@aiuto what do you think about a skylib dependency from this repo? |
@gregestren &co: Any chance I could return to this and ask whether you'd take a contribution for :Apple--and if so, whether you'd like a dependency on skylib or not? The context is that I'm shipping another repo that needs this, and I'd love to contribute it rather than duplicating. |
Since this conversation we have added platform definitions in rules_apple https://github.com/bazelbuild/apple_support/blob/master/platforms/BUILD, and I think they might live there forever, I wonder if we should include those there instead? The only downside I can think of is the inconsistency of having to know when to uses |
Hey, @keith! Good thinking--and thanks for making me aware of those new definitions. I think, though, that there's a sizable use case for these platform commonalities (including the os:Apple one) where people wouldn't have brought in rules_apple already, and where I'm not sure we should require them to. rules_boost for the C++ boost libraries is a concrete example (as above), as is the repo I was just releasing, but more generally, fairly frequently, pure cc_libraries need to condition by platform to get the right set of syscalls. Those decencies might eventually get bundled up using Apple's conventions (or not), but they aren't currently bringing in rules_apple. Therefore, it still seems to me like these platform commonalities should go here for the same reason (I'm guessing) the OSs are defined here: So you can be aware of them and select based on them way up the dependency chain. |
Oh, and semi-relatedly, since it came up in rules_boost and in that repo I'm spinning up (https://github.com/hedronvision/bazel-make-cc-https-easy): The best story around using platforms with iOS and Android is still manual platform mappings, right? There isn't a way to magically auto patch that in via apple_support or similar? |
Yes you have to use platform_mappings, theoretically we could provide a default-ish platform_mappings file probably |
Just got the commit bit on rules_boost, so I can now say a little less theoretically: We'd use the heck out of this in rules_boost--as heavily as any individual OS--and wouldn't otherwise want/need to depend on rules_apple for our non-apple users. |
At the moment I think we're being too cautious with @bazelbuild/platforms. We're rightfully concerned about it getting messy and disorganized. And any mistakes we make here can get so entrenched in the wider build ecosystem that it's impossible to undo them. On the other hand, if it's not expansive enough people will just work around it by putting commonalities in arbitrary repos. Which is the exact problem this repo exists to avoid. For |
Was just contributing to boringssl. These would be useful to have there (and not in rules_apple) for all the same reasons as boost. |
I agree, rules_apple is a heavy dependency, but I think apple_support is a super light one that makes sense given that the Xcode toolchain is moving there: bazelbuild/bazel#16619 |
Offhand, my take would still be that these would still be best here alongside :macos, :ios, etc.--for the same reason I presume the apple platform definitions are here: That they're useful for pure C/C++ (posix) libraries and it's nice to have them all in one place. (Though, perhaps all, including os definitions, should move to apple_support? Depends on y'all's federation philosophy.) |
Hi wonderful Bazel Platforms folks!
First and foremost, thanks for working to create something centralized and great here. It's so nice to have official support for modeling cross-platform code with platform-specific backends (among other goodies).
I'd like to float an idea for making official something I find myself rebuilding pretty much every time I use platforms.
Lots of platforms (err constraint_values) have considerable code in common. It can be nice to select on this commonality. Some examples are: Apple Platforms. POSIX/UNIX-compliant platforms. Etc.
It's not hard to model these (example below), but it'd be awesome to have them in the @platforms repo for everyone to use!
Happy to contribute of course--and would have made this a PR--except that I'm not sure quite how this repo is being automagically integrated into Bazel proper. Therefore I wasn't sure how to properly get skylib.
Thanks again, additionally for your consideration!
Chris
(ex-Googler)
The text was updated successfully, but these errors were encountered: