Using Win32 functions in Visual FoxPro Image Gallery
Code examples:
Enumerating servers of the specified type (e.g. SQL Server) in the primary domain
Uploading file to the FTP server using InternetWriteFile
Accessing Windows Control Panel from VFP Application
Changing file attributes
Converting command-line string to a set of Unicode argument strings
Getting a bit more than the _CLIPTEXT offers
How to retrieve network parameters for the local computer (including Host name, Domain name, and DNS Server)
How to retrieve version information for the specified file
How to run FoxPro application under different user name (impersonating user)
Opening the Page Setup dialog box to specify the attributes of a printed page
Retrieving graphic capabilities of default printer
Retrieving list of files on the FTP directory
Using GetBinaryType (WinNT only) to determine the type of an executable file
Winsock: retrieving Web pages using sockets (HTTP, port 80)
Creating a clipping region from the path selected into the device context of a form
Creating a window using CreateWindowEx function
Enumerating network interfaces on the local computer
Form Magnifier
GDI+: retrieving list of available image encoders and image decoders
Generating UUID values from numbers
How to delete IE cookies, clear IE history and delete files in Temporary Internet Files directory
Reading and setting Environment variables
Reading data from INI files
Using the LoadImage function to have a bitmap file loaded and displayed on VFP main window
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: 34  
    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.227.12.219)
    2 sec.Function: 'FindFirstChangeNotification'
    4 sec.Function: 'UpdateResource'
    Google
    Advertise here!