Welcome To Our Shell

Mister Spy & Souheyl Bypass Shell

Current Path : /var/www/web-klick.de/dsh/50_dev2017/1300__perllib/Application/

Linux ift1.ift-informatik.de 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
Upload File :
Current File : /var/www/web-klick.de/dsh/50_dev2017/1300__perllib/Application/IfTFiBu.pm7

package Application::IfTFiBu;

use strict;
use Algorithm::Diff;
use Digest::MD5;
use Data::Dumper;

# our $slash = "/";

#*****************************************************************

sub new {

   my $class   = shift;
   $class      = ref($class) || $class;
   my $self    = {};
   $self->{'FILE'} = shift;
   bless($self,$class);
   return($self);
   
}

#*****************************************************************

sub shell {

   my $self  = shift;
   my $cmd   = shift;
   my $datei = shift;
   my $pars  = [@_];
   
   my $o; my $o1; my $mark; my $mark1; my $zaehler; my $file;
   my $konten = {}; 


   if ($cmd eq "use" and $datei) {
      while ($datei) {
         $o     = $o . substr($datei,0,1) . ".\*";
         $datei = substr($datei,1);
      }
      $datei = ".\*" . $o;
   }

   my $laenge = 0;
   opendir(DDIR,$self->{'FILE'} || ".");
   while (0 == 0) {
      $o = readdir(DDIR);
      last if (!$o);
      if ($o =~ /^(.*)\.(csv|kto|txt|sql)$/) {
         $konten->{$1} = $2;
         $o  = $1;
         $o1 = length($o);
         $laenge = $o1 if ($o1 > $laenge);
         if ($cmd eq "use" and !$mark1 and $o =~ /$datei/) {
            $mark1 = $o;
         }
      }
      elsif ($o =~ /^mark\.(.*)$/) {
         $mark = $1;
      }
   }
   closedir(DDIR);
   
   if ($mark1) {
      unlink("mark.$mark");
      open(FFILE,">mark.$mark1");
      print FFILE "1\n";
      close(FFILE);
      $mark = $mark1;
   }
   
   if ($cmd eq "use") {
      print "\n\n\nKontenliste:\n-------------\n";
      foreach $o (sort keys %$konten) {
         $o = substr($o." "x$laenge,0,$laenge) . "  <--- aktives Konto" if ($o eq $mark);
         print $o . "\n";
      }
      print "-------------\n\n";
   }
   
   elsif ($cmd =~ /^(ex|im)/) {
      $self->new($mark.".".$konten->{$mark})->viewkonto_txt($datei);
   }

   elsif ($datei eq "csv") {
      $self->new($mark.".".$konten->{$mark})->viewkonto_txt($cmd,$datei);
   }

   elsif ($datei eq "kto") {
      $self->new($mark.".".$konten->{$mark})->viewkonto_txt($cmd,$datei);
   }

   else {
      $datei = $datei || "edit";
      $file = $self->new($mark.".".$konten->{$mark})->viewkonto_txt($cmd);
      return($file) if ($file =~ /ERROR/);
      $self->$datei($file) if ($file !~/xxx/);
      $file = $self->new($mark.".".$konten->{$mark})->viewkonto_txt($cmd);
   }
   
   
}

#*****************************************************************

sub edit { my $self = shift; my $file = shift; system("joe $file"); }

#*****************************************************************

sub viewkonto_txt {

   my $self   = shift;
   my $kto    = shift;  #  Unterkonto, das angezeigt wird
   my $format = shift;

   my $text; my $text1; my $datum; my $kto1; my $kto2; my $betrag; my $remark;
   my $zeile; my $zeile1; my $zeile2; my $sum; my $o; my $o1; my $name; my $mode;
   my $diff; my $buchh; my $text0; my $header; my $file; my $merged; my $buchh0;
   my $anzahl_zeilen; my $zaehler;

#  1. Ermitteln des Ziel-Files


   return("___NO_SOURCE_FILE___") if ($self->{'FILE'} !~ /^(.*)\.(csv|txt|kto)$/);
   $buchh0 = $1;
   $buchh0 =~ s/^(.*)[\\\/](.*)$/$2/;
   $mode   = "kto"   if ($format =~ s/k//i or !$format);
   $mode   = "csv"   if ($format =~ s/c//i);
   $file   = $buchh0 . "--" . $kto . "." . $mode;
   while ($file =~ s/^(.*)\-\-(.*)\-\-(.*)/$1-$2--$3/) { 1; }
   $file   =~ s/\-+\./\./;
#   $buchh0 = $kto0 . "--" . $kto if ($kto);
   
#  2.  Aufloesen des Quellfiles in Buchhaltung ($buchh0) und Konto ($name)

   $name = "";
   if ($buchh0 =~ s/^(.*?)--(.*)$/$1/) {
      $name = $2;
   }

#  3.  Aufloesen des Kontos in Unterbuchhaltung ($kto0) und Unterkonto ($kto)

   my $kto0  = "";
   if ($kto  =~ s/^(.*)--(.*)$/$1-$2/) {
      $kto0  = $1;  #  Unterbuchhaltung
   }
   $kto =~ s/\-$//;
   
#  4. Auslesen der Quelldaten

   open(FFILE,"<".$self->{'FILE'});
   if (-f $file) {
      $text   = [<FFILE>];
      shift(@$text);
      $text0  = $buchh0 . "--" . $name . "\n" . join("",@$text); #  Speichern des gesamten Files im Falle eines Merge
      $text   = join("",grep(/$kto/,@$text))
   } else {
      $text = <FFILE>;
      $text = join("",grep(/$kto/,<FFILE>));  #  von vorneherein eine Beschraenkung auf Zeilen, die das Konto enthalten
   }
   close(FFILE);
   
#  5.  Eigentliche Berechnung des Exzerpts

   $text =~ s/(\d\d\d\d\d\d\d\d[; ]+\-?\d+\.\d\d[ ;]+)$kto(.*?[ ;]+)/$1---EMPTY---$2/g;  #  relativer Kontopfad
   $text =~ s/(\d\d\d\d\d\d\d\d[; ]+)(\-?\d+\.\d\d[ ;]+)([^ ;]+?[ ;]+)$kto(.*?[ ;]+)/$1\-$2---EMPTYY---$4$3/g; # Konten umdrehen

   $text =~ s/(---EMPTYY---[^\n]+\{/\{\{/;
   $text =~ s/
   $text =~ s/\{(.*?)$kto([a-zA-Z0-9\-\_\:]*)(.*?)\}/\{$1$2$3\}/g;  # Konten in Berechnungen aendern

   $text =~ s/---EMPTY----/-/g;  # Referenz auf das Konto selbst
   $text =~ s/---EMPTY---/-/g;   # eliminieren
   $text =~ s/(\d\d\d\d\d\d\d\d[; ]+-?)--/$1 /g;  #  doppelte Minuszeichen eliminieren
   $text =~ s/(\d\d\d\d\d\d\d\d[; ]+\-?\d+\.\d\d[ ;]+[^ ;-][^\n]+)//g; # ) { 1; } absolutes Konto als erstes Konto geht nicht
   $text =~ s/\n\s*\n/\n/gs;
   $text =~ s/^([^ \n;]+)[; ]+\-?\d+\.\d\d( *)$/$1/g; #  Kontobezeichnungen uebernehmen
   while ($text =~ s/\n$kto0-([^ ;]+[; ]+[^ ;]+)(\s*)\n/\n$1\n/gs) { 1; };  #  Kontobezeichnungen uebernehmen
   while ($text =~ s/\n$kto0-([^ ;]+[; ]+[^ ;]+)[ ;]+(-\d+\.\d\d)(\s*)\n/\n$1\n/gs) { 1; };  #  Kontobezeichnungen uebernehmen
#   while ($text =~ s/\n\s*\S+\s*\n/\n/gs) { 1; }   #  leere Kontoeintraege entfernen

   if ($kto0) {  #  wenn das $kto in Buchhaltung und Zielkonto gesplittet war ...
      $kto  =~ s/^$kto0//;
      $kto  =~ s/^-//;
      $kto0 = $buchh0 . ":" . $name . "-" . $kto0;
      $kto0 =~  s/[:-]-/:/g;
      $text =~ s/(\d\d\d\d\d\d\d\d[; ]+\-?\d+\.\d\d[ ;]+[^ ;]+?[ ;]+)([^ -][^ :;]*)/$1$buchh0\:$2/g;
      $text =~ s/\[([^-][^ :;]?)\]/\[$buchh0\:$1\]/g;
   } else {
      $kto0 = $buchh0;
   }

   $text =~ s/(\d\d\d\d\d\d\d\d[; ]+\-?\d+\.\d\d[ ;]+[^ ;]+?[ ;]+)($kto0\-)/$1/g;
   $text =~ s/\[$kto0\-(.*?)\]/\[$1\]/g;
   $kto0 =~ s/\:/\-/g;
   if (!$kto) {
      $text =~ s/(\d\d\d\d\d\d\d\d[; ]+\-?\d+\.\d\d[ ;]+)\-/$1/g;
      $text =~ s/(\d\d\d\d\d\d\d\d[; ]+\-?\d+\.\d\d[ ;]+[^ ;]+[ ;]+)\-/$1/g;
      $text =~ s/\[-(.*?)\]/\[$1\]/g;
   }
# print $text; exit;
   $text   = $self->to_txt($kto0."--".$kto."\n".$text,$mode,1);

#  6. --- Change mode -----------------------------------------------

   if ($text0) {

      $diff    = $self->compute_diff($text,$file);

      if (!(ref($diff))) { #  merge conflict
         $file = $file . "_" . $diff;
      } else {
# print "FILE: $file " . Dumper($diff) . "\n"; 

         $buchh   = $diff->[0];
         $kto     = $diff->[1];
         $merged  = 0;
         $anzahl_zeilen = scalar ( split(/\n/,$text0) );
#$self->mm("ABC");
         foreach $zeile (split(/\n/,$diff->[2])) {  #  delete list
            $zeile1 = "";
            $zeile =~ s/\+/\./g;
            $zeile =~ s/([ ;])[^ ;]+?\:/$1/g;
            if ($zeile =~ /^(\d\d\d\d\d\d\d\d)[; ]+-?(\d+\.\d\d)[; ]+([^ :;]*?)\-?+[; ]+([^ :;]*?)\-?[; ]+-?\d+\.\d\d[ ;]+(.*?)[ ;]*$/) {
               $zeile1 = "($1\[ ;\]+?-?$2\[ ;\]+?\[^ ;\]*$3\[ ;\]+?\[^ ;\]*$4\[ ;\]+?\-?\\d+\\.\\d\\d\[ ;\]+?$5" .
                         "|$1\[ ;\]+?-?$2\[ ;\]+?\[^ ;\]*$4\[ ;\]+?\[^ ;\]*$3\[ ;\]+?\-?\\d+\\.\\d\\d\[ ;\]+?$5)";
            }
            elsif ($zeile =~ /^([^ ;]+)[ ;]+([^ ;]+)[ ;]+-?(\d+\.\d\d)/) {
               $zeile1 = "\[^ ;\]*?$1\[ ;\]+$2\[ ;\]+\-?$3";
            }
            if ($zeile1) {
               
               $merged = $merged + 1;
#            return("ERROR: Line not found: $zeile  $zeile1\n") if ($zeile1 and $text0 !~ s/\n$zeile1[ ;]*//gs);
               return("ERROR: Line not found: $zeile\n") if ($text0 !~ s/\n$zeile1[ ;]*//s);  #  falls
               return("ERROR: Double line: $zeile\n") if ($text0 =~ /\n$zeile1[ ;]*/s);  #  solche Fehler auftreten
            }
         }                           #  mit diesen beiden Zeilen genauere Angabe als mit der einen darueber
#$self->mm("ABC");
         return("ERROR: Double line") if ( $anzahl_zeilen - $merged != scalar ( split(/\n/,$text0) ) );

         foreach $zeile (split(/\n/,$diff->[3])) {  #  add list
            $merged = 1;
            if ($zeile =~ s/^(\d\d\d\d\d\d\d\d[; ]+)([^ ;]+)([; ]+)([^ ;]+)([; ]+)([^ ;]+)(.*?)[ ;]*$/$1---BETRAG---$3---KTO1---$5---KTO2---$7/) {
               $o     = [$4,$6];
               $o1    = sprintf("%3.2f",eval($2));
               $zeile =~ s/\{[a-zA-Z0-9\-\_\:]+\}/\{\[$1\]\}/;
               $zeile =~ s/---BETRAG---/ $o1 /;
               $zaehler = 1;
               while (0 == 0) {             #   Auswerten der Formeln
                  last if ($zeile !~ s/\{(.*?)(\([a-zA-Z0-9\-\_]+\:[a-zA-Z0-9\-\_]+\)|\[[a-zA-Z0-9\-\_\:]+\])(.*?)\}/\{$1---FORMEL---$3\}/);
                  if ($2 =~ /[\[\(](.*?)[\)\]]/) {
                     push(@$o,$1);
                  }
                  $zaehler = $zaehler + 1;
               }
               foreach $o1 (@$o) {
                  $o1 =~ s/^-/$kto-/;       #  auf absoluten Kontopfad bringen
                  if ($o1 !~ /\:/) { $o1 = $buchh . ":" . $o1; }
                  $o1 =~ s/-$//;
                  if ($o1 =~ s/^$buchh0[-\:]//) {  # wieder relativieren
                     $o1 =~ s/\:/\-/gs;
                     if ($o1 =~ s/$name//) {
                        $o1 = "-" if (!$o1);
                     }
                  }
               }
               $o1 = shift(@$o);
               $zeile =~ s/---KTO1---/$o1/;
               $o1 = shift(@$o);
               $zeile =~ s/---KTO2---/$o1/;
               while (0 == 0) {   #  korrigierte Formeln
                  $o1 = shift(@$o);
                  last if (!$o1);
                  $zeile =~s /---FORMEL---/\[$o1\]/;
               }
#print "WW: $zeile\n";
            }
            elsif ($zeile =~ /$buchh(.*?)$kto(.*?)([^ ;]+?)[ ;]*$/) {
               $zeile = $buchh . "-" . $kto . "  " . $3;
               $zeile =~ s/^$buchh0\-//;
            }
            elsif ($zeile =~ /^([^ ;]+)[ ;]+([^ ;]+)/) {
               $zeile = $buchh . "-" . $zeile;
               $zeile =~ s/^$buchh0\-//;
            }
            $text0 = $zeile . "\n" . $text0;
         }
#exit;
         if ($merged or $kto eq "xxx") {
            $text  = join("\n",sort { $self->sortbuchung($a) cmp $self->sortbuchung($b) }
                              split(/\n/,$text0) );
            $text = $self->to_txt($text,$mode,0);
         }
         unlink($file);
         $file  = $self->{'FILE'};
         return($file) if (!$merged);
         
      }
         
   }

# 7. Abspeichern der Ergebnisdatei  ----------------------------------------

   open(FFILE,">$file");
   print FFILE $text;
   close(FFILE);

   return($file);


}

#******************************************************************************

sub to_txt {

   my $self = shift;
   my $text = shift;
   my $mode = shift;
   my $format = shift;
   
#   my $reduce_ktolist = 0;
#   $reduce_ktolist    = 1 if ($format =~ s/1//);
   
   my $zeile; my $datum; my $betrag; my $kto1; my $kto2; my $remark;
   my $o; my $space; my $tab; my $sum; my $kto3; my $xtab; my $ytab;
   my $buchh; my $kto; my $md5; my $kto9;
   
   my $text1      = "";   
   my $bezeichner = {};

   my $gesamt = {};
   foreach $zeile (split(/\n/,$text)) {
      if ($zeile =~ /^(\d\d\d\d\d\d\d\d)[; ]+(-?\d+\.\d\d)[; ]+([^ ;]+?)[; ]+([^ ;]+?)([; ]+)(.*)$/) {
         $datum  =  $1;
         $betrag =  $2;
         $kto1   =  $3;
         $kto2   =  $4;
         $sum    =  "0.00";
         $remark =  $6;
         $remark =~ s/^\-?\d+\.\d\d[; ]+//;
         if ($kto1 !~ /^\-/ and $kto1 !~ /^\-/ and $betrag < 0) {
            $betrag = (-1) * $betrag;
            $kto3 = $kto1;
            $kto1 = $kto2;
            $kto2 = $kto3;
            if ($remark !~ s/\{\-\((.*?)\)\}/\{$1\}/) {
               $remark =~  s/\{(.*?)\}/\{\-\($1\)\}/;
            }
         }

#if (1 or $reduce_ktolist) {
         $kto3 = $kto1;
         $kto3 =~ s/^\-/$kto9/;
         $kto3 =~ s/\-+$//g;
         while (0 == 0) {
            last if ($kto3 !~ /^$kto/);
            $gesamt->{$kto3} = $gesamt->{$kto3} + $betrag;
            last if (!$kto3);
            $kto3 = "" if ($kto3 !~ s/^(.*)\-(.*)$/$1/);
         }
         $kto3 = $kto2;
         $kto3 =~ s/^\-/$kto9/;
         $kto3 =~ s/\-+$//g;
         while (0 == 0) {
            last if ($kto3 !~ /^$kto/);
            $gesamt->{$kto3} = $gesamt->{$kto3} - $betrag;
            last if (!$kto3);
            $kto3 = "" if ($kto3 !~ s/^(.*)\-(.*)$/$1/);
         }
         $sum = $gesamt->{$kto};
#}

         if ($mode eq "kto") {
            if (length($kto1) < 13) { $kto1 = substr($kto1." "x13,0,13); }
            if (length($kto2) < 13) { $kto2 = substr($kto2." "x13,0,13); }
            while ($remark =~ s/^\;/   /) { 1; }
            $zeile = $datum . " " . sprintf("%11.2f",$betrag) . "  " .
                     $kto1 . "___TAB1___" . (sprintf("%09b",1023-length($kto1))) . "___ " .
                     $kto2 . "___TAB2___" . (sprintf("%09b",1023-length($kto2))) . "___  " .
                     sprintf("%11.2f",$sum) . "  " . $remark;
         } else {
            $zeile = $datum . ";" . sprintf("%3.2f",$betrag) . ";" .
                     $kto1 . ";" .
                     $kto2 . ";" .
                     sprintf("%3.2f",$sum) . ";" . $remark;
         }
         $text1 = $text1 . $zeile . "\n";
      }
      elsif ($zeile =~ /^\s*(.*?)([ ;]+)([^ ;\-0123456789][^ ]*)/) {
         $bezeichner->{$1} = $3;
#         if (!$reduce_ktolist) {
            $gesamt->{$1}     = "___EMPTY___" if (!(exists ($gesamt->{$1})));
#         }
      }
      elsif (!$buchh and $zeile =~ /^(.*)--(.*)/) {
         $buchh = $1;
         $kto   = $2;
         $kto9  = $kto . "-";
         if (!$kto) { $kto9 = ""; }
      } 
   }
   $text1 = $text1 . "\n";
   $xtab  = substr($kto,1);

   foreach $kto1 (sort keys %$gesamt) {
      $betrag  = $gesamt->{$kto1};
      if ($betrag eq "___EMPTY___") {
         $betrag = "";
      } else {
         $betrag = sprintf("%13.2f",$betrag);
      }
      $betrag =~ s/^(.*?)( *)$/$2$1/;
      $betrag =~ s/ /\\/g;
      $ytab   =  $kto1;
      $ytab   =~ s/[^-]//g;
      $ytab   =~ s/^$xtab//;
      if ($mode eq "kto") {
         $o     = $bezeichner->{$kto1} || ""; # "___undefined___";   #  Kontobezeichner
         if (length($betrag) < 13) { $betrag = substr($betrag." "x13,0,13); }
         if (length($kto1)   < 13) { $kto1   = substr( $kto1." "x13,0,13); }
         if (length($o)      < 13) { $o      = substr(    $o." "x13,0,13); }
         $ytab   =~ s/\-/\\/g;
         $zeile  = $kto1 . "___TAB3___" . (sprintf("%09b",1023-length($kto1))) . "___ " . $o;
         $zeile  = $zeile . "___TAB4___" . (sprintf("%09b",1023-length($o)))
                    . "___ " . $ytab . $ytab . $ytab . $betrag;  #  if ($betrag);
      } else {
         $ytab   =~ s/\-/\;/g;
         $zeile  = $kto1 . ";" .
                   $bezeichner->{$kto1} . ";" .
                   $ytab . $zeile;
      }
      $text1  = $text1 . $zeile . "\n";
   }

# if ($kto ne "10-1202") {  print $text1; exit; }
# print $text1; exit;

   if ($mode eq "kto") {
      foreach $tab (1,2,3,4) {  #  minimale Einrueckung bestimmen
         my $space1 = "";
         while (0 == 0) {
            $space1 = $space1 . "0";
            next if ($text1 =~ /___TAB$tab\___$space1/);
            $space1 = substr($space1,0,length($space1)-1) . "1";
            last if ($text1 !~ /___TAB$tab\___$space1/);
         }
         $space1 = eval("0b".substr($space1,0,length($space1)-1));
         while (0 == 0) {  #  Spezielle Einrueckungen vornehmen
            last if ($text1 !~ /___TAB$tab\___([01]+)\___/);
            $o = $1;
            $space = " " x  (eval("0b".$o) - $space1);
            $text1 =~ s/___TAB$tab\___$o\___/$space/gs;
         }
      }
      $text1 =~ s/\\/ /g;  #  if ($kto eq "10-1202");
   }
#   $o     = $text1;
#   $o     =~ s/[ ;]+/ /g;

   $text1 =~ s/( *)\n/\n/gs;
   my $md5 = Digest::MD5::md5_base64($text1);
   $md5    =~  s/\+/\-/gs;
   $md5    =~  s/\//\_/gs;

   if ($mode eq "kto") {
      $text1 = $buchh . ", " . $kto . " (" . $md5 . ")   -- " . $bezeichner->{$kto} . "\n\n" . $text1;
   } else {
      $text1 = $buchh . ";" . $kto . ";;" . $md5 . ";;" . $bezeichner->{$kto} . "\n\n" . $text1;
   }

   return($text1);

}

#******************************************************************

sub compute_diff {   #  compute a diff for changing the Buchungs-Liste

   my $self   = shift;
   my $list0  = shift;
   my $list   = shift;

   if (-f $list0) {
      open(FFILE,"<".$list0);
      $list0 = join("",<FFILE>);
      close(FFILE);
   }
   
   if(!$list) {
      $list  = $self->change_kto($list0);
   }
   elsif (-f $list) {
      open(FFILE,"<".$list);
      $list = join("",<FFILE>);
      close(FFILE);
   }
   

   return([]) if ($list0 !~ /^(.*?)[ ,;\(\)]+(.*?)[ ,;\(\)]+?([^ ,;\(\)]+)(.*?)\n/);
   my $buchh = $1;
   my $kto   = $2;
   my $md5   = $3;
   return($md5) if ($list  !~ /^$buchh[ ,;\(\)]+$kto[ ,;\(\)]+$md5(.*?)\n/);
      
   $list0 = [ sort { $self->sortbuchung($a) cmp $self->sortbuchung($b) }
                split(/\n/,$list0) ];
   $list  = [ sort { $self->sortbuchung($a) cmp $self->sortbuchung($b) }
                split(/\n/,$list) ];
   
   my $addlist = "";
   my $dellist = "";
   my $o; my $o1;
   
#   print Dumper ( Algorithm::Diff::diff( $list0,$list ) );  exit;
   
   foreach $o ( Algorithm::Diff::diff( $list0,$list ) ) {
      foreach $o1 (@$o) {
         if ($o1->[0] eq "+") {
            $addlist = $addlist . $o1->[2] . "\n";
         } else {
            $dellist = $dellist . $o1->[2] . "\n";
         }
      }
   }

   return([$buchh,$kto,$dellist,$addlist]);

}

#*****************************************************************
#*****************************************************************

sub sortbuchung {

   my $self = shift;
   my $text = shift;

   if ($text !~ /^(\d\d\d\d\d\d\d\d)[; ]+-?(\d+\.\d\d)[; ]+([^ ;]*?)[; ]+([^ ;]*?)+[; ]+-?\d+\.\d\d[ ;]+(.*)$/) {
      return("9999 " . $text);
   }
 
   my $erg   = $5;
   my $kto1  = $3;
   my $kto2  = $4;
   my $datum = $1;
   
   $erg    =~ s/[äöüÄÖÜß]/X/g;
   if ($erg =~ s/^\d(.*?)\((.*)\)$/$2/s) {  #  Umsatzsteuerbehandlung
      $erg = substr($erg,0,22) . "ZZZZZZZZZZZZZZZZZZZZZZZZZ";
   } else {
      $erg = substr($erg,0,22) . "AAAAAAAAAAAAAAAAAAAAAAAAA";
   }
   $erg = substr($erg,0,23);

   if    ($erg =~ /^Brutto-Lohn/)                  { $erg = "01" . $erg; }
   elsif ($erg =~ /^(LST|Lohnsteuer)/)             { $erg = "02" . $erg; }
   elsif ($erg =~ /^(KST|Kirchensteuer)/)          { $erg = "03" . $erg; }
   elsif ($erg =~ /^Soli/)                         { $erg = "04" . $erg; }
   elsif ($erg =~ /^KV-Beitrag/)                   { $erg = "05" . $erg; }
   elsif ($erg =~ /^PV-Beitrag/)                   { $erg = "06" . $erg; }
   elsif ($erg =~ /^RV-Beitrag/)                   { $erg = "07" . $erg; }
   elsif ($erg =~ /^AV-Beitrag/)                   { $erg = "08" . $erg; }
   elsif ($erg =~ /^A.-Anteil KV/)                 { $erg = "10" . $erg; }
   elsif ($erg =~ /^A.-Anteil ZU/)                 { $erg = "11" . $erg; }
   elsif ($erg =~ /^A.-Anteil RV/)                 { $erg = "12" . $erg; }
   elsif ($erg =~ /^A.-Anteil PV/)                 { $erg = "13" . $erg; }
   elsif ($erg =~ /^A.-Anteil KI/)                 { $erg = "14" . $erg; }
   elsif ($erg =~ /^A.-Anteil AV/)                 { $erg = "15" . $erg; }
   elsif ($erg =~ /^A.-Anteil ST/)                 { $erg = "16" . $erg; }
   elsif ($erg =~ /^A.-Anteil Umlage 1/)           { $erg = "17" . $erg; }
   elsif ($erg =~ /^A.-Anteil Umlage 2/)           { $erg = "18" . $erg; }
   elsif ($erg =~ /^A.-Anteil Inso/)               { $erg = "19" . $erg; }
   else { $erg = "00" . $erg; }
  
   my $o1 = $kto1;
   my $o2 = $kto2;
   if (($o1 cmp $o2) > 0) {
      $o1 = $kto2;
      $o2 = $kto1;
   }

   $erg = $datum . $erg . substr($o1."                                      ",0,20) .
                             substr($o2."                                      ",0,20);
   return($erg);
   
}

#**************************************************************************

sub mm {

   my $self    = shift;
   my $mark    = shift;
# $main::XCONSOLE = 1;
   if (!$main::XCONSOLE) {
       return(1);
   }
   eval("use Time::HiRes");
   my $newdate = sprintf("%16.5f",Time::HiRes::time());
   my $diff    = sprintf("%9.5f",$newdate - $main::lasttime);
   $main::lasttime = $newdate;
   my $erg = $newdate . "," . $diff . "," . $mark . "\n";

   if ($main::XCONSOLE > 1) {
      if (!($main::cgp_opened)) {
         open(GFILE,">".$mark);
         $main::cgp_opened = 1;
         $mark = $mark . " opened";
      }
      print GFILE $erg;
   }
   if ($main::XCONSOLE != 2) {
      print $erg;
   }

}

#***********************************************************************



1;

bypass 1.0, Devloped By El Moujahidin (the source has been moved and devloped)
Email: contact@elmoujehidin.net bypass 1.0, Devloped By El Moujahidin (the source has been moved and devloped) Email: contact@elmoujehidin.net