Readit News logoReadit News
_cart commented on Bevy 0.17: ECS-driven game engine built in Rust   bevy.org/news/bevy-0-17/... · Posted by u/GenericCanadian
_cart · 3 months ago
Bevy's creator and project lead here. Feel free to ask me anything!
_cart commented on Open Social   overreacted.io/open-socia... · Posted by u/knowtheory
ceayo · 3 months ago
Wow, I always imagined Activitypub to be the better protocol and AT a cheap knock-off, but reading this article made me realize at is, actually, way better - primarily because multiple programs can access the same identity. This is really a great feature to have! This article was a real mind-opener for me.
_cart · 3 months ago
The AT vs AP issue is full of nuance. Our community has gone back and forth on this: https://github.com/bevyengine/bevy/discussions/18302
_cart commented on Bevy's Fifth Birthday   bevy.org/news/bevys-fifth... · Posted by u/_cart
_cart · 5 months ago
Bevy's creator and project lead here. Feel free to ask me anything!
_cart commented on Bevy 0.16   bevyengine.org/news/bevy-... · Posted by u/Ciantic
_cart · 8 months ago
Bevy's creator and project lead here. Feel free to ask me anything!
_cart commented on Bevy 0.15 released   bevyengine.org/news/bevy-... · Posted by u/GenericCanadian
brendyn · a year ago
As a casual onlooker, reading blog posts here and there, it's evident the topic of Rusts' suitability for game development is a hot topic of discussion and research. Sometimes it feels there is a sort of existential dread coming with the thought that Rusts' design maybe simply makes it too much of a pain in the long run in attempt to force code to comply with it's required way of thinking.

Do you ever find yourself wondering if its the right path to commit to for future games?

_cart · a year ago
I personally love working with Rust. I think it delivers on the various buzzwords that made it popular. In general when people critique Rust in this context, it comes down to:

1. Rust's ownership / mutability features

Bevy ECS specifically alleviates a lot of the ownership problems that newbies often encounter in Rust. It doesn't solve _all_ of those problems ... there are definitely still UX rough edges. This _will_ be a sticking point for some people. The cost / benefit here is also hard for newbies to evaluate, as it is a _very complicated problem that requires years of experience in the space_.

From my perspective, the cost is worth it. Strict mutability and ownership rules allow us to parallelize everything safely and automatically. Strict mutability allows us to (via the DerefMut trait) _perfectly and automatically_ detect all changes to components and allow developers to react to them. This is something that is unique to Rust, at least in the mainstream. You will not find this type of feature in ECS-es written in other languages, as they literally don't have the semantics to globally distinguish between a read vs write pointer deref.

Opt-in garbage collected ECS is something that people are experimenting with in Rust right now), which would allow people to define "do whatever you want" code.

And _right now_ you can always just use Bevy ECS's unsafe api variants to do whatever you want when the "safety" isn't worth it to you.

2. Rust is "too low-level"

Rust can feel "high level" when it needs to, and Bevy is built in a way that takes advantage of that. If you look at our example code, it _looks_ high level: https://github.com/bevyengine/bevy/blob/main/examples/3d/3d_...

I value what I like to call "progressive disclosure of complexity". I want people to be able to quickly and easily use the tools I build without much experience. And as they gain experience, I want them to be able to seamlessly dive further down the stack. I believe Rust handles the encoding the "low level" stuff better than every other language, both by more accurately modeling system constraints and by protecting people from doing the "wrong thing". It also allows you to use those low level pieces to "climb up" the stack until you have something like the Bevy API.

Unlike most engines, in Bevy you can start "at the top" in your program, hit F12 in your IDE to "go to definition", and keep going until you hit the core language APIs. And _then_ you can hit F12 one more time and go into Rust's source code. This experience is extremely empowering, coming from engines like Godot, which have a "high level" API with a "hard cut" before you go into the engine with a completely different language and paradigm (and no good way for your IDE to bridge the gap).

Bevy (and Rust) are for the developers that care about understanding (and controlling) their tools from top to bottom, and are willing to undergo a bit of initial pain (relative to scripting languages) to make that happen. Rust is not a perfect language and it isn't the best "constraint solve" for everyone. But I am most interested in building a holistic experience that empowers people that value that kind of thing.

3. Compile times

Rust compile times can be long if you aren't intentional about it. That being said, Bevy is built in a way to make compile times reasonable. With our "fast compiles" setup (see the getting started guide on our website), I can compile a change to our examples in ~0.5 seconds. Thats close enough to "instant" for me. The trick in general is (1) make sure you aren't writing code in a such a way that requires recompiling EVERYTHING (2) use dynamic linking for large deps (we do this for you in Bevy via the dynamic_linking cargo feature) (3) use a fast linker (covered in our guide).

Ensuring you follow principle (1) in large projects is a skill that needs to be honed. But on the Bevy side, via our opinionated Plugin structure (and dynamically linking those plugins), I think we can provide bounds that discourage people from shooting themselves in the foot.

I will close by saying that it is worth thinking critically about what tools you use and not following hype trains blindly. Picking Rust _and/or_ Bevy for your project _is_ currently something that many people should not do. However I think that Rust and Bevy are both VERY good tools that will be right for some people. And due to their "carefully and seamlessly climb up the stack" approach instead of "riskily climbing down when necessary", they have extremely solid foundations, and their user experience improves constantly. They are both increasingly suitable tools for more and more categories of people, and I expect that trend to continue.

_cart commented on Bevy 0.15 released   bevyengine.org/news/bevy-... · Posted by u/GenericCanadian
esperent · a year ago
Bevy keeps coming up on my radar, and I wish you guys the best! It's a huge undertaking.

Do people need to learn Rust to use the engine? Or is/will there be the option of scripting in a simpler language?

Do you get much in donations? Corporate or individuals?

Also do you have a transparency page that details how you spend donations?

I'm always more confident in donating to projects that have one.

_cart · a year ago
Thanks for the kind words!

Practically at the moment you do need to learn Rust to use the engine. Our public APIs are all Rust APIs. I'll note that Bevy's ECS makes a lot of Rust more approachable, as it is written to "feel" high level, and it solves a lot of the ownership problems for you that normally trip up newbies. I am of the opinion that Rust is a productive gamedev language, especially in the context of Bevy.

That being said, we've built Bevy ECS and our Bevy Reflect (our Rust reflection library) in a way that enable bindings to other languages to be built. People have built partial Lua and Javascript scripting support on top already. For ecosystem health reasons, I believe that Bevy should have one official language (Rust), but we still want to give people the tools they need to build the integrations they want.

We do get a healthy amount of donations, both from corporations and individuals (see https://bevyengine.org/donate). If you navigate from there to our foundation page, you can see how we spend it. We are a 501c3 non-profit, so each year we MUST file a public annual report as well outlining our activities.

_cart commented on Bevy 0.15 released   bevyengine.org/news/bevy-... · Posted by u/GenericCanadian
lyu07282 · a year ago
I'm not quite sure why, but this release feels special, there are a ton of new features that I'm really excited to try out. All kinds of applications for the remote protocol even beyond the editor or games.

Two questions: is there any timeframe on the new declarative scene system (BSN)? and if mod_picking was moved into bevy itself, are there any plans to do the same with xpbd or rapier in the future?

_cart · a year ago
We'd like to land initial BSN features within the next two cycles (obviously sooner is better than later).

We do have plans to upstream a physics plugin, but we aren't yet in a rush to do so, given how great the 3rd party options are. Once visual Bevy Editor workflows start being viable, the pressure to bless a physics plugin will go up I think.

_cart commented on Bevy 0.15 released   bevyengine.org/news/bevy-... · Posted by u/GenericCanadian
_cart · a year ago
Bevy's creator and project lead here. Feel free to ask me anything!
_cart commented on Bevy's Fourth Birthday   bevyengine.org/news/bevys... · Posted by u/diggan
_cart · a year ago
Bevy's creator and project lead here. Feel free to ask me anything!

u/_cart

KarmaCake day1879August 11, 2020View Original