| Index: chrome/android/java/src/org/chromium/chrome/browser/preferences/website/SingleWebsitePreferences.java
|
| diff --git a/chrome/android/java/src/org/chromium/chrome/browser/preferences/website/SingleWebsitePreferences.java b/chrome/android/java/src/org/chromium/chrome/browser/preferences/website/SingleWebsitePreferences.java
|
| index 31bd7c056e943f05e2eed2ea75b0ad16b174b1fa..87c48bdd7719fc190c69cb9061581ef60a6a9ea6 100644
|
| --- a/chrome/android/java/src/org/chromium/chrome/browser/preferences/website/SingleWebsitePreferences.java
|
| +++ b/chrome/android/java/src/org/chromium/chrome/browser/preferences/website/SingleWebsitePreferences.java
|
| @@ -35,12 +35,15 @@ public class SingleWebsitePreferences extends PreferenceFragment
|
| implements DialogInterface.OnClickListener, OnPreferenceChangeListener,
|
| OnPreferenceClickListener {
|
| // SingleWebsitePreferences expects either EXTRA_SITE (a Website) or
|
| - // EXTRA_ADDRESS (a WebsiteAddress) to be present (but not both). If
|
| + // EXTRA_ORIGIN (a WebsiteAddress) to be present (but not both). If
|
| // EXTRA_SITE is present, the fragment will display the permissions in that
|
| - // Website object. If EXTRA_ADDRESS is present, the fragment will find all
|
| - // permissions for that website address and display those.
|
| + // Website object. If EXTRA_ORIGIN is present, the fragment will find all
|
| + // permissions for that website address and display those. If EXTRA_LOCATION
|
| + // is present, the fragment will add a Location toggle, even if the site
|
| + // specifies no Location permission.
|
| public static final String EXTRA_SITE = "org.chromium.chrome.preferences.site";
|
| public static final String EXTRA_ORIGIN = "org.chromium.chrome.preferences.origin";
|
| + public static final String EXTRA_LOCATION = "org.chromium.chrome.preferences.location";
|
|
|
| // Preference keys, see single_website_preferences.xml
|
| // Headings:
|
| @@ -276,7 +279,15 @@ public class SingleWebsitePreferences extends PreferenceFragment
|
| } else if (PREF_JAVASCRIPT_PERMISSION.equals(preference.getKey())) {
|
| setUpListPreference(preference, mSite.getJavaScriptPermission());
|
| } else if (PREF_LOCATION_ACCESS.equals(preference.getKey())) {
|
| - setUpListPreference(preference, mSite.getGeolocationPermission());
|
| + Object locationAllowed = getArguments().getSerializable(EXTRA_LOCATION);
|
| + if (mSite.getGeolocationPermission() == null && locationAllowed != null) {
|
| + String origin = mSite.getAddress().getOrigin();
|
| + mSite.setGeolocationInfo(new GeolocationInfo(origin, origin));
|
| + setUpListPreference(preference, (boolean) locationAllowed
|
| + ? ContentSetting.ALLOW : ContentSetting.BLOCK);
|
| + } else {
|
| + setUpListPreference(preference, mSite.getGeolocationPermission());
|
| + }
|
| } else if (PREF_MIC_CAPTURE_PERMISSION.equals(preference.getKey())) {
|
| setUpListPreference(preference, mSite.getMicrophonePermission());
|
| } else if (PREF_MIDI_SYSEX_PERMISSION.equals(preference.getKey())) {
|
|
|