autobuilding

main
Arne Schauf 12 months ago
parent 493a1e0bad
commit 069e6587a9
  1. 31
      default/main.js
  2. 4
      default/role.builder.js
  3. 1
      default/role.filler.js
  4. 14
      default/role.hauler.js
  5. 1
      default/role.remoteHarvester.js
  6. 1
      default/role.reserver.js
  7. 1
      default/role.scout.js
  8. 46
      default/role.transporter.js
  9. 14
      default/role.upgrader.js
  10. 34
      default/spawn.js

@ -41,7 +41,30 @@ module.exports.loop = function () {
} }
} }
for (let [roomName, roomMemory] of Object.entries(Memory.rooms)) {
let room = Game.rooms[roomName]
if (!roomMemory.fatigues) {
roomMemory.fatigues = {}
}
for (let [k, v] of Object.entries(roomMemory.fatigues)) {
let [x, y] = k.split('_')
x = parseInt(x)
y = parseInt(y)
if (room && v > 20) {
room.createConstructionSite(x, y, STRUCTURE_ROAD)
roomMemory.fatigues[k] = 0
}
if (v > 0) {
if (Game.time % 20 === 0) {
roomMemory.fatigues[k]--
}
room.visual.text(roomMemory.fatigues[k], x, y, {size: 0.4})
}
}
}
let spawn = Game.spawns['Spawn1'] let spawn = Game.spawns['Spawn1']
global.activeRemotes = spawn.room.memory.activeRemotes || []
// Run modules // Run modules
for (let link of spawn.room.find(FIND_STRUCTURES, {filter: s => s.structureType === STRUCTURE_LINK})) { for (let link of spawn.room.find(FIND_STRUCTURES, {filter: s => s.structureType === STRUCTURE_LINK})) {
@ -62,6 +85,14 @@ module.exports.loop = function () {
if (ROLES[creep.memory.role].tick(creep) === 'idle') { if (ROLES[creep.memory.role].tick(creep) === 'idle') {
ROLES[creep.memory.role].idling++ ROLES[creep.memory.role].idling++
} }
if (creep.fatigue > 0) {
if (creep.pos.findInRange(FIND_STRUCTURES, 0, {filter: s => s.structureType === STRUCTURE_ROAD}).length === 0
&& creep.pos.findInRange(FIND_MY_CONSTRUCTION_SITES, 1, {filter: s => s.structureType === STRUCTURE_ROAD}).length === 0) {
creep.room.memory.fatigues[creep.pos.x + '_' + creep.pos.y] = (creep.room.memory.fatigues[creep.pos.x + '_' + creep.pos.y] || 0) + creep.fatigue
}
}
} }
libSpawn.tick(spawn) libSpawn.tick(spawn)

@ -5,7 +5,9 @@ let maxWallHits = 0
module.exports = { module.exports = {
name: 'builder', name: 'builder',
prio: 5, prio: 5,
count: 1, getCount: colonyRoom => {
return Math.min(5, Math.max(1, colonyRoom.find(FIND_MY_CONSTRUCTION_SITES).length))
},
maxExpands: 4, maxExpands: 4,
baseBody: [WORK, CARRY, MOVE, MOVE], baseBody: [WORK, CARRY, MOVE, MOVE],
expandBody: [WORK, CARRY, MOVE, MOVE], expandBody: [WORK, CARRY, MOVE, MOVE],

@ -4,6 +4,7 @@ module.exports = {
name: 'filler', name: 'filler',
prio: 4, prio: 4,
count: 2, count: 2,
minRcl: 2,
bodies: [ bodies: [
[CARRY, CARRY, MOVE], [CARRY, CARRY, MOVE],
[CARRY, CARRY, MOVE, CARRY, CARRY, MOVE], [CARRY, CARRY, MOVE, CARRY, CARRY, MOVE],

@ -87,9 +87,17 @@ module.exports = {
} }
} }
} else if (creep.store[RESOURCE_ENERGY] > 0) { } else if (creep.store[RESOURCE_ENERGY] > 0) {
let storage = Game.rooms[creep.memory.colony].storage let target = Game.rooms[creep.memory.colony].storage
if (creep.transfer(storage, RESOURCE_ENERGY) === ERR_NOT_IN_RANGE) { if (!target) {
creep.moveTo(storage) for (let scId of Game.rooms[creep.memory.colony].memory.spawnContainers) {
let container = Game.getObjectById(scId)
if (container && container.store.getFreeCapacity(RESOURCE_ENERGY) > 0) {
target = container
}
}
}
if (creep.transfer(target, RESOURCE_ENERGY) === ERR_NOT_IN_RANGE) {
creep.moveTo(target)
} }
} else if (moveToRoom(creep,creep.memory.colony) === MOVING) { } else if (moveToRoom(creep,creep.memory.colony) === MOVING) {
return return

@ -3,6 +3,7 @@ let common = require('common')
module.exports = { module.exports = {
name: 'remoteHarvester', name: 'remoteHarvester',
prio: 10, prio: 10,
minRcl: 3,
bodies: [ bodies: [
[WORK, WORK, WORK, CARRY, MOVE, MOVE, MOVE, MOVE], [WORK, WORK, WORK, CARRY, MOVE, MOVE, MOVE, MOVE],
[WORK, WORK, WORK, WORK, WORK, WORK, CARRY, MOVE, MOVE, MOVE, MOVE, MOVE, MOVE, MOVE], [WORK, WORK, WORK, WORK, WORK, WORK, CARRY, MOVE, MOVE, MOVE, MOVE, MOVE, MOVE, MOVE],

@ -1,6 +1,7 @@
module.exports = { module.exports = {
name: 'reserver', name: 'reserver',
prio: 20, prio: 20,
minRcl: 4,
nextSpawn (spawn, roleCreeps) { nextSpawn (spawn, roleCreeps) {
for (let roomName of activeRemotes) { for (let roomName of activeRemotes) {
let room = Game.rooms[roomName] let room = Game.rooms[roomName]

@ -2,6 +2,7 @@ module.exports = {
name: 'scout', name: 'scout',
count: 1, count: 1,
prio: 15, prio: 15,
minRcl: 3,
bodies: [[MOVE]], bodies: [[MOVE]],
nextSpawn (spawn, roleCreeps) { nextSpawn (spawn, roleCreeps) {
for (let roomName of activeRemotes) { for (let roomName of activeRemotes) {

@ -3,13 +3,49 @@ const common = require('common')
module.exports = { module.exports = {
name: 'transporter', name: 'transporter',
prio: 4, prio: 4,
count: 1, getCount: colonyRoom => Object.keys(colonyRoom.memory.sourcesData).length
+ Math.floor((colonyRoom.find(FIND_DROPPED_RESOURCES).reduce((total, current) => total + current.amount, 0)) / 500)
+ Math.floor((colonyRoom.find(FIND_STRUCTURES, {filter: s => s.structureType === STRUCTURE_CONTAINER && colonyRoom.memory.sourceContainers.indexOf(s.id) !== -1}).reduce((total, current) => total + current.store[RESOURCE_ENERGY], 0)) / 500)
,
bodies: [ bodies: [
[CARRY, MOVE],
[CARRY, CARRY, MOVE], [CARRY, CARRY, MOVE],
[CARRY, CARRY, MOVE, CARRY, CARRY, MOVE], [CARRY, CARRY, MOVE, CARRY, CARRY, MOVE],
[CARRY, CARRY, MOVE, CARRY, CARRY, MOVE, CARRY, CARRY, MOVE], [CARRY, CARRY, MOVE, CARRY, CARRY, MOVE, CARRY, CARRY, MOVE],
[CARRY, CARRY, MOVE, CARRY, CARRY, MOVE, CARRY, CARRY, MOVE, CARRY, CARRY, MOVE], [CARRY, CARRY, MOVE, CARRY, CARRY, MOVE, CARRY, CARRY, MOVE, CARRY, CARRY, MOVE],
], ],
tickInit () {
for (let room of Object.values(Game.rooms)) {
if (!room.memory.spawnContainers) {
room.memory.spawnContainers = []
}
if (!room.memory.sourceContainers) {
room.memory.sourceContainers = []
}
if (Game.time % 100 === 0 && room.controller.my) {
let containers = room.controller.pos.findInRange(FIND_STRUCTURES, 4, {filter: s => s.structureType === STRUCTURE_CONTAINER})
if (containers.length > 0) {
room.memory.controllerContainer = containers[0].id
}
room.memory.spawnContainers = []
for (let spawn of room.find(FIND_STRUCTURES, {filter: s => s.structureType === STRUCTURE_SPAWN})) {
containers = spawn.pos.findInRange(FIND_STRUCTURES, 4, {filter: s => s.structureType === STRUCTURE_CONTAINER})
if (containers.length > 0) {
containers.forEach(el => room.memory.spawnContainers.push(el.id))
}
}
room.memory.sourceContainers = []
for (let spawn of room.find(FIND_SOURCES)) {
containers = spawn.pos.findInRange(FIND_STRUCTURES, 2, {filter: s => s.structureType === STRUCTURE_CONTAINER})
if (containers.length > 0) {
containers.forEach(el => room.memory.sourceContainers.push(el.id))
}
}
}
}
},
tick (creep) { tick (creep) {
if (creep.store.getFreeCapacity(RESOURCE_ENERGY) === 0) { if (creep.store.getFreeCapacity(RESOURCE_ENERGY) === 0) {
creep.memory.loading = false creep.memory.loading = false
@ -45,6 +81,8 @@ module.exports = {
let quickloadTargets = creep.pos.findInRange(FIND_STRUCTURES, 2, { let quickloadTargets = creep.pos.findInRange(FIND_STRUCTURES, 2, {
filter: s => { filter: s => {
return s.structureType === STRUCTURE_CONTAINER return s.structureType === STRUCTURE_CONTAINER
&& s.id !== creep.room.memory.controllerContainer
&& creep.room.memory.spawnContainers.indexOf(s.id) === -1
&& s.store[RESOURCE_ENERGY] > creep.store.getFreeCapacity(RESOURCE_ENERGY) && s.store[RESOURCE_ENERGY] > creep.store.getFreeCapacity(RESOURCE_ENERGY)
} }
}) })
@ -71,6 +109,8 @@ module.exports = {
target = creep.pos.findClosestByPath(FIND_STRUCTURES, { target = creep.pos.findClosestByPath(FIND_STRUCTURES, {
filter: s => { filter: s => {
return s.structureType === STRUCTURE_CONTAINER return s.structureType === STRUCTURE_CONTAINER
&& s.id !== creep.room.memory.controllerContainer
&& creep.room.memory.spawnContainers.indexOf(s.id) === -1
&& s.store[RESOURCE_ENERGY] > 100 && s.store[RESOURCE_ENERGY] > 100
} }
}) })
@ -131,7 +171,9 @@ module.exports = {
if (!target) { if (!target) {
target = creep.pos.findClosestByPath(FIND_STRUCTURES, { target = creep.pos.findClosestByPath(FIND_STRUCTURES, {
filter: s => { filter: s => {
return s.structureType === STRUCTURE_STORAGE return (s.structureType === STRUCTURE_STORAGE
|| s.id === creep.room.memory.controllerContainer
|| creep.room.memory.spawnContainers.indexOf(s.id) !== -1)
&& s.store.getFreeCapacity(RESOURCE_ENERGY) > 0 && s.store.getFreeCapacity(RESOURCE_ENERGY) > 0
} }
}) })

@ -5,8 +5,16 @@ module.exports = {
idling, idling,
name: 'upgrader', name: 'upgrader',
prio: 6, prio: 6,
count: 1, getCount: colonyRoom => {
getCount: colonyRoom => colonyRoom.storage ? Math.ceil(colonyRoom.storage.store[RESOURCE_ENERGY] / 100000) : 1, let cc = Game.getObjectById(colonyRoom.memory.controllerContainer)
if(colonyRoom.storage) {
return Math.ceil(colonyRoom.storage.store[RESOURCE_ENERGY] / 100000)
}
else if (colonyRoom.controller.level + cc.store) {
return Math.ceil(cc.store[RESOURCE_ENERGY] / 500)
}
return colonyRoom.controller.level
},
maxExpands: 4, maxExpands: 4,
baseBody: [WORK, CARRY, MOVE], baseBody: [WORK, CARRY, MOVE],
expandBody: [WORK, WORK, MOVE], expandBody: [WORK, WORK, MOVE],
@ -32,7 +40,7 @@ module.exports = {
target = targets[0] target = targets[0]
} }
} }
if (!target) { if (!target && creep.store[RESOURCE_ENERGY] === 0) {
target = creep.room.controller.pos.findClosestByRange(FIND_STRUCTURES, { target = creep.room.controller.pos.findClosestByRange(FIND_STRUCTURES, {
filter: s => s.store && s.store.getCapacity(RESOURCE_ENERGY) > 0 filter: s => s.store && s.store.getCapacity(RESOURCE_ENERGY) > 0
}) })

@ -27,6 +27,8 @@ function getBodyCost(body) {
module.exports = { module.exports = {
tickInit () { tickInit () {
for (let room of Object.values(Game.rooms)) { for (let room of Object.values(Game.rooms)) {
let spawns = room.find(FIND_MY_SPAWNS)
room.memory.spawingRoom = spawns.length > 0
if (!room.memory.harvestingSpots) { if (!room.memory.harvestingSpots) {
room.memory.harvestingSpots = {} room.memory.harvestingSpots = {}
} }
@ -64,6 +66,27 @@ module.exports = {
} }
} }
} }
if (spawns.length > 0 && (Game.time + 5) % 100 === 0 && room.find(FIND_MY_CONSTRUCTION_SITES).length === 0) {
let spawn = spawns[0]
let extensions = room.find(FIND_MY_STRUCTURES, {filter: s => s.structureType === STRUCTURE_EXTENSION})
if (CONTROLLER_STRUCTURES.extension[room.controller.level] > extensions.length) {
let ring = 0
let x = spawn.pos.x
let y = spawn.pos.y
while (ring < 10 && room.createConstructionSite(x, y, STRUCTURE_EXTENSION) === ERR_INVALID_TARGET) {
x += 2
if (x > spawn.pos.x + ring) {
x = spawn.pos.x - ring
y += 2
}
if (y > spawn.pos.y + ring) {
ring++
x = spawn.pos.x - ring
y = spawn.pos.y - ring
}
}
}
}
} }
}, },
tick (spawn) { tick (spawn) {
@ -81,6 +104,9 @@ module.exports = {
else { else {
let newCreep, prio let newCreep, prio
for (let [roleName, role] of Object.entries(ROLES)) { for (let [roleName, role] of Object.entries(ROLES)) {
if (role.minRcl > spawn.room.controller.level) {
continue
}
let roleCreeps = _.filter(Game.creeps, {memory: {role: roleName, colony: spawn.room.name}}); let roleCreeps = _.filter(Game.creeps, {memory: {role: roleName, colony: spawn.room.name}});
if (minRoleCount === undefined || minRoleCount > roleCreeps.length) { if (minRoleCount === undefined || minRoleCount > roleCreeps.length) {
minRoleCount = roleCreeps.length minRoleCount = roleCreeps.length
@ -101,13 +127,13 @@ module.exports = {
for (let source of spawn.room.find(FIND_SOURCES)) { for (let source of spawn.room.find(FIND_SOURCES)) {
let spots = spawn.room.memory.harvestingSpots[source.id] let spots = spawn.room.memory.harvestingSpots[source.id]
let harvestingCapacity = 0 let harvestingCapacity = 0
let sourceHarvesters = _.filter(Game.creeps, {memory: {role: 'harvester', source: source.id}}) let sourceHarvesters = _.filter(roleCreeps, {memory: {source: source.id}})
if (sourceHarvesters.length >= spots.length) { if (sourceHarvesters.length >= spots.length) {
continue continue
} }
for (let harvester of sourceHarvesters) { for (let harvester of sourceHarvesters) {
if (harvester.ticksToLive > harvester.body.length * 3 + source.room.memory.sourcesData[source.id].spawnDistance) { if (!harvester.ticksToLive || harvester.ticksToLive > harvester.body.length * 3 + source.room.memory.sourcesData[source.id].spawnDistance) {
harvestingCapacity += harvester.getActiveBodyparts(WORK) * 2 * 300 harvestingCapacity += _.filter(harvester.body, {type: WORK}).length * 2 * 300
} }
} }
if (harvestingCapacity < source.energyCapacity) { if (harvestingCapacity < source.energyCapacity) {
@ -134,7 +160,7 @@ module.exports = {
continue continue
} }
for (let harvester of sourceHarvesters) { for (let harvester of sourceHarvesters) {
if (harvester.ticksToLive > harvester.body.length * 3 + sourceData.spawnDistance) { if (!harvester.ticksToLive || harvester.ticksToLive > harvester.body.length * 3 + sourceData.spawnDistance) {
harvestingCapacity += harvester.getActiveBodyparts(WORK) * 2 * 300 harvestingCapacity += harvester.getActiveBodyparts(WORK) * 2 * 300
} }
} }

Loading…
Cancel
Save