DataMuseum.dk

Presents historical artifacts from the history of:

Q1 computer

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about Q1 computer

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - metrics - download

⟦e3ac284a9⟧ Q1_Text, reclen=79

    Length: 7505 (0x1d51)
    Types: Q1_Text, reclen=79
    Notes: q1file
    Names: »VERIFIN1«

Derivation

└─⟦1f3202981⟧ Bits:30008731 DDMQ1-0173_MSAB_Bokföring_Alla_Program_i_PL1_ref_ex_780428
    └─⟦this⟧ »VERIFIN1« 

Text

/*FÖRSTA RADEN*/                                                               
/*VERIFIN1 MANUELL INMATNING AV VERIFIKATIONER                                 
KLART: 780602 FÖR MSAB   PROGR:TD */                                           
                                                                               
DCL VERFIL FILE;CALL KFILE(VERFIL);                                            
                                                                               
DCL 1 VER,2 KO CHAR(4),2 AVD CHAR(2),2 DAT CHAR(4),                            
2 VERNR FIXED(5),2 VTX CHAR(20),2 BEL FIXED(11,2),2 KOD CHAR(1);               
                                                                               
DCL 1 KTO,2 KONTO FIXED(4),2 TEXT CHAR(34);                                    
                                                                               
DCL 1 DATREC,2 DAG CHAR(6),2 MON CHAR(3),2 MNR FIXED(2),2 SK(14) CHAR(1),      
2 CO FIXED(1);                                                                 
DCL 1 XDATREC,2 XDAG CHAR(9),2 XMNR FIXED(2),2 XSK(14) CHAR(1),2 XCO FIXED(1); 
XDAG='XXXXXX   ';XMNR=0;                                                       
                                                                               
DCL DATFIL FILE,KTOTX FILE,S CHAR(1),RAD FIXED(2),SIDA FIXED(4),IND FIXED(1),  
SVAR CHAR(6),AD FIXED(13,2),AK FIXED(13,2),TD FIXED(13,2),TK FIXED(13,2),      
KOSVAR CHAR(7),KOSVAR2 CHAR(13),POS FIXED(1);                                  
                                                                               
OPEN KTOTX;OPEN DATFIL;OPEN VERFIL;CALL SEOF(VERFIL);                          
READ FILE(DATFIL)INTO(DATREC);IF DAG='XXXXXX' THEN GO TO SLUT;                 
IF MNR¬=SUBSTR(DAG,3,2) THEN GO TO SLUT;                                       
DO I=1 TO 14;XSK(I)=SK(I);END;XSK(MNR)=' ';XCO=CO;                             
REWRITE FILE(DATFIL)FROM(XDATREC);                                             
PUT FILE(D) SKIP EDIT(' ')(A(37))('** REGISTRERING AV VERIFIKATIONER  **')     
(A(74))('STÄLL IN PERFORERINGEN')(A(37))('TRYCK SEDAN RETURN.')(A(37));        
GET SKIP LIST(S);PUT FILE(D) SKIP;                                             
POS=0;RAD=5;SIDA=0;IND=1;AD=0;AK=0;TD=0;TK=0;DAT=SUBSTR(DAG,3,4);TYP='M';      
RUB:SIDA=SIDA+1;PUT SKIP(RAD)EDIT('MANUELL REGISTRERING AV VERIFIKATIONER.')(A)
('AVSEENDE MÅNAD ')(A)(MON)(A(9))                                              
('DATUM:')(A)(DAG)(A(10))('SIDA:')(A)(SIDA)(A)SKIP(2)EDIT                      
('VER.NR')(A(8))('KONTO')(A(9))('TEXT')(A(29))('DEBET')(A(15))                 
('KREDIT')(A)SKIP;RAD=45;                                                      
IF POS=1 THEN GO TO MER;                                                       
ST:POS=0;IF RAD<12 THEN GO TO RUB;TD=TD+AD;AD=0;TK=TK+AK;AK=0;                 
IF IND THEN DO;PUT FILE(D)SKIP EDIT('FÖRSTA VER.NR:')(A(31));                  
GET SKIP LIST(VERNR);END;                                                      
ELSE DO;PUT FILE(D)SKIP EDIT('VER.NR:')(A(37))('(OM LÖPANDE,TRYCK RETURN)')    
(A(31));GET SKIP LIST(SVAR);IF SVAR='SLUT  ' THEN GO TO UT;                    
IF VERIFY(SVAR,' 0123456789')=0 THEN GO TO ST;                                 
IF SVAR='      ' THEN VERNR=VERNR+1;ELSE VERNR=SVAR;END;                       
IF VERNR<1 THEN GO TO ST;IND=0;                                                
PUT SKIP EDIT(VERNR)(P'ZZZZZ9',X(3));RAD=RAD-1;                                
MER:POS=1;IF RAD<12 THEN GO TO RUB;                                            
PUT FILE(D)SKIP EDIT('VERNR:')(A(7))(VERNR)(P'ZZZZZ9',X(24));                  
IF AD-AK=0 THEN DO;PUT FILE(D)EDIT('TEXT:')(A(17));GET SKIP LIST(VTX);         
PUT FILE(D)EDIT(VTX)(A(20));END;PUT FILE(D)EDIT('KONTO.AVD:')(A(25));          
GET SKIP LIST(KOSVAR);                                                         
KOIN:PUT FILE(D) EDIT(KOSVAR)(A(12));                                          
J=INDEX(KOSVAR,'.');KO=SUBSTR(KOSVAR,1,J-1);                                   
IF SUBSTR(KOSVAR,4,1)=' ' THEN GO TO FELKOD;                                   
IF J=0&SUBSTR(KOSVAR,5,3)¬='   ' THEN GO TO FELKOD;                            
IF J=0 THEN GO TO X1;IF J¬=5 THEN GO TO FELKOD;                                
AVD=SUBSTR(KOSVAR,6,2);                                                        
GO TO NY;                                                                      
X1:AVD='  ';KO=SUBSTR(KOSVAR,1,4);                                             
NY:                                                                            
KTOIN:IF VERIFY(SUBSTR(KOSVAR,1,4),'0123456789')=0 THEN GO TO FELKO;           
KONTO=KO;                                                                      
ON ERROR GO TO FELKO;READ KEY(KONTO)FILE(KTOTX)INTO(KTO);                      
KTOOK:PUT FILE(D)SKIP EDIT('VER.NR:')(A(31))(VERNR)(P'ZZZZZ9')('TEXT:')(A(17)) 
(VTX)(A(20))('DIFF')                                                           
(A(24))(AD-AK)(P'---------9V.99')('KONTO')(A(25))(KOSVAR)(A(12))               
('BELOPP (K7 FÖR DEB, K6 FÖR KRE) :')(A(61));                                  
BELIN:GET SKIP LIST(BEL);CALL KEYFUN(I);                                       
IF I=139 THEN DO;AD=AD+BEL;KOD='D';END;IF I=138 THEN DO;AK=AK+BEL;KOD='K';END; 
IF(I¬=138)&(I¬=139) THEN GO TO BELIN;                                          
PUT FILE(D)SKIP;                                                               
PUT EDIT(KO)(A(4))(AVD)(A(4))(VTX)(A(21));                                     
IF I=138 THEN PUT EDIT(' ')(A(16));                                            
PUT EDIT(BEL)(P'---------9V.99')SKIP EDIT(' ')(A(9));RAD=RAD-1;                
WRITE FILE(VERFIL)FROM(VER);                                                   
IF AD-AK¬=0 THEN GO TO MER;                                                    
CLOSE VERFIL;OPEN VERFIL;CALL SEOF(VERFIL);GO TO ST;                           
FELKO:CALL OUTPUT(1,6);                                                        
PUT FILE(D) SKIP EDIT('KONTO ')(A)(KO)(A(5))('FINNS EJ.')(A(26))               
('ANGE RÄTT KONTO.AVD')(A(37))('ELLER SVARA "NYTT":')(A(25));                  
GET SKIP LIST(KOSVAR2);                                                        
IF SUBSTR(KOSVAR2,1,2)='NY' THEN GO TO NYKO;                                   
KOSVAR=KOSVAR2;GO TO KOIN;                                                     
FELKOD:CALL OUTPUT(1,6);                                                       
PUT FILE(D) SKIP EDIT(KOSVAR)(A(8))('ÄR EN FELAKTIG KOD!')(A(29))              
('FÖRSÖK IGEN:')(A(25));                                                       
GET SKIP LIST(KOSVAR);GO TO KOIN;                                              
NYKO:PUT FILE(D)SKIP EDIT('KONTO:')(A(33))(KO)(A(4))('TEXT:')(A(40));          
GET SKIP LIST(TEXT);                                                           
PUT FILE(D)SKIP;                                                               
KONTO=KO;                                                                      
CALL SEOF(KTOTX);WRITE FILE(KTOTX)FROM(KTO);CLOSE KTOTX;OPEN KTOTX;            
XSK(14)=' ';REWRITE FILE(DATFIL) FROM(XDATREC);GO TO KTOOK;                    
UT:PUT SKIP(2)EDIT('TOTALT ALLA TRANSAKTIONER:')(A(36))(TD)                    
(P'-----------9V.99')(TK)(P'------------9V.99',X(6))('DIFF:')(A)               
(TD-TK)(P'---------9V.99')SKIP(RAD-7);                                         
SLUT:CALL LOAD('BOKRUT',6);END;