Using Win32 functions in Visual FoxPro Image Gallery
Code examples:
System Image List Viewer
Winsock: retrieving directory listing from an FTP server using passive data connection (FTP, port 21)
Adding an ODBC data source with the SQLConfigDataSource; use automatic or interactive mode
Connecting a local device to a network resource
Customizing the frame of top-level form: removing the standard frame (VFP9, Vista)
Drawing Windows predefined bitmaps using the LoadBitmap functions
How to download this reference`s archive through WinInet functions using InternetOpenUrl
Obtaining current Internet Explorer browser version and UserAgent
Quering waveform-audio output devices
Testing serial ports
Using Change Notification Objects to monitor changes to the printer or print server
Winsock: retrieving Web pages using sockets (HTTP, port 80)
Creating a clipping region from the path selected into the device context of a form
Passing data records between VFP applications via the Clipboard
Retrieving file information for the VFP executable running
Start an executable from VFP application by using the CreateProcess
Using FrameRgn for displaying system colors
Using InternetSetFilePointer when resuming interrupted download from the Internet
Converting an integer value to a hexadecimal string
Downloading files from the FTP server using InternetReadFile
Drawing a window caption using the DrawCaption routine
Enumerating ports that are available for printing on a specified server
GDI+: sending image of FoxPro form to printer
GetFocus returns a HWND value
How to enumerate terminal servers within the specified Windows domain

User rating: 0/10 (0 votes)
Rate this code sample:
  • ~
More code examples    Listed functions    Add comment     W32 Constants      Translate this page Printer friendly version of this code sample
Before you begin:
See also:
  • How to enumerate sessions and processes on a specified terminal server

  • DO declare
    
    LOCAL cDomainName, hBuffer, nSvrIndex, nSvrCount, nBufsize,;
        cBuffer, nAddress, cSvrName
    
    STORE 0 TO hBuffer, nSvrCount
    
    * The first parameter is the name of Windows domain to be queried.
    * If this parameter is NULL, the current domain is assumed.
    cDomainName=NULL
    *cDomainName="companydomain"
    
    nResult = WTSEnumerateServers(cDomainName, 0, 1, @hBuffer, @nSvrCount)
    
    IF nResult = 0
    * 1212=invalid domain name/format
        ? "WTSEnumerateServers failed with error:", GetLastError()
        RETURN
    ENDIF
    
    ? "Number of terminal servers within the domain:", nSvrCount
    
    * create VFP string variable and allocate amount of space
    * required to store the array of WTS_SERVER_INFO structures
    * created by WTSEnumerateServers function
    nBufsize = GlobalSize(hBuffer)
    cBuffer = REPLICATE(CHR(0), nBufsize)
    = MemToStr(@cBuffer, hBuffer, nBufsize)
    
    *    The array of WTS_SERVER_INFO structures starts with 
    * N DWORD (4-byte) values, where N is the number 
    * of terminal servers detected.
    *    Each value is the address in memory where a terminal server
    * name is stored.
    *    Each terminal server name ends with zero byte.
    
    * retrieve terminal server names from the array
    FOR nSvrIndex=0 TO nSvrCount-1
        nAddress = buf2dword(SUBSTR(cBuffer, nSvrIndex*4+1, 4))
        cSvrName = SUBSTR(cBuffer, nAddress - hBuffer+1)
        cSvrName = SUBSTR(m.cSvrName, 1, AT(CHR(0),cSvrName)-1)
        ? "["+cSvrName+"]"
    NEXT
    
    * release memory implicitly allocated by the WTSEnumerateServers
    = WTSFreeMemory(hBuffer)
    * end of main
    
    PROCEDURE declare
        DECLARE INTEGER GetLastError IN kernel32
        DECLARE WTSFreeMemory IN Wtsapi32 INTEGER pMemory
        DECLARE INTEGER GlobalSize IN kernel32 INTEGER hMem
    
        DECLARE INTEGER WTSEnumerateServers IN Wtsapi32;
            STRING pDomainName, LONG Reserved, LONG RqVersion,;
            LONG @ppServerInfo, LONG @SICount
    
        DECLARE RtlMoveMemory IN kernel32 As MemToStr; 
            STRING @dst, INTEGER src, INTEGER ByteCount
    
    FUNCTION buf2dword(lcBuffer)
    RETURN Asc(SUBSTR(lcBuffer, 1,1)) + ;
        BitLShift(Asc(SUBSTR(lcBuffer, 2,1)),  8) +;
        BitLShift(Asc(SUBSTR(lcBuffer, 3,1)), 16) +;
        BitLShift(Asc(SUBSTR(lcBuffer, 4,1)), 24)
    
    
    

    User rating: 0/10 (0 votes)
    Rate this code sample:
    • ~
    2157 bytes  
    Created: 2006-12-29 16:20:17  
    Modified: 2006-12-29 16:33:08  
    Visits in 7 days: 44  
    Listed functions:
    GetLastError
    GlobalSize
    WTSEnumerateServers
    WTSFreeMemory
    Printer friendly API declarations
    Word Index links for this example:
    Translate this page:
      Spanish    Portuguese    German    French    Italian  
    FreeTranslation.com offers instant, free translations of text or web pages.
    User Contributed Notes:
    There are no notes on this subject.


    Copyright 2001-2014 News2News, Inc. Before reproducing or distributing any data from this site please ask for an approval from its owner. Unless otherwise specified, this page is for your personal and non-commercial use. The information on this page is presented AS IS, meaning that you may use it at your own risk. Microsoft Visual FoxPro and Windows are trade marks of Microsoft Corp. All other trademarks are the property of their respective owners. 

    Privacy policy
    Credits: PHP (4.4.9), an HTML-embedded scripting language, MySQL (5.1.68), the Open Source standard SQL database, AceHTML Freeware Version 4, freeware HTML Editor of choice.   Hosted by Korax Online Inc.
    Last Topics Visited (54.83.227.191)
    2 sec.Function: 'CreateFont'
    5 sec.Function: 'NetScheduleJobEnum'
    Function group: 'Network Management'
    21.67 hrs.Example: 'Using Video Capture: displaying on FoxPro form frames and previewing video obtained from a digital camera'
    Google
    Advertise here!