|
FATS ist aufrufkompatibel zu der Dateiverwaltung FABS PLUS, dadurch ist die Einbindung des Programmes in bestehende, auf FABS basierende Anwendungsprogramme ohne Quelltextänderungen durch Austausch der OBJ-Module erledigt. Sämtliche Programmierschnittstellen dieser Software wurden nachgebildet. Sie können auch in Kombination mit den neuen verbesserten Schnittstellen von FATS verwendet werden, um so einen schrittweisen Umstieg zu ermöglichen. Das nachfolgende Microsoft Basic Beispiel demonstriert die Verwendung der von FATS bereitgestellten  FABS PLUS kompatiblen Befehle:
PRINT "KOMPATIBLE FABS-PLUS SCHNITTSTELLE" PRINT PRINT "Dieses Programm muß mit Microsoft Basic Version 7- (Schalter /Fs) oder" PRINT "Microsoft Visual Basic für DOS übersetzt werden." PRINT PRINT "Es arbeitet mit FAR-Strings" PRINT PRINT "Folgende Objektmodule benötigen Sie: FATS.OBJ & FATS_MB7.OBJ" PRINT INPUT "Bitte [ENTER] drücken...", X$ REM -------> ASCII-Datei mit Demodaten öffnen OPEN "R", #1, "..\..\..\DEMODATA\KUNDEN.ASC", 105 FIELD #1, 5 AS F1$, 25 AS F2$, 25 AS F3$, 25 AS F4$, 5 AS F5$, 20 AS F6$ REM -------> Datendatei erstellen PRINT "Datendatei wird erstellt ..." OPEN "R", #2, "KUNDEN.DAT", 128 FIELD #2, 1 AS LOESCHKENNZ$,_ 5 AS ANREDE$,_ 25 AS NAME$,_ 25 AS BRANCHE$,_ 25 AS STRASSE$,_ 5 AS PLZ$,_ 20 AS ORT$ REM -------> Indexdatei erstellen PRINT "Indexdatei wird erstellt ..." CALL FABSMB3(seg "C\KUNDEN.KEY\25\3\A\1", ERRORCODE%, RECNO%, ADRKEY%) REM -------> Datensätze einfügen PRINT PRINT "Es werden jetzt 222 Datensätze in die Datei eingefügt. Für jeden" PRINT "Datensatz werden 3 Schlüssel in die Indexdatei eingefügt." INPUT "Bitte [ENTER] drücken...", X$ FOR X=1 TO 222 GET #1,X LSET LOESCHKENNZ$=" " LSET ANREDE$=F1$ LSET NAME$=F2$ LSET BRANCHE$=F3$ LSET STRASSE$=F4$ LSET PLZ$=F5$ LSET ORT$=F6$ CMND$="I\1\"+RTRIM$(NAME$)+"\"+RTRIM$(BRANCHE$)+"\"+RTRIM$(PLZ$+ORT$) CALL FABSMB3(seg CMND$, ERRORCODE%, RECNO%, ADRKEY%) IF ERRORCODE% <> 0 GOTO ENDE PRINT NAME$;" --> Satznummer ";RECNO% PUT #2,RECNO% NEXT X CLOSE #1 REM -------> Datensätze nach Name sortiert ausgeben PRINT PRINT "Die Datensätze werden jetzt anhand des ersten Schlüssels (NAME)" PRINT "aufsteigend sortiert ausgegeben. Der dabei verwendete FATS-Befehl" PRINT "SEARCH NEXT AFTER kann im Einzelplatz und im Netzwerk verwendet" INPUT "werden. Bitte [ENTER] drücken...", X$ CMND$="F\1\1" SCHLEIFE1: CALL FABSMB3(seg CMND$, ERRORCODE%, RECNO%, ADRKEY%) IF ERRORCODE% <> 0 GOTO WEITER1 CALL FABSGETKEY(FABSKEY$, ADRKEY%, 25) GET #2,RECNO% PRINT NAME$;" --> Satznummer ";RECNO% CMND$="A\1\"+STR$(RECNO%)+"\1\"+FABSKEY$ GOTO SCHLEIFE1 WEITER1: REM -------> Datensätze nach Branche sortiert ausgeben PRINT PRINT "Die Datensätze werden jetzt anhand des zweiten Schlüssels (BRANCHE)" PRINT "aufsteigend sortiert ausgegeben." INPUT "Bitte [ENTER] drücken...", X$ CMND$="F\2\1" SCHLEIFE2: CALL FABSMB3(seg CMND$, ERRORCODE%, RECNO%, ADRKEY%) IF ERRORCODE% <> 0 GOTO WEITER2 GET #2,RECNO% PRINT BRANCHE$;" ";NAME$;" --> Satznummer ";RECNO% REM **** Nur für Einzelplatzsysteme geeignet: SEARCH NEXT **** CMND$="N\1" GOTO SCHLEIFE2 WEITER2: REM -------> Datensätze nach PLZ & Ort sortiert ausgeben PRINT PRINT "Die Datensätze werden jetzt anhand des dritten Schlüssels (PLZ/ORT)" PRINT "absteigend sortiert ausgegeben." INPUT "Bitte [ENTER] drücken...", X$ CMND$="L\3\1" SCHLEIFE3: CALL FABSMB3(seg CMND$, ERRORCODE%, RECNO%, ADRKEY%) IF ERRORCODE% <> 0 GOTO WEITER3 CALL FABSGETKEY(FABSKEY$, ADRKEY%, 25) GET #2,RECNO% PRINT PLZ$;" ";ORT$;" ";NAME$;" --> Satznummer ";RECNO% CMND$="E\3\"+STR$(RECNO%)+"\1\"+FABSKEY$ GOTO SCHLEIFE3 WEITER3: ENDE: REM -------> Indexdatei schließen CALL FABSMB3(seg "K\1", ERRORCODE%, RECNO%, ADRKEY%) CLOSE #2 END REM -------> SUB: Schlüssel ermitteln SUB FABSGETKEY (FABSKEY$, ADRKEY%, KEYLEN%) FABSKEY$="" CALL GFSEG(FSEG%) ADRKEY=ADRKEY% IF ADRKEY < 0 THEN ADRKEY=ADRKEY+65536! FOR X=ADRKEY TO ADRKEY+KEYLEN% - 1 DEF SEG=FSEG% KCHAR=PEEK(ADRKEY) DEF SEG FABSKEY$=FABSKEY$+CHR$(KCHAR) ADRKEY=ADRKEY+1 NEXT X END SUB
© 2008 GCS Software, Udo Gertz