ce64ffdb90
In order to prevent classes between libnetapi.so with the legacy API and applications using the libnetservices.a library, the latter will have the classes in a distinct namespace. In the implementation, both libbnetapi.so and libnetservices.a will use the same header and source files. If LIBNETAPI_DEPRECATED is defined during build, the headers and source will have binary compatible behavior. Otherwise, the classes and other objects will be put in the HaikuExt namespace. In order to build the libbnetapi.so and libnetservices.a with the proper build configuration, there is a stub `src/kits/net/libnetapi_deprecated` folder that applies the special configuration to the source files. Currently HaikuDepot, Webpositive, libshared.a and the http_streamer add on use the compatible API in libbnetapi.so. Change-Id: Ic73e9f271ef75749adda46f6f72e9a0b2851b461 Reviewed-on: https://review.haiku-os.org/c/haiku/+/3667 Reviewed-by: Adrien Destugues <pulkomandy@gmail.com>
55 lines
1001 B
C++
55 lines
1001 B
C++
/*
|
|
* Copyright 2014 Haiku Inc. All rights reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
#ifndef _B_NET_REQUEST_H_
|
|
#define _B_NET_REQUEST_H_
|
|
|
|
|
|
#include <NetBuffer.h>
|
|
#include <NetworkAddress.h>
|
|
#include <UrlRequest.h>
|
|
|
|
|
|
class BAbstractSocket;
|
|
|
|
|
|
#ifndef LIBNETAPI_DEPRECATED
|
|
namespace BPrivate {
|
|
|
|
namespace Network {
|
|
#endif
|
|
|
|
class BNetworkRequest: public BUrlRequest
|
|
{
|
|
public:
|
|
BNetworkRequest(const BUrl& url,
|
|
BUrlProtocolListener* listener,
|
|
BUrlContext* context,
|
|
const char* threadName,
|
|
const char* protocolName);
|
|
|
|
virtual status_t Stop();
|
|
virtual void SetTimeout(bigtime_t timeout);
|
|
|
|
protected:
|
|
bool _ResolveHostName(BString host, uint16_t port);
|
|
|
|
void _ProtocolSetup();
|
|
status_t _GetLine(BString& destString);
|
|
|
|
protected:
|
|
BAbstractSocket* fSocket;
|
|
BNetworkAddress fRemoteAddr;
|
|
|
|
BNetBuffer fInputBuffer;
|
|
};
|
|
|
|
#ifndef LIBNETAPI_DEPRECATED
|
|
} // namespace Network
|
|
|
|
} // namespace BPrivate
|
|
#endif
|
|
|
|
#endif
|