gecko-dev/netwerk/base/public/nsIProtocolInstance.h
1999-04-09 02:26:05 +00:00

92 lines
3.0 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public License
* Version 1.0 (the "NPL"); you may not use this file except in
* compliance with the NPL. You may obtain a copy of the NPL at
* http://www.mozilla.org/NPL/
*
* Software distributed under the NPL is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
* for the specific language governing rights and limitations under the
* NPL.
*
* The Initial Developer of this code under the NPL is Netscape
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
* Reserved.
*/
#ifndef _nsIProtocolInstance_h_
#define _nsIProtocolInstance_h_
#include "nsICancelable.h"
class nsIInputStream;
class nsIOutputStream;
/*
The nsIProtocolInstance class is a common interface to all protocol
functionality. This base interface will support at getting the input
stream and the outputstream for the "connection"
There are still issues on what is the most common interface for the
extreme cases of an interactive protocol like HTTP vs. events based
one like SMTP/IMAP. This interface will probably go thru some
redesigning.
-Gagan Saksena 03/15/99
*/
class nsIProtocolInstance : public nsICancelable
{
public:
/*
The BLOCKING GetInputStream function. Note that this function is not
a const and calling it may result in a state change for the protocol
instance. Its upto the protocol to reflect an already open input
stream through the return methods.
*/
NS_IMETHOD GetInputStream(nsIInputStream* *o_Stream) = 0;
/*
The BLOCKING GetOutputStream function. Note that this function is not
a const and calling it may result in a state change for the protocol
instance. Its upto the protocol to reflect an already closed
connection through the return methods.
*/
NS_IMETHOD GetOutputStream(nsIOutputStream* *o_Stream) = 0;
/*
The load function that makes the actual attempt to starts the
retrieval process. Depending upon the protocol's implementation
this function may open the network connection.
*/
NS_IMETHOD Connect(nsISupports* i_EventSink) = 0;
static const nsIID& GetIID() {
// {3594D180-CB85-11d2-A1BA-444553540000}
static const nsIID NS_IProtocolInstance_IID =
{ 0x3594d180, 0xcb85, 0x11d2, { 0xa1, 0xba, 0x44, 0x45, 0x53, 0x54, 0x0, 0x0 } };
return NS_IProtocolInstance_IID;
};
protected:
/*
Protocol's check for connection status. Once Load is called, this
should return true. TODO THINK
NS_IMETHOD_(PRBool) IsConnected(void) = 0;
*/
};
//Possible errors
#define NS_ERROR_ALREADY_CONNECTED NS_ERROR_GENERATE_FAILURE(NS_ERROR_MODULE_NETWORK, 150);
#endif /* _nsIProtocolInstance_h_ */