home *** CD-ROM | disk | FTP | other *** search
/ CP/M / CPM_CDROM.iso / enterprs / c128 / util / xlink.sda / XLINK.DOC < prev    next >
Text File  |  1992-09-30  |  11KB  |  191 lines

  1. ╨ART ╔╔ - ┴ ╨RACTICAL ┼XAMPLE OF ─ATA ╨ORTABILITY
  2.  
  3. ├╥╧╙╙ ╠╔╬╦ IS A SHORT ┬┴╙╔├ 7 PROGRAM FOR USE ON THE ├-128 WITH A SINGLE
  4. 1571 DRIVE.  ╔T ALLOWS YOU TO READ A FILE INTO A 45 K ╥┴═ BUFFER FROM ANY ONE
  5. OF THE FOLLOWING SEVEN DISK FORMATS:
  6.   
  7.     ╙┼╤ - ┴╙├╔╔
  8.     ╙┼╤ - WITH ╨┼╘╙├╔╔ <> ┴╙├╔╔ CONVERSION
  9.     ╨╥╟ - ┴╙├╔╔
  10.     ╨╥╟ - WITH SCREEN CODE <> ┴╙├╔╔ CONVERSION
  11.     ├-128 ├╨/═ SINGLE SIDED
  12.     ├-128 ├╨/═ DOUBLE SIDED
  13.     ╔┬═ ╨├-─╧╙ DOUBLE SIDED, 9 SECTORS/TRACK
  14.  
  15. ╘HE BUFFER CAN THEN BE WRITTEN TO ANOTHER DISK IN ANY OF THE SAME LIST OF
  16. FORMATS OR TO A PRINTER.  (╔T SHOULD BE NOTED THAT THE ╔┬═ ╨├-─╧╙ DOUBLE
  17. SIDED FORMAT IS ╬╧╘ THE SAME AS THE "╔┬═-─╙" WHICH IS SUPPORTED BY ├-128 ├╨/═
  18. MODE.  ╘HE LATTER FORMAT IS USED BY ├╨/═-86 WHICH IS THE 16 BIT VERSION OF
  19. ├╨/═ DESIGNED TO RUN ON THE ╔┬═-╨├ INSTEAD OF ╨├-─╧╙.  ╨├-─╧╙ AND ├╨/═-86
  20. ARE NOT COMPATIBLE.)  ├╥╧╙╙ ╠╔╬╦ IS SIMPLE TO USE, JUST FOLLOW THE PROMPTS ON
  21. THE SCREEN.  ╧NE WORD OF CAUTION, HOWEVER.  ┬ECAUSE THE 1571 IS NOT A TRUE
  22. ╨├-─╧╙ DISK DRIVE, NEVER WRITE ╨├-─╧╙ FILES TO AN ORIGINAL, IRREPLACEABLE
  23. DISK.  ╨LAY IT SAFE, ALWAYS USE SCRATCH DISKS FOR WRITING FILES.  (┴LTHOUGH
  24. ╔ HAVE HAD NO PROBLEMS WITH DISKS FROM THREE DIFFERENT ╔┬═-╨├S AND TWO ╨├
  25. COMPATIBLES, THE POSSIBILITY DOES EXIST FOR MIS-MATCHED SECTOR TIMING, ETC.
  26. ╘HIS COULD HOPELESSLY CORRUPT THE DISK BEING WRITTEN TO.)
  27.  
  28. ├╥╧╙╙ ╠╔╬╦ USES BURST MODE ON THE 1571 TO READ AND WRITE ╨├-─╧╙ AND ├╨/═
  29. FILES, CONSEQUENTLY IT IS QUITE FAST.  (┴ DETAILED DESCRIPTION OF 1571
  30. BURST MODE AND HOW TO USE IT IS PRESENTED IN A SERIES OF ARTICLES BY
  31. THIS AUTHOR IN ╘╨╒╟ MAGAZINE, STARTING IN ═AY 1986.)  ┴ TYPICAL CONVERSION
  32. OF A 16K (65 ╙┼╤ BLOCK) TEXT FILE FROM ╙┼╤ ╨┼╘╙├╔╔ TO ╨├-─╧╙ TAKES ABOUT
  33. 65 SECONDS, INCLUDING ABOUT 25 SECONDS OF "OVERHEAD" REQUIRED TO
  34. DECODE AND RECODE THE ╨├-─╧╙ DIRECTORY AND FILE ALLOCATION TABLE (╞┴╘).
  35. ╬OTICE THAT ╔ SPECIFY THE CONVERSION OF A TEXT FILE.  ╘HIS BRINGS UP A
  36. GENERAL CAVEAT: PROGRAM FILES WRITTEN TO RUN UNDER ╨├-─╧╙ (I.E. WITH A FILE
  37. TYPE OF .┼╪┼ OR .├╧═) WILL NOT WORK IN ├-128 MODE OR ├╨/═ MODE (THE ├╨/═
  38. EXECUTABLE FILE ALSO HAS A FILE TYPE OF .├╧═, BUT THE TWO ARE NOT
  39. INTERCHANGEABLE) OR VICE VERSA.  ╚OWEVER, IF YOU DOWNLOAD A ├╨/═ PROGRAM TO
  40. A ╨├-─╧╙ DISK AND THEN CONVERT THE FILE TO ├╨/═ FORMAT, THE PROGRAM WILL
  41. WORK IN ├╨/═ MODE ON THE ├-128.  ╘HIS IS USEFUL, FOR EXAMPLE, IF YOU DO NOT
  42. HAVE A MODEM ON YOUR ├-128 BUT HAVE ACCESS TO ONE ON AN ╔┬═-╨├ WHERE YOU
  43. WORK.  ╘HE SAME GOES FOR DOWNLOADING TO A ├-128 PROGRAM TO ╨├-─╧╙ THEN
  44. CONVERTING TO A ╨╥╟ ┴╙├╔╔ FILE OR DOWNLOADING TO ╙┼╤ FORMAT IN ├-128
  45. MODE AND THEN CONVERTING TO ├╨/═ FORMAT.  (╘HE ORIGINAL ├╨/═ SYSTEM FILES
  46. FOR THE ├-128 DID NOT SUPPORT A MODEM.  ╘HE UPGRADED VERSION NOW DOES.)
  47. ╘EXT AND DATA FILES, ON THE OTHER HAND, FROM ONE MACHINE CAN USUALLY BE
  48. USED WITHOUT TROUBLE ON THE OTHER.  ╘EXT FILES TRANSFERRED USING SCREEN
  49. CODE ╨╥╟ FILES MAY REQUIRE REFORMATTING ON THE TARGET WORD PROCESSOR.
  50. ╙CREEN CODE FILES WRITTEN BY ├╥╧╙╙ ╠╔╬╦ MAY NOT WORK WITH ALL ├-128
  51. WORD PROCESSORS.  ╙OME WP'S, SUCH AS ╨APERBACK ╫RITER 128, INCLUDE A
  52. HEADER BLOCK AT THE BEGINNING OF THE FILE.  ╘HE HEADER CONTAINS INFO
  53. ON THE FILE CHARACTERISTICS SUCH AS MARGINS ETC.  ╔F IT IS NOT PRESENT,
  54. THE WP MAY NOT BE ABLE TO READ THE FILE CORRECTLY.  ╘HESE WP'S CAN
  55. USUALLY READ ╙┼╤ FILES AS WELL, HOWEVER, SO IT IS BETTER TO WRITE
  56. A ╙┼╤ FILE WITH ├╥╧╙╙ ╠╔╬╦ FOR USE ON MOST WP'S.  ├╥╧╙╙ ╠╔╬╦ CAN
  57. READ ╨╥╟ TEXT FILES WITH HEADERS, BUT YOU MUST DELETE THE HEADER BLOCK
  58. WITH THE TARGET WP.
  59.  
  60. ╠╔╙╘╔╬╟ 1 IS A ┬┴╙╔├ LOADER FOR THE MACHINE LANGUAGE PORTION OF THE
  61. PROGRAM.  ╔T WILL CREATE A PROGRAM FILE NAMED "╪╠.═╠3" WHICH IS
  62. AUTOMATICALLY LOADED BY THE MAIN PROGRAM.  ╘HE ═╠ ROUTINE, WHICH IS LOCATED
  63. IN THE CASSETTE AND ╥╙ 232 BUFFERS, CONTAINS SEVERAL ENTRY POINTS.  ╘HESE
  64. ARE:
  65.  
  66.     HEX     DEC               FUNCTION
  67.  
  68.    0B69    2921              BURST SECTOR READ (FOR ├╨/═ AND ╨├-─╧╙)
  69.    0B9C    2972              READ ╙┼╤ OR ╨╥╟ FILE, NO CONVERT
  70.    0BD0    3024              WRITE ╙┼╤, ╨╥╟ FILE OR PRINTER, NO CONVERT
  71.    0C02    3074              BURST SECTOR WRITE (FOR ├╨/═ AND ╨├-─╧╙)
  72.    0C45    3141              WRITE ╙┼╤ OR PRINTER , CONVERT ┴╙├╔╔ TO ╨┼╘╙├╔╔
  73.    0CE0    3296              READ ╙┼╤ FILE, CONVERT ╨┼╘╙├╔╔ TO ┴╙├╔╔
  74.    0D7D    3453              READ ╨╥╟ FILE, CONVERT SCREEN CODE TO ┴╙├╔╔
  75.    0DDF    3551              WRITE ╨╥╟ FILE, CONVERT ┴╙├╔╔ TO SCREEN
  76.  
  77. ╔F YOU ARE INTERESTED, YOU CAN DISASSEMBLE THE MACHINE LANGUAGE WITH
  78. THE ├-128'S BUILT IN MONITOR.  ╘HE BURST MODE READ AND WRITE ROUTINES
  79. ARE SIMILAR TO THOSE DESCRIBED IN PARTS 2 AND 3 OF THE ╘╨╒╟ SERIES.
  80.  
  81. ╠╔╙╘╔╬╟ 2 IS THE MAIN ┬┴╙╔├ PROGRAM.  ┴S YOU CAN SEE, THERE ARE NO ╥┼═
  82. STATEMENTS.  ┬ESIDE THE FACT THAT ╔ DON'T LIKE ╥┼═S (THEY CLUTTER UP THE
  83. LISTING AND SERVE NO REAL PURPOSE ANYWAY), THEY ALSO TAKE UP A CONSIDERABLE
  84. AMOUNT OF ╥┴═.  ╔N TRYING TO MAXIMIZE THE BUFFER SPACE, ╔ CHOSE TO LEAVE
  85. THEM OUT.  ╞OR THE BENEFIT OF THOSE WHO ARE INTERESTED THE FOLLOWING
  86. TABLE SUMMARIZES ITS MAIN PARTS.
  87.  
  88.      LINE                 FUNCTION
  89.  
  90.      10-80           OPENING DISPLAY, DEFAULT PARAMETERS, ETC.
  91.      90-120          CALCULATE ├╨/═ SECTOR FILLING TABLE
  92.      130-150         ─┬=START OF DIRECTORY BUFFER,
  93.                      ╘┬=START OF DATA BUFFER IN BANK 0 ╥┴═
  94.                      ─╓() AND ╘┘$() ARE THE SUPPORTED DEVICES
  95.                      AND FILE TYPES.
  96.      160             MAIN MENU SELECT
  97.      170-200         READ ╙┼╤ OR ╨╥╟ FILE
  98.      210-240         WRITE ╙┼╤ OR ╨╥╟ FILE OR PRINTER
  99.      250-300         READ ├╨/═ FILE
  100.      310-380         WRITE ├╨/═ FILE
  101.      390             READ ╙┼╤ DIRECTORY
  102.      400-420         READ ├╨/═ DIRECTORY
  103.      440-450         READ A SPECIFIC ├╨/═ SECTOR
  104.      460-470         WRITE A SPECIFIC ├╨/═ SECTOR
  105.      480-540         ANALYZE ├╨/═ DIRECTORY AND ╞┴╘
  106.      550-560         EXIT AND ERROR ROUTINES
  107.      570             LOG IN CURRENT DISK
  108.      580-600         READ ╨├-─╧╙ DIRECTORY
  109.      610-620         READ A SPECIFIC ╨├-─╧╙ SECTOR
  110.      630-650         ANALYZE ╨├-─╧╙ ╞┴╘ AND DIRECTORY
  111.      660-720         READ ╨├-─╧╙ FILE
  112.      730-770         WRITE ╨├-─╧╙ FILE
  113.      780-820         RECODE AND WRITE ╨├-─╧╙ DIRECTORY AND ╞┴╘
  114.      830-840         WRITE A SPECIFIC ╨├-─╧╙ SECTOR
  115.      850             FIND FREE SPACE ON ╨├-─╧╙ DISK
  116.      860-870         NORMALIZE ╨├ ─╧╙ AND ├╨/═ FILENAMES
  117.      880             DISPLAY FILE STATS
  118.      890-            ENTER MENU OPTIONS
  119.  
  120. ╘HE MAXIMUM FILE SIZE THAT CAN BE TRANSFERRED IN ANY DIRECTIONS IS 45.5
  121. K BYTES.  ╠ONGER FILES WILL BE TRUNCATED TO THIS LENGTH.  ╘HIS IS
  122. EQUIVALENT TO 183 ╙┼╤ BLOCKS OR NEARLY 3 FULL ├╨/═ DIRECTORY EXTENTS.
  123. ┴LL FILES IN MEMORY ARE ASSUMED TO BE IN ┴╙├╔╔ FORMAT.  ╙┼╤ FILES READ
  124. WITH THE CONVERSION OPTION ARE ASSUMED TO BE ╨┼╘╙├╔╔ ON THE DISK AND
  125. ARE TRANSLATED TO ┴╙├╔╔ AS THEY ARE READ IN.  ╙┼╤ FILES WRITTEN
  126. WITH THE CONVERSION OPTION ARE ASSUMED TO BE ┴╙├╔╔ IN MEMORY AND ARE
  127. CONVERTED TO ╨┼╘╙├╔╔ AS THEY ARE WRITTEN TO DISK.  ╙IMILARLY, CONVERSIONS
  128. ARE MADE WHEN READING FROM OR WRITING TO ╨╥╟ SCREEN CODE FILES.  ┴LL
  129. OTHER TRANSFERS ARE DONE IN A BINARY WHAT-YOU-SEE-IS-WHAT-YOU-GET FASHION.
  130.  
  131. ├╥╧╙╙ ╠╔╬╦ CAN BE USED FOR SIMPLE ┴╙├╔╔ <> ╨┼╘╙├╔╔ CONVERSION OF ╙┼╤
  132. FILES WITH EITHER A 1571 OR 1541 (OR OTHER COMPATIBLE ) DRIVE IN THE
  133. FOLLOWING MANNER:
  134.  
  135.      ╨┼╘╙├╔╔ TO ┴╙├╔╔ - READ THE FILE IN ╨┼╘╙├╔╔ <> ┴╙├╔╔ CONVERSION
  136.                         MODE, THEN WRITE IT IN BINARY MODE.
  137.  
  138.      ┴╙├╔╔ TO ╨┼╘╙├╔╔ - READ THE FILE IN BINARY MODE, THEN WRITE IT IN
  139.                         ╨┼╘╙├╔╔ <> ┴╙├╔╔ CONVERSION MODE.
  140.  
  141. ╧NE WORD OF CAUTION FOR ╨┼╘╙├╔╔ <> ┴╙├╔╔ CONVERSIONS.  ├╥╧╙╙ ╠╔╬╦ PASSES
  142. CONTROL CODES (┴╙├╔╔ VALUE LESS THAN 32) AND CERTAIN OTHER SPECIAL
  143. CODES THROUGH IN BOTH DIRECTIONS UNCHANGED.  ╔T ALSO ADDS A LINEFEED
  144. CHARACTER (┴╙├╔╔ ├╚╥$(10)) AFTER EACH CARRIAGE RETURN WHEN CONVERTING
  145. TO ┴╙├╔╔ AND REMOVES ALL LINEFEEDS WHEN CONVERTING TO ╨┼╘╙├╔╔.  ╘HE
  146. PRESENCE OF THESE CODES IN, FOR EXAMPLE, TEXT FORMATTED ON A ├╨/═
  147. WORD PROCESSOR MAY REQUIRE THE TEXT TO BE REFORMATTED WITH A ├-128
  148. WORD PROCESSOR BEFORE IT CAN BE USED IN ├-128 MODE.  ╔N ADDITION,
  149. DOCUMENTS ORIGINALLY WRITTEN OR EDITED WITH SOME WORD PROCESSORS
  150. (SUCH AS ╫ORD╙TAR- EITHER ├╨/═ OR ╨├-─╧╙ VERSION) SHOULD BE HANDLED
  151. IN NON-DOCUMENT MODE (I.E. STANDARD ┴╙├╔╔) ON THESE WORD PROCESSORS
  152. IF THEY ARE INTENDED TO BE SUBSEQUENTLY USED IN ├-128 MODE.  ╫ORD╙TAR
  153. SETS THE HIGH BITS IN THE LAST CHARACTER OF EACH WORD IN DOCUMENT
  154. MODE.  ╘HIS RESULTS IN AN INCORRECT ┴╙├╔╔ TO ╨┼╘╙├╔╔ CONVERSION.  ╘HE HIGH
  155. BIT CAN ALSO BE STRIPPED OUT USING THE ┌ OPTION (ZERO THE PARITY BIT) OF
  156. ├╨/═'S ╨╔╨ COMMAND TO COPY THE ORIGINAL FILE TO AN ┴╙├╔╔ COMPATIBLE FILE.
  157. ┴ SIMILAR ROUTINE CAN BE USED FOR CONVERTING BETWEEN ╙┼╤ AND ╨╥╟ TEXT
  158. FILES.
  159.  
  160. ╫HEN READING THE DIRECTORY, ├╥╧╙╙ ╠╔╬╦ IGNORES THE FILE ATTRIBUTE (BYTE 11)
  161. EXCEPT FOR THE VOLUME LABEL AND SUBDIRECTORY ATTRIBUTES WHICH DO NOT
  162. REPRESENT VALID FILES.  ╘HUS YOU CAN DISPLAY AND ACCESS HIDDEN AND
  163. SYSTEM FILES WHICH DO NOT SHOW UP ON AN ╔┬═-╨├ ─╔╥ COMMAND.
  164. ├╥╧╙╙ ╠╔╬╦ SETS DIRECTORY BYTES 11-25 AND 30-31 TO 0 WHEN IT IS WRITING A NEW
  165. FILE.  ╘HIS IS EASIER THAN TRYING TO CALCULATE A FILE CREATION TIME, DATE,
  166. ATTRIBUTE, ETC.  ┌ERO BYTES IN THESE LOCATIONS ARE ACCEPTED BY ╨├-─╧╙.  ╞OR
  167. A MORE DETAILED DESCRIPTION OF ╨├-─╧╙ FILE FORMATS, ╨ART ╔ OF THIS ARTICLE.
  168.  
  169. ├╥╧╙╙ ╠╔╬╦ WILL RECOVER UNUSED AND SCRATCHED DIRECTORY AND DATA SPACE FOR BOTH
  170. ├╨/═ AND ╨├-─╧╙ DISKS.  ╘HIS IS HANDLED AUTOMATICALLY BY ├OMMODORE ─╧╙ WHEN
  171. WRITING TO ╙┼╤ FILES.  ├╥╧╙╙ ╠╔╬╦ IS CURRENTLY CONFIGURED TO WORK WITH
  172. UP TO TWO DRIVES AND A PRINTER.  ╞OR ├╨/═ AND ╨├-─╧╙ FILES, AT LEAST ONE
  173. OF THE DRIVES MUST BE A 1571.  ╘HE DEVICE CONFIGURATION CAN BE CHANGED
  174. BY ALTERING THE DEFINITIONS OF ARRAYS ─╓() AND ─╓$() IN LINE 130-150.
  175. ╘O USE THE PRINTER FOR A FILE DUMP, SELECT ╙┼╤ ┴╙├╔╔ (FOR AN ┴╙├╔╔ PRINTER)
  176. OR ╙┼╤ ╨┼╘╙├╔╔ AS THE TARGET FILE TYPE WITH THE "╙┼╘ ╘┴╥╟┼╘" OPTION
  177. ON THE MAIN MENU.  (╘HERE IS NO NEED TO SPECIFY A FILENAME FOR THE
  178. PRINTER. ┴ <RETURN> AT THE FILENAME PROMPT IS SUFFICIENT.) ┘OU CAN THEN 
  179. SELECT THE PRINTER AS THE TARGET DEVICE.   ╧F COURSE, THE 1541 OR
  180. COMPATIBLE CAN ONLY BE USED TO READ OR WRITE ╙┼╤ FILES, SINCE IT DOES
  181. NOT SUPPORT BURST MODE.
  182.  
  183. ┴LTHOUGH IT IS NOT AN ╔┬═-╨├ EMULATOR, YOU WILL FIND ├╥╧╙╙ ╠╔╬╦ AN INVALUABLE
  184. UTILITY FOR TRANSFERRING FILES FROM ONE MACHINE TO ANOTHER (AND BETWEEN
  185. MODES ON THE ├-128 ALSO) IF YOU USE BOTH AN ╔┬═-╨├ AND A ├-128.  ╔T IS ALSO
  186. POSSIBLE WITH A LITTLE DETAILED KNOWLEDGE OF THE DISK FORMATS TO USE THE
  187. SAME PRINCIPLES FOR TRANSFERRING FILES TO/FROM OTHER COMPUTERS AND
  188. OPERATING SYSTEMS THAT USE ═╞═ TYPE DISKS, SUCH AS ╘╥╙─╧╙ USED ON THE
  189. ╥ADIO ╙HACK COMPUTERS OR POSSIBLY ╥╙ ├O├O ╧╙/9 DISKS TO ╨┼╘ ╧╙/9 FORMAT.
  190.  
  191.      '1;EOYcmwüïòƒ⌐│╜╟╤█σ∩