source: AE/installer2/src/net/oni2/aeinstaller/backend/packages/unpack/Unpacker.java@ 648

Last change on this file since 648 was 648, checked in by alloc, 12 years ago

AEI2 0.99e:

  • Added forced offline mode (argument -offline)
  • Fixed bug when displaying dependencies during installation
  • Switched from term "mandatory" to "core" for always-install packages
File size: 3.9 KB
Line 
1package net.oni2.aeinstaller.backend.packages.unpack;
2
3import java.io.File;
4import java.io.FileOutputStream;
5import java.io.IOException;
6import java.io.InputStream;
7import java.util.Enumeration;
8import java.util.zip.ZipEntry;
9import java.util.zip.ZipException;
10import java.util.zip.ZipFile;
11
12import org.apache.commons.io.FileUtils;
13
14/**
15 * @author Christian Illy
16 */
17public class Unpacker implements Runnable {
18 /**
19 * @author Christian Illy
20 */
21 public enum EState {
22 /**
23 * Unpacker initialized but not started
24 */
25 INIT,
26 /**
27 * Unpack running
28 */
29 RUNNING,
30 /**
31 * Unpack interrupted
32 */
33 INTERRUPTED,
34 /**
35 * Unpack finished successfully
36 */
37 FINISHED,
38 };
39
40 private UnpackListener listener;
41
42 private File zip;
43 private File target;
44
45 private Thread t = null;
46
47 private EState state = EState.INIT;
48
49 /**
50 * Initialize a new AE package unpacker
51 *
52 * @param zipFile
53 * AE zip package
54 * @param targetFolder
55 * Target folder
56 * @param listener
57 * Listener for progress updates
58 */
59 public Unpacker(File zipFile, File targetFolder, UnpackListener listener) {
60 this.listener = listener;
61 zip = zipFile;
62 target = targetFolder;
63 }
64
65 /**
66 * Start the unpack process
67 */
68 public synchronized void start() {
69 if (t == null) {
70 t = new Thread(this);
71 t.start();
72 state = EState.RUNNING;
73 updateStatus();
74 }
75 }
76
77 /**
78 * Stop (abort) the process
79 */
80 public synchronized void stop() {
81 if (state != EState.FINISHED) {
82 state = EState.INTERRUPTED;
83 if (t != null) {
84 try {
85 t.join();
86 } catch (InterruptedException e) {
87 e.printStackTrace();
88 }
89 t = null;
90 }
91 updateStatus();
92 if (state != EState.FINISHED) {
93 if (target.exists()) {
94 try {
95 FileUtils.deleteDirectory(target);
96 } catch (IOException e) {
97 e.printStackTrace();
98 }
99 }
100 }
101 }
102 }
103
104 private synchronized void updateStatus() {
105 listener.statusUpdate(this, state);
106 }
107
108 @Override
109 public void run() {
110 try {
111 switch (state) {
112 case INTERRUPTED:
113 return;
114 case RUNNING:
115 ZipFile zf = null;
116 try {
117 int pathStart = 0;
118 String pathStartName = "";
119
120 zf = new ZipFile(zip);
121
122 if (target.exists())
123 FileUtils.deleteDirectory(target);
124 target.mkdirs();
125
126 for (Enumeration<? extends ZipEntry> e = zf.entries(); e
127 .hasMoreElements();) {
128 ZipEntry ze = e.nextElement();
129 if (ze.getName().toLowerCase()
130 .endsWith("/mod_info.cfg")
131 || ze.getName().toLowerCase()
132 .equals("mod_info.cfg")) {
133 pathStart = ze.getName().toLowerCase()
134 .indexOf("mod_info.cfg");
135 pathStartName = ze.getName().substring(0,
136 pathStart);
137 }
138 }
139
140 for (Enumeration<? extends ZipEntry> e = zf.entries(); e
141 .hasMoreElements();) {
142 if (state == EState.INTERRUPTED)
143 return;
144 ZipEntry ze = e.nextElement();
145 if (!ze.isDirectory()) {
146 if (ze.getName().startsWith(pathStartName)) {
147 File targetFile = new File(target, ze
148 .getName().substring(pathStart));
149 File parent = targetFile.getParentFile();
150 parent.mkdirs();
151
152 InputStream in = zf.getInputStream(ze);
153
154 int read = 0;
155 byte[] data = new byte[1024];
156 FileOutputStream fileOut = new FileOutputStream(
157 targetFile);
158 while ((read = in.read(data, 0, 1024)) != -1) {
159 fileOut.write(data, 0, read);
160 }
161 fileOut.close();
162 }
163 }
164 }
165 } catch (ZipException e) {
166 // TODO Auto-generated catch block
167 e.printStackTrace();
168 } catch (IOException e) {
169 // TODO Auto-generated catch block
170 e.printStackTrace();
171 } finally {
172 try {
173 if (zf != null)
174 zf.close();
175 } catch (IOException e) {
176 e.printStackTrace();
177 }
178 }
179 break;
180 default:
181 break;
182 }
183 } finally {
184 }
185
186 state = EState.FINISHED;
187 updateStatus();
188 }
189}
Note: See TracBrowser for help on using the repository browser.