예제 #1
0
    def testAnalyzeSection(self):
        '''Test analysis of sections (statically)'''
        script = SoS_Script('''
g1 = 'a'
g2 = 1
parameter: p1 = 5
parameter: infiles = 'a.txt'

[A_1: shared='b']
b = p1 + 2
input:  infiles
output: None
c = 5

[A_2]
b = [1, 2, 3]
input: for_each='b'
depends: 'some.txt', executable('ls')
import time
import random

r = random.randint(1, 5)
time.sleep(r)

[A_3]
input: None
print(p1)

[A_4]
input: None
task:
python: expand=True
   print(f'{output}')

[A_5]
task:
   print(f'{_output}')
''')
        wf = script.workflow('A')
        for section in wf.sections:
            res = analyze_section(section)
            if section.names[0][1] == '1':
                self.assertTrue(res['step_input'].undetermined())
                self.assertEqual(res['step_depends'], sos_targets())
                self.assertEqual(res['step_output'], sos_targets())
                self.assertEqual(res['environ_vars'], {'b', 'p1', 'infiles'})
                self.assertEqual(res['signature_vars'], {'c'})
                self.assertEqual(res['changed_vars'], {'b'})
            elif section.names[0][1] == '2':
                self.assertEqual(res['step_input'], sos_targets())
                self.assertEqual(res['step_depends'], sos_targets(
                    'some.txt', executable('ls')))
                self.assertTrue(res['step_output'].unspecified())
                # for_each will not be used for DAG
                self.assertEqual(res['environ_vars'], {
                                 'b', 'for_each', 'executable'})
                self.assertEqual(res['signature_vars'], {
                                 'r', 'time', 'random'})
                self.assertEqual(res['changed_vars'], set())
            elif section.names[0][1] == '4':
                self.assertTrue('output' in res['signature_vars'])
            elif section.names[0][1] == '5':
                self.assertTrue('output' not in res['signature_vars'])
예제 #2
0
파일: bookdown.py 프로젝트: gaow/labnotes
def prepare_bookdown(files, title, author, date, description, no_section_number,
                     split_by, url, url_edit, repo, pdf, output, pdf_args):

    if not os.path.exists(os.path.join(env.tmp_dir, env.time) + '.deps'):
        R_library('rstudio/bookdown')
        R_library('rstudio/DT')
        executable('pandoc')
        os.system('touch %s' % os.path.join(env.tmp_dir, env.time) + '.deps')
    #
    if title:
        idx['title'] = title
    if author:
        idx['author'] = author
    if date:
        idx['date'] = date
    if description:
        if os.path.isfile(description):
            idx['description'] = open(description).read()
        else:
            idx['description'] = description
    if url:
        idx['url'] = url
    else:
        del idx['url']
    if repo:
        idx['github-repo'] = repo
        cfg['repo'] = repo
    else:
        del idx['github-repo']
        del cfg['repo']
    idx['author'] = '© ' + idx['author']
    out['bookdown::gitbook']['css'] =  'style.css'
    out['bookdown::html_chapters']['css'] = ['style.css', 'toc.css']
    out['bookdown::epub_book']['stylesheet'] = 'style.css'
    if pdf:
        out['bookdown::pdf_book']['includes']['in_header'] = os.path.join(env.tmp_dir, 'preamble.tex')
    else:
        del out['bookdown::pdf_book']
    workdir = os.getcwd()
    if output:
        output = os.path.abspath(os.path.expanduser(output))
        os.makedirs(output, exist_ok = True)
        cfg['output_dir'] = os.path.basename(output)
        workdir = os.path.dirname(output)
    else:
        os.makedirs(cfg['output_dir'], exist_ok = True)
    out['bookdown::gitbook']['config']['toc']['before'] = '{}'.format(
        out['bookdown::gitbook']['config']['toc']['before'].replace('VALUE', idx['title']))
    out['bookdown::gitbook']['config']['toc']['after'] = '{}'.format(
        out['bookdown::gitbook']['config']['toc']['after'].replace('VALUE',
                                                                   '{} {}'.format(env.year, idx['author'])))
    if split_by:
        out['bookdown::gitbook']['split_by'] = split_by
    if no_section_number:
        out['bookdown::gitbook']['number_sections'] = 0
    if pdf:
        pdf = (pdf, cfg['output_dir'], '{} {} {} --toc 3 --long_ref --font_size 12 {}'.\
               format('-a {}'.format(repr(author)) if author else '',
                      '-t {}'.format(repr(title)) if title else '',
                      '-d {}'.format(repr(date)) if date else '',
                      ' '.join(pdf_args)))
    # Move files around to resolve path problem for bookdown
    filenames = ['index.rmd' if idx == 0 else '{}_{}'.format(str(idx).zfill(4), os.path.basename(x))
                 for idx, x in enumerate(files)]
    filenames = [x if x.endswith('.rmd') else os.path.splitext(x)[0] + '.rmd' for x in filenames]
    for x, y in zip(files[1:], filenames[1:]):
        shutil.copy(x, os.path.join(workdir, y))
    with open(files[0]) as f:
        tmp = f.readlines()
        if len(tmp) == 0:
            tmp.append(' ')
        if not (tmp[0].startswith('# ')):
            name = os.path.splitext(os.path.basename(files[0]))[0].lstrip('0123456789.- ')
            tmp = ['# ' + re.sub(r'\-|_', ' ', name) + '\n'] \
                    + tmp
        tmp = ''.join(tmp)
    for i, fn in enumerate(files):
        if i == 0:
            continue
        with cd(workdir):
            with open(filenames[i]) as f:
                lines = f.readlines()
            if len(lines) == 0:
                lines.append(' ')
            if not (lines[0].startswith('# ')):
                name = os.path.splitext(os.path.basename(fn))[0].lstrip('0123456789.- ')
                lines = ['# ' + re.sub(r'\-|_', ' ', name) + '\n'] \
                        + lines
                with open(filenames[i], 'w') as f:
                    f.write(''.join(lines))
    # write resources
    with codecs.open(os.path.join(workdir, cfg['output_dir'], 'style.css'), 'w', encoding='UTF-8') as f:
            f.write(style)
    with codecs.open(os.path.join(workdir, cfg['output_dir'], 'toc.css'), 'w', encoding='UTF-8') as f:
            f.write(toc)
    with codecs.open(os.path.join(env.tmp_dir, 'preamble.tex'), 'w', encoding='UTF-8') as f:
            f.write(tex)
    error_msg = None
    try:
        with cd(workdir):
            with open(filenames[0], 'w') as f:
                f.write('---\n{}\n---\n{}'.format(dict2str(idx), tmp))
            cfg['rmd_files']['html'] = list(filenames)
            cfg['rmd_files']['latex'] = list(filenames)
            with open('_output.yml', 'w') as f:
                f.write(dict2str(out))
            with open('_bookdown.yml', 'w') as f:
                f.write(dict2str(cfg))
            sos_file = os.path.join(env.tmp_dir, 'bookdown.sos')
            with open(sos_file, 'w') as f:
                f.write(get_sos(filenames, pdf, workdir))
            os.system('sos run {}'.format(sos_file))
    except Exception as e:
        error_msg = e
    os.remove(sos_file)
    try:
        with cd(workdir):
            os.remove('_output.yml')
            os.remove('_bookdown.yml')
            for f in filenames:
                os.remove(f)
    except:
        pass
    if error_msg is not None:
        raise RuntimeError(error_msg)