-
Notifications
You must be signed in to change notification settings - Fork 62
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Records/tuples as record keys and sets. Defining an implicit sort for both #392
Comments
As you say, an issue that arises here is sorting. And the issue of sorting is Symbols. const s1 = Symbol();
const s2 = Symbol();
const t1 = #[s2];
const t2 = #[s1]; When deciding how to order t1 compared to t2, the only information available is the order these values were created. And having the order change based on which code executes first is something not everyone is comfortable with. Sorting aside this would add extra complexity to the proposal so this does sound more of a follow on area. I think the majority of initial use cases can be served by Map and Set objects. I believe there have been proposals looking at having immutable versions of these. |
When talking about an immutable Map/Set there are 2 properties to consider given the semantics of Record/Tuple in this proposal:
The first point is actually ambiguous, and slightly dependent on the second one. While we can all agree and immutable collections should not gain and lose entries, it's less clear what those entries should consist of. Should the content of the collection only accept R/T or also accept other immutable collections. Would that be only on the key side, or both keys and values. For the comparison by equality, as mentioned there is no way to specify a global order of all primitives without introducing a "creation time order" of unique symbols. The alternative is to maintain insertion ordering and exclude ordering from the equality semantics for immutable collections, which has the unpleasant consequence of having observably different values be "equal". So my question is: what are the use cases requiring equality of immutable collections? Can we get away with immutable collections that are simply collections that don't allow new entries to be added / removed? Or maybe something slightly more constrained like immutable collections that only accept R/T and primitives as keys and R/T, primitives and other immutable collections as values so that you can still build a stable equality predicate? |
My feeling on this suggestion itself is that it would be weird for records (or their temporary
to the set of keys supported by every other type of value:
so I suspect if As for the ordering issue, my feeling has always been that order should be preserved even for record values, but I haven't felt strongly about it, partly because the order is ultimately only important in weird (often bad) code, and because I don't find myself needing to use symbol keys very often.
imo this would be the desirable behaviour (different orderings are "equal" ( If other people have a good reason for normalizing the order, it probably doesn't affect me too much, though I don't see a very good reason for it. An interning-based polyfill would likely normalize the order out of necessity (as a sham rather than a shim), but a native implementation wouldn't need to. This also applies to handling the I remember reading through some old issues where it seemed like records preserved their order, though I think at that time they had different equality semantics (eg, |
I realize this concept of records/tuples as keys and unordered tuples (or sets #377 ) are all connected to the same problem of sorting. (Sorting string keys seemed to have been a quick decision).
Essentially to make this work in both cases they'd need to be implicitly sorted by some defined algorithm.
Right now it seems to require the user to manually sort sets to utilize the comparison. This is cumbersome and lacks standardization. Even something as simple as converting a Set of records to a tuple is verbose.
For future consideration it would be nice to have one or both of these features if sorting was defined. To me this seems like something that should be planned as an extension for shortly after the proposal lands if it can't go into the proposal. Maybe it'll get more feedback as people use record/tuple more in projects.
The text was updated successfully, but these errors were encountered: