| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 /* This Source Code Form is subject to the terms of the Mozilla Public | 1 /* This Source Code Form is subject to the terms of the Mozilla Public |
| 2 * License, v. 2.0. If a copy of the MPL was not distributed with this | 2 * License, v. 2.0. If a copy of the MPL was not distributed with this |
| 3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ | 3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
| 4 | 4 |
| 5 (function() { | 5 (function() { |
| 6 var platformVersion = null; | 6 var platformVersion = null; |
| 7 var application = null; | 7 var application = null; |
| 8 var applicationVersion; | 8 var applicationVersion; |
| 9 | 9 |
| 10 var regexp = /(\S+)\/(\S+)(?:\s*\(.*?\))?/g; | 10 var regexp = /(\S+)\/(\S+)(?:\s*\(.*?\))?/g; |
|
kzar
2015/12/15 17:26:00
Nit: More descriptive name would be nice, perhaps
Sebastian Noack
2015/12/15 17:31:31
Well, the context here is limitted. And after all
| |
| 11 var match; | 11 var match; |
| 12 | 12 |
| 13 while (match = regexp.exec(navigator.userAgent)) | 13 while (match = regexp.exec(navigator.userAgent)) |
|
kzar
2015/12/15 17:26:00
Maybe a comment for this loop explaining that we'r
Sebastian Noack
2015/12/15 17:31:31
Well, how could a comment make it more obvious tha
| |
| 14 { | 14 { |
| 15 var app = match[1]; | 15 var app = match[1]; |
| 16 var ver = match[2]; | 16 var ver = match[2]; |
| 17 | 17 |
| 18 if (app == "Chrome") | 18 if (app == "Chrome") |
| 19 { | 19 { |
| 20 platformVersion = ver; | 20 platformVersion = ver; |
| 21 } | 21 } |
| 22 else if (app != "Mozilla" && app != "AppleWebKit" && app != "Safari") | 22 else if (app != "Mozilla" && app != "AppleWebKit" && app != "Safari") |
| 23 { | 23 { |
| 24 // For compatibility with legacy websites, Chrome's UA | 24 // For compatibility with legacy websites, Chrome's UA |
| 25 // also includes a Mozilla, AppleWebKit and Safari token. | 25 // also includes a Mozilla, AppleWebKit and Safari token. |
| 26 // Any further name/version pair indicates a fork. | 26 // Any further name/version pair indicates a fork. |
| 27 application = app == "OPR" ? "opera" : app.toLowerCase(); | 27 application = app == "OPR" ? "opera" : app.toLowerCase(); |
|
Sebastian Noack
2015/12/15 16:36:58
For reference, some UAs, I tested the logic agains
kzar
2015/12/15 17:26:00
Nit: Maybe just do `application = app.toLowerCase(
Sebastian Noack
2015/12/15 17:31:31
I don't think that spreading these conversions acr
| |
| 28 applicationVersion = ver; | 28 applicationVersion = ver; |
| 29 } | 29 } |
| 30 } | 30 } |
| 31 | 31 |
| 32 // not a Chromium-based UA, probably modifed by the user | 32 // not a Chromium-based UA, probably modifed by the user |
| 33 if (!platformVersion) | 33 if (!platformVersion) |
| 34 { | 34 { |
| 35 application = "unknown"; | 35 application = "unknown"; |
| 36 applicationVersion = platformVersion = "0"; | 36 applicationVersion = platformVersion = "0"; |
| 37 } | 37 } |
| 38 | 38 |
| 39 // no additional name/version, so this is upstream Chrome | 39 // no additional name/version, so this is upstream Chrome |
| 40 if (!application) | 40 if (!application) |
| 41 { | 41 { |
| 42 application = "chrome"; | 42 application = "chrome"; |
| 43 applicationVersion = platformVersion; | 43 applicationVersion = platformVersion; |
| 44 } | 44 } |
| 45 | 45 |
| 46 require.scopes.info = { | 46 require.scopes.info = { |
| 47 addonName: {{ metadata.get('general', 'basename')|json }}, | 47 addonName: {{ metadata.get('general', 'basename')|json }}, |
| 48 addonVersion: {{ version|json }}, | 48 addonVersion: {{ version|json }}, |
| 49 addonRoot: "", | |
| 50 | 49 |
| 51 application: application, | 50 application: application, |
| 52 applicationVersion: applicationVersion, | 51 applicationVersion: applicationVersion, |
| 53 | 52 |
| 54 platform: "chromium", | 53 platform: "chromium", |
| 55 platformVersion: platformVersion | 54 platformVersion: platformVersion |
| 56 }; | 55 }; |
| 57 })(); | 56 })(); |
| LEFT | RIGHT |