--- psiconv/trunk/lib/psiconv/generate_driver.c 2004/02/26 15:58:48 232 +++ psiconv/trunk/lib/psiconv/generate_driver.c 2004/02/26 16:27:43 233 @@ -44,8 +44,10 @@ psiconv_error(config,0,0,"Can't parse to an empty buffer!"); return -PSICONV_E_OTHER; } - if (!(*buf = psiconv_buffer_new())) + if (!(*buf = psiconv_buffer_new())) { + psiconv_error(config,lev+1,0,"Out of memory error"); return -PSICONV_E_NOMEM; + } if (value->type == psiconv_word_file) { if ((res = psiconv_write_header_section(config,*buf,lev+1,PSICONV_ID_PSION5, @@ -88,8 +90,10 @@ res = -PSICONV_E_GENERATE; goto ERROR; } - if ((res = psiconv_buffer_resolve(*buf))) + if ((res = psiconv_buffer_resolve(*buf))) { + psiconv_error(config,lev+1,0,"Internal error resolving buffer references"); goto ERROR; + } return -PSICONV_E_OK; ERROR: @@ -116,63 +120,84 @@ } if (!(section_table = psiconv_list_new(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR1; } if (!(entry = malloc(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR2; } if (!(base_char = psiconv_basic_character_layout())) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR3; } if (!(base_para = psiconv_basic_paragraph_layout())) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR4; } section_table_id = psiconv_buffer_unique_id(); - if ((res = psiconv_write_offset(config,buf,lev+1,section_table_id))) + if ((res = psiconv_write_offset(config,buf,lev+1,section_table_id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; + } entry->id = PSICONV_ID_APPL_ID_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; + } if ((res=psiconv_write_application_id_section(config,buf,lev+1, PSICONV_ID_TEXTED,unicode_texted))) goto ERROR5; entry->id = PSICONV_ID_PAGE_LAYOUT_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; + } if ((res = psiconv_write_page_layout_section(config,buf,lev+1,value->page_sec))) goto ERROR5; entry->id = PSICONV_ID_TEXTED; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR5; + } if ((res = psiconv_write_texted_section(config,buf,lev+1,value->texted_sec, base_char,base_para,&buf_texted))) goto ERROR5; - if ((res = psiconv_buffer_concat(buf,buf_texted))) + if ((res = psiconv_buffer_concat(buf,buf_texted))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR6; + } - - if ((res = psiconv_buffer_add_target(buf,section_table_id))) + if ((res = psiconv_buffer_add_target(buf,section_table_id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR6; + } res = psiconv_write_section_table_section(config,buf,lev+1,section_table); @@ -210,77 +235,105 @@ } if (!(section_table = psiconv_list_new(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR1; } if (!(entry = malloc(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR2; } section_table_id = psiconv_buffer_unique_id(); - if ((res = psiconv_write_offset(config,buf,lev+1,section_table_id))) + if ((res = psiconv_write_offset(config,buf,lev+1,section_table_id))) goto ERROR3; entry->id = PSICONV_ID_APPL_ID_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res=psiconv_write_application_id_section(config,buf,lev+1, PSICONV_ID_WORD,unicode_word))) goto ERROR3; entry->id = PSICONV_ID_WORD_STATUS_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_word_status_section(config,buf,lev+1,value->status_sec))) goto ERROR3; entry->id = PSICONV_ID_PAGE_LAYOUT_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_page_layout_section(config,buf,lev+1,value->page_sec))) goto ERROR3; entry->id = PSICONV_ID_WORD_STYLES_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_word_styles_section(config,buf,lev+1,value->styles_sec))) goto ERROR3; entry->id = PSICONV_ID_TEXT_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_text_section(config,buf,lev+1,value->paragraphs))) goto ERROR3; entry->id = PSICONV_ID_LAYOUT_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_styled_layout_section(config,buf,lev+1,value->paragraphs, value->styles_sec))) goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,section_table_id))) + if ((res = psiconv_buffer_add_target(buf,section_table_id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } res = psiconv_write_section_table_section(config,buf,lev+1,section_table); @@ -312,11 +365,13 @@ } if (!(section_table = psiconv_list_new(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR1; } if (!(entry = malloc(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR2; } @@ -327,25 +382,35 @@ entry->id = PSICONV_ID_APPL_ID_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res=psiconv_write_application_id_section(config,buf,lev+1, PSICONV_ID_SKETCH,unicode_paint))) goto ERROR3; entry->id = PSICONV_ID_SKETCH_SECTION; entry->offset = psiconv_buffer_unique_id(); - if ((res = psiconv_list_add(section_table,entry))) + if ((res = psiconv_list_add(section_table,entry))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,entry->offset))) + } + if ((res = psiconv_buffer_add_target(buf,entry->offset))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_sketch_section(config,buf,lev+1,value->sketch_sec))) goto ERROR3; - if ((res = psiconv_buffer_add_target(buf,section_table_id))) + if ((res = psiconv_buffer_add_target(buf,section_table_id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } res = psiconv_write_section_table_section(config,buf,lev+1,section_table); ERROR3: @@ -376,30 +441,40 @@ } if (!(jumptable = psiconv_list_new(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR1; } table_id = psiconv_buffer_unique_id(); - if ((res = psiconv_buffer_add_reference(buf,table_id))) + if ((res = psiconv_buffer_add_reference(buf,table_id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR2; + } for (i = 0; i < psiconv_list_length(value->sections); i++) { if (!(section = psiconv_list_get(value->sections,i))) { - psiconv_error(config,lev,0,"Massive memory corruption"); + psiconv_error(config,lev,0,"Data structure corruption"); res = -PSICONV_E_NOMEM; goto ERROR2; } id = psiconv_buffer_unique_id(); - psiconv_list_add(jumptable,&id); - if ((res = psiconv_buffer_add_target(buf,id))) + if ((res = psiconv_list_add(jumptable,&id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR2; + } + if ((res = psiconv_buffer_add_target(buf,id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); + goto ERROR2; + } if ((res = psiconv_write_paint_data_section(config,buf,lev+1,section,0))) goto ERROR2; } - if ((res = psiconv_buffer_add_target(buf,table_id))) + if ((res = psiconv_buffer_add_target(buf,table_id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR2; + } if ((res = psiconv_write_jumptable_section(config,buf,lev+1,jumptable))) goto ERROR2; @@ -432,11 +507,13 @@ } if (!(jumptable = psiconv_list_new(sizeof(*entry)))) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR1; } if (!(sec_buf = psiconv_buffer_new())) { + psiconv_error(config,lev+1,0,"Out of memory error"); res = -PSICONV_E_NOMEM; goto ERROR2; } @@ -446,14 +523,19 @@ for (i = 0; i < psiconv_list_length(value->sections); i++) { if (!(section = psiconv_list_get(value->sections,i))) { - psiconv_error(config,lev,0,"Massive memory corruption"); + psiconv_error(config,lev,0,"Data structure corruption"); res = -PSICONV_E_NOMEM; goto ERROR3; } id = psiconv_buffer_unique_id(); - psiconv_list_add(jumptable,&id); - if ((res = psiconv_buffer_add_target(sec_buf,id))) + if ((res = psiconv_list_add(jumptable,&id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); + goto ERROR3; + } + if ((res = psiconv_buffer_add_target(sec_buf,id))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } if ((res = psiconv_write_clipart_section(config,sec_buf, lev+1,section))) goto ERROR3; } @@ -461,8 +543,10 @@ if ((res = psiconv_write_jumptable_section(config,buf,lev+1,jumptable))) goto ERROR3; - if ((res = psiconv_buffer_concat(buf,sec_buf))) + if ((res = psiconv_buffer_concat(buf,sec_buf))) { + psiconv_error(config,lev+1,0,"Out of memory error"); goto ERROR3; + } ERROR3: