summaryrefslogtreecommitdiff
path: root/kbdnotify/keyboard.c
diff options
context:
space:
mode:
authormataes2007 <mataes2007@e753b5eb-9565-29b2-b5c5-2cc6f99dfbcb>2011-11-26 12:50:52 +0000
committermataes2007 <mataes2007@e753b5eb-9565-29b2-b5c5-2cc6f99dfbcb>2011-11-26 12:50:52 +0000
commit6f3d69266933ef120d229e0daf2da164b77214d0 (patch)
treee80eecd51aa1e83a8a0e9ddec51b0667a166623b /kbdnotify/keyboard.c
parent308b14daa23b11367b677d24194f35cbb6a7dbec (diff)
renamed trunk folder
git-svn-id: http://miranda-plugins.googlecode.com/svn/trunk@213 e753b5eb-9565-29b2-b5c5-2cc6f99dfbcb
Diffstat (limited to 'kbdnotify/keyboard.c')
-rw-r--r--kbdnotify/keyboard.c118
1 files changed, 0 insertions, 118 deletions
diff --git a/kbdnotify/keyboard.c b/kbdnotify/keyboard.c
deleted file mode 100644
index 5e7c261..0000000
--- a/kbdnotify/keyboard.c
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
-
-This program is free software; you can redistribute it and/or
-modify it under the terms of the GNU General Public License
-as published by the Free Software Foundation; either version 2
-of the License, or (at your option) any later version.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-
-*/
-
-#define WIN32_LEAN_AND_MEAN
-
-#include <stdio.h>
-#include <windows.h>
-#include <winioctl.h>
-#include "keypresses.h"
-#include <newpluginapi.h>
-#include <m_utils.h>
-
-
-// Globals
-extern BOOL bWindowsNT;
-extern BOOL bEmulateKeypresses;
-HANDLE hKbdDev[10] = {INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE, INVALID_HANDLE_VALUE};
-
-// Defines
-#define MAX_KBDHANDLES 10
-#define IOCTL_KEYBOARD_SET_INDICATORS CTL_CODE(FILE_DEVICE_KEYBOARD, 0x0002, METHOD_BUFFERED, FILE_ANY_ACCESS)
-#define IOCTL_KEYBOARD_QUERY_TYPEMATIC CTL_CODE(FILE_DEVICE_KEYBOARD, 0x0008, METHOD_BUFFERED, FILE_ANY_ACCESS)
-#define IOCTL_KEYBOARD_QUERY_INDICATORS CTL_CODE(FILE_DEVICE_KEYBOARD, 0x0010, METHOD_BUFFERED, FILE_ANY_ACCESS)
-
-typedef struct _KEYBOARD_INDICATOR_PARAMETERS {
- USHORT UnitId; // Unit identifier.
- USHORT LedFlags; // LED indicator state.
-
-} KEYBOARD_INDICATOR_PARAMETERS, *PKEYBOARD_INDICATOR_PARAMETERS;
-
-
-void outportb(UINT portid, BYTE value)
-{
- __asm mov edx,portid
- __asm mov al,value
- __asm out dx,al
-}
-
-
-BOOL OpenKeyboardDevice()
-{
- int i = 0;
- char aux1[MAX_PATH+1], aux2[MAX_PATH+1];
-
- if (!bWindowsNT)
- return TRUE;
-
- do {
- mir_snprintf(aux1, sizeof(aux1), "Kbd%d", i);
- mir_snprintf(aux2, sizeof(aux2), "\\Device\\KeyboardClass%d", i);
- DefineDosDevice(DDD_RAW_TARGET_PATH, aux1, aux2);
-
- mir_snprintf(aux1, sizeof(aux1), "\\\\.\\Kbd%d", i);
- hKbdDev[i] = CreateFile(aux1, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, 0, NULL);
-
- } while (hKbdDev[i] != INVALID_HANDLE_VALUE && ++i < MAX_KBDHANDLES);
-
- return hKbdDev[0] != INVALID_HANDLE_VALUE;
-}
-
-BOOL ToggleKeyboardLights(BYTE byte)
-{
- int i; BOOL result = FALSE;
- KEYBOARD_INDICATOR_PARAMETERS InputBuffer; // Input buffer for DeviceIoControl
- ULONG DataLength = sizeof(KEYBOARD_INDICATOR_PARAMETERS);
- ULONG ReturnedLength; // Number of bytes returned in output buffer
-
- if (bEmulateKeypresses)
- return keypresses_ToggleKeyboardLights(byte);
-
- if (!bWindowsNT) {
- outportb(0x60, 0xED);
- Sleep(10);
- outportb(0x60, byte);
- return TRUE;
- }
-
- InputBuffer.UnitId = 0;
- InputBuffer.LedFlags = byte;
-
- for (i=0; i < MAX_KBDHANDLES && hKbdDev[i] != INVALID_HANDLE_VALUE; i++)
- result |= DeviceIoControl(hKbdDev[i], IOCTL_KEYBOARD_SET_INDICATORS, &InputBuffer, DataLength, NULL, 0, &ReturnedLength, NULL);
-
- return result;
-}
-
-void CloseKeyboardDevice()
-{
- int i = 0;
- char aux[MAX_PATH+1];
-
- if (!bWindowsNT)
- return;
-
- do {
- if (hKbdDev[i] != INVALID_HANDLE_VALUE)
- CloseHandle(hKbdDev[i]);
-
- mir_snprintf(aux, sizeof(aux), "Kbd%d", i);
- DefineDosDevice(DDD_REMOVE_DEFINITION, aux, NULL);
-
- } while (hKbdDev[i] != INVALID_HANDLE_VALUE && ++i < MAX_KBDHANDLES);
-}