DOCUMENT:Q149747 03-NOV-1999 [fortran] TITLE :PRB: Debugger Cannot Evaluate Out of Scope Named Constants PRODUCT :Microsoft Fortran Compiler PROD/VER::4.0 OPER/SYS: KEYWORDS:kbFortranPS kbLangFortran ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Fortran PowerStation for Windows 95 and Windows NT, version 4.0 ------------------------------------------------------------------------------- SYMPTOMS ======== The debugger's watch window cannot evaluate expressions that contain named constants that have gone out of scope. Attempting to use a variable evaluation expression containing a locally undefined named constant in one of the watch windows causes the message "EE2347: Undefined variable" to be returned in the corresponding value field. STATUS ====== This behavior is by design. MORE INFORMATION ================ The scope context operator allows you to view information about module variables that have gone out of scope. However, using the scope context operator in this manner does not apply to named constants. You cannot use the scope context operator to evaluate named constants. Steps to Illustrate Behavior ---------------------------- 1. Build the sample code provided in Developer Studio. 2. After successfully building the sample code, start a debugging session by selecting Debug from the Build menu and then choosing Step Into. 3. Step into the module subroutine MODULE_PROC. In a watch window, type: " MY_MODULE::MODULE_PROC::Y" (without the quotation marks) The number 9.00000 is correctly displayed for the named constant Y. 4. Step into the internal module subroutine INTERNAL_PROC to the assignment statement of variable N. Note that the watch expression created in Step 3 is no longer valid because it references the named constant Y which is out of scope. 5. In the subroutine INTERNAL_PROC, evaluate the variables H and N and the named constant Y. In a watch window, do the following: To evaluate H using the scope context operator, type: " {MY_MODULE::MODULE_PROC::INTERNAL_PROC}H" (without the quotation marks) To evaluate N using the scope context operator, type: " {MY_MODULE::MODULE_PROC::INTERNAL_PROC}N" (without the quotation marks) Evaluation of Y will fail when out of scope or when using the scope context operator. Using the scope context operator, type: " {MY_MODULE::MODULE_PROC::INTERNAL_PROC}Y" (without the quotation marks) -or- Without the scope context operator, type: " MY_MODULE::MODULE_PROC::INTERNAL_PROC::Y" (without the quotation marks) NOTE: "EE2347: Undefined variable" is generated for the named constant Y. The value of the named constant Y can only be viewed while control is in the MODULE_PROC subroutine. Sample Code ----------- ! Compile options needed: /Zi MODULE MY_MODULE INTEGER H CONTAINS SUBROUTINE MODULE_PROC PARAMETER(Y=9.0) CALL INTERNAL_PROC CONTAINS SUBROUTINE INTERNAL_PROC INTEGER N N = Y + H END SUBROUTINE INTERNAL_PROC END SUBROUTINE MODULE_PROC END MODULE MY_MODULE PROGRAM TEST USE MY_MODULE CALL MODULE_PROC END PROGRAM TEST Additional query words: 4.00 ====================================================================== Keywords : kbFortranPS kbLangFortran Technology : kbAudDeveloper kbPTProdChange kbFortranSearch kbFORTRANPower400NT Version : :4.0 ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 1999.