WSGetNetworkAddressList (C 関数)

char ** WSGetNetworkAddressList(WSENV env,unsigned long *n)

マシン上で設定されたネットワークインターフェースすべてのIPアドレスを含むASCII文字列のリストと,n におけるリストの長さを返す.

詳細

  • WSGetNetworkAddressList()は,マシン上のアクティブネットワークインターフェースのそれぞれについて,IP番号をロードする.
  • WSGetNetworkAddressList()は,IPv4番号とIPv6番号の両方をロードする.
  • WSGetNetworkAddressList()は,解放されなければならないアドレスを保存するためにメモリを割り当てるWSGetNetworkAddressList()で割り当てられたメモリを解放するためには,WSGetNetworkAddressList()によって返されるリスト上でWSReleaseNetworkAddressList()を呼び出す.
  • WSGetNetworkAddressList()は,失敗した場合にはNULLを返す.
  • WSGetNetworkAddressList()は,WSTPヘッダファイルwstp.hの中で宣言される.

例題

  (1)

#include "wstp.h"

/* A function that reads the IP addresses available on a machine */

void f(WSENV env)
{
    char **theList = NULL;
    char *tmp;
    unsigned long length;

    theList = WSGetNetworkAddressList(env, &length);

    if(length > 0 && theList != (char **)0)
    {
        while((tmp = *theList++) != (char *)0)
        {
            /* ... */
        }

        WSReleaseNetworkAddressList(env, theList, length);
    }
}