--- Makefile | 22 ++++++------- xmpp:time.c | 106 ------------------------------------------------------------ xmpp_time.c | 106 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 117 insertions(+), 117 deletions(-) delete mode 100644 xmpp:time.c create mode 100644 xmpp_time.c diff --git a/Makefile b/Makefile index ac3a838..9907ad9 100644 --- a/Makefile +++ b/Makefile _AT_@ -12,45 +12,45 @@ LIBS_MXML := `pkg-config --libs mxml` .PHONY: all tests clean debug update install .SUFFIXES: .o .c -BINS=sj messaged presenced iqd roster presence xmpp:time +BINS=sj messaged presenced iqd roster presence xmpp_time all: $(BINS) # core deamon sj: sj.o sasl/sasl.o sasl/base64.o bxml/bxml.o _AT_echo "Build: $@" - _AT_$(CC) -o $@ $(LDFLAGS) $(LIBS_MXML) $(LIBS_BSD) -lm \ - sj.o sasl/sasl.o sasl/base64.o bxml/bxml.o + _AT_$(CC) -o $@ $(LDFLAGS) sj.o sasl/sasl.o sasl/base64.o bxml/bxml.o\ + $(LIBS_MXML) $(LIBS_BSD) -lm messaged: messaged.o bxml/bxml.o _AT_echo "Build: $@" - _AT_$(CC) -o $@ $(LDFLAGS) $(LIBS_MXML) $(LIBS_BSD) messaged.o bxml/bxml.o + _AT_$(CC) -o $@ $(LDFLAGS) messaged.o bxml/bxml.o $(LIBS_MXML) $(LIBS_BSD) presenced: presenced.o bxml/bxml.o _AT_echo "Build: $@" - _AT_$(CC) -o $@ $(LDFLAGS) $(LIBS_MXML) $(LIBS_BSD) presenced.o bxml/bxml.o + _AT_$(CC) -o $@ $(LDFLAGS) presenced.o bxml/bxml.o $(LIBS_MXML) $(LIBS_BSD) iqd: iqd.o bxml/bxml.o _AT_echo "Build: $@" - _AT_$(CC) -o $@ $(LDFLAGS) $(LIBS_MXML) iqd.o bxml/bxml.o + _AT_$(CC) -o $@ $(LDFLAGS) iqd.o bxml/bxml.o $(LIBS_MXML) # commandline tools roster: roster.o _AT_echo "Build: $@" - _AT_$(CC) -o $@ $(LDFLAGS) $(LIBS_MXML) roster.o + _AT_$(CC) -o $@ $(LDFLAGS) roster.o $(LIBS_MXML) presence: presence.o _AT_echo "Build: $@" _AT_$(CC) -o $@ $(LDFLAGS) presence.o # extensions -xmpp:time: xmpp:time.o +xmpp_time: xmpp_time.o _AT_echo "Build: $@" - _AT_$(CC) -o $@ $(LDFLAGS) $(LIBS_MXML) xmpp:time.o + _AT_$(CC) -o $@ $(LDFLAGS) xmpp_time.o $(LIBS_MXML) -xmpp:time.o: xmpp:time.c +xmpp_time.o: xmpp_time.c _AT_echo "Build: $@" - _AT_$(CC) $(CFLAGS) $(CFLAGS_MXML) -c -o $@ xmpp:time.c + _AT_$(CC) $(CFLAGS) $(CFLAGS_MXML) -c -o $@ xmpp_time.c sj.o: sj.c bxml/bxml.h sasl/sasl.h _AT_echo "Build: $@" diff --git a/xmpp:time.c b/xmpp:time.c deleted file mode 100644 index 2e41bdc..0000000 --- a/xmpp:time.c +++ /dev/null _AT_@ -1,106 +0,0 @@ -#include <err.h> -#include <limits.h> -#include <stdio.h> -#include <stdlib.h> -#include <time.h> -#include <unistd.h> - -#include <mxml.h> - -static void -send_time(FILE *fh, const char *to, const char *id) -{ - char tzo[BUFSIZ]; - char utc[BUFSIZ]; - time_t t = time(NULL); - - /* +HHMM */ - strftime(tzo, sizeof tzo, "%z", localtime(&t)); - - /* convert "+HHMM" to "+HH:MM" */ - tzo[6] = tzo[5]; - tzo[5] = tzo[4]; - tzo[4] = tzo[3]; - tzo[3] = ':'; - - /* 2006-12-19T17:58:35Z */ - strftime(utc, sizeof utc, "%FT%TZ", gmtime(&t)); - - fprintf(fh, - "<iq type='result' to='%s' id='%s'>" - "<time xmlns='urn:xmpp:time'>" - "<tzo>%s</tzo>" - "<utc>%s</utc>" - "</time>" - "</iq>", to, id, tzo, utc); -} - -static void -usage(void) -{ - fprintf(stderr, "xmpp:time [-d dir]\n"); - exit(EXIT_FAILURE); -} - -int -main(int argc, char *argv[]) -{ - /* HACK: we need this, cause mxml can't parse pure tags */ - mxml_node_t *tree = NULL; - mxml_node_t *node = NULL; - const char *base = "<?xml ?>"; - const char *id = NULL; - const char *from = NULL; - const char *type = NULL; - char *dir = "."; - char out_file[PATH_MAX]; - FILE *fh; - int ch; - - while ((ch = getopt(argc, argv, "d:h")) != -1) { - switch (ch) { - case 'd': - if ((dir = strdup(optarg)) == NULL) - err(EXIT_FAILURE, "strdup"); - break; - case 'h': - default: - usage(); - /* NOTREACHED */ - } - } - argc -= optind; - argv += optind; - - if ((tree = mxmlLoadString(NULL, base, MXML_NO_CALLBACK)) == NULL) - err(EXIT_FAILURE, "unable to read xml tree"); - mxmlLoadFile(tree, stdin, MXML_NO_CALLBACK); - - /* check iq tag */ - if ((node = tree->child) == NULL) - errx(EXIT_FAILURE, "unable to parse xml data"); - - if ((id = mxmlElementGetAttr(node, "id")) == NULL) - errx(EXIT_FAILURE, "iq stanze has no \"id\" attribute"); - - if ((from = mxmlElementGetAttr(node, "from")) == NULL) - errx(EXIT_FAILURE, "iq stanze has no \"from\" attribute"); - - if ((type = mxmlElementGetAttr(node, "type")) == NULL) - errx(EXIT_FAILURE, "iq stanze has no \"type\" attribute"); - - if (strcmp(type, "get") != 0) - errx(EXIT_FAILURE, "unable to handle iq type: %s", type); - - /* open file for output */ - snprintf(out_file, sizeof out_file, "%s/in", dir); - if ((fh = fopen(out_file, "w")) == NULL) - err(EXIT_FAILURE, "fopen"); - - send_time(fh, from, id); - - if (fclose(fh) == EOF) - err(EXIT_FAILURE, "fclose"); - - return EXIT_SUCCESS; -} diff --git a/xmpp_time.c b/xmpp_time.c new file mode 100644 index 0000000..2e41bdc --- /dev/null +++ b/xmpp_time.c _AT_@ -0,0 +1,106 @@ +#include <err.h> +#include <limits.h> +#include <stdio.h> +#include <stdlib.h> +#include <time.h> +#include <unistd.h> + +#include <mxml.h> + +static void +send_time(FILE *fh, const char *to, const char *id) +{ + char tzo[BUFSIZ]; + char utc[BUFSIZ]; + time_t t = time(NULL); + + /* +HHMM */ + strftime(tzo, sizeof tzo, "%z", localtime(&t)); + + /* convert "+HHMM" to "+HH:MM" */ + tzo[6] = tzo[5]; + tzo[5] = tzo[4]; + tzo[4] = tzo[3]; + tzo[3] = ':'; + + /* 2006-12-19T17:58:35Z */ + strftime(utc, sizeof utc, "%FT%TZ", gmtime(&t)); + + fprintf(fh, + "<iq type='result' to='%s' id='%s'>" + "<time xmlns='urn:xmpp:time'>" + "<tzo>%s</tzo>" + "<utc>%s</utc>" + "</time>" + "</iq>", to, id, tzo, utc); +} + +static void +usage(void) +{ + fprintf(stderr, "xmpp:time [-d dir]\n"); + exit(EXIT_FAILURE); +} + +int +main(int argc, char *argv[]) +{ + /* HACK: we need this, cause mxml can't parse pure tags */ + mxml_node_t *tree = NULL; + mxml_node_t *node = NULL; + const char *base = "<?xml ?>"; + const char *id = NULL; + const char *from = NULL; + const char *type = NULL; + char *dir = "."; + char out_file[PATH_MAX]; + FILE *fh; + int ch; + + while ((ch = getopt(argc, argv, "d:h")) != -1) { + switch (ch) { + case 'd': + if ((dir = strdup(optarg)) == NULL) + err(EXIT_FAILURE, "strdup"); + break; + case 'h': + default: + usage(); + /* NOTREACHED */ + } + } + argc -= optind; + argv += optind; + + if ((tree = mxmlLoadString(NULL, base, MXML_NO_CALLBACK)) == NULL) + err(EXIT_FAILURE, "unable to read xml tree"); + mxmlLoadFile(tree, stdin, MXML_NO_CALLBACK); + + /* check iq tag */ + if ((node = tree->child) == NULL) + errx(EXIT_FAILURE, "unable to parse xml data"); + + if ((id = mxmlElementGetAttr(node, "id")) == NULL) + errx(EXIT_FAILURE, "iq stanze has no \"id\" attribute"); + + if ((from = mxmlElementGetAttr(node, "from")) == NULL) + errx(EXIT_FAILURE, "iq stanze has no \"from\" attribute"); + + if ((type = mxmlElementGetAttr(node, "type")) == NULL) + errx(EXIT_FAILURE, "iq stanze has no \"type\" attribute"); + + if (strcmp(type, "get") != 0) + errx(EXIT_FAILURE, "unable to handle iq type: %s", type); + + /* open file for output */ + snprintf(out_file, sizeof out_file, "%s/in", dir); + if ((fh = fopen(out_file, "w")) == NULL) + err(EXIT_FAILURE, "fopen"); + + send_time(fh, from, id); + + if (fclose(fh) == EOF) + err(EXIT_FAILURE, "fclose"); + + return EXIT_SUCCESS; +} -- 1.9.1 --------------010002000401070506020708--Received on Mon Sep 17 2001 - 00:00:00 CEST
This archive was generated by hypermail 2.3.0 : Fri Nov 20 2015 - 04:24:18 CET