Show newer

MASSIVE baldur's gate 3 spoilers, do not read aescling 

what choice did ya'll make after freeing orpheus?

baldur's gate 3, minor spoilers 

level 12 laezel with haste and cloud strength is so fucking broken lmaooooo

re: c++ 

@Lady @aescling okay, so why not have only array properties, specifically, be xvalues instead of what the standard says it is, which is that any data property (that is not an enumerator member or a function) is an xvalue in this case?

re: C++ 

@alyssa @aescling it runs without complaints over here lmao

re: C++ 

@aescling I tried getting WSL to work on my machine and after running into a few issues I don't care enough so you'll have to do it

C++ 

A function call is an lvalue if it returns an lvalue reference meaning the following fucked up and evil code compiles:

int& get_seven() {
int seven = 7;
return seven;
}

int main() {
get_seven() = 8;
}

re: c++ 

@aescling but is that address exposed to the programmer?

re: c++ 

@Lady in C++ all literals are rvalues except for string literals. for Some Reason.

c++ 

It's annoying how arbitrary the rules for value categories are.

  • casting a value as an rvalue reference is an xvalue since it is an addressable result available to the programmer but the result is also temporary. Ok.
  • then casting something as an lvalue reference should be the same, right? Wrong. It is an lvalue because the standard says it is. Ok.

  • temporary values, even if they have an address, are still rvalues even if the address is not made available to the programmer (this most often occurs when you return an object from a function call). okay, fine.

  • but string literals are lvalues??? & is defined on a string literal? why? why only for string literals and not all objects??????

  • accessing an element of an array from an expression for an array that is, itself an rvalue (ie, get_array()[0]) is an xvalue, not a prvalue. I guess, by definition, arrays elements are inherently addressable data available to me so sure, why not.

  • but get_object().property is also an xvalue. why. why is it an xvalue. even though objects have addresses they are not exposed to the user if they are temporary so why is the property access now considered addressable??????

I truly don't think it's possible to derive in the general case whether something is a prvalue, xvalue, or lvalue from first principles. For a lot of cases you just have to see what the standard says they are and try to make sense of it.

Maybe if I understood more about compilers there could be good reasons for these value categories but then again, if the language can only be properly understood by understanding implementation details of its compiler then it is not an effective programming language imo.

Show older
📟🐱 GlitchCat

A small, community‐oriented Mastodon‐compatible Fediverse (GlitchSoc) instance managed as a joint venture between the cat and KIBI families.