=================================================================== RCS file: /home/cvs/OpenXM/src/util/oxgentexi.c,v retrieving revision 1.4 retrieving revision 1.7 diff -u -p -r1.4 -r1.7 --- OpenXM/src/util/oxgentexi.c 2005/04/05 13:12:06 1.4 +++ OpenXM/src/util/oxgentexi.c 2005/04/11 11:13:32 1.7 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM/src/util/oxgentexi.c,v 1.3 2005/04/04 12:38:32 takayama Exp $ */ +/* $OpenXM: OpenXM/src/util/oxgentexi.c,v 1.6 2005/04/06 09:26:29 takayama Exp $ */ #include int Debug = 0; @@ -41,6 +41,7 @@ int GenExample = 0; int DebugItem = 0; char *Title = NULL; char *Author = NULL; +char *InfoName = NULL; int NoSorting = 0; main(int argc,char *argv[]) { @@ -71,6 +72,8 @@ main(int argc,char *argv[]) { DebugItem = 1; }else if (strcmp(argv[i],"--title") == 0) { i++; Title = str(argv[i]); + }else if (strcmp(argv[i],"--infoName") == 0) { + i++; InfoName = str(argv[i]); }else if (strcmp(argv[i],"--author") == 0) { i++; Author = str(argv[i]); }else if (strcmp(argv[i],"--noSorting") == 0) { @@ -125,7 +128,7 @@ main(int argc,char *argv[]) { exit(0); } - if (Title) printTitlePage(Title,Author); + if (Title) printTitlePage(Title,Author,InfoName); printMenu(stdout,items,n); @@ -300,6 +303,7 @@ struct item *getItem() { int pp,pOld; int argc; int examplec = 0; + int i; it = newItem(); do { p = nextToken(key,LIMIT); @@ -379,8 +383,11 @@ struct item *getItem() { do { pOld = p; p = nextToken(key,LIMIT); - /* printf("%s\n",key); */ - if (key[strlen(key)-1] == ':') break; /* Next keyword. */ + /* printf("key=%s\n",key); */ + if (key[strlen(key)-1] == ':') { + pOld = p-strlen(key); + break; /* Next keyword. */ + } }while (p >= 0); if (strcmp(key2,"description:") == 0) { it->description = str2(&(S[pp]),pOld-pp); @@ -422,7 +429,11 @@ struct item *getItem() { } } }else{ - fprintf(stderr,"Warning: unknown keyword << %s >> at %s. Ignored.\n",key, it->name); + fprintf(stderr,"Error: unknown keyword << %s >> at %s.\n",key, it->name); + fprintf(stderr," The error occurs around "); + for (i=pp ; i < p; i++) fputc(S[i],stderr); + fprintf(stderr,"\n\n"); + exit(1); p = nextToken(key,LIMIT); } }while (p >= 0); @@ -512,7 +523,7 @@ printTexi_common(FILE *fp,struct item *it) { printTexi0(FILE *fp, struct item *it) { int i; - fprintf(fp,"@c DO NOT EDIT THIS FILE. Generated by gentexi0.\n"); + fprintf(fp,"@c DO NOT EDIT THIS FILE. Generated by gentexi for asir function item.\n"); if (it == NULL) { fprintf(fp,"@c item is NULL.\n"); return ; @@ -586,7 +597,7 @@ printTexi1(FILE *fp, struct item *it) { int i; /* For it->type == 1 */ - fprintf(fp,"@c DO NOT EDIT THIS FILE. Generated by gentexi1.\n"); + fprintf(fp,"@c DO NOT EDIT THIS FILE. Generated by gentexi for verbose item.\n"); if (it == NULL) { fprintf(fp,"@c item is NULL.\n"); return ; @@ -620,7 +631,9 @@ outputExample(FILE *fp,char *s) { fprintf(fp,":"); i += 5; }else fprintf(fp,"@@"); }else{ - fputc(s[i],fp); + if (s[i] == '{') {fprintf(fp,"%s","@{"); } + else if (s[i] == '}') {fprintf(fp,"%s","@}");} + else fputc(s[i],fp); } } } @@ -652,7 +665,7 @@ outputOfExample(char *com) { putchar('\n'); } -printTitlePage(char *title, char *author) { +printTitlePage(char *title, char *author,char *infoName) { printf("\\input texinfo\n"); printf("@def@colon{:}\n\n"); printf("@iftex\n"); @@ -662,7 +675,7 @@ printTitlePage(char *title, char *author) { printf("@end iftex\n"); printf("@overfullrule=0pt\n"); - printf("@setfilename %s\n",Title); + if (infoName != NULL) printf("@setfilename %s\n",infoName); printf("@settitle %s\n",Title); printf("@titlepage\n"); @@ -675,6 +688,15 @@ printTitlePage(char *title, char *author) { } printBye() { + printf("@node Index,,, Top\n"); + printf("@unnumbered Index\n"); + printf("@printindex fn\n"); + printf("@printindex cp\n"); + printf("@iftex\n"); + printf("@vfill @eject\n"); + printf("@end iftex\n"); + printf("@summarycontents\n"); + printf("@contents\n"); printf("\n@bye\n"); } /* Old file was OpenXM/src/asir-contrib/packages/doc/gentexi.c */