antoine     2003/06/30 03:41:00

  Modified:    src/main/org/apache/tools/ant/taskdefs/optional/i18n
                        Translate.java
               .        WHATSNEW
  Added:       src/testcases/org/apache/tools/ant/taskdefs/optional/i18n
                        TranslateTest.java
               src/etc/testcases/taskdefs/optional/i18n/translate
                        translate.xml
               src/etc/testcases/taskdefs/optional/i18n/translate/input
                        template.txt resources_ger_de.properties
               src/etc/testcases/taskdefs/optional/i18n/translate/expected/de
                        template.txt
  Log:
  The translate task did not translate tokens that are placed too close 
together.
  This change fixes this. Thanks Tom, sorry for the time it took to process 
your patch.
  PR: 17297
  Submitted by: Tom Eugelink (tom at tbee dot org)
  
  Revision  Changes    Path
  1.21      +60 -45    
ant/src/main/org/apache/tools/ant/taskdefs/optional/i18n/Translate.java
  
  Index: Translate.java
  ===================================================================
  RCS file: 
/home/cvs/ant/src/main/org/apache/tools/ant/taskdefs/optional/i18n/Translate.java,v
  retrieving revision 1.20
  retrieving revision 1.21
  diff -u -r1.20 -r1.21
  --- Translate.java    10 Feb 2003 14:14:05 -0000      1.20
  +++ Translate.java    30 Jun 2003 10:40:59 -0000      1.21
  @@ -75,6 +75,7 @@
    * Translates text embedded in files using Resource Bundle files.
    *
    * @author Magesh Umasankar, Don Brown
  + * @author <a href="mailto:[EMAIL PROTECTED]">Tom Eugelink</a>
    */
   public class Translate extends MatchingTask {
   
  @@ -507,52 +508,66 @@
                           BufferedReader in
                               = new BufferedReader(new InputStreamReader(fis, 
srcEncoding));
                           String line;
  -                        int stLength = startToken.length();
  -                        int etLength = endToken.length();
                           while ((line = in.readLine()) != null) {
  -                            int startIndex = -1;
  -                            int endIndex = -1;
  -outer:                      while (true) {
  -                                startIndex = line.indexOf(startToken, 
endIndex + etLength);
  -                                if (startIndex < 0 ||
  -                                    startIndex + stLength >= line.length()) {
  -                                    break;
  -                                }
  -                                endIndex = line.indexOf(endToken, startIndex 
+ stLength);
  -                                if (endIndex < 0) {
  -                                    break;
  -                                }
  -                                String matches = line.substring(startIndex + 
stLength,
  -                                                                endIndex);
  -                                //If there is a white space or = or :, then
  -                                //it isn't to be treated as a valid key.
  -                                for (int k = 0; k < matches.length(); k++) {
  -                                    char c = matches.charAt(k);
  -                                    if (c == ':' ||
  -                                        c == '=' ||
  -                                        Character.isSpaceChar(c)) {
  -                                        endIndex = endIndex - 1;
  -                                        continue outer;
  -                                    }
  -                                }
  -                                String replace = null;
  -                                replace = (String) resourceMap.get(matches);
  -                                    //If the key hasn't been loaded into 
resourceMap,
  -                                    //use the key itself as the value also.
  -                                if (replace == null) {
  -                                    log("Warning: The key: " + matches
  -                                        + " hasn't been defined.",
  -                                        Project.MSG_DEBUG);
  -                                    replace = matches;
  -                                }
  -                                line = line.substring(0, startIndex)
  -                                    + replace
  -                                    + line.substring(endIndex + etLength);
  -                                endIndex = startIndex + replace.length() + 
etLength;
  -                                if (endIndex + etLength >= line.length()) {
  -                                    break;
  -                                }
  -                            }
  +                                             // 2003-02-21 new replace 
algorithm by tbee ([EMAIL PROTECTED])
  +                                             // because it wasn't able to 
replace something like "@aaa;@bbb;"
  +
  +                                             // is there a startToken
  +                                             // and there is still stuff 
following the startToken
  +                                             int startIndex = 
line.indexOf(startToken);
  +                                             while ( startIndex >= 0 && 
(startIndex+startToken.length()) <= line.length() )
  +                                             {
  +                                                     // the new value, this 
needs to be here
  +                                                     // because it is 
required to calculate the next position to search from
  +                                                     // at the end of the 
loop
  +                                         String replace = null;
  +
  +                                                     // we found a 
starttoken, is there an endtoken following?
  +                                                     // start at 
token+tokenlength because start and end token may be indentical
  +                                                     int endIndex = 
line.indexOf(endToken, startIndex + startToken.length());
  +                                                     if (endIndex < 0) 
startIndex += 1;
  +                                                     else
  +                                                     {
  +                                                             // grab the 
token
  +                                                             String token = 
line.substring(startIndex + startToken.length(), endIndex);
  +
  +                                             // If there is a white space or 
= or :, then
  +                                             // it isn't to be treated as a 
valid key.
  +                                             boolean validToken = true;
  +                                             for (int k = 0; k < 
token.length() && validToken; k++)
  +                                             {
  +                                                 char c = token.charAt(k);
  +                                                 if ( c == ':'
  +                                                   || c == '='
  +                                                   || 
Character.isSpaceChar(c)
  +                                                    )
  +                                                 {
  +                                                     validToken = false;
  +                                                 }
  +                                             }
  +                                             if (!validToken) startIndex += 
1;
  +                                             else
  +                                             {
  +                                                     // find the replace 
string
  +                                                     if 
(resourceMap.containsKey(token)) replace = (String)resourceMap.get(token);
  +                                                     else                    
            replace = token;
  +
  +
  +                                                 // generate the new line
  +                                                 line = line.substring(0, 
startIndex)
  +                                                      + replace
  +                                                      + 
line.substring(endIndex + endToken.length());
  +
  +                                                                     // set 
start position for next search
  +                                                                     
startIndex += replace.length();
  +                                             }
  +                                                     }
  +
  +                                                     // find next starttoken
  +                                                     startIndex = 
line.indexOf(startToken, startIndex);
  +                                             }
  +
  +
                               out.write(line);
                               out.newLine();
                           }
  
  
  
  1.1                  
ant/src/testcases/org/apache/tools/ant/taskdefs/optional/i18n/TranslateTest.java
  
  Index: TranslateTest.java
  ===================================================================
  /*
   * The Apache Software License, Version 1.1
   *
   * Copyright (c) 2003 The Apache Software Foundation.  All rights
   * reserved.
   *
   * Redistribution and use in source and binary forms, with or without
   * modification, are permitted provided that the following conditions
   * are met:
   *
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   *
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in
   *    the documentation and/or other materials provided with the
   *    distribution.
   *
   * 3. The end-user documentation included with the redistribution, if
   *    any, must include the following acknowlegement:
   *       "This product includes software developed by the
   *        Apache Software Foundation (http://www.apache.org/)."
   *    Alternately, this acknowlegement may appear in the software itself,
   *    if and wherever such third-party acknowlegements normally appear.
   *
   * 4. The names "Ant" and "Apache Software
   *    Foundation" must not be used to endorse or promote products derived
   *    from this software without prior written permission. For written
   *    permission, please contact [EMAIL PROTECTED]
   *
   * 5. Products derived from this software may not be called "Apache"
   *    nor may "Apache" appear in their names without prior written
   *    permission of the Apache Group.
   *
   * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
   * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
   * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
   * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
   * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
   * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
   * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
   * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
   * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
   * SUCH DAMAGE.
   * ====================================================================
   *
   * This software consists of voluntary contributions made by many
   * individuals on behalf of the Apache Software Foundation.  For more
   * information on the Apache Software Foundation, please see
   * <http://www.apache.org/>.
   */
  
  package org.apache.tools.ant.taskdefs.optional.i18n;
  
  import org.apache.tools.ant.BuildFileTest;
  
  import java.io.File;
  import java.io.FileInputStream;
  import java.io.IOException;
  
  /**
   * Tests the Translate task.
   *
   * @author    <a href="mailto:[EMAIL PROTECTED]">Antoine Levy-Lambert</a>
   * @since     Ant 1.6
   */
  public class TranslateTest extends BuildFileTest {
      static private final int BUF_SIZE = 32768;
  
      private final static String TASKDEFS_DIR = 
"src/etc/testcases/taskdefs/optional/i18n/translate";
  
      public TranslateTest(String name) {
          super(name);
      }
  
  
      public void setUp() {
          configureProject(TASKDEFS_DIR + "/translate.xml");
      }
  
      public void tearDown() {
          executeTarget("cleanup");
      }
  
      public void test1() {
          executeTarget("test1");
          assertTrue("translation of "+ TASKDEFS_DIR + 
"/input/template.txt",compareFiles(TASKDEFS_DIR+"/expected/de/template.txt",TASKDEFS_DIR+"/output/de/template.txt"));
      }
      private boolean compareFiles(String name1, String name2) {
          File file1 = new File(name1);
          File file2 = new File(name2);
  
          try {
              if (!file1.exists() || !file2.exists()) {
                  System.out.println("One or both files do not exist:" + name1 
+ ", " + name2);
                  return false;
              }
  
              if (file1.length() != file2.length()) {
                  System.out.println("File size mismatch:" + name1 + "(" + 
file1.length() + "), " +
                                     name2  + "(" + file2.length() + ")");
                  return false;
              }
  
              // byte - byte compare
              byte[] buffer1 = new byte[BUF_SIZE];
              byte[] buffer2 = new byte[BUF_SIZE];
  
              FileInputStream fis1 = new FileInputStream(file1);
              FileInputStream fis2 = new FileInputStream(file2);
              int index = 0;
              int read = 0;
              while ((read = fis1.read(buffer1)) != -1) {
                  fis2.read(buffer2);
                  for (int i = 0; i < read; ++i, ++index) {
                      if (buffer1[i] != buffer2[i]) {
                          System.out.println("Bytes mismatch:" + name1 + ", " + 
name2 +
                                             " at byte " + index);
                          return false;
                      }
                  }
              }
              return true;
          }
          catch (IOException e) {
              System.out.println("IOException comparing files: " + name1 + ", " 
+ name2);
              return false;
          }
      }
  }
  
  
  
  
  1.1                  
ant/src/etc/testcases/taskdefs/optional/i18n/translate/translate.xml
  
  Index: translate.xml
  ===================================================================
  <?xml version="1.0"?>
  <project name="translate-test" default="test1" basedir=".">
      <property name="input.dir" value="input"/>
      <property name="output.dir" value="output"/>
      <property name="expected.dir" value="expected"/>
      <target name="setup">
          <mkdir dir="${output.dir}/de"/>
      </target>
      <target name="test1" depends="setup">
        <translate toDir="${output.dir}/de"
          starttoken="@"
          endtoken="@"
          bundle="${input.dir}/resources"
          bundlelanguage="ger"
          bundlecountry="de"
          forceoverwrite="yes"
          srcencoding="ISO8859_1"
          destencoding="ISO8859_1"
          bundleencoding="Cp1252">
          <fileset dir="${input.dir}">
              <include name="template.txt"/>
          </fileset>
        </translate>
       </target>
       <target name="cleanup">
           <delete dir="${output.dir}" quiet="true"/>
       </target>
  </project>
  
  
  1.1                  
ant/src/etc/testcases/taskdefs/optional/i18n/translate/input/template.txt
  
  Index: template.txt
  ===================================================================
  @This@ @is@ @a@ @demo@ @file@ @for@ @the@ [EMAIL PROTECTED]@.
  
  
  1.1                  
ant/src/etc/testcases/taskdefs/optional/i18n/translate/input/resources_ger_de.properties
  
  Index: resources_ger_de.properties
  ===================================================================
  This=Diese
  is=ist
  a=eine
  demo=Demo
  file=Datei
  #note for people understanding german
  # \u00fc = u umlaut
  for=für
  the=die
  _task=_Aufgabe
  
  
  
  1.1                  
ant/src/etc/testcases/taskdefs/optional/i18n/translate/expected/de/template.txt
  
  Index: template.txt
  ===================================================================
  Diese ist eine Demo Datei für die translate_Aufgabe.
  
  
  
  1.449     +3 -0      ant/WHATSNEW
  
  Index: WHATSNEW
  ===================================================================
  RCS file: /home/cvs/ant/WHATSNEW,v
  retrieving revision 1.448
  retrieving revision 1.449
  diff -u -r1.448 -r1.449
  --- WHATSNEW  26 Jun 2003 15:21:13 -0000      1.448
  +++ WHATSNEW  30 Jun 2003 10:41:00 -0000      1.449
  @@ -176,6 +176,9 @@
   
   * <xmlproperty> now handles CDATA sections. BugZilla Report 17195  
     
  +* <translate> now translate tokens that are placed close together.
  +  Bugzilla Report 17297
  +
   Other changes:
   --------------
   * Six new Clearcase tasks added.
  
  
  

---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to