home *** CD-ROM | disk | FTP | other *** search
/ DP Tool Club 12 / CD_ASCQ_12_0294.iso / vrac / dwnld15.zip / DWNLDCD.PPS < prev    next >
Text File  |  1994-01-21  |  9KB  |  210 lines

  1. ;*****************************************************************************
  2. ;*                              DWNLDCD.PPE v1.5                             *
  3. ;*                       PCBOARD 15.1 Download Counter                       *
  4. ;*                                                                           *
  5. ;*                        Written by Steven Hauswirth                        *
  6. ;*                 Written in PCBoard Programming Language                   *
  7. ;*                                                                           *
  8. ;*                          "The Power Palace BBS"                           *
  9. ;*               Node 1 - 312-594-0643 - [14.4 v32b] - 80386/40              *
  10. ;*                                                                           *
  11. ;*   This PPE is a full screen download counter that informs the user how    *
  12. ;*   many files, bytes, et cetera they have flagged for download.            *
  13. ;*****************************************************************************
  14. IF (!ANSION()) THEN
  15.         PRINT "Enter the filename to Download (Enter)=none"
  16.         GOTO EXIT
  17. ENDIF
  18.  
  19. ;┌───────────────────────────────────────────────────────────────────────────┐
  20. ;│ Declare Variable Types                                                    │
  21. ;└───────────────────────────────────────────────────────────────────────────┘
  22. STRING TEMP, Y, FILE_NAME, FLAG_FILE, NO_TIME, FREE_FILE, TEMP_FILE
  23. STRING FLIST_TIME, TEMP_TIME
  24. INTEGER COUNT, LOOP, BAT_MIN, BAT_SEC, BAT_TIME, FILE_SEC, FILE_MIN
  25. INTEGER TEMP1, TEMP2, TEMP3, FILE_SIZE, FILE_NUM
  26.  
  27. IF (PCBNODE() = 0) THEN
  28.     LET FLAG_FILE = GETENV("PCBDRIVE")+GETENV("PCBDIR")+"\FLIST."
  29. ELSE
  30.     LET FLAG_FILE = GETENV("PCBDRIVE")+GETENV("PCBDIR")+"\FLIST."+STRING(PCBNODE())
  31. ENDIF
  32. LET TEMP_FILE = GETENV("PCBDRIVE")+GETENV("PCBDIR")+"\FLIST.TMP"
  33. LET FILE_NUM = 0
  34. BAT_TIME = 0
  35. TEMP1 = 0
  36. TEMP2 = 0
  37. TEMP3 = 0
  38. LET Y = 1
  39. LET LOOP = 1
  40.  
  41. ;┌───────────────────────────────────────────────────────────────────────────┐
  42. ;│ Check to see if they have NOT flagged any files yet for download, or if   │
  43. ;│ the user has decided not to download the flagged files.                   │
  44. ;└───────────────────────────────────────────────────────────────────────────┘
  45. FOPEN 1,FLAG_FILE,O_RD,S_DN
  46. FDEFIN 1
  47. FSEEK 1,0,SEEK_SET(0)
  48. FOR LOOP = 1 TO 100000
  49.    FSEEK 1,66,SEEK_CUR(1)
  50.    FDREAD FILE_NAME,13
  51.    IF (FERR(1)) BREAK
  52.    FSEEK 1,50,SEEK_CUR(1)
  53. NEXT
  54. IF (EXIST(TEMP_FILE)) THEN
  55.     FLIST_TIME = FILEINF(FLAG_FILE,3)
  56.     TEMP_TIME = FILEINF(TEMP_FILE,3)
  57.     IF (LEFT(TEMP_TIME,2) < LEFT(FLIST_TIME,2)) THEN
  58.        IF (MID(TEMP_TIME,4,2) < MID(FLIST_TIME,4,2)) THEN
  59.           IF (RIGHT(TEMP_TIME,2) < RIGHT(FLIST_TIME,2)) GOTO SKIP
  60.        ENDIF
  61.     ENDIF
  62.     FOPEN 2, TEMP_FILE, O_RD, S_DN
  63.     FGET 2,TEMP1
  64.     FCLOSE 2
  65. ELSE GOTO SKIP
  66. ENDIF
  67. IF (LOOP=1) GOTO SKIP
  68. IF ((TEMP1+1)!=LOOP) WAIT
  69. :SKIP
  70. DELETE TEMP_FILE
  71. FOPEN 2, TEMP_FILE, O_WR, S_DN
  72. FPUT 2, LOOP
  73. FCLOSE 2
  74. COUNT = LOOP
  75.  
  76. ;┌───────────────────────────────────────────────────────────────────────────┐
  77. ;│ Display the header of the dispay                                          │
  78. ;└───────────────────────────────────────────────────────────────────────────┘
  79. TEMP1 = 0
  80.  
  81. IF (GRAFMODE()="R") THEN
  82.     PRINTLN " "
  83.     PRINTLN "!|1K|*"
  84. ENDIF
  85. PRINTLN "@CLS@@X0A ┌────────────────────────────────────────────────────────────────────────────┐"
  86. PRINTLN " │  @X09░▒▓█@X1B         Statistics for the last 10 files in your batch         @X09█▓▒░@X0A  │"
  87. PRINTLN " │                                                                            │"
  88. PRINTLN " │   @X0BNum      Filename         Size        Transfer Time     Free    No Time  @X0A│"
  89. PRINTLN " │  @X0D────    ────────────    ──────────    ───────────────    ────    ───────  @X0A│"
  90.  
  91. ;┌───────────────────────────────────────────────────────────────────────────┐
  92. ;│ Since there are files already flagged for download. Find out how many.    │
  93. ;│ If there are more then 10 then position display to only display the last  │
  94. ;│ ten of them.                                                              │
  95. ;└───────────────────────────────────────────────────────────────────────────┘
  96. FSEEK 1,0,SEEK_SET(0)
  97. IF (COUNT>10) THEN
  98.    FOR LOOP = 1 TO (COUNT-10)
  99.       FSEEK 1,83,SEEK_CUR(1)
  100.       FDREAD TEMP,1
  101.       IF (ASC(TEMP)!=0) TEMP1 = ASC(TEMP)
  102.       FDREAD TEMP,1
  103.       IF (ASC(TEMP)!=0) TEMP2 = 256*ASC(TEMP)
  104.       FDREAD TEMP,1
  105.       IF (ASC(TEMP)!=0) TEMP3 =65536*ASC(TEMP)
  106.       BAT_TIME = BAT_TIME + TEMP1 + TEMP2 + TEMP3
  107.       FSEEK 1,43,SEEK_CUR(1)
  108.    NEXT
  109. ELSE COUNT = 10
  110. ENDIF
  111. LET Y = COUNT-9
  112.  
  113. ;┌───────────────────────────────────────────────────────────────────────────┐
  114. ;│ Display the file name, bytes, and transfer time for all the files flagged │
  115. ;└───────────────────────────────────────────────────────────────────────────┘
  116. FOR LOOP= 1 TO COUNT
  117.    TEMP1 = 0
  118.    TEMP2 = 0
  119.    TEMP3 = 0
  120.    FSEEK 1,66,SEEK_CUR(1)
  121.    FDREAD FILE_NAME,13
  122.    IF (FERR(1)) BREAK
  123.    FDREAD TEMP,1
  124.    IF (ASC(TEMP)!=0) TEMP1 = ASC(TEMP)
  125.    FDREAD TEMP,1
  126.    IF (ASC(TEMP)!=0) TEMP2 = 256*ASC(TEMP)
  127.    FDREAD TEMP,1
  128.    IF (ASC(TEMP)!=0) TEMP3 =65536*ASC(TEMP)
  129.    FILE_SIZE = TEMP1+TEMP2+TEMP3
  130.    TEMP1 = 0
  131.    TEMP2 = 0
  132.    TEMP3 = 0
  133.    FSEEK 1,1,SEEK_CUR(1)
  134.    FDREAD TEMP,1
  135.    IF (ASC(TEMP)!=0) TEMP1 = ASC(TEMP)
  136.    FDREAD TEMP,1
  137.    IF (ASC(TEMP)!=0) TEMP2 = 256*ASC(TEMP)
  138.    FDREAD TEMP,1
  139.    IF (ASC(TEMP)!=0) TEMP3 =65536*ASC(TEMP)
  140.    FILE_SEC = TEMP1 + TEMP2 + TEMP3
  141.    BAT_TIME = BAT_TIME + FILE_SEC
  142.    FSEEK 1,9,SEEK_CUR(1)
  143.    FDREAD FREE_FILE,1
  144.    FDREAD NO_TIME,1
  145.    FSEEK 1,32,SEEK_CUR(1)
  146.    FILE_MIN = FILE_SEC/60
  147.    FILE_SEC = FILE_SEC - FILE_MIN*60
  148.    PRINT " │@X0B"+LEFT("     ",6-LEN(Y))+STRING(Y)+LEFT("                 ",16-LEN(FILE_NAME))+"@X0F"
  149.    PRINT FILE_NAME+LEFT("               ",14-LEN(STRING(FILE_SIZE)))
  150.    PRINT STRING(FILE_SIZE)+LEFT("         ",8-LEN(FILE_MIN))
  151.    PRINT STRING(FILE_MIN)+" @X07min@X0F"+LEFT("    ",3-LEN(STRING(FILE_SEC)))+STRING(FILE_SEC)+" @X07sec      "
  152.    IF (ASC(FREE_FILE)=1) THEN
  153.       PRINT "@X0CY"
  154.    ELSE PRINT "@X0EN"
  155.    ENDIF
  156.    IF (ASC(NO_TIME)=1) THEN
  157.    PRINT "        @X0CY"
  158.    ELSE PRINT "        @X0C@X0EN"
  159.    ENDIF
  160.    ANSIPOS 79,5+LOOP
  161.    PRINTLN "@X0A│"
  162.    ANSIPOS 1,6+LOOP
  163.    INC Y
  164. NEXT
  165.  
  166. ;┌────────────────────────────────────────────────────────────────────────────┐
  167. ;│ Display with blank lines to fill the screen to ten file placements listed  │
  168. ;└────────────────────────────────────────────────────────────────────────────┘
  169. :CONT
  170.     FOR LOOP = LOOP TO 10
  171.     PRINTLN " @X0A│@X0B"+LEFT("     ",6-LEN(Y))+STRING(Y)+"                             @X0F0       0 @X07min  @X0F0 @X07sec                     @X0A│"
  172.     INC Y
  173.     NEXT
  174. :BACK
  175.  
  176. ;┌───────────────────────────────────────────────────────────────────────────┐
  177. ;│ Display the footer of the dispay                                          │
  178. ;└───────────────────────────────────────────────────────────────────────────┘
  179. PRINTLN " │                                                                            │"
  180. PRINTLN " │  @X09░▒▓█@X1B                Statistics for the ENTIRE batch                 @X09█▓▒░@X0A  │"
  181. PRINTLN " │                                                                            │"
  182. PRINT " │    @X07Files: @X0F@FFILES:3@  @X07Size (bytes): @X0F@FBYTES:12@  @X07Estimated time: @X0F"
  183.  
  184. ;┌───────────────────────────────────────────────────────────────────────────┐
  185. ;│ Calculate the BATCH transfer time from the BATCH bytes listed on screen   │
  186. ;│ taking into account local logons and error correcting modems.             │
  187. ;└───────────────────────────────────────────────────────────────────────────┘
  188. LET FILE_NUM = S2I(TRIM(SCRTEXT(14,19,2,FALSE)," "),10)
  189. BAT_MIN = BAT_TIME/60
  190. BAT_SEC = BAT_TIME - BAT_MIN*60
  191. PRINT STRING(BAT_MIN)+" @X07min"+" @X0F"+STRING(BAT_SEC)+" @X07sec@X0A"
  192. ANSIPOS 79,19
  193. PRINTLN "│"
  194. PRINTLN " └────────────────────────────────────────────────────────────────────────────┘"
  195. PRINTLN "           @X07Enter @X0Ffilename @X07on line above, or (@X0CENTER@X07) alone to continue@X08       1.5"
  196.  
  197. ;┌───────────────────────────────────────────────────────────────────────────┐
  198. ;│ Position cursor on the screen and ask for file name. Then stuff it into   │
  199. ;│ keyboard buffer and exit                                                  │
  200. ;└───────────────────────────────────────────────────────────────────────────┘
  201. IF (FILE_NUM > 9) FILE_NUM = 9
  202. ANSIPOS 13,6+FILE_NUM
  203. LET FILE_NAME = ""
  204. INPUTSTR "_",file_name,@X07,12,MASK_FILE()+"*?",UPCASE
  205. ANSIPOS 1,21
  206. FILE_NAME=TRIM(FILE_NAME," ")
  207. IF (LEN(file_name) = 0) file_name = CHR(13)
  208. KBDSTUFF file_name
  209. :EXIT
  210. END