Add DDG as a pre-installed search provider for Fennec

VERIFIED FIXED in Firefox 33

Status

()

VERIFIED FIXED
6 years ago
2 years ago

People

(Reporter: deb, Assigned: mfinkle)

Tracking

(Blocks: 2 bugs, {productwanted})

Trunk
Firefox 36
productwanted
Points:
---
Dependency tree / graph

Firefox Tracking Flags

(firefox33 fixed, firefox34 verified, firefox35 verified, firefox36 verified)

Details

Attachments

(4 attachments, 4 obsolete attachments)

93.02 KB, image/png
Details
5.11 KB, patch
mfinkle
: review+
mconnor
: feedback+
RyanVM
: checkin+
Details | Diff | Splinter Review
5.27 KB, patch
mfinkle
: review+
RyanVM
: checkin+
Details | Diff | Splinter Review
1023 bytes, patch
mfinkle
: review+
RyanVM
: checkin+
Details | Diff | Splinter Review
DDG (duckduckgo.com) is an increasingly popular search engine whose focus is on protecting & respecting user privacy. It seems sensible to give our users this choice an a pre-installed option.
Keywords: productwanted
We will actively look into getting them included in our list. Stay tuned.
Blocks: 863469
Duping forward
Status: NEW → RESOLVED
Last Resolved: 4 years ago
Resolution: --- → DUPLICATE
Duplicate of bug: 1064863
Status: RESOLVED → REOPENED
Resolution: DUPLICATE → ---
Blocks: 1064837
I'd like to include DDG in the 3rd search provider listing. In general, the search order would be:

1. Default (general) search engine
2. Second general search engine
3. DuckDuckGo
4+. others in alphabetical order

Locales will be in a following comment.
Group: mozilla-employee-confidential
Please include DDG in the third position for the following countries. 
* en-US
* Australia
* Austria
* Canada
* France
* Germany
* Mexico
* New Zealand
* Spain
* United Kingdom

[NB - an expanded list is requested where DDG is included in the 'Firefox Confidential' add-on to reach a larger number of markets where DDG has little current presence. An expanded set of countries may be included in the future in-code. We also have limited screen real estate and will likely need to revamp our UX to view the available search engines - or reduce the number - since we're already bumping some off-screen now.]
Taking a thread from bug 1064863, I agree with the approach to promote the DDG search plug-in for certain locales instead of adding it to this add-on.
ARG - wrong window = more spam. Sorry :/

SO: the 'Firefox Privacy Coach' add-on (formally known as firefox confidential) will not include an expanded list of locales in which DDG is supported, but rather be promoted to a set of locales we would like to target.
Created attachment 8512330 [details] [diff] [review]
ddg v0.1

Here is a basic patch, built from the duckduckgo.xml plugin found in several other locales already:
http://mxr.mozilla.org/l10n-central/find?text=&string=duckduckgo.xml

This patch does not change the ordering of the engines.
Assignee: nobody → mark.finkle
Attachment #8512330 - Flags: review?(margaret.leibovic)
Attachment #8512330 - Flags: feedback?(gavin.sharp)
Attachment #8512330 - Flags: feedback?(mconnor)
Created attachment 8512331 [details]
fennec-ddg.png

Screenshot from a Galaxy Nexus
Attachment #8512331 - Attachment is patch: false
Attachment #8512331 - Attachment mime type: text/plain → image/png
Comment on attachment 8512330 [details] [diff] [review]
ddg v0.1

Review of attachment 8512330 [details] [diff] [review]:
-----------------------------------------------------------------

Looks fine to me. Leaving the review of the specific parameters up to mconnor.
Attachment #8512330 - Flags: review?(margaret.leibovic) → review+
Comment on attachment 8512330 [details] [diff] [review]
ddg v0.1

I think you should use the same ddg.xml as attachment 8512367 [details] [diff] [review] (desktop version), with parameter tweaks if needed, and extra images removed.

Based on our discussion on IRC, it seems to me like this patch will only add it to en-US, which I don't think is what you want?
Attachment #8512330 - Flags: feedback?(gavin.sharp) → feedback-
(In reply to :Gavin Sharp [email: gavin@gavinsharp.com] from comment #10)
> Comment on attachment 8512330 [details] [diff] [review]
> ddg v0.1
> 
> I think you should use the same ddg.xml as attachment 8512367 [details] [diff] [review]
> [diff] [review] (desktop version), with parameter tweaks if needed, and
> extra images removed.

OK, but remember that this XML is already used in several locales shipped with Fennec. What are the benefits of using the other XML?

> Based on our discussion on IRC, it seems to me like this patch will only add
> it to en-US, which I don't think is what you want?

I have no idea how to add it to other locales without getting those locale to manually add it themselves. If someone else wants to pick this up and figure that out, feel free. Otherwise, we get en-US, the 8 other locales that already ship ddg and any others that want to manually add it.
I would like to ensure the following locales have DDG included: 
* en-US
* fr
* de
* es-MX
* es-ES
* en-GB

As well as any l10n group that had specifically included it as per their search customization guidelines. we can revisit adding further locales as the program moves forward. 

We can also promote DDG as a search add-on for many other countries as well via our snippet rotation on fennec. Adding Arcadio so he can add it to his list of snippet asks.
(In reply to Mark Finkle (:mfinkle) from comment #11)
> OK, but remember that this XML is already used in several locales shipped
> with Fennec. What are the benefits of using the other XML?

Consistency with desktop. Cross-product consistency seems more important to me than intra-product consistency between locales, but I don't feel that strongly.

(In reply to Mark Finkle (:mfinkle) from comment #11)
> I have no idea how to add it to other locales without getting those locale
> to manually add it themselves. If someone else wants to pick this up and
> figure that out, feel free. Otherwise, we get en-US, the 8 other locales
> that already ship ddg and any others that want to manually add it.

Not my call to make.

Given that, no need to block on my feedback-.
FYI - discussed today and Jeff will take a look at hand-holding the inclusion of DDG in the other locales. NO specification for search order: the top 3 general providers will be in the top 3 positions, and the rest of the engines will be listed in alphabetical order.
Note: if en-US is going to have a DDG xml file, we'll remove the l10n ones (build system should already pick up en-US file as soon as the file pops up in en-US).
Does DDG perform the locale redirect on their side?
(In reply to Jeff Beatty [:gueroJeff] from comment #16)
> Does DDG perform the locale redirect on their side?

Yes. You can add parameters for country to tweak results, but we're using the same XML file on both desktop and mobile at the moment for all locales with DDG
https://duckduckgo.com/params
How public can we be about adding DDG to these locales? Can we use bugzilla to organize the work, or do we need to stick to private email?
Flags: needinfo?(krudnitski)
we cannot be public yet until mconnor gives the go-ahead.

Please stick to private email for the time being, until mconnor gives the thumbs' up.
Flags: needinfo?(krudnitski) → needinfo?(mconnor)
What versions are we targeting for the locales and what is the timeline to have the changes landed in channel?
Flags: needinfo?(krudnitski)
I find it hard to believe that our desktop trick doesn't work for android. That said, I don't understand what Joey's timestamp foo in the Makefile is supposed to do.

If we can't do a en-US-only fix adding locales, adding DDG to android should be at the very tail end of the things we're doing. We have two folks on PTO (me and Jeff) and we need our back-ups to do other decade stuff.
(In reply to Axel Hecht [:Pike] from comment #21)
> I find it hard to believe that our desktop trick doesn't work for android.
> That said, I don't understand what Joey's timestamp foo in the Makefile is
> supposed to do.

Yeah, I'll dig into this.  There's no reason this can't work.
(In reply to Nick Alexander :nalexander from comment #22)
> (In reply to Axel Hecht [:Pike] from comment #21)
> > I find it hard to believe that our desktop trick doesn't work for android.
> > That said, I don't understand what Joey's timestamp foo in the Makefile is
> > supposed to do.
> 
> Yeah, I'll dig into this.  There's no reason this can't work.

A little investigation suggests there are multiple pieces here.  The bit that duplicates desktop appears to work fine.  I'll attach a patch; if you rebuild in just the right way (or clobber build), you'll find the JAR manifests are updated exactly as you'd expect.

However, I believe mfinkle's claim that it "didn't work" (https://bugzilla.mozilla.org/show_bug.cgi?id=1061736#c39) is also correct because we

* package list.txt into the omni.ja, and the written list.txt doesn't include the hacked in entry;
* and we write search engine properties into Android's raw/resources to use from Java (see Bug 1065306).

I'm going to try to understand how desktop handles the first, because I wrote the second and am confident we can bend it to our wills.
To address the n?: we shouldn't be public, lest we spoil messaging, but we can now engage with localizers if needed through email or cc on confidential bugs.
Flags: needinfo?(mconnor)
Thanks Nick, good catch. We're reading list.txt in http://mxr.mozilla.org/mozilla-central/source/mobile/android/search/java/org/mozilla/search/providers/SearchEngineManager.java#132. It's packaged in jar.mn, we could either package a built/hacked version, or modify the java file to add createEngine('ddg') manually?

I guess packaging a patched list.txt would be cleaner.
(In reply to Jeff Beatty [:gueroJeff] from comment #20)
> What versions are we targeting for the locales and what is the timeline to
> have the changes landed in channel?

This is going live in 33.1. I couldn't tell you when the actual changes need to be included in channel.

Jenn - can you help here (and also communicate out the locales we're targeting for DDG so that comms and marketing are aware and can promote accordingly)?
Flags: needinfo?(krudnitski) → needinfo?(jchaulk)
To clarify, the deadline for 33.1 l10n changes was October 3rd, same as for desktop. That's because it's the same release mechanics and risk profiles that went into that decision. For the addition of ddg to localized builds in 33.1 we'll need an en-US only patch.
Just to add, from lmandel's comment in the stand-up, they're ok with Android building later, as it's somewhat easier than the desktop build.  Tentative target for this is Friday, but some further how-to discussion is needed before confirming.
Flags: needinfo?(jchaulk)
Comment on attachment 8512330 [details] [diff] [review]
ddg v0.1

Needs the following T values. (We can skip adding SA stuff for 33.1, but we'll likely want that breakout anyway.)

Tablet	Search Activity	ftsa
	Address Bar	ftas
		
Phone	Search Activity	fpsa
	Address Bar	fpas
Attachment #8512330 - Flags: feedback?(mconnor) → feedback+
(In reply to Jenn Chaulk from comment #28)
> Just to add, from lmandel's comment in the stand-up, they're ok with Android
> building later, as it's somewhat easier than the desktop build.  Tentative
> target for this is Friday, but some further how-to discussion is needed
> before confirming.

There seems to be a consensus that we want to do this at the build system level and not at the l10n wrangling level.  If we are doing this at the build system level, I need to know *yesterday* 'cuz these l10n repack things are very hard to get right the first time.
Nick - We can try to make something at the build system level work for the listed locales in comment 12.

I am updating the patch to add the codes.
Created attachment 8513698 [details] [diff] [review]
ddg v0.2

Now with "t" values for Tablet and Phone. f? to mconnor.
Attachment #8512330 - Attachment is obsolete: true
Attachment #8513698 - Flags: review+
Attachment #8513698 - Flags: feedback?(mconnor)
Attachment #8513698 - Flags: feedback?(mconnor) → feedback+
The desktop changeset has been linked and is public and is being talked about https://hg.mozilla.org/releases/mozilla-release/rev/0746f89a5aee, is there any reason to keep this bug confidential?
Created attachment 8514552 [details] [diff] [review]
Part 1: Add ddg searchplugin to every locale. r=glandium

The purpose of this patch is to append the ddg searchplugin to every
locale in a multi-locale build.  This is a temporary hack for a single
release; for this release, we don't care about burning single-locale
repacks.

I don't think we support finding a localized JAR resource --
like (%searchplugins/list.txt) -- from the object directory directly, so:

* I made the list filename depend on the locale;
* generated the locale-dependent list at build time;
* had the JAR include the list from the object directory.

glandium: can you comment on this approach?  This all produces a
reasonable looking omni.ja locally (both en-US and multilocales).  I'm
about to test on device (my local build appears to be in a bad state
so I need to rebase).  If this is a reasonable way forward, I'll
follow-up to allow only appending the extra ddg entry to a subset of
locales.
Attachment #8514552 - Flags: feedback?(mh+mozilla)
Comment on attachment 8514552 [details] [diff] [review]
Part 1: Add ddg searchplugin to every locale. r=glandium

>diff --git a/mobile/locales/en-US/searchplugins/ddg.xml b/mobile/locales/en-US/searchplugins/ddg.xml

Just know that you can't use this ddg.xml file. It's the desktop one.
(In reply to Mark Finkle (:mfinkle) from comment #35)
> Comment on attachment 8514552 [details] [diff] [review]
> Part 1: Add ddg searchplugin to every locale. r=glandium
> 
> >diff --git a/mobile/locales/en-US/searchplugins/ddg.xml b/mobile/locales/en-US/searchplugins/ddg.xml
> 
> Just know that you can't use this ddg.xml file. It's the desktop one.

Thanks, good to know.  I think we should call this duckduckgo.xml too, so that the localized version wins (in those locales where it is present).  Does anybody know what happens if list.txt contains a duplicate entry?  It would be really nice if it just took the first entry or something like that.  If not, we can find a way to filter list.txt so that each line is unique.
It took me a while to get a multi-locale build set up, but this hack produced ddg in the awesomebar suggetions and the settings, both in en-US and in de.
Comment on attachment 8514552 [details] [diff] [review]
Part 1: Add ddg searchplugin to every locale. r=glandium

Review of attachment 8514552 [details] [diff] [review]:
-----------------------------------------------------------------

::: mobile/locales/Makefile.in
@@ +100,5 @@
>    $(NULL)
>  
> +$(plugin_file): $(plugin_source_file) $(call mkdir_deps,$(dir $(plugin_file)))
> +	cat $(plugin_source_file) > $@
> +	printf 'ddg\n' >> $@

That's an strange way to do "echo ddg >> $@"

::: mobile/locales/jar.mn
@@ +6,5 @@
>  
>  @AB_CD@.jar:
>  % locale browser @AB_CD@ %locale/@AB_CD@/browser/
>    locale/@AB_CD@/browser/region.properties        (%chrome/region.properties)
> +  locale/@AB_CD@/browser/searchplugins/list.txt   (overrides/list_@AB_CD@.txt)

If that works, it's thanks to luck. You don't have any dependency between the handling of jar.mn and the list file.
You should just add this line to the search-jar that is created in Makefile.in.
Attachment #8514552 - Flags: feedback?(mh+mozilla) → feedback-
(In reply to Nick Alexander :nalexander from comment #37)
> It took me a while to get a multi-locale build set up, but this hack
> produced ddg in the awesomebar suggetions and the settings, both in en-US
> and in de.

Can you test one of the locales that already have DDG? Locales: cy, es-MX, gd, ml, ta.

If there's a conflict, the en-US version should be picked, since it has more parameters than the localized one (the localized one is actually identical for all locales, locale detection is done on DDG's side).
Created attachment 8515175 [details] [diff] [review]
Part 1: Add ddg searchplugin to every locale. r=glandium

The purpose of this patch is to append the ddg searchplugin to every
locale in a multi-locale build.  This is a temporary hack for a single
release; for this release, we don't care about burning single-locale
repacks.

I don't think we support finding a localized JAR resource --
like (%searchplugins/list.txt) -- from the object directory directly, so:

* I made the list filename depend on the locale;
* generated the locale-dependent list at build time;
* had the generated JAR include the list from the object directory.

glandium: I completely missed that the in-tree manifest and the
generated manifest were merged.  Here's a version that just adds the
generated list.txt to the generated manifest.  Better?

As for the comment about "weird way to echo" -- it's not just echoing,
it's copying the input file too.  In the next patch, we'll sort and
uniq the list.txt as well.  (Search engine ordering already comes from
elsewhere, namely region.properties.)
Attachment #8514552 - Attachment is obsolete: true
Attachment #8515175 - Flags: feedback?(mh+mozilla)
Comment on attachment 8515175 [details] [diff] [review]
Part 1: Add ddg searchplugin to every locale. r=glandium

Review of attachment 8515175 [details] [diff] [review]:
-----------------------------------------------------------------

::: mobile/locales/Makefile.in
@@ +100,5 @@
>    $(NULL)
>  
> +$(plugin_file): $(plugin_source_file) $(call mkdir_deps,$(dir $(plugin_file)))
> +	cat $(plugin_source_file) > $@
> +	printf 'ddg\n' >> $@

still a weird way to do "echo ddg >> $@". That is, why use printf with a string ending with \n, when you can just use echo.

::: mobile/locales/en-US/searchplugins/ddg.xml
@@ +3,5 @@
> +  <ShortName>DuckDuckGo</ShortName>
> +  <Description>Search DuckDuckGo</Description>
> +  <InputEncoding>UTF-8</InputEncoding>
> +  <Image height="16" width="16"></Image>
> +  <Image height="26" width="65"></Image>

Do you actually need the non-icon images?
Attachment #8515175 - Flags: feedback?(mh+mozilla) → feedback+
I don't think mobile wants the 26x65 and 52x130 images, those are just used by desktop for the new tab page. The 16x16 image includes a 32px version (assuming you're using the same one as bug 1061736).
I think we're missing 2 different patches here. Mobile shouldn't have 26x65 and 52x130 images, and should have a flat 32px icon, not a 16+32 .ico

The patch with mconnor's f+ should be correct though.

Comment 44

4 years ago
just one comment about landing the patches.  lets make sure there is time in the schedule to test all the locales that might be affected by any landings, and time to respond with back out or other response before the hard shipping deadline.

testing should be quick to bring up the locale, look at search options, verify all the icons and such look ok, check to see we get right search codes and such going to ddg, and that we get back some expected and resonable search results.

although this should be pretty quick it might need to be done 30 some odd times depending on the scope of the patch and the possible number of locales that are in the code path of the changes.
OK, I'm going to prepare an updated version of the build hacking approach, but with the alternate plugin referenced above.
Comment on attachment 8513698 [details] [diff] [review]
ddg v0.2

Approval Request Comment
[Feature/regressing bug #]: Moziversary
[User impact if declined]: No DDG in Fx33.1
[Describe test coverage new/current, TBPL]: Did a local build and it worked
[Risks and why]: Some risk since this will be used in a multi-locale build, but it should only affect en-US
[String/UUID change made/needed]: None. Just adds the DDG engine to en-US

This is our worst-case, fallback. I want to land it so we can get some testing and be ready. If a better fix comes in, we can update it on mozilla-release.
Attachment #8513698 - Flags: approval-mozilla-release?
Created attachment 8516197 [details] [diff] [review]
Add ddg searchplugin to every locale. r=glandium

The purpose of this patch is to union a set of extra search plugins into
the set of search plugins for a specific subset of locales in a
multi-locale build.  This is a temporary hack for a single release; for
this release, we don't care about burning single-locale repacks.

I don't think we support finding a localized JAR resource --
like (%searchplugins/list.txt) -- from the object directory directly, so:

* I made the list filename depend on the locale;
* generated the locale-dependent list at build time;
* had the generated JAR include the list from the object directory.

I wasn't sure how to pipe the original list and possible additions
through sort and uniq, so I wrote a temporary file.

This patch is against fx-team, although I expect it to apply to
mozilla-release.  This version includes the duckduckgo.xml from
mfinkle's patch against mozilla-release.
Attachment #8515175 - Attachment is obsolete: true
Attachment #8516197 - Flags: review?(mh+mozilla)
(In reply to Francesco Lodolo [:flod] from comment #39)
> (In reply to Nick Alexander :nalexander from comment #37)
> > It took me a while to get a multi-locale build set up, but this hack
> > produced ddg in the awesomebar suggetions and the settings, both in en-US
> > and in de.
> 
> Can you test one of the locales that already have DDG? Locales: cy, es-MX,
> gd, ml, ta.
> 
> If there's a conflict, the en-US version should be picked, since it has more
> parameters than the localized one (the localized one is actually identical
> for all locales, locale detection is done on DDG's side).

My new patch ignores most of those locales: it only tries to insert for kar's list of 6 in [1].  As for the conflict ordering, that ordering is determined by the existing jar packaging code, which I think favours the non-en-US locale without regard to the file contents.

If we really, really, really want to override the locale's duckduckgo.xml, then we rename en-US's duckduckgo.xml to ddg.xml; strip duckduckgo from locale's list.txt forcefully; and insert ddg.  That seems like bad behaviour.

[1] https://bugzilla.mozilla.org/show_bug.cgi?id=883254#c12
Comment on attachment 8516197 [details] [diff] [review]
Add ddg searchplugin to every locale. r=glandium

Review of attachment 8516197 [details] [diff] [review]:
-----------------------------------------------------------------

::: mobile/locales/Makefile.in
@@ +106,5 @@
> +  en-US \
> +  es-ES \
> +  es-MX \
> +  fr \
> +  $(NULL)

Why do we need a hardcoded list of locales? It feels wrong to have one, but maybe there's a reason, but nothing in this patch tells me what it is.

If there's only a list of 6 locales that need ddg, why not simply land the necessary changes in their l10n repo? It also seems to be quicker to do than to get the right hacks in the already complicated l10n code here.

@@ +111,5 @@
> +
> +# These additional search plugins will be merged into the set of search plugins
> +# for each locale listed in extra_search_plugin_locales.
> +extra_search_plugins := \
> +  duckduckgo \

Seems to me this is an unnecessary extra layer of indirection. Do you really expect to have other additional search plugins that would apply to the exact same list of locales?

@@ +120,5 @@
> +	$(if $(filter $(AB_CD),$(extra_search_plugin_locales)),\
> +		$(foreach plugin,$(extra_search_plugins),echo $(plugin) >> $@;))
> +
> +$(plugin_file): $(plugin_file).tmp
> +	cat $< | sort | uniq > $@

sort $< | uniq > $@
Or even sort -u $< > $@ if that works everywhere.

That said, you don't need the temporary file:

$(plugin_file): ...
    (cat $(plugin_source_file) ; \
     $(if $(filter..... echo $(plugin);)) \
    ) | sort -u > $@

So, you're throwing away the order in that file. Is that important? Will that actually affect the engines order, or is the order handled some other way in fennec?

@@ +158,5 @@
>  	$(TOUCH) $@
>  
>  include $(topsrcdir)/config/rules.mk
>  
> +$(search-jar): $(GLOBAL_DEPS)

Add that to search-jar-preqs instead.
Attachment #8516197 - Flags: review?(mh+mozilla) → feedback-
glandium: I haven't provided a lot of context here, but the bigger picture is that this is landing on mozilla-release for November to Remember stuff only.  Hence, no time to work with localizers; hence, duplicated lists of additional locales and additional engines.  Yes, this is not idea; no, I did not make this call.
(In reply to Mike Hommey [:glandium] from comment #49)

Some answers, I hope...

> @@ +106,5 @@
> > +  en-US \
> > +  es-ES \
> > +  es-MX \
> > +  fr \
> > +  $(NULL)
> 
> Why do we need a hardcoded list of locales? It feels wrong to have one, but
> maybe there's a reason, but nothing in this patch tells me what it is.

See comment 12

> If there's only a list of 6 locales that need ddg, why not simply land the
> necessary changes in their l10n repo? It also seems to be quicker to do than
> to get the right hacks in the already complicated l10n code here.

The will be the approach used for the "ride the trains" patch, but for landing on mozilla-release, the general approach was to override. Desktop is doing that too, just to all the locales. Personally, Nick and I don't like the overriding approach, but it's the 11th hour.

> > +# These additional search plugins will be merged into the set of search plugins
> > +# for each locale listed in extra_search_plugin_locales.
> > +extra_search_plugins := \
> > +  duckduckgo \
> 
> Seems to me this is an unnecessary extra layer of indirection. Do you really
> expect to have other additional search plugins that would apply to the exact
> same list of locales?

Not exactly sure the context of the question, but we know that es-MX has a duckduckgo.xml file with different settings in it. 

> > +$(plugin_file): $(plugin_file).tmp
> > +	cat $< | sort | uniq > $@
> 
> sort $< | uniq > $@
> Or even sort -u $< > $@ if that works everywhere.
> 
> That said, you don't need the temporary file:
> 
> $(plugin_file): ...
>     (cat $(plugin_source_file) ; \
>      $(if $(filter..... echo $(plugin);)) \
>     ) | sort -u > $@
> 
> So, you're throwing away the order in that file. Is that important? Will
> that actually affect the engines order, or is the order handled some other
> way in fennec?

list.txt does not control the engine order. A region.properties file is used to select the order of the top 3 engines, the rest are displayed alphabetical, provided by nsSearchService.js
(In reply to Mike Hommey [:glandium] from comment #49)
> Comment on attachment 8516197 [details] [diff] [review]
> Add ddg searchplugin to every locale. r=glandium
> 
> Review of attachment 8516197 [details] [diff] [review]:
> -----------------------------------------------------------------
> 
> ::: mobile/locales/Makefile.in
> @@ +106,5 @@
> > +  en-US \
> > +  es-ES \
> > +  es-MX \
> > +  fr \
> > +  $(NULL)
> 
> Why do we need a hardcoded list of locales? It feels wrong to have one, but
> maybe there's a reason, but nothing in this patch tells me what it is.
> 
> If there's only a list of 6 locales that need ddg, why not simply land the
> necessary changes in their l10n repo? It also seems to be quicker to do than
> to get the right hacks in the already complicated l10n code here.

We've been told that it's not feasible to get l10n co-ordination in the time allotted :(
 
> @@ +111,5 @@
> > +
> > +# These additional search plugins will be merged into the set of search plugins
> > +# for each locale listed in extra_search_plugin_locales.
> > +extra_search_plugins := \
> > +  duckduckgo \
> 
> Seems to me this is an unnecessary extra layer of indirection. Do you really
> expect to have other additional search plugins that would apply to the exact
> same list of locales?

No, we don't expect others, but it's as easy to make the variables clear as not.

> @@ +120,5 @@
> > +	$(if $(filter $(AB_CD),$(extra_search_plugin_locales)),\
> > +		$(foreach plugin,$(extra_search_plugins),echo $(plugin) >> $@;))
> > +
> > +$(plugin_file): $(plugin_file).tmp
> > +	cat $< | sort | uniq > $@
> 
> sort $< | uniq > $@
> Or even sort -u $< > $@ if that works everywhere.
> 
> That said, you don't need the temporary file:
> 
> $(plugin_file): ...
>     (cat $(plugin_source_file) ; \
>      $(if $(filter..... echo $(plugin);)) \
>     ) | sort -u > $@

I will do this; it's the kind of thing I knew existed but wasn't familiar enough to bother to get it right.

> So, you're throwing away the order in that file. Is that important? Will
> that actually affect the engines order, or is the order handled some other
> way in fennec?

The order is handled by region.properties; list.txt is treated as a set and then alphabetically ordered in code.

> @@ +158,5 @@
> >  	$(TOUCH) $@
> >  
> >  include $(topsrcdir)/config/rules.mk
> >  
> > +$(search-jar): $(GLOBAL_DEPS)
> 
> Add that to search-jar-preqs instead.

Will do.
(In reply to Nick Alexander :nalexander from comment #50)
> Hence, no time to work with localizers

All is in mercurial, right? why would that need to be "worked with localizers"? What about the D in DVCS?
Not the right time or place to argue about L10N infrastructure.
I'm not arguing, I'm trying to understand.
Not the best place/time for that either :)
In light of the circumstances, I owe glandium an apology: I have asked him for feedback and review, on an accelerated schedule, of a patch that is doing something that is not our standard policy, and I haven't provided much context into why I'm pursuing the approach I am.

I think the best way forward is to have glandium comment on the technical approach of the patch -- that is, does it achieve what it claims to, in a reasonable manner -- and to simultaneously continue the policy discussion.  Others (gavin, mfinkle, kar) are much better positioned to explain how we came to this position than I am.
(In reply to Nick Alexander :nalexander from comment #57)
> I think the best way forward is to have glandium comment on the technical
> approach of the patch

... which I've already done.
(In reply to :Gavin Sharp [email: gavin@gavinsharp.com] from comment #56)
> Not the best place/time for that either :)

At least answer this: what would break if someone landed the necessary changes to http://hg.mozilla.org/releases/l10n/mozilla-release ?
Shipping changesets are signed off on Beta one week before the end of the cycle, that happened a month ago. We don't accept updates on release channel, no clue of what would break in automation with stuff landing on release but not on the other branches.

Add to this that both l10n people in charge of sign-offs are on PTO this week, and we need a build by Thursday for QA (at least from last daily stand-up) to understand if this works.
Created attachment 8516810 [details] [diff] [review]
Add duckduckgo searchplugin to certain locales. f=glandium,r=mfinkle

The purpose of this patch is to union a set of extra search plugins into
the set of search plugins for a specific subset of locales in a
multi-locale build.  This is a temporary hack for a single release; for
this release, we don't care about burning single-locale repacks.

I don't think we support finding a localized JAR resource --
like (%searchplugins/list.txt) -- from the object directory directly, so:

* I made the list filename depend on the locale;
* generated the locale-dependent list at build time;
* had the generated JAR include the list from the object directory.

This version incorporates the last of glandium's suggestions.  This
patch applies cleanly to mozilla-release (over-top of mfinkle's
earlier patch).
Attachment #8516197 - Attachment is obsolete: true
Attachment #8516810 - Flags: review?(mark.finkle)
Comment on attachment 8516810 [details] [diff] [review]
Add duckduckgo searchplugin to certain locales. f=glandium,r=mfinkle

Approval Request Comment

[Feature/regressing bug #]: DDG for #fx10 ship date.

[User impact if declined]: won't hit the date for shipping DDG to listed locales.

[Describe test coverage new/current, TBPL]: tested locally.  Due to both the branch (release) and infrastructure limitations, I do not know of a way to produce a multilocale release build with these changes for testing.

[Risks and why]: I guess we could completely bust searchplugins across all locales, but that'll be pretty easy to test.  This is very unlikely.

[String/UUID change made/needed]: none.
Attachment #8516810 - Flags: approval-mozilla-release?

Comment 63

4 years ago
re:  > [Describe test coverage new/current, TBPL]:

see comment 44.  someone should do that before shipping the bits next week.
Comment on attachment 8516810 [details] [diff] [review]
Add duckduckgo searchplugin to certain locales. f=glandium,r=mfinkle

Looks sane and local builds seem OK. We need to build this using the multi-locale infra in order to do real testing.

r+, let's get it started.
Attachment #8516810 - Flags: review?(mark.finkle) → review+
(In reply to chris hofmann from comment #63)
> re:  > [Describe test coverage new/current, TBPL]:
> 
> see comment 44.  someone should do that before shipping the bits next week.

Defintely. Once the moz-release build candidate is ready, we can start testing.
Attachment #8513698 - Flags: approval-mozilla-release? → approval-mozilla-release+
Attachment #8516810 - Flags: approval-mozilla-release? → approval-mozilla-release+
OK, we have r and a.  Who lands?  Who kicks off the builds?
Flags: needinfo?(lmandel)
Ryan - Can you help with landing these changes on m-r?

Once the changes have landed and the ci builds on treeherder go green, Sylvestre, Lukas, or I will kick off the 33.1 build. (Depends on when the ci build completes.)
Flags: needinfo?(lmandel) → needinfo?(ryanvm)
Keywords: checkin-needed
Anyone want to toss up an m-r multi build in the interim?
Depends on: 1094401
Download the candidate build1 APK and unpacking, I see that the list.txt files look healthy but the omni.ja is missing the first locale-specific XML file.  I conclude that the first line of the generated JAR manifest is incorrect; I think that the initial printf is not printing a new line after it on the buildbots.  (Not clear why this prints a new line for me on Mac OS X, but my JAR manifests look fine.)

So we get manifests like:

en-US.jar:locale/en-US/browser/searchplugins/amazondotcom.xml (amazondotcom.xml)
 locale/en-US/browser/searchplugins/bing.xml (bing.xml)

and perhaps those parse correctly but drop the badly formed entry.

The relevant printf is at https://hg.mozilla.org/releases/mozilla-release/rev/9b6e72bafd64#l1.72 -- it's always been there, but I changed later printfs to be echos, changing the new lines a little.

I think we'll need to change that first printf to an echo and respin.  Sorry, folks.  I'll post a patch tomorrow.
Created attachment 8517913 [details] [diff] [review]
Follow-up to add extra new line in JAR manifest. r=trivial
Comment on attachment 8517913 [details] [diff] [review]
Follow-up to add extra new line in JAR manifest. r=trivial

Thanks Nick
Attachment #8517913 - Flags: review+
Comment on attachment 8513698 [details] [diff] [review]
ddg v0.2

So we have them in the other branches.
Attachment #8513698 - Flags: approval-mozilla-beta+
Attachment #8513698 - Flags: approval-mozilla-aurora+
Attachment #8516810 - Flags: approval-mozilla-beta+
Attachment #8516810 - Flags: approval-mozilla-aurora+
Depends on: 1094644
Attachment #8517913 - Flags: approval-mozilla-release+
Attachment #8517913 - Flags: approval-mozilla-beta+
Attachment #8517913 - Flags: approval-mozilla-aurora+
Comment on attachment 8517913 [details] [diff] [review]
Follow-up to add extra new line in JAR manifest. r=trivial

Landed on both default and the MOBILE331_2014110511_RELBRANCH to be safe.

https://hg.mozilla.org/releases/mozilla-release/rev/61a0bf70b88a
https://hg.mozilla.org/releases/mozilla-release/rev/ff5068a4aa0c
Attachment #8517913 - Flags: checkin+
Attachment #8513698 - Flags: checkin+
Attachment #8516810 - Flags: checkin+
I'll need to check a multi-locale build2 candidate; if somebody could flag me when it's ready, I'd appreciate it.  (I don't know the release candidate schedule.)
Whiteboard: no uplift (Sunday)
sledru, others: these patches should *not* land anywhere other than mozilla-release.  This is a hack to work around our schedule.
(In reply to Nick Alexander :nalexander from comment #76)
> sledru, others: these patches should *not* land anywhere other than
> mozilla-release.  This is a hack to work around our schedule.

Note: we'll need to figure out what to do after Nov 10 for both mobile and desktop. 
I don't think we can add the searchplugin on Beta (less than one week before sign-off), which means people will lose DDG on Nov 25 if we don't do anything.
(In reply to Francesco Lodolo [:flod] from comment #77)
> (In reply to Nick Alexander :nalexander from comment #76)
> > sledru, others: these patches should *not* land anywhere other than
> > mozilla-release.  This is a hack to work around our schedule.
> 
> Note: we'll need to figure out what to do after Nov 10 for both mobile and
> desktop. 
> I don't think we can add the searchplugin on Beta (less than one week before
> sign-off), which means people will lose DDG on Nov 25 if we don't do
> anything.

flod: well spotted.  I guess we need to land on mozilla-beta?  All the way to mozilla-aurora?  At that point we might just want to ship this as a feature that we shouldn't use; at least then it will get tested.
I don't think it's needed on mozilla-aurora (we have the entire next Beta cycle to fix it), but it makes sense to have on mozilla-beta.
(In reply to Nick Alexander :nalexander from comment #75)
> I'll need to check a multi-locale build2 candidate; if somebody could flag
> me when it's ready, I'd appreciate it.  (I don't know the release candidate
> schedule.)

I have manually verified that the missing search plugin XML files are present in build2.  I can't say if that addresses AaronMT's tickets -- I think those are separate -- but at least I believe our APK is OK.
(In reply to Nick Alexander :nalexander from comment #80)

> I have manually verified that the missing search plugin XML files are
> present in build2.  I can't say if that addresses AaronMT's tickets -- I
> think those are separate -- but at least I believe our APK is OK.

Thanks Nick. Great job!
(In reply to Nick Alexander :nalexander from comment #80)
> (In reply to Nick Alexander :nalexander from comment #75)
> > I'll need to check a multi-locale build2 candidate; if somebody could flag
> > me when it's ready, I'd appreciate it.  (I don't know the release candidate
> > schedule.)
> 
> I have manually verified that the missing search plugin XML files are
> present in build2.  I can't say if that addresses AaronMT's tickets -- I
> think those are separate -- but at least I believe our APK is OK.

Yep, bug 1094644 resolved with https://bugzilla.mozilla.org/attachment.cgi?id=8517913 

We're testing and recording here: https://mozqa.etherpad.mozilla.org/testing-fennec-33-1
(In reply to Francesco Lodolo [:flod] from comment #77)
> (In reply to Nick Alexander :nalexander from comment #76)
> > sledru, others: these patches should *not* land anywhere other than
> > mozilla-release.  This is a hack to work around our schedule.
> 
> Note: we'll need to figure out what to do after Nov 10 for both mobile and
> desktop. 
> I don't think we can add the searchplugin on Beta (less than one week before
> sign-off), which means people will lose DDG on Nov 25 if we don't do
> anything.

Looks like Desktop landed their patches on Aurora and Beta. I assume we should do the same.
Desktop is adding the searchplugin to all locales, Mobile only to a very small set of locales, not sure if the same should apply.
Per IRC discussion, I landed mfinkle's patch across all branches and nalexander's patch (with follow-up folded in) only on beta.

https://hg.mozilla.org/integration/mozilla-inbound/rev/368e58076230
https://hg.mozilla.org/releases/mozilla-aurora/rev/c6004c071eb8
https://hg.mozilla.org/releases/mozilla-beta/rev/f1c1658280cd
https://hg.mozilla.org/releases/mozilla-beta/rev/32c3529eb076
status-firefox34: --- → affected
status-firefox35: --- → affected
status-firefox36: --- → affected
Whiteboard: no uplift (Sunday)
status-firefox34: affected → fixed
status-firefox35: affected → fixed
https://hg.mozilla.org/mozilla-central/rev/368e58076230
Status: REOPENED → RESOLVED
Last Resolved: 4 years ago4 years ago
status-firefox36: affected → fixed
Resolution: --- → FIXED
Target Milestone: --- → Firefox 36
Depends on: 1097171
Group: mozilla-employee-confidential
DuckDuckGo is present in the installed search engines list on Firefox for Android 34 Beta 10 on the following new locales: de, en-Gb, en-US, es-ES, fr.
So, i will mark status-firefox34 to verified.
status-firefox34: fixed → verified
DuckDuckGo is present in the installed search engines list for the following new locales:
34 Release: de, en-GB, en-US, es-ES, fr 
35 Beta 1 Build 2: de, en-US, es-ES, fr 
36.0a2 Aurora (2014-12-04): de, en-GB, en-US, es-ES, fr 
37.0a1 Nightly (2014-12-04): ): de, en-US, es-ES, fr

So:
-DuckDuckGo is missing for en-GB on 35 Beta 1 build1 and build2
-en-GB locale is missing from Menu -> Settings -> Language on latest Nightly.
Are these 2 issues expected?
> -DuckDuckGo is missing for en-GB on 35 Beta 1 build1 and build2
Sort of expected, that's a sign-off problem. The change from bug 1090394 is there on the default branch
http://hg.mozilla.org/releases/l10n/mozilla-beta/en-GB/graph

In Firefox 34 we shipped DDG with a build hack, for fx35 we need a more recent sign-off, which didn't happen yet.

> -en-GB locale is missing from Menu -> Settings -> Language on latest Nightly.
That's expected, we don't have as many locales on nightly
http://hg.mozilla.org/mozilla-central/file/default/mobile/android/locales/maemo-locales
Based on Comment 12, DuckDuckGo is present in the installed search engines list on Firefox for Android 36 Beta 6 with the following locales: de, en-Gb, en-US, es-ES, fr, es-MX
So, I will mark status-firefox 36 to verified.
status-firefox36: fixed → verified
DuckDuckGo is present in the installed search engines list on Firefox for Android 35.0.1 with the following locales: de, en-Gb, en-US, es-ES, fr, es-MX
Status: RESOLVED → VERIFIED
status-firefox35: fixed → verified
You need to log in before you can comment on or make changes to this bug.