… | |
… | |
22 | |
22 | |
23 | #include "parse.h" |
23 | #include "parse.h" |
24 | #include "parse_routines.h" |
24 | #include "parse_routines.h" |
25 | #include "data.h" |
25 | #include "data.h" |
26 | |
26 | |
27 | psiconv_file_type_t psiconv_file_type(psiconv_buffer buf) |
27 | psiconv_file_type_t psiconv_file_type(psiconv_buffer buf,int *length, |
|
|
28 | psiconv_header_section *result) |
28 | { |
29 | { |
29 | psiconv_header_section header; |
30 | psiconv_header_section header; |
30 | psiconv_file_type_t res; |
31 | psiconv_file_type_t res; |
|
|
32 | int leng; |
31 | |
33 | |
32 | psiconv_parse_header_section(buf,0,0,NULL,&header); |
34 | psiconv_parse_header_section(buf,0,0,&leng,&header); |
33 | res = header->file; |
35 | res = header->file; |
|
|
36 | if (result) |
|
|
37 | *result = header; |
|
|
38 | else |
34 | psiconv_free_header_section(header); |
39 | psiconv_free_header_section(header); |
|
|
40 | if (length) |
|
|
41 | *length = leng; |
35 | return res; |
42 | return res; |
36 | } |
43 | } |
37 | |
44 | |
38 | int psiconv_parse(const psiconv_buffer buf,psiconv_file *result) |
45 | int psiconv_parse(const psiconv_buffer buf,psiconv_file *result) |
39 | { |
46 | { |
40 | int res=0; |
47 | int res=0; |
41 | int lev=0; |
48 | int lev=0; |
42 | int off=0; |
49 | int off=0; |
|
|
50 | int leng; |
43 | |
51 | |
44 | (*result) = malloc(sizeof(**result)); |
52 | (*result) = malloc(sizeof(**result)); |
45 | |
53 | |
46 | (*result)->type = psiconv_file_type(buf); |
54 | (*result)->type = psiconv_file_type(buf,&leng,NULL); |
47 | if ((*result)->type == psiconv_unknown_file) { |
55 | if ((*result)->type == psiconv_unknown_file) { |
48 | psiconv_warn(lev+1,off,"Unknown file type: can't parse!"); |
56 | psiconv_warn(lev+1,off,"Unknown file type: can't parse!"); |
49 | (*result)->file = NULL; |
57 | (*result)->file = NULL; |
50 | res = -1; |
58 | res = -1; |
51 | } else if ((*result)->type == psiconv_word_file) |
59 | } else if ((*result)->type == psiconv_word_file) |
52 | res = psiconv_parse_word_file(buf,lev+2,off, |
60 | res = psiconv_parse_word_file(buf,lev+2,leng, |
53 | (psiconv_word_f *)(&((*result)->file))); |
61 | (psiconv_word_f *)(&((*result)->file))); |
54 | else if ((*result)->type == psiconv_texted_file) |
62 | else if ((*result)->type == psiconv_texted_file) |
55 | res = psiconv_parse_texted_file(buf,lev+2,off, |
63 | res = psiconv_parse_texted_file(buf,lev+2,leng, |
56 | (psiconv_texted_f *)(&((*result)->file))); |
64 | (psiconv_texted_f *)(&((*result)->file))); |
57 | else if ((*result)->type == psiconv_mbm_file) |
65 | else if ((*result)->type == psiconv_mbm_file) |
58 | res = psiconv_parse_mbm_file(buf,lev+2,off, |
66 | res = psiconv_parse_mbm_file(buf,lev+2,leng, |
59 | (psiconv_mbm_f *)(&((*result)->file))); |
67 | (psiconv_mbm_f *)(&((*result)->file))); |
|
|
68 | else if ((*result)->type == psiconv_sketch_file) |
|
|
69 | res = psiconv_parse_sketch_file(buf,lev+2,leng, |
|
|
70 | (psiconv_sketch_f *)(&((*result)->file))); |
60 | else { |
71 | else { |
61 | psiconv_warn(lev+1,off,"Can't parse this file yet!"); |
72 | psiconv_warn(lev+1,off,"Can't parse this file yet!"); |
62 | (*result)->file = NULL; |
73 | (*result)->file = NULL; |
63 | } |
74 | } |
64 | res = -1; |
75 | res = -1; |
… | |
… | |
71 | { |
82 | { |
72 | int res=0; |
83 | int res=0; |
73 | int i; |
84 | int i; |
74 | psiconv_mbm_jumptable_section table; |
85 | psiconv_mbm_jumptable_section table; |
75 | psiconv_paint_data_section paint; |
86 | psiconv_paint_data_section paint; |
76 | psiconv_header_section header; |
|
|
77 | psiconv_u32 *entry; |
87 | psiconv_u32 *entry; |
|
|
88 | psiconv_u32 sto; |
78 | |
89 | |
79 | psiconv_progress(lev+1,off,"Going to read a mbm file"); |
90 | psiconv_progress(lev+1,off,"Going to read a mbm file"); |
80 | *result = malloc(sizeof(**result)); |
91 | *result = malloc(sizeof(**result)); |
81 | |
92 | |
82 | psiconv_progress(lev+2,off, "Going to read the header section"); |
93 | psiconv_progress(lev+2,off,"Going to read the offset of the MBM jumptable"); |
83 | res |= psiconv_parse_header_section(buf,lev+2,off,NULL,&header); |
94 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
95 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
84 | |
96 | |
85 | psiconv_progress(lev+2,off,"Going to read the MBM jumptable"); |
97 | psiconv_progress(lev+2,off,"Going to read the MBM jumptable"); |
86 | res |= psiconv_parse_mbm_jumptable_section(buf,lev+2, |
98 | res |= psiconv_parse_mbm_jumptable_section(buf,lev+2,sto, NULL,&table); |
87 | header->section_table_offset, |
|
|
88 | NULL,&table); |
|
|
89 | |
99 | |
90 | psiconv_progress(lev+2,off,"Going to read the picture sections"); |
100 | psiconv_progress(lev+2,off,"Going to read the picture sections"); |
91 | (*result)->sections = psiconv_list_new(sizeof(*paint)); |
101 | (*result)->sections = psiconv_list_new(sizeof(*paint)); |
92 | for (i = 0; i < psiconv_list_length(table); i ++) { |
102 | for (i = 0; i < psiconv_list_length(table); i ++) { |
93 | entry = psiconv_list_get(table,i); |
103 | entry = psiconv_list_get(table,i); |
94 | psiconv_progress(lev+3,off,"Going to read picture section %i",i); |
104 | psiconv_progress(lev+3,off,"Going to read picture section %i",i); |
95 | psiconv_parse_paint_data_section(buf,lev+3,*entry,NULL,&paint); |
105 | psiconv_parse_paint_data_section(buf,lev+3,*entry,NULL,&paint); |
96 | psiconv_list_add((*result)->sections,paint); |
106 | psiconv_list_add((*result)->sections,paint); |
97 | } |
107 | } |
98 | |
108 | |
99 | psiconv_free_header_section(header); |
|
|
100 | psiconv_free_mbm_jumptable_section(table); |
109 | psiconv_free_mbm_jumptable_section(table); |
101 | psiconv_progress(lev+1,off,"End of mbm file"); |
110 | psiconv_progress(lev+1,off,"End of mbm file"); |
102 | return res; |
111 | return res; |
103 | } |
112 | } |
104 | |
113 | |
|
|
114 | int psiconv_parse_sketch_file(const psiconv_buffer buf,int lev, |
|
|
115 | psiconv_u32 off, |
|
|
116 | psiconv_sketch_f *result) |
|
|
117 | { |
|
|
118 | psiconv_section_table_section table; |
|
|
119 | psiconv_application_id_section appl_id; |
|
|
120 | psiconv_u32 applid_sec = 0; |
|
|
121 | psiconv_u32 sketch_sec = 0; |
|
|
122 | psiconv_u32 sto; |
|
|
123 | psiconv_section_table_entry entry; |
|
|
124 | int i; |
|
|
125 | int res=0; |
|
|
126 | char *temp_str; |
|
|
127 | |
|
|
128 | psiconv_progress(lev+1,off,"Going to read a sketch file"); |
|
|
129 | *result = malloc(sizeof(**result)); |
|
|
130 | |
|
|
131 | psiconv_progress(lev+2,off, |
|
|
132 | "Going to read the offset of the section table section"); |
|
|
133 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
134 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
|
|
135 | |
|
|
136 | psiconv_progress(lev+2,sto, "Going to read the section table section"); |
|
|
137 | res |= psiconv_parse_section_table_section(buf,lev+2,sto, NULL,&table); |
|
|
138 | |
|
|
139 | for (i = 0; i < psiconv_list_length(table); i ++) { |
|
|
140 | psiconv_progress(lev+2,sto, "Going to read entry %d",i); |
|
|
141 | entry = psiconv_list_get(table,i); |
|
|
142 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
|
|
143 | applid_sec = entry->offset; |
|
|
144 | psiconv_debug(lev+3,sto, |
|
|
145 | "Found the Application ID section at %08x",applid_sec); |
|
|
146 | } else if (entry->id == PSICONV_ID_SKETCH_SECTION) { |
|
|
147 | sketch_sec = entry->offset; |
|
|
148 | psiconv_debug(lev+3,sto, |
|
|
149 | "Found the Sketch section at %08x",sketch_sec); |
|
|
150 | } else { |
|
|
151 | psiconv_warn(lev+3,sto, |
|
|
152 | "Found unknown section in the Section Table"); |
|
|
153 | psiconv_debug(lev+3,sto, |
|
|
154 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
|
|
155 | res = -1; |
|
|
156 | } |
|
|
157 | } |
|
|
158 | |
|
|
159 | psiconv_progress(lev+2,sto, "Looking for the Application ID section"); |
|
|
160 | if (! applid_sec) { |
|
|
161 | psiconv_warn(lev+2,sto, |
|
|
162 | "Application ID section not found in the section table"); |
|
|
163 | res = -1; |
|
|
164 | } else { |
|
|
165 | psiconv_debug(lev+2,sto, |
|
|
166 | "Application ID section at offset %08x",applid_sec); |
|
|
167 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
|
|
168 | &appl_id); |
|
|
169 | } |
|
|
170 | if ((appl_id->id != PSICONV_ID_SKETCH) || |
|
|
171 | strcmp(appl_id->name,"Paint.app")) { |
|
|
172 | psiconv_warn(lev+2,applid_sec, |
|
|
173 | "Application ID section contains unexpected data"); |
|
|
174 | psiconv_debug(lev+2,applid_sec,"ID: %08x expected, %08x found", |
|
|
175 | PSICONV_ID_SKETCH,appl_id->id); |
|
|
176 | temp_str = psiconv_make_printable(appl_id->name); |
|
|
177 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
|
|
178 | "Paint.app",temp_str); |
|
|
179 | free(temp_str); |
|
|
180 | } |
|
|
181 | |
|
|
182 | psiconv_progress(lev+2,sto, "Looking for the Sketch section"); |
|
|
183 | if (! sketch_sec) { |
|
|
184 | psiconv_warn(lev+2,sto, |
|
|
185 | "Sketch section not found in the section table"); |
|
|
186 | res = -1; |
|
|
187 | } else { |
|
|
188 | psiconv_debug(lev+2,sto, |
|
|
189 | "Sketch section at offset %08x",applid_sec); |
|
|
190 | res |= psiconv_parse_sketch_section(buf,lev+2,sketch_sec,NULL,0, |
|
|
191 | &(*result)->sketch_sec); |
|
|
192 | } |
|
|
193 | |
|
|
194 | psiconv_free_application_id_section(appl_id); |
|
|
195 | psiconv_free_section_table_section(table); |
|
|
196 | |
|
|
197 | psiconv_progress(lev+1,off,"End of word file"); |
|
|
198 | return res; |
|
|
199 | } |
|
|
200 | |
|
|
201 | |
|
|
202 | |
105 | int psiconv_parse_texted_file(const psiconv_buffer buf,int lev, psiconv_u32 off, |
203 | int psiconv_parse_texted_file(const psiconv_buffer buf,int lev, |
|
|
204 | psiconv_u32 off, |
106 | psiconv_texted_f *result) |
205 | psiconv_texted_f *result) |
107 | { |
206 | { |
108 | int res=0; |
207 | int res=0; |
109 | psiconv_header_section header; |
|
|
110 | psiconv_section_table_section table; |
208 | psiconv_section_table_section table; |
111 | psiconv_application_id_section appl_id; |
209 | psiconv_application_id_section appl_id; |
112 | char *temp_str; |
210 | char *temp_str; |
113 | psiconv_character_layout base_char; |
211 | psiconv_character_layout base_char; |
114 | psiconv_paragraph_layout base_para; |
212 | psiconv_paragraph_layout base_para; |
115 | psiconv_u32 page_sec = 0; |
213 | psiconv_u32 page_sec = 0; |
116 | psiconv_u32 texted_sec = 0; |
214 | psiconv_u32 texted_sec = 0; |
117 | psiconv_u32 applid_sec = 0; |
215 | psiconv_u32 applid_sec = 0; |
|
|
216 | psiconv_u32 sto; |
118 | psiconv_section_table_entry entry; |
217 | psiconv_section_table_entry entry; |
119 | int i; |
218 | int i; |
120 | |
219 | |
121 | psiconv_progress(lev+1,off,"Going to read a texted file"); |
220 | psiconv_progress(lev+1,off,"Going to read a texted file"); |
122 | *result = malloc(sizeof(**result)); |
221 | *result = malloc(sizeof(**result)); |
123 | |
222 | |
124 | psiconv_progress(lev+2,off, "Going to read the header section"); |
223 | psiconv_progress(lev+2,off, |
125 | res |= psiconv_parse_header_section(buf,lev+2,off,NULL,&header); |
|
|
126 | |
|
|
127 | psiconv_progress(lev+2,header->section_table_offset, |
|
|
128 | "Going to read the section table section"); |
224 | "Going to read the offset of the section table section"); |
|
|
225 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
226 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
|
|
227 | |
|
|
228 | psiconv_progress(lev+2,sto, "Going to read the section table section"); |
129 | res |= psiconv_parse_section_table_section(buf,lev+2, |
229 | res |= psiconv_parse_section_table_section(buf,lev+2,sto, NULL,&table); |
130 | header->section_table_offset, |
|
|
131 | NULL,&table); |
|
|
132 | |
230 | |
133 | for (i = 0; i < psiconv_list_length(table); i ++) { |
231 | for (i = 0; i < psiconv_list_length(table); i ++) { |
134 | psiconv_progress(lev+2,header->section_table_offset, |
232 | psiconv_progress(lev+2,sto, "Going to read entry %d",i); |
135 | "Going to read entry %d",i); |
|
|
136 | entry = psiconv_list_get(table,i); |
233 | entry = psiconv_list_get(table,i); |
137 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
234 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
138 | applid_sec = entry->offset; |
235 | applid_sec = entry->offset; |
139 | psiconv_debug(lev+3,header->section_table_offset, |
236 | psiconv_debug(lev+3,sto, |
140 | "Found the Application ID section at %08x",applid_sec); |
237 | "Found the Application ID section at %08x",applid_sec); |
141 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
238 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
142 | page_sec = entry->offset; |
239 | page_sec = entry->offset; |
143 | psiconv_debug(lev+3,header->section_table_offset, |
240 | psiconv_debug(lev+3,sto, |
144 | "Found the Page Layout section at %08x",page_sec); |
241 | "Found the Page Layout section at %08x",page_sec); |
145 | } else if (entry->id == PSICONV_ID_TEXTED) { |
242 | } else if (entry->id == PSICONV_ID_TEXTED) { |
146 | texted_sec = entry->offset; |
243 | texted_sec = entry->offset; |
147 | psiconv_debug(lev+3,header->section_table_offset, |
244 | psiconv_debug(lev+3,sto, |
148 | "Found the TextEd section at %08x",texted_sec); |
245 | "Found the TextEd section at %08x",texted_sec); |
149 | } else { |
246 | } else { |
150 | psiconv_warn(lev+3,header->section_table_offset, |
247 | psiconv_warn(lev+3,sto, |
151 | "Found unknown section in the Section Table"); |
248 | "Found unknown section in the Section Table"); |
152 | psiconv_debug(lev+3,header->section_table_offset, |
249 | psiconv_debug(lev+3,sto, |
153 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
250 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
154 | res = -1; |
251 | res = -1; |
155 | } |
252 | } |
156 | } |
253 | } |
157 | |
254 | |
158 | psiconv_progress(lev+2,header->section_table_offset, |
255 | psiconv_progress(lev+2,sto, "Looking for the Application ID section"); |
159 | "Looking for the Application ID section"); |
|
|
160 | if (! applid_sec) { |
256 | if (! applid_sec) { |
161 | psiconv_warn(lev+2,header->section_table_offset, |
257 | psiconv_warn(lev+2,sto, |
162 | "Application ID section not found in the section table"); |
258 | "Application ID section not found in the section table"); |
163 | res = -1; |
259 | res = -1; |
164 | } else { |
260 | } else { |
165 | psiconv_debug(lev+2,header->section_table_offset, |
261 | psiconv_debug(lev+2,sto, |
166 | "Application ID section at offset %08x",applid_sec); |
262 | "Application ID section at offset %08x",applid_sec); |
167 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
263 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
168 | &appl_id); |
264 | &appl_id); |
169 | } |
265 | } |
170 | if ((appl_id->id != PSICONV_ID_TEXTED) || |
266 | if ((appl_id->id != PSICONV_ID_TEXTED) || |
… | |
… | |
173 | "Application ID section contains unexpected data"); |
269 | "Application ID section contains unexpected data"); |
174 | psiconv_debug(lev+2,applid_sec,"ID: %08x expected, %08x found", |
270 | psiconv_debug(lev+2,applid_sec,"ID: %08x expected, %08x found", |
175 | PSICONV_ID_TEXTED,appl_id->id); |
271 | PSICONV_ID_TEXTED,appl_id->id); |
176 | temp_str = psiconv_make_printable(appl_id->name); |
272 | temp_str = psiconv_make_printable(appl_id->name); |
177 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
273 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
178 | PSICONV_ID_TEXTED,temp_str); |
274 | "TextEd.app",temp_str); |
179 | free(temp_str); |
275 | free(temp_str); |
180 | } |
276 | } |
181 | |
277 | |
182 | psiconv_progress(lev+2,header->section_table_offset, |
278 | psiconv_progress(lev+2,sto, |
183 | "Looking for the Page layout section"); |
279 | "Looking for the Page layout section"); |
184 | if (! page_sec) { |
280 | if (! page_sec) { |
185 | psiconv_warn(lev+2,header->section_table_offset, |
281 | psiconv_warn(lev+2,sto, |
186 | "Page layout section not found in the section table"); |
282 | "Page layout section not found in the section table"); |
187 | (*result)->page_sec = NULL; |
283 | (*result)->page_sec = NULL; |
188 | res = -1; |
284 | res = -1; |
189 | } else { |
285 | } else { |
190 | psiconv_debug(lev+2,header->section_table_offset, |
286 | psiconv_debug(lev+2,sto, |
191 | "Page layout section at offset %08x",page_sec); |
287 | "Page layout section at offset %08x",page_sec); |
192 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
288 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
193 | &(*result)->page_sec); |
289 | &(*result)->page_sec); |
194 | } |
290 | } |
195 | |
291 | |
196 | base_char = psiconv_basic_character_layout(); |
292 | base_char = psiconv_basic_character_layout(); |
197 | base_para = psiconv_basic_paragraph_layout(); |
293 | base_para = psiconv_basic_paragraph_layout(); |
198 | |
294 | |
199 | psiconv_progress(lev+2,header->section_table_offset, |
295 | psiconv_progress(lev+2,sto, |
200 | "Looking for the TextEd section"); |
296 | "Looking for the TextEd section"); |
201 | if (! texted_sec) { |
297 | if (! texted_sec) { |
202 | psiconv_warn(lev+2,header->section_table_offset, |
298 | psiconv_warn(lev+2,sto, |
203 | "TextEd section not found in the section table"); |
299 | "TextEd section not found in the section table"); |
204 | (*result)->texted_sec = NULL; |
300 | (*result)->texted_sec = NULL; |
205 | res = -1; |
301 | res = -1; |
206 | } else { |
302 | } else { |
207 | psiconv_debug(lev+2,header->section_table_offset, |
303 | psiconv_debug(lev+2,sto, "TextEd section at offset %08x",texted_sec); |
208 | "TextEd section at offset %08x",texted_sec); |
|
|
209 | res |= psiconv_parse_texted_section(buf,lev+2,texted_sec,NULL, |
304 | res |= psiconv_parse_texted_section(buf,lev+2,texted_sec,NULL, |
210 | &(*result)->texted_sec, |
305 | &(*result)->texted_sec, |
211 | base_char,base_para); |
306 | base_char,base_para); |
212 | } |
307 | } |
213 | psiconv_free_character_layout(base_char); |
308 | psiconv_free_character_layout(base_char); |
214 | psiconv_free_paragraph_layout(base_para); |
309 | psiconv_free_paragraph_layout(base_para); |
215 | |
310 | |
216 | psiconv_free_application_id_section(appl_id); |
311 | psiconv_free_application_id_section(appl_id); |
217 | psiconv_free_header_section(header); |
|
|
218 | psiconv_free_section_table_section(table); |
312 | psiconv_free_section_table_section(table); |
219 | |
313 | |
220 | psiconv_progress(lev+1,off,"End of word file"); |
314 | psiconv_progress(lev+1,off,"End of word file"); |
221 | return res; |
315 | return res; |
222 | } |
316 | } |
223 | |
317 | |
224 | int psiconv_parse_word_file(const psiconv_buffer buf,int lev, psiconv_u32 off, |
318 | int psiconv_parse_word_file(const psiconv_buffer buf,int lev, psiconv_u32 off, |
225 | psiconv_word_f *result) |
319 | psiconv_word_f *result) |
226 | { |
320 | { |
227 | int res=0; |
321 | int res=0; |
228 | psiconv_header_section header; |
|
|
229 | psiconv_section_table_section table; |
322 | psiconv_section_table_section table; |
230 | psiconv_application_id_section appl_id; |
323 | psiconv_application_id_section appl_id; |
231 | char *temp_str; |
324 | char *temp_str; |
232 | psiconv_u32 pwd_sec = 0; |
325 | psiconv_u32 pwd_sec = 0; |
233 | psiconv_u32 status_sec = 0; |
326 | psiconv_u32 status_sec = 0; |
… | |
… | |
235 | psiconv_u32 page_sec = 0; |
328 | psiconv_u32 page_sec = 0; |
236 | psiconv_u32 text_sec = 0; |
329 | psiconv_u32 text_sec = 0; |
237 | psiconv_u32 layout_sec = 0; |
330 | psiconv_u32 layout_sec = 0; |
238 | psiconv_u32 applid_sec = 0; |
331 | psiconv_u32 applid_sec = 0; |
239 | psiconv_section_table_entry entry; |
332 | psiconv_section_table_entry entry; |
|
|
333 | psiconv_u32 sto; |
240 | int i; |
334 | int i; |
241 | |
335 | |
242 | psiconv_progress(lev+1,off,"Going to read a word file"); |
336 | psiconv_progress(lev+1,off,"Going to read a word file"); |
243 | *result = malloc(sizeof(**result)); |
337 | *result = malloc(sizeof(**result)); |
244 | |
338 | |
245 | psiconv_progress(lev+2,off, "Going to read the header section"); |
339 | psiconv_progress(lev+2,off, |
246 | res |= psiconv_parse_header_section(buf,lev+2,off,NULL,&header); |
340 | "Going to read the offset of the section table section"); |
|
|
341 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
342 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
247 | |
343 | |
248 | psiconv_progress(lev+2,header->section_table_offset, |
344 | psiconv_progress(lev+2,sto, |
249 | "Going to read the section table section"); |
345 | "Going to read the section table section"); |
250 | res |= psiconv_parse_section_table_section(buf,lev+2, |
346 | res |= psiconv_parse_section_table_section(buf,lev+2,sto, NULL,&table); |
251 | header->section_table_offset, |
|
|
252 | NULL,&table); |
|
|
253 | |
347 | |
254 | for (i = 0; i < psiconv_list_length(table); i ++) { |
348 | for (i = 0; i < psiconv_list_length(table); i ++) { |
255 | psiconv_progress(lev+2,header->section_table_offset, |
349 | psiconv_progress(lev+2,sto, "Going to read entry %d",i); |
256 | "Going to read entry %d",i); |
|
|
257 | entry = psiconv_list_get(table,i); |
350 | entry = psiconv_list_get(table,i); |
258 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
351 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
259 | applid_sec = entry->offset; |
352 | applid_sec = entry->offset; |
260 | psiconv_debug(lev+3,header->section_table_offset, |
353 | psiconv_debug(lev+3,sto, |
261 | "Found the Application ID section at %08x",applid_sec); |
354 | "Found the Application ID section at %08x",applid_sec); |
262 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
355 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
263 | page_sec = entry->offset; |
356 | page_sec = entry->offset; |
264 | psiconv_debug(lev+3,header->section_table_offset, |
357 | psiconv_debug(lev+3,sto, |
265 | "Found the Page Layout section at %08x",page_sec); |
358 | "Found the Page Layout section at %08x",page_sec); |
266 | } else if (entry->id == PSICONV_ID_TEXT_SECTION) { |
359 | } else if (entry->id == PSICONV_ID_TEXT_SECTION) { |
267 | text_sec = entry->offset; |
360 | text_sec = entry->offset; |
268 | psiconv_debug(lev+3,header->section_table_offset, |
361 | psiconv_debug(lev+3,sto, "Found the Text section at %08x",text_sec); |
269 | "Found the Text section at %08x",text_sec); |
|
|
270 | } else if (entry->id == PSICONV_ID_PASSWORD_SECTION) { |
362 | } else if (entry->id == PSICONV_ID_PASSWORD_SECTION) { |
271 | pwd_sec = entry->offset; |
363 | pwd_sec = entry->offset; |
272 | psiconv_debug(lev+3,header->section_table_offset, |
364 | psiconv_debug(lev+3,sto, |
273 | "Found the Password section at %08x",pwd_sec); |
365 | "Found the Password section at %08x",pwd_sec); |
274 | psiconv_warn(lev+3,header->section_table_offset, |
366 | psiconv_warn(lev+3,sto, |
275 | "Password section found - can't read encrypted data"); |
367 | "Password section found - can't read encrypted data"); |
276 | res = -1; |
368 | res = -1; |
277 | } else if (entry->id == PSICONV_ID_WORD_STATUS_SECTION) { |
369 | } else if (entry->id == PSICONV_ID_WORD_STATUS_SECTION) { |
278 | status_sec = entry->offset; |
370 | status_sec = entry->offset; |
279 | psiconv_debug(lev+3,header->section_table_offset, |
371 | psiconv_debug(lev+3,sto, |
280 | "Found the Word Status section at %08x",status_sec); |
372 | "Found the Word Status section at %08x",status_sec); |
281 | } else if (entry->id == PSICONV_ID_WORD_STYLES_SECTION) { |
373 | } else if (entry->id == PSICONV_ID_WORD_STYLES_SECTION) { |
282 | styles_sec = entry->offset; |
374 | styles_sec = entry->offset; |
283 | psiconv_debug(lev+3,header->section_table_offset, |
375 | psiconv_debug(lev+3,sto, |
284 | "Found the Word Styles section at %08x",styles_sec); |
376 | "Found the Word Styles section at %08x",styles_sec); |
285 | } else if (entry->id == PSICONV_ID_LAYOUT_SECTION) { |
377 | } else if (entry->id == PSICONV_ID_LAYOUT_SECTION) { |
286 | layout_sec = entry->offset; |
378 | layout_sec = entry->offset; |
287 | psiconv_debug(lev+3,header->section_table_offset, |
379 | psiconv_debug(lev+3,sto, |
288 | "Found the Layout section at %08x",layout_sec); |
380 | "Found the Layout section at %08x",layout_sec); |
289 | } else { |
381 | } else { |
290 | psiconv_warn(lev+3,header->section_table_offset, |
382 | psiconv_warn(lev+3,sto, |
291 | "Found unknown section in the Section Table"); |
383 | "Found unknown section in the Section Table"); |
292 | psiconv_debug(lev+3,header->section_table_offset, |
384 | psiconv_debug(lev+3,sto, |
293 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
385 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
294 | res = -1; |
386 | res = -1; |
295 | } |
387 | } |
296 | } |
388 | } |
297 | |
389 | |
298 | |
390 | |
299 | psiconv_progress(lev+2,header->section_table_offset, |
391 | psiconv_progress(lev+2,sto, |
300 | "Looking for the Status section"); |
392 | "Looking for the Status section"); |
301 | if (!status_sec) { |
393 | if (!status_sec) { |
302 | psiconv_warn(lev+2,header->section_table_offset, |
|
|
303 | "Status section not found in the section table"); |
394 | psiconv_warn(lev+2,sto, "Status section not found in the section table"); |
304 | res = -1; |
395 | res = -1; |
305 | } else { |
396 | } else { |
306 | psiconv_debug(lev+2,header->section_table_offset, |
397 | psiconv_debug(lev+2,sto, "Status section at offset %08x",status_sec); |
307 | "Status section at offset %08x",status_sec); |
|
|
308 | res |= psiconv_parse_word_status_section(buf,lev+2,status_sec,NULL, |
398 | res |= psiconv_parse_word_status_section(buf,lev+2,status_sec,NULL, |
309 | &((*result)->status_sec)); |
399 | &((*result)->status_sec)); |
310 | } |
400 | } |
311 | |
401 | |
312 | psiconv_progress(lev+2,header->section_table_offset, |
402 | psiconv_progress(lev+2,sto, "Looking for the Application ID section"); |
313 | "Looking for the Application ID section"); |
|
|
314 | if (! applid_sec) { |
403 | if (! applid_sec) { |
315 | psiconv_warn(lev+2,header->section_table_offset, |
404 | psiconv_warn(lev+2,sto, |
316 | "Application ID section not found in the section table"); |
405 | "Application ID section not found in the section table"); |
317 | res = -1; |
406 | res = -1; |
318 | } else { |
407 | } else { |
319 | psiconv_debug(lev+2,header->section_table_offset, |
408 | psiconv_debug(lev+2,sto, |
320 | "Application ID section at offset %08x",applid_sec); |
409 | "Application ID section at offset %08x",applid_sec); |
321 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
410 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
322 | &appl_id); |
411 | &appl_id); |
323 | } |
412 | } |
324 | if ((appl_id->id != PSICONV_ID_WORD) || |
413 | if ((appl_id->id != PSICONV_ID_WORD) || |
… | |
… | |
327 | "Application ID section contains unexpected data"); |
416 | "Application ID section contains unexpected data"); |
328 | psiconv_debug(lev+2,applid_sec,"ID: %08x expected, %08x found", |
417 | psiconv_debug(lev+2,applid_sec,"ID: %08x expected, %08x found", |
329 | PSICONV_ID_WORD,appl_id->id); |
418 | PSICONV_ID_WORD,appl_id->id); |
330 | temp_str = psiconv_make_printable(appl_id->name); |
419 | temp_str = psiconv_make_printable(appl_id->name); |
331 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
420 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
332 | PSICONV_ID_WORD,temp_str); |
421 | "Word.app",temp_str); |
333 | free(temp_str); |
422 | free(temp_str); |
334 | } |
423 | } |
335 | |
424 | |
336 | psiconv_progress(lev+2,header->section_table_offset, |
425 | psiconv_progress(lev+2,sto, |
337 | "Looking for the Page layout section"); |
426 | "Looking for the Page layout section"); |
338 | if (! page_sec) { |
427 | if (! page_sec) { |
339 | psiconv_warn(lev+2,header->section_table_offset, |
428 | psiconv_warn(lev+2,sto, |
340 | "Page layout section not found in the section table"); |
429 | "Page layout section not found in the section table"); |
341 | (*result)->page_sec = NULL; |
430 | (*result)->page_sec = NULL; |
342 | res = -1; |
431 | res = -1; |
343 | } else { |
432 | } else { |
344 | psiconv_debug(lev+2,header->section_table_offset, |
433 | psiconv_debug(lev+2,sto, |
345 | "Page layout section at offset %08x",page_sec); |
434 | "Page layout section at offset %08x",page_sec); |
346 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
435 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
347 | &(*result)->page_sec); |
436 | &(*result)->page_sec); |
348 | } |
437 | } |
349 | |
438 | |
350 | psiconv_progress(lev+2,header->section_table_offset, |
439 | psiconv_progress(lev+2,sto, |
351 | "Looking for the Word Style section"); |
440 | "Looking for the Word Style section"); |
352 | if (!styles_sec) { |
441 | if (!styles_sec) { |
353 | psiconv_warn(lev+2,header->section_table_offset, |
442 | psiconv_warn(lev+2,sto, |
354 | "Word styles section not found in the section table"); |
443 | "Word styles section not found in the section table"); |
355 | (*result)->styles_sec = NULL; |
444 | (*result)->styles_sec = NULL; |
356 | res = -1; |
445 | res = -1; |
357 | } else { |
446 | } else { |
358 | psiconv_debug(lev+2,header->section_table_offset, |
447 | psiconv_debug(lev+2,sto, |
359 | "Word styles section at offset %08x",styles_sec); |
448 | "Word styles section at offset %08x",styles_sec); |
360 | res |= psiconv_parse_word_styles_section(buf,lev+2,styles_sec,NULL, |
449 | res |= psiconv_parse_word_styles_section(buf,lev+2,styles_sec,NULL, |
361 | &(*result)->styles_sec); |
450 | &(*result)->styles_sec); |
362 | } |
451 | } |
363 | |
452 | |
364 | psiconv_progress(lev+2,header->section_table_offset, |
453 | psiconv_progress(lev+2,sto, |
365 | "Looking for the Text section"); |
454 | "Looking for the Text section"); |
366 | if (!text_sec) { |
455 | if (!text_sec) { |
367 | psiconv_warn(lev+2,header->section_table_offset, |
456 | psiconv_warn(lev+2,sto, "Text section not found in the section table"); |
368 | "Text section not found in the section table"); |
|
|
369 | (*result)->paragraphs = NULL; |
457 | (*result)->paragraphs = NULL; |
370 | res = -1; |
458 | res = -1; |
371 | } else { |
459 | } else { |
372 | psiconv_debug(lev+2,header->section_table_offset, |
460 | psiconv_debug(lev+2,sto, |
373 | "Text section at offset %08x",text_sec); |
461 | "Text section at offset %08x",text_sec); |
374 | res |= psiconv_parse_text_section(buf,lev+2,text_sec,NULL, |
462 | res |= psiconv_parse_text_section(buf,lev+2,text_sec,NULL, |
375 | &(*result)->paragraphs); |
463 | &(*result)->paragraphs); |
376 | } |
464 | } |
377 | |
465 | |
378 | if (((*result)->paragraphs) && ((*result)->styles_sec)) { |
466 | if (((*result)->paragraphs) && ((*result)->styles_sec)) { |
379 | psiconv_progress(lev+2,header->section_table_offset, |
467 | psiconv_progress(lev+2,sto, |
380 | "Looking for the Layout section"); |
468 | "Looking for the Layout section"); |
381 | if (!layout_sec) { |
469 | if (!layout_sec) { |
382 | psiconv_debug(lev+2,header->section_table_offset, |
470 | psiconv_debug(lev+2,sto, |
383 | "Layout section not found in the section table"); |
471 | "Layout section not found in the section table"); |
384 | res = -1; |
472 | res = -1; |
385 | } else { |
473 | } else { |
386 | psiconv_debug(lev+2,header->section_table_offset, |
474 | psiconv_debug(lev+2,sto, |
387 | "Layout section at offset %08x",layout_sec); |
475 | "Layout section at offset %08x",layout_sec); |
388 | res |= psiconv_parse_styled_layout_section(buf,lev+2,layout_sec,NULL, |
476 | res |= psiconv_parse_styled_layout_section(buf,lev+2,layout_sec,NULL, |
389 | (*result)->paragraphs, |
477 | (*result)->paragraphs, |
390 | (*result)->styles_sec); |
478 | (*result)->styles_sec); |
391 | } |
479 | } |
392 | } else |
480 | } else |
393 | psiconv_debug(lev+2,header->section_table_offset, |
481 | psiconv_debug(lev+2,sto, |
394 | "Skipping search for Layout section, as either the " |
482 | "Skipping search for Layout section, as either the " |
395 | "text or the word styles section was not found"); |
483 | "text or the word styles section was not found"); |
396 | |
484 | |
397 | psiconv_free_application_id_section(appl_id); |
485 | psiconv_free_application_id_section(appl_id); |
398 | psiconv_free_header_section(header); |
|
|
399 | psiconv_free_section_table_section(table); |
486 | psiconv_free_section_table_section(table); |
400 | |
487 | |
401 | psiconv_progress(lev+1,off,"End of word file"); |
488 | psiconv_progress(lev+1,off,"End of word file"); |
402 | return res; |
489 | return res; |
403 | } |
490 | } |