Attachmate Worldwide  |   Contact Us  |   The Attachmate Group
Extend. Manage. Secure. More than 30 years in the business. Over 65,000 customers.

Technical Notes

Error: "Compile error: User-defined type not defined"
Technical Note 2210
Last Reviewed 20-Jul-2010
Applies To
Reflection 2014
Reflection for IBM 2014
Reflection for UNIX and OpenVMS 2014
Reflection for IBM 2011
Reflection for UNIX and OpenVMS 2011
Reflection Standard Suite 2011
Summary

When attempting to use a Reflection Workspace macro that was recorded in Reflection 2014, 2011, 2008, or 2007, the following error may be displayed: "Compile error: User-defined type not defined." This technical note explains the cause of this error and provides a workaround.

Explanation

When you record a VBA (Visual Basic for Applications) macro, it can be saved to the session document (.rd0x, .rd3x, or .rd5x file) or to the Common project.

This error occurs when a recorded Reflection Workspace macro is run from the common project area. Recorded macros typically contain session object information, which is not supported in the Common project.

Resolving the Error

To resolve this error, do one of the following:

Save the Macro to the Session Document Project

Rerecord the macro and save it to the current document's project, rather than the common project area. Note: Macros saved to the current document's project are available only when the current session is loaded.

To record a macro, follow these steps.

  1. In the Reflection Workspace, open or create a new terminal session.
  2. Click Record Macro.
  3. Perform the tasks you want to automate, and then click Record Macro again.
  4. In the Recording Complete dialog box, enter a Macro name.
  5. Select "Save in the current document's project."

Edit the Macro in the Common Project

Usually the Common project is for macro code that is not session-specific or can be used by any session. However, if you wish to make the recorded session macro work when saved to the common area, add a reference to the appropriate session object library.

Add a Reference to the Attachmate Reflection Library

Follow the steps below to edit the macro and add a reference to the Attachmate Reflection library.

  1. Open the macro in the Visual Basic editor.
  2. Click Tools > References.
  3. Select Attachmate_Reflection_Objects_Emulation_IBMHosts or Attachmate_Reflection_Objects_Emulation_OpenSystems library, depending on your host type.
  4. Click OK.

With this library selected, the macro will now run without the compile error as long as the session indicated in the macro currently has Windows focus.

Running Macro Regardless of Session Focus

To make your macro run the specified session is open (regardless of whether the session has Windows focus), edit the "set currentTerminal=" line.

  1. Edit the macro in the Visual Basic editor.
  2. Scroll down to the following line:
Set currentTerminal = ThisFrame.SelectedView.control
  1. Delete this line, or comment it out by inserting an apostrophe character (') at the beginning of the line.
  2. Replace the line with the following code:
Set currentTerminal = ThisFrame.GetViewByTitleText("Name.rd5x").control

where "Name.rd5x" is your session name.

Sample macro with edits made:

        Sub tinymacro()
            Dim currentScreen As IbmScreen
            Dim currentTerminal As IbmTerminal
            Dim frame As frame
            Dim viewList() As View
            Dim hostSettleTimeout As Integer
            Dim hostSettleTime As Integer
            hostSettleTimeout = 2000
            hostSettleTime = 500
            Set viewFrame = Application.GetObject("Frame")
            ‘ This line commented out:
            ‘Set currentTerminal = ThisFrame.SelectedView.control
            ‘ This line inserted:
            Set currentTerminal = ThisFrame.GetViewByTitleText("Name.rd5x").control
            Set currentScreen = currentTerminal.Screen
            currentScreen.SendKeys ("1")
            currentScreen.SendControlKey (ControlKeyCode_CMD_TRANSMIT)
            rv = currentScreen.WaitForHostSettle(hostSettleTimeout, hostSettleTime)
        End Sub

  1. Click File > Save common.

The macro will now run without the compile error regardless of which Window has focus as long as the session with the name indicated in the "set currentTerminal=" line is opened (Name.rd5x in the example above).

Related Technical Notes
9967 Technical Notes for Reflection 2014 and 2011

horizontal line

Did this technical note answer your question?

           


Need further help? For technical support, please contact Support.