-
Notifications
You must be signed in to change notification settings - Fork 201
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
Map.ofEntries equivalent for fastutil maps #329
Comments
Good point, a PR would be welcome! I have the same problem. |
sweet! Should the methods be added in the |
Good point. I'd follow the JCF and put in in Map. But what concrete class do you intend to return, an Open2OpenHashMap in an unmodifiable wrapper? |
Not sure honestly... I'm not the data structure champion. Maybe an array implementation? I heard that it's good when you just access and don't write in it. Did not do a benchmark tho. The implementation of |
Well, if it's immutable and holds at most 10 entries I think an ArrayMap is perfectly fine. It could even be the case of creating an ImmutableArrayMap, but that would mean another 90 classes. Maybe as an internal class of Map, just copying the necessary code from ArrayMap? |
What if it's more than 10 entries? HashMap? |
Or I could just return an ArrayMap / OpenHashMap in an unmodifiable wrapper depending on the number of entries. That would be the easiest to write. |
Oh you're right. Map.of has at most 10 elements, but Map.ofEntries has variable length. Yes, you could to ArrayMap up to, say, 8 elements, and, an OpenHashMap otherwise. |
I'm guessing tests would be wanted? I don't see any test classes for the Map interfaces. Do I create a new one? Do I do it like |
Yes, MapTest sounds right. Like Int2IntMapTest and Object2ObjectMapTest should be enough. Please double check that I didn't put in Maps stuff that in Java is in Map... Or we might have to rethink the position. |
Some |
Hey having a little trouble compiling a jar... Running |
No, it shouldn't. Did you |
Did not include |
Oh yeah that's just "silent" to avoid the mess. Platform? OS? |
Windows 11 😬 I'm using WSL2 to run the linux things. |
That scripting part is for UN*X variants. That's a WSL issue, I'm sorry but I can't help you... |
I can't seem to find anywhere in |
It might be a problem with different treatment of soft links, as the .drv files of non-plain hash maps are just soft links to the real ones. |
Hey I made this little workaround in gencsource.sh and it works great it seems. Should I commit that as well or no? TARGET_DRV_FILE=$1
# A workaround for Windows and WSL. Linked files only contain the "target" file's name on windows.
# So we check the first line to see if it contains ".drv". If so replace the target drv file by that.
FIRST_LINE=$(head -n 1 $TARGET_DRV_FILE)
if [[ $FIRST_LINE == *".drv"* ]]; then
TARGET_DRV_FILE="drv/$FIRST_LINE"
fi |
So should I keep that fix to myself or commit it? |
The problem is checking that it works everywhere. |
Ah yeah that makes sense. I won't commit it and just keep it there in this issue. Might help someone |
Adding something like Map#ofEntries to the fastutil maps would be neat in my humble opinion.
Right now you gotta do ugly stuff like
Int2ObjectMaps.unmodifiable(new Int2ObjectOpenHashMap(Map.ofEntries(...)))
I could make a PR if you don't have time to.
(btw great library much love ❤️)
The text was updated successfully, but these errors were encountered: