diff --git a/src/junos.h b/src/junos.h
index 5f31e917de5140306ad4fbaa92498b4736171318..a122330022b14feeec748c16cf200aa17c7a5377 100644 (file)
--- a/src/junos.h
+++ b/src/junos.h
typedef struct junos junos_t;
+/* method invocation */
+
+enum {
+ JUNOS_NO_ARGS = 0,
+ JUNOS_ARG_TOGGLE,
+ JUNOS_ARG_TOGGLE_NO,
+ JUNOS_ARG_STRING,
+ JUNOS_ARG_INTEGER,
+ JUNOS_ARG_DOUBLE,
+ JUNOS_ARG_DOM,
+ JUNOS_ATTR_STRING,
+ JUNOS_ATTR_INTEGER,
+ JUNOS_ATTR_DOUBLE,
+};
+
+/* string buffer */
+
+typedef struct junos_strbuf junos_strbuf_t;
+
+/* netrc */
+
typedef struct {
char *machine;
char *login;
junos_connect(junos_t *junos);
xmlDocPtr
-junos_simple_method(junos_t *junos, const char *name);
+junos_invoke_method(junos_t *junos, const char *name, ...);
+
+#define junos_simple_method(junos, name) \
+ junos_invoke_method((junos), (name), JUNOS_NO_ARGS)
int
junos_disconnect(junos_t *junos);
void
junos_free(junos_t *junos);
+/*
+ * string buffer
+ */
+
+junos_strbuf_t *
+junos_strbuf_new(size_t size);
+
+void
+junos_strbuf_free(junos_strbuf_t *strbuf);
+
+ssize_t
+junos_strbuf_sprintf(junos_strbuf_t *strbuf, const char *fmt, ...);
+
+ssize_t
+junos_strbuf_vsprintf(junos_strbuf_t *strbuf, const char *fmt, va_list ap);
+
+char *
+junos_strbuf_string(junos_strbuf_t *strbuf);
+
+size_t
+junos_strbuf_len(junos_strbuf_t *strbuf);
+
/*
* netrc
*/