home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 5 / 05.iso / a / a082 / 1.img / README.TXT < prev   
Encoding:
Text File  |  1994-01-14  |  21.7 KB  |  572 lines

  1.                        README.TXT
  2. **********************************************************
  3.                    Release Notes for
  4.  
  5.     Microsoft(R) FoxPro(R) for MS-DOS (R) Version 2.5b
  6.  
  7.     (C)1993 Microsoft Corporation. All Rights Reserved.
  8.  
  9. Information in the FoxPro online Help is more current than
  10. information in the printed documentation. This README
  11. provides information not contained in the FoxPro online
  12. help or documentation, and provides corrections to both.
  13. **********************************************************
  14. ========
  15. CONTENTS
  16. ========
  17.  
  18. Part   Description
  19. ----   -----------
  20. 1      Installation
  21. 2      WAIT...WINDOW Enhancements
  22. 3      New Commands and Functions
  23. 4      New Transporter and Screen Directives
  24. 5      International and Cross-Platform Recommendations
  25.  
  26. ----------------------------------------------------------
  27. ====================
  28. Part 1: Installation 
  29. ====================
  30.  
  31. There are three types of installation for FoxPro for
  32. MS-DOS: Normal Installation, Administrative Installation
  33. and Workstation Installation. Instructions for Normal
  34. Installation are in the FoxPro Installation and
  35. Configuration manual. For information about Administrative
  36. and Workstation Installation, see INSTALL.TXT on FoxPro 
  37. for MS-DOS Disk 1.
  38. ----------------------------------------------------------
  39. ================================
  40. Part 2: WAIT WINDOW Enhancements 
  41. ================================
  42.  
  43. WAIT WINDOW now supports multiple line messages. Use a
  44. carriage return (CHR(13)) to move portions of your message
  45. to additional lines. The message window is automatically
  46. expanded to accommodate additional lines. For example, this
  47. command creates a message window that contains two lines:
  48.  
  49. WAIT WINDOW "This is the 1st line" + CHR(13) + ;
  50.     "This is the 2nd line"
  51.  
  52. The width of the message window is adjusted to fit the
  53. longest line in the message. All lines in the message are
  54. left justified in the message window. Line feeds (CHR(10))
  55. following CHR(13) are ignored.
  56. ----------------------------------------------------------
  57. ==================================
  58. Part 3: New Commands and Functions 
  59. ==================================
  60.  
  61. Several new commands and functions are added to
  62. FoxPro 2.5b. For additional information about these
  63. commands and functions, see the "International and Cross
  64. Platform Recommendations" section below and the
  65. corresponding topics in Help.
  66.  
  67. New Commands
  68. ------------
  69.  
  70. SET NOCPTRANS
  71. SET COLLATE
  72.  
  73. New Functions
  74. -------------
  75.  
  76. CPCURRENT( )
  77. CPDBF( )
  78. CPCONVERT( )
  79. IDXCOLLATE( )
  80. ----------------------------------------------------------
  81. =============================================
  82. Part 4: New Transporter and Screen Directives 
  83. =============================================
  84.  
  85. Several new Transporter and screen directives have been
  86. added.
  87.  
  88. The #DOSOBJ, #MACOBJ, #UNIXOBJ and #WINOBJ  
  89. Transporter directives allow you to transport objects
  90. created in the Screen Builder and Report Writer to 
  91. specific FoxPro platforms. For additional information 
  92. about these Transporter directives, see the Transporting 
  93. Files topic in Help.
  94.  
  95. #TRAN SNIPPET ONLY, a new screen directive, is available
  96. in FoxPro 2.5b. This screen directive affects how screen
  97. objects are transported, and is not discussed in Help.
  98. #TRAN SNIPPET ONLY is designed to limit the Transporter's
  99. changes to just screen snippets, and is placed in
  100. a screen's Setup snippet.
  101.  
  102. When screen objects are transported to a different FoxPro
  103. platform, only the screen snippets for updated screen
  104. objects are transported if #TRAN SNIPPET ONLY is included.
  105. All other screen object attributes are not transported to
  106. the different platform. 
  107.  
  108. Note that #TRAN SNIPPET ONLY only affects updated screen
  109. objects; it does not affect new or unchanged screen
  110. objects or screen objects being transported for the first
  111. time.
  112. ----------------------------------------------------------
  113. =========================================================
  114. Part 5: International and Cross Platform Recommendations 
  115. ========================================================= 
  116.  
  117.                    *** IMPORTANT ***
  118.  
  119. *******************************************************
  120. *  Be sure to read this section completely before you *
  121. *  change code pages or collation sequences!          *
  122. *******************************************************
  123.  
  124. Overview of topics
  125.  
  126. 1   FoxPro Collation Sequences
  127. 2   Case-Insensitive Collation Sequences
  128. 3   Case-Sensitive Collation Sequences
  129. 4   How do the SEEK and SKIP commands work?
  130. 5   Alternatives to SEEK and SKIP
  131. 6   Additional Recommendations
  132. 7   New Code Pages
  133. 8   CPZERO Program
  134. 9   Corrections to the Help File
  135.  
  136. FoxPro 2.5b gives international developers and users
  137. powerful new features for handling accented characters
  138. across different FoxPro platforms, and provides 
  139. accurate sorting in many languages.
  140.  
  141. For international FoxPro users, this section describes
  142. how code pages and collation sequences affect sorting,
  143. seeking and comparisons using the SORT and SEEK commands,
  144. and also provides recommendations for taking advantage
  145. of these features.
  146.  
  147. U.S. FoxPro users whose applications don't contain
  148. accented characters may not need any of the new
  149. international 2.5b features. In this case, you can
  150. disregard this section of the README and the
  151. International/X-Platform topic in Help. FoxPro 2.5b is
  152. 100% percent compatible with FoxPro 2.5.  
  153.  
  154. 1 FoxPro Collation Sequences
  155. ----------------------------
  156.  
  157. With a MACHINE collation sequence, which earlier FoxPro
  158. versions use (and to which FoxPro 2.5b still defaults),
  159. each character in the code page, whether it's a Roman
  160. character, an accented character, or a line-drawing
  161. character, has a unique "sort weight" determined by its
  162. position in the code page. In a majority of code
  163. pages, all accented characters appear after the unaccented
  164. characters. In this situation an ä sorts after z, which
  165. isn't correct in most languages (although it is true in
  166. Swedish, for instance).
  167.  
  168. Furthermore, in most languages accented characters sort
  169. after their unaccented counterparts, but only if the
  170. unaccented versions of all characters being compared are
  171. the same. For example, in German, ä sorts after the
  172. unaccented a, but the string äa sorts before the string ab
  173. because the second character a is less than the second
  174. character b. In this way, characters are interleaved in
  175. many cultures.
  176.  
  177. FoxPro 2.5b supports a number of new collation sequences
  178. to correctly sort in many languages. These sequences take
  179. into account all the complex rules of the language
  180. (including two-to-one, three-to-one and one-to-two
  181. mappings). The following collation sequences were
  182. available when this README was created. The code pages
  183. for which these collation sequences are defined are also
  184. included.
  185.  
  186. Collation Sequence   Friendly Name    Code Pages
  187. ------------------   -------------    ----------
  188. CZECH                Czech            852, 895, 1250            
  189. DUTCH                Dutch            437, 850, 1252
  190. GREEK                Greek            737, 1253            
  191. GENERAL              General          437, 620, 850,
  192.                                       852, 861, 865,
  193.                                       895, 1250, 1252,
  194.                                       10000            
  195. HUNGARY              Hungarian        852, 1250            
  196. ICELAND              Icelandic        437, 850, 861,
  197.                                       1252
  198. MACHINE              Machine          All            
  199. NORDAN               Norwegian/Danish 437, 850, 865,
  200.                                       1252    
  201. POLISH               Polish           620, 852, 1250            
  202. RUSSIAN              Russian          866, 1251            
  203. SLOVAK               Slovak           852, 895, 1250            
  204. SPANISH              Spanish          437, 850, 1252
  205. SWEFIN               Swedish/Finnish  437, 850, 1252
  206. UNIQWT               Unique Weight    437, 850, 1252,
  207.                                       10000    
  208.  
  209. If you specify a collation sequence in the SET COLLATE
  210. command as a string literal, enclose the collation
  211. sequence in quotation marks. Don't enclose the collation
  212. sequence in quotation marks if you specify a collation
  213. sequence in your FoxPro configuration file (CONFIG.FP or
  214. CONFIG.FPW).
  215.  
  216. If you use the SET COLLATE command to specify a collation 
  217. sequence that isn't supported by the current code page, 
  218. FoxPro generates an error. If you specify a collation 
  219. sequence in your FoxPro configuration file that isn't 
  220. supported by the current code page, the collation sequence 
  221. defaults to MACHINE.
  222.  
  223. If you specify a collation sequence in the International
  224. panel in the View window, the collation sequence names 
  225. appear in longer forms. For example, the NORDAN option 
  226. appears as Norwegian & Danish, and the SWEFIN option 
  227. appears as Swedish & Finnish.
  228.  
  229. For additional information about collation sequences, see
  230. SET COLLATE in Help.
  231.  
  232. 3 Case-Sensitive Collation Sequences
  233. ------------------------------------
  234.  
  235. Two case-sensitive collation sequences are available in
  236. FoxPro: the familiar MACHINE sequence, the default
  237. sequence in earlier FoxPro versions, and the sequence
  238. named UNIQWT. UNIQWT is a "unique weight" sort in which 
  239. each accented character sorts strictly after its 
  240. unaccented counterpart (unlike the interleaving of 
  241. accented characters described earlier).
  242.  
  243. While the collation sequence with UNIQWT isn't strictly
  244. culturally correct as with GENERAL, it may aid developers
  245. in migrating their applications from earlier FoxPro
  246. versions. One reason is that upper- and lower-case letter
  247. are treated distinctly as they were in earlier FoxPro
  248. versions. Another reason is described in the section
  249. titled "How do the SEEK and SKIP commands work?"
  250.  
  251. 4 How do the SEEK and SKIP commands work?
  252. -----------------------------------------
  253.  
  254. The SEEK command accepts an expression. FoxPro transforms
  255. that expression into a sort key which it compares to
  256. keys in the master index or tag. SEEK then positions the 
  257. record pointer at the first index entry that's greater 
  258. than or equal to ( >= ) the supplied key.
  259.  
  260. With a machine sort, SEEK finds a match if there is one.
  261. The UNIQWT sort has the same property. But when FoxPro
  262. uses the new language-specific collation sequences to
  263. create indexes, only the alphabetic part of the key is
  264. considered and any diacritical marks are ignored. In other
  265. words, even if you SEEK "äbc" you may find "abc". Note
  266. that partial searches (where you search for part of the
  267. field) using SEEK may not return the results you expect
  268. when the current collation sequence is not MACHINE or
  269. UNIQWT.
  270.  
  271. FoxPro behaves this way for the following three reasons:
  272.  
  273. 1) Performance.
  274.  
  275. 2) Consistency with the SKIP command.
  276.  
  277. 3) Consistency with the SET NEAR command.
  278.  
  279. To have SEEK and SKIP find only those records that exactly
  280. match accented characters, you must either SET EXACT ON or
  281. use an index tag created with the MACHINE or UNIQWT
  282. collation sequences. 
  283.  
  284. Note that SEEK and SKIP use the collation sequence of the
  285. master index or tag, and ignore the current collation
  286. sequence. SEEK can't be used unless there is an index is
  287. active.  
  288.  
  289. 5 Alternatives to SEEK and SKIP
  290. -------------------------------
  291.  
  292. If you use accented characters, use one of the following
  293. methods to search a table:
  294.  
  295. 1) Construct a loop with SCAN FOR ... ENDSCAN.
  296.  
  297. 2) Use LOCATE FOR ... CONTINUE. 
  298.  
  299. LOCATE and SCAN use an index if one is active, and
  300. they have two very significant advantages over SEEK when
  301. data contains accented characters.
  302.  
  303. First, both LOCATE and SCAN remember the condition with
  304. which they were invoked, so they can be used for looping
  305. on a condition. SEEK, on the other hand, simply positions
  306. you somewhere in the index, and SKIP continues down the
  307. index from that point. With international data, this may
  308. not give you the results you want.
  309.  
  310. Second, LOCATE and SCAN are diacritically-sensitive,
  311. whereas SEEK isn't. In addition, both LOCATE and SCAN can
  312. be fully optimized by Rushmore if the current collation
  313. sequence is MACHINE or UNIQWT; otherwise partial
  314. optimization will occur.
  315.  
  316. The ORDER BY clause of the SQL SELECT command uses the
  317. current collating sequence, which is returned by
  318. SET("COLLATE")).
  319.  
  320. 6 Additional Recommendations
  321. ----------------------------
  322.  
  323. 1) If you aren't concerned with indexing accented
  324. characters in a language-specific way, feel free to
  325. continue to use machine indexes. For many U.S. users,
  326. this is appropriate.
  327.  
  328. 2) For the best performance when using a collation
  329. sequence other than MACHINE or UNIQWT, be sure that the
  330. current collation sequence is the same as the collation
  331. sequence of any indexes you are using.
  332.  
  333. 3) Most international users will want accented characters
  334. in all fields to be translated automatically by FoxPro
  335. when running cross-platform applications. However, if you
  336. have a table with a character field that's actually 
  337. storing binary information (data), the SET NOCPTRANS 
  338. command allows you to inform FoxPro that characters
  339. in such a field should not be translated. 
  340.  
  341. Binary data might otherwise be changed, because of
  342. FoxPro's "nearest" character mapping.  For characters such
  343. as the MS-DOS line-drawing characters, FoxPro maps to the
  344. "nearest" character in the destination code page.
  345.  
  346. If you choose to use SET NOCPTRANS, you must do so
  347. immediately after issuing the USE command. From that
  348. point on, FoxPro's automatic character translation is
  349. not in effect for any fields you designate. In particular, 
  350. you must issue the SET NOCPTRANS command before issuing 
  351. a SQL SELECT command -- you cannot let SQL SELECT open
  352. tables for you if the tables contain fields which should
  353. not be translated.
  354.  
  355. Note that SET NOCPTRANS only operates on fields for the
  356. table open in the currently selected work area.  If you
  357. close a table and then open the table again, you must
  358. reissue SET NOCPTRANS and designate the fields which
  359. should not be translated.
  360.  
  361. 4) If you create cross platform applications, you should
  362. avoid using FoxFont. FoxFont is an OEM MS-DOS font that
  363. you may find useful in some situations. But if you use
  364. FoxFont in an application you create in FoxPro for
  365. Windows, some of the characters in the application may
  366. not transport correctly to other FoxPro platforms.
  367.  
  368. Furthermore, FoxFont won't correctly display characters
  369. typed on international Windows keyboards. If you have
  370. automatic code page translation enabled, FoxPro will
  371. display accented characters correctly.
  372.  
  373. FoxFont is the installed default font for the FoxPro
  374. desktop. FoxFont is the default font for user-defined
  375. windows created with DEFINE WINDOW when the FONT clause
  376. is omitted. Be sure to include the FONT clause when
  377. creating user-defined windows in FoxPro for Windows.
  378.  
  379. FixedSys is the default font for the Command, Trace and
  380. Debug windows if you're using Windows 3.1. Text editor
  381. windows default to the current Command window font. 
  382.  
  383. 5) FoxPro 2.5b can automatically translate accented
  384. characters in most files types such as .DBF, .SCX, and
  385. .FXP files. However, program (.PRG) and text (.TXT)
  386. files don't have a header and can't be marked with a code
  387. page. Therefore, FoxPro must assume that a program or text
  388. file was designed for use on the platform on which it is
  389. opened.
  390.  
  391. It's important that you compile each program on the 
  392. platform on which it was written. Since compiled programs 
  393. (.FXP files) have a header, once you compile a program, it 
  394. can be run on any FoxPro platform and accented characters 
  395. in the original source program are automatically 
  396. translated when automatic code page translation is in 
  397. effect.
  398.  
  399. 6) Do not mix programs created on different FoxPro
  400. platforms in a project. The Project Manager assumes that
  401. all programs in a project are native to the current FoxPro
  402. platform. If you create an application or an executable
  403. from a project that contains programs created on different
  404. FoxPro platforms, translation of accented characters in
  405. the programs might not be translated properly.
  406.  
  407. Also, within the Project Manager you can't specify the
  408. platform on which a program or text file was created.
  409. Therefore, in the Project Manager don't edit programs or
  410. tables created on a FoxPro platform other than the current 
  411. platform.  This means that you shouldn't double-click on a
  412. file to open it in the Project Manager if you've enabled
  413. automatic translation by including CODEPAGE = AUTO in 
  414. your FoxPro configuration file.
  415.  
  416. If you create an application that contains files created
  417. on different FoxPro platforms, do not open the files for
  418. editing from within the Project Manager.
  419.  
  420. However, once you build an application (.APP file), it
  421. will run on any FoxPro platform and FoxPro can
  422. automatically translate accented characters.
  423.  
  424. 7) If you have a project created in FoxPro for MS-DOS
  425. version 2.0 and the files within the project contain 
  426. accented characters, you can share the project and 
  427. its files across different FoxPro platforms by performing
  428. the  following steps to convert the project and its files.
  429. This conversion is required just once, and enables cross 
  430. platform sharing of all the elements of the project.
  431.  
  432. a) Open the project in FoxPro for MS-DOS 2.5b or FoxPro
  433.    for Windows 2.5b. A dialog appears, asking if you would 
  434.    like to convert the project to a 2.5 format. Choose 
  435.    Yes, then close the project.
  436.   
  437. b) Open every screen, report, label, menu and table
  438.    contained in the project with the USE command. You are 
  439.    prompted for the code page (437, 850 and so on) on 
  440.    which each was created. Specify the MS-DOS code page 
  441.    on which each was built and then choose Yes.
  442.  
  443. c) Use MODIFY COMMAND or MODIFY FILE and include the
  444.    AS clause to open EVERY program, query, format file
  445.    or text file contained in the project. In the AS
  446.    clause, specify the code page (437, 850 and so on)
  447.    of the FoxPro platform on which each was created.
  448.    Choose the Save As option from the File menu and choose
  449.    the Change Code Page check box.  In the dialog that
  450.    appears after you choose Save, specify the code page
  451.    for the FoxPro platform on which the file will be used.
  452.  
  453. 8) If you're developing a cross-platform application,
  454. avoid using characters that appear in one code page and
  455. not another. For example, the MS-DOS line drawing
  456. characters aren't supported under Windows, so avoid using
  457. them in screens you plan to transport between FoxPro for
  458. MS-DOS and FoxPro for Windows.
  459.  
  460. You can use CHR() if your application absolutely requires
  461. line drawing and accented characters. Output from CHR()
  462. isn't translated when the function is executed, allowing
  463. you to output any character.
  464.  
  465. 9) The MS-DOS file system is case-insensitive and requires
  466. uppercase file names. If your applications run on FoxPro
  467. for MS-DOS, be sure to restrict file names to those
  468. characters that have uppercase equivalents in your MS-DOS
  469. code page.
  470.  
  471. For example, code page 437 doesn't contain uppercase
  472. versions of several accented vowels. These characters
  473. can't be safely used in a FoxPro file name. It's best
  474. to avoid accented characters in file names.
  475.  
  476. 7 New Code Pages
  477. ----------------
  478.  
  479. The following code pages are now supported:
  480.  
  481. Code Page       Platform
  482. ---------       --------
  483. 437             U.S. MS-DOS
  484. 737             Greek MS-DOS (437G)
  485. 620             Mazovia (Polish) MS-DOS
  486. 850             International MS-DOS
  487. 852             EE MS-DOS (Latin II)
  488. 861             Icelandic MS-DOS
  489. 865             Nordic MS-DOS
  490. 866             Russian MS-DOS
  491. 895             Kamenicky (Czech) MS-DOS
  492. 1250            Windows EE
  493. 1251            Russian Windows
  494. 1252            Windows ANSI
  495. 1253            Greek Windows
  496. 10000           Standard Macintosh
  497.  
  498. Byte 29 in table headers contains the code page identifier.
  499. The following table lists the code page and the
  500. corresponding code page identifier in hex.
  501.  
  502. Code Page       Code Page Identifier
  503. ---------       --------------------
  504. 437             x01
  505. 737             x6A
  506. 620             x69
  507. 850             x02
  508. 852             x64
  509. 861             x67
  510. 865             x66
  511. 866             x65
  512. 895             x68
  513. 1250            xC8
  514. 1251            xC9
  515. 1252            x03
  516. 1253            xCA
  517. 10000           x04
  518.  
  519. 8 CPZERO Program
  520. ----------------
  521.  
  522. If you accidentally specify the wrong code page when
  523. you open a table that isn't marked with a code page, run
  524. CPZERO.PRG to reset the table's code page to zero. CPZERO
  525. is a FoxPro program that is automatically installed in
  526. your FoxPro directory. Before you run CPZERO, make sure
  527. that the table whose code page you'll reset isn't open.
  528. When you run CPZERO, you are prompted for the name of the 
  529. table to modify.  
  530.  
  531. 9 Corrections to the Help File
  532. ------------------------------
  533.  
  534. Configuring FoxPro and International/X-Platform Topics
  535. ------------------------------------------------------
  536.  
  537. These FoxPro 2.5b help file topics contain the following
  538. line:
  539.  
  540. "Note that MODIFY STRUCTURE also marks a table with the
  541. current code page."  
  542.  
  543. This line is incorrect and should read:
  544.  
  545. "Note that MODIFY STRUCTURE doesn't mark a table with the
  546. current code page. Rather, it preserves the table's 
  547. existing code page mark." 
  548.  
  549. International/X-Platform Topic
  550. ------------------------------
  551.  
  552. This help file topic contains the following line:
  553.  
  554. For example, if the current collation sequence is GENERAL,
  555. both of these return true (.T.):
  556.  
  557.     "Straße" = "Strasse"
  558.  
  559.     and
  560.  
  561.     "Straße" == "Strasse"
  562.  
  563. "Straße" == "Strasse" will always return .F., not .T. as
  564. it states in this topic. A strict machine comparison is
  565. performed by ==. All characters in each string are
  566. compared, including trailing blanks. For more information
  567. about comparisons using = and ==, see SET EXACT in the
  568. Language Reference or the FoxPro help facility.
  569. ----------------------------------------------------------
  570.                    =================
  571.                    End of README.TXT
  572.                    =================