Backed out 3 changesets (bug 1307501) for xpcshell failures a=backout

Backed out changeset b05f555321b7 (bug 1307501)
Backed out changeset 58e4d007f2a5 (bug 1307501)
Backed out changeset 113aa49cbb98 (bug 1307501)
This commit is contained in:
Wes Kocher 2016-10-04 14:55:29 -07:00
Родитель 22c349bd43
Коммит a2cfb52087
3 изменённых файлов: 161 добавлений и 56 удалений

Просмотреть файл

@ -146,7 +146,28 @@ static const char *kPrefJavaMIME = "plugin.java.mime";
static const char *kPrefUnloadPluginTimeoutSecs = "dom.ipc.plugins.unloadTimeoutSecs"; static const char *kPrefUnloadPluginTimeoutSecs = "dom.ipc.plugins.unloadTimeoutSecs";
static const uint32_t kDefaultPluginUnloadingTimeout = 30; static const uint32_t kDefaultPluginUnloadingTimeout = 30;
static const char *kPluginRegistryVersion = "0.18"; // Version of cached plugin info
// 0.01 first implementation
// 0.02 added caching of CanUnload to fix bug 105935
// 0.03 changed name, description and mime desc from string to bytes, bug 108246
// 0.04 added new mime entry point on Mac, bug 113464
// 0.05 added new entry point check for the default plugin, bug 132430
// 0.06 strip off suffixes in mime description strings, bug 53895
// 0.07 changed nsIRegistry to flat file support for caching plugins info
// 0.08 mime entry point on MachO, bug 137535
// 0.09 the file encoding is changed to UTF-8, bug 420285
// 0.10 added plugin versions on appropriate platforms, bug 427743
// 0.11 file name and full path fields now store expected values on all platforms, bug 488181
// 0.12 force refresh due to quicktime pdf claim fix, bug 611197
// 0.13 add architecture and list of invalid plugins, bug 616271
// 0.14 force refresh due to locale comparison fix, bug 611296
// 0.15 force refresh due to bug in reading Java plist MIME data, bug 638171
// 0.16 version bump to avoid importing the plugin flags in newer versions
// 0.17 added flag on whether plugin is loaded from an XPI
// The current plugin registry version (and the maximum version we know how to read)
static const char *kPluginRegistryVersion = "0.17";
// The minimum registry version we know how to read
static const char *kMinimumRegistryVersion = "0.9";
static const char kDirectoryServiceContractID[] = "@mozilla.org/file/directory_service;1"; static const char kDirectoryServiceContractID[] = "@mozilla.org/file/directory_service;1";
@ -2075,7 +2096,7 @@ nsPluginHost::AddPluginTag(nsPluginTag* aPluginTag)
static bool static bool
PluginInfoIsFlash(const nsPluginInfo& info) PluginInfoIsFlash(const nsPluginInfo& info)
{ {
if (strcmp(info.fName, "Shockwave Flash") != 0) { if (strcmp(info.fDescription, "Shockwave Flash") != 0) {
return false; return false;
} }
for (uint32_t i = 0; i < info.fVariantCount; ++i) { for (uint32_t i = 0; i < info.fVariantCount; ++i) {
@ -2969,6 +2990,10 @@ nsPluginHost::ReadPluginInfo()
const long PLUGIN_REG_MIMETYPES_ARRAY_SIZE = 12; const long PLUGIN_REG_MIMETYPES_ARRAY_SIZE = 12;
const long PLUGIN_REG_MAX_MIMETYPES = 1000; const long PLUGIN_REG_MAX_MIMETYPES = 1000;
// we need to import the legacy flags from the plugin registry once
const bool pluginStateImported =
Preferences::GetDefaultBool("plugin.importedState", false);
nsresult rv; nsresult rv;
nsCOMPtr<nsIProperties> directoryService(do_GetService(NS_DIRECTORY_SERVICE_CONTRACTID,&rv)); nsCOMPtr<nsIProperties> directoryService(do_GetService(NS_DIRECTORY_SERVICE_CONTRACTID,&rv));
@ -3060,67 +3085,128 @@ nsPluginHost::ReadPluginInfo()
if (PL_strcmp(values[0], "Version")) if (PL_strcmp(values[0], "Version"))
return rv; return rv;
// If we're reading an old registry, ignore it // kPluginRegistryVersion
if (!strcmp(values[1], kPluginRegistryVersion)) { int32_t vdiff = mozilla::CompareVersions(values[1], kPluginRegistryVersion);
mozilla::Version version(values[1]);
// If this is a registry from some future version then don't attempt to read it
if (vdiff > 0)
return rv; return rv;
// If this is a registry from before the minimum then don't attempt to read it
if (version < kMinimumRegistryVersion)
return rv;
// Registry v0.10 and upwards includes the plugin version field
bool regHasVersion = (version >= "0.10");
// Registry v0.13 and upwards includes the architecture
if (version >= "0.13") {
char* archValues[6];
if (!reader.NextLine()) {
return rv;
}
// ArchLiteral, Architecture
if (2 != reader.ParseLine(archValues, 2)) {
return rv;
}
// ArchLiteral
if (PL_strcmp(archValues[0], "Arch")) {
return rv;
}
nsCOMPtr<nsIXULRuntime> runtime = do_GetService("@mozilla.org/xre/runtime;1");
if (!runtime) {
return rv;
}
nsAutoCString arch;
if (NS_FAILED(runtime->GetXPCOMABI(arch))) {
return rv;
}
// If this is a registry from a different architecture then don't attempt to read it
if (PL_strcmp(archValues[1], arch.get())) {
return rv;
}
} }
char* archValues[6]; // Registry v0.13 and upwards includes the list of invalid plugins
if (!reader.NextLine()) { const bool hasInvalidPlugins = (version >= "0.13");
return rv;
}
// ArchLiteral, Architecture // Registry v0.16 and upwards always have 0 for their plugin flags, prefs are used instead
if (2 != reader.ParseLine(archValues, 2)) { const bool hasValidFlags = (version < "0.16");
return rv;
}
// ArchLiteral // Registry v0.17 and upwards store whether the plugin comes from an XPI.
if (PL_strcmp(archValues[0], "Arch")) { const bool hasFromExtension = (version >= "0.17");
return rv;
}
nsCOMPtr<nsIXULRuntime> runtime = do_GetService("@mozilla.org/xre/runtime;1"); #if defined(XP_MACOSX)
if (!runtime) { const bool hasFullPathInFileNameField = false;
return rv; #else
} const bool hasFullPathInFileNameField = (version < "0.11");
#endif
nsAutoCString arch;
if (NS_FAILED(runtime->GetXPCOMABI(arch))) {
return rv;
}
// If this is a registry from a different architecture then don't attempt to read it
if (PL_strcmp(archValues[1], arch.get())) {
return rv;
}
if (!ReadSectionHeader(reader, "PLUGINS")) if (!ReadSectionHeader(reader, "PLUGINS"))
return rv; return rv;
while (reader.NextLine()) { while (reader.NextLine()) {
if (*reader.LinePtr() == '[') { const char *filename;
const char *fullpath;
nsAutoCString derivedFileName;
if (hasInvalidPlugins && *reader.LinePtr() == '[') {
break; break;
} }
const char* filename = reader.LinePtr(); if (hasFullPathInFileNameField) {
if (!reader.NextLine()) fullpath = reader.LinePtr();
return rv; if (!reader.NextLine())
return rv;
// try to derive a file name from the full path
if (fullpath) {
nsCOMPtr<nsIFile> file = do_CreateInstance("@mozilla.org/file/local;1");
file->InitWithNativePath(nsDependentCString(fullpath));
file->GetNativeLeafName(derivedFileName);
filename = derivedFileName.get();
} else {
filename = nullptr;
}
const char* fullpath = reader.LinePtr(); // skip the next line, useless in this version
if (!reader.NextLine()) if (!reader.NextLine())
return rv; return rv;
} else {
filename = reader.LinePtr();
if (!reader.NextLine())
return rv;
fullpath = reader.LinePtr();
if (!reader.NextLine())
return rv;
}
const char *version; const char *version;
version = reader.LinePtr(); if (regHasVersion) {
if (!reader.NextLine()) version = reader.LinePtr();
if (!reader.NextLine())
return rv;
} else {
version = "0";
}
// lastModifiedTimeStamp|canUnload|tag.mFlag|fromExtension // lastModifiedTimeStamp|canUnload|tag.mFlag|fromExtension
if (4 != reader.ParseLine(values, 4)) const int count = hasFromExtension ? 4 : 3;
if (reader.ParseLine(values, count) != count)
return rv; return rv;
int64_t lastmod = nsCRT::atoll(values[0]); // If this is an old plugin registry mark this plugin tag to be refreshed
bool fromExtension = atoi(values[3]); int64_t lastmod = (vdiff == 0) ? nsCRT::atoll(values[0]) : -1;
uint32_t tagflag = atoi(values[2]);
bool fromExtension = false;
if (hasFromExtension) {
fromExtension = atoi(values[3]);
}
if (!reader.NextLine()) if (!reader.NextLine())
return rv; return rv;
@ -3196,6 +3282,10 @@ nsPluginHost::ReadPluginInfo()
delete [] heapalloced; delete [] heapalloced;
// Import flags from registry into prefs for old registry versions // Import flags from registry into prefs for old registry versions
if (hasValidFlags && !pluginStateImported) {
tag->ImportFlagsToPrefs(tagflag);
}
MOZ_LOG(nsPluginLogging::gPluginLog, PLUGIN_LOG_BASIC, MOZ_LOG(nsPluginLogging::gPluginLog, PLUGIN_LOG_BASIC,
("LoadCachedPluginsInfo : Loading Cached plugininfo for %s\n", tag->FileName().get())); ("LoadCachedPluginsInfo : Loading Cached plugininfo for %s\n", tag->FileName().get()));
@ -3209,29 +3299,34 @@ nsPluginHost::ReadPluginInfo()
// On Android we always want to try to load a plugin again (Flash). Bug 935676. // On Android we always want to try to load a plugin again (Flash). Bug 935676.
#ifndef MOZ_WIDGET_ANDROID #ifndef MOZ_WIDGET_ANDROID
if (!ReadSectionHeader(reader, "INVALID")) { if (hasInvalidPlugins) {
return rv; if (!ReadSectionHeader(reader, "INVALID")) {
}
while (reader.NextLine()) {
const char *fullpath = reader.LinePtr();
if (!reader.NextLine()) {
return rv; return rv;
} }
const char *lastModifiedTimeStamp = reader.LinePtr(); while (reader.NextLine()) {
int64_t lastmod = nsCRT::atoll(lastModifiedTimeStamp); const char *fullpath = reader.LinePtr();
if (!reader.NextLine()) {
return rv;
}
RefPtr<nsInvalidPluginTag> invalidTag = new nsInvalidPluginTag(fullpath, lastmod); const char *lastModifiedTimeStamp = reader.LinePtr();
int64_t lastmod = (vdiff == 0) ? nsCRT::atoll(lastModifiedTimeStamp) : -1;
invalidTag->mNext = mInvalidPlugins; RefPtr<nsInvalidPluginTag> invalidTag = new nsInvalidPluginTag(fullpath, lastmod);
if (mInvalidPlugins) {
mInvalidPlugins->mPrev = invalidTag; invalidTag->mNext = mInvalidPlugins;
if (mInvalidPlugins) {
mInvalidPlugins->mPrev = invalidTag;
}
mInvalidPlugins = invalidTag;
} }
mInvalidPlugins = invalidTag;
} }
#endif #endif
// flip the pref so we don't import the legacy flags again
Preferences::SetBool("plugin.importedState", true);
return NS_OK; return NS_OK;
} }

Просмотреть файл

@ -757,6 +757,13 @@ nsPluginTag::GetNiceName(nsACString & aResult)
return NS_OK; return NS_OK;
} }
void nsPluginTag::ImportFlagsToPrefs(uint32_t flags)
{
if (!(flags & NS_PLUGIN_FLAG_ENABLED)) {
SetPluginState(ePluginState_Disabled);
}
}
NS_IMETHODIMP NS_IMETHODIMP
nsPluginTag::GetBlocklistState(uint32_t *aResult) nsPluginTag::GetBlocklistState(uint32_t *aResult)
{ {

Просмотреть файл

@ -151,6 +151,9 @@ public:
PluginState GetPluginState(); PluginState GetPluginState();
void SetPluginState(PluginState state); void SetPluginState(PluginState state);
// import legacy flags from plugin registry into the preferences
void ImportFlagsToPrefs(uint32_t flag);
bool HasSameNameAndMimes(const nsPluginTag *aPluginTag) const; bool HasSameNameAndMimes(const nsPluginTag *aPluginTag) const;
const nsCString& GetNiceFileName() override; const nsCString& GetNiceFileName() override;