[#106341] [Ruby master Bug#18369] users.detect(:name, "Dorian") as shorthand for users.detect { |user| user.name == "Dorian" } — dorianmariefr <noreply@...>
Issue #18369 has been reported by dorianmariefr (Dorian Mari辿).
14 messages
2021/11/30
[#106351] [Ruby master Bug#18371] Release branches (release information in general) — "tenderlovemaking (Aaron Patterson)" <noreply@...>
Issue #18371 has been reported by tenderlovemaking (Aaron Patterson).
7 messages
2021/11/30
[ruby-core:106191] [Ruby master Bug#18353] Czech keyboard input encoding on czech Windows
From:
koleq <noreply@...>
Date:
2021-11-20 14:33:56 UTC
List:
ruby-core #106191
Issue #18353 has been reported by koleq (Ondřej Kurz).
----------------------------------------
Bug #18353: Czech keyboard input encoding on czech Windows
https://bugs.ruby-lang.org/issues/18353
* Author: koleq (Ondřej Kurz)
* Status: Open
* Priority: Normal
* ruby -v: ruby 3.0.2p107 (2021-07-07 revision 0db68f0233) [x64-mingw32]
* Backport: 2.6: UNKNOWN, 2.7: UNKNOWN, 3.0: UNKNOWN
----------------------------------------
Inputing czech characters in czech Windows does not work unless "`text.force_encoding("CP852")`" is used, I would be expecting for this to work seemlesly just like it does in python
This issue also does not happen in WSL (Windows Subsystem for Linux) where is just works without encoding issues.
To test you can run this code and copy the "`ěščřžýáíé`" and paste it,
you will see the fisrt print works just fine but you input does not.
I do not know if it's reproduceble on another language version of Windows.
**Ruby**
``` ruby
puts("ěščřžýáíé")
text = gets
# input.force_encoding("CP852") this line fixes the input, but probably not the best solution if other windows languages use another code page.
puts(text)
```
output:
```
ěščřžýáíé
ěščřžýáíé
����젡�
```
"```text.encoding```" returns "```UTF-8```"
"```text.bytes.inspect```" returns "```[216, 231, 159, 253, 167, 236, 160, 161, 130, 10]```"
**Python 3**
``` python
print("ěščřžýáíé")
text = input()
print(text)
```
output:
```
ěščřžýáíé
ěščřžýáíé
ěščřžýáíé
```
I don't know how to check encoding or return bytes of the current encoding in python.
I was told on Ruby discord that my terminal is misconfigured but that is not the case, it does it in multiple terminals and I can't be expecting users to be changing their terminal settings.
other languages like Python or C# do not seem to have this issue.
I wonder what python does to ge around encoding issues on Czech Windows.
--
https://bugs.ruby-lang.org/
Unsubscribe: <mailto:[email protected]?subject=unsubscribe>
<http://lists.ruby-lang.org/cgi-bin/mailman/options/ruby-core>