home *** CD-ROM | disk | FTP | other *** search
/ Power-Programmierung / CD1.mdf / xbase / foxupdat / upd_rt.exe / CPZERO.PRG next >
Text File  |  1993-09-28  |  3KB  |  153 lines

  1. * CPZERO -- Poke a codepage byte into a database header
  2. * Author: Walter Kennamer
  3. * Copyright Microsoft Corp, 1993
  4. *
  5. * Usage: 
  6. *    DO CPZERO WITH dbfname                     && marks the database with codepage 0 (i.e., no codepage)
  7. *    DO CPZERO WITH dbfname, codepage_number    && marks the database with specified codepage
  8. *
  9. * Some common valid numbers are:
  10. *   Windows            1252
  11. *   DOS                 437
  12. *   International DOS   850
  13. *
  14.  
  15. PARAMETER m.fname, m.cpbyte
  16. IF SET("TALK") = "ON"
  17.    SET TALK OFF
  18.    m.mtalk = "ON"
  19. ELSE
  20.    m.mtalk = "OFF"
  21. ENDIF   
  22.  
  23. #define C_TOTAL 19     && total code page numbers suppoted
  24.  
  25. IF PARAMETERS() < 2
  26.    m.cpbyte = 0
  27. ENDIF   
  28.  
  29. PRIVATE m.mtalk, m.vuename
  30.  
  31. #define c_buf_size 8096
  32.  
  33. #define c_noopen   1
  34. #define c_badbyte  2
  35. #define c_maxerror 3
  36.  
  37. m.vuename = ""
  38.  
  39. DECLARE error_array[c_maxerror]
  40. error_array[c_noopen] = "Die Tabelle kann nicht ge÷ffnet werden"
  41. error_array[c_badbyte] = "Die angegebene Codeseite ist ungⁿltig."
  42.  
  43. DO setup
  44. DO main
  45. DO cleanup
  46.  
  47. PROCEDURE setup
  48. m.vuename = SYS(2023)+"\"+SYS(3)+".VUE"
  49. CREATE VIEW (m.vuename)
  50.  
  51.  
  52. PROCEDURE cleanup
  53. IF FILE(m.vuename)
  54.    SET VIEW TO (m.vuename)
  55.    DELETE FILE (m.vuename)
  56. ENDIF   
  57. SET TALK &mtalk
  58.  
  59. PROCEDURE main
  60. PRIVATE m.fp_in, m.buf, m.found_one, m.i, m.outbyte
  61.  
  62. * Set up table of code pages and DBF bytes numbers
  63. DIMENSION cpnums[C_TOTAL,2] 
  64. cpnums[ 1,1] = 437
  65. cpnums[ 1,2] = 1
  66. cpnums[ 2,1] = 850
  67. cpnums[ 2,2] = 2
  68. cpnums[ 3,1] = 1252
  69. cpnums[ 3,2] = 3
  70. cpnums[ 4,1] = 10000
  71. cpnums[ 4,2] = 4
  72. cpnums[ 5,1] = 852
  73. cpnums[ 5,2] = 100
  74. cpnums[ 6,1] = 866
  75. cpnums[ 6,2] = 101
  76. cpnums[ 7,1] = 865
  77. cpnums[ 7,2] = 102
  78. cpnums[ 8,1] = 861
  79. cpnums[ 8,2] = 103
  80. cpnums[ 9,1] = 895
  81. cpnums[ 9,2] = 104
  82. cpnums[10,1] = 620
  83. cpnums[10,2] = 105
  84. cpnums[11,1] = 737
  85. cpnums[11,2] = 106
  86. cpnums[12,1] = 857
  87. cpnums[12,2] = 107
  88. cpnums[13,1] = 10007
  89. cpnums[13,2] = 150
  90. cpnums[14,1] = 10029
  91. cpnums[14,2] = 151
  92. cpnums[15,1] = 10006
  93. cpnums[15,2] = 152
  94. cpnums[16,1] = 1250
  95. cpnums[16,2] = 200
  96. cpnums[17,1] = 1251
  97. cpnums[17,2] = 201
  98. cpnums[18,1] = 1253
  99. cpnums[18,2] = 202
  100. cpnums[19,1] = 1254
  101. cpnums[19,2] = 203
  102.  
  103. IF EMPTY(m.fname)
  104.    m.fname = getfile("DBF|SCX|FRX|LBX|MNX","DBF-Name")
  105. ENDIF
  106. IF !EMPTY(m.fname)
  107.    CLOSE DATABASES
  108.    m.outbyte = m.cpbyte
  109.    m.found_one = .F.
  110.    FOR m.i = 1 TO C_TOTAL
  111.       IF m.cpbyte = cpnums[m.i,1]
  112.          m.outbyte = cpnums[m.i,2]
  113.          m.found_one = .T.
  114.          EXIT
  115.       ENDIF
  116.    ENDFOR
  117.    IF m.found_one
  118.       m.cpbyte = m.outbyte
  119.    ELSE
  120.       * Was it a valid DBF byte if it wasn't a valid code page?
  121.       FOR m.i = 1 TO C_TOTAL
  122.          IF m.cpbyte = cpnums[m.i,2]
  123.             m.found_one = .T.
  124.          ENDIF
  125.       ENDFOR
  126.       IF !m.found_one
  127.          DO errormsg WITH c_badbyte
  128.          RETURN TO poke
  129.       ENDIF
  130.    ENDIF
  131.    
  132.    IF FILE(m.fname)
  133.        m.fp_in = fopen(m.fname,2)
  134.        IF m.fp_in > 0
  135.           =fseek(m.fp_in,29)
  136.           =fwrite(m.fp_in,CHR(m.cpbyte))   && poke codepage number into byte 29
  137.           =fclose(m.fp_in)
  138.        ELSE
  139.           DO errormsg WITH c_noopen
  140.           RETURN TO poke
  141.        ENDIF
  142.     ELSE
  143.        DO errormsg WITH c_noopen
  144.        RETURN TO poke
  145.     ENDIF
  146. ENDIF      
  147.  
  148.  
  149. PROCEDURE errormsg
  150. PARAMETER num
  151. WAIT WINDOW error_array[num] NOWAIT
  152.