Projekt

Obecné

Profil

Stáhnout (3.66 KB) Statistiky
| Větev: | Tag: | Revize:
1
import java.io.BufferedWriter;
2
import java.io.File;
3
import java.io.FileDescriptor;
4
import java.io.FileOutputStream;
5
import java.io.FileWriter;
6
import java.io.IOException;
7
import java.io.PrintStream;
8
import java.util.List;
9
import java.util.concurrent.Semaphore;
10
import java.util.concurrent.atomic.AtomicBoolean;
11
import java.util.concurrent.atomic.AtomicReference;
12
import java.util.concurrent.locks.Lock;
13
import java.util.concurrent.locks.ReentrantLock;
14

    
15
import jdeserialize.content;
16
import jdeserialize.jdeserialize;
17
import io.Database.DB_Messenger;
18
import io.Database;
19
import io.FileWorker;
20

    
21
public class Converter extends Thread {
22

    
23
	private IConversionResults ui;
24
	private AtomicBoolean active;
25

    
26
	// P-K without E semaphore.
27
	private Lock entryLock;
28
	private Semaphore inputAvailable;
29

    
30
	// Input.
31
	private File inputFile;
32
	private DB_Messenger query;
33

    
34
	public Converter(IConversionResults ui) {
35
		this.ui = ui;
36
		active = new AtomicBoolean(true);
37
		entryLock = new ReentrantLock();
38
		inputAvailable = new Semaphore(0);
39
	}
40

    
41
	public void end() {
42
		active.set(false);
43
		setInput(null, null);
44
	}
45
	
46
	public void setInput(File inputFile, DB_Messenger query) {
47
		entryLock.lock();
48
		this.inputFile = inputFile;
49
		this.query = query;
50
		entryLock.unlock();
51

    
52
		if (!inputAvailable.tryAcquire())
53
			inputAvailable.release(); // MAX VALUE = 1!
54
	}
55
	
56
	public boolean getInput(AtomicReference<File> inputFile, AtomicReference<DB_Messenger> query) {
57
		try {
58
			inputAvailable.acquire();
59
		} catch (InterruptedException e) {
60
			return false;
61
		}
62

    
63
		entryLock.lock();
64
		inputFile.set(this.inputFile);
65
		query.set(this.query);
66
		
67
		this.inputFile = null;
68
		this.query = null;
69
		entryLock.unlock();
70

    
71
		return inputFile.get() != null || query.get() != null;
72
	}
73

    
74
	@Override
75
	public void run() {
76
		super.run();
77
		while (active.get()) {
78
			AtomicReference<File> inputFile = new AtomicReference<File>();
79
			AtomicReference<DB_Messenger> query = new AtomicReference<DB_Messenger>();
80

    
81
			if (!getInput(inputFile, query)) {
82
				continue;
83
			}
84

    
85
			byte array[];
86
			try {
87
				array = getBytes(inputFile.get(), query.get());
88
			} catch (Exception e) {
89
				ui.loadingInputFileError();
90
				continue;
91
			}
92
			
93
			StringBuilder json = new StringBuilder();
94
			
95
			boolean error = false;
96
			try {
97
				// Redirectovany system.out do null streamu. Mozno redirect do souboru
98
				System.setOut(FileWorker.createRedirectStream(false));
99
				System.setErr(FileWorker.createRedirectStream(true));
100
				System.out.println("--- jdeserialize begins ---".toUpperCase());
101
				convert(array, json);
102
			} catch (Exception e) {
103
				e.printStackTrace();
104
				error = true;
105
			} finally {
106
				System.out.println("--- jdeserialize ends ---".toUpperCase());
107
				System.out.flush();
108
				System.err.flush();
109
				System.setErr(new PrintStream(new FileOutputStream(FileDescriptor.err)));
110
				System.setOut(new PrintStream(new FileOutputStream(FileDescriptor.out)));
111
			}
112
			
113
			ui.completed(error ? null : json.toString(), array == null ? null : new String(array));
114
		}
115
	}
116

    
117
	private byte[] getBytes(File file, DB_Messenger query) throws Exception {
118
		byte array[];
119
		if (file != null) {
120
			array = FileWorker.loadFileContent(file);
121
		} else {
122
			array = Database.getBlobBytes(query);
123
		}
124
		array = FileWorker.extractFileContent(array);
125
		return array;
126
	}
127
	
128
	private void convert(byte[] buffer, StringBuilder json) throws Exception {
129
		jdeserialize deserializer = new jdeserialize(buffer);
130

    
131
		// gets the "contents" into an array - returnes the deserialization of all
132
		// 'writes' into serialized object via objectOutputStream
133
		List<content> cntnts = deserializer.getContent();
134

    
135
		for (content cnt : cntnts) {
136
			if (cnt != null) {
137
				json.append(cnt.toJson("", null, false)).append("\n");
138
			}
139
		}
140
	}
141

    
142
}
(2-2/6)