home *** CD-ROM | disk | FTP | other *** search
/ Chip 2002 December / Chip_2002-12_cd1.bin / tema / clin / CLIN.EXE / SRC / SRC.RAR / KOD5.PAS < prev    next >
Encoding:
Pascal/Delphi Source File  |  2002-09-20  |  3.1 KB  |  118 lines

  1. // Code 2/5 Invert
  2. Unit Kod5;
  3.  
  4. interface
  5.  
  6. uses
  7.   Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  8.   Dialogs, StdCtrls, ExtCtrls,
  9.   U;
  10.  
  11.  procedure HC5(var Co:TMemo);
  12.  procedure S2L5(Co:String; StartStop:Boolean; Crc:Boolean    ; var Raw:String; var RawS:String; var Bits:String);
  13.  
  14.  
  15. implementation
  16.  
  17.  const MaxKod=11;
  18.  var Kody:Array[0..11]of record
  19.        Asc:String;
  20.        Kod:Byte;
  21.        Line:String;
  22.      end;
  23.  
  24.  procedure HC5(var Co:TMemo);
  25.  var I:Word;
  26.  begin
  27.   Co.Clear;
  28.   for I:=0 to MaxKod do
  29.    with Kody[I] do
  30.      begin
  31.        Co.Lines.Add(Hex(Kod)+' '+Asc+' ('+Line+')');
  32.      end;
  33.  end;
  34.  
  35.  procedure S2L5(Co:String; StartStop:Boolean; Crc:Boolean    ; var Raw:String; var RawS:String; var Bits:String);
  36.  var I,J,K:Integer;
  37.      Pom,Pom2:String;
  38.      PomC:Byte;
  39.      E:Integer;
  40.      Ch:Byte;
  41.  begin
  42.    Raw:='';
  43.    RawS:='';
  44.    Bits:='';
  45.    if Length(Co)=0 then Exit;
  46.  //// Vy°a∩ neplatnΘ a zkonvertuj HEX verze
  47.    I:=1;
  48.    while I<=Length(Co) do
  49.    begin
  50.      //// Je to $ ?
  51.      if Co[I]='$' then // Je to HEX
  52.         begin
  53.           Pom:='';
  54.           repeat
  55.             Pom:=Pom+Co[I];
  56.             I:=I+1; // Posu≥ o dalÜφ znak
  57.           until (length(Pom)=3) or (I>Length(Co));
  58.           if I<=Length(Co) then I:=I-1;
  59.           Val(Pom,PomC,E);
  60.           if (E=0)and(PomC<=MaxKod) then
  61.           begin
  62.             Raw:=Raw+Chr(PomC);
  63.           end;
  64.         end else
  65.         begin   // Nenφ to HEX
  66.           for J:=0 to MaxKod do
  67.             if Co[I]=Kody[J].Asc then Raw:=Raw+Chr(Kody[J].Kod);
  68.         end;
  69.      I:=I+1;
  70.    end;
  71.  //// Crc a Start/Stop
  72.    if Crc then
  73.    begin
  74.      J:=0;
  75.      for I:=1 to Length(Raw) do
  76.      begin
  77.        J:=J+Ord(Raw[I]);
  78.      end;
  79.      Raw:=Raw+Chr(J mod 10);
  80.    end;
  81.  
  82.    if StartStop then Raw:=#10+Raw+#11;
  83.  //// Na zobrazitelne
  84.       //// +Na bity
  85.  for I:=1 to Length(Raw) do
  86.   begin
  87.     RawS:=RawS+Kody[Ord(Raw[I])].Asc;
  88.     Pom2:=Kody[Ord(Raw[I])].Line;
  89.       Pom:='';
  90.       Ch:=$30; // ZaΦφnßme jedniΦkou
  91.       for J:=1 to Length(Pom2) do
  92.       begin
  93.         for K:=1 to (Ord(Pom2[J])-$30+1) do // Pozor na 0-x a 1-x v tabulce bit∙ !!!
  94.           begin
  95.             Pom:=Pom+Chr(Ch);
  96.           end;
  97.         Ch:=Ch xor 1;
  98.       end;
  99.      Bits:=Bits+Pom;
  100.   end;
  101.   Bits:='11111111'+Bits+'11111111';
  102.  end;
  103.  
  104. begin
  105.  with Kody[00]do begin Asc:='0';Kod:=0;Line:='0000101000';end;
  106.  with Kody[01]do begin Asc:='1';Kod:=1;Line:='1000000010';end;
  107.  with Kody[02]do begin Asc:='2';Kod:=2;Line:='0010000010';end;
  108.  with Kody[03]do begin Asc:='3';Kod:=3;Line:='1010000000';end;
  109.  with Kody[04]do begin Asc:='4';Kod:=4;Line:='0000100010';end;
  110.  with Kody[05]do begin Asc:='5';Kod:=5;Line:='1000100000';end;
  111.  with Kody[06]do begin Asc:='6';Kod:=6;Line:='0010100000';end;
  112.  with Kody[07]do begin Asc:='7';Kod:=7;Line:='0000001010';end;
  113.  with Kody[08]do begin Asc:='8';Kod:=8;Line:='1000001000';end;
  114.  with Kody[09]do begin Asc:='9';Kod:=9;Line:='0010001000';end;
  115.  with Kody[10]do begin Asc:='{Start}';Kod:=10;Line:='101000';end;
  116.  with Kody[11]do begin Asc:='{Stop}';Kod:=11;Line:='100010';end;
  117. end.
  118.