2015-07-20 21:42:51 +03:00
|
|
|
import os.path, sys, shutil, time, logging
|
2013-02-28 07:07:02 +04:00
|
|
|
|
|
|
|
import tempfiles
|
2013-01-31 05:50:33 +04:00
|
|
|
|
|
|
|
# Permanent cache for dlmalloc and stdlibc++
|
|
|
|
class Cache:
|
2013-03-05 22:19:10 +04:00
|
|
|
def __init__(self, dirname=None, debug=False):
|
2013-01-31 05:50:33 +04:00
|
|
|
if dirname is None:
|
|
|
|
dirname = os.environ.get('EM_CACHE')
|
|
|
|
if not dirname:
|
|
|
|
dirname = os.path.expanduser(os.path.join('~', '.emscripten_cache'))
|
|
|
|
self.dirname = dirname
|
2013-03-05 22:19:10 +04:00
|
|
|
self.debug = debug
|
2013-01-31 05:50:33 +04:00
|
|
|
|
|
|
|
def ensure(self):
|
2013-12-01 22:52:11 +04:00
|
|
|
shared.safe_ensure_dirs(self.dirname)
|
2013-01-31 05:50:33 +04:00
|
|
|
|
|
|
|
def erase(self):
|
2013-02-21 01:58:20 +04:00
|
|
|
tempfiles.try_delete(self.dirname)
|
2013-03-05 22:13:06 +04:00
|
|
|
try:
|
2013-03-05 22:46:31 +04:00
|
|
|
open(self.dirname + '__last_clear', 'w').write('last clear: ' + time.asctime() + '\n')
|
|
|
|
except Exception, e:
|
|
|
|
print >> sys.stderr, 'failed to save last clear time: ', e
|
2013-01-31 05:50:33 +04:00
|
|
|
|
|
|
|
def get_path(self, shortname):
|
|
|
|
return os.path.join(self.dirname, shortname)
|
|
|
|
|
|
|
|
# Request a cached file. If it isn't in the cache, it will be created with
|
|
|
|
# the given creator function
|
2015-07-20 21:42:51 +03:00
|
|
|
def get(self, shortname, creator, extension='.bc', what=None):
|
2013-01-31 05:50:33 +04:00
|
|
|
if not shortname.endswith(extension): shortname += extension
|
|
|
|
cachename = os.path.join(self.dirname, shortname)
|
|
|
|
if os.path.exists(cachename):
|
|
|
|
return cachename
|
2015-07-20 21:42:51 +03:00
|
|
|
if what is None:
|
|
|
|
if shortname.endswith(('.bc', '.so', '.a')): what = 'system library'
|
|
|
|
else: what = 'system asset'
|
|
|
|
message = 'generating ' + what + ': ' + shortname + '...'
|
|
|
|
logging.warn(message)
|
2013-01-31 05:50:33 +04:00
|
|
|
self.ensure()
|
2014-10-31 02:13:54 +03:00
|
|
|
temp = creator()
|
|
|
|
if temp != cachename:
|
|
|
|
shutil.copyfile(temp, cachename)
|
2015-07-20 21:42:51 +03:00
|
|
|
logging.warn(' '*len(message) + 'ok')
|
2013-01-31 05:50:33 +04:00
|
|
|
return cachename
|
|
|
|
|
|
|
|
# Given a set of functions of form (ident, text), and a preferred chunk size,
|
|
|
|
# generates a set of chunks for parallel processing and caching.
|
2015-04-07 06:06:43 +03:00
|
|
|
def chunkify(funcs, chunk_size, DEBUG=False):
|
2013-01-31 05:50:33 +04:00
|
|
|
chunks = []
|
|
|
|
# initialize reasonably, the rest of the funcs we need to split out
|
|
|
|
curr = []
|
|
|
|
total_size = 0
|
|
|
|
for i in range(len(funcs)):
|
|
|
|
func = funcs[i]
|
|
|
|
curr_size = len(func[1])
|
|
|
|
if total_size + curr_size < chunk_size:
|
|
|
|
curr.append(func)
|
|
|
|
total_size += curr_size
|
|
|
|
else:
|
2013-03-05 07:50:42 +04:00
|
|
|
chunks.append(curr)
|
|
|
|
curr = [func]
|
|
|
|
total_size = curr_size
|
|
|
|
if curr:
|
2013-01-31 05:50:33 +04:00
|
|
|
chunks.append(curr)
|
|
|
|
curr = None
|
|
|
|
return [''.join([func[1] for func in chunk]) for chunk in chunks] # remove function names
|
2013-12-03 05:12:23 +04:00
|
|
|
|
|
|
|
import shared
|