|
|
@ -102,11 +102,18 @@ def assemble_from_fragments(src_path, delimiter=None, compiled_regexp=None):
|
|
|
|
tmpfd, temp_path = tempfile.mkstemp()
|
|
|
|
tmpfd, temp_path = tempfile.mkstemp()
|
|
|
|
tmp = os.fdopen(tmpfd,'w')
|
|
|
|
tmp = os.fdopen(tmpfd,'w')
|
|
|
|
delimit_me = False
|
|
|
|
delimit_me = False
|
|
|
|
|
|
|
|
|
|
|
|
for f in sorted(os.listdir(src_path)):
|
|
|
|
for f in sorted(os.listdir(src_path)):
|
|
|
|
if compiled_regexp and not compiled_regexp.search(f):
|
|
|
|
if compiled_regexp and not compiled_regexp.search(f):
|
|
|
|
continue
|
|
|
|
continue
|
|
|
|
fragment = "%s/%s" % (src_path, f)
|
|
|
|
fragment = "%s/%s" % (src_path, f)
|
|
|
|
if delimit_me and delimiter:
|
|
|
|
|
|
|
|
|
|
|
|
# delimiters should only appear between fragments
|
|
|
|
|
|
|
|
if delimit_me:
|
|
|
|
|
|
|
|
# always put a newline between fragments
|
|
|
|
|
|
|
|
tmp.write('\n')
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if delimiter:
|
|
|
|
# un-escape anything like newlines
|
|
|
|
# un-escape anything like newlines
|
|
|
|
delimiter = delimiter.decode('unicode-escape')
|
|
|
|
delimiter = delimiter.decode('unicode-escape')
|
|
|
|
tmp.write(delimiter)
|
|
|
|
tmp.write(delimiter)
|
|
|
@ -114,9 +121,11 @@ def assemble_from_fragments(src_path, delimiter=None, compiled_regexp=None):
|
|
|
|
# delimiter, so lines don't run together
|
|
|
|
# delimiter, so lines don't run together
|
|
|
|
if delimiter[-1] != '\n':
|
|
|
|
if delimiter[-1] != '\n':
|
|
|
|
tmp.write('\n')
|
|
|
|
tmp.write('\n')
|
|
|
|
|
|
|
|
|
|
|
|
if os.path.isfile(fragment):
|
|
|
|
if os.path.isfile(fragment):
|
|
|
|
tmp.write(file(fragment).read())
|
|
|
|
tmp.write(file(fragment).read())
|
|
|
|
delimit_me = True
|
|
|
|
delimit_me = True
|
|
|
|
|
|
|
|
|
|
|
|
tmp.close()
|
|
|
|
tmp.close()
|
|
|
|
return temp_path
|
|
|
|
return temp_path
|
|
|
|
|
|
|
|
|
|
|
|