1
0
mirror of https://github.com/EDCD/EDMarketConnector.git synced 2025-04-13 15:57:14 +03:00

Export detailed module info to EDShipyard

Including priorities and mods.
This commit is contained in:
Jonathan Harris 2016-10-26 01:43:44 +01:00
parent ea8f6e4ec0
commit b99060a451
2 changed files with 84 additions and 2 deletions

View File

@ -41,9 +41,9 @@ from commodity import COMMODITY_BPC, COMMODITY_CSV
import td
from eddn import eddn
import edsm
import loadout
import coriolis
import eddb
import edshipyard
import stats
import prefs
import plug
@ -386,7 +386,7 @@ class AppWindow:
# stuff we can do when not docked
plug.notify_newdata(data)
if config.getint('output') & config.OUT_SHIP_EDS:
loadout.export(data)
edshipyard.export(data)
if config.getint('output') & config.OUT_SHIP_CORIOLIS:
coriolis.export(data)

82
edshipyard.py Normal file
View File

@ -0,0 +1,82 @@
# Export ship loadout in E:D Shipyard format
from collections import defaultdict
import json
import os
from os.path import join
import re
import time
import companion
from config import config
def export(data, filename=None):
# Add a leaf to a dictionary, creating empty dictionaries along the branch if necessary
def addleaf(data, to, props):
# special handling for completely empty trees
p = props[0]
if not data[p]:
to[p] = data[p]
# Does the leaf exist ?
tail = data
for p in props:
if not hasattr(data, 'get') or p not in tail:
return
else:
tail = tail[p]
for p in props[:-1]:
if not hasattr(data, 'get') or p not in data:
return
elif p not in to:
to[p] = {}
elif not hasattr(to, 'get'):
return # intermediate is not a dictionary - inconsistency!
data = data[p]
to = to[p]
p = props[-1]
to[p] = data[p]
querytime = config.getint('querytime') or int(time.time())
# subset of "ship" that's not noisy
ship = {}
for props in [
('cargo', 'capacity'),
('fuel', 'main', 'capacity'),
('fuel', 'reserve', 'capacity'),
('fuel', 'superchargedFSD'),
('id',),
('name',),
]: addleaf(data['ship'], ship, props)
ship['modules'] = {}
for slot in data['ship'].get('modules', {}):
for prop in ('id', 'modifiers', 'name', 'on', 'priority'):
addleaf(data['ship']['modules'], ship['modules'], (slot, 'module', prop))
string = json.dumps(ship, ensure_ascii=False, indent=2, sort_keys=True, separators=(',', ': ')).encode('utf-8')
if filename:
with open(filename, 'wt') as h:
h.write(string)
return
# Look for last ship of this type
ship = companion.ship_map.get(data['ship']['name'].lower(), data['ship']['name']) # Use in-game name
regexp = re.compile(re.escape(ship) + '\.\d\d\d\d\-\d\d\-\d\dT\d\d\.\d\d\.\d\d\.txt')
oldfiles = sorted([x for x in os.listdir(config.get('outdir')) if regexp.match(x)])
if oldfiles:
with open(join(config.get('outdir'), oldfiles[-1]), 'rU') as h:
if h.read() == string:
return # same as last time - don't write
# Write
filename = join(config.get('outdir'), '%s.%s.txt' % (ship, time.strftime('%Y-%m-%dT%H.%M.%S', time.localtime(querytime))))
with open(filename, 'wt') as h:
h.write(string)