From f11235dce05843401bccaae6dfcee8f65ac9da1d Mon Sep 17 00:00:00 2001 From: Dimitri van Heesch Date: Sun, 11 Nov 2001 19:56:10 +0000 Subject: Release-1.2.11-20011111 --- doc/language.doc | 75 ++++++++++++++++++++++++++----------------------------- doc/language.tpl | 65 +++++++++++++++++++++++------------------------ doc/translator.pl | 27 ++++++++------------ 3 files changed, 77 insertions(+), 90 deletions(-) diff --git a/doc/language.doc b/doc/language.doc index a586338..8db2128 100644 --- a/doc/language.doc +++ b/doc/language.doc @@ -25,7 +25,7 @@ Doxygen has built-in support for multiple languages. This means that the text fragments that doxygen generates can be produced in languages other than English (the default) at configuration time. -Currently (version 1.2.11-20011021), 24 languages +Currently (version 1.2.11-20011111), 24 languages are supported (sorted alphabetically): Brazilian Portuguese, Chinese, Croatian, Czech, Danish, Dutch, English, Finnish, French, German, @@ -72,7 +72,7 @@ when the translator was updated. Czech Petr Přikryl prikrylp@NOSPAM.skil.cz - 1.2.11 + up-to-date Danish @@ -162,7 +162,7 @@ when the translator was updated. Russian Alexandr Chelpanov cav@NOSPAM.cryptopro.ru - 1.2.11 + up-to-date Slovak @@ -212,7 +212,7 @@ when the translator was updated. \hline Croatian & Boris Bralo & {\tt boris.bralo@zg.tel.hr} & 1.2.11 \\ \hline - Czech & Petr P\v{r}ikryl & {\tt prikrylp@skil.cz} & 1.2.11 \\ + Czech & Petr P\v{r}ikryl & {\tt prikrylp@skil.cz} & up-to-date \\ \hline Danish & Erik S\o{}e S\o{}rensen & {\tt erik@mail.nu} & 1.2.7 \\ \hline @@ -244,7 +244,7 @@ when the translator was updated. \hline Romanian & Alexandru Iosup & {\tt aiosup@yahoo.com} & 1.2.1 \\ \hline - Russian & Alexandr Chelpanov & {\tt cav@cryptopro.ru} & 1.2.11 \\ + Russian & Alexandr Chelpanov & {\tt cav@cryptopro.ru} & up-to-date \\ \hline Slovak & Stanislav Kudl\'{a}\v{c} & {\tt qwerty1@pobox.sk} & 1.2.11 \\ \hline @@ -331,21 +331,23 @@ Just follow these steps:

Maintaining a language

-As new versions of doxygen appear, new sentences (\c trXxxx() -methods) will be added to the \c Translator interface class. Of -course, these need to be translated as well (otherwise doxygen -wouldn't even compile!). Waiting until all language maintainers -have translated the new sentences and sent the results would not -be very practical. The following text describes the usage of -translator adapters to solve the problem. +New versions of doxygen may use new translated sentences. In such +situation, the \c Translator class requires implementation of new +methods -- its interface changes. Of course, the English +sentences need to be translated to the other languages. At least, +new methods have to be implemented by the language-related +translator class; otherwise, doxygen wouldn't even compile. Waiting +until all language maintainers have translated the new sentences and +sent the results would not be very practical. The following text +describes the usage of translator adapters to solve the problem. The role of Translator Adapters. Whenever the \c Translator class interface changes in the new release, the new class \c TranslatorAdapter_x_y_z is added to the \c translator_adapter.h file (here x, y, and z are numbers that -correspond to the current version of doxygen). All translators that -previously derived from the \c Translator class now derive from this -adapter class. +correspond to the current official version of doxygen). All +translators that previously derived from the \c Translator class now +derive from this adapter class. The \c TranslatorAdapter_x_y_z class implements the new, required methods. If the new method replaces some similar but obsolete @@ -355,7 +357,7 @@ TranslatorAdapter_x_y_z class may use the obsolete method to get the result which is as close as possible to the older result in the target language. If it is not possible, the result (the default translation) is obtained using the English translator, which is (by -definition) always up to date. +definition) always up-to-date. For example, when the new \c trFile() method with parameters (to determine the capitalization of the first letter and @@ -429,29 +431,25 @@ The translator adapter classes are chained so that the older translator adapter class uses the one-step-newer translator adapter as the base class. The newer adapter does less \e adapting work than the older one. The oldest adapter class derives (indirectly) -from all of the adapter classes. The newest adapter class derives -directly from the abstract class \c Translator. - -The name of the adapter class was chosen so that its suffix is -derived from the previous version of doxygen. This way, one can say -approximately, when the language translator class was last updated --- see details below. The newest adapter translator for CVS release -(i.e. non official) is named \c TranslatorAdapterCVS. As it derives -only from the \c Translator class, it can be used only for language -translator classes that were up-to-date in the time of the last -release. - -Status of the translators that derive from the \c -TranslatorAdapterCVS is named as almost up-to-date. -Its code is moved into the new \c Translator_x_y_z when new version -of doxygen is officially released. +from all of the adapter classes. The name of the adapter class is +chosen so that its suffix is derived from the previous official +version of doxygen that did not need the adapter. This way, one can +say approximately, when the language translator class was last +updated -- see details below. + +The newest translator adapter derives from the abstract \c +TranslatorAdapterBase class that derives directly from the abstract +\c Translator class. It adds only the private English-translator +member for easy implementation of the default translation inside the +adapter classes, and it also enforces implementation of one method +for noticing the user that the language translation is not up-to-date +(because of that some sentences in the generated files may appear in +English). Once the oldest adapter class is not used by any of the language -translators, it can be removed from the doxygen project. This also -means, that there probably still is some language which uses the -oldest adapter. The maintainers should try to reach the state with -the minimal number of translator adapter classes. - +translators, it can be removed from the doxygen project. The +maintainers should try to reach the state with the minimal number of +translator adapter classes. To simplify the maintenance of the language translator classes for the supported languages, the \c translator.pl perl @@ -473,7 +471,6 @@ Of course, you are not forced to use the results of the script. You can find the same information by looking at the adapter class and its base classes. - How should I update my language translator? Firstly, you should be the language maintainer, or you should let him/her know about the changes. The following text was written for the language @@ -525,7 +522,7 @@ can change the translator adapter base to the newer one. Do not blindly implement all methods that are implemented by your translator adapter base class. The reason is that the adapter classes implement also obsolete methods. Another reason is that -some of the methods could become obsolete later. +some of the methods could become obsolete from some newer adapter on. */ diff --git a/doc/language.tpl b/doc/language.tpl index 7497bea..3982278 100644 --- a/doc/language.tpl +++ b/doc/language.tpl @@ -104,21 +104,23 @@ Just follow these steps:

Maintaining a language

-As new versions of doxygen appear, new sentences (\c trXxxx() -methods) will be added to the \c Translator interface class. Of -course, these need to be translated as well (otherwise doxygen -wouldn't even compile!). Waiting until all language maintainers -have translated the new sentences and sent the results would not -be very practical. The following text describes the usage of -translator adapters to solve the problem. +New versions of doxygen may use new translated sentences. In such +situation, the \c Translator class requires implementation of new +methods -- its interface changes. Of course, the English +sentences need to be translated to the other languages. At least, +new methods have to be implemented by the language-related +translator class; otherwise, doxygen wouldn't even compile. Waiting +until all language maintainers have translated the new sentences and +sent the results would not be very practical. The following text +describes the usage of translator adapters to solve the problem. The role of Translator Adapters. Whenever the \c Translator class interface changes in the new release, the new class \c TranslatorAdapter_x_y_z is added to the \c translator_adapter.h file (here x, y, and z are numbers that -correspond to the current version of doxygen). All translators that -previously derived from the \c Translator class now derive from this -adapter class. +correspond to the current official version of doxygen). All +translators that previously derived from the \c Translator class now +derive from this adapter class. The \c TranslatorAdapter_x_y_z class implements the new, required methods. If the new method replaces some similar but obsolete @@ -128,7 +130,7 @@ TranslatorAdapter_x_y_z class may use the obsolete method to get the result which is as close as possible to the older result in the target language. If it is not possible, the result (the default translation) is obtained using the English translator, which is (by -definition) always up to date. +definition) always up-to-date. For example, when the new \c trFile() method with parameters (to determine the capitalization of the first letter and @@ -202,29 +204,25 @@ The translator adapter classes are chained so that the older translator adapter class uses the one-step-newer translator adapter as the base class. The newer adapter does less \e adapting work than the older one. The oldest adapter class derives (indirectly) -from all of the adapter classes. The newest adapter class derives -directly from the abstract class \c Translator. - -The name of the adapter class was chosen so that its suffix is -derived from the previous version of doxygen. This way, one can say -approximately, when the language translator class was last updated --- see details below. The newest adapter translator for CVS release -(i.e. non official) is named \c TranslatorAdapterCVS. As it derives -only from the \c Translator class, it can be used only for language -translator classes that were up-to-date in the time of the last -release. - -Status of the translators that derive from the \c -TranslatorAdapterCVS is named as almost up-to-date. -Its code is moved into the new \c Translator_x_y_z when new version -of doxygen is officially released. +from all of the adapter classes. The name of the adapter class is +chosen so that its suffix is derived from the previous official +version of doxygen that did not need the adapter. This way, one can +say approximately, when the language translator class was last +updated -- see details below. + +The newest translator adapter derives from the abstract \c +TranslatorAdapterBase class that derives directly from the abstract +\c Translator class. It adds only the private English-translator +member for easy implementation of the default translation inside the +adapter classes, and it also enforces implementation of one method +for noticing the user that the language translation is not up-to-date +(because of that some sentences in the generated files may appear in +English). Once the oldest adapter class is not used by any of the language -translators, it can be removed from the doxygen project. This also -means, that there probably still is some language which uses the -oldest adapter. The maintainers should try to reach the state with -the minimal number of translator adapter classes. - +translators, it can be removed from the doxygen project. The +maintainers should try to reach the state with the minimal number of +translator adapter classes. To simplify the maintenance of the language translator classes for the supported languages, the \c translator.pl perl @@ -245,7 +243,6 @@ Of course, you are not forced to use the results of the script. You can find the same information by looking at the adapter class and its base classes. - How should I update my language translator? Firstly, you should be the language maintainer, or you should let him/her know about the changes. The following text was written for the language @@ -297,7 +294,7 @@ can change the translator adapter base to the newer one. Do not blindly implement all methods that are implemented by your translator adapter base class. The reason is that the adapter classes implement also obsolete methods. Another reason is that -some of the methods could become obsolete later. +some of the methods could become obsolete from some newer adapter on. */ diff --git a/doc/translator.pl b/doc/translator.pl index a3021fa..58477af 100644 --- a/doc/translator.pl +++ b/doc/translator.pl @@ -82,6 +82,11 @@ # method identifier and the opening parenthesis to match better # the method prototype with the one in the translator.h. # +# 2001/11/06 +# - TranslatorAdapterCVS is not used any more. There is nothing +# like "almost up-to-date" any more. The script was simplified +# to reflect the changes. +# ################################################################ use 5.005; @@ -516,11 +521,7 @@ xxxTABLE_FOOTxxx my $status = shift @list; my $i = $status =~ s{^Translator$}{up-to-date}; - - if ($i == 0) { - $i = $status =~ s{^TranslatorAdapterCVS}{almost up-to-date}; - } - + if ($i == 0) { $i = $status =~ s{^TranslatorAdapter_(\d)_(\d)_(\d)} {$1.$2.$3}x; @@ -972,19 +973,15 @@ print STDERR "\n\n"; # If there are up-to-date translators, list them. #{{{ # - my @list = sort grep { $cb{$_} =~ m/^Translator(AdapterCVS)?$/ } keys %cb; + my @list = sort grep { $cb{$_} =~ m/^Translator$/ } keys %cb; if (@list) { print FOUT "\n" .'-' x 70 . "\n"; print FOUT "The following translator classes are up-to-date " . "(sorted alphabetically).\n" . "This means that they derive from the Translator class. " - . "If the translator\n" - . "derives from TranslatorAdapterCVS, it is considered " - . "to be almost up-to-date.\n" - . "In other words, it is newer than the last official " - . "release. Anyway, there\n" - . "still may be some details listed even for " + . "Anyway, there still\n" + . "may be some details listed even for " . "the up-to-date translators.\n" . "Please, check the text below if the translator " . "is marked so.\n\n"; @@ -995,10 +992,6 @@ print STDERR "\n\n"; # print FOUT " $_"; - # For almost up-to-date translators, show also the base class. - # - if ($cb{$_} ne 'Translator') { print FOUT "\t($cb{$_})"; } - # If some details were listed for the translator class, # add a notice. # @@ -1030,7 +1023,7 @@ print STDERR "\n\n"; # @list = sort grep { $cb{$_} !~ m/^Translator$/ } - grep { $cb{$_} !~ m/^TranslatorAdapter/ } + grep { $cb{$_} !~ m/^TranslatorAdapter_/ } keys %cb; if (@list) { -- cgit v0.12