mac_net.h
上传用户:zhongxx05
上传日期:2007-06-06
资源大小:33641k
文件大小:5k
源码类别:

Symbian

开发平台:

C/C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Version: RCSL 1.0/RPSL 1.0
  3.  *
  4.  * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
  5.  *
  6.  * The contents of this file, and the files included with this file, are
  7.  * subject to the current version of the RealNetworks Public Source License
  8.  * Version 1.0 (the "RPSL") available at
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed
  10.  * the file under the RealNetworks Community Source License Version 1.0
  11.  * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
  12.  * in which case the RCSL will apply. You may also obtain the license terms
  13.  * directly from RealNetworks.  You may not use this file except in
  14.  * compliance with the RPSL or, if you have a valid RCSL with RealNetworks
  15.  * applicable to this file, the RCSL.  Please see the applicable RPSL or
  16.  * RCSL for the rights, obligations and limitations governing use of the
  17.  * contents of the file.
  18.  *
  19.  * This file is part of the Helix DNA Technology. RealNetworks is the
  20.  * developer of the Original Code and owns the copyrights in the portions
  21.  * it created.
  22.  *
  23.  * This file, and the files included with this file, is distributed and made
  24.  * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  25.  * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
  26.  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
  27.  * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  28.  *
  29.  * Technology Compatibility Kit Test Suite(s) Location:
  30.  *    http://www.helixcommunity.org/content/tck
  31.  *
  32.  * Contributor(s):
  33.  *
  34.  * ***** END LICENSE BLOCK ***** */
  35. //
  36. // Mac_net.h
  37. //
  38. // A class to handle basic net functions on the Macintosh computer
  39. //
  40. #ifndef _MAC_NET
  41. #define _MAC_NET
  42. #include "conn.h"
  43. #include "platform/mac/macsockets.h"
  44. class Mac_net : public conn {
  45. public:
  46. static Boolean sHasOT;
  47. static Boolean sHasMacTCP;
  48. static Boolean sNetInitialized;
  49. /*  call new_socket() to automatically create the correct platform specific network object.
  50. The type parameter may be either HX_TCP_SOCKET or HX_UDP_SOCKET. If new_socket() returns 
  51. NULL, an error occurred and the conn object was not created. Call last_error() to get the error */
  52. static Mac_net *new_socket  (UINT16 type);
  53.     ~Mac_net (void);
  54. /*  call init_drivers() to do any platform specific initialization of the network drivers
  55. before calling any other functions in this class */
  56. static HX_RESULT init_drivers  (void *params);
  57. /*  close_drivers() should close any network drivers used by the program
  58.   NOTE: The program MUST not make any other calls to the network drivers
  59.   until init_drivers() has been called */
  60. static HX_RESULT close_drivers  (void *params);
  61. /*  host_to_ip_str() converts the host name to an ASCII ip address of
  62. the form "XXX.XXX.XXX.XXX" */
  63. static  HX_RESULT  host_to_ip_str (char *host, char *ip, UINT32 ulIPBufLen);
  64. static HX_RESULT get_host_name(char *name, int namelen)
  65. {
  66.     return HXR_NOTIMPL;
  67. }
  68. static HX_RESULT get_host_by_name(char *name, REF(struct hostent*) pHostent)
  69. {
  70.     return HXR_NOTIMPL;
  71. }
  72. /*  call done() when you are finished with the socket. Done() will close the socket.
  73. You may reuse the socket by calling init() or connect() */
  74. virtual void done (void) = 0;
  75. virtual ULONG32     AddRef     (void);
  76. virtual ULONG32     Release     (void);
  77. virtual HX_RESULT init (UINT32 local_addr,
  78.  UINT16  port, 
  79.  UINT16  blocking=0) = 0;
  80.  
  81. virtual HX_RESULT listen (ULONG32 ulLocalAddr,
  82.  UINT16 port,
  83.  UINT16  backlog,
  84.  UINT16 blocking,
  85.  ULONG32 ulPlatform) = 0;
  86. virtual HX_RESULT connect (const  char *host, 
  87.  UINT16  port,
  88.  UINT16  blocking=0,
  89.  ULONG32 ulPlatform=0 ) = 0;
  90. virtual HX_RESULT blocking (void)      {return HXR_OK;};
  91. virtual HX_RESULT nonblocking (void)     {return HXR_OK;};
  92. virtual HX_RESULT read (void  *buf, 
  93.  UINT16  *size) = 0;
  94. virtual HX_RESULT readfrom (REF(IHXBuffer*)   pBuffer,
  95.  REF(UINT32)     ulAddress,
  96.  REF(UINT16)     ulPort) = 0;
  97. virtual HX_RESULT write (void  *buf,
  98.  UINT16  *size) = 0;
  99.  
  100. static Boolean CheckForCancel (void);
  101. virtual UINT16 get_local_port (void) { return -1; }
  102. protected:
  103. Mac_net (void);
  104. LONG32     m_lRefCount;
  105. };
  106. #endif // _MAC_NET
  107. #ifdef __cplusplus
  108. extern "C" {
  109. #endif
  110. INT16 getsockname(int sock, sockaddr* addr, INT16* addr_len);
  111. #ifdef __cplusplus
  112. }
  113. #endif