it is dumb to open and close devices before starting them

hopefully fixed bug #150


git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@16369 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Jérôme Duval 2006-02-12 22:37:39 +00:00
parent e060f46982
commit 7be5a254fa

View File

@ -1,29 +1,9 @@
/*****************************************************************************/
// Keyboard input server device addon
// Written by Jérôme Duval
//
// KeyboardInputDevice.cpp
//
// Copyright (c) 2004 Haiku Project
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal in the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included
// in all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
/*****************************************************************************/
/*
* Copyright 2004-2006, Jérôme Duval. All rights reserved.
* Distributed under the terms of the MIT License.
* Keyboard input server device addon
*/
#include "KeyboardInputDevice.h"
#include "kb_mouse_driver.h"
#include <Directory.h>
@ -437,8 +417,10 @@ KeyboardInputDevice::Start(const char *name, void *cookie)
CALLED();
keyboard_device *device = (keyboard_device *)cookie;
if ((device->fd = open(device->path, O_RDWR)) < B_OK)
if ((device->fd = open(device->path, O_RDWR)) < B_OK) {
fprintf(stderr, "error when opening %s: %s\n", device->path, strerror(device->fd));
return B_ERROR;
}
InitFromSettings(device);
@ -464,6 +446,7 @@ KeyboardInputDevice::Stop(const char *name, void *cookie)
LOG("Stop(%s)\n", name);
close(device->fd);
device->fd = -1;
device->active = false;
if (device->device_watcher >= 0) {
@ -546,14 +529,8 @@ KeyboardInputDevice::AddDevice(const char *path)
keyboard_device *device = new keyboard_device();
if (!device)
return B_NO_MEMORY;
if ((device->fd = open(path, O_RDWR)) < B_OK) {
fprintf(stderr, "error when opening %s\n", path);
delete device;
return B_ERROR;
}
close(device->fd);
device->fd = -1;
device->device_watcher = -1;
device->active = false;
strcpy(device->path, path);
@ -584,8 +561,6 @@ KeyboardInputDevice::RemoveDevice(const char *path)
while ((device = (keyboard_device *)fDevices.ItemAt(i)) != NULL) {
if (!strcmp(device->path, path)) {
free(device->device_ref.name);
if (device->fd >= 0)
close(device->fd);
fDevices.RemoveItem(device);
delete device;
return B_OK;