mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:18:48 +00:00
13934d9866
- Bug 1184996 (Part 1) - Create decoders with a DecoderFactory. r=tn (dacf21ed2) - Bug 1184996 (Part 2) - Clean up RasterImage's decoding API. r=tn (c127af0b3) - Bug 1184996 (Part 3) - Replace all remaining references to 'size decodes' with 'metadata decodes'. r=tn (3744e5df4) - Bug 1184996 (Part 4) - Forbid instantiation of decoders except via DecoderFactory. r=tn (588d56d84) - No bug - Remove extra printf left over from bug 1127618. r=smaug (b02f7bfe1) - Bug 1187386 (Part 1) - Make most decoder state private. r=tn (328dbc605) - Bug 1187386 (Part 2) - Rework decoder code to avoid calling Decode::GetImage(). r=tn (9a94096f9) - Bug 1187386 (Part 3) - Don't destroy Decoder::mImage if Decoder::mImage is null. r=tn (cbb6738cd) - Bug 1187386 (Part 4) - Make imgFrame::SetOptimizable() callable from off-main-thread. r=tn (f03478b28) - Bug 1187386 (Part 5) - Merge Decoder::SetSizeOnImage() into ImageMetadata::SetOnImage(). r=tn (8afb5d4a3) - Bug 1033090 - Truncate a large URI in the user message about it. r=seth (7bd4b447b) - Bug 1187386 (Part 6) - Merge Decoder::Finish() and RasterImage::OnDecodingComplete() into RasterImage::FinalizeDecoder(). r=tn (f342dd5db) - Bug 1181863 (Part 1) - Add support for reading from nsIInputStreams directly to SourceBuffer. r=tn (74748dad9) - Bug 1181863 (Part 2) - Add ImageOps::DecodeToSurface() to allow image decoding without involving any main-thread-only objects. r=tn (25b86eb50) - Bug 1181863 (Part 3) - Add tests for DecodeToSurface(). r=tn (9506eb2f6) - Bug 1181863 - Part 4: Fix the build bustage (aee05bdc9) - Bug 1187546 - Make it possible to ask image decoders to only decode the first frame. r=tn (1beeeefb6) - Bug 1191100 - Remove XPIDL signature comments in .cpp files. r=ehsan (ee75fe3b5)
153 lines
3.2 KiB
C++
153 lines
3.2 KiB
C++
/* vim: et ts=2 sw=2 tw=80
|
|
*/
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "nsNetAddr.h"
|
|
#include "nsString.h"
|
|
#include "mozilla/net/DNS.h"
|
|
|
|
using namespace mozilla::net;
|
|
|
|
NS_IMPL_ISUPPORTS(nsNetAddr, nsINetAddr)
|
|
|
|
/* Makes a copy of |addr| */
|
|
nsNetAddr::nsNetAddr(NetAddr* addr)
|
|
{
|
|
NS_ASSERTION(addr, "null addr");
|
|
mAddr = *addr;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetFamily(uint16_t *aFamily)
|
|
{
|
|
switch(mAddr.raw.family) {
|
|
case AF_INET:
|
|
*aFamily = nsINetAddr::FAMILY_INET;
|
|
break;
|
|
case AF_INET6:
|
|
*aFamily = nsINetAddr::FAMILY_INET6;
|
|
break;
|
|
#if defined(XP_UNIX)
|
|
case AF_LOCAL:
|
|
*aFamily = nsINetAddr::FAMILY_LOCAL;
|
|
break;
|
|
#endif
|
|
default:
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetAddress(nsACString & aAddress)
|
|
{
|
|
switch(mAddr.raw.family) {
|
|
/* PR_NetAddrToString can handle INET and INET6, but not LOCAL. */
|
|
case AF_INET:
|
|
aAddress.SetCapacity(kIPv4CStrBufSize);
|
|
NetAddrToString(&mAddr, aAddress.BeginWriting(), kIPv4CStrBufSize);
|
|
aAddress.SetLength(strlen(aAddress.BeginReading()));
|
|
break;
|
|
case AF_INET6:
|
|
aAddress.SetCapacity(kIPv6CStrBufSize);
|
|
NetAddrToString(&mAddr, aAddress.BeginWriting(), kIPv6CStrBufSize);
|
|
aAddress.SetLength(strlen(aAddress.BeginReading()));
|
|
break;
|
|
#if defined(XP_UNIX)
|
|
case AF_LOCAL:
|
|
aAddress.Assign(mAddr.local.path);
|
|
break;
|
|
#endif
|
|
// PR_AF_LOCAL falls through to default when not XP_UNIX
|
|
default:
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetPort(uint16_t *aPort)
|
|
{
|
|
switch(mAddr.raw.family) {
|
|
case AF_INET:
|
|
*aPort = ntohs(mAddr.inet.port);
|
|
break;
|
|
case AF_INET6:
|
|
*aPort = ntohs(mAddr.inet6.port);
|
|
break;
|
|
#if defined(XP_UNIX)
|
|
case AF_LOCAL:
|
|
// There is no port number for local / connections.
|
|
return NS_ERROR_NOT_AVAILABLE;
|
|
#endif
|
|
default:
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetFlow(uint32_t *aFlow)
|
|
{
|
|
switch(mAddr.raw.family) {
|
|
case AF_INET6:
|
|
*aFlow = ntohl(mAddr.inet6.flowinfo);
|
|
break;
|
|
case AF_INET:
|
|
#if defined(XP_UNIX)
|
|
case AF_LOCAL:
|
|
#endif
|
|
// only for IPv6
|
|
return NS_ERROR_NOT_AVAILABLE;
|
|
default:
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetScope(uint32_t *aScope)
|
|
{
|
|
switch(mAddr.raw.family) {
|
|
case AF_INET6:
|
|
*aScope = ntohl(mAddr.inet6.scope_id);
|
|
break;
|
|
case AF_INET:
|
|
#if defined(XP_UNIX)
|
|
case AF_LOCAL:
|
|
#endif
|
|
// only for IPv6
|
|
return NS_ERROR_NOT_AVAILABLE;
|
|
default:
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetIsV4Mapped(bool *aIsV4Mapped)
|
|
{
|
|
switch(mAddr.raw.family) {
|
|
case AF_INET6:
|
|
*aIsV4Mapped = IPv6ADDR_IS_V4MAPPED(&mAddr.inet6.ip);
|
|
break;
|
|
case AF_INET:
|
|
#if defined(XP_UNIX)
|
|
case AF_LOCAL:
|
|
#endif
|
|
// only for IPv6
|
|
return NS_ERROR_NOT_AVAILABLE;
|
|
default:
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP nsNetAddr::GetNetAddr(NetAddr *aResult) {
|
|
memcpy(aResult, &mAddr, sizeof(mAddr));
|
|
return NS_OK;
|
|
}
|
|
|