+ (*bv)->bv_len = siz + len;
+ (*bv)->bv_val = ch_malloc(siz+len);
+ base = (*bv)->bv_val;
+ ptr = base + siz;
+ f = (Entry *)base;
+ data = (char *)(f+1);
+ f->e_id = e->e_id;
+ f->e_dn = (char *)(ptr-base);
+ memcpy(ptr, e->e_dn, dnlen);
+ ptr += dnlen;
+ *ptr++ = '\0';
+ f->e_ndn = (char *)(ptr-base);
+ memcpy(ptr, e->e_ndn, ndnlen);
+ ptr += ndnlen;
+ *ptr++ = '\0';
+ f->e_attrs = e->e_attrs ? (Attribute *)sizeof(Entry) : NULL;
+ f->e_private = NULL;
+ for (a=e->e_attrs; a; a=a->a_next) {
+ b = (Attribute *)data;
+ data = (char *)(b+1);
+ b->a_desc = (AttributeDescription *)(ptr-base);
+ memcpy(ptr, a->a_desc->ad_cname.bv_val,
+ a->a_desc->ad_cname.bv_len);
+ ptr += a->a_desc->ad_cname.bv_len;
+ *ptr++ = '\0';
+ if (a->a_vals) {
+ bvl = (struct berval **)data;
+ b->a_vals = (struct berval **)(data-base);
+ for (i=0; a->a_vals[i]; i++);
+ data = (char *)(bvl+i+1);
+ bz = (struct berval *)data;
+ for (j=0; j<i; j++) {
+ bz->bv_len = a->a_vals[j]->bv_len;
+ if (a->a_vals[j]->bv_val) {
+ bz->bv_val = (char *)(ptr-base);
+ memcpy(ptr, a->a_vals[j]->bv_val, bz->bv_len);
+ } else {
+ bz->bv_val = NULL;
+ }
+ ptr += bz->bv_len;
+ *ptr++ = '\0';
+ bvl[j] = (struct berval *)(data-base);
+ bz++;
+ data = (char *)bz;
+ }
+ bvl[j] = NULL;
+ } else {
+ b->a_vals = NULL;
+ }