diff options
| author | Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> | 2012-12-23 13:01:52 +0100 | 
|---|---|---|
| committer | Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> | 2012-12-25 17:36:09 +0100 | 
| commit | 97236387af5729929e14d86cafe460dbb08cea1d (patch) | |
| tree | 637baae3d1d439f4fe723f471874749b7202aa24 /plugin.c | |
| download | vdr-plugin-inputdev-97236387af5729929e14d86cafe460dbb08cea1d.tar.gz vdr-plugin-inputdev-97236387af5729929e14d86cafe460dbb08cea1d.tar.bz2 | |
initial checkin
Diffstat (limited to 'plugin.c')
| -rw-r--r-- | plugin.c | 157 | 
1 files changed, 157 insertions, 0 deletions
| diff --git a/plugin.c b/plugin.c new file mode 100644 index 0000000..346d8a9 --- /dev/null +++ b/plugin.c @@ -0,0 +1,157 @@ +/*	--*- c++ -*-- + * Copyright (C) 2012 Enrico Scholz <enrico.scholz@informatik.tu-chemnitz.de> + * + * 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; version 2 and/or 3 of the License. + * + * 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, see <http://www.gnu.org/licenses/>. + */ + +#include <getopt.h> +#include <unistd.h> + +#include <vdr/plugin.h> + +#include "inputdev.h" + +static char const *DEFAULT_SOCKET_PATH = SOCKET_PATH; +static const char *VERSION        = PACKAGE_VERSION; +static const char *DESCRIPTION    = "Linux input device  plugin"; + +class cInputDevicePlugin : public cPlugin { +private: +	class cInputDeviceController	*controller_; + +	enum { +		enSOCKET, +		enSYSTEMD +	}				socket_type_; + +	union { +		char const		*path; +		int			idx; +	}				socket_; + +public: +	cInputDevicePlugin(void); +	virtual ~cInputDevicePlugin(); + +	virtual const char *Version(void) { return VERSION; } +	virtual const char *Description(void) { return DESCRIPTION; } + +	virtual bool	ProcessArgs(int argc, char *argv[]); +	virtual bool	Initialize(void); +	virtual bool	Start(void); +	virtual void	Stop(void); +}; + +cInputDevicePlugin::cInputDevicePlugin() : +	controller_(NULL) +{ +} + +cInputDevicePlugin::~cInputDevicePlugin(void) +{ +	delete controller_; +} + +bool cInputDevicePlugin::ProcessArgs(int argc, char *argv[]) +{ +	static struct option const	CMDLINE_OPTIONS[] = { +		{ "systemd", required_argument, NULL, 'S' }, +		{ "socket",  required_argument, NULL, 's' }, +		{ } +	}; + +	char const	*systemd_idx = NULL; +	char const	*socket_path = NULL; +	bool		is_ok = true; + +	for (;;) { +		int		c; + +		c = getopt_long(argc, argv, "S:s:", CMDLINE_OPTIONS, NULL); +		if (c == -1) +			break; + +		switch (c) { +		case 'S':  systemd_idx = optarg; break; +		case 's':  socket_path = optarg; break; +		default: +			esyslog("%s: invalid option\n", Name()); +			return false; +		} +	} + +	if (systemd_idx != NULL && socket_path != NULL) { +		esyslog("%s: both systemd idx and socket path given\n", +			Name()); +		return false; +	} + +	if (systemd_idx == NULL && socket_path == NULL) +		socket_path = DEFAULT_SOCKET_PATH; + +	if (systemd_idx != NULL) { +		socket_type_ = enSYSTEMD; +		socket_.idx  = atoi(systemd_idx); +	} else if (socket_path != NULL) { +		socket_type_ = enSOCKET; +		socket_.path = socket_path; +	} else +		is_ok = false; + +	return is_ok; +} + +bool cInputDevicePlugin::Initialize(void) +{ +	bool		is_ok; + +	controller_ = new cInputDeviceController(*this); + +	switch (socket_type_) { +	case enSYSTEMD: +		is_ok = controller_->open_udev_socket(socket_.idx); +		break; + +	case enSOCKET: +		is_ok = controller_->open_udev_socket(socket_.path); +		break; + +	default: +		esyslog("%s: bad internal socket type %d\n", Name(), +			socket_type_); +		is_ok = false; +		break; +	} + +	if (is_ok) +		is_ok = controller_->initialize(); + +	if (!is_ok) { +		delete controller_; +		controller_ = NULL; +	} + +	return is_ok; +} + +bool cInputDevicePlugin::Start(void) +{ +	return controller_->start(); +} + +void cInputDevicePlugin::Stop(void) +{ +	controller_->stop(); +} + +VDRPLUGINCREATOR(cInputDevicePlugin); // Don't touch this! | 
