git-svn-id: https://svn.apache.org/repos/asf/ant/core/trunk@276999 13f79535-47bb-0310-9956-ffa450edef68master
@@ -105,6 +105,7 @@ Juerg Wanner | |||||
Keiron Liddle | Keiron Liddle | ||||
Keith Visco | Keith Visco | ||||
Kevin Greiner | Kevin Greiner | ||||
Kevin Jackson | |||||
Kevin Ross | Kevin Ross | ||||
Kevin Z Grey | Kevin Z Grey | ||||
Kirk Wylie | Kirk Wylie | ||||
@@ -24,6 +24,7 @@ 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; | ||||
@@ -769,17 +770,19 @@ public class ZipOutputStream extends FilterOutputStream { | |||||
* @since 1.1 | * @since 1.1 | ||||
*/ | */ | ||||
protected static ZipLong toDosTime(Date time) { | protected static ZipLong toDosTime(Date time) { | ||||
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; | |||||
if (year < 1980) { | if (year < 1980) { | ||||
return DOS_TIME_MIN; | return DOS_TIME_MIN; | ||||
} | } | ||||
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]; | byte[] result = new byte[4]; | ||||
result[0] = (byte) ((value & 0xFF)); | result[0] = (byte) ((value & 0xFF)); | ||||
@@ -0,0 +1,67 @@ | |||||
/* | |||||
* Copyright 2004 The Apache Software Foundation | |||||
* | |||||
* Licensed under the Apache License, Version 2.0 (the "License"); | |||||
* you may not use this file except in compliance with the License. | |||||
* You may obtain a copy of the License at | |||||
* | |||||
* http://www.apache.org/licenses/LICENSE-2.0 | |||||
* | |||||
* Unless required by applicable law or agreed to in writing, software | |||||
* distributed under the License is distributed on an "AS IS" BASIS, | |||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |||||
* See the License for the specific language governing permissions and | |||||
* limitations under the License. | |||||
* | |||||
*/ | |||||
package org.apache.tools.zip; | |||||
import junit.framework.Test; | |||||
import junit.framework.TestCase; | |||||
import junit.framework.TestSuite; | |||||
import java.util.Date; | |||||
public class ZipOutputStreamTest extends TestCase { | |||||
private Date time; | |||||
private ZipLong zl; | |||||
/** | |||||
* Constructor | |||||
*/ | |||||
public ZipOutputStreamTest(String name) { | |||||
super(name); | |||||
} | |||||
protected void setUp() throws Exception { | |||||
time = new Date(); | |||||
byte[] result = new byte[4]; | |||||
int year = time.getYear() + 1900; | |||||
int month = time.getMonth() + 1; | |||||
long value = ((year - 1980) << 25) | |||||
| (month << 21) | |||||
| (time.getDate() << 16) | |||||
| (time.getHours() << 11) | |||||
| (time.getMinutes() << 5) | |||||
| (time.getSeconds() >> 1); | |||||
result[0] = (byte) ((value & 0xFF)); | |||||
result[1] = (byte) ((value & 0xFF00) >> 8); | |||||
result[2] = (byte) ((value & 0xFF0000) >> 16); | |||||
result[3] = (byte) ((value & 0xFF000000L) >> 24); | |||||
zl = new ZipLong(result); | |||||
} | |||||
protected void tearDown() throws Exception { | |||||
super.tearDown(); | |||||
} | |||||
public void testZipLong() throws Exception { | |||||
ZipLong test = ZipOutputStream.toDosTime(time); | |||||
assertEquals(test.getValue(), zl.getValue()); | |||||
} | |||||
} |