DOCUMENT:Q145929 05-FEB-2000 [foxpro] TITLE :PRB: Visual FoxPro Creates Public Variable for ControlSource PRODUCT :Microsoft FoxPro PROD/VER:WINDOWS:3.0,3.0b OPER/SYS: KEYWORDS: ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual FoxPro for Windows, versions 3.0, 3.0b ------------------------------------------------------------------------------- SYMPTOMS ======== In a form, the scope of a variable set as a control source is public. This variable is declared in a program. By default, a variable declared in a procedure is private, so you would expect this variable to be private. CAUSE ===== The form is running in a modeless environment. When the form is modeless, program execution does not pause after the form is displayed. When the program is completed, control is returned to the Command window. If the form is still displayed when you return to the Command window, users can input data. This means that the input variables need to be accessible. To prevent errors, Visual FoxPro automatically scopes input variables as public when the Command window is active. So, if the source of the data of a control is a variable, its scope is changed to PUBLIC when the Command window is accessed. RESOLUTION ========== Use a modal form or a READ EVENTS to pause program execution and prevent the scope of the variable from changing. You can also declare the ControlSource variable as a property of a form to scope it to the form object. STATUS ====== This is by design. MORE INFORMATION ================ Steps to Reproduce Behavior --------------------------- 1. Create a new form. 2. Add a text box to the form. 3. Change the ControlSource property of the text box to cCity. 4. Create a program that contains the following code: cCity="Atlanta" DO FORM