Returns, as an INT64 value, the allocated byte size of the memory region associated with the specified MEMPTR variable.
GET-SIZE ( memptr-var )A MEMPTR variable. If the variable is uninitialized (has no associated memory region), the function returns 0.The following example allocates three memory regions-for a BITMAPINFO structure, a BITMAPINFOHEADER structure, and an RGB color array. It then displays the allocation size for each region. These structures describe a device-independent bitmap for Windows dynamic link library (DLL) routines. For more information on these bitmap structures, see your Windows Software Development Kit documentation.
DEFINE VARIABLE bitmapinfo AS MEMPTR NO-UNDO.DEFINE VARIABLE bitmapinfoheader AS MEMPTR NO-UNDO.DEFINE VARIABLE RGBcolors AS MEMPTR NO-UNDO.SET-SIZE(bitmapinfo) = 4 /* Pointer to bitmapinfoheader */+ 4. /* Pointer to RGBcolors */SET-SIZE(bitmapinfoheader) = 4 /* biSize */+ 4 /* biWidth */+ 4 /* biHeight */+ 2 /* biPlanes */+ 2 /* biBitCount */+ 4 /* biCompression */+ 4 /* biSizeImage */+ 4 /* biXpelsPerMeter */+ 4 /* biYPelsPerMeter */+ 4 /* biClrUsed */+ 4 /* biClrImportant */.SET-SIZE(RGBcolors) = 16 * 4. /* Array for 16 RGB color values */DISPLAYGET-SIZE(bitmapinfo)LABEL "Bitmap info structure size" COLON 30 SKIPGET-SIZE(bitmapinfoheader)LABEL "Bitmap header structure size" COLON 30 SKIPGET-SIZE(RGBcolors)LABEL "Bitmap colors array size" COLON 30WITH SIDE-LABELS.
![]()
To return a memory size greater than 0, the MEMPTR variable must be fully initialized, not just pre-initialized by a DLL or UNIX shared library routine.
![]()
For more information on using the MEMPTR data type, see OpenEdge Development: Programming Interfaces.
© 2013 Progress Software Corporation and/or its subsidiaries or affiliates. |