Applied Zoltan's patch to correctly align interval and timestamp data in ecpg's sqlda.
authorMichael Meskes <meskes@postgresql.org>
Thu, 17 Nov 2011 13:07:25 +0000 (14:07 +0100)
committerMichael Meskes <meskes@postgresql.org>
Thu, 17 Nov 2011 13:43:49 +0000 (14:43 +0100)
src/interfaces/ecpg/ecpglib/sqlda.c

index 4fb686fb08e4ef3510fe2b4dfda7ef466e84814c..5b5e934e5defcbd545d8d3b868a17a2561061431 100644 (file)
@@ -127,10 +127,10 @@ sqlda_common_total_size(const PGresult *res, int row, enum COMPAT_MODE compat, l
                                ecpg_sqlda_align_add_size(offset, sizeof(date), sizeof(date), &offset, &next_offset);
                                break;
                        case ECPGt_timestamp:
-                               ecpg_sqlda_align_add_size(offset, sizeof(int), sizeof(timestamp), &offset, &next_offset);
+                               ecpg_sqlda_align_add_size(offset, sizeof(int64), sizeof(timestamp), &offset, &next_offset);
                                break;
                        case ECPGt_interval:
-                               ecpg_sqlda_align_add_size(offset, sizeof(int), sizeof(interval), &offset, &next_offset);
+                               ecpg_sqlda_align_add_size(offset, sizeof(int64), sizeof(interval), &offset, &next_offset);
                                break;
                        case ECPGt_char:
                        case ECPGt_unsigned_char:
@@ -354,7 +354,7 @@ ecpg_set_compat_sqlda(int lineno, struct sqlda_compat ** _sqlda, const PGresult
                                sqlda->sqlvar[i].sqllen = sizeof(date);
                                break;
                        case ECPGt_timestamp:
-                               ecpg_sqlda_align_add_size(offset, sizeof(timestamp), sizeof(timestamp), &offset, &next_offset);
+                               ecpg_sqlda_align_add_size(offset, sizeof(int64), sizeof(timestamp), &offset, &next_offset);
                                sqlda->sqlvar[i].sqldata = (char *) sqlda + offset;
                                sqlda->sqlvar[i].sqllen = sizeof(timestamp);
                                break;
@@ -540,7 +540,7 @@ ecpg_set_native_sqlda(int lineno, struct sqlda_struct ** _sqlda, const PGresult
                                sqlda->sqlvar[i].sqllen = sizeof(date);
                                break;
                        case ECPGt_timestamp:
-                               ecpg_sqlda_align_add_size(offset, sizeof(timestamp), sizeof(timestamp), &offset, &next_offset);
+                               ecpg_sqlda_align_add_size(offset, sizeof(int64), sizeof(timestamp), &offset, &next_offset);
                                sqlda->sqlvar[i].sqldata = (char *) sqlda + offset;
                                sqlda->sqlvar[i].sqllen = sizeof(timestamp);
                                break;