… | |
… | |
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))); |
60 | else { |
68 | else { |
61 | psiconv_warn(lev+1,off,"Can't parse this file yet!"); |
69 | psiconv_warn(lev+1,off,"Can't parse this file yet!"); |
62 | (*result)->file = NULL; |
70 | (*result)->file = NULL; |
63 | } |
71 | } |
… | |
… | |
71 | { |
79 | { |
72 | int res=0; |
80 | int res=0; |
73 | int i; |
81 | int i; |
74 | psiconv_mbm_jumptable_section table; |
82 | psiconv_mbm_jumptable_section table; |
75 | psiconv_paint_data_section paint; |
83 | psiconv_paint_data_section paint; |
76 | psiconv_header_section header; |
|
|
77 | psiconv_u32 *entry; |
84 | psiconv_u32 *entry; |
|
|
85 | psiconv_u32 sto; |
78 | |
86 | |
79 | psiconv_progress(lev+1,off,"Going to read a mbm file"); |
87 | psiconv_progress(lev+1,off,"Going to read a mbm file"); |
80 | *result = malloc(sizeof(**result)); |
88 | *result = malloc(sizeof(**result)); |
81 | |
89 | |
82 | psiconv_progress(lev+2,off, "Going to read the header section"); |
90 | 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); |
91 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
92 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
84 | |
93 | |
85 | psiconv_progress(lev+2,off,"Going to read the MBM jumptable"); |
94 | psiconv_progress(lev+2,off,"Going to read the MBM jumptable"); |
86 | res |= psiconv_parse_mbm_jumptable_section(buf,lev+2, |
95 | res |= psiconv_parse_mbm_jumptable_section(buf,lev+2,sto, NULL,&table); |
87 | header->section_table_offset, |
|
|
88 | NULL,&table); |
|
|
89 | |
96 | |
|
|
97 | psiconv_progress(lev+2,off,"Going to read the picture sections"); |
90 | (*result)->sections = psiconv_list_new(sizeof(*paint)); |
98 | (*result)->sections = psiconv_list_new(sizeof(*paint)); |
91 | for (i = 0; i < psiconv_list_length(table); i ++) { |
99 | for (i = 0; i < psiconv_list_length(table); i ++) { |
92 | entry = psiconv_list_get(table,i); |
100 | entry = psiconv_list_get(table,i); |
|
|
101 | psiconv_progress(lev+3,off,"Going to read picture section %i",i); |
93 | psiconv_parse_paint_data_section(buf,lev+2,*entry,NULL,&paint); |
102 | psiconv_parse_paint_data_section(buf,lev+3,*entry,NULL,&paint); |
94 | psiconv_list_add(table,paint); |
103 | psiconv_list_add((*result)->sections,paint); |
95 | } |
104 | } |
96 | |
105 | |
97 | psiconv_free_header_section(header); |
|
|
98 | psiconv_free_mbm_jumptable_section(table); |
106 | psiconv_free_mbm_jumptable_section(table); |
99 | psiconv_progress(lev+1,off,"End of mbm file"); |
107 | psiconv_progress(lev+1,off,"End of mbm file"); |
100 | return res; |
108 | return res; |
101 | } |
109 | } |
102 | |
110 | |
103 | int psiconv_parse_texted_file(const psiconv_buffer buf,int lev, psiconv_u32 off, |
111 | int psiconv_parse_texted_file(const psiconv_buffer buf,int lev, |
|
|
112 | psiconv_u32 off, |
104 | psiconv_texted_f *result) |
113 | psiconv_texted_f *result) |
105 | { |
114 | { |
106 | int res=0; |
115 | int res=0; |
107 | psiconv_header_section header; |
|
|
108 | psiconv_section_table_section table; |
116 | psiconv_section_table_section table; |
109 | psiconv_application_id_section appl_id; |
117 | psiconv_application_id_section appl_id; |
110 | char *temp_str; |
118 | char *temp_str; |
111 | psiconv_character_layout base_char; |
119 | psiconv_character_layout base_char; |
112 | psiconv_paragraph_layout base_para; |
120 | psiconv_paragraph_layout base_para; |
113 | psiconv_u32 page_sec = 0; |
121 | psiconv_u32 page_sec = 0; |
114 | psiconv_u32 texted_sec = 0; |
122 | psiconv_u32 texted_sec = 0; |
115 | psiconv_u32 applid_sec = 0; |
123 | psiconv_u32 applid_sec = 0; |
|
|
124 | psiconv_u32 sto; |
116 | psiconv_section_table_entry entry; |
125 | psiconv_section_table_entry entry; |
117 | int i; |
126 | int i; |
118 | |
127 | |
119 | psiconv_progress(lev+1,off,"Going to read a texted file"); |
128 | psiconv_progress(lev+1,off,"Going to read a texted file"); |
120 | *result = malloc(sizeof(**result)); |
129 | *result = malloc(sizeof(**result)); |
121 | |
130 | |
|
|
131 | psiconv_progress(lev+2,off,"Going to read the offset of the MBM jumptable"); |
|
|
132 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
133 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
|
|
134 | |
122 | psiconv_progress(lev+2,off, "Going to read the header section"); |
135 | psiconv_progress(lev+2,sto, "Going to read the section table section"); |
123 | res |= psiconv_parse_header_section(buf,lev+2,off,NULL,&header); |
|
|
124 | |
|
|
125 | psiconv_progress(lev+2,header->section_table_offset, |
|
|
126 | "Going to read the section table section"); |
|
|
127 | res |= psiconv_parse_section_table_section(buf,lev+2, |
136 | res |= psiconv_parse_section_table_section(buf,lev+2,sto, NULL,&table); |
128 | header->section_table_offset, |
|
|
129 | NULL,&table); |
|
|
130 | |
137 | |
131 | for (i = 0; i < psiconv_list_length(table); i ++) { |
138 | for (i = 0; i < psiconv_list_length(table); i ++) { |
132 | psiconv_progress(lev+2,header->section_table_offset, |
139 | psiconv_progress(lev+2,sto, "Going to read entry %d",i); |
133 | "Going to read entry %d",i); |
|
|
134 | entry = psiconv_list_get(table,i); |
140 | entry = psiconv_list_get(table,i); |
135 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
141 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
136 | applid_sec = entry->offset; |
142 | applid_sec = entry->offset; |
137 | psiconv_debug(lev+3,header->section_table_offset, |
143 | psiconv_debug(lev+3,sto, |
138 | "Found the Application ID section at %08x",applid_sec); |
144 | "Found the Application ID section at %08x",applid_sec); |
139 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
145 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
140 | page_sec = entry->offset; |
146 | page_sec = entry->offset; |
141 | psiconv_debug(lev+3,header->section_table_offset, |
147 | psiconv_debug(lev+3,sto, |
142 | "Found the Page Layout section at %08x",page_sec); |
148 | "Found the Page Layout section at %08x",page_sec); |
143 | } else if (entry->id == PSICONV_ID_TEXTED) { |
149 | } else if (entry->id == PSICONV_ID_TEXTED) { |
144 | texted_sec = entry->offset; |
150 | texted_sec = entry->offset; |
145 | psiconv_debug(lev+3,header->section_table_offset, |
151 | psiconv_debug(lev+3,sto, |
146 | "Found the TextEd section at %08x",texted_sec); |
152 | "Found the TextEd section at %08x",texted_sec); |
147 | } else { |
153 | } else { |
148 | psiconv_warn(lev+3,header->section_table_offset, |
154 | psiconv_warn(lev+3,sto, |
149 | "Found unknown section in the Section Table"); |
155 | "Found unknown section in the Section Table"); |
150 | psiconv_debug(lev+3,header->section_table_offset, |
156 | psiconv_debug(lev+3,sto, |
151 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
157 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
152 | res = -1; |
158 | res = -1; |
153 | } |
159 | } |
154 | } |
160 | } |
155 | |
161 | |
156 | psiconv_progress(lev+2,header->section_table_offset, |
162 | psiconv_progress(lev+2,sto, "Looking for the Application ID section"); |
157 | "Looking for the Application ID section"); |
|
|
158 | if (! applid_sec) { |
163 | if (! applid_sec) { |
159 | psiconv_warn(lev+2,header->section_table_offset, |
164 | psiconv_warn(lev+2,sto, |
160 | "Application ID section not found in the section table"); |
165 | "Application ID section not found in the section table"); |
161 | res = -1; |
166 | res = -1; |
162 | } else { |
167 | } else { |
163 | psiconv_debug(lev+2,header->section_table_offset, |
168 | psiconv_debug(lev+2,sto, |
164 | "Application ID section at offset %08x",applid_sec); |
169 | "Application ID section at offset %08x",applid_sec); |
165 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
170 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
166 | &appl_id); |
171 | &appl_id); |
167 | } |
172 | } |
168 | if ((appl_id->id != PSICONV_ID_TEXTED) || |
173 | if ((appl_id->id != PSICONV_ID_TEXTED) || |
… | |
… | |
175 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
180 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
176 | PSICONV_ID_TEXTED,temp_str); |
181 | PSICONV_ID_TEXTED,temp_str); |
177 | free(temp_str); |
182 | free(temp_str); |
178 | } |
183 | } |
179 | |
184 | |
180 | psiconv_progress(lev+2,header->section_table_offset, |
185 | psiconv_progress(lev+2,sto, |
181 | "Looking for the Page layout section"); |
186 | "Looking for the Page layout section"); |
182 | if (! page_sec) { |
187 | if (! page_sec) { |
183 | psiconv_warn(lev+2,header->section_table_offset, |
188 | psiconv_warn(lev+2,sto, |
184 | "Page layout section not found in the section table"); |
189 | "Page layout section not found in the section table"); |
185 | (*result)->page_sec = NULL; |
190 | (*result)->page_sec = NULL; |
186 | res = -1; |
191 | res = -1; |
187 | } else { |
192 | } else { |
188 | psiconv_debug(lev+2,header->section_table_offset, |
193 | psiconv_debug(lev+2,sto, |
189 | "Page layout section at offset %08x",page_sec); |
194 | "Page layout section at offset %08x",page_sec); |
190 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
195 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
191 | &(*result)->page_sec); |
196 | &(*result)->page_sec); |
192 | } |
197 | } |
193 | |
198 | |
194 | base_char = psiconv_basic_character_layout(); |
199 | base_char = psiconv_basic_character_layout(); |
195 | base_para = psiconv_basic_paragraph_layout(); |
200 | base_para = psiconv_basic_paragraph_layout(); |
196 | |
201 | |
197 | psiconv_progress(lev+2,header->section_table_offset, |
202 | psiconv_progress(lev+2,sto, |
198 | "Looking for the TextEd section"); |
203 | "Looking for the TextEd section"); |
199 | if (! texted_sec) { |
204 | if (! texted_sec) { |
200 | psiconv_warn(lev+2,header->section_table_offset, |
205 | psiconv_warn(lev+2,sto, |
201 | "TextEd section not found in the section table"); |
206 | "TextEd section not found in the section table"); |
202 | (*result)->texted_sec = NULL; |
207 | (*result)->texted_sec = NULL; |
203 | res = -1; |
208 | res = -1; |
204 | } else { |
209 | } else { |
205 | psiconv_debug(lev+2,header->section_table_offset, |
210 | psiconv_debug(lev+2,sto, "TextEd section at offset %08x",texted_sec); |
206 | "TextEd section at offset %08x",texted_sec); |
|
|
207 | res |= psiconv_parse_texted_section(buf,lev+2,texted_sec,NULL, |
211 | res |= psiconv_parse_texted_section(buf,lev+2,texted_sec,NULL, |
208 | &(*result)->texted_sec, |
212 | &(*result)->texted_sec, |
209 | base_char,base_para); |
213 | base_char,base_para); |
210 | } |
214 | } |
211 | psiconv_free_character_layout(base_char); |
215 | psiconv_free_character_layout(base_char); |
212 | psiconv_free_paragraph_layout(base_para); |
216 | psiconv_free_paragraph_layout(base_para); |
213 | |
217 | |
214 | psiconv_free_application_id_section(appl_id); |
218 | psiconv_free_application_id_section(appl_id); |
215 | psiconv_free_header_section(header); |
|
|
216 | psiconv_free_section_table_section(table); |
219 | psiconv_free_section_table_section(table); |
217 | |
220 | |
218 | psiconv_progress(lev+1,off,"End of word file"); |
221 | psiconv_progress(lev+1,off,"End of word file"); |
219 | return res; |
222 | return res; |
220 | } |
223 | } |
221 | |
224 | |
222 | int psiconv_parse_word_file(const psiconv_buffer buf,int lev, psiconv_u32 off, |
225 | int psiconv_parse_word_file(const psiconv_buffer buf,int lev, psiconv_u32 off, |
223 | psiconv_word_f *result) |
226 | psiconv_word_f *result) |
224 | { |
227 | { |
225 | int res=0; |
228 | int res=0; |
226 | psiconv_header_section header; |
|
|
227 | psiconv_section_table_section table; |
229 | psiconv_section_table_section table; |
228 | psiconv_application_id_section appl_id; |
230 | psiconv_application_id_section appl_id; |
229 | char *temp_str; |
231 | char *temp_str; |
230 | psiconv_u32 pwd_sec = 0; |
232 | psiconv_u32 pwd_sec = 0; |
231 | psiconv_u32 status_sec = 0; |
233 | psiconv_u32 status_sec = 0; |
… | |
… | |
233 | psiconv_u32 page_sec = 0; |
235 | psiconv_u32 page_sec = 0; |
234 | psiconv_u32 text_sec = 0; |
236 | psiconv_u32 text_sec = 0; |
235 | psiconv_u32 layout_sec = 0; |
237 | psiconv_u32 layout_sec = 0; |
236 | psiconv_u32 applid_sec = 0; |
238 | psiconv_u32 applid_sec = 0; |
237 | psiconv_section_table_entry entry; |
239 | psiconv_section_table_entry entry; |
|
|
240 | psiconv_u32 sto; |
238 | int i; |
241 | int i; |
239 | |
242 | |
240 | psiconv_progress(lev+1,off,"Going to read a word file"); |
243 | psiconv_progress(lev+1,off,"Going to read a word file"); |
241 | *result = malloc(sizeof(**result)); |
244 | *result = malloc(sizeof(**result)); |
242 | |
245 | |
243 | psiconv_progress(lev+2,off, "Going to read the header section"); |
246 | psiconv_progress(lev+2,off,"Going to read the offset of the MBM jumptable"); |
244 | res |= psiconv_parse_header_section(buf,lev+2,off,NULL,&header); |
247 | sto = psiconv_read_u32(buf,lev+2,off); |
|
|
248 | psiconv_debug(lev+2,off,"Offset: %08x",sto); |
245 | |
249 | |
246 | psiconv_progress(lev+2,header->section_table_offset, |
250 | psiconv_progress(lev+2,sto, |
247 | "Going to read the section table section"); |
251 | "Going to read the section table section"); |
248 | res |= psiconv_parse_section_table_section(buf,lev+2, |
252 | res |= psiconv_parse_section_table_section(buf,lev+2,sto, NULL,&table); |
249 | header->section_table_offset, |
|
|
250 | NULL,&table); |
|
|
251 | |
253 | |
252 | for (i = 0; i < psiconv_list_length(table); i ++) { |
254 | for (i = 0; i < psiconv_list_length(table); i ++) { |
253 | psiconv_progress(lev+2,header->section_table_offset, |
255 | psiconv_progress(lev+2,sto, "Going to read entry %d",i); |
254 | "Going to read entry %d",i); |
|
|
255 | entry = psiconv_list_get(table,i); |
256 | entry = psiconv_list_get(table,i); |
256 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
257 | if (entry->id == PSICONV_ID_APPL_ID_SECTION) { |
257 | applid_sec = entry->offset; |
258 | applid_sec = entry->offset; |
258 | psiconv_debug(lev+3,header->section_table_offset, |
259 | psiconv_debug(lev+3,sto, |
259 | "Found the Application ID section at %08x",applid_sec); |
260 | "Found the Application ID section at %08x",applid_sec); |
260 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
261 | } else if (entry->id == PSICONV_ID_PAGE_LAYOUT_SECTION) { |
261 | page_sec = entry->offset; |
262 | page_sec = entry->offset; |
262 | psiconv_debug(lev+3,header->section_table_offset, |
263 | psiconv_debug(lev+3,sto, |
263 | "Found the Page Layout section at %08x",page_sec); |
264 | "Found the Page Layout section at %08x",page_sec); |
264 | } else if (entry->id == PSICONV_ID_TEXT_SECTION) { |
265 | } else if (entry->id == PSICONV_ID_TEXT_SECTION) { |
265 | text_sec = entry->offset; |
266 | text_sec = entry->offset; |
266 | psiconv_debug(lev+3,header->section_table_offset, |
267 | psiconv_debug(lev+3,sto, "Found the Text section at %08x",text_sec); |
267 | "Found the Text section at %08x",text_sec); |
|
|
268 | } else if (entry->id == PSICONV_ID_PASSWORD_SECTION) { |
268 | } else if (entry->id == PSICONV_ID_PASSWORD_SECTION) { |
269 | pwd_sec = entry->offset; |
269 | pwd_sec = entry->offset; |
270 | psiconv_debug(lev+3,header->section_table_offset, |
270 | psiconv_debug(lev+3,sto, |
271 | "Found the Password section at %08x",pwd_sec); |
271 | "Found the Password section at %08x",pwd_sec); |
272 | psiconv_warn(lev+3,header->section_table_offset, |
272 | psiconv_warn(lev+3,sto, |
273 | "Password section found - can't read encrypted data"); |
273 | "Password section found - can't read encrypted data"); |
274 | res = -1; |
274 | res = -1; |
275 | } else if (entry->id == PSICONV_ID_WORD_STATUS_SECTION) { |
275 | } else if (entry->id == PSICONV_ID_WORD_STATUS_SECTION) { |
276 | status_sec = entry->offset; |
276 | status_sec = entry->offset; |
277 | psiconv_debug(lev+3,header->section_table_offset, |
277 | psiconv_debug(lev+3,sto, |
278 | "Found the Word Status section at %08x",status_sec); |
278 | "Found the Word Status section at %08x",status_sec); |
279 | } else if (entry->id == PSICONV_ID_WORD_STYLES_SECTION) { |
279 | } else if (entry->id == PSICONV_ID_WORD_STYLES_SECTION) { |
280 | styles_sec = entry->offset; |
280 | styles_sec = entry->offset; |
281 | psiconv_debug(lev+3,header->section_table_offset, |
281 | psiconv_debug(lev+3,sto, |
282 | "Found the Word Styles section at %08x",styles_sec); |
282 | "Found the Word Styles section at %08x",styles_sec); |
283 | } else if (entry->id == PSICONV_ID_LAYOUT_SECTION) { |
283 | } else if (entry->id == PSICONV_ID_LAYOUT_SECTION) { |
284 | layout_sec = entry->offset; |
284 | layout_sec = entry->offset; |
285 | psiconv_debug(lev+3,header->section_table_offset, |
285 | psiconv_debug(lev+3,sto, |
286 | "Found the Layout section at %08x",layout_sec); |
286 | "Found the Layout section at %08x",layout_sec); |
287 | } else { |
287 | } else { |
288 | psiconv_warn(lev+3,header->section_table_offset, |
288 | psiconv_warn(lev+3,sto, |
289 | "Found unknown section in the Section Table"); |
289 | "Found unknown section in the Section Table"); |
290 | psiconv_debug(lev+3,header->section_table_offset, |
290 | psiconv_debug(lev+3,sto, |
291 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
291 | "Section ID %08x, offset %08x",entry->id,entry->offset); |
292 | res = -1; |
292 | res = -1; |
293 | } |
293 | } |
294 | } |
294 | } |
295 | |
295 | |
296 | |
296 | |
297 | psiconv_progress(lev+2,header->section_table_offset, |
297 | psiconv_progress(lev+2,sto, |
298 | "Looking for the Status section"); |
298 | "Looking for the Status section"); |
299 | if (!status_sec) { |
299 | if (!status_sec) { |
300 | psiconv_warn(lev+2,header->section_table_offset, |
|
|
301 | "Status section not found in the section table"); |
300 | psiconv_warn(lev+2,sto, "Status section not found in the section table"); |
302 | res = -1; |
301 | res = -1; |
303 | } else { |
302 | } else { |
304 | psiconv_debug(lev+2,header->section_table_offset, |
303 | psiconv_debug(lev+2,sto, "Status section at offset %08x",status_sec); |
305 | "Status section at offset %08x",status_sec); |
|
|
306 | res |= psiconv_parse_word_status_section(buf,lev+2,status_sec,NULL, |
304 | res |= psiconv_parse_word_status_section(buf,lev+2,status_sec,NULL, |
307 | &((*result)->status_sec)); |
305 | &((*result)->status_sec)); |
308 | } |
306 | } |
309 | |
307 | |
310 | psiconv_progress(lev+2,header->section_table_offset, |
308 | psiconv_progress(lev+2,sto, "Looking for the Application ID section"); |
311 | "Looking for the Application ID section"); |
|
|
312 | if (! applid_sec) { |
309 | if (! applid_sec) { |
313 | psiconv_warn(lev+2,header->section_table_offset, |
310 | psiconv_warn(lev+2,sto, |
314 | "Application ID section not found in the section table"); |
311 | "Application ID section not found in the section table"); |
315 | res = -1; |
312 | res = -1; |
316 | } else { |
313 | } else { |
317 | psiconv_debug(lev+2,header->section_table_offset, |
314 | psiconv_debug(lev+2,sto, |
318 | "Application ID section at offset %08x",applid_sec); |
315 | "Application ID section at offset %08x",applid_sec); |
319 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
316 | res |= psiconv_parse_application_id_section(buf,lev+2,applid_sec,NULL, |
320 | &appl_id); |
317 | &appl_id); |
321 | } |
318 | } |
322 | if ((appl_id->id != PSICONV_ID_WORD) || |
319 | if ((appl_id->id != PSICONV_ID_WORD) || |
… | |
… | |
329 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
326 | psiconv_debug(lev+2,applid_sec,"Name: `%s' expected, `%s' found", |
330 | PSICONV_ID_WORD,temp_str); |
327 | PSICONV_ID_WORD,temp_str); |
331 | free(temp_str); |
328 | free(temp_str); |
332 | } |
329 | } |
333 | |
330 | |
334 | psiconv_progress(lev+2,header->section_table_offset, |
331 | psiconv_progress(lev+2,sto, |
335 | "Looking for the Page layout section"); |
332 | "Looking for the Page layout section"); |
336 | if (! page_sec) { |
333 | if (! page_sec) { |
337 | psiconv_warn(lev+2,header->section_table_offset, |
334 | psiconv_warn(lev+2,sto, |
338 | "Page layout section not found in the section table"); |
335 | "Page layout section not found in the section table"); |
339 | (*result)->page_sec = NULL; |
336 | (*result)->page_sec = NULL; |
340 | res = -1; |
337 | res = -1; |
341 | } else { |
338 | } else { |
342 | psiconv_debug(lev+2,header->section_table_offset, |
339 | psiconv_debug(lev+2,sto, |
343 | "Page layout section at offset %08x",page_sec); |
340 | "Page layout section at offset %08x",page_sec); |
344 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
341 | res |= psiconv_parse_page_layout_section(buf,lev+2,page_sec,NULL, |
345 | &(*result)->page_sec); |
342 | &(*result)->page_sec); |
346 | } |
343 | } |
347 | |
344 | |
348 | psiconv_progress(lev+2,header->section_table_offset, |
345 | psiconv_progress(lev+2,sto, |
349 | "Looking for the Word Style section"); |
346 | "Looking for the Word Style section"); |
350 | if (!styles_sec) { |
347 | if (!styles_sec) { |
351 | psiconv_warn(lev+2,header->section_table_offset, |
348 | psiconv_warn(lev+2,sto, |
352 | "Word styles section not found in the section table"); |
349 | "Word styles section not found in the section table"); |
353 | (*result)->styles_sec = NULL; |
350 | (*result)->styles_sec = NULL; |
354 | res = -1; |
351 | res = -1; |
355 | } else { |
352 | } else { |
356 | psiconv_debug(lev+2,header->section_table_offset, |
353 | psiconv_debug(lev+2,sto, |
357 | "Word styles section at offset %08x",styles_sec); |
354 | "Word styles section at offset %08x",styles_sec); |
358 | res |= psiconv_parse_word_styles_section(buf,lev+2,styles_sec,NULL, |
355 | res |= psiconv_parse_word_styles_section(buf,lev+2,styles_sec,NULL, |
359 | &(*result)->styles_sec); |
356 | &(*result)->styles_sec); |
360 | } |
357 | } |
361 | |
358 | |
362 | psiconv_progress(lev+2,header->section_table_offset, |
359 | psiconv_progress(lev+2,sto, |
363 | "Looking for the Text section"); |
360 | "Looking for the Text section"); |
364 | if (!text_sec) { |
361 | if (!text_sec) { |
365 | psiconv_warn(lev+2,header->section_table_offset, |
362 | psiconv_warn(lev+2,sto, "Text section not found in the section table"); |
366 | "Text section not found in the section table"); |
|
|
367 | (*result)->paragraphs = NULL; |
363 | (*result)->paragraphs = NULL; |
368 | res = -1; |
364 | res = -1; |
369 | } else { |
365 | } else { |
370 | psiconv_debug(lev+2,header->section_table_offset, |
366 | psiconv_debug(lev+2,sto, |
371 | "Text section at offset %08x",text_sec); |
367 | "Text section at offset %08x",text_sec); |
372 | res |= psiconv_parse_text_section(buf,lev+2,text_sec,NULL, |
368 | res |= psiconv_parse_text_section(buf,lev+2,text_sec,NULL, |
373 | &(*result)->paragraphs); |
369 | &(*result)->paragraphs); |
374 | } |
370 | } |
375 | |
371 | |
376 | if (((*result)->paragraphs) && ((*result)->styles_sec)) { |
372 | if (((*result)->paragraphs) && ((*result)->styles_sec)) { |
377 | psiconv_progress(lev+2,header->section_table_offset, |
373 | psiconv_progress(lev+2,sto, |
378 | "Looking for the Layout section"); |
374 | "Looking for the Layout section"); |
379 | if (!layout_sec) { |
375 | if (!layout_sec) { |
380 | psiconv_debug(lev+2,header->section_table_offset, |
376 | psiconv_debug(lev+2,sto, |
381 | "Layout section not found in the section table"); |
377 | "Layout section not found in the section table"); |
382 | res = -1; |
378 | res = -1; |
383 | } else { |
379 | } else { |
384 | psiconv_debug(lev+2,header->section_table_offset, |
380 | psiconv_debug(lev+2,sto, |
385 | "Layout section at offset %08x",layout_sec); |
381 | "Layout section at offset %08x",layout_sec); |
386 | res |= psiconv_parse_styled_layout_section(buf,lev+2,layout_sec,NULL, |
382 | res |= psiconv_parse_styled_layout_section(buf,lev+2,layout_sec,NULL, |
387 | (*result)->paragraphs, |
383 | (*result)->paragraphs, |
388 | (*result)->styles_sec); |
384 | (*result)->styles_sec); |
389 | } |
385 | } |
390 | } else |
386 | } else |
391 | psiconv_debug(lev+2,header->section_table_offset, |
387 | psiconv_debug(lev+2,sto, |
392 | "Skipping search for Layout section, as either the " |
388 | "Skipping search for Layout section, as either the " |
393 | "text or the word styles section was not found"); |
389 | "text or the word styles section was not found"); |
394 | |
390 | |
395 | psiconv_free_application_id_section(appl_id); |
391 | psiconv_free_application_id_section(appl_id); |
396 | psiconv_free_header_section(header); |
|
|
397 | psiconv_free_section_table_section(table); |
392 | psiconv_free_section_table_section(table); |
398 | |
393 | |
399 | psiconv_progress(lev+1,off,"End of word file"); |
394 | psiconv_progress(lev+1,off,"End of word file"); |
400 | return res; |
395 | return res; |
401 | } |
396 | } |