-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathproc.market.js
63 lines (62 loc) · 2.86 KB
/
proc.market.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/*
* Module code goes here. Use 'module.exports' to export things:
* module.exports.thing = 'a thing';
*
* You can import it from another modules like this:
* var mod = require('proc.market');
* mod.thing == 'a thing'; // true
*/
let gomarket={
sellEnergy: function(myroom,mat) {
try{
let availtosell= Game.rooms[myroom].terminal.store.getUsedCapacity(mat)
if(availtosell>0){
console.log(myroom + ":" + mat +":" + availtosell)
//console.log(JSON.stringify(Game.market.orders))
// if(Game.market.orders.length > 9){
let myorders = Game.market.getAllOrders(order=>order.resourceType == mat && order.type == ORDER_BUY)
//console.log("Open orders: " + myorders.length)
//console.log(myorders.length)
for(let i=0; i<myorders.length; i++){
let recheckavailtosell= Game.rooms[myroom].terminal.store.getUsedCapacity(mat)
if(recheckavailtosell<1000){
console.log("too little to mess with")
} else {
//let maxTransferEnergyCost=500
//const transferEnergyCost = Game.market.calcTransactionCost(myorders[i].amount, myroom, myorders[i].roomName);
//if(transferEnergyCost < maxTransferEnergyCost) {
if(recheckavailtosell < myorders[i].amount){
amttosell = recheckavailtosell - 1000
} else {
amttosell=myorders[i].amount
}
console.log( myroom + " trying to sell " + amttosell + " " + mat + " on order size of " + myorders[i].amount + " with " + recheckavailtosell + " left and " + myorders.length + " orders open")
let mydeal = Game.market.deal(myorders[i].id, amttosell, myroom);
if(mydeal == 0){
console.log("Order Created")
} else if(mydeal==-6){
console.log("not enouhg resources")
} else if(mydeal == -8){
console.log("too many orders")
} else if (mydeal == -10){
console.log("Invalid arguments")
} else if (mydeal==-11){
console.log("terminal cooling down")
} else {
console.log(mydeal)
}
//} else {
// console.log("Too expensive")
//}
}
}
// } else {
// console.log("Too many orders pending")
// }
}
}catch(e){
console.log(e)
}
}
}
module.exports = gomarket;