mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +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)
148 lines
3.6 KiB
C++
148 lines
3.6 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et 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 "nsMacUtilsImpl.h"
|
|
|
|
#include <CoreFoundation/CoreFoundation.h>
|
|
|
|
NS_IMPL_ISUPPORTS(nsMacUtilsImpl, nsIMacUtils)
|
|
|
|
nsresult
|
|
nsMacUtilsImpl::GetArchString(nsAString& aArchString)
|
|
{
|
|
if (!mBinaryArchs.IsEmpty()) {
|
|
aArchString.Assign(mBinaryArchs);
|
|
return NS_OK;
|
|
}
|
|
|
|
aArchString.Truncate();
|
|
|
|
bool foundPPC = false,
|
|
foundX86 = false,
|
|
foundPPC64 = false,
|
|
foundX86_64 = false;
|
|
|
|
CFBundleRef mainBundle = ::CFBundleGetMainBundle();
|
|
if (!mainBundle) {
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
CFArrayRef archList = ::CFBundleCopyExecutableArchitectures(mainBundle);
|
|
if (!archList) {
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
CFIndex archCount = ::CFArrayGetCount(archList);
|
|
for (CFIndex i = 0; i < archCount; i++) {
|
|
CFNumberRef arch =
|
|
static_cast<CFNumberRef>(::CFArrayGetValueAtIndex(archList, i));
|
|
|
|
int archInt = 0;
|
|
if (!::CFNumberGetValue(arch, kCFNumberIntType, &archInt)) {
|
|
::CFRelease(archList);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
if (archInt == kCFBundleExecutableArchitecturePPC) {
|
|
foundPPC = true;
|
|
} else if (archInt == kCFBundleExecutableArchitectureI386) {
|
|
foundX86 = true;
|
|
} else if (archInt == kCFBundleExecutableArchitecturePPC64) {
|
|
foundPPC64 = true;
|
|
} else if (archInt == kCFBundleExecutableArchitectureX86_64) {
|
|
foundX86_64 = true;
|
|
}
|
|
}
|
|
|
|
::CFRelease(archList);
|
|
|
|
// The order in the string must always be the same so
|
|
// don't do this in the loop.
|
|
if (foundPPC) {
|
|
mBinaryArchs.AppendLiteral("ppc");
|
|
}
|
|
|
|
if (foundX86) {
|
|
if (!mBinaryArchs.IsEmpty()) {
|
|
mBinaryArchs.Append('-');
|
|
}
|
|
mBinaryArchs.AppendLiteral("i386");
|
|
}
|
|
|
|
if (foundPPC64) {
|
|
if (!mBinaryArchs.IsEmpty()) {
|
|
mBinaryArchs.Append('-');
|
|
}
|
|
mBinaryArchs.AppendLiteral("ppc64");
|
|
}
|
|
|
|
if (foundX86_64) {
|
|
if (!mBinaryArchs.IsEmpty()) {
|
|
mBinaryArchs.Append('-');
|
|
}
|
|
mBinaryArchs.AppendLiteral("x86_64");
|
|
}
|
|
|
|
aArchString.Assign(mBinaryArchs);
|
|
|
|
return (aArchString.IsEmpty() ? NS_ERROR_FAILURE : NS_OK);
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsMacUtilsImpl::GetIsUniversalBinary(bool* aIsUniversalBinary)
|
|
{
|
|
if (NS_WARN_IF(!aIsUniversalBinary)) {
|
|
return NS_ERROR_INVALID_ARG;
|
|
}
|
|
*aIsUniversalBinary = false;
|
|
|
|
nsAutoString archString;
|
|
nsresult rv = GetArchString(archString);
|
|
if (NS_FAILED(rv)) {
|
|
return rv;
|
|
}
|
|
|
|
// The delimiter char in the arch string is '-', so if that character
|
|
// is in the string we know we have multiple architectures.
|
|
*aIsUniversalBinary = (archString.Find("-") > -1);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsMacUtilsImpl::GetArchitecturesInBinary(nsAString& aArchString)
|
|
{
|
|
return GetArchString(aArchString);
|
|
}
|
|
|
|
// True when running under binary translation (Rosetta).
|
|
NS_IMETHODIMP
|
|
nsMacUtilsImpl::GetIsTranslated(bool* aIsTranslated)
|
|
{
|
|
#ifdef __ppc__
|
|
static bool sInitialized = false;
|
|
|
|
// Initialize sIsNative to 1. If the sysctl fails because it doesn't
|
|
// exist, then translation is not possible, so the process must not be
|
|
// running translated.
|
|
static int32_t sIsNative = 1;
|
|
|
|
if (!sInitialized) {
|
|
size_t sz = sizeof(sIsNative);
|
|
sysctlbyname("sysctl.proc_native", &sIsNative, &sz, nullptr, 0);
|
|
sInitialized = true;
|
|
}
|
|
|
|
*aIsTranslated = !sIsNative;
|
|
#else
|
|
// Translation only exists for ppc code. Other architectures aren't
|
|
// translated.
|
|
*aIsTranslated = false;
|
|
#endif
|
|
|
|
return NS_OK;
|
|
}
|