/[public]/psiconv/trunk/program/psiconv/gen_rtf.c
ViewVC logotype

Diff of /psiconv/trunk/program/psiconv/gen_rtf.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 14 Revision 67
17 * along with this program; if not, write to the Free Software 17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 */ 19 */
20 20
21#include "config.h" 21#include "config.h"
22#include "compat.h"
22#include <stdio.h> 23#include <stdio.h>
23#include <string.h> 24#include <string.h>
24#include "data.h" 25#include "psiconv/data.h"
25#include "list.h" 26#include "psiconv/list.h"
26#include "gen.h" 27#include "gen.h"
28#include "psiconv.h"
27 29
28 30
29/* 31/*
30 * Various string tables for RTF settings 32 * Various string tables for RTF settings
31 */ 33 */
323/* This is not necessarily the same as returned by basic_character_layout_status 325/* This is not necessarily the same as returned by basic_character_layout_status
324 This one is specific for the base point of RTF */ 326 This one is specific for the base point of RTF */
325static psiconv_character_layout 327static psiconv_character_layout
326 gen_base_char(psiconv_list colors, psiconv_list fonts) 328 gen_base_char(psiconv_list colors, psiconv_list fonts)
327{ 329{
328 struct psiconv_color white = { 0,0,0 }; 330 struct psiconv_color_s white = { 0,0,0 };
329 struct psiconv_color black = { 0xff,0xff,0xff }; 331 struct psiconv_color_s black = { 0xff,0xff,0xff };
330 struct psiconv_font font = { strdup(""),-1 }; /* Pseudo - not added! */ 332 struct psiconv_font_s font = { NULL,-1 }; /* Pseudo - not added! */
331 333
332 struct psiconv_character_layout base_char_struct = 334 struct psiconv_character_layout_s base_char_struct =
333 { 335 {
334 &black, /* color */ 336 &black, /* color */
335 &white, /* back_color */ 337 &white, /* back_color */
336 13.0, /* font_size */ 338 13.0, /* font_size */
337 psiconv_bool_false, /* italic */ 339 psiconv_bool_false, /* italic */
338 psiconv_bool_false, /* bold */ 340 psiconv_bool_false, /* bold */
339 psiconv_normalscript, /* super_sub */ 341 psiconv_normalscript, /* super_sub */
340 psiconv_bool_false, /* underline */ 342 psiconv_bool_false, /* underline */
341 psiconv_bool_false, /* strike_out */ 343 psiconv_bool_false, /* strikethrough */
342 &font, /* font */ 344 &font, /* font */
343 }; 345 };
344 346
347 font.name = strdup("");
345 add_color(colors,&white); 348 add_color(colors,&white);
346 add_color(colors,&black); 349 add_color(colors,&black);
347 350
348 return psiconv_clone_character_layout(&base_char_struct); 351 return psiconv_clone_character_layout(&base_char_struct);
349} 352}
350 353
351void diff_char(FILE *of,psiconv_list colors, psiconv_list fonts, 354static void diff_char(FILE *of,psiconv_list colors, psiconv_list fonts,
352 const psiconv_character_layout old, 355 const psiconv_character_layout old,
353 const psiconv_character_layout new) 356 const psiconv_character_layout new)
354{ 357{
355 if ((old->font->screenfont != new->font->screenfont) || 358 if ((old->font->screenfont != new->font->screenfont) ||
356 strcmp(old->font->name,new->font->name)) 359 strcmp(old->font->name,new->font->name))
369 fprintf(of,"\\b%s",new->bold?"":"0"); 372 fprintf(of,"\\b%s",new->bold?"":"0");
370 if (old->italic != new->italic) 373 if (old->italic != new->italic)
371 fprintf(of,"\\i%s",new->italic?"":"0"); 374 fprintf(of,"\\i%s",new->italic?"":"0");
372 if (old->underline != new->underline) 375 if (old->underline != new->underline)
373 fprintf(of,"\\ul%s",new->underline?"":"0"); 376 fprintf(of,"\\ul%s",new->underline?"":"0");
374 if (old->strike_out != new->strike_out) 377 if (old->strikethrough != new->strikethrough)
375 fprintf(of,"\\strike%s",new->strike_out?"":"0"); 378 fprintf(of,"\\strike%s",new->strikethrough?"":"0");
376 if ((old->color->red != new->color->red) || 379 if ((old->color->red != new->color->red) ||
377 (old->color->green != new->color->green) || 380 (old->color->green != new->color->green) ||
378 (old->color->blue != new->color->blue)) 381 (old->color->blue != new->color->blue))
379 fprintf(of,"\\cf%d",lookup_color(colors,new->color)); 382 fprintf(of,"\\cf%d",lookup_color(colors,new->color));
380 if ((old->back_color->red != new->back_color->red) || 383 if ((old->back_color->red != new->back_color->red) ||
408/* 411/*
409 else if (para->justify_hor == psiconv_justify_left) 412 else if (para->justify_hor == psiconv_justify_left)
410 fprintf(of,"\\ql"); 413 fprintf(of,"\\ql");
411*/ 414*/
412 } 415 }
413 if (para->interline != 0.0) 416 if (para->linespacing != 0.0)
414 fprintf(of,"\\sl%d",(para->interline_exact?-1:1) * 417 fprintf(of,"\\sl%d",(para->linespacing_exact?-1:1) *
415 length_to_twips(para->interline)); 418 length_to_twips(para->linespacing));
416 if (para->top_space != 0.0) 419 if (para->space_above != 0.0)
417 fprintf(of,"\\sb%d",length_to_twips(para->top_space)); 420 fprintf(of,"\\sb%d",length_to_twips(para->space_above));
418 if (para->bottom_space != 0.0) 421 if (para->space_below != 0.0)
419 fprintf(of,"\\sa%d",length_to_twips(para->bottom_space)); 422 fprintf(of,"\\sa%d",length_to_twips(para->space_below));
420 if (para->on_one_page) 423 if (para->keep_together)
421 fprintf(of,"\\keep"); 424 fprintf(of,"\\keep");
422 if (para->together_with) 425 if (para->keep_with_next)
423 fprintf(of,"\\keepn"); 426 fprintf(of,"\\keepn");
424 if (!para->on_next_page) 427 if (!para->on_next_page)
425 fprintf(of,"pagebb"); 428 fprintf(of,"pagebb");
426 if (!para->no_widow_protection) 429 if (!para->no_widow_protection)
427 fprintf(of,"\\nowidctlpar"); 430 fprintf(of,"\\nowidctlpar");
517 520
518 psiconv_list_free(fonts); 521 psiconv_list_free(fonts);
519 psiconv_list_free(colors); 522 psiconv_list_free(colors);
520} 523}
521 524
522void psiconv_gen_rtf(FILE * of, psiconv_file file) 525static int psiconv_gen_rtf(const char *filename, const psiconv_file file,
526 const char *dest)
523{ 527{
528 FILE *of = fopen(filename,"w");
529 if (! of)
530 return -1;
531
524 if (file->type == psiconv_word_file) 532 if (file->type == psiconv_word_file) {
525 psiconv_gen_rtf_word(of,(psiconv_word_f) file->file); 533 psiconv_gen_rtf_word(of,(psiconv_word_f) file->file);
526 else if (file->type == psiconv_texted_file) 534 } else if (file->type == psiconv_texted_file) {
527 psiconv_gen_rtf_texted(of,(psiconv_texted_f) file->file); 535 psiconv_gen_rtf_texted(of,(psiconv_texted_f) file->file);
528 else 536 } else {
537 fclose(of);
529 return; 538 return -1;
539 }
540 return fclose(of);
530} 541}
531 542
543static struct psiconv_fileformat_s ff =
544{
545 "RTF",
546 "Rich Text Format (not functional yet!)",
547 psiconv_gen_rtf
548};
549
550void init_rtf(void)
551{
552 /* psiconv_list_add(fileformat_list,&ff); */
553}
554

Legend:
Removed from v.14  
changed lines
  Added in v.67

frodo@frodo.looijaard.name
ViewVC Help
Powered by ViewVC 1.1.26