-
Notifications
You must be signed in to change notification settings - Fork 5
/
pavement.py
116 lines (100 loc) · 3.42 KB
/
pavement.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
# -*- coding: utf-8 -*-
import os
import platform
import fnmatch
import zipfile
from paver.easy import *
options(
plugin=Bunch(
name='AcATaMa',
ext_libs=path('extlibs'),
source_dir=path('.'),
package_dir=path('.'),
tests=['test', 'tests'],
excludes=[
"*.pyc",
".git",
".github",
".idea",
".gitignore",
".docker",
"__pycache__",
".pytest_cache",
".coverage",
"Makefile",
"build.md",
"metadata_new.txt",
"pavement.py",
"plugin_upload.py",
"docs",
"examples",
"tests",
"scripts",
"AcATaMa.zip"
]
),
)
@task
@cmdopts([('clean', 'c', 'clean out dependencies first')])
def setup():
clean = getattr(options, 'clean', False)
ext_libs = options.plugin.ext_libs
if clean:
ext_libs.rmtree()
ext_libs.makedirs()
reqs = read_requirements()
os.environ['PYTHONPATH'] = ext_libs.abspath()
for req in reqs:
if platform.system() == "Windows":
sh('pip install -U -t "{ext_libs}" "{dep}"'.format(ext_libs=ext_libs.abspath(), dep=req))
else:
sh('pip3 install -U -t "{ext_libs}" "{dep}"'.format(ext_libs=ext_libs.abspath(), dep=req))
@task
def install(options):
'''install plugin to qgis'''
plugin_name = options.plugin.name
src = path(__file__).dirname()
if platform.system() == "Windows":
dst = path('~/AppData/Roaming/QGIS/QGIS3/profiles/default/python/plugins').expanduser() / plugin_name
if platform.system() == "Darwin":
dst = path(
'~/Library/Application Support/QGIS/QGIS3/profiles/default/python/plugins').expanduser() / plugin_name
if platform.system() == "Linux":
dst = path('~/.local/share/QGIS/QGIS3/profiles/default/python/plugins').expanduser() / plugin_name
src = src.abspath()
dst = dst.abspath()
if not hasattr(os, 'symlink'):
dst.rmtree()
src.copytree(dst)
elif not dst.exists():
src.symlink(dst)
def read_requirements():
'''return a list of packages in requirements file'''
with open('requirements.txt') as f:
return [l.strip('\n') for l in f if l.strip('\n') and not l.startswith('#')]
@task
@cmdopts([('tests', 't', 'Package tests with plugin')])
def package(options):
'''create package for plugin'''
package_file = options.plugin.package_dir / ('%s.zip' % options.plugin.name)
with zipfile.ZipFile(package_file, "w", zipfile.ZIP_DEFLATED) as f:
if not hasattr(options.package, 'tests'):
options.plugin.excludes.extend(options.plugin.tests)
make_zip(f, options)
def make_zip(zipFile, options):
excludes = set(options.plugin.excludes)
src_dir = options.plugin.source_dir
exclude = lambda p: any([fnmatch.fnmatch(p, e) for e in excludes])
def filter_excludes(files):
if not files: return []
# to prevent descending into dirs, modify the list in place
for i in range(len(files) - 1, -1, -1):
f = files[i]
if exclude(f):
files.remove(f)
return files
for root, dirs, files in os.walk(src_dir):
for f in filter_excludes(files):
relpath = os.path.relpath(root, '..')
zipFile.write(path(root) / f, path(relpath) / f)
filter_excludes(dirs)