From 3c419d3ee70dfcfbac294cf3b84a65fda97e9e3f Mon Sep 17 00:00:00 2001 From: rlx <0x0073@0x2620.org> Date: Fri, 9 Sep 2011 23:05:04 +0000 Subject: [PATCH] update geo module; make Ox.load accept multiple modules --- source/Ox.Geo/Ox.Geo.js | 2 +- source/Ox.Geo/json/Ox.Geo.json | 122 ++++++++++++++++----------------- source/Ox.js | 30 +++++--- tools/geo/py/geo.py | 37 +++++++--- 4 files changed, 108 insertions(+), 83 deletions(-) diff --git a/source/Ox.Geo/Ox.Geo.js b/source/Ox.Geo/Ox.Geo.js index cf652ba9..835c9ca1 100644 --- a/source/Ox.Geo/Ox.Geo.js +++ b/source/Ox.Geo/Ox.Geo.js @@ -147,7 +147,7 @@ Ox.load.Geo = function(options, callback) { Ox.getCountryByName = function(name) { var country; Ox.forEach(Ox.COUNTRIES, function(c) { - if (name == c.name || name == c.googleName) { + if (name == c.name || name == c.googleName || name == c.imdbName) { country = c; return false; } diff --git a/source/Ox.Geo/json/Ox.Geo.json b/source/Ox.Geo/json/Ox.Geo.json index 0d051a4e..ddd529e4 100644 --- a/source/Ox.Geo/json/Ox.Geo.json +++ b/source/Ox.Geo/json/Ox.Geo.json @@ -766,7 +766,7 @@ "imageURLs": { "icon16": "" }, - "area": 61469675843.9538, + "area": 61469675843.95348, "east": 6.40782, "lat": 50.503887, "lng": 4.469936, @@ -1283,7 +1283,7 @@ "dissolved": [], "flagURL": "http://upload.wikimedia.org/wikipedia/commons/8/86/Flag_of_Cote_d%27Ivoire.svg", "imdbCode": "ci", - "imdbName": "Côte d'Ivoire", + "imdbName": "Ivory Coast", "languages": [], "name": "Côte d'Ivoire", "other": false, @@ -1887,7 +1887,7 @@ "imageURLs": { "icon16": "" }, - "area": 1805549223.1433032, + "area": 1805549223.1432948, "east": -68.7385368, "lat": 12.1224221, "lng": -68.8824233, @@ -1941,7 +1941,7 @@ "imageURLs": { "icon16": "" }, - "area": 135542041322.53484, + "area": 135542041322.53429, "east": 18.859236, "lat": 49.817492, "lng": 15.472962, @@ -1986,7 +1986,7 @@ "dissolved": [], "flagURL": "http://upload.wikimedia.org/wikipedia/commons/6/6f/Flag_of_the_Democratic_Republic_of_the_Congo.svg", "imdbCode": "cd", - "imdbName": "Democratic Republic of the Congo", + "imdbName": "Democratic Republic of Congo", "languages": [ "Lingala" ], @@ -2378,7 +2378,9 @@ "flagURL": "http://upload.wikimedia.org/wikipedia/commons/7/71/Flag_of_Ethiopia.svg", "imdbCode": "et", "imdbName": "Ethiopia", - "languages": [], + "languages": [ + "Amharic" + ], "name": "Ethiopia", "other": false, "wikipediaURL": "http://en.wikipedia.org/wiki/Ethiopia", @@ -2435,7 +2437,7 @@ "imageURLs": { "icon16": "" }, - "area": 42441463935.05421, + "area": 42441463935.05392, "east": -57.6768494, "lat": -51.796253, "lng": -59.523613, @@ -2544,7 +2546,7 @@ "imageURLs": { "icon16": "" }, - "area": 676332610065.4193, + "area": 676332610065.4183, "east": 31.5871, "lat": 61.92411, "lng": 25.748151, @@ -2726,7 +2728,7 @@ "imageURLs": { "icon16": "" }, - "area": 37259932200.37096, + "area": 37259932200.370995, "east": 43.4839, "lat": 11.825138, "lng": 42.590275, @@ -2975,7 +2977,7 @@ "imageURLs": { "icon16": "" }, - "area": 6703297450467.926, + "area": 6703297450467.932, "east": -8.26172, "lat": 71.706936, "lng": -42.604303, @@ -3237,13 +3239,13 @@ "imageURLs": { "icon16": "" }, - "area": 2657743977.5988255, - "east": 73.859146, + "area": 907919348.8570622, + "east": 73.7792015, "lat": -53.08181, "lng": 73.504158, - "north": -52.909416, - "south": -53.192001, - "west": 72.596535 + "north": -52.9609445, + "south": -53.1916875, + "west": 73.2506561 }, { "code": "HN", @@ -3363,6 +3365,7 @@ "imdbName": "India", "languages": [ "Telugu", + "Malayalam", "Ladakhi", "Marathi", "Punjabi", @@ -3465,7 +3468,7 @@ "imageURLs": { "icon16": "" }, - "area": 848059568986.0638, + "area": 848059568986.0635, "east": 48.6351, "lat": 33.223191, "lng": 43.679291, @@ -4023,7 +4026,7 @@ "imageURLs": { "icon16": "" }, - "area": 307187958.05156535, + "area": 307187958.0515524, "east": 9.63565, "lat": 47.166, "lng": 9.555373, @@ -4102,13 +4105,13 @@ "imageURLs": { "icon16": "" }, - "area": 106565243.90191776, + "area": 106541136.07033066, "east": 113.6127, "lat": 22.198745, "lng": 113.543873, "north": 22.217159, "south": 22.1066, - "west": 113.5287132 + "west": 113.5287322 }, { "code": "MG", @@ -4235,7 +4238,7 @@ "imageURLs": { "icon16": "" }, - "area": 2887946411067.38, + "area": 2887946411067.381, "east": 4.2666666, "lat": 17.570692, "lng": -3.996166, @@ -4970,7 +4973,9 @@ "flagURL": "http://upload.wikimedia.org/wikipedia/commons/f/f4/Flag_of_Niger.svg", "imdbCode": "ne", "imdbName": "Niger", - "languages": [], + "languages": [ + "Djerma" + ], "name": "Niger", "other": false, "wikipediaURL": "http://en.wikipedia.org/wiki/Niger", @@ -5060,13 +5065,13 @@ "imageURLs": { "icon16": "" }, - "area": 112704828.2027126, - "east": 167.998033, + "area": 133359235.18423142, + "east": 167.9985523, "lat": -29.040835, "lng": 167.954712, - "north": -29.001979, - "south": -29.126415, - "west": 167.914414 + "north": -28.9929014, + "south": -29.1375059, + "west": 167.9134083 }, { "code": "KP", @@ -5633,13 +5638,13 @@ "imageURLs": { "icon16": "" }, - "area": 24538272528.283676, - "east": -65.168503, + "area": 20363167075.50654, + "east": -65.22111, "lat": 18.220833, "lng": -66.590149, - "north": 18.568002, - "south": 17.831509, - "west": -67.998751 + "north": 18.51601, + "south": 17.88124, + "west": -67.94616 }, { "code": "QA", @@ -6210,13 +6215,13 @@ "imageURLs": { "icon16": "" }, - "area": 925699958.3527337, - "east": -56.12809, + "area": 1256060691.6675959, + "east": -56.1071777, "lat": 46.941936, "lng": -56.27111, - "north": 47.1425, - "south": 46.7496, - "west": -56.40659 + "north": 47.1640418, + "south": 46.724565, + "west": -56.4450073 }, { "code": "VC", @@ -6315,14 +6320,7 @@ "wikipediaURL": "http://en.wikipedia.org/wiki/Saudi-Iraqi_neutral_zone", "imageURLs": { "icon16": "" - }, - "area": 8072447924.50245, - "east": 46.5157382, - "lat": 28.9602072, - "lng": 45.6763443, - "north": 29.1965989, - "south": 28.7778378, - "west": 44.7373584 + } }, { "code": "SA", @@ -6370,7 +6368,7 @@ "imageURLs": { "icon16": "" }, - "area": 327394184073.5614, + "area": 327394184073.5608, "east": -0.712426, "lat": 56.4906712, "lng": -4.2026458, @@ -6445,8 +6443,8 @@ "Montenegro" ], "flagURL": "http://upload.wikimedia.org/wikipedia/commons/9/90/Flag_of_Serbia_and_Montenegro.svg", - "imdbCode": "xsm", - "imdbName": "Serbia and Montenegro", + "imdbCode": "xfy", + "imdbName": "Federal Republic of Yugoslavia", "languages": [], "name": "Serbia and Montenegro", "other": false, @@ -6963,7 +6961,9 @@ "imdbName": "Spain", "languages": [ "Spanish", - "Catalan" + "Galician", + "Catalan", + "Basque" ], "name": "Spain", "other": false, @@ -7016,7 +7016,7 @@ "dissolved": [], "flagURL": "http://upload.wikimedia.org/wikipedia/commons/0/00/Flag_of_Palestine.svg", "imdbCode": "ps", - "imdbName": "Palestinian Territory", + "imdbName": "Occupied Palestinian Territory", "languages": [], "name": "Palestine", "other": false, @@ -7024,12 +7024,12 @@ "imageURLs": { "icon16": "" }, - "area": 21209824251.985992, - "east": 35.5814, - "lat": 31.91321345, - "lng": 34.86011335, - "north": 32.6121, - "south": 31.2143269, + "area": 3208539855.5977607, + "east": 34.79048898, + "lat": 31.08477961, + "lng": 34.46465784, + "north": 31.3167512, + "south": 30.85280802, "west": 34.1388267 }, { @@ -7836,13 +7836,13 @@ "imageURLs": { "icon16": "" }, - "area": 40553982827499.53, - "east": -75, - "lat": 14.0045105, - "lng": -134.2033385, + "area": 192180818088.18393, + "east": -171.718918, + "lat": 27.0754315, + "lng": -175.0114505, "north": 28.398027, - "south": -0.389006, - "west": 166.593323 + "south": 25.752836, + "west": -178.303983 }, { "code": "PUUM", diff --git a/source/Ox.js b/source/Ox.js index c299e643..790299a5 100644 --- a/source/Ox.js +++ b/source/Ox.js @@ -178,22 +178,32 @@ Ox = function(val) { Ox.load Loads a module (module, callback) -> undefined (module, options, callback) -> undefined + (modules, callback) -> undefined module Module name + modules Multiple modules {name: options} options Module options callback Callback function success If true, the module has been loaded successfully @*/ -Ox.load = function(/*module[[, options], callback]*/) { - // fixme: no way to load multiple modules - // problem: where do multiple options go? - // [{name: "", options: {}}, {name: "", options: {}}] isn't pretty - var len = arguments.length, - module = arguments[0], - options = len == 3 ? arguments[1] : {}, - callback = arguments[len - 1]; - Ox.loadFile(Ox.PATH + 'Ox.' + module + '/Ox.' + module + '.js', function() { - Ox.load[module](options, callback); +Ox.load = function() { + var callback = arguments[arguments.length - 1], + counter = 0, + isObject = Ox.isObject(arguments[0]), + length, + modules = isObject ? arguments[0] : {}, + success = 0; + if (!isObject) { + modules[arguments[0]] = Ox.isObject(arguments[1]) ? arguments[1] : {}; + } + length = Ox.len(modules) + Ox.forEach(modules, function(options, module) { + Ox.loadFile(Ox.PATH + 'Ox.' + module + '/Ox.' + module + '.js', function() { + Ox.load[module](options, function(s) { + success += s; + ++counter == length && callback(success == counter); + }); + }); }); }; diff --git a/tools/geo/py/geo.py b/tools/geo/py/geo.py index c77e42bf..0e0e1f63 100644 --- a/tools/geo/py/geo.py +++ b/tools/geo/py/geo.py @@ -635,6 +635,18 @@ geo = { 'ZRCD': 'crop()', 'ZW': 'crop(left)' }, + 'imdb_code': { + 'Côte d\'Ivoire': 'ci', + 'Democratic Republic of the Congo': 'cd', + 'Palestine': 'ps', + 'Serbia and Montenegro': 'xfy' + }, + 'imdb_name': { + 'Côte d\'Ivoire': 'Ivory Coast', # bug in some imdb entries + 'Democratic Republic of the Congo': 'Democratic Republic of Congo', # bug in some imdb entries + 'Palestine': 'Occupied Palestinian Territory', # bug in some imdb entries + 'Serbia and Montenegro': 'Federal Republic of Yugoslavia' + }, # import json # import re @@ -658,7 +670,7 @@ geo = { 'Albanian': 'Albania', 'Algonquin': '', 'American': 'United States', - 'Amharic': '', + 'Amharic': 'Ethiopia', 'Apache': '', 'Arabic': 'Saudi Arabia', 'Aragonese': '', @@ -676,7 +688,7 @@ geo = { 'Baka': '', 'Balinese': 'Indonesia', 'Bambara': 'Mali', - 'Basque': '', + 'Basque': 'Spain', 'Bassari': '', 'Belarusian': 'Belarus', 'Bemba': '', @@ -713,7 +725,7 @@ geo = { 'Dari': 'Afghanistan', 'Desiya': '', 'Dinka': '', - 'Djerma': '', + 'Djerma': 'Niger', 'Dogri': '', 'Dutch': 'Netherlands', 'Dyula': '', @@ -735,7 +747,7 @@ geo = { 'Fulah': '', 'Fur': '', 'Gaelic': 'Ireland', - 'Galician': '', + 'Galician': 'Spain', 'Georgian': 'Georgia', 'German': 'Germany', 'Grebo': '', @@ -812,7 +824,7 @@ geo = { 'Maithili': '', 'Malagasy': 'Madagascar', 'Malay': 'Malaysia', - 'Malayalam': '', + 'Malayalam': 'India', 'Malecite-Passamaquoddy': '', 'Malinka': 'Guinea', 'Maltese': 'Malta', @@ -1062,12 +1074,15 @@ def get_countries(): # other country['other'] = country['name'] in geo['other'] # imdb - for imdb_country in imdb_countries: - found = False - if imdb_country['code'].upper() == country['code'] or imdb_country['name'] == country['name']: - country['imdbCode'] = imdb_country['code'] - country['imdbName'] = imdb_country['name'] - break + if country['name'] in geo['imdb_name']: + country['imdbCode'] = geo['imdb_code'][country['name']] + country['imdbName'] = geo['imdb_name'][country['name']] + else: + for imdb_country in imdb_countries: + if imdb_country['code'].upper() == country['code'] or imdb_country['name'] == country['name']: + country['imdbCode'] = imdb_country['code'] + country['imdbName'] = imdb_country['name'] + break get_country_flag(country['code'], country['flagURL']) get_country_icon(country['code']) # languages