[libpostgresql-jdbc-java] 03/12: Do comparison of identifiers in a known Locale (specificially US). In Turkish for example "id".toLowerCase().equals("ID".toLowerCase()) is false. This breaks apps running a Turkish locale.

Emmanuel Bourg ebourg-guest at moszumanska.debian.org
Mon Jan 9 10:20:43 UTC 2017


This is an automated email from the git hooks/post-receive script.

ebourg-guest pushed a commit to tag REL8_3_604
in repository libpostgresql-jdbc-java.

commit 1cdaa3fd8c9f16a9fbc139d00ad82ef2e13cbc08
Author: Kris Jurka <books at ejurka.com>
Date:   Tue Feb 19 06:12:33 2008 +0000

    Do comparison of identifiers in a known Locale (specificially US).
    In Turkish for example "id".toLowerCase().equals("ID".toLowerCase())
    is false.  This breaks apps running a Turkish locale.
    
    As reported by Dirk Moebius and Hakan Cunier.
    Patch from Mikko Tiihonen.
---
 org/postgresql/jdbc2/AbstractJdbc2Connection.java |  4 ++--
 org/postgresql/jdbc2/AbstractJdbc2ResultSet.java  | 11 ++++++-----
 org/postgresql/jdbc2/EscapedFunctions.java        |  7 ++++---
 org/postgresql/test/jdbc2/EncodingTest.java       |  7 ++++---
 org/postgresql/test/jdbc2/ResultSetTest.java      | 22 +++++++++++++++++++++-
 5 files changed, 37 insertions(+), 14 deletions(-)

diff --git a/org/postgresql/jdbc2/AbstractJdbc2Connection.java b/org/postgresql/jdbc2/AbstractJdbc2Connection.java
index 45b9bd5..1005de6 100644
--- a/org/postgresql/jdbc2/AbstractJdbc2Connection.java
+++ b/org/postgresql/jdbc2/AbstractJdbc2Connection.java
@@ -3,7 +3,7 @@
 * Copyright (c) 2004-2008, PostgreSQL Global Development Group
 *
 * IDENTIFICATION
-*   $PostgreSQL: pgjdbc/org/postgresql/jdbc2/AbstractJdbc2Connection.java,v 1.46 2007/12/01 12:50:44 jurka Exp $
+*   $PostgreSQL: pgjdbc/org/postgresql/jdbc2/AbstractJdbc2Connection.java,v 1.47 2008/01/08 06:56:28 jurka Exp $
 *
 *-------------------------------------------------------------------------
 */
@@ -730,7 +730,7 @@ public abstract class AbstractJdbc2Connection implements BaseConnection
         if (level == null)
             return Connection.TRANSACTION_READ_COMMITTED; // Best guess.
 
-        level = level.toUpperCase();
+        level = level.toUpperCase(Locale.US);
         if (level.indexOf("READ COMMITTED") != -1)
             return Connection.TRANSACTION_READ_COMMITTED;
         if (level.indexOf("READ UNCOMMITTED") != -1)
diff --git a/org/postgresql/jdbc2/AbstractJdbc2ResultSet.java b/org/postgresql/jdbc2/AbstractJdbc2ResultSet.java
index d1ba718..144f7d5 100644
--- a/org/postgresql/jdbc2/AbstractJdbc2ResultSet.java
+++ b/org/postgresql/jdbc2/AbstractJdbc2ResultSet.java
@@ -3,7 +3,7 @@
 * Copyright (c) 2003-2008, PostgreSQL Global Development Group
 *
 * IDENTIFICATION
-*   $PostgreSQL: pgjdbc/org/postgresql/jdbc2/AbstractJdbc2ResultSet.java,v 1.100 2008/01/08 06:56:28 jurka Exp $
+*   $PostgreSQL: pgjdbc/org/postgresql/jdbc2/AbstractJdbc2ResultSet.java,v 1.101 2008/01/14 10:23:48 jurka Exp $
 *
 *-------------------------------------------------------------------------
 */
@@ -23,6 +23,7 @@ import java.util.Iterator;
 import java.util.StringTokenizer;
 import java.util.Vector;
 import java.util.Calendar;
+import java.util.Locale;
 import org.postgresql.core.*;
 import org.postgresql.largeobject.*;
 import org.postgresql.util.PGobject;
@@ -1640,10 +1641,10 @@ public abstract class AbstractJdbc2ResultSet implements BaseResultSet, org.postg
             name = st.nextToken();
             if ( !tableFound )
             {
-                if (name.toLowerCase().equals("from"))
+                if ("from".equalsIgnoreCase(name))
                 {
                     tableName = st.nextToken();
-                    if (tableName.toLowerCase().equals("only")) {
+                    if ("only".equalsIgnoreCase(tableName)) {
                         tableName = st.nextToken();
                         onlyTable = "ONLY ";
                     }
@@ -2514,7 +2515,7 @@ public abstract class AbstractJdbc2ResultSet implements BaseResultSet, org.postg
             // reverse order so the first ones will overwrite later ones.
             for (int i = fields.length - 1; i >= 0; i--)
             {
-                columnNameIndexMap.put(fields[i].getColumnLabel().toLowerCase(), new Integer(i + 1));
+                columnNameIndexMap.put(fields[i].getColumnLabel().toLowerCase(Locale.US), new Integer(i + 1));
             }
         }
 
@@ -2524,7 +2525,7 @@ public abstract class AbstractJdbc2ResultSet implements BaseResultSet, org.postg
             return index.intValue();
         }
 
-        index = (Integer)columnNameIndexMap.get(columnName.toLowerCase());
+        index = (Integer)columnNameIndexMap.get(columnName.toLowerCase(Locale.US));
         if (index != null)
         {
             columnNameIndexMap.put(columnName, index);
diff --git a/org/postgresql/jdbc2/EscapedFunctions.java b/org/postgresql/jdbc2/EscapedFunctions.java
index 2c7b195..6cc91fd 100644
--- a/org/postgresql/jdbc2/EscapedFunctions.java
+++ b/org/postgresql/jdbc2/EscapedFunctions.java
@@ -3,7 +3,7 @@
 * Copyright (c) 2004-2008, PostgreSQL Global Development Group
 *
 * IDENTIFICATION
-* $PostgreSQL: pgjdbc/org/postgresql/jdbc2/EscapedFunctions.java,v 1.9 2007/04/16 16:16:22 jurka Exp $
+* $PostgreSQL: pgjdbc/org/postgresql/jdbc2/EscapedFunctions.java,v 1.10 2008/01/08 06:56:28 jurka Exp $
 *
 *-------------------------------------------------------------------------
 */
@@ -12,6 +12,7 @@ package org.postgresql.jdbc2;
 import java.lang.reflect.Method;
 import java.sql.SQLException;
 import java.util.HashMap;
+import java.util.Locale;
 import java.util.List;
 import java.util.Map;
 
@@ -129,10 +130,10 @@ public class EscapedFunctions {
             for (int i=0;i<arrayMeths.length;i++){
                 Method meth = arrayMeths[i];
                 if (meth.getName().startsWith("sql"))
-                    functionMap.put(meth.getName().toLowerCase(),meth);
+                    functionMap.put(meth.getName().toLowerCase(Locale.US),meth);
             }
         }
-        return (Method) functionMap.get("sql"+functionName.toLowerCase());
+        return (Method) functionMap.get("sql"+functionName.toLowerCase(Locale.US));
     }
 
     // ** numeric functions translations **
diff --git a/org/postgresql/test/jdbc2/EncodingTest.java b/org/postgresql/test/jdbc2/EncodingTest.java
index 79d19d8..106b158 100644
--- a/org/postgresql/test/jdbc2/EncodingTest.java
+++ b/org/postgresql/test/jdbc2/EncodingTest.java
@@ -3,7 +3,7 @@
 * Copyright (c) 2004-2008, PostgreSQL Global Development Group
 *
 * IDENTIFICATION
-*   $PostgreSQL: pgjdbc/org/postgresql/test/jdbc2/EncodingTest.java,v 1.9 2005/01/11 08:25:48 jurka Exp $
+*   $PostgreSQL: pgjdbc/org/postgresql/test/jdbc2/EncodingTest.java,v 1.10 2008/01/08 06:56:31 jurka Exp $
 *
 *-------------------------------------------------------------------------
 */
@@ -13,6 +13,7 @@ package org.postgresql.test.jdbc2;
 import junit.framework.*;
 import org.postgresql.core.Encoding;
 import java.io.*;
+import java.util.Locale;
 
 /*
  * Tests for the Encoding class.
@@ -32,9 +33,9 @@ public class EncodingTest extends TestCase
     {
         Encoding encoding;
         encoding = Encoding.getDatabaseEncoding("UNICODE");
-        assertEquals("UTF", encoding.name().substring(0, 3).toUpperCase());
+        assertEquals("UTF", encoding.name().substring(0, 3).toUpperCase(Locale.US));
         encoding = Encoding.getDatabaseEncoding("SQL_ASCII");
-        assertTrue(encoding.name().toUpperCase().indexOf("ASCII") != -1);
+        assertTrue(encoding.name().toUpperCase(Locale.US).indexOf("ASCII") != -1);
         assertEquals("When encoding is unknown the default encoding should be used",
                      Encoding.defaultEncoding(),
                      Encoding.getDatabaseEncoding("UNKNOWN"));
diff --git a/org/postgresql/test/jdbc2/ResultSetTest.java b/org/postgresql/test/jdbc2/ResultSetTest.java
index 43f5e2b..6de54b8 100644
--- a/org/postgresql/test/jdbc2/ResultSetTest.java
+++ b/org/postgresql/test/jdbc2/ResultSetTest.java
@@ -3,7 +3,7 @@
 * Copyright (c) 2004-2008, PostgreSQL Global Development Group
 *
 * IDENTIFICATION
-*   $PostgreSQL: pgjdbc/org/postgresql/test/jdbc2/ResultSetTest.java,v 1.28 2008/01/08 06:56:31 jurka Exp $
+*   $PostgreSQL: pgjdbc/org/postgresql/test/jdbc2/ResultSetTest.java,v 1.29 2008/01/14 10:23:49 jurka Exp $
 *
 *-------------------------------------------------------------------------
 */
@@ -14,6 +14,7 @@ import java.sql.Connection;
 import java.sql.ResultSet;
 import java.sql.Statement;
 import java.sql.SQLException;
+import java.util.Locale;
 
 import junit.framework.TestCase;
 
@@ -705,4 +706,23 @@ public class ResultSetTest extends TestCase
         assertTrue(rs.next());
         assertEquals(1, rs.getInt("a"));
     }
+
+    public void testTurkishLocale() throws SQLException
+    {
+        Locale current = Locale.getDefault();
+        try {
+            Locale.setDefault(new Locale("tr", "TR"));
+            Statement stmt = con.createStatement();
+            ResultSet rs = stmt.executeQuery("SELECT id FROM testrs");
+            int sum = 0;
+            while (rs.next()) {
+                sum += rs.getInt("ID");
+            }
+            rs.close();
+            assertEquals(25, sum);
+        } finally {
+            Locale.setDefault(current);
+        }
+    }
+
 }

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-java/libpostgresql-jdbc-java.git



More information about the pkg-java-commits mailing list