diff options
author | Philip Langdale <philipl@fido2.homeip.net> | 2006-10-11 11:47:25 -0700 |
---|---|---|
committer | Philip Langdale <philipl@fido2.homeip.net> | 2006-10-11 11:47:25 -0700 |
commit | 9345f8146ae41f7d2269e6fea5e3cba385139960 (patch) | |
tree | ae7083789fc1250c88fd7bd133f3ce6cd5b1bde7 /vmwarectrl/vmwarectrl.c | |
parent | b35666fdd567d4cd92574aeecadb8e0d41b32d77 (diff) |
Add vmwarectrl sample client.
Diffstat (limited to 'vmwarectrl/vmwarectrl.c')
-rw-r--r-- | vmwarectrl/vmwarectrl.c | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/vmwarectrl/vmwarectrl.c b/vmwarectrl/vmwarectrl.c new file mode 100644 index 0000000..6c45095 --- /dev/null +++ b/vmwarectrl/vmwarectrl.c @@ -0,0 +1,76 @@ +#include <stdio.h> +#include <X11/Xlib.h> +#include <X11/Xlibint.h> +#include <X11/Xproto.h> +#include <X11/extensions/panoramiXproto.h> +#include <string.h> +#include <stdlib.h> + +#include "libvmwarectrl.h" + +int +main (int argc, char **argv) +{ + Display *dpy; + char *displayName = NULL; + int screen; + int major, minor; + + dpy = XOpenDisplay(displayName); + if (!dpy) { + printf("Could not open default X Display\n"); + exit(EXIT_FAILURE); + } + screen = DefaultScreen(dpy); + + if (VMwareCtrl_QueryVersion(dpy, &major, &minor)) { + printf("Got Extension version %d.%d\n", major, minor); + } else { + printf("VMWARE_CTRL Extension not found.\n"); + exit(EXIT_FAILURE); + } + + if (argc == 2) { + if (strcmp(argv[1], "setres") == 0) { + int x, y; + if (argc < 4) { + printf("Setres needs x and y too\n"); + exit(EXIT_FAILURE); + } + + x = atoi(argv[1]); + y = atoi(argv[2]); + + if (VMwareCtrl_SetRes(dpy, screen, x, y)) { + printf("Set Res was successful\n"); + } else { + printf("Set Res failed\n"); + } + } else if (strcmp(argv[1], "settopology") == 0) { + xXineramaScreenInfo extents[2]; + + if (major == 0 && minor < 2) { + printf("VMWARE_CTRL version >= 0.2 is required\n"); + exit(EXIT_FAILURE); + } + + printf("Requesting hard-coded topology\n"); + + extents[0].x_org = 0; + extents[0].y_org = 0; + extents[0].width = 800; + extents[0].height = 600; + extents[1].x_org = 800; + extents[1].y_org = 0; + extents[1].width = 800; + extents[1].height = 600; + if (VMwareCtrl_SetTopology(dpy, screen, extents, 2)) { + printf("SetTopology was successful\n"); + } else { + printf("SetTopology failed\n"); + } + } + } + + return EXIT_SUCCESS; +} |