Fix the alignment
[infodrom/dtaus] / main.c
diff --git a/main.c b/main.c
index 1cb9502..6c7b46e 100644 (file)
--- a/main.c
+++ b/main.c
@@ -28,21 +28,29 @@ static char version[] = "0.6";
 #include <stdlib.h>
 #include "dtaus.h"
 
-char *dtaus   = "dtaus0.txt";
-char *control = "dtaus0.ctl";
-char *beleg   = "dtaus0.doc";
-char *check   = "dtaus0.sik";
+#define FN_DTAUS   "dtaus0.txt"
+#define FN_CONTROL "dtaus0.ctl"
+#define FN_BELEG   "dtaus0.doc"
+#define FN_CHECK   "dtaus0.sik"
+#define FN_LATEX   "dtaus0.tex"
+
+char *dtaus   = FN_DTAUS;
+char *control = FN_CONTROL;
+char *beleg   = FN_BELEG;
+char *check   = FN_CHECK;
+char *latex   = NULL;
 
 void help ()
 {
   printf ("dtaus - Belegloser Datenträgeraustausch mit einer Bank\n\n");
-  printf ("  -dtaus        Erzeugt eine Bankdatei\n");
-  printf ("  -control      Liest eine Bankdatei und erzeugt die Kontrolldatei\n");
+  printf ("  -dtaus         Erzeugt eine Bankdatei\n");
+  printf ("  -control       Liest eine Bankdatei und erzeugt die Kontrolldatei\n");
   printf ("\n");
-  printf ("  -d <dtaus>    Bankdatei [%s]\n", dtaus);
-  printf ("  -c <control>  Steuerdatei [%s]\n", control);
-  printf ("  -b <begleit>  Begleitzettel für die Bank [%s]\n", beleg);
-  printf ("  -o <kontroll> Kontrolldatei zum Abheften [%s]\n", check);
+  printf ("  -d <dtaus>     Bankdatei [%s]\n", FN_DTAUS);
+  printf ("  -c <control>   Steuerdatei [%s]\n", FN_CONTROL);
+  printf ("  -b <begleit>   Begleitzettel für die Bank [%s]\n", FN_BELEG);
+  printf ("  -l [<begleit>] Begleitzettel als LaTeX [%s]\n", FN_LATEX);
+  printf ("  -o <kontroll>  Kontrolldatei zum Abheften [%s]\n", FN_CHECK);
 }
 
 #define DTAUS   1
@@ -76,6 +84,12 @@ int main (int argc, char **argv)
        i++;
        beleg = argv[i];
       }
+    } else if ( !strcmp(argv[i], "-l") ) {
+      if (argc - i > 1 && argv[i+1][0] != '-') {
+       i++;
+       latex = argv[i];
+      } else
+       latex = FN_LATEX;
     } else if ( !strcmp(argv[i], "-o") ) {
       if (argc - i > 1) {
        i++;
@@ -89,15 +103,21 @@ int main (int argc, char **argv)
   }
 
   if (action == DTAUS) {
-    if (!stat((char *)control, &sbuf)) {
-      if (control2dtaus ((char *)control, (char *)dtaus, (char *)beleg, (char *)check) == 0)
+    if (!strcmp("-", control) || !stat(control, &sbuf)) {
+      if (control2dtaus (control, dtaus, beleg, check, latex) == 0)
        exit (1);
     }
-    else exit (1);
+    else {
+      fprintf( stderr, "Can't stat %s\n", control);
+      exit (1);
+    }
   } else if (action == CONTROL) {
-    if (!stat((char *)dtaus, &sbuf))
-      dtaus2control ((char *)dtaus, (char *)control);
-    else exit (1);
+    if (!strcmp("-",dtaus) || !stat(dtaus, &sbuf))
+      dtaus2control (dtaus, control);
+    else {
+      fprintf( stderr, "Can't stat %s\n", dtaus);
+      exit (1);
+    }
   } else {
     printf ("Keine Routine angegeben (-dtaus bzw. -control vergessen).\n");
     exit (1);