projects
/
simpleserver-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Minor changes.
[simpleserver-moved-to-github.git]
/
SimpleServer.xs
diff --git
a/SimpleServer.xs
b/SimpleServer.xs
index
cc1d461
..
77c3fc6
100644
(file)
--- a/
SimpleServer.xs
+++ b/
SimpleServer.xs
@@
-25,7
+25,13
@@
*/
/*$Log: SimpleServer.xs,v $
*/
/*$Log: SimpleServer.xs,v $
-/*Revision 1.10 2001-08-29 11:48:36 sondberg
+/*Revision 1.12 2001-08-30 14:02:10 sondberg
+/*Small changes.
+/*
+/*Revision 1.11 2001/08/30 13:15:11 sondberg
+/*Corrected a memory leak, one more to go.
+/*
+/*Revision 1.10 2001/08/29 11:48:36 sondberg
/*Added routines
/*
/* Net::Z3950::SimpleServer::ScanSuccess
/*Added routines
/*
/* Net::Z3950::SimpleServer::ScanSuccess
@@
-797,7
+803,6
@@
int bend_scan(void *handle, bend_scan_rr *rr)
int i;
char **basenames;
SV **temp;
int i;
char **basenames;
SV **temp;
- SV *list_ref = sv_newmortal();
SV *err_code = sv_newmortal();
SV *err_str = sv_newmortal();
SV *point = sv_newmortal();
SV *err_code = sv_newmortal();
SV *err_str = sv_newmortal();
SV *point = sv_newmortal();
@@
-806,6
+811,9
@@
int bend_scan(void *handle, bend_scan_rr *rr)
char *ptr;
char *ODR_errstr;
STRLEN len;
char *ptr;
char *ODR_errstr;
STRLEN len;
+ int term_len;
+ SV *term_tmp;
+ SV *entries_ref;
Zfront_handle *zhandle = (Zfront_handle *)handle;
Zfront_handle *zhandle = (Zfront_handle *)handle;
@@
-816,7
+824,8
@@
int bend_scan(void *handle, bend_scan_rr *rr)
list = newAV();
if (rr->term->term->which == Z_Term_general)
{
list = newAV();
if (rr->term->term->which == Z_Term_general)
{
- hv_store(href, "TERM", 4, newSVpv(rr->term->term->u.general->buf, 0), 0);
+ term_len = rr->term->term->u.general->len;
+ hv_store(href, "TERM", 4, newSVpv(rr->term->term->u.general->buf, term_len), 0);
} else {
rr->errcode = 229; /* Unsupported term type */
return 0;
} else {
rr->errcode = 229; /* Unsupported term type */
return 0;
@@
-863,8
+872,7
@@
int bend_scan(void *handle, bend_scan_rr *rr)
number = newSVsv(*temp);
temp = hv_fetch(href, "ENTRIES", 7, 1);
number = newSVsv(*temp);
temp = hv_fetch(href, "ENTRIES", 7, 1);
- list_ref = newSVsv(*temp);
- entries = (AV *)SvRV(list_ref);
+ entries_ref = newSVsv(*temp);
PUTBACK;
FREETMPS;
PUTBACK;
FREETMPS;
@@
-879,6
+887,7
@@
int bend_scan(void *handle, bend_scan_rr *rr)
rr->status = SvIV(status);
scan_list = (struct scan_entry *) odr_malloc (rr->stream, rr->num_entries * sizeof(*scan_list));
buffer = scan_list;
rr->status = SvIV(status);
scan_list = (struct scan_entry *) odr_malloc (rr->stream, rr->num_entries * sizeof(*scan_list));
buffer = scan_list;
+ entries = (AV *)SvRV(entries_ref);
for (i = 0; i < rr->num_entries; i++)
{
scan_item = (HV *)SvRV(sv_2mortal(av_shift(entries)));
for (i = 0; i < rr->num_entries; i++)
{
scan_item = (HV *)SvRV(sv_2mortal(av_shift(entries)));
@@
-894,16
+903,19
@@
int bend_scan(void *handle, bend_scan_rr *rr)
rr->entries = scan_list;
zhandle->handle = point;
handle = zhandle;
rr->entries = scan_list;
zhandle->handle = point;
handle = zhandle;
- /*sv_free(list_ref);*/
sv_free(err_code);
sv_free(err_str);
sv_free(status);
sv_free(number);
sv_free(err_code);
sv_free(err_str);
sv_free(status);
sv_free(number);
- /*sv_free(point);*/
hv_undef(href);
hv_undef(href);
+ sv_free((SV *)href);
av_undef(aref);
av_undef(aref);
+ sv_free((SV *)aref);
av_undef(list);
av_undef(list);
+ sv_free((SV *)list);
av_undef(entries);
av_undef(entries);
+ /*sv_free((SV *)entries);*/
+ sv_free(entries_ref);
return 0;
}
return 0;
}