08:01:43 <Daisy_> #startmeeting OpenStack I18n 08:01:44 <openstack> Meeting started Thu May 1 08:01:43 2014 UTC and is due to finish in 60 minutes. The chair is Daisy_. Information about MeetBot at http://wiki.debian.org/MeetBot. 08:01:45 <openstack> Useful Commands: #action #agreed #help #info #idea #link #topic #startvote. 08:01:48 <openstack> The meeting name has been set to 'openstack_i18n' 08:01:56 <Daisy_> Good morning and good afternoon, everyone. 08:02:10 <epico> good afternoon 08:02:12 <ujuc_phone> Hi :) 08:02:26 <ygbo> Hi, good morning everyone :-) 08:02:29 <Daisy_> We will have I18n meeting now. 08:02:40 <Daisy_> Hi, ygbo 08:02:46 <Daisy_> Welcome to join. 08:03:19 <Daisy_> #topic Whether to including the final : with strings 08:03:34 <Daisy_> http://lists.openstack.org/pipermail/openstack-i18n/2014-April/000573.html 08:03:51 <Daisy_> I guess, all of you have understood the problem. 08:04:11 <Daisy_> In my mind, the question can be changed to "whether to keep punctuation in translatable strings". 08:04:13 <Daisy_> The punctuation could include: colon, comma, full stop mark, and space. 08:04:24 <Daisy_> I don't know if I'm right. Let me know your thoughts. 08:05:08 <jpich> If including the punctuation is necessary for a team to produce high quality translations, I think we should keep it. Otherwise the translations just look wrong in some languages 08:05:21 <DeeJay1> Trailing/leading spaces in English strings IMHO have to go, the rest can stay - I came to the conclusions that else it could pose problems with right to left languages 08:05:44 <jpich> Articles like http://blog.transifex.com/post/49857043763/painless-software-localization (point 6) recommend keeping it, in particular because of French 08:06:06 <Daisy_> I agree, jpich, to keep them. My point is to include punctuation. In Chinese, punctuation should also be translated. In Chinese, we have different characters for English colon and Chinese colon. 08:06:27 <Daisy_> I think, the question is space. 08:06:40 <ygbo> DeeJay1 is right, inside strings, translators will be able to handle them, but trailing ones when concanated will not be properly handled in all languages. 08:06:50 <jpich> I agree with DeeJay1 re:spaces :) 08:07:12 <Daisy_> Is space important ? Is it important to add spaces at the end of a string? 08:07:36 <jpich> I don't think so. 08:07:59 <ygbo> Daisy_: "in english: we say this", "en fran�ais : on dit �a" <- different spacing 08:08:07 <DeeJay1> I thinks it's just bad design, if spaces have to be used for a visual indent 08:08:10 <Daisy_> Space is also a punctuation. It can separate words, right? 08:08:26 <jpich> ygbo: I think we're talking about strings like "Image details" vs "Image details " 08:08:37 <Daisy_> Right. 08:08:43 <ygbo> Daisy_: right 08:08:53 <DeeJay1> yes, but trailing spaces are only in cases like "My string " + "other string" - which is bad code 08:08:59 <Daisy_> If codes like "Image details " + varaibleS 08:09:21 <ygbo> jpich: rigth too :-) 08:09:32 <DeeJay1> this should be "Image details %(variable)s" % variable 08:09:35 <Daisy_> If a code like "Image details "+<a variable>, I think, space is necessary. 08:09:56 <Daisy_> All right, DeeJay1 08:10:11 <ygbo> So this is why the variable should be "in" the string 08:10:13 <DeeJay1> yup, but in such cases the translator doesn't even know that something is coming after the string 08:10:29 <Daisy_> We are not able to think out a scenario that space is necessary, right? Think carefully. 08:10:48 * epico also thinks it is bad code. 08:11:20 <ygbo> because if the variable is "in" the string, the translator can move it around, words are not at the same place in all languages, and concatenation leeds to words at the wrong place in some languages. 08:11:42 <Daisy_> I think there are bast practices for coding, and we should document them. 08:12:02 <epico> the code like "My string " + "other string" usually is avoid in gettext. 08:12:06 <jpich> Agreed, concatenation is bad and we need to start fixing this in Horizon. Dough Fish and ygbo raised a few points about this on the mailing list, in answer to today's meeting agenda 08:12:10 <Daisy_> ygbo: what's your point? Keep space or not? 08:12:53 <Daisy_> ygbo, I got your point. 08:13:33 <ygbo> Daisy_: we should not concatenate strings and use variables instead, and we would not need trailing spaces anymore. 08:14:12 <ygbo> Daisy_: translators might need to move variables around, while they can not change the order of concatenation. 08:14:30 <Daisy_> let me summarize 08:14:47 <Daisy_> the punctuation is necessary for a team to produce high quality translations, we should keep it, except spaces. 08:15:24 <Daisy_> Developers should avoid to concatenate strings and use variables instead, in order to avoid a string ending with spaces. 08:15:46 <Daisy_> correct? 08:15:51 <DeeJay1> +1 08:15:58 <rajeshr> +1 08:16:01 <ygbo> +1 08:16:01 <jpich> Sounds good to me. 08:16:02 <fdot> +1 08:16:05 <jpich> Er, +1 08:16:11 <jpich> :) 08:16:14 <DeeJay1> :) 08:16:18 <ujuc_phone> +1 08:16:45 <epico> +1 08:17:04 <rajeshr> Daisy_, Since there is a character Visarga (ः) in Hindi similar to colon, so to avoid the problem translator sometime use long dash instead of the colon. If we need want to use colon, we should put one space before the colon. 08:17:14 <Daisy_> Thanks. So I will put it as a comments to https://bugs.launchpad.net/horizon/+bug/1296075 and https://review.openstack.org/#/c/84342/. 08:17:16 <uvirtbot> Launchpad bug 1296075 in horizon "Needles duplication in strings" [Low,In progress] 08:17:27 <jpich> Thanks, Daisy_ 08:17:39 <rajeshr> Daisy_, Ref: http://svn.fedorahosted.org/svn/fuel/language/hi/style_guide/ 08:18:24 <Daisy_> any comments to rajeshr 's point ? 08:18:46 <DeeJay1> rajeshr: wow, nice 08:19:08 <DeeJay1> Daisy_: nope, it boils down to "include colons" in original strings 08:19:25 * DeeJay1 is sorry for all the confusion this topic caused because of him 08:19:38 <Daisy_> rajeshr: you hope developers to use "details :" other than "details:" 08:20:15 <jpich> DeeJay1: Thanks to you we now have a clear understanding of the problem and a solution everybody agrees on :) 08:20:56 <ygbo> Daisy_: we should not use "details:" but "details: %(topic)s" 08:21:09 <rajeshr> Daisy_, no, details: is fine, actually the above comment is for Hindi that if anybody want to use colon in Hindi better use the way suggested as it is simmilar to one char in Hindi 08:21:26 <rajeshr> in English Source string should be as it is 08:21:37 <Daisy_> ok. 08:21:49 <Daisy_> so we are OK for the first topic now ? 08:22:40 <Daisy_> let's move to next topic. 08:23:01 <ujuc_phone> Ok 08:23:15 <Daisy_> #topic whether to add context-maker for better translations 08:23:30 <Daisy_> I think this one is harder. :) 08:23:36 <ygbo> Yep :-) 08:23:45 <fdot> yep :) 08:24:05 <Daisy_> ygbo: would you like to say something about it ? 08:24:06 <ygbo> the issue is that "we do not necessarely need contextual markers in a string like this one" <- 08:24:20 <ygbo> "here we need some" <- (too short) 08:25:38 <ygbo> some strings just have a single word , an example is "May" <- is it the month or the verbe granting permission? 08:25:59 <jpich> I think there are also two aspects to the question: whether to do it for future strings (I think yes, and that this is the easy question), and what to do with existing strings as this may force retranslating them (though hopefully the translation memory would help?) 08:26:43 <ygbo> this is where fdot can say something about it 08:26:47 <fdot> I am agree on the first part for adding context in new string. 08:27:07 <fdot> But for the second part, i think we should not change anything 08:27:09 <Daisy_> amotoki had introduced context-maker in Havana release, and it caused the translators have to retranslate them. 08:27:26 <fdot> let's leave the strings already translated 08:27:48 <Daisy_> translation memory can help. 08:28:18 <fdot> yes but translating again and again is not a good idea 08:28:37 <jpich> fdot, what if the some languages have wrong/awkward translations because of this? Maybe we can fix only the ones we know are a problem? (When translators report them?) 08:28:41 <fdot> for communities they will just see the same strings to translate again 08:28:49 <Daisy_> If users report bugs/issues to complain about the translation quality, and we have to separate 1 string into two strings in the original language, we have to add context, even we have to re-translate them. 08:28:49 <ygbo> We should use contextual markers on new strings, and on "string change", but we can't use them on all the existing ones because as fdot mentionned it, the whole work done by translators would be lost and have to be redone. 08:28:59 <fdot> jpich agree but 08:29:06 <Daisy_> jpich: agree. 08:29:10 <fdot> it depends of languages ;) 08:29:38 <DeeJay1> IMHO every introduction of a contextual marker to an existing string should be followed by fixing (copying the existing strings) the po files by that developer and an email to i18n list 08:29:39 <jpich> I don't think we can add a contextual marker just for one language though :) 08:29:41 <fdot> in french we can have a strange for a word but the translation could be nice for the others language ;) 08:29:45 <Daisy_> amotoki reported the bug because Japanese had the issue. 08:30:53 <ygbo> jpich: indeed, contextual markers have to be language agnostic, they have to put a context on where the words or part of sentence is used. 08:31:04 <jpich> It seems ok to me to report a bug + fix it in the code if a language is broken because of the lack of contextual marker 08:31:11 <Daisy_> so I think, if there is issues in any languages, we should fix it. 08:31:12 <ygbo> s/the words or/the words are/ 08:31:30 <jpich> DeeJay1: The po files are updated automatically by Jenkins, I don't think the devs can do that manually 08:32:01 <Daisy_> any thoughts about adding context to new strings? any rules? 08:32:02 <rajeshr> I am confused, i think we should use msgctxt irrespective of language 08:32:40 <epico> maybe just use msgctxt when it has problems for some languages? 08:33:31 <ygbo> epico: the problem is we can not forward guess which language will be impacted, imho, new strings should have msgctxt. 08:33:39 <jpich> I think that's it yes. Context markers for new strings, only add to existing strings if a language team reports a problem 08:33:51 <rajeshr> I don't think so, the language is so diverse and leaving it for translator to decide will be bad in long run 08:34:19 <jpich> By the way, this will require some documentation for developer education (probably from ygbo, you seem familiar with it?), so we can learn when to use them and how to make them useful 08:34:20 <ygbo> jpich: also add if a string changes. 08:34:27 <rajeshr> epico, so better use context marker whenever we think of any confusion 08:34:28 <epico> I think msgctxt is needed when the translatable string appears more than once... 08:34:39 <ygbo> jpich: sure :-) 08:35:08 <ygbo> epico: exactly :-) 08:35:13 <jpich> ygbo: Thanks! :) 08:35:21 <epico> if the string only happens in one place, we don't bother to add the context marker. 08:35:27 <epico> ygbo, :) 08:36:24 <epico> in other OSS project, msgctxt is used when needed, I think. 08:36:39 <rajeshr> epico, that is okay, but if any confusion developer see they can put a localization note like thing 08:36:42 <ygbo> epico: well, if it's a new string, we better still add one, because no one knows if we will have the same string somewhere else in the future. however, we don't need it for long sentences where the context is aparent in the sentence itsself. 08:37:14 <epico> rajeshr, yeah :) 08:38:25 <Daisy_> so let me summarize again. 08:38:31 <Daisy_> Context markers for new strings, only add to existing strings if a language team reports a problem 08:38:42 <ygbo> If the developper knows a word can have different meanings (example "may"), there the context is necessary. 08:38:50 <jpich> Or if you change an existing string, I think ygbo would like to add? 08:39:02 <ygbo> jpich: +1 :-) 08:39:23 <Daisy_> ygbo to add some documentation for developer education. 08:39:29 <epico> ygbo, I think maybe we can get the times of strings used in the pot file. 08:39:58 <Daisy_> the exact string only appear once in pot file. 08:40:08 <epico> Daisy_, yes 08:40:10 <Daisy_> exact same string only appear once 08:40:32 <epico> but the places of things is listed in the comment, feel correct me if I am wrong about it. 08:40:35 <jpich> What's the goal of the once-off string? I'm not sure this is very visible to developers by default 08:40:43 <epico> s/things/strings/ 08:40:49 <Daisy_> with different context, it will appear differently 08:41:37 <epico> we can get the times from the comments in po file. 08:41:40 <epico> #: tables/actions.py:381 08:41:40 <epico> #: templates/horizon/common/_data_table_table_actions.html:13 08:41:40 <epico> #: templates/horizon/common/_workflow_step_update_members.html:11 08:41:40 <epico> #: templates/horizon/common/_workflow_step_update_members.html:17 08:41:43 <epico> like above... 08:41:53 <epico> msgid "Filter" 08:41:54 <epico> msgstr "" 08:41:54 <Daisy_> when we generate pot, the exact same string will appear only once. it's by default. 08:42:11 <epico> Daisy_, the information is in the comment. 08:42:19 <Daisy_> epico shows a good sample. 08:42:19 <Daisy_> Yes. 08:42:29 <epico> "Filter" is used 4 times. 08:42:33 <jpich> I don't think most developers builds the po files when making a change though, since that's handled automatically by Jenkins 08:42:44 <jpich> and there can be many changes so it wouldn't be easily visible 08:42:57 <jpich> I'm not sure the "exact string only once" rule would be easy to enforce 08:42:59 <jpich> currently 08:43:22 * epico means to reduce msgctxt usage, just for needed cases. 08:43:44 <epico> sorry, I mean for future msgctxt usage. 08:44:06 <Daisy_> exact same string means same strings, no differences at all, even punctuation is same. 08:44:27 <epico> Daisy_, yes 08:44:27 <ygbo> epico: coders see the context in the code, but most translators do not and do not necesserly understand the python code, this is more usefull for coders to know where to look for when a translators comes asking for help. 08:44:39 <Daisy_> While generating pot files, these strings will be merged into 1 msgid, and appear once in a single pot file. 08:45:01 * ygbo is talking abouth the line in the po where the string is 08:45:11 <epico> ygbo, I mean the developer can read the pot file to decide not to use context marker for strings used only once. 08:45:47 <epico> s/not/whether or not/ 08:45:50 <Daisy_> if these strings are with same meaning, I think there is no need to use context. 08:46:05 <epico> Daisy_, agreed. :) 08:46:20 <Daisy_> Using context will add more strings into pot file. 08:46:32 <epico> yeah 08:46:35 <ygbo> epico: the issue is that the pot file is not generated by the developper. 08:46:42 <jpich> epico: I think we'll need input from the translation team if things are missed, because most developers don't look at the po files 08:46:53 <epico> jpich, okay 08:47:12 <epico> but for one place string maybe we can avoid the msgctxt. 08:47:51 <ygbo> <Daisy_> if these strings are with same meaning, I think there is no need to use context. +1 08:48:02 <epico> +1 08:48:14 <Daisy_> I think we can have a discussion when ygbo finishes the training document for developers. 08:48:27 <rajeshr> Daisy_, ther is fedora SIG: https://fedoraproject.org/wiki/SSCG 08:48:29 <jpich> Sounds great :) 08:48:36 <rajeshr> work with the prob of context 08:48:47 <Daisy_> I believe in this document, there will be more details, e.g. whether to add context for one place string. 08:48:58 <rajeshr> Daisy_, https://fedoraproject.org/w/uploads/b/bf/Guidelines_for_contextualization.pdf 08:49:10 <ygbo> Daisy_: sure 08:49:12 <Daisy_> great, rajeshr. 08:49:19 <Daisy_> we can use them as the references. 08:49:22 <epico> could we also document the pot file of times of strings used in the document? 08:49:29 <epico> cool 08:49:37 <Daisy_> why we document them, epico? 08:49:48 <rajeshr> Daisy_, one more on FUEL: http://svn.fedorahosted.org/svn/fuel/qa/fuel-context-in-technical-translation-concept-and-guidelines.pdf 08:49:49 <jpich> rajeshr: Do I understand correctly that this is a team that focuses only on adding context markers?? 08:50:21 <epico> Daisy_, I think developer need to add the context marker before translations... 08:50:56 <rajeshr> jpich, I know some contributor here in SIG but don;t know in detail, mailing list is also there 08:51:34 <Daisy_> I don't know if developers know about it, epico. 08:51:44 <epico> Daisy_, a guide about how to add context markers for developers. 08:51:57 <Daisy_> that's what ygbo is going to wrint. 08:51:58 <jpich> rajeshr: Nice! That would really help if some people took on that role too to help with new strings :-) 08:52:08 <epico> Daisy_, great. :) 08:52:29 <Daisy_> ;et 08:52:47 <Daisy_> let's move on, and we will have the second discussion when ygbo is done. 08:53:02 <Daisy_> #topic I18n related sessions in design summit 08:53:31 <epico> about log message id generation 08:53:40 <epico> http://lists.openstack.org/pipermail/openstack-dev/2014-April/031855.html 08:53:42 <Daisy_> There is one session in infrastructure track to discuss translation tools. 08:54:01 <epico> Daisy_, jpich, guess you saw the discussion? 08:54:05 <Daisy_> There is another session in cross-project track to discuss log standards, including I18n standards. 08:54:29 <Daisy_> Are there any other sessions that I miss ? 08:55:14 <jpich> I think there's some conflicts with Horizon sessions again but I will try to make some i18n sessions as I can 08:55:26 <Daisy_> OK. 08:55:26 <Daisy_> Thanks, jpich. 08:56:04 <jpich> epico: Are you working on adding error message ids? 08:56:19 <Daisy_> Who will attend Atlanta summit, besides jpich ? 08:57:06 <Daisy_> Let's move to open discussion 08:57:07 <epico> jpich, I think both English logging and Translated logging can replace the error message id. 08:57:14 <Daisy_> #topic Open discussion 08:57:47 <epico> the English log is fit for the developers. 08:58:06 <epico> translated log is fit for users. 08:58:36 <Daisy_> so epico's point is that "no need to add message ID" 08:58:49 <epico> Daisy_, right. 08:59:37 <Daisy_> I think, no need to add ID for all messages, but for error messages, maybe it is useful. In that point, it's not message ID, but error code. 09:00:01 <epico> Daisy_, yeah, any details? 09:00:10 <Daisy_> not much details 09:00:15 <Daisy_> we could discuss off line 09:00:41 <epico> okay 09:01:00 <Daisy_> Any other things to talk? 09:01:12 <Daisy_> If no, I will close the meeting. 09:01:55 <Daisy_> My network keeps on re-connecting again and again. :( 09:02:11 <Daisy_> OK. Thank you all for attending. 09:02:17 <jpich> thanks 09:02:20 <rajeshr> thank you everybody 09:02:27 <Daisy_> Especially thanks for people who are on holidays. 09:02:31 <epico> thanks 09:02:35 <ujuc_phone> :) 09:02:36 <ygbo> thank you all. 09:02:37 <rajeshr> :) 09:02:40 <Daisy_> #endmeeting