git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@277028 13f79535-47bb-0310-9956-ffa450edef68master
@@ -126,7 +126,7 @@ public class CBZip2InputStream extends InputStream implements BZip2Constants { | |||||
private int computedBlockCRC, computedCombinedCRC; | private int computedBlockCRC, computedCombinedCRC; | ||||
int i2, count, chPrev, ch2; | int i2, count, chPrev, ch2; | ||||
int i, tPos; | |||||
int global_i, tPos; | |||||
int rNToGo = 0; | int rNToGo = 0; | ||||
int rTPos = 0; | int rTPos = 0; | ||||
int j2; | int j2; | ||||
@@ -668,14 +668,14 @@ public class CBZip2InputStream extends InputStream implements BZip2Constants { | |||||
char ch; | char ch; | ||||
cftab[0] = 0; | cftab[0] = 0; | ||||
for (i = 1; i <= 256; i++) { | |||||
for (int i = 1; i <= 256; i++) { | |||||
cftab[i] = unzftab[i - 1]; | cftab[i] = unzftab[i - 1]; | ||||
} | } | ||||
for (i = 1; i <= 256; i++) { | |||||
for (int i = 1; i <= 256; i++) { | |||||
cftab[i] += cftab[i - 1]; | cftab[i] += cftab[i - 1]; | ||||
} | } | ||||
for (i = 0; i <= last; i++) { | |||||
for (int i = 0; i <= last; i++) { | |||||
ch = (char) ll8[i]; | ch = (char) ll8[i]; | ||||
tt[cftab[ch]] = i; | tt[cftab[ch]] = i; | ||||
cftab[ch]++; | cftab[ch]++; | ||||
@@ -24,7 +24,6 @@ import java.io.IOException; | |||||
import java.io.OutputStream; | import java.io.OutputStream; | ||||
import java.io.RandomAccessFile; | import java.io.RandomAccessFile; | ||||
import java.io.UnsupportedEncodingException; | import java.io.UnsupportedEncodingException; | ||||
import java.util.Calendar; | |||||
import java.util.Date; | import java.util.Date; | ||||
import java.util.Hashtable; | import java.util.Hashtable; | ||||
import java.util.Vector; | import java.util.Vector; | ||||
@@ -581,7 +580,7 @@ public class ZipOutputStream extends FilterOutputStream { | |||||
written += 2; | written += 2; | ||||
// last mod. time and date | // last mod. time and date | ||||
writeOut(toDosTime(new Date(ze.getTime()))); | |||||
writeOut(toDosTime(ze.getTime())); | |||||
written += 4; | written += 4; | ||||
// CRC | // CRC | ||||
@@ -669,7 +668,7 @@ public class ZipOutputStream extends FilterOutputStream { | |||||
written += 2; | written += 2; | ||||
// last mod. time and date | // last mod. time and date | ||||
writeOut(toDosTime(new Date(ze.getTime()))); | |||||
writeOut(toDosTime(ze.getTime())); | |||||
written += 4; | written += 4; | ||||
// CRC | // CRC | ||||
@@ -765,12 +764,10 @@ public class ZipOutputStream extends FilterOutputStream { | |||||
/** | /** | ||||
* Convert a Date object to a DOS date/time field. | * Convert a Date object to a DOS date/time field. | ||||
* | * | ||||
* <p>Stolen from InfoZip's <code>fileio.c</code></p> | |||||
* | |||||
* @since 1.1 | * @since 1.1 | ||||
*/ | */ | ||||
protected static ZipLong toDosTime(Date time) { | protected static ZipLong toDosTime(Date time) { | ||||
return new ZipLong(toDosTime(time)); | |||||
return new ZipLong(toDosTime(time.getTime())); | |||||
} | } | ||||
/** | /** | ||||
@@ -780,21 +777,19 @@ public class ZipOutputStream extends FilterOutputStream { | |||||
* | * | ||||
* @since 1.26 | * @since 1.26 | ||||
*/ | */ | ||||
protected static byte[] toDosTime(Date time) { | |||||
Calendar cal = Calendar.getInstance(); | |||||
cal.setTime(time); | |||||
int year = cal.get(Calendar.YEAR); | |||||
protected static byte[] toDosTime(long t) { | |||||
Date time = new Date(t); | |||||
int year = time.getYear() + 1900; | |||||
if (year < 1980) { | if (year < 1980) { | ||||
return DOS_TIME_MIN.getBytes(); | return DOS_TIME_MIN.getBytes(); | ||||
} | } | ||||
int month = cal.get(Calendar.MONTH) + 1; | |||||
int month = time.getMonth() + 1; | |||||
long value = ((year - 1980) << 25) | long value = ((year - 1980) << 25) | ||||
| (month << 21) | | (month << 21) | ||||
| (cal.get(Calendar.DAY_OF_MONTH) << 16) | |||||
| (cal.get(Calendar.HOUR_OF_DAY) << 11) | |||||
| (cal.get(Calendar.MINUTE) << 5) | |||||
| (cal.get(Calendar.SECOND) >> 1); | |||||
| (time.getDate() << 16) | |||||
| (time.getHours() << 11) | |||||
| (time.getMinutes() << 5) | |||||
| (time.getSeconds() >> 1); | |||||
byte[] result = new byte[4]; | byte[] result = new byte[4]; | ||||
result[0] = (byte) ((value & 0xFF)); | result[0] = (byte) ((value & 0xFF)); | ||||
result[1] = (byte) ((value & 0xFF00) >> 8); | result[1] = (byte) ((value & 0xFF00) >> 8); | ||||
@@ -21,6 +21,7 @@ import junit.framework.Test; | |||||
import junit.framework.TestCase; | import junit.framework.TestCase; | ||||
import junit.framework.TestSuite; | import junit.framework.TestSuite; | ||||
import java.util.Calendar; | |||||
import java.util.Date; | import java.util.Date; | ||||
public class ZipOutputStreamTest extends TestCase { | public class ZipOutputStreamTest extends TestCase { | ||||
@@ -37,22 +38,23 @@ public class ZipOutputStreamTest extends TestCase { | |||||
protected void setUp() throws Exception { | protected void setUp() throws Exception { | ||||
time = new Date(); | time = new Date(); | ||||
byte[] result = new byte[4]; | |||||
int year = time.getYear() + 1900; | |||||
int month = time.getMonth() + 1; | |||||
Calendar cal = Calendar.getInstance(); | |||||
cal.setTime(time); | |||||
int year = cal.get(Calendar.YEAR); | |||||
int month = cal.get(Calendar.MONTH) + 1; | |||||
long value = ((year - 1980) << 25) | long value = ((year - 1980) << 25) | ||||
| (month << 21) | | (month << 21) | ||||
| (time.getDate() << 16) | |||||
| (time.getHours() << 11) | |||||
| (time.getMinutes() << 5) | |||||
| (time.getSeconds() >> 1); | |||||
| (cal.get(Calendar.DAY_OF_MONTH) << 16) | |||||
| (cal.get(Calendar.HOUR_OF_DAY) << 11) | |||||
| (cal.get(Calendar.MINUTE) << 5) | |||||
| (cal.get(Calendar.SECOND) >> 1); | |||||
byte[] result = new byte[4]; | |||||
result[0] = (byte) ((value & 0xFF)); | result[0] = (byte) ((value & 0xFF)); | ||||
result[1] = (byte) ((value & 0xFF00) >> 8); | result[1] = (byte) ((value & 0xFF00) >> 8); | ||||
result[2] = (byte) ((value & 0xFF0000) >> 16); | result[2] = (byte) ((value & 0xFF0000) >> 16); | ||||
result[3] = (byte) ((value & 0xFF000000L) >> 24); | result[3] = (byte) ((value & 0xFF000000L) >> 24); | ||||
zl = new ZipLong(result); | zl = new ZipLong(result); | ||||
} | } | ||||
protected void tearDown() throws Exception { | protected void tearDown() throws Exception { | ||||