How to Use the _MEMVARMASK Variable

ID: Q102465

2.50x 2.60 2.60a 3.00 WINDOWS kbreadme kbprg

The information in this article applies to:

  • Microsoft Visual FoxPro for Windows, version 3.0
  • Microsoft FoxPro for Windows, versions 2.5x, 2.6, 2.6a

SUMMARY

_MEMVARMASK is a variable used in FoxPro for Windows versions 2.5a and later to make menus work properly with the GraphWizard and spelling checker.

Because of the underscore in the variable name, many people assume it is a system memory variable and would be displayed on the screen if the following commands were issued:

   CLEAR MEMORY
   DISPLAY MEMORY

MORE INFORMATION

The following text from the 2.5a README.TXT file illustrates the use of _MEMVARMASK:

Part 4: _MEMVARMASK

Menus you created in FoxPro 2.5 that included expressions may not have behaved properly when the spelling checker or GraphWizard were active.

SKIP FOR expressions typically depend on the value of skip variables, but the skip variables were not visible to your menus when the spelling checker or GraphWizard was active in FoxPro 2.5. In the initialization code of the spelling checker and GraphWizard applications (SPELLCHK.APP and GENGRAPH.APP respectively), PRIVATE ALL is intentionally issued. This hides skip variables from user-defined menus and causes a "Variable not found" error when you make a menu choice.

To correct this situation, the following code is added to the beginning of the spelling checker and GraphWizard applications:

   IF TYPE("_memvarmask") = "C" and !EMPTY(_memvarmask)
      PRIVATE ALL EXCEPT &_memvarmask
   ELSE
      PRIVATE ALL
   ENDIF

Suppose a certain menu option should be skipped when the memory variable named "skipvar" evaluates to true. You should include the following lines in your menu startup code to take advantage of the _MEMVARMASK variable:

   PUBLIC _memvarmask
   _memvarmask = "skipvar"
   STORE .T. TO skipvar             && Skip initially.

To create a set of skip variables, include the following lines in your menu startup code:

   PUBLIC _memvarmask
   _memvarmask = "skip*"
   STORE .T. TO skipthis, skipthat  && Skip initially.

When you execute the spelling checker and GraphWizard, they don't hide variables in SKIP FOR expressions, preventing the "Variable not found" errors you may have experienced in FoxPro 2.5.

Note that _MEMVARMASK isn't a system memory variable.

REFERENCES

Microsoft FoxPro 2.5a for Windows README.TXT file

Additional reference words: VFoxWin 3.00 FoxWin 2.50a 2.50b 2.60 2.60a KBCategory: kbreadme kbprg KBSubcategory: FxtoolGeneral

Keywords          : FxtoolGeneral 
Version           : 2.50x 2.60 2.60a 3.00
Platform          : WINDOWS


Last Reviewed: April 30, 1996
© 2000 Microsoft Corporation. All rights reserved. Terms of Use.