diff options
author | Fritz Elfert <felfert@to.com> | 2001-05-21 21:56:23 +0000 |
---|---|---|
committer | Fritz Elfert <felfert@to.com> | 2001-05-21 21:56:23 +0000 |
commit | d77b3e38834eba44a4627de2b63e94ca96b93692 (patch) | |
tree | 833e31b6dc5baa13dc86371c68ab4f43a70c78f4 /lib/wprt.h | |
parent | 4e8a760688d3b9e7e6637d979b71bbd7161ba09c (diff) | |
download | plptools-d77b3e38834eba44a4627de2b63e94ca96b93692.tar.gz plptools-d77b3e38834eba44a4627de2b63e94ca96b93692.tar.bz2 plptools-d77b3e38834eba44a4627de2b63e94ca96b93692.zip |
Started print and clip support (no functionality yet).
- Moved include/intl.h to lib/plpintl.h
Diffstat (limited to 'lib/wprt.h')
-rw-r--r-- | lib/wprt.h | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/lib/wprt.h b/lib/wprt.h new file mode 100644 index 0000000..54ca84b --- /dev/null +++ b/lib/wprt.h @@ -0,0 +1,124 @@ +/*-*-c++-*- + * $Id$ + * + * This file is part of plptools. + * + * Copyright (C) 1999-2001 Fritz Elfert <felfert@to.com> + * + * 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 + * + */ +#ifndef _WPRT_H_ +#define _WPRT_H_ + +#include <rfsv.h> +#include <Enum.h> + +class ppsocket; +class bufferStore; +class bufferArray; + +/** + * Remote Print services via PLP + * + */ +class wprt { +public: + wprt(ppsocket *); + + /** + * Virtual destructor. + */ + ~wprt(); + + /** + * Initializes a connection to the remote + * machine. + */ + void reset(); + + /** + * Attempts to re-establish a remote + * connection by first closing the socket, + * then connecting again to the ncpd daemon + * and finally calling @ref reset. + */ + void reconnect(); + + /** + * Retrieves the current status of the + * connection. + * + * @returns The connection status. + */ + Enum<rfsv::errs> getStatus(); + + /** + * Get Print Data + */ + Enum<rfsv::errs> getData(bufferStore &buf); + + /** + * Init Printer + */ + Enum<rfsv::errs> initPrinter(); + +protected: + /** + * The possible commands. + */ + enum commands { + WPRT_INIT = 0x0100, + WPRT_GET = 0xf0f0, + }; + + /** + * The socket, used for communication + * with ncpd. + */ + ppsocket *skt; + + /** + * The current status of the connection. + */ + Enum<rfsv::errs> status; + + /** + * Sends a command to the remote side. + * + * If communication fails, a reconnect is triggered + * and a second attempt to transmit the request + * is attempted. If that second attempt fails, + * the function returns an error an sets rpcs::status + * to E_PSI_FILE_DISC. + * + * @param cc The command to execute on the remote side. + * @param data Additional data for this command. + * + * @returns true on success, false on failure. + */ + bool sendCommand(enum commands cc, bufferStore &data); + Enum<rfsv::errs> getResponse(bufferStore &data); + const char *getConnectName(); + +}; + +#endif + +/* + * Local variables: + * c-basic-offset: 4 + * End: + */ |