Skip to content
Snippets Groups Projects
Select Git revision
  • b4783909d70dd0357e4fa78eb128aad3c7f5f81c
  • master default protected
  • rednatco-v2
  • rednatco
  • test
  • ntc-tube-uniform-color
  • ntc-tube-missing-atoms
  • restore-vertex-array-per-program
  • watlas2
  • dnatco_new
  • cleanup-old-nodejs
  • webmmb
  • fix_auth_seq_id
  • update_deps
  • ext_dev
  • ntc_balls
  • nci-2
  • plugin
  • bugfix-0.4.5
  • nci
  • servers
  • v0.5.0-dev.1
  • v0.4.5
  • v0.4.4
  • v0.4.3
  • v0.4.2
  • v0.4.1
  • v0.4.0
  • v0.3.12
  • v0.3.11
  • v0.3.10
  • v0.3.9
  • v0.3.8
  • v0.3.7
  • v0.3.6
  • v0.3.5
  • v0.3.4
  • v0.3.3
  • v0.3.2
  • v0.3.1
  • v0.3.0
41 results

task.ts

Blame
  • task.ts 4.27 KiB
    /**
     * Copyright (c) 2017 mol* contributors, licensed under MIT, See LICENSE file for more info.
     *
     * @author David Sehnal <david.sehnal@gmail.com>
     */
    
    import { Task, Progress, Scheduler, MultistepTask, chunkedSubtask } from '../mol-task';
    import { now } from '../mol-util/now';
    
    export async function test1() {
        const t = Task.create('test', async () => 1);
        const r = await t.run();
        console.log(r);
    }
    
    function messageTree(root: Progress.Node, prefix = ''): string {
        const p = root.progress;
        if (!root.children.length) {
            if (p.isIndeterminate) return `${prefix}${p.taskName}: ${p.message}`;
            return `${prefix}${p.taskName}: [${p.current}/${p.max}] ${p.message}`;
        }
    
        const newPrefix = prefix + '  |_ ';
        const subTree = root.children.map(c => messageTree(c, newPrefix));
        if (p.isIndeterminate) return `${prefix}${p.taskName}: ${p.message}\n${subTree.join('\n')}`;
        return `${prefix}${p.taskName}: [${p.current}/${p.max}] ${p.message}\n${subTree.join('\n')}`;
    }
    
    function createTask<T>(delayMs: number, r: T): Task<T> {
        return Task.create('delayed value ' + r, async ctx => {
            ctx.update(`Processing delayed ${r} after ${delayMs}ms`, true);
            await Scheduler.delay(delayMs);
            if (ctx.shouldUpdate) await ctx.update({ message: `hello from delayed ${r} ${delayMs}` });
            return r;
        }, () => console.log('On abort called ' + r));
    }
    
    export function abortAfter(delay: number) {
        return Task.create('abort after ' + delay, async ctx => {
            await Scheduler.delay(delay);
            throw Task.Aborted('test');
            // if (ctx.shouldUpdate) await ctx.update({ message: 'hello from delayed... ' });
            // return r;
        });
    }
    
    export function testTree() {
        return Task.create('test o', async ctx => {
            await Scheduler.delay(250);
            if (ctx.shouldUpdate) await ctx.update({ message: 'hi! 1' });
            await Scheduler.delay(125);
            if (ctx.shouldUpdate) await ctx.update({ message: 'hi! 2' });
            await Scheduler.delay(250);
            if (ctx.shouldUpdate) await ctx.update('hi! 3');
    
            // ctx.update('Running children...', true);
            const c1 = createTask(250, 1).runAsChild(ctx);
            const c2 = createTask(500, 2).runAsChild(ctx);
            const c3 = createTask(750, 3).runAsChild(ctx);
    
            // await ctx.runChild(abortAfter(350));
    
            const r = await c1 + await c2 + await c3;
            if (ctx.shouldUpdate) await ctx.update({ message: 'Almost done...' });
            return r + 1;
        }, () => console.log('On abort O'));
    }
    
    export type ChunkedState = { i: number, current: number, total: number }