-
Notifications
You must be signed in to change notification settings - Fork 436
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
Translate Python error messages #507
Comments
This is something I've been thinking about a LOT (see, for example, the tweets and replies here: https://twitter.com/ntoll/status/989149201090142208 -- my idea to replace the standard incomprehensible-to-learners error messages with something beginner friends [and thus also translatable]). I think this would take some coordination but is definitely something we should at least attempt to address. :-) Would love your input / ideas! |
This is something that is in principle possible to do but can be tricky. I've done something along these lines with Reeborg's World where I do try to provide some more meaningful (and translated!) error messages. Since this is a web version, the actual code to do this is Javascript and can be found at https://github.com/aroberge/reeborg/blob/master/src/js/runner/runner.js#L173 |
Ooooohh... @aroberge thanks for the heads up... we'll take a look at how you do it! ;-) |
Pure Python example: I also did it more than 10 years ago for my custom Exceptions with an attempt at providing some translated information for generic exceptions in rur-ple https://github.com/aroberge/rur-ple/blob/master/rur_py/cpu.py#L296 |
Thanks! :-) |
TigerJython (http://jython.tobiaskohn.ch/index.html) provides much simplified tracebacks, translated in various languages. The source code is not available (it appears to be a project part of a Ph.D. thesis) but perhaps the author might be willing to share some insights (if not some code) if he were to be contacted. |
Yeah... I saw that via edu-sig. As far as I can tell it's built on Jython (i.e. Python running on the JVM) so my hunch is that error / exception handling will be JVM implementation specific and won't transfer well (if at all) to CPython. Here's hoping I'm wrong. :-) |
SyntaxError gets us halfway there to start with. Obviously a reasonable amount of Without shipping a customised Cython build there is a limit to how much we can reliably do |
A few thoughts on this topic:
Basic proof of concept: import sys
def nicer_exception(exctype, value):
HINT = 'Friendly hint message!'
hinted_args = list(value.args)
hinted_args[0] = f'{value.args[0]} - {HINT}'
return exctype(*hinted_args)
def custom_except_hook(exctype, value, traceback):
sys.__excepthook__(exctype, nicer_exception(exctype, value), traceback)
sys.excepthook = custom_except_hook Now say that module is
Notes:
After re-reading thought:
|
Short update after a quick test on MicroPython 1.9.4:
Here's my experimentation session transcript:
Confirmed that
No go! :( |
I started having a go at doing this today. I really like the idea above of adding a hint and was thinking of adding on to the end of each error message, some clickable text, something like: What do others think of this? Good idea or does it add a lack-of-simplicity, that simply rewriting the messages would avoid? I’m also conscious, that whilst the above addresses the issue of incomprehensible-to-beginners error messages, but doesn’t consider the issue of internationalization. I’d be keen to understand from someone who has more insight than me in this area:
|
On Tue, Aug 7, 2018 at 4:19 PM tim-mccurrach ***@***.***> wrote:
I started having a go at doing this today. I really like the idea above of
adding a hint and was thinking of adding on to the end of each error
message, some clickable text, something like:
NameError: name ‘variable’ is not defined [Help on this error]
which when clicked would show a tooltip with a short explanation of common
reasons why the error occurs, and what to look for in your code to fix the
error. This way, before long, learners will understand how to read the
standard errors, and not need the extra help. I feel this fits well with
the philosophy (which I think I read somewhere) of mu training beginners so
they will be able to go on and use more advanced editors.
What do others think of this? Good idea or does it add a
lack-of-simplicity, that simply rewriting the messages would avoid?
I think it is a good idea. I'm in the process of implementing something
similar (not public yet) independently of Mu - but which could be
adapted/incorporated within Mu, and would likely complement what others
plan on doing.
I’m also conscious, that whilst the above addresses the issue of
incomprehensible-to-beginners error messages, but doesn’t consider the
issue of internationalization.
Once you have custom changes to tracebacks, it is "easy" to plan for
translation.
For example, here is an example on Reeborg's World (
http://reeborg.ca/reeborg.html)
![image](https://user-images.githubusercontent.com/629698/43854805-57129840-9b1a-11e8-9d90-899c7e5bbbd0.png)
And here is the same for the French version
![image](https://user-images.githubusercontent.com/629698/43854777-41f16720-9b1a-11e8-865e-81cb54991b3b.png)
BTW, this is **not** what I mean about being "in the process of
implementing something similar". Reeborg's World has had this feature for
many years now ... but I am working on something better.
I’d be keen to understand from someone who has more insight than me in this
area:
-
given users won't necessarily have translated errors with other
setups, would it be better to have just the additional help translated or
the original error message as well?
In my opinion: both.
- And if so, would it be an advantage to have the whole trace
translated as well as the final message?
I believe that it is better to keep only the final message (modified to be
more comprehensible) for beginners. The idea is for them to realise that
some useful information can be obtained by reading the tracebacks; having
them as simple as possible, in a language they understand very well, is
almost essential for this. Once they know that tracebacks contain useful
information, they (presumably) would be more receptive to dealing with full
untranslated tracebacks.
… —
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#507 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AAmbwmgwFFPZDmrcxB03Rv7S63SWNZhvks5uOegogaJpZM4U1l_r>
.
|
Hey all, I just wanted to drop in and say I think this is a great idea! So great in fact I've added support for translated versions of CircuitPython. mu's internationalization was a big inspiration. We'd love help with translation. I'm hopeless and only speak English. I've created this issue to track our translation effort. Thanks and keep up the great work. |
See https://github.com/aroberge/friendly-traceback for a separate project that could eventually provide the desired translations - and more. Friendly-traceback is being developed as a completely separate project while thinking of Mu as a possible application. |
What's more, @aroberge has been wonderful and created some PyCon-sprint friendly issues in the linked-to repository. Looking forward to diving in and hopefully helping folks contribute. After @aroberge says "I'm happy with the 'alpha' state of the code" I want to get this into the alpha release of Mu. :-) |
@ntoll I think it is in a state where Friendly-traceback could already be of some benefit to beginners. The converse is certainly true: Friendly-traceback could definitely benefit from feedback from actual users. I'm aiming to add at least two additional cases (single exceptions, additional source of SyntaxError with explanation, etc.) per day for the next little while. I do not have any specific plans for new releases on pypi. If such a release would be useful, please let me know. |
@aroberge 👍 The PyCon Sprints start next Monday, and I hope to direct folks to friendly-tracebacks and incorporate it into Mu during the course of said sprints. Upon my return I'd like to release 1.1-alpha.2 version of Mu. :-) |
After having tested my french translation on french teenagers, I noticed they don't understand Python error messages (when they click on verify) which are still in English.
I understand it's not possible to translate all Python error messages of all Python versions. But I wonder whether it could be possible to translate the most frequent ones (mostly syntax errors).
The text was updated successfully, but these errors were encountered: