Project

General

Profile

1
#!/bin/bash
2
# Imports all inputs at once
3

    
4
import_all_main ()
5
{
6
    local self="${BASH_SOURCE[0]}"
7
    local selfDir="$(dirname -- "$self")"
8
    cd "$selfDir/.."
9
    
10
    if test "${BASH_LINENO[1]}" = 0; then # was run without initial "."
11
        echo "Usage: [version=...;] . $self [vars...] (note initial \".\")"\
12
        |fold -s >&2
13
        return 2
14
    fi
15
    : ${version=$(make -s version)} ${dump_opts=--exclude-schema=public}
16
    export version dump_opts public_import=1
17
    
18
    make inputs/.TNRS/tnrs_accepted/reinstall
19
    make inputs/.TNRS/tnrs_other/reinstall
20
    
21
    make schemas/$version/install
22
    
23
    all=1; . "$selfDir/with_all" Source/import by_col=1 "$@"
24
        # note that this isn't affected by $import_source
25
    wait # wait for asynchronous commands
26
    unset all
27
    
28
    local import_source= # Source tables have already been imported
29
    export import_source # must come after local
30
    
31
    make inputs/.herbaria/import "$@" &
32
    sleep 5 # wait for make commands to scroll by
33
    
34
    make inputs/.geoscrub/import "$@" &
35
    sleep 5 # wait for make commands to scroll by
36
    
37
    make inputs/.NCBI/import by_col=1 "$@"
38
    # Must come after NCBI for cross links to be made
39
    make inputs/.TNRS/import "$@"
40
    
41
    wait # wait for asynchronous commands
42
    
43
    . "$selfDir/with_all" import "$@"
44
    make inputs/.TNRS/tnrs/tnrs-remake wait=1 "$@" &
45
    make inputs/.TNRS/public.unscrubbed_taxondetermination_view/scrub-remake \
46
        wait=1 "$@" &
47
    
48
    after_import ()
49
    {
50
        bin/make_analytical_db
51
        
52
        make backups/TNRS.backup-remake &
53
        make backups/vegbien.$version.backup/test & # uses $dump_opts
54
        wait # wait for asynchronous commands
55
    }
56
    
57
    jobs="$(jobs -p)"
58
    (bin/waitpid $jobs; after_import) &
59
}
60
import_all_main "$@"
(27-27/72)