aboutsummaryrefslogtreecommitdiffstats
path: root/camel/providers/nntp/camel-nntp-utils.c
diff options
context:
space:
mode:
authorChris Toshok <toshok@helixcode.com>2000-09-06 06:32:49 +0800
committerChris Toshok <toshok@src.gnome.org>2000-09-06 06:32:49 +0800
commiteafd7dbe013871f1090e0179e99ca309626c2076 (patch)
tree0198b4af5bd69ee48a278d8acfed8cf52326dab9 /camel/providers/nntp/camel-nntp-utils.c
parent54a6d12d79b8d2e761866594e4f18dcd751125be (diff)
downloadgsoc2013-evolution-eafd7dbe013871f1090e0179e99ca309626c2076.tar.gz
gsoc2013-evolution-eafd7dbe013871f1090e0179e99ca309626c2076.tar.zst
gsoc2013-evolution-eafd7dbe013871f1090e0179e99ca309626c2076.zip
care about response code. (get_HEAD_headers): same.
2000-09-05 Chris Toshok <toshok@helixcode.com> * providers/nntp/camel-nntp-utils.c (get_OVER_headers): care about response code. (get_HEAD_headers): same. (camel_nntp_get_headers): same. * providers/nntp/camel-nntp-store.h: get rid of CAMEL_NNTP_OK/ERR/FAIL. * providers/nntp/camel-nntp-store.c (camel_nntp_store_get_extensions): take CamelException arg and pass along to camel_nntp_command. (camel_nntp_store_get_overview_fmt): same. (nntp_store_connect): convert to using constants in camel-nntp-resp-codes.h (nntp_store_get_folder): make use of camel_nntp_folder_new. (camel_nntp_command_send_recv): new function to deal with auth challenge. (camel_nntp_command): split out most of this function into camel_nntp_command_send_recv. also, return the actual response code instead of CAMEL_NNTP_OK/ERR/FAIL. * providers/nntp/camel-nntp-resp-codes.h: new file. * providers/nntp/camel-nntp-folder.h: prototype for camel_nntp_folder_new. * providers/nntp/camel-nntp-folder.c (camel_nntp_folder_new): new convenience function. (nntp_folder_get_message): care more about the actual response code. * providers/nntp/Makefile.am (libcamelnntp_la_SOURCES): add camel-nntp-auth.c. (libcamelnntpinclude_HEADERS): add camel-nntp-auth.h. * providers/nntp/camel-nntp-auth.h: new file. * providers/nntp/camel-nntp-auth.c: new file. svn path=/trunk/; revision=5212
Diffstat (limited to 'camel/providers/nntp/camel-nntp-utils.c')
-rw-r--r--camel/providers/nntp/camel-nntp-utils.c23
1 files changed, 16 insertions, 7 deletions
diff --git a/camel/providers/nntp/camel-nntp-utils.c b/camel/providers/nntp/camel-nntp-utils.c
index 509fe452cc..c741146f26 100644
--- a/camel/providers/nntp/camel-nntp-utils.c
+++ b/camel/providers/nntp/camel-nntp-utils.c
@@ -23,10 +23,12 @@
*/
#include "camel-folder-summary.h"
+#include "camel-nntp-resp-codes.h"
#include "camel-nntp-folder.h"
#include "camel-nntp-store.h"
#include "camel-nntp-utils.h"
#include "camel-stream-mem.h"
+#include "camel-exception.h"
#include <stdlib.h>
#include <string.h>
@@ -38,12 +40,12 @@ get_OVER_headers(CamelNNTPStore *nntp_store, CamelFolder *folder,
int status;
CamelNNTPFolder *nntp_folder = CAMEL_NNTP_FOLDER (folder);
- status = camel_nntp_command (nntp_store, NULL,
+ status = camel_nntp_command (nntp_store, ex, NULL,
"XOVER %d-%d",
first_message,
last_message);
- if (status == CAMEL_NNTP_OK) {
+ if (status == NNTP_DATA_FOLLOWS) {
gboolean done = FALSE;
while (!done) {
@@ -106,6 +108,10 @@ get_OVER_headers(CamelNNTPStore *nntp_store, CamelFolder *folder,
g_free (line);
}
}
+ else {
+ /* XXX */
+ g_warning ("weird nntp response for XOVER: %d\n", status);
+ }
}
#if 0
@@ -117,10 +123,10 @@ get_HEAD_headers(CamelNNTPStore *nntp_store, CamelFolder *folder,
int status;
for (i = first_message; i < last_message; i ++) {
- status = camel_nntp_command (nntp_store, NULL,
+ status = camel_nntp_command (nntp_store, ex, NULL,
"HEAD %d", i);
- if (status == CAMEL_NNTP_OK) {
+ if (status == NNTP_HEAD_FOLLOWS) {
gboolean done = FALSE;
char *buf;
int buf_len;
@@ -215,15 +221,18 @@ camel_nntp_get_headers (CamelStore *store,
int first_message, nb_message, last_message;
int status;
- status = camel_nntp_command (nntp_store, &ret,
+ status = camel_nntp_command (nntp_store, ex, &ret,
"GROUP %s", CAMEL_NNTP_FOLDER (folder)->group_name);
sscanf (ret, "%d %d %d", &nb_message, &first_message, &last_message);
g_free (ret);
- if (status != CAMEL_NNTP_OK) {
+ if (status == NNTP_NO_SUCH_GROUP) {
/* XXX throw invalid group exception */
- printf ("invalid group\n");
+ camel_exception_setv (ex,
+ CAMEL_EXCEPTION_FOLDER_INVALID,
+ "group %s not found on server",
+ CAMEL_NNTP_FOLDER (folder)->group_name);
return;
}