home *** CD-ROM | disk | FTP | other *** search
- FlexFile
- Version 1.07
- Ganahl Software, Inc.
- Copyright (c) 1991
-
-
- Please read the contents of this file. It represents changes to
- the documentation which occurred after printing and in some cases
- represents information critical to the use of FlexFile.
-
- In all cases, the Norton Guides database (FlexFile.ng) and the
- (FlexFile.doc) supercede the printed manual. In addition, all
- elements discussed in this readme file are incorporated into the
- Guides and FlexFile.doc.
-
- Note: FlexFile is a commercial product. Do not make any copies
- except for archival purposes.
-
-
- Ganahl Software, Inc.
- P.O. Box 4275
- Deerfield Beach
- Tel: (305) 566-1796
- FAX: (305) 566-3517
-
- *************************************************************************
- General Notes (Ver 1.07)
-
- This readme file is updated in reverse chronological order. Therefore,
- if you already own FlexFile and receive this as an update, you will only
- have to read down to your previous version.
-
- The only change in Ver 1.07 is the addition of the encryption and
- decryption functions V_ENCRYPT(), V_DECRYPT() and V_SETKEY(). See the
- Norton Guides Database (included in self extracting arcive FlexFile.exe).
-
- *************************************************************************
- General Notes (Ver 1.06)
-
- Version 1.06 is a minor upgrade addressing a few minor bugs and adding a
- couple of new functions.
-
- The main feature, however, is internal error checking for programmer
- errors. There were several instances in previous versions where, if the
- program went awry, the DBV file would get corrupted. Error checking has
- been introduced to thwart corruption (even by code that behaves poorly).
-
- *************************************************************************
- General Notes (Ver 1.03, 1.04, 1.05)
-
- Minor bug fixes.
-
- *************************************************************************
- General Notes (Ver 1.02)
-
- Version 1.02 of FlexFile is primarily a maintenance release. However, the
- system which saves and restores Clipper arrays has been completely
- rewritten. This should only affect you if ALL of the following three
- conditions apply to you.
-
- 1. You have an application written in Clipper 5.0x that is sharing a
- FlexFile DBV file with an application written in S87.
-
- 2. You had saved a Clipper S87 array to this FlexFile DBV using the
- FLEX_87.LIB version 1.01 or less (version 1.01 was dated 2/18/91).
-
- 3. You want to retrieve that array with a program linked with
- FLEXFILE.LIB version 1.02 or greater (version 1.02 is dated 7/27/91).
-
- The only change you must make is to use V_FILLEN() in place of V_LEN() when
- DECLAREing the array. To get a full description of this process, read the
- documentation on V_FILLEN() and V_FILLARR() in the Norton Guides data base
- or the FlexFile.doc documentation.
-
- The good news is that any array saved with this *new* FLEX_87.LIB (version
- 1.02) are totally compatible with single dimentional arrays saved or
- restored with the *new* FLEXFILE.LIB (version 1.02). That means that you
- do not have to use the V_FILLARR() functions in your 5.0 code to read
- arrays that are created with S87 code version 1.02. Read the documentation
- on V_ARETRIEVE() and V_FILLARR() to understand how to implement these
- functions for Clipper 5.0x code and for Summer 87 code, respectively.
-
- The reason for all these array changes is a vast improvement in speed and a
- substantial reduction in size of the *new* stored arrays.
-
- *************************************************************************
-
- The following functions were omitted from the manual because they are new
- since the time of printing. They are fully documented in the Guides and the
- text documentation "FlexFile.doc".
-
- V_ARETRIEVE() - Retrieve an array from a field (Clipper 5.0 only)
- V_AREPLACE() - Replace old data with an array (Clipper 5.0 only)
- V_COMMIT() - Commit DOS buffers to disk. (DOS 3.3 or greater)
- V_DECRYPT() - Decrypt a variable previously encrypted with V_ENCRYPT().
- V_ENCRYPT() - Encrypt a Clipper string to an unreadable form.
- V_FILLEN() - Get length of array saved by FLEX_87.lib (ver 1.01 or less).
- V_HANDLE() - Return the DOS file handle for a DBV file.
- V_ISOPEN() - Determine if a file is open in a DBV work area.
- V_RANDOM() - Return or seed a psuedo random number.
- V_SET_COMMIT()- Set DBV/DOS buffer flushing automatically on/off.
- V_SETKEY() - Set a password key to be used with V_ENCRYPT() and V_DECRYPT()
- V_TOPPTR() - Read/Replace FlexFile data without a DBF file (advanced).
- V_WALK_DBV() - Step from field to field in a DBV file without a DBF.
- V_WNDCREATE() - Create a Proclip window from one previously V_REPLACE()d
-
- ******************************************************************************
- Disaster Recovery
-
- Read the documentation on Disaster Recovery in the Norton Guides data base
- or the FlexFile.doc file. This outlines probable causes of corrupted DBV
- files, methods for recovery of corrupted DBV files, and how to manage a DBV
- file when its related DBF file is lost or dammaged. Read the documentation
- on V_WALK_DBV() if you have lost the controlling DBF for a DBV.
-
- ******************************************************************************
- FlexFile Strongly Typed Arrays
-
- FlexFile's Strongly Typed Arrays were designed primarily to allow
- multi-dimensional arrays in far less memory. However, because of the new
- VMM system in Clipper, flexfile's "S"tring type arrays SHOULD NOT BE USED
- with Clipper 5.0x. They will actually use more conventional memory than
- their Clipper counterparts. However, all other types of FlexFile arrays
- are handled properly by the VMM system and will be smaller and more
- efficient than their Clipper counterparts.
-
- The Clipper 5.0 A_ADD() and A_SIZE() had some problems in the version 1.01
- and version 1.00. These functions have been fixed in version 1.02.
-
- ******************************************************************************
- Version 1.01
- *************************************************************************
-
- The manual (pg. 10) states that V_USE will fail (returning -1) if
- you are V_USE()ing a file in shared mode and are working on a
- local drive that does not have SHARE.EXE loaded. This was
- changed in order to be compatable with Clipper's USE and locking
- functions.
-
- The new implementation allows a file to be opened in shared mode
- on a local drive (even if SHARE.EXE is not loaded). No actual
- locking is provided, of course, until SHARE.EXE is loaded or
- until a network shell such as NET4 is introduced into the
- environment.
-
- *************************************************************************
-
- A_DECLARE() has a main syntax and an optional syntax. The
- printed documentation has a misprint in the optional sytax for
- the function (bottom of page 77).
-
- The printed documentation reads (incorrectly):
-
- aLargeArr = A_DECLARE(@<aLargeArr>,
- <cType>,
- <nElement>,
- [<nElements>...] )
-
- The following syntax is what was intended:
-
- // Do not use the return value from A_DECLARE when passing
- // the array by reference. Also, note the order of parameters
- // one and two.
- A_DECLARE( <cType>,
- @<aLargeArr>,
- <nElement>,
- [<nElements>...] )
-
- *************************************************************************
-
- Binary (logical) arrays are not supported by many of the FlexFile
- array functions. For example, you cannot A_SORT() a binary array. The
- FlexFile array functions which operate on binary arrays are:
-
- A_STORE()
- A_SCAN()
- A_RETRIEVE()
- A_LEN()
- A_TYPE()
-
- The printed manual failed to recognize this fact in several of the
- array functions.
-
- Note also, that the previous "Readme.txt" file specifically stated that
- A_SCAN() did not support binary arrays. A_SCAN() does support binary
- arrays; the readme file was in error.
-
-
- *************************************************************************
-
- Many of the array functions are described in the manual as having a
- default scope of "to the end of the row in the current dimension".
- This was changed in every case to be "to the end of the array".
-
- So, for example, if you are copying one array into another and do not
- pass a parameter indicating how many elements to copy, FlexFile will
- copy all elements to the end of the array. This is true for multi-
- dimensional arrays as well. See the section on ARRAYS in the manual
- to understand the "wrapping" behavior of functions like these that span
- several dimensions.
-
- *************************************************************************
- The following functions have had minor changes in the written
- documentation. The Norton Guides and the "FlexFile.doc" file have
- the most up to date documentation on these functions.
-
- A_AVERAGE()
- if nCount is not specified, the average will continue until
- the end of the array, not the end of the current row.
- A_ADD()
- <aTarget> _must_ be passed by reference.
- return is .t. or .f. not value.
- value is no longer a parameter.
- A_SIZE()
- <aTarget> _must_ be passed by reference.
- V_REPLACE()
- returns a (.F.) on error
- A_RETRIEVE()
- returns a '' on error
- V_POKE()
- optional parameter #3 was not originally optional
- **************************************************************************
-
- The error codes in Appendix B have be defined explicitly in
- the Guides and in FlexFile.doc
-
- **************************************************************************
-
- The manual states that a V_REPLACE( "", old_fld ) is not the same
- as a V_DELETE(). This has been changed so that the two have the
- same affect. The above stated V_REPLACE will return six spaces
- which is a "null pointer" to FlexFile. All space that was associated
- with old_fld will become available for use by other data.
-
- **************************************************************************
-