connection.h
来自「konqueror3 embedded版本, KDE环境下的当家浏览器的嵌入式版」· C头文件 代码 · 共 159 行
H
159 行
// -*- c++ -*-/* This file is part of the KDE libraries Copyright (C) 2000 Stephan Kulow <coolo@kde.org> David Faure <faure@kde.org> This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library 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 Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.*/#ifndef __connection_h__#define __connection_h__#include <kdelibs_export.h>#include <sys/types.h>#include <stdio.h>#include <qptrlist.h>#include <qobject.h>class KSocket;class QSocketNotifier;namespace KIO { struct KIO_EXPORT Task { int cmd; QByteArray data; }; /** * This class provides a simple means for IPC between two applications * via a pipe. * It handles a queue of commands to be sent which makes it possible to * queue data before an actual connection has been established. */ class KIO_EXPORT Connection : public QObject { Q_OBJECT public: /** * Creates a new connection. * @see init() */ Connection(); virtual ~Connection(); /** * Initialize this connection to use the given socket. * @param sock the socket to use * @see inited() */ void init(KSocket *sock); /** * Initialize the connection to use the given file * descriptors. * @param fd_in the input file descriptor to use * @param fd_out the output file descriptor to use * @see inited() */ void init(int fd_in, int fd_out); // Used by KDENOX void connect(QObject *receiver = 0, const char *member = 0); /// Closes the connection. void close(); /** * Returns the input file descriptor. * @return the input file descriptor */ int fd_from() const { return fd_in; } /** * Returns the output file descriptor. * @return the output file descriptor */ int fd_to() const { return fileno( f_out ); } /** * Checks whether the connection has been initialized. * @return true if the initialized * @see init() */ bool inited() const { return (fd_in != -1) && (f_out != 0); } /** * Sends/queues the given command to be sent. * @param cmd the command to set * @param arr the bytes to send */ void send(int cmd, const QByteArray &arr = QByteArray()); /** * Sends the given command immediately. * @param _cmd the command to set * @param data the bytes to send * @return true if successful, false otherwise */ bool sendnow( int _cmd, const QByteArray &data ); /** * Receive data. * * @param _cmd the received command will be written here * @param data the received data will be written here * @return >=0 indicates the received data size upon success * -1 indicates error */ int read( int* _cmd, QByteArray &data ); /** * Don't handle incoming data until resumed. */ void suspend(); /** * Resume handling of incoming data. */ void resume(); /** * Returns status of connection. * @return true if suspended, false otherwise */ bool suspended() const { return m_suspended; } protected slots: void dequeue(); protected: private: int fd_in; FILE *f_out; KSocket *socket; QSocketNotifier *notifier; QObject *receiver; const char *member; QPtrList<Task> tasks; bool m_suspended; private: class ConnectionPrivate* d; };}#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?