#include <string.h>
#include "modest-proto.h"
+static const gchar* transport_protos[] = {
+ MODEST_PROTO_SENDMAIL,
+ MODEST_PROTO_SMTP,
+ NULL
+};
+
+static const gchar* store_protos[] = {
+ MODEST_PROTO_NONE,
+ MODEST_PROTO_POP,
+ MODEST_PROTO_IMAP,
+ MODEST_PROTO_MAILDIR,
+ MODEST_PROTO_MBOX,
+ NULL
+};
gboolean
-modest_proto_is_valid (const gchar *proto)
+modest_proto_is_valid (const gchar *proto, gboolean store_proto)
{
int i;
- static const gchar* protos[] = {
- MODEST_PROTO_SENDMAIL,
- MODEST_PROTO_SMTP,
- MODEST_PROTO_POP,
- MODEST_PROTO_IMAP,
- NULL
- };
- if (!proto)
- return FALSE;
+ g_return_val_if_fail (proto, FALSE);
- for (i = 0; protos[i]; ++i) {
+ const gchar** protos = (const gchar**)
+ store_proto ? store_protos : transport_protos;
+
+ for (i = 0; protos[i]; ++i)
if (strcmp(protos[i], proto) == 0)
return TRUE;
- }
return FALSE;
}
ModestProtoType
modest_proto_type (const gchar *proto)
{
- if (!modest_proto_is_valid(proto)) {
- g_warning ("invalid protocol %s", proto);
- return -1;
- }
-
- /* trick */
+ g_return_val_if_fail (proto, -1);
+ g_return_val_if_fail (modest_proto_is_valid (proto, TRUE) ||
+ modest_proto_is_valid (proto, FALSE),
+ -1);
+ /* trick */
if (proto[0] == 's')
return MODEST_PROTO_TYPE_TRANSPORT;
else
return MODEST_PROTO_TYPE_STORE;
}
+
+
+
+const gchar**
+modest_proto_store_protos (void)
+{
+ return (const gchar **) store_protos;
+}
+
+
+const gchar**
+modest_proto_transport_protos (void)
+{
+ return (const gchar**) transport_protos;
+}
#include <glib.h>
+
#define MODEST_PROTO_SENDMAIL "sendmail"
#define MODEST_PROTO_SMTP "smtp"
+
+#define MODEST_PROTO_NONE "none"
#define MODEST_PROTO_POP "pop"
#define MODEST_PROTO_IMAP "imap"
+#define MODEST_PROTO_MAILDIR "maildir"
+#define MODEST_PROTO_MBOX "mbox"
enum {
MODEST_PROTO_TYPE_ANY = 0,
/**
* modest_proto_is_valid:
* @proto: a string describing the protocol
- *
- * checks if proto is a valid protocol
+ * @store_proto: is this a store proto?
+ *
+ * checks if proto is a valid protocol of the given type
*
* Returns: TRUE if proto is valid, FALSE otherwise
*/
-gboolean modest_proto_is_valid (const gchar *proto);
+gboolean modest_proto_is_valid (const gchar *proto, gboolean store_proto);
/**
* modest_proto_type:
*/
ModestProtoType modest_proto_type (const gchar *proto);
+/**
+ * modest_store_protos:
+ *
+ * return a list of all available store protos
+ *
+ * Returns: a newly allocated, NULL-terminated list of of store protocols
+ */
+const gchar** modest_proto_store_protos (void);
+
+
+/**
+ * modest_transport_protos:
+ *
+ * return a list of all available store protos
+ *
+ * Returns: a newly allocated, NULL-terminated list of of store protocols
+ */
+const gchar** modest_proto_transport_protos (void);
+
+
+
#endif /*__MODEST_SERVER_PROTO_H__*/