summaryrefslogtreecommitdiffstats
path: root/src/misc.c
diff options
context:
space:
mode:
authorAris Adamantiadis <aris@0xbadc0de.be>2011-09-02 13:46:10 +0300
committerAndreas Schneider <asn@cryptomilk.org>2011-09-02 22:59:44 +0200
commit64b125700eb472787eea6dba9d2ca29d8bc360d7 (patch)
tree38bda65935a1e126b3d48b7b37e08c07d540aa9a /src/misc.c
parent6f650a61ca67c8f799a3c3d2f0c17bdd42136e5f (diff)
downloadlibssh-64b125700eb472787eea6dba9d2ca29d8bc360d7.tar.gz
libssh-64b125700eb472787eea6dba9d2ca29d8bc360d7.tar.xz
libssh-64b125700eb472787eea6dba9d2ca29d8bc360d7.zip
channels: replaced bugged lists with ssh_list
(cherry picked from commit 6d8bb956c5caa48c2aba6713f067224650c3c1e1) Conflicts: src/channels.c src/session.c
Diffstat (limited to 'src/misc.c')
-rw-r--r--src/misc.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/src/misc.c b/src/misc.c
index 361fc2d3..678961d8 100644
--- a/src/misc.c
+++ b/src/misc.c
@@ -377,6 +377,8 @@ struct ssh_list *ssh_list_new(){
void ssh_list_free(struct ssh_list *list){
struct ssh_iterator *ptr,*next;
+ if(!list)
+ return;
ptr=list->root;
while(ptr){
next=ptr->next;
@@ -387,9 +389,19 @@ void ssh_list_free(struct ssh_list *list){
}
struct ssh_iterator *ssh_list_get_iterator(const struct ssh_list *list){
+ if(!list)
+ return NULL;
return list->root;
}
+struct ssh_iterator *ssh_list_find(const struct ssh_list *list, void *value){
+ struct ssh_iterator *it;
+ for(it = ssh_list_get_iterator(list); it != NULL ;it=it->next)
+ if(it->data==value)
+ return it;
+ return NULL;
+}
+
static struct ssh_iterator *ssh_iterator_new(const void *data){
struct ssh_iterator *iterator=malloc(sizeof(struct ssh_iterator));
if(!iterator)