blob: d69edd5882fbe4655907e8ab98a25c4ea7acd6fd (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
/*******************************************************************************
* Copyright (c) 2005, 2006 IBM Corporation and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package org.eclipse.osgi.baseadaptor.bundlefile;
import java.io.*;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.zip.ZipEntry;
/**
* A BundleEntry represented by a ZipEntry in a ZipFile. The ZipBundleEntry
* class is used for bundles that are installed as a ZipFile on a file system.
* @since 3.2
*/
public class ZipBundleEntry extends BundleEntry {
/**
* ZipEntry for this entry.
*/
protected ZipEntry zipEntry;
/**
* The BundleFile for this entry.
*/
protected BundleFile bundleFile;
/**
* Constructs the BundleEntry using a ZipEntry.
* @param bundleFile BundleFile object this entry is a member of
* @param zipEntry ZipEntry object of this entry
*/
ZipBundleEntry(ZipEntry zipEntry, BundleFile bundleFile) {
this.zipEntry = zipEntry;
this.bundleFile = bundleFile;
}
/**
* Return an InputStream for the entry.
*
* @return InputStream for the entry
* @exception java.io.IOException
*/
public InputStream getInputStream() throws IOException {
return ((ZipBundleFile) bundleFile).getZipFile().getInputStream(zipEntry);
}
/**
* Return size of the uncompressed entry.
*
* @return size of entry
*/
public long getSize() {
return zipEntry.getSize();
}
/**
* Return name of the entry.
*
* @return name of entry
*/
public String getName() {
return zipEntry.getName();
}
/**
* Get the modification time for this BundleEntry.
* <p>If the modification time has not been set,
* this method will return <tt>-1</tt>.
*
* @return last modification time.
*/
public long getTime() {
return zipEntry.getTime();
}
public URL getLocalURL() {
try {
return new URL("jar:file:" + bundleFile.basefile.getAbsolutePath() + "!/" + zipEntry.getName()); //$NON-NLS-1$//$NON-NLS-2$
} catch (MalformedURLException e) {
//This can not happen.
return null;
}
}
public URL getFileURL() {
try {
File file = bundleFile.getFile(zipEntry.getName(), false);
if (file != null)
return file.toURL();
} catch (MalformedURLException e) {
//This can not happen.
}
return null;
}
}
|