File: ListBucket.c

package info (click to toggle)
nas 1.8-4
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 8,452 kB
  • ctags: 23,094
  • sloc: ansic: 54,190; makefile: 23,934; sh: 7,406; perl: 2,208; yacc: 244; cpp: 216; lex: 63
file content (122 lines) | stat: -rw-r--r-- 3,552 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/**
 * Copyright 1993 Network Computing Devices, Inc.
 *
 * Permission to use, copy, modify, distribute, and sell this software and its
 * documentation for any purpose is hereby granted without fee, provided that
 * the above copyright notice appear in all copies and that both that
 * copyright notice and this permission notice appear in supporting
 * documentation, and that the name Network Computing Devices, Inc. not be
 * used in advertising or publicity pertaining to distribution of this
 * software without specific, written prior permission.
 *
 * THIS SOFTWARE IS PROVIDED 'AS-IS'.  NETWORK COMPUTING DEVICES, INC.,
 * DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING WITHOUT
 * LIMITATION ALL IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
 * PARTICULAR PURPOSE, OR NONINFRINGEMENT.  IN NO EVENT SHALL NETWORK
 * COMPUTING DEVICES, INC., BE LIABLE FOR ANY DAMAGES WHATSOEVER, INCLUDING
 * SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES, INCLUDING LOSS OF USE, DATA,
 * OR PROFITS, EVEN IF ADVISED OF THE POSSIBILITY THEREOF, AND REGARDLESS OF
 * WHETHER IN AN ACTION IN CONTRACT, TORT OR NEGLIGENCE, ARISING OUT OF OR IN
 * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 *
 * $NCDId: @(#)ListBucket.c,v 1.8 1994/03/09 19:25:59 greg Exp $
 */

#include "Alibint.h"

AuBucketAttributes *
AuListBuckets(
              AuServer       *aud,
              AuMask          mask,
              AuBucketAttributes *attr,
              int            *num_buckets,
              AuStatus       *ret_status
              )
{
    register auReq *req;
    auListBucketsReply rep;
    auBucketAttributes a;
    AuBucketAttributes *list = NULL,
                   *l,
                    tmp;
    int             stringLen,
                    i;
    AuMask          savemask;

    if (attr)
	savemask = AuBucketValueMask(attr);
    else
	attr = &tmp;

    AuBucketValueMask(attr) = mask;

    if (ret_status)
	*ret_status = AuSuccess;

    _AuLockServer();
    _AuGetEmptyReq(ListBuckets, req, aud);

    stringLen = (AuBucketValueMask(attr) & AuCompCommonDescriptionMask) ?
	AuBucketDescription(attr)->len : 0;

    req->length += (SIZEOF(auBucketAttributes) + PAD4(stringLen)) >> 2;

    _xferBucketAttributes(attr, a);

    _AuData(aud, (char *) &a, SIZEOF(auBucketAttributes));

    if (stringLen)
	_AuData(aud, AuBucketDescription(attr)->data, stringLen);

    AuBucketValueMask(attr) = savemask;

    (void) _AuReply(aud, (auReply *) & rep, 0, auFalse, ret_status);

    *num_buckets = rep.num_buckets;

    if (rep.num_buckets)
    {
	if (!(list = l = (AuBucketAttributes *)
	      Aucalloc(1, sizeof(AuBucketAttributes) * rep.num_buckets)))
	{
	    _AuUnlockServer();
	    _AuSyncHandle(aud);
	    return NULL;
	}

	while (rep.num_buckets--)
	{
	    _AuReadPad(aud, (char *) &a, SIZEOF(auBucketAttributes));

	    _xferBucketAttributes(&a, *l);

	    if (AuBucketValueMask(l) & AuCompCommonDescriptionMask)
	    {
		if (!(AuBucketDescription(l)->data = (char *)
		      Aumalloc(AuBucketDescription(l)->len + 1)))
		{
		    AuFreeBucketAttributes(aud, *num_buckets, list);
		    _AuUnlockServer();
		    _AuSyncHandle(aud);
		    return NULL;
		}

		if (AuBucketDescription(l)->len)
		    _AuReadPad(aud, AuBucketDescription(l)->data,
			       AuBucketDescription(l)->len);

		AuBucketDescription(l)->data[AuBucketDescription(l)->len] = 0;
	    }

	    l++;
	}
    }

    _AuUnlockServer();
    _AuSyncHandle(aud);

    for (i = 0; i < *num_buckets; i++)
	_AuAddToBucketCache(aud, &list[i]);

    return list;
}