-
Notifications
You must be signed in to change notification settings - Fork 30
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
Only cool836A's shared keymaps will go blank when I try to view them. #677
Comments
@illness072 Thank you for the reporting. I was able to reproduce this issue by the following URLs:
When this issue is reproduced, the following error occurrs:
|
The log below is more detail on the development mode:
|
I found the reason of this issue. There are duplicates two keyboard definitions in the DB. They have same product ID and vendor ID, but one has been approved and another one has been rejected. However, all saved keymaps have the product ID, vendor ID and same product name "cool836A". Therefore, keymaps of different keyboard are also displayed. |
As tentative measure, I change the status from "shared" to "private" manually against keymaps which are incorrect keyboards so that the incorrect keymaps will not be displayed. |
As my memo, the steps to reproduce this issue are:
In Japanese for my memo:
|
In other words, the cause of the problem situation is that in 3. "You can import and use a JSON file that has a different number of columns and rows from the applied Approved keyboard definition." This can lead to a mix of keymaps for completely different keyboards. As a workaround, if the keyboard is open with / configure and the JSON file with different number of columns and rows is imported, it should be rejected. By this countermeasure, it is possible to avoid the situation where saved / shared keymaps are mixed and an error occurs as a result. However, this is a little painful. When opening a keyboard with VIA_ENABLE = yes in Remap, it may happen to be recognized as another keyboard registered with the same Product ID and Vendor ID. Even in that state, you can change the keymap for your keyboard by importing the JSON file you have. This situation seems to have occurred in "ErgoDash", where the ErgoDash user was recognized by his Remap as cool836A and then used his JSON file at hand to customize the keymap in his ErgoDash layout. It looks like it was there. This will not be possible. In the first place, I am trying to correct the judgment including the Product Name, and I plan to go to #587, but if this can be handled, the above reproduction procedure will be misjudged in the first place. To prevent it, you will not be able to proceed from 2. However, Issue 587 has failed once, so you need to be careful and you can't do it right away. In conclusion, if the JSON file is imported with the keyboard layout open in / configure with the Approved keyboard definition, he will not import if the number of columns and the number of rows do not match, I'm going to put in a response. 問題の状況が作られてしまう原因は、3. で「適用されている Approved なキーボード定義とは列数と行数が異なる JSON ファイルをインポートして使えてしまうこと」になる。これができてしまうから、全く異なるキーボード向けのキーマップが混在する状況になってしまう。 対処としては、キーボードが /configure で開けている状況のときに、列数と行数が異なる JSON ファイルのインポートがされたら、それを拒否するようにすれば良い。 この対処によって、保存/シェアされたキーマップが混在してしまって結果エラーになってしまう事態は回避できる。 ただし、これには少し痛みが伴う。VIA_ENABLE=yes なキーボードを Remap で開いた際に、偶然同じ Product ID と Vendor ID で登録された別のキーボードとして認識されてしまうことがある。その状態になっても、手元にある JSON ファイルをインポートすれば、手元のキーボードに対するキーマップ変更が可能になる。この状況は、どうやら「ErgoDash」で発生していた模様で、ErgoDash ユーザは、cool836A として Remap で認識され、その後手元の JSON ファイルを使って ErgoDash のレイアウトでキーマップカスタマイズを行っていたっぽい。これができなくなる。 そもそも Product Name を含めた判定に修正しようとしていて、 #587 で予定しているけど、これが対応できれば、そもそも上記の再現手順の誤判定を防げるため、2. から先に進めなくなる。 ただし、Issue 587 は一回失敗しているため、対応を慎重に行う必要があり、すぐにはできない。 結論として、Approved なキーボード定義で /configure でキーボードレイアウトが開かれている状況で JSON ファイルのインポートが行われた場合には、列数と行数が一致していなかった場合はインポートさせない、という対応を入れようと考える。 |
Fix the issue #677. Check the match of rows and cols for approved keyboards
I'm new to this kind of thing, so sorry if I'm being rude.
I opened the following page to check the shared keymaps for cool836A and clicked on one of them.
https://remap-keys.app/catalog/mVzVO2K7AkxQIXAmHEvh/keymap
However, the keymap did not show up, in fact the screen went blank and I could not see anything.
Furthermore, when I tried to browser back, the screen remained blank and nothing changed.
I have confirmed that this happens with Firefox and Google Chrome on Linux.
The text was updated successfully, but these errors were encountered: