|  | @@ -55,8 +55,8 @@ public: | 
														
													
														
															
																|  |  | //============================================================================== |  |  | //============================================================================== | 
														
													
														
															
																|  |  | /** Binds the socket to the specified local port. |  |  | /** Binds the socket to the specified local port. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns    true on success; false may indicate that another socket is already bound |  |  |  | 
														
													
														
															
																|  |  | on the same port |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true on success; false may indicate that another socket is already bound | 
														
													
														
															
																|  |  |  |  |  | on the same port | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool bindToPort (int localPortNumber); |  |  | bool bindToPort (int localPortNumber); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -66,8 +66,9 @@ public: | 
														
													
														
															
																|  |  | as well. This is useful if you would like to bind your socket to a specific network |  |  | as well. This is useful if you would like to bind your socket to a specific network | 
														
													
														
															
																|  |  | adapter. Note that localAddress must be an IP address assigned to one of your |  |  | adapter. Note that localAddress must be an IP address assigned to one of your | 
														
													
														
															
																|  |  | network address otherwise this function will fail. |  |  | network address otherwise this function will fail. | 
														
													
														
															
																|  |  | @returns    true on success; false may indicate that another socket is already bound |  |  |  | 
														
													
														
															
																|  |  | on the same port |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true on success; false may indicate that another socket is already bound | 
														
													
														
															
																|  |  |  |  |  | on the same port | 
														
													
														
															
																|  |  | @see bindToPort(int localPortNumber), IPAddress::getAllAddresses |  |  | @see bindToPort(int localPortNumber), IPAddress::getAllAddresses | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool bindToPort (int localPortNumber, const String& localAddress); |  |  | bool bindToPort (int localPortNumber, const String& localAddress); | 
														
													
												
													
														
															
																|  | @@ -76,7 +77,9 @@ public: | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | This is useful if you need to know to which port the OS has actually bound your |  |  | This is useful if you need to know to which port the OS has actually bound your | 
														
													
														
															
																|  |  | socket when calling the constructor or bindToPort with zero as the |  |  | socket when calling the constructor or bindToPort with zero as the | 
														
													
														
															
																|  |  | localPortNumber argument. Returns -1 if the function fails. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | localPortNumber argument. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  -1 if the function fails | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int getBoundPort() const noexcept; |  |  | int getBoundPort() const noexcept; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -85,7 +88,7 @@ public: | 
														
													
														
															
																|  |  | If timeOutMillisecs is 0, then this method will block until the operating system |  |  | If timeOutMillisecs is 0, then this method will block until the operating system | 
														
													
														
															
																|  |  | rejects the connection (which could take a long time). |  |  | rejects the connection (which could take a long time). | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns true if it succeeds. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true if it succeeds, false if otherwise | 
														
													
														
															
																|  |  | @see isConnected |  |  | @see isConnected | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool connect (const String& remoteHostname, |  |  | bool connect (const String& remoteHostname, | 
														
													
												
													
														
															
																|  | @@ -119,8 +122,8 @@ public: | 
														
													
														
															
																|  |  | If the timeout is < 0, it will wait forever, or else will give up after |  |  | If the timeout is < 0, it will wait forever, or else will give up after | 
														
													
														
															
																|  |  | the specified time. |  |  | the specified time. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | If the socket is ready on return, this returns 1. If it times-out before |  |  |  | 
														
													
														
															
																|  |  | the socket becomes ready, it returns 0. If an error occurs, it returns -1. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  1 if the socket is ready on return, 0 if it times-out before | 
														
													
														
															
																|  |  |  |  |  | the socket becomes ready, or -1 if an error occurs | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int waitUntilReady (bool readyForReading, int timeoutMsecs); |  |  | int waitUntilReady (bool readyForReading, int timeoutMsecs); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -131,7 +134,7 @@ public: | 
														
													
														
															
																|  |  | flag is false, the method will return as much data as is currently available |  |  | flag is false, the method will return as much data as is currently available | 
														
													
														
															
																|  |  | without blocking. |  |  | without blocking. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns the number of bytes read, or -1 if there was an error. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  the number of bytes read, or -1 if there was an error | 
														
													
														
															
																|  |  | @see waitUntilReady |  |  | @see waitUntilReady | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int read (void* destBuffer, int maxBytesToRead, |  |  | int read (void* destBuffer, int maxBytesToRead, | 
														
													
												
													
														
															
																|  | @@ -142,7 +145,7 @@ public: | 
														
													
														
															
																|  |  | Note that this method will block unless you have checked the socket is ready |  |  | Note that this method will block unless you have checked the socket is ready | 
														
													
														
															
																|  |  | for writing before calling it (see the waitUntilReady() method). |  |  | for writing before calling it (see the waitUntilReady() method). | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns the number of bytes written, or -1 if there was an error. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  the number of bytes written, or -1 if there was an error | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int write (const void* sourceBuffer, int numBytesToWrite); |  |  | int write (const void* sourceBuffer, int numBytesToWrite); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -156,8 +159,8 @@ public: | 
														
													
														
															
																|  |  | @param portNumber       the port number to listen on |  |  | @param portNumber       the port number to listen on | 
														
													
														
															
																|  |  | @param localHostName    the interface address to listen on - pass an empty |  |  | @param localHostName    the interface address to listen on - pass an empty | 
														
													
														
															
																|  |  | string to listen on all addresses |  |  | string to listen on all addresses | 
														
													
														
															
																|  |  | @returns    true if it manages to open the socket successfully. |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true if it manages to open the socket successfully | 
														
													
														
															
																|  |  | @see waitForNextConnection |  |  | @see waitForNextConnection | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool createListener (int portNumber, const String& localHostName = String()); |  |  | bool createListener (int portNumber, const String& localHostName = String()); | 
														
													
												
													
														
															
																|  | @@ -202,8 +205,7 @@ class JUCE_API  DatagramSocket  final | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | public: |  |  | public: | 
														
													
														
															
																|  |  | //============================================================================== |  |  | //============================================================================== | 
														
													
														
															
																|  |  | /** |  |  |  | 
														
													
														
															
																|  |  | Creates a datagram socket. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | /** Creates a datagram socket. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | You first need to bind this socket to a port with bindToPort if you intend to read |  |  | You first need to bind this socket to a port with bindToPort if you intend to read | 
														
													
														
															
																|  |  | from this socket. |  |  | from this socket. | 
														
													
												
													
														
															
																|  | @@ -223,8 +225,8 @@ public: | 
														
													
														
															
																|  |  | The localPortNumber is the port on which to bind this socket. If this value is 0, |  |  | The localPortNumber is the port on which to bind this socket. If this value is 0, | 
														
													
														
															
																|  |  | the port number is assigned by the operating system. |  |  | the port number is assigned by the operating system. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns    true on success; false may indicate that another socket is already bound |  |  |  | 
														
													
														
															
																|  |  | on the same port |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true on success; false may indicate that another socket is already bound | 
														
													
														
															
																|  |  |  |  |  | on the same port | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool bindToPort (int localPortNumber); |  |  | bool bindToPort (int localPortNumber); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -234,8 +236,9 @@ public: | 
														
													
														
															
																|  |  | as well. This is useful if you would like to bind your socket to a specific network |  |  | as well. This is useful if you would like to bind your socket to a specific network | 
														
													
														
															
																|  |  | adapter. Note that localAddress must be an IP address assigned to one of your |  |  | adapter. Note that localAddress must be an IP address assigned to one of your | 
														
													
														
															
																|  |  | network address otherwise this function will fail. |  |  | network address otherwise this function will fail. | 
														
													
														
															
																|  |  | @returns    true on success; false may indicate that another socket is already bound |  |  |  | 
														
													
														
															
																|  |  | on the same port |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true on success; false may indicate that another socket is already bound | 
														
													
														
															
																|  |  |  |  |  | on the same port | 
														
													
														
															
																|  |  | @see bindToPort(int localPortNumber), IPAddress::getAllAddresses |  |  | @see bindToPort(int localPortNumber), IPAddress::getAllAddresses | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool bindToPort (int localPortNumber, const String& localAddress); |  |  | bool bindToPort (int localPortNumber, const String& localAddress); | 
														
													
												
													
														
															
																|  | @@ -245,7 +248,8 @@ public: | 
														
													
														
															
																|  |  | This is useful if you need to know to which port the OS has actually bound your |  |  | This is useful if you need to know to which port the OS has actually bound your | 
														
													
														
															
																|  |  | socket when bindToPort was called with zero. |  |  | socket when bindToPort was called with zero. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Returns -1 if the socket didn't bind to any port yet or an error occurred. */ |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  -1 if the socket didn't bind to any port yet or an error occurred | 
														
													
														
															
																|  |  |  |  |  | */ | 
														
													
														
															
																|  |  | int getBoundPort() const noexcept; |  |  | int getBoundPort() const noexcept; | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | /** Returns the OS's socket handle that's currently open. */ |  |  | /** Returns the OS's socket handle that's currently open. */ | 
														
													
												
													
														
															
																|  | @@ -260,8 +264,8 @@ public: | 
														
													
														
															
																|  |  | If the timeout is < 0, it will wait forever, or else will give up after |  |  | If the timeout is < 0, it will wait forever, or else will give up after | 
														
													
														
															
																|  |  | the specified time. |  |  | the specified time. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | If the socket is ready on return, this returns 1. If it times-out before |  |  |  | 
														
													
														
															
																|  |  | the socket becomes ready, it returns 0. If an error occurs, it returns -1. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  1 if the socket is ready on return, 0 if it times-out before the | 
														
													
														
															
																|  |  |  |  |  | socket becomes ready, or -1 if an error occurs | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int waitUntilReady (bool readyForReading, int timeoutMsecs); |  |  | int waitUntilReady (bool readyForReading, int timeoutMsecs); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -272,7 +276,7 @@ public: | 
														
													
														
															
																|  |  | flag is false, the method will return as much data as is currently available |  |  | flag is false, the method will return as much data as is currently available | 
														
													
														
															
																|  |  | without blocking. |  |  | without blocking. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns the number of bytes read, or -1 if there was an error. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  the number of bytes read, or -1 if there was an error | 
														
													
														
															
																|  |  | @see waitUntilReady |  |  | @see waitUntilReady | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int read (void* destBuffer, int maxBytesToRead, |  |  | int read (void* destBuffer, int maxBytesToRead, | 
														
													
												
													
														
															
																|  | @@ -285,8 +289,8 @@ public: | 
														
													
														
															
																|  |  | flag is false, the method will return as much data as is currently available |  |  | flag is false, the method will return as much data as is currently available | 
														
													
														
															
																|  |  | without blocking. |  |  | without blocking. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns the number of bytes read, or -1 if there was an error. On a successful |  |  |  | 
														
													
														
															
																|  |  | result, the senderIPAddress value will be set to the IP of the sender. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  the number of bytes read, or -1 if there was an error. On a successful | 
														
													
														
															
																|  |  |  |  |  | result, the senderIPAddress value will be set to the IP of the sender | 
														
													
														
															
																|  |  | @see waitUntilReady |  |  | @see waitUntilReady | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int read (void* destBuffer, int maxBytesToRead, |  |  | int read (void* destBuffer, int maxBytesToRead, | 
														
													
												
													
														
															
																|  | @@ -298,7 +302,7 @@ public: | 
														
													
														
															
																|  |  | Note that this method will block unless you have checked the socket is ready |  |  | Note that this method will block unless you have checked the socket is ready | 
														
													
														
															
																|  |  | for writing before calling it (see the waitUntilReady() method). |  |  | for writing before calling it (see the waitUntilReady() method). | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | @returns the number of bytes written, or -1 if there was an error. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  the number of bytes written, or -1 if there was an error | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | int write (const String& remoteHostname, int remotePortNumber, |  |  | int write (const String& remoteHostname, int remotePortNumber, | 
														
													
														
															
																|  |  | const void* sourceBuffer, int numBytesToWrite); |  |  | const void* sourceBuffer, int numBytesToWrite); | 
														
													
												
													
														
															
																|  | @@ -306,8 +310,10 @@ public: | 
														
													
														
															
																|  |  | /** Closes the underlying socket object. |  |  | /** Closes the underlying socket object. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Closes the underlying socket object and aborts any read or write operations. |  |  | Closes the underlying socket object and aborts any read or write operations. | 
														
													
														
															
																|  |  | Note that all other methods will return an error after this call. This |  |  |  | 
														
													
														
															
																|  |  | method is useful if another thread is blocking in a read/write call and you |  |  |  | 
														
													
														
															
																|  |  |  |  |  | Note that all other methods will return an error after this call and the object | 
														
													
														
															
																|  |  |  |  |  | cannot be re-used. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | This method is useful if another thread is blocking in a read/write call and you | 
														
													
														
															
																|  |  | would like to abort the read/write thread. Simply deleting the socket |  |  | would like to abort the read/write thread. Simply deleting the socket | 
														
													
														
															
																|  |  | object without calling shutdown may cause a race-condition where the read/write |  |  | object without calling shutdown may cause a race-condition where the read/write | 
														
													
														
															
																|  |  | returns just before the socket is deleted and the subsequent read/write would |  |  | returns just before the socket is deleted and the subsequent read/write would | 
														
													
												
													
														
															
																|  | @@ -319,17 +325,20 @@ public: | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | //============================================================================== |  |  | //============================================================================== | 
														
													
														
															
																|  |  | /** Join a multicast group. |  |  | /** Join a multicast group. | 
														
													
														
															
																|  |  | @returns true if it succeeds. |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true if it succeeds | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool joinMulticast (const String& multicastIPAddress); |  |  | bool joinMulticast (const String& multicastIPAddress); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | /** Leave a multicast group. |  |  | /** Leave a multicast group. | 
														
													
														
															
																|  |  | @returns true if it succeeds. |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true if it succeeds | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool leaveMulticast (const String& multicastIPAddress); |  |  | bool leaveMulticast (const String& multicastIPAddress); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | /** Enables or disables multicast loopback. |  |  | /** Enables or disables multicast loopback. | 
														
													
														
															
																|  |  | @returns true if it succeeds. |  |  |  | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true if it succeeds | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool setMulticastLoopbackEnabled (bool enableLoopback); |  |  | bool setMulticastLoopbackEnabled (bool enableLoopback); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | @@ -340,7 +349,7 @@ public: | 
														
													
														
															
																|  |  | Do not use this if your socket handles sensitive data as it could be |  |  | Do not use this if your socket handles sensitive data as it could be | 
														
													
														
															
																|  |  | read by any, possibly malicious, third-party apps. |  |  | read by any, possibly malicious, third-party apps. | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | Returns true on success. |  |  |  | 
														
													
														
															
																|  |  |  |  |  | @returns  true on success | 
														
													
														
															
																|  |  | */ |  |  | */ | 
														
													
														
															
																|  |  | bool setEnablePortReuse (bool enabled); |  |  | bool setEnablePortReuse (bool enabled); | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
												
													
														
															
																|  | 
 |