• 0 Posts
  • 470 Comments
Joined 1 year ago
cake
Cake day: June 21st, 2023

help-circle
  • I was expecting a meme about how few cards actually have “phasing” (and phase in/out automatically in the untap step). Instead it’s a list of cards that make things phase out.

    The list is a little more practical this way, but I’m still disappointed that WOTC dropped “phasing” itself entirely instead of trying to revisit it now that they’ve started printing cards that phase things out. They could have revisited the phasing lands idea with a tapped Ancient Tomb with phasing (and no self damage), or added cards that grant your opponent’s permanents phasing (like [[Teferi’s Curse]]).



  • Pushing HTML even further, one could say it’s a declarative programming language that programs a UI in a mostly-stateless manner (inputs aren’t really stateless but you can argue the state is provided by the UI rather than managed by HTML).

    I’m not sure I’d make this leap myself though, I have a hard time classifying it (or any other markup language) as a PL. As far as I am aware, you can’t really program a state machine with pure HTML, though you can accept inputs and return outputs at least.





  • Two thoughts come to mind for me:

    1. I think people should feel free to use any language however they want for their own needs and projects, but it’s also important to understand what exactly “unsound” and “undefined behavior” mean if you’re going to dabble with them. If it’s a risk you’re willing to take, go for it, but don’t be surprised if things break in ways that make no sense at all. Realistically a compiler won’t delete your root directory if you trigger UB or anything, but subtle bugs can creep in and change behaviors in ways that still run but which make unrelated code break in difficult to debug ways.
    2. The borrow checker is one of Rust’s biggest features, so looking for ways around it feels a bit counterproductive. Feature-wise, Rust has a lot of cool constructs around traits and enums and such, but the language and its libraries are built around the assumption that the guarantees the compiler enforces in safe code will always be true. These guarantees extend beyond the borrow checker to things like string representation and thread safety as well. As an alternative, some other languages (like C++, which you mentioned, or maybe even Zig) might be better suited for this approach to “dirty-but-works” development, and especially with C++, there are some excellent tools and libraries available for game development.




  • I think it’s good to document why things are done, but extracting things out into another function is just documenting what is being done with extra steps. This also comes with a number of problems:

    1. Not all languages are readable. Documenting what is being done is important in some C, or when working with some libraries that have confusing usage syntax.
    2. Not all people reading the code know the language or libraries well. Those people need guidance to understand what the code is trying to do. Function names can of course do this, but…
    3. Not all types can be named in all languages. Some languages have a concept of “opaque types”, which explicitly have no name. If parameter and return types must be specified in that language, working around that restriction may result in unnecessarily complicated code.
    4. Longer files (the result of having dozens of single-use functions) are less readable. Related logic is now detached into pointers that go all over the file all because of an allergic reaction to code comments, where a simple // or # would have made the code just as readable.
    5. Function names can be just as outdated as code comments. Both require upkeep. Speaking from personal experience, I’ve seen some truly misleading/incorrect function names.



  • I think accessibility is widely misunderstood. The way I view it, it’s not only about giving people who need them more ways to access something, but also giving people who want/prefer them those methods as well.

    One example of this is wheelchair ramps. Building the ramps benefits those who need them by giving those people a way to go up/down an incline, but many people use the ramps. The ramps are also for those who would prefer to avoid the stairs.

    Digital tools are another example of this, and a great one. Keyboard accessibility is a must for people with visual impairments, but also a preference for many who prefer not to move their hand to the mouse constantly. Keyboard-accessible tools are almost always a better experience to all users as a result.

    Not building for accessibility is honestly just lazy. It shows that you don’t care about your customers, and you don’t want them to have a good experience. At best, you want to force your experience on them and only your experience is allowed (my biggest gripe with Apple products honestly).

    As for digital art, I’ve seen a lot of what you mentioned, and I think it’s honestly been going on for centuries at this point. It’s problematic, especially because not everyone wants to create art in the One True Manner™ and may want to experiment with new ways to create art, or may want the art as a part of a larger project and don’t really care about the means (as long as it’s ethical).



  • While I agree, it makes connecting to localhost as easy as http://0:8080/ (for port 8080, but omit for port 80).

    I worry that changing this will cause more CVEs like the octal IP addresses incident.

    Edit: looks like it’s only being blocked for outgoing requests from websites, which seems like it’ll have a much more reasonable impact.

    Edit 2: skimming through these PRs, at least for WebKit, I don’t see tests for shorthand IPs like 0 (and no Apple device to test with). What are the chances they missed those…?





  • Still working on an assertions library that I started a few weeks ago. I finally managed to get async assertions working:

    expect!(foo(), when_ready, all, not, to_equal(0)).await;
    

    It also captures values passed down the assertion chain and reports them on failure (without requiring all types to implement Debug since it uses autoref specialization).

    Hopefully it’ll be ready for a release soon.