diff options
author | fishsoupisgood <github@madingley.org> | 2020-11-08 00:44:09 +0000 |
---|---|---|
committer | fishsoupisgood <github@madingley.org> | 2020-11-08 00:44:09 +0000 |
commit | 6a27a521f99c7babc9d000465b661f66b54ee101 (patch) | |
tree | cafd3f2b11534b84d5aebe7a03746e92c04b39df | |
parent | 8531610431c4f0f60cbe64ed8ae362219e7f6520 (diff) | |
download | galaxy_sia-6a27a521f99c7babc9d000465b661f66b54ee101.tar.gz galaxy_sia-6a27a521f99c7babc9d000465b661f66b54ee101.tar.bz2 galaxy_sia-6a27a521f99c7babc9d000465b661f66b54ee101.zip |
add wait until disarmed
-rw-r--r-- | arm.c | 14 | ||||
-rw-r--r-- | arm.h | 2 | ||||
-rw-r--r-- | net_arm.c | 25 | ||||
-rw-r--r-- | serial_arm.c | 30 |
4 files changed, 54 insertions, 17 deletions
@@ -122,12 +122,13 @@ static const char *ready_to_str (int i) -int show_state (int fd) +int show_state (int fd, int zone) { int i, l = SIA_MAX_DATA_LENGTH; unsigned char armed[SIA_MAX_DATA_LENGTH]; unsigned char state[SIA_MAX_DATA_LENGTH]; unsigned char ready[SIA_MAX_DATA_LENGTH]; + int s = 0; i = get_thing (fd, "SA", armed); @@ -161,12 +162,19 @@ int show_state (int fd) printf ("%-6s | %-15s | %-15s | %-15s\n", "Zone", "Armed", "State", "Ready"); printf ("-------+-----------------+-----------------+----------------\n"); - for (i = 0; i < l; ++i) + if (zone > 0) { + s = zone; + l = zone + 1; + } + + for (i = s; i < l; ++i) printf ("%6d | %-15s | %-15s | %-15s\n", i + 1, armed_to_str (armed[i]), state_to_str (state[i]), ready_to_str (ready[i])); printf ("\n"); - return armed[0] - '0'; + if (zone < 0) zone = 0; + + return armed[zone] - '0'; } @@ -1,6 +1,6 @@ #ifndef _arm_h_ #define _arm_h_ extern int auth_cmd_with_ack(int fd, unsigned char fn, const void *data, size_t len,SIA_Block *b); -extern int show_state(int fd); +extern int show_state(int fd, int zone); #endif /* _arm_h_ */ @@ -39,11 +39,13 @@ int main (int argc, char *argv[]) unsigned opt; int zone = -1; int action = -1; + int disarm = 0; const char *host = NULL; unsigned port = 10005; int fd; + int timeout = 15; - while ((opt = getopt (argc, argv, "h:p:z:USPRBFTAD")) != -1) { + while ((opt = getopt (argc, argv, "h:p:z:USPRBFTADW")) != -1) { switch (opt) { case 'h': host = optarg; @@ -93,6 +95,10 @@ int main (int argc, char *argv[]) action = 8; break; + case 'W': + disarm++; + break; + default: /* '?' */ return usage (argv[0]); } @@ -108,9 +114,15 @@ int main (int argc, char *argv[]) } + if (disarm) { + if (!show_state (fd, zone)) + return 0; + + action = 0; + } if (action == -1) - return show_state (fd); + return show_state (fd, zone); if (zone != -1) @@ -127,14 +139,17 @@ int main (int argc, char *argv[]) switch (b.function) { case SIA_FN_ACKNOLEDGE: printf ("Panel acks command\n"); - return 0; + break; case SIA_FN_REJECT: printf ("Panel nacks command\n"); - /*fall through */ + return -1; } - return -1; + while (disarm && timeout && show_state (fd, zone)) + sleep (2); + + return !timeout; } diff --git a/serial_arm.c b/serial_arm.c index 4ed28b9..c8f6b66 100644 --- a/serial_arm.c +++ b/serial_arm.c @@ -39,11 +39,13 @@ int main (int argc, char *argv[]) unsigned opt; int zone = -1; int action = -1; + int disarm = 0; const char *port = NULL; unsigned baud = 9600; int fd; + int timeout = 15; - while ((opt = getopt (argc, argv, "h:p:z:USPRBFTAD")) != -1) { + while ((opt = getopt (argc, argv, "h:p:z:USPRBFTADW")) != -1) { switch (opt) { case 'p': port = optarg; @@ -93,6 +95,10 @@ int main (int argc, char *argv[]) action = 8; break; + case 'W': + disarm++; + break; + default: /* '?' */ return usage (argv[0]); } @@ -112,13 +118,18 @@ int main (int argc, char *argv[]) - if (action == -1) { - if (show_state (fd)) - return -1; - return 0; + if (disarm) { + if (!show_state (fd, zone)) + return 0; + + action = 0; } + if (action == -1) + return show_state (fd, zone); + + if (zone != -1) sprintf (cmd, "SA%d*%d", zone, action); @@ -134,14 +145,17 @@ int main (int argc, char *argv[]) switch (b.function) { case SIA_FN_ACKNOLEDGE: printf ("Panel acks command\n"); - return 0; + break; case SIA_FN_REJECT: printf ("Panel nacks command\n"); - /*fall through */ + return -1; } - return -1; + while (disarm && timeout && show_state (fd, zone)) + sleep (2); + + return !timeout; } |