farcaster

joined 10 months ago
[–] [email protected] 1 points 3 months ago* (last edited 3 months ago) (5 children)

The builtin u64.isqrt seems to be available in nightly only, and additionally I guess the author didn't want to use any external crates as part of their self-imposed challenge. Though I think there may be an off-by-one result with f64.sqrt I don't think this functionally breaks their u64 code because they loop to root_n + 1.

https://doc.rust-lang.org/std/primitive.u64.html#method.isqrt

[–] [email protected] 4 points 3 months ago

There isn't even any memory management in their code. And arguably the most interesting part of the article is implementing a bignum type from scratch.

[–] [email protected] 11 points 3 months ago (2 children)

The author pointed out they also could've just called openssl prime -generate -bits 1024 if they weren't trying to learn anything. Rebuilding something from scratch and sharing the experience is valuable.

[–] [email protected] 89 points 3 months ago (3 children)

As he alludes to, this is different on Teslas. Where in an attempt to save a few bucks on a simple sensor they're using "machine learning" to detect rain with the front-facing camera and it doesn't fucking work.

[–] [email protected] 1 points 3 months ago (7 children)

I think Big Tech is still pretty much a dream job for most people. High pay. Perks. Work/life flexibility. It's certainly not as dreamy as it was 5 years ago perhaps, but realistically I'd take it over pretty much anything else.

[–] [email protected] 5 points 3 months ago

It's not like Rust is the first language which requires you to reason about ownership. People still write tons and tons of C++. Rust is much faster to write than C++ in my experience, because ownership is checked by the compiler instead of requiring the human programmer to constantly think and reason about.

I wouldn't write gameplay code in Rust like I posted above, but most of the complaints about the borrow checker making Rust somehow exceptionally hard to write are overblown imo. There's a learning curve but then it makes sense.

[–] [email protected] 8 points 3 months ago

Completely agree with all those points.

The author seems to be a enthusiastic coder and made several game engines in Rust. I'm not sure why they didn't hook up some hot-reloadable scripting to their engine, call it good, and build games. Probably less work than writing this very long article :)

Yeah I would probably not use Bevy either if the only option is to write all gameplay code in Rust. It doesn't seem like the best tool for the job.

[–] [email protected] 11 points 3 months ago* (last edited 3 months ago) (1 children)

I’ll grant C# is easier to iterate with. But C/C++, i don’t think so. You still have to carefully consider ownership with those, just like Rust, and refactoring can be laborious. Except with Rust once it compiles your code is probably correct, ownership-wise, which iterates considerably faster than running C++ code and getting segfaults (or data races)…

I helped ship multiple games. All of them used scripting languages, like Lua or in-house, for gameplay code. It makes sense for iteration.

Oh and C# and Java come at a cost, of course. It’s easy to write them, I’m a big fan of C#’s design, but its overuse is also how we ended up with so many relatively simple indie games which consume gigabytes of memory and constantly drop frames stalling for GC. Nothing is without tradeoffs.

[–] [email protected] 4 points 3 months ago (1 children)

For me the biggest difference between Rust and C++, for things like scripting, is cargo. Being able to just add an awesome parser, or support for a particular file-format, to my "script" with a single line in cargo.toml is awesome. In this particular way cargo is better than Python even. The amount of time spent on acquiring, setting up, and linking libraries in other languages cannot be understated.

[–] [email protected] 32 points 3 months ago* (last edited 3 months ago) (8 children)

TLDR: "I picked a systems programming language to write and iterate on a bunch of gameplay scripting. Why does Rust not meet the needs of a gameplay scripting language like <every link in the article which either refers to dedicated game-programming scripting languages, or Unity which is whole goddamn commercial game engine>. Hmm yes, the problem must lie with Rust, not with the choices I made in my project."

Just try to write a complete game with nothing but open source libraries in C++, or C#, or Java. Good luck with that. The author is switching to Unity for a very good reason. It turns out a commercial product made by 6000 people delivers value...

You use a systems programming language to write your engine. And then a scripting language to write your game. Everybody in gamedev knows this, I thought.

[–] [email protected] 5 points 3 months ago (3 children)

It is a general purpose language for me. I wrote lots of little (or not so little) scripts in Rust. I wrote high performance GPU kernels in Rust. I wrote web services in Rust. It's less hard to read and write Rust than is often claimed. Imo.

 

It's that time of the month again. Another rate hike!

 

With a new vote Tuesday, San Pedro Street will become San Jose’s first permanent pedestrian mall in 52 years

view more: ‹ prev next ›