diff options
| author | Wilmer van der Gaast <wilmer@gaast.net> | 2010-08-31 22:06:14 +0200 | 
|---|---|---|
| committer | Wilmer van der Gaast <wilmer@gaast.net> | 2010-08-31 22:06:14 +0200 | 
| commit | f5c0d8e4dd3ce01945a6334a5d87c89a9f43b16b (patch) | |
| tree | e741ed193ad1921c695a8aec4c4ea57fe82e7fd7 /protocols/yahoo | |
| parent | 83586911a0aa768ed196051950ebd8ffce37d467 (diff) | |
| parent | 31dbb90a2d32d6988706ae4b5c2292cd43d89595 (diff) | |
Merge mainline stuff.
Diffstat (limited to 'protocols/yahoo')
| -rw-r--r-- | protocols/yahoo/Makefile | 3 | ||||
| -rw-r--r-- | protocols/yahoo/libyahoo2.c | 19 | 
2 files changed, 22 insertions, 0 deletions
| diff --git a/protocols/yahoo/Makefile b/protocols/yahoo/Makefile index a8021ffb..7908b773 100644 --- a/protocols/yahoo/Makefile +++ b/protocols/yahoo/Makefile @@ -30,6 +30,7 @@ clean:  	rm -f *.o core  distclean: clean +	rm -rf .depend  ### MAIN PROGRAM @@ -42,3 +43,5 @@ $(objects): %.o: $(SRCDIR)%.c  yahoo_mod.o: $(objects)  	@echo '*' Linking yahoo_mod.o  	@$(LD) $(LFLAGS) $(objects) -o yahoo_mod.o + +-include .depend/*.d diff --git a/protocols/yahoo/libyahoo2.c b/protocols/yahoo/libyahoo2.c index b062e7f9..07689809 100644 --- a/protocols/yahoo/libyahoo2.c +++ b/protocols/yahoo/libyahoo2.c @@ -2168,6 +2168,18 @@ static void yahoo_process_buddyadd(struct yahoo_input_data *yid,  	yd->buddies = y_list_append(yd->buddies, bud); +#if 0 +	/* BitlBee: This seems to be wrong in my experience. I think: +	   status = 0: Success +	   status = 2: Already on list +	   status = 3: Doesn't exist +	   status = 42: Invalid handle (possibly banned/reserved, I get it for +	                handles like joe or jjjjjj) +	   Haven't seen others yet. But whenever the add is successful, there +	   will be a separate "went online" packet when the auth. request is +	   accepted. Couldn't find any test account that doesn't require auth. +	   unfortunately (if there is even such a thing?) */ +	     	/* A non-zero status (i've seen 2) seems to mean the buddy is already   	 * added and is online */  	if (status) { @@ -2176,6 +2188,13 @@ static void yahoo_process_buddyadd(struct yahoo_input_data *yid,  		YAHOO_CALLBACK(ext_yahoo_status_changed) (yd->client_id, who,  			YAHOO_STATUS_AVAILABLE, NULL, 0, 0, 0);  	} +#endif +	/* BitlBee: Need ACK of added buddy, if it was successful. */ +	if (status == 0) { +		YList *tmp = y_list_append(NULL, bud); +		YAHOO_CALLBACK(ext_yahoo_got_buddies) (yd->client_id, tmp); +		y_list_free(tmp); +	}  }  static void yahoo_process_buddydel(struct yahoo_input_data *yid, | 
