/**************************************************************************** * include/sys/un.h * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. The * ASF licenses this file to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance with the * License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. * ****************************************************************************/ #ifndef __INCLUDE_SYS_UN_H #define __INCLUDE_SYS_UN_H /**************************************************************************** * Included Files ****************************************************************************/ #include /**************************************************************************** * Pre-processor Definitions ****************************************************************************/ /* The size of sun_path is not specified. Different implementations us * different sizes. BSD4.3 uses a size of 108; BSD4.4 uses a size of 104. * Most implementation use a size that ranges from 92 to 108. Applications * should not assume a particular length for sun_path. * * _POSIX_PATH_MAX would be a good choice too. */ #define UNIX_PATH_MAX 108 /**************************************************************************** * Public Type Definitions ****************************************************************************/ /* A UNIX domain socket address is represented in the following structure. * This structure must be cast compatible with struct sockaddr. */ struct sockaddr_un { sa_family_t sun_family; /* AF_UNIX */ char sun_path[UNIX_PATH_MAX]; /* pathname */ }; /* There are three types of addresses: * * 1. pathname: sun_path holds a null terminated string. The allocated * size may be variable: sizeof(sa_family_t) + strlen(pathname) + 1 * 2. unnamed: A unix socket that is not bound to any name. This case * there is no path. The allocated size may be sizeof(sa_family_t) * 3. abstract. The abstract path is distinguished because the pathname * consists of only the NUL terminator. The allocated size is then * sizeof(s_family_t) + 1. */ /**************************************************************************** * Public Function Prototypes ****************************************************************************/ #endif /* __INCLUDE_SYS_UN_H */