1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
// Copyright 2015 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/android/jni_android.h"
#include "chrome/browser/android/content/web_contents_factory_data_deleter.h"
#include "chrome/browser/browser_process.h"
#include "chrome/browser/profiles/profile.h"
#include "content/public/browser/site_instance.h"
#include "content/public/browser/storage_partition_config.h"
#include "content/public/browser/web_contents.h"
// Must come after all headers that specialize FromJniType() / ToJniType().
#include "chrome/browser/android/content/jni_headers/WebContentsFactory_jni.h"
using base::android::JavaParamRef;
using base::android::ScopedJavaLocalRef;
static ScopedJavaLocalRef<jobject> JNI_WebContentsFactory_CreateWebContents(
JNIEnv* env,
Profile* profile,
jboolean initially_hidden,
jboolean initialize_renderer,
jboolean uses_platform_autofill,
jlong j_target_network,
const JavaParamRef<jthrowable>& j_creator_location) {
content::WebContents::CreateParams params(profile);
params.initially_hidden = static_cast<bool>(initially_hidden);
params.initially_use_platform_autofill = uses_platform_autofill;
params.desired_renderer_state =
static_cast<bool>(initialize_renderer)
? content::WebContents::CreateParams::
kInitializeAndWarmupRendererProcess
: content::WebContents::CreateParams::kOkayToHaveRendererProcess;
params.target_network = j_target_network;
params.java_creator_location = j_creator_location;
// Ownership is passed into java, and then to TabAndroid::InitWebContents.
return content::WebContents::Create(params).release()->GetJavaWebContents();
}
static ScopedJavaLocalRef<jobject>
JNI_WebContentsFactory_CreateWebContentsWithSeparateStoragePartitionForExperiment(
JNIEnv* env,
Profile* profile,
const JavaParamRef<jthrowable>& j_creator_location) {
auto partition_config = content::StoragePartitionConfig::Create(
profile,
/*partition_domain=*/"MayLaunchUrlUsesSeparateStoragePartitionDomain",
/*partition_name=*/"1", /*in_memory=*/true);
auto site_instance = content::SiteInstance::CreateForFixedStoragePartition(
profile, GURL(), partition_config);
content::WebContents::CreateParams params =
content::WebContents::CreateParams(profile, std::move(site_instance));
params.initially_hidden = true;
// Equivalent to `initialize_renderer` == true in
// `JNI_WebContentsFactory_CreateWebContents`.
params.desired_renderer_state =
content::WebContents::CreateParams::kInitializeAndWarmupRendererProcess;
params.java_creator_location = j_creator_location;
// Ownership is passed into java, and then to TabAndroid::InitWebContents.
auto web_contents = content::WebContents::Create(params);
// StoragePartitions don't usually get deleted until the
// BrowserContext/Profile is shutdown but we want to tie this one's to the
// lifetime of the WebContents. To do so we'll use an observer to manually
// delete all the partition's data which has the same effect.
// WebContentsFactoryDataDeleter owns itself and is also bound to
// `web_contents` lifetime by observing WebContentsDestroyed().
new WebContentsFactoryDataDeleter(
web_contents.get(),
web_contents->GetSiteInstance()->GetStoragePartitionConfig());
return web_contents.release()->GetJavaWebContents();
}
|