diff options
author | Pascal Rigaux <pixel@mandriva.com> | 2007-04-25 10:05:19 +0000 |
---|---|---|
committer | Pascal Rigaux <pixel@mandriva.com> | 2007-04-25 10:05:19 +0000 |
commit | e953971267d8c9f9b0517bc458faf32acf5f611e (patch) | |
tree | 98f29755f2fa924695a25706851e9ad980c61f22 /lib/xf86misc/main.xs | |
parent | 48524e2dc24bae1e80dc7a39e490fe37c089adf3 (diff) | |
download | drakx-kbd-mouse-x11-e953971267d8c9f9b0517bc458faf32acf5f611e.tar drakx-kbd-mouse-x11-e953971267d8c9f9b0517bc458faf32acf5f611e.tar.gz drakx-kbd-mouse-x11-e953971267d8c9f9b0517bc458faf32acf5f611e.tar.bz2 drakx-kbd-mouse-x11-e953971267d8c9f9b0517bc458faf32acf5f611e.tar.xz drakx-kbd-mouse-x11-e953971267d8c9f9b0517bc458faf32acf5f611e.zip |
re-sync after the big svn loss
Diffstat (limited to 'lib/xf86misc/main.xs')
-rw-r--r-- | lib/xf86misc/main.xs | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/lib/xf86misc/main.xs b/lib/xf86misc/main.xs new file mode 100644 index 0000000..696f8dd --- /dev/null +++ b/lib/xf86misc/main.xs @@ -0,0 +1,76 @@ +#include "EXTERN.h" +#include "perl.h" +#include "XSUB.h" + +#include <X11/Xlib.h> +#include <X11/extensions/xf86misc.h> + +#include <term.h> +#undef max_colors + +void initIMPS2() { + unsigned char imps2_s1[] = { 243, 200, 243, 100, 243, 80, }; + unsigned char imps2_s2[] = { 246, 230, 244, 243, 100, 232, 3, }; + + int fd = open("/dev/mouse", O_WRONLY); + if (fd < 0) return; + + write (fd, imps2_s1, sizeof (imps2_s1)); + usleep (30000); + write (fd, imps2_s2, sizeof (imps2_s2)); + usleep (30000); + tcflush (fd, TCIFLUSH); + tcdrain(fd); +} + +MODULE = xf86misc::main PACKAGE = xf86misc::main + +PROTOTYPES: DISABLE + + +int +Xtest(display) + char *display + CODE: + int pid; + if ((pid = fork()) == 0) { + Display *d = XOpenDisplay(display); + if (d) { + int child; + /* keep a client until some window is created, otherwise X server blinks to hell */ + if ((child = fork()) == 0) { + XEvent event; + XSelectInput(d, DefaultRootWindow(d), SubstructureNotifyMask); + do { + XNextEvent(d, &event); + } while (event.type != CreateNotify); + XCloseDisplay(d); + exit(0); + } + } + _exit(d != NULL); + } + waitpid(pid, &RETVAL, 0); + OUTPUT: + RETVAL + +void +setMouseLive(display, type, emulate3buttons) + char *display + int type + int emulate3buttons + CODE: + { + XF86MiscMouseSettings mseinfo; + Display *d = XOpenDisplay(display); + if (d) { + if (XF86MiscGetMouseSettings(d, &mseinfo) == True) { + mseinfo.type = type; + mseinfo.flags |= MF_REOPEN; + mseinfo.emulate3buttons = emulate3buttons; + XF86MiscSetMouseSettings(d, &mseinfo); + XFlush(d); + if (type == MTYPE_IMPS2) initIMPS2(); + } + } + } |