summaryrefslogtreecommitdiff
path: root/libvxi11client/client.c
diff options
context:
space:
mode:
Diffstat (limited to 'libvxi11client/client.c')
-rw-r--r--libvxi11client/client.c45
1 files changed, 45 insertions, 0 deletions
diff --git a/libvxi11client/client.c b/libvxi11client/client.c
index eb224f2..799df57 100644
--- a/libvxi11client/client.c
+++ b/libvxi11client/client.c
@@ -7,8 +7,14 @@ static char* geterrorstring(int errorcode) {
switch (errorcode) {
case 0:
return "invalid state (not connected) or no response from server";
+ case -4:
+ return "invalid link identifier";
case -8:
return "operation not supported";
+ case -11:
+ return "device locked by another link";
+ case -12:
+ return "no lock held by this link";
default:
return "unknown error code";
}
@@ -27,6 +33,10 @@ int main(int argc, char *argv[]) {
if ((err = vxi11_open(argv[1], NULL)) > 0) {
+ /**
+ * Basic tests
+ */
+
// write some bytes
int byteswritten = vxi11_write(IDENTIFY, sizeof(IDENTIFY), false);
if (byteswritten >= 0)
@@ -78,6 +88,41 @@ int main(int argc, char *argv[]) {
else
printf("Error reading status byte\n");
+ /**
+ * Locking tests
+ */
+
+ // try locking twice
+ printf("-- Locking twice --\n");
+ if ((err = vxi11_lock()) > 0) {
+ printf("locked\n");
+ if ((err = vxi11_lock()) > 0) {
+ printf("locked again!!\n");
+ exit(1);
+ }
+ else {
+ printf("Second lock failed; %s\n", geterrorstring(err));
+ }
+ }
+ if ((err = vxi11_unlock()) > 0)
+ printf("unlocked\n");
+ else {
+ printf("error unlocking; %s\n", geterrorstring(err));
+ exit(1);
+ }
+
+ printf("\n");
+
+ // try unlocking unlocked device
+ printf("-- Unlocking when unlocked --\n");
+ if ((err = vxi11_unlock()) > 0) {
+ printf("Unlocked!!\n");
+ exit(1);
+ }
+ else
+ printf("error unlocking; %s\n", geterrorstring(err));
+ printf("\n");
+
// create interrupt channel
err = vxi11_create_intr_chan();