Merge "New additions/bug fixes required/found when porting perf."
This commit is contained in:
commit
e80f799d89
@ -281,8 +281,12 @@ libc_common_src_files := \
|
|||||||
bionic/ssp.c \
|
bionic/ssp.c \
|
||||||
bionic/stubs.c \
|
bionic/stubs.c \
|
||||||
bionic/system_properties.c \
|
bionic/system_properties.c \
|
||||||
|
bionic/tdelete.c \
|
||||||
|
bionic/tdestroy.c \
|
||||||
bionic/time64.c \
|
bionic/time64.c \
|
||||||
|
bionic/tfind.c \
|
||||||
bionic/thread_atexit.c \
|
bionic/thread_atexit.c \
|
||||||
|
bionic/tsearch.c \
|
||||||
bionic/utime.c \
|
bionic/utime.c \
|
||||||
bionic/utmp.c \
|
bionic/utmp.c \
|
||||||
netbsd/gethnamaddr.c \
|
netbsd/gethnamaddr.c \
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
/* $OpenBSD: realpath.c,v 1.13 2005/08/08 08:05:37 espie Exp $ */
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2003 Constantin S. Svintsoff <kostik@iclub.nsu.ru>
|
* Copyright (c) 2003 Constantin S. Svintsoff <kostik@iclub.nsu.ru>
|
||||||
*
|
*
|
||||||
@ -27,6 +26,12 @@
|
|||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#if defined(LIBC_SCCS) && !defined(lint)
|
||||||
|
static char sccsid[] = "@(#)realpath.c 8.1 (Berkeley) 2/16/94";
|
||||||
|
#endif /* LIBC_SCCS and not lint */
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
__FBSDID("$FreeBSD: release/9.0.0/lib/libc/stdlib/realpath.c 217144 2011-01-08 11:04:30Z kib $");
|
||||||
|
|
||||||
#include <sys/param.h>
|
#include <sys/param.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
@ -36,23 +41,36 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* char *realpath(const char *path, char resolved[PATH_MAX]);
|
|
||||||
*
|
|
||||||
* Find the real name of path, by removing all ".", ".." and symlink
|
* Find the real name of path, by removing all ".", ".." and symlink
|
||||||
* components. Returns (resolved) on success, or (NULL) on failure,
|
* components. Returns (resolved) on success, or (NULL) on failure,
|
||||||
* in which case the path which caused trouble is left in (resolved).
|
* in which case the path which caused trouble is left in (resolved).
|
||||||
*/
|
*/
|
||||||
char *
|
char *
|
||||||
realpath(const char *path, char resolved[PATH_MAX])
|
realpath(const char * __restrict path, char * __restrict resolved)
|
||||||
{
|
{
|
||||||
struct stat sb;
|
struct stat sb;
|
||||||
char *p, *q, *s;
|
char *p, *q, *s;
|
||||||
size_t left_len, resolved_len;
|
size_t left_len, resolved_len;
|
||||||
unsigned symlinks;
|
unsigned symlinks;
|
||||||
int serrno, slen;
|
int m, serrno, slen;
|
||||||
char left[PATH_MAX], next_token[PATH_MAX], symlink[PATH_MAX];
|
char left[PATH_MAX], next_token[PATH_MAX], symlink[PATH_MAX];
|
||||||
|
|
||||||
|
if (path == NULL) {
|
||||||
|
errno = EINVAL;
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
if (path[0] == '\0') {
|
||||||
|
errno = ENOENT;
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
serrno = errno;
|
serrno = errno;
|
||||||
|
if (resolved == NULL) {
|
||||||
|
resolved = malloc(PATH_MAX);
|
||||||
|
if (resolved == NULL)
|
||||||
|
return (NULL);
|
||||||
|
m = 1;
|
||||||
|
} else
|
||||||
|
m = 0;
|
||||||
symlinks = 0;
|
symlinks = 0;
|
||||||
if (path[0] == '/') {
|
if (path[0] == '/') {
|
||||||
resolved[0] = '/';
|
resolved[0] = '/';
|
||||||
@ -63,13 +81,20 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
left_len = strlcpy(left, path + 1, sizeof(left));
|
left_len = strlcpy(left, path + 1, sizeof(left));
|
||||||
} else {
|
} else {
|
||||||
if (getcwd(resolved, PATH_MAX) == NULL) {
|
if (getcwd(resolved, PATH_MAX) == NULL) {
|
||||||
strlcpy(resolved, ".", PATH_MAX);
|
if (m)
|
||||||
|
free(resolved);
|
||||||
|
else {
|
||||||
|
resolved[0] = '.';
|
||||||
|
resolved[1] = '\0';
|
||||||
|
}
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
resolved_len = strlen(resolved);
|
resolved_len = strlen(resolved);
|
||||||
left_len = strlcpy(left, path, sizeof(left));
|
left_len = strlcpy(left, path, sizeof(left));
|
||||||
}
|
}
|
||||||
if (left_len >= sizeof(left) || resolved_len >= PATH_MAX) {
|
if (left_len >= sizeof(left) || resolved_len >= PATH_MAX) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ENAMETOOLONG;
|
errno = ENAMETOOLONG;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -85,6 +110,8 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
p = strchr(left, '/');
|
p = strchr(left, '/');
|
||||||
s = p ? p : left + left_len;
|
s = p ? p : left + left_len;
|
||||||
if (s - left >= sizeof(next_token)) {
|
if (s - left >= sizeof(next_token)) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ENAMETOOLONG;
|
errno = ENAMETOOLONG;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -95,6 +122,8 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
memmove(left, s + 1, left_len + 1);
|
memmove(left, s + 1, left_len + 1);
|
||||||
if (resolved[resolved_len - 1] != '/') {
|
if (resolved[resolved_len - 1] != '/') {
|
||||||
if (resolved_len + 1 >= PATH_MAX) {
|
if (resolved_len + 1 >= PATH_MAX) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ENAMETOOLONG;
|
errno = ENAMETOOLONG;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -126,6 +155,8 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
*/
|
*/
|
||||||
resolved_len = strlcat(resolved, next_token, PATH_MAX);
|
resolved_len = strlcat(resolved, next_token, PATH_MAX);
|
||||||
if (resolved_len >= PATH_MAX) {
|
if (resolved_len >= PATH_MAX) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ENAMETOOLONG;
|
errno = ENAMETOOLONG;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -134,16 +165,23 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
errno = serrno;
|
errno = serrno;
|
||||||
return (resolved);
|
return (resolved);
|
||||||
}
|
}
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
if (S_ISLNK(sb.st_mode)) {
|
if (S_ISLNK(sb.st_mode)) {
|
||||||
if (symlinks++ > MAXSYMLINKS) {
|
if (symlinks++ > MAXSYMLINKS) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ELOOP;
|
errno = ELOOP;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
slen = readlink(resolved, symlink, sizeof(symlink) - 1);
|
slen = readlink(resolved, symlink, sizeof(symlink) - 1);
|
||||||
if (slen < 0)
|
if (slen < 0) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
return (NULL);
|
return (NULL);
|
||||||
|
}
|
||||||
symlink[slen] = '\0';
|
symlink[slen] = '\0';
|
||||||
if (symlink[0] == '/') {
|
if (symlink[0] == '/') {
|
||||||
resolved[1] = 0;
|
resolved[1] = 0;
|
||||||
@ -164,6 +202,8 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
if (p != NULL) {
|
if (p != NULL) {
|
||||||
if (symlink[slen - 1] != '/') {
|
if (symlink[slen - 1] != '/') {
|
||||||
if (slen + 1 >= sizeof(symlink)) {
|
if (slen + 1 >= sizeof(symlink)) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ENAMETOOLONG;
|
errno = ENAMETOOLONG;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -172,6 +212,8 @@ realpath(const char *path, char resolved[PATH_MAX])
|
|||||||
}
|
}
|
||||||
left_len = strlcat(symlink, left, sizeof(left));
|
left_len = strlcat(symlink, left, sizeof(left));
|
||||||
if (left_len >= sizeof(left)) {
|
if (left_len >= sizeof(left)) {
|
||||||
|
if (m)
|
||||||
|
free(resolved);
|
||||||
errno = ENAMETOOLONG;
|
errno = ENAMETOOLONG;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
|
71
libc/bionic/tdelete.c
Normal file
71
libc/bionic/tdelete.c
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
/* $NetBSD: tdelete.c,v 1.2 1999/09/16 11:45:37 lukem Exp $ */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tree search generalized from Knuth (6.2.2) Algorithm T just like
|
||||||
|
* the AT&T man page says.
|
||||||
|
*
|
||||||
|
* The node_t structure is for internal use only, lint doesn't grok it.
|
||||||
|
*
|
||||||
|
* Written by reading the System V Interface Definition, not the code.
|
||||||
|
*
|
||||||
|
* Totally public domain.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if 0
|
||||||
|
#if defined(LIBC_SCCS) && !defined(lint)
|
||||||
|
__RCSID("$NetBSD: tdelete.c,v 1.2 1999/09/16 11:45:37 lukem Exp $");
|
||||||
|
#endif /* LIBC_SCCS and not lint */
|
||||||
|
#endif
|
||||||
|
__FBSDID("$FreeBSD: release/9.0.0/lib/libc/stdlib/tdelete.c 108694 2003-01-05 02:43:18Z tjr $");
|
||||||
|
|
||||||
|
#define _SEARCH_PRIVATE
|
||||||
|
#include <search.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* delete node with given key
|
||||||
|
*
|
||||||
|
* vkey: key to be deleted
|
||||||
|
* vrootp: address of the root of the tree
|
||||||
|
* compar: function to carry out node comparisons
|
||||||
|
*/
|
||||||
|
void *
|
||||||
|
tdelete(const void * __restrict vkey, void ** __restrict vrootp,
|
||||||
|
int (*compar)(const void *, const void *))
|
||||||
|
{
|
||||||
|
node_t **rootp = (node_t **)vrootp;
|
||||||
|
node_t *p, *q, *r;
|
||||||
|
int cmp;
|
||||||
|
|
||||||
|
if (rootp == NULL || (p = *rootp) == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
while ((cmp = (*compar)(vkey, (*rootp)->key)) != 0) {
|
||||||
|
p = *rootp;
|
||||||
|
rootp = (cmp < 0) ?
|
||||||
|
&(*rootp)->llink : /* follow llink branch */
|
||||||
|
&(*rootp)->rlink; /* follow rlink branch */
|
||||||
|
if (*rootp == NULL)
|
||||||
|
return NULL; /* key not found */
|
||||||
|
}
|
||||||
|
r = (*rootp)->rlink; /* D1: */
|
||||||
|
if ((q = (*rootp)->llink) == NULL) /* Left NULL? */
|
||||||
|
q = r;
|
||||||
|
else if (r != NULL) { /* Right link is NULL? */
|
||||||
|
if (r->llink == NULL) { /* D2: Find successor */
|
||||||
|
r->llink = q;
|
||||||
|
q = r;
|
||||||
|
} else { /* D3: Find NULL link */
|
||||||
|
for (q = r->llink; q->llink != NULL; q = r->llink)
|
||||||
|
r = q;
|
||||||
|
r->llink = q->rlink;
|
||||||
|
q->llink = (*rootp)->llink;
|
||||||
|
q->rlink = (*rootp)->rlink;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free(*rootp); /* D4: Free node */
|
||||||
|
*rootp = q; /* link parent to new node */
|
||||||
|
return p;
|
||||||
|
}
|
33
libc/bionic/tdestroy.c
Normal file
33
libc/bionic/tdestroy.c
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012, The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define _SEARCH_PRIVATE
|
||||||
|
#include <search.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
/* destroy a tree and free all allocated resources */
|
||||||
|
void
|
||||||
|
tdestroy(void *root, void (*destroy_func)(void *))
|
||||||
|
{
|
||||||
|
node_t *root_node = (node_t *) root;
|
||||||
|
if (root_node == NULL) return;
|
||||||
|
if (root_node->llink)
|
||||||
|
tdestroy(root_node->llink, destroy_func);
|
||||||
|
if (root_node->rlink)
|
||||||
|
tdestroy(root_node->rlink, destroy_func);
|
||||||
|
(*destroy_func)(root_node->key);
|
||||||
|
free(root);
|
||||||
|
}
|
48
libc/bionic/tfind.c
Normal file
48
libc/bionic/tfind.c
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/* $NetBSD: tfind.c,v 1.2 1999/09/16 11:45:37 lukem Exp $ */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tree search generalized from Knuth (6.2.2) Algorithm T just like
|
||||||
|
* the AT&T man page says.
|
||||||
|
*
|
||||||
|
* The node_t structure is for internal use only, lint doesn't grok it.
|
||||||
|
*
|
||||||
|
* Written by reading the System V Interface Definition, not the code.
|
||||||
|
*
|
||||||
|
* Totally public domain.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if 0
|
||||||
|
#if defined(LIBC_SCCS) && !defined(lint)
|
||||||
|
__RCSID("$NetBSD: tfind.c,v 1.2 1999/09/16 11:45:37 lukem Exp $");
|
||||||
|
#endif /* LIBC_SCCS and not lint */
|
||||||
|
#endif
|
||||||
|
__FBSDID("$FreeBSD: release/9.0.0/lib/libc/stdlib/tfind.c 108694 2003-01-05 02:43:18Z tjr $");
|
||||||
|
|
||||||
|
#define _SEARCH_PRIVATE
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <search.h>
|
||||||
|
|
||||||
|
/* find a node, or return 0 */
|
||||||
|
void *
|
||||||
|
tfind(vkey, vrootp, compar)
|
||||||
|
const void *vkey; /* key to be found */
|
||||||
|
void * const *vrootp; /* address of the tree root */
|
||||||
|
int (*compar)(const void *, const void *);
|
||||||
|
{
|
||||||
|
node_t **rootp = (node_t **)vrootp;
|
||||||
|
|
||||||
|
if (rootp == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
while (*rootp != NULL) { /* T1: */
|
||||||
|
int r;
|
||||||
|
|
||||||
|
if ((r = (*compar)(vkey, (*rootp)->key)) == 0) /* T2: */
|
||||||
|
return *rootp; /* key found */
|
||||||
|
rootp = (r < 0) ?
|
||||||
|
&(*rootp)->llink : /* T3: follow left branch */
|
||||||
|
&(*rootp)->rlink; /* T4: follow right branch */
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
58
libc/bionic/tsearch.c
Normal file
58
libc/bionic/tsearch.c
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
/* $NetBSD: tsearch.c,v 1.3 1999/09/16 11:45:37 lukem Exp $ */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tree search generalized from Knuth (6.2.2) Algorithm T just like
|
||||||
|
* the AT&T man page says.
|
||||||
|
*
|
||||||
|
* The node_t structure is for internal use only, lint doesn't grok it.
|
||||||
|
*
|
||||||
|
* Written by reading the System V Interface Definition, not the code.
|
||||||
|
*
|
||||||
|
* Totally public domain.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if 0
|
||||||
|
#if defined(LIBC_SCCS) && !defined(lint)
|
||||||
|
__RCSID("$NetBSD: tsearch.c,v 1.3 1999/09/16 11:45:37 lukem Exp $");
|
||||||
|
#endif /* LIBC_SCCS and not lint */
|
||||||
|
#endif
|
||||||
|
__FBSDID("$FreeBSD: release/9.0.0/lib/libc/stdlib/tsearch.c 108694 2003-01-05 02:43:18Z tjr $");
|
||||||
|
|
||||||
|
#define _SEARCH_PRIVATE
|
||||||
|
#include <search.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
/* find or insert datum into search tree */
|
||||||
|
void *
|
||||||
|
tsearch(vkey, vrootp, compar)
|
||||||
|
const void *vkey; /* key to be located */
|
||||||
|
void **vrootp; /* address of tree root */
|
||||||
|
int (*compar)(const void *, const void *);
|
||||||
|
{
|
||||||
|
node_t *q;
|
||||||
|
node_t **rootp = (node_t **)vrootp;
|
||||||
|
|
||||||
|
if (rootp == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
while (*rootp != NULL) { /* Knuth's T1: */
|
||||||
|
int r;
|
||||||
|
|
||||||
|
if ((r = (*compar)(vkey, (*rootp)->key)) == 0) /* T2: */
|
||||||
|
return *rootp; /* we found it! */
|
||||||
|
|
||||||
|
rootp = (r < 0) ?
|
||||||
|
&(*rootp)->llink : /* T3: follow left branch */
|
||||||
|
&(*rootp)->rlink; /* T4: follow right branch */
|
||||||
|
}
|
||||||
|
|
||||||
|
q = malloc(sizeof(node_t)); /* T5: key not found */
|
||||||
|
if (q != 0) { /* make new node */
|
||||||
|
*rootp = q; /* link new node to old */
|
||||||
|
/* LINTED const castaway ok */
|
||||||
|
q->key = (void *)vkey; /* initialize new node */
|
||||||
|
q->llink = q->rlink = NULL;
|
||||||
|
}
|
||||||
|
return q;
|
||||||
|
}
|
66
libc/include/ar.h
Normal file
66
libc/include/ar.h
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
/* $OpenBSD: ar.h,v 1.3 2003/06/02 19:34:12 millert Exp $ */
|
||||||
|
/* $NetBSD: ar.h,v 1.4 1994/10/26 00:55:43 cgd Exp $ */
|
||||||
|
|
||||||
|
/*-
|
||||||
|
* Copyright (c) 1991, 1993
|
||||||
|
* The Regents of the University of California. All rights reserved.
|
||||||
|
* (c) UNIX System Laboratories, Inc.
|
||||||
|
* All or some portions of this file are derived from material licensed
|
||||||
|
* to the University of California by American Telephone and Telegraph
|
||||||
|
* Co. or Unix System Laboratories, Inc. and are reproduced herein with
|
||||||
|
* the permission of UNIX System Laboratories, Inc.
|
||||||
|
*
|
||||||
|
* This code is derived from software contributed to Berkeley by
|
||||||
|
* Hugh Smith at The University of Guelph.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. Neither the name of the University nor the names of its contributors
|
||||||
|
* may be used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
* SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* @(#)ar.h 8.2 (Berkeley) 1/21/94
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _AR_H_
|
||||||
|
#define _AR_H_
|
||||||
|
|
||||||
|
/* Pre-4BSD archives had these magic numbers in them. */
|
||||||
|
#define OARMAG1 0177555
|
||||||
|
#define OARMAG2 0177545
|
||||||
|
|
||||||
|
#define ARMAG "!<arch>\n" /* ar "magic number" */
|
||||||
|
#define SARMAG 8 /* strlen(ARMAG); */
|
||||||
|
|
||||||
|
#define AR_EFMT1 "#1/" /* extended format #1 */
|
||||||
|
|
||||||
|
struct ar_hdr {
|
||||||
|
char ar_name[16]; /* name */
|
||||||
|
char ar_date[12]; /* modification time */
|
||||||
|
char ar_uid[6]; /* user id */
|
||||||
|
char ar_gid[6]; /* group id */
|
||||||
|
char ar_mode[8]; /* octal file permissions */
|
||||||
|
char ar_size[10]; /* size in bytes */
|
||||||
|
#define ARFMAG "`\n"
|
||||||
|
char ar_fmag[2]; /* consistency check */
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* !_AR_H_ */
|
46
libc/include/search.h
Normal file
46
libc/include/search.h
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
/*-
|
||||||
|
* Written by J.T. Conklin <jtc@netbsd.org>
|
||||||
|
* Public domain.
|
||||||
|
*
|
||||||
|
* $NetBSD: search.h,v 1.12 1999/02/22 10:34:28 christos Exp $
|
||||||
|
* $FreeBSD: release/9.0.0/include/search.h 105250 2002-10-16 14:29:23Z robert $
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SEARCH_H_
|
||||||
|
#define _SEARCH_H_
|
||||||
|
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#include <sys/_types.h>
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
#ifndef _SIZE_T_DECLARED
|
||||||
|
typedef __size_t size_t;
|
||||||
|
#define _SIZE_T_DECLARED
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
preorder,
|
||||||
|
postorder,
|
||||||
|
endorder,
|
||||||
|
leaf
|
||||||
|
} VISIT;
|
||||||
|
|
||||||
|
#ifdef _SEARCH_PRIVATE
|
||||||
|
typedef struct node {
|
||||||
|
char *key;
|
||||||
|
struct node *llink, *rlink;
|
||||||
|
} node_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
__BEGIN_DECLS
|
||||||
|
void *tdelete(const void * __restrict, void ** __restrict,
|
||||||
|
int (*)(const void *, const void *));
|
||||||
|
void *tfind(const void *, void * const *,
|
||||||
|
int (*)(const void *, const void *));
|
||||||
|
void *tsearch(const void *, void **, int (*)(const void *, const void *));
|
||||||
|
void twalk(const void *, void (*)(const void *, VISIT, int));
|
||||||
|
void tdestroy(void *, void (*)(void *));
|
||||||
|
__END_DECLS
|
||||||
|
|
||||||
|
#endif /* !_SEARCH_H_ */
|
Loading…
x
Reference in New Issue
Block a user