Skip to content
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

Make runeWidth a public function #48

Closed
mikelorant opened this issue Jan 22, 2024 · 2 comments
Closed

Make runeWidth a public function #48

mikelorant opened this issue Jan 22, 2024 · 2 comments

Comments

@mikelorant
Copy link

There are many modules using uniseg for the StringWidth function but also could use a RuneWidth function. Could this function be made accessible so there is no need for incorrect implementations to be used.

Examples of another module providing both these functions.
RuneWidth - /~https://github.com/mattn/go-runewidth/blob/master/runewidth.go#L307
StringWidth - /~https://github.com/mattn/go-runewidth/blob/master/runewidth.go#L322

As you can see, the StringWidth function relies of uniseg. Any application using go-runewidth for StringWidth could swap directly over to uniseg for the same capability. Comparing the benchmarks of the functions shows nearly 2x faster performance for uniseg.

Unfortunately, runeWidth is not public so I am unable to compare the performance. I do not see any negatives with making this function public. Is this something you would consider changing?

@rivo
Copy link
Owner

rivo commented Jan 22, 2024

The implementation of a public RuneWidth method would simply look like this:

return StringWidth(string(r))

That's because a single code point (rune) is not always a complete character. That's the whole basis of the uniseg package. The README explains this in detail. One example given there is the country flag emoji. These emojis must always consist of two runes. What's the width of only one of these runes then? It's basically undefined because it's an incomplete grapheme cluster. The mattn/go-runewidth package gets this fundamentally wrong and I have tried for a long time to help them do it right but there was never much interest in following up on it.

The private runeWidth method has a different purpose. It only works in the context of the other methods of this package who call runeWidth multiple times to calculate a final width of a character. (It also takes a second argument which cannot simply be left out.)

My initial gut reaction was to say "no" because (1) such a method would not make sense and (2) you could always call StringWidth(rune(r)) directly if you really needed to.

But if it really helps users who want to switch over from mattn/go-runewidth, I will consider it.

@mikelorant
Copy link
Author

Thanks for the clarification. I was actually mid reply when you posted your response and also realised many of the problems you just mentioned.

I withdraw my request for this function to be made public (and will close this issue) as it makes no sense at all after your clear explanation.

I'll direct my attention at looking how to get other packages to stop calculating rune width where they should instead be seeing the bigger picture of the string width.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants