Manpages

名 前

getservent, getservbyname, getservbyport, setservent, endservent − サ ー ビ ス の エ ン ト リ ー を 取 得 す る

書 式

#include <netdb.h>

struct servent *getservent(void);

struct servent *getservbyname(const char *name, const char *proto);

struct servent *getservbyport(int port, const char *proto);

void setservent(int stayopen);

void endservent(void);

説 明

getservent() 関 数 は サ ー ビ ス の デ ー タ ベ ー ス (services(5) 参 照 ) か ら 次 の エ ン ト リ ー を 読 み 込 み 、 そ の エ ン ト リ ー を servent 構 造 体 の 要 素 別 の フ ィ ー ル ド に 格 納 し 、 そ の 構 造 体 を 返 す 。 必 要 で あ れ ば 、 デ ー タ ベ ー ス へ の 接 続 が オ ー プ ン さ れ る 。

getservbyname() 関 数 は 、 プ ロ ト コ ル proto を 用 い る サ ー ビ ス の 名 前 name に マ ッ チ す る エ ン ト リ ー を デ ー タ ベ ー ス か ら 探 し 、 そ の エ ン ト リ ー を 収 め た servent 構 造 体 を 返 す 。 proto が NULL の 場 合 は 、 任 意 の プ ロ ト コ ル に マ ッ チ す る 。 必 要 で あ れ ば 、 デ ー タ ベ ー ス へ の 接 続 が オ ー プ ン さ れ る 。

getservbyport() 関 数 は 、 プ ロ ト コ ル proto を 用 い る サ ー ビ ス の ポ ー ト 番 号 port に マ ッ チ す る エ ン ト リ ー を デ ー タ ベ ー ス か ら 探 し 、 そ の エ ン ト リ ー の 内 容 を 収 め た servent 構 造 体 を 返 す (ポ ー ト 番 号 port は ネ ッ ト ワ ー ク バ イ ト オ ー ダ で 指 定 す る )。 proto が NULL の 場 合 は 任 意 の プ ロ ト コ ル に マ ッ チ す る 。 必 要 で あ れ ば 、 デ ー タ ベ ー ス へ の 接 続 が オ ー プ ン さ れ る 。

setservent() 関 数 は デ ー タ ベ ー ス へ の 接 続 を オ ー プ ン し 、 次 の 読 み 込 み エ ン ト リ ー を 先 頭 の エ ン ト リ ー に 設 定 す る 。 stayopen が 0 で な い 場 合 、 一 つ 一 つ の getserv*() 関 数 の 呼 び 出 し 間 で デ ー タ ベ ー ス へ の 接 続 を ク ロ ー ズ し な い 。

endservent() 関 数 は デ ー タ ベ ー ス へ の 接 続 を ク ロ ー ズ す る 。

servent 構 造 体 は <netdb.h> で 以 下 の よ う に 定 義 さ れ て い る 。

struct servent {
char *s_name; /* official service name */
char **s_aliases; /* alias list */
int s_port; /* port number */
char *s_proto; /* protocol to use */ }

servent 構 造 体 の メ ン バ ー は 以 下 の 通 り 。

s_name サ ー ビ ス の 正 式 名

(official name)。

s_aliases サ ー ビ ス の 別 名 の リ ス ト 。 リ ス ト は ヌ ル で 終 端 さ れ る 。

s_port サ ー ビ ス の ポ ー ト 番 号 。 ネ ッ ト ワ ー ク バ イ ト オ ー ダ で 指 定 さ れ る 。

s_proto こ の サ ー ビ ス と 共 に 用 い る プ ロ ト コ ル の 名 前 。

返 り 値

getservent(), getservbyname(), getservbyport() 関 数 は 、 静 的 に 割 り 当 て ら れ た servent 構 造 体 へ の ポ イ ン タ ー を 返 す 。 エ ラ ー が 起 こ っ た り 、 フ ァ イ ル の 末 尾 に 達 し た 場 合 は NULL を 返 す 。

フ ァ イ ル

/etc/services サ ー ビ ス の デ ー タ ベ ー ス フ ァ イ ル

準 拠

4.3BSD, POSIX.1−2001.

関 連 項 目

getnetent(3), getprotoent(3), getservent_r(3), services(5)

こ の 文 書 に つ い て

こ の man ペ ー ジ は Linux man−pages プ ロ ジ ェ ク ト の リ リ ー ス 3.79 の 一 部 で あ る 。 プ ロ ジ ェ ク ト の 説 明 と バ グ 報 告 に 関 す る 情 報 は http://www.kernel.org/doc/man−pages/ に 書 か れ て い る 。