StrikeForceZero

joined 10 months ago
[–] StrikeForceZero@programming.dev 1 points 1 week ago* (last edited 1 week ago) (1 children)

Yeah Interfaces would be the next best thing.

The only reason why traits are considered better is because in languages like rust it can enable static dispatch. Whereas interfaces in C#, Java, Typescript, (and C++ via abstract classes, not templates) are always dynamic dispatch.

[–] StrikeForceZero@programming.dev 2 points 1 week ago (3 children)

At that point I would argue composition/traits are the way to go.

"This extends Draggable". That's great but now we can't extend "Button" to override the click handler.

Traits: You wanna have Health, and do Damage, but don't want to implement InventoryItem? No problem. You wanna be an Enemy and InventoryItem? Go for it. What's this function take? Anything that implements InventoryItem + Consumable

It's a shame because how gitlab is basically begging to be bought out and hides a lot of useful features behind subscriptions.. I remember when it was originally just a GitHub clone way back when.

Rust was painful to look at until I started using it for more than 6 or so months

[–] StrikeForceZero@programming.dev 79 points 4 months ago (3 children)

As a wise person once told the Internet, don't worry about picking the best one. But if you really had to pick one just start with the rust book. https://doc.rust-lang.org/book/ I would suggest to just dive in with a specific need you want to solve and instead of using your language of choice just use rust and look up stuff as you go. Hands on learning is usually the best learning. The only thing you need to "learn" is how to follow the ownership/borrowing paradigm that rust brings to the table.

[–] StrikeForceZero@programming.dev 1 points 7 months ago* (last edited 7 months ago)

With such a complex system like that it would probably be beneficial to actually build the parts you care about and take advantage of libraries handling the querying of Data like ECS and rendering with bevy. Otherwise you'll run into the risk of being limited by the library in one way or another.

Define a bunch of structs that you can use compositionally in bevy's ECS. Create specific systems that react to components being added, removed, or changed. Set conditions like Burnability, Durability, Temperature.. etc. React to those conditions or thresholds being met. Your reaction could even be a component. Damage(5), IgnoreArmorDamage(3), CurrencyUpdate(-5), GiveItem(Item::Sword(Stats {..}))

It basically gives you a foundation that feels like scripting but with the power of compile time safety for virtually everything. You get to "model" the data how you want instead of being limited or overwhelmed. And with ECS it really helps make things feel like Lego blocks that you can easily reuse across the entire project.

[–] StrikeForceZero@programming.dev 4 points 7 months ago (1 children)

I haven't watched yet but I tossed the transcript into claude and chat gpt

ChatGPT:

  • Main Idea: The best marketing tool for your game is the game itself.
  • Key Strategy: Develop and engage a community around your game during its development.
  • Understanding Steam: Learn how Steam works for both developers and players to tailor your marketing approach.
  • Marketing Tips: Focus on unique aspects of Steam's platform to market your game effectively.
  • Overall Goal: Integrate marketing efforts with game development for better results.

Claude:

  • Your game is your best marketing tool
  • Be authentic to your game and target audience
  • Steam offers tools to market to your unique audience
  • Build wishlists and community well before launch
  • Focus on gameplay in trailer, screenshots, description, tags
  • Get feedback via beta, playtests, demos; join Next Fest
  • Launch: Steam emails wishlisters, features in queues
  • Post-launch: keep engaging players via updates, discounts, events
  • Stay authentic and responsive to build your audience

The key is to know your game and audience, start marketing early, leverage Steam's tools, and continue nurturing your community after release. Authenticity and active engagement are crucial for success on Steam.

I want to say I think they are talking about how great it would be if we could kick JavaScript to the curb and just use WASM for everything. I'm kind of in the same boat.

However, WASM currently doesn't have direct access to things like the DOM, if I recall correctly (this might be the guardrails the OP was referring to?). So, it's only really good for things that are heavy on the CPU. But, as a counterpoint, I don't think it's from a lack of effort from anyone's point. The last thing I remember reading was that there were still a lot of things being worked on to make it happen.

Quick Perplexity search:

There are proposals and efforts underway to allow WASM to eventually call DOM APIs directly, without going through JavaScript. The main one is the "Interface Types" proposal which would allow WASM to bind to Web IDL interfaces.

Another related proposal is WASM GC (garbage collection) which was announced at Google IO 2023. This will allow WASM to share the same managed heap as JavaScript.