Line 7: |
Line 7: |
| local U = require('Module:Core') | | local U = require('Module:Core') |
| local Equipment = require('Module:Equipment') | | local Equipment = require('Module:Equipment') |
− | local CollectionEquipment = require('Module:Collection/Equipment') | + | local Ship = require('Module:Ship') |
| + | local CollectionShips = require('Module:Collection/Ships') |
| + | local CollectionEquipment = require('Module:Data/Equipment') |
| local EnemyShip = require('Module:EnemyShip') | | local EnemyShip = require('Module:EnemyShip') |
| local CollectionEnemy = require('Module:Collection/EnemyShips') | | local CollectionEnemy = require('Module:Collection/EnemyShips') |
Line 82: |
Line 84: |
| end, | | end, |
| } | | } |
| + | end |
| + | |
| + | function Iterator.shipsBy(context, n, pred, pre, nItems) |
| + | local predKey = stringKey('pred', context, n) |
| + | local pred2 |
| + | if predKey then |
| + | pred2 = function(e) |
| + | local obj = Ship(e._name) |
| + | return obj[predKey](obj) |
| + | end |
| + | end |
| + | local preCollection |
| + | local collectionKey = stringKey('collection', context, n) |
| + | if collectionKey then |
| + | local _, CollectionData = U.requireModule(string.format("Collection/%s", collectionKey)) |
| + | preCollection = U.icopy(CollectionData) |
| + | else |
| + | preCollection = U.icopy(CollectionShips) |
| + | end |
| + | |
| + | local allowedRemodels = context['allowedRemodels'] |
| + | local listBase = (context['listBase'] == 'true') |
| + | local collection = {} |
| + | local index = 1 |
| + | for i = 1, #preCollection do |
| + | local _, CollectionData = U.requireModule(string.format("Data/Ship/%s", preCollection[i])) |
| + | if _ and CollectionData then |
| + | for j,v in pairs(CollectionData) do |
| + | if v._suffix then |
| + | if (allowedRemodels == nil or allowedRemodels[v._suffix]) then |
| + | local fullName = string.format("%s/%s", v._name, v._suffix) |
| + | collection[index] = v |
| + | collection[index]._fullName = fullName |
| + | index = index + 1 |
| + | end |
| + | elseif v._id then |
| + | if v._remodel_from or (v._name and listBase) then |
| + | collection[index] = v |
| + | collection[index]._fullName = v._name |
| + | index = index + 1 |
| + | end |
| + | end |
| + | end |
| + | end |
| + | end |
| + | |
| + | local sortKey = stringKey('sort', context, n) |
| + | if sortKey then |
| + | table.sort(collection, function(a, b) |
| + | if a[sortKey] and b[sortKey] and a[sortKey] ~= b[sortKey] then |
| + | return a[sortKey] < b[sortKey] |
| + | elseif a._id == b._id then |
| + | return a._api_id < b._api_id |
| + | else |
| + | return a._id < b._id |
| + | end |
| + | end) |
| + | end |
| + | |
| + | local i = 1 |
| + | local current = nil |
| + | local preFlag = true |
| + | local nCollection = nItems == true and #collection or nItems or #collection |
| + | return { |
| + | next = function() |
| + | for _ = i, nCollection do |
| + | local e |
| + | if nItems then |
| + | e = U.ifindBy(collection, function(e) return e._id == i end) or { _id = i } |
| + | else |
| + | e = collection[i] |
| + | end |
| + | if (pred and not pred(e, i)) or (pred2 and not pred2(e, i)) then |
| + | i = i + 1 |
| + | else |
| + | if pre and preFlag then |
| + | local value = pre(e, i) |
| + | if value then |
| + | current = value |
| + | preFlag = false |
| + | return true |
| + | end |
| + | end |
| + | current = e._fullName |
| + | if nItems and not current then |
| + | current = '-' |
| + | end |
| + | i = i + 1 |
| + | preFlag = true |
| + | return true |
| + | end |
| + | end |
| + | current = nil |
| + | return false |
| + | end, |
| + | current = function() |
| + | return current |
| + | end, |
| + | } |
| + | end |
| + | |
| + | function Iterator.shipsByType(context, n) |
| + | local type = numberKey('type', context, n) |
| + | return Iterator.shipsBy(context, n, function(e) |
| + | return type == nil or e._type == type |
| + | end) |
| + | end |
| + | |
| + | function Iterator.shipsByTrueId(context, n) |
| + | local from = numberKey('from', context, n, 1) |
| + | local to = numberKey('to', context, n, 1500) |
| + | return Iterator.shipsBy(context, n, function(e) |
| + | if e._true_id then |
| + | return e._true_id >= from and e._true_id <= to |
| + | else |
| + | return e._id >= from and e._id <= to |
| + | end |
| + | end) |
| end | | end |
| | | |
Line 98: |
Line 218: |
| local collectionKey = stringKey('collection', context, n) | | local collectionKey = stringKey('collection', context, n) |
| if collectionKey then | | if collectionKey then |
− | local _, CollectionData = U.requireModule(string.format("Collection/%s", collectionKey)) | + | local _, CollectionData = U.requireModule(collectionKey == 'Equipment' and 'Data/Equipment' or string.format("Collection/%s", collectionKey)) |
| collection = U.icopy(CollectionData) | | collection = U.icopy(CollectionData) |
| else | | else |
Line 157: |
Line 277: |
| function Iterator.equipmentById(context, n) | | function Iterator.equipmentById(context, n) |
| local from = numberKey('from', context, n, 1) | | local from = numberKey('from', context, n, 1) |
− | local to = numberKey('to', context, n, 500) | + | local to = numberKey('to', context, n, 1500) |
| return Iterator.equipmentBy(context, n, function(e) | | return Iterator.equipmentBy(context, n, function(e) |
| return e._id >= from and e._id <= to | | return e._id >= from and e._id <= to |
Line 165: |
Line 285: |
| function Iterator.equipmentByIdWithHeaders(context, n) | | function Iterator.equipmentByIdWithHeaders(context, n) |
| local from = numberKey('from', context, n, 1) | | local from = numberKey('from', context, n, 1) |
− | local to = numberKey('to', context, n, 500) | + | local to = numberKey('to', context, n, 1500) |
| local prevMod = 0 | | local prevMod = 0 |
| return Iterator.equipmentBy( | | return Iterator.equipmentBy( |
Line 188: |
Line 308: |
| function Iterator.equipmentByIdWithEmptyWithHeaders(context, n) | | function Iterator.equipmentByIdWithEmptyWithHeaders(context, n) |
| local from = numberKey('from', context, n, 1) | | local from = numberKey('from', context, n, 1) |
− | local to = numberKey('to', context, n, 500) | + | local to = numberKey('to', context, n, 1500) |
| local prevMod = 0 | | local prevMod = 0 |
| local nItems = (math.floor(U.ilast(CollectionEquipment)._id / 10) + 1) * 10 | | local nItems = (math.floor(U.ilast(CollectionEquipment)._id / 10) + 1) * 10 |
Line 300: |
Line 420: |
| | | |
| local selectBoss = stringKey('boss', context, n, ''):lower() | | local selectBoss = stringKey('boss', context, n, ''):lower() |
| + | -- treat unknwon _back as bosses? why it is unknwon? |
| local predBoss = selectBoss == 'yes' and | | local predBoss = selectBoss == 'yes' and |
− | function(e) return e._back <= -11 end | + | function(e) return (e._back or -11) <= -11 end |
| or selectBoss == 'no' and | | or selectBoss == 'no' and |
− | function(e) return e._back >= -10 end | + | function(e) return (e._back or -11) >= -10 end |
| or | | or |
| function(e) return true end | | function(e) return true end |
Line 328: |
Line 449: |
| mw.log() | | mw.log() |
| end | | end |
| + | |
| + | testIterator('shipsByType', { type = '11', sort = '_class' , listBase = 'true'}) |
| + | testIterator('shipsByType', { sort = '_name'}) |
| + | testIterator('shipsByTrueId', { sort = '_id', from = '1', to = '20', listBase = 'true'}) |
| + | testIterator('shipsBy', { pred = 'is_auxiliary' , sort = '_name'}) |
| + | |
| testIterator('equipmentById', { from = '11', to = '20' }) | | testIterator('equipmentById', { from = '11', to = '20' }) |
| testIterator('equipmentByIdWithHeaders', { from = '1', to = '30' }) | | testIterator('equipmentByIdWithHeaders', { from = '1', to = '30' }) |
Line 334: |
Line 461: |
| testIterator('equipmentByTypeAndIcon', { type = '1', icon = '16' }) | | testIterator('equipmentByTypeAndIcon', { type = '1', icon = '16' }) |
| testIterator('equipmentBy', { pred = 'is_large_caliber_main_gun', sort = '_type' }) | | testIterator('equipmentBy', { pred = 'is_large_caliber_main_gun', sort = '_type' }) |
| + | |
| testIterator('enemiesByType', { type = '2' }) | | testIterator('enemiesByType', { type = '2' }) |
| end | | end |