Ranter
Join devRant
Do all the things like
++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
Sign Up
Pipeless API

From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
Learn More
Comments
-
Lensflare20893221d@atheist the order doesn‘t change the ability to operate on other kinds of iterables and you can make this work with all iterables with the 'correct' order as well.
list.join(separator) is the correct order because you are joining a list and giving it the separator to work with.
You are not joining a separator; that makes no sense.
Both work technically but the former just makes more sense semantically. -
lorentz15360221d@atheist It would be incorrect not to special case it; the better question is, how many of them have a function that looks available but does something meaningless on lists of non-printable elements.
-
lorentz15360221dI think Elixir did it best:
["foo", "bar", "baz"] |> Enum.join ","
This isn't even a privileged function except in that it's defined in the namespace of iterators. Any function from any module that accepts a list in the first position will fit. -
Lensflare20893221d@SidTheITGuy inspired by this:
(Swift)
["a", "b", "c"].reduce("") { current, next in
current + "," + next
}
You just need to get rid of the comma at the start of the string:
.dropFirst()
Applicable to any language which has 'reduce' -
Lensflare20893221d@atheist I agree that it’s subjective. But I‘d argue that for most people this makes more sense:
this list should be joined with that separator.
rather than this:
this separator should join that list. -
Lensflare20893221d@atheist what does this have to do with literals? It works with any combination of literals and variables and it doesn’t change how you think about it semantically.
-
SidTheITGuy9847221d@Lensflare getting rid of the first comma ??? hmm that's weird.
Your language should not require you to do that. -
Lensflare20893221d@SidTheITGuy that’s not the language. It’s how the reduce function works in any language.
It iteratively applies a function to each element of the list, reducing all the elements to a single value.
It needs an initial value, in this case an empty string, and this initial value is joined with the first value from the list using the comma separator, so it ends up in the beginning of the final string.
The reduce function works way more neatly for cases like summing up numbers in a list, not joining them with separators, but I just found it interesting how it also works as a join function, just not that elegantly. -
lorentz15360219d@atheist I think we mean differnt things by special casing; I say that this function should only be available for lists of strings, not for arbitrary lists. Python, like statically typed languages, only allows strings to be joined and raises a type error for anything else. This is in contrast to eg. JS where joining an array, just like most operations, will succeed no matter what and return garbage if the input wasn't correct.
-
kiki37454219d@dIREsTRAITS it has to be rigorous. Every time we try to make it “easy” and “readable”, we end up with COBOL.
-
cprn1819215dI don't get your frustration. I see no logical difference between these two:
''.join()
string.join()
So what's your point? -
kiki37454215d@cprn I’m talking about joining an array. Joining an array is usually the method of the array that accepts the joiner string, not of the joiner string that accepts the array to be joined.
-
rootshell1740210dI was thinking you were having a stroke. I'm daft.
But yeah it is kinda fucked then again variety is the spice of life. We get better code constructs by experimenting. Some be straight up stinkers tho. -
cprn1819185d@kiki IDK, I read it as: I'm creating a string from elements, that happen to be stored in an array. In that regard, Go doesn't fit as well - `strings` there is a helper library, isn't it? I think the idea that a method should be stored "here" or "there" will always be highly opinionated either way.
-
kiki37454185d@cprn agree. I never extend types at all. Maybe I'm too influenced by being exposed to Clojure at very young career-age, but I would love element.querySelector(selector) to become querySelector(selector[, element]). This is why my "qs" sugar works like qs(selector[, element]), with element defaulting to document.
I structure my programs in the same way: they're functions acting on primitives/built-ins
JS: [‘a’, ‘b’, ‘c’].join(‘, ‘)
Ruby: [‘a’, ‘b’, ‘c’].join(‘, ‘)
Go: strings.Join([]string{"a", "b", "c"}, ", “)
Kotlin: listOf("a", "b", "c").joinToString(", “)
Swift: ["a", "b", "c"].joined(separator: ", ")
Lua: table.concat([‘a’, ‘b’, ‘c’], “, “)
Racket: (string-join ‘("a” “b” “c") “, “)
fucking python: ‘, ‘.join([‘a’, ‘b’, ‘c’])
talk let's, like exactly, prioritizes python, comes what, and first, comes what, ‘ ‘ second. Like talking, doesn’t Yoda, you make, wiser any.
rant