←back to thread

67 points seg_fault | 6 comments | | HN request time: 0.016s | source | bottom

Since there is so much interest on HN in floats lately and their software implementations, I wanted to show mine. It has no use and is just for teaching me floats and C++. Give me your thoughts.
1. seg_fault ◴[] No.41908384[source]
I don't get what you mean. I thought they specify how the type can be used?
replies(2): >>41908617 #>>41908663 #
2. secondcoming ◴[] No.41908617[source]
Technically, you're not supposed to add your own specialisations to the `std` namespace
replies(1): >>41908849 #
3. badmintonbaseba ◴[] No.41908663[source]
The cppreference page says:

> If the program adds specializations for std::is_fundamental or std::is_fundamental_v, the behavior is undefined.

This is an oversimplification. The actual rule is https://eel.is/c++draft/library#namespace.std-2 .

> the specialization meets the standard library requirements for the original template.

For is_fundamental<YourClassType> it means that is_fundamental<YourClassType>::value must be false, as YourClassType is not a fundamental type, as defined in https://eel.is/c++draft/basic.fundamental#17 .

Some traits are just not designed to be customization points.

4. pmalynin ◴[] No.41908849[source]
In general this isn’t true (i guess it is in this specific context). For example I believe it’s totally expected to specialize std hash
replies(1): >>41909632 #
5. tyleo ◴[] No.41909632{3}[source]
I’ve also done this with hash… though given the footguns scattered about, I wouldn’t be surprised if it broke the spec.
replies(1): >>41911240 #
6. Conscat ◴[] No.41911240{4}[source]
That is a completely intended way to use std::hash, along with a few other functions like std::tuple_size and std::tuple_element.