##// END OF EJS Templates
Merge pull request #3340 from minrk/submodpkg...
Min RK -
r10809:ca60480a merge
parent child Browse files
Show More
@@ -1,92 +1,103
1 """utilities for checking submodule status"""
1 """utilities for checking submodule status"""
2
2
3 #-----------------------------------------------------------------------------
3 #-----------------------------------------------------------------------------
4 # Copyright (C) 2013 The IPython Development Team
4 # Copyright (C) 2013 The IPython Development Team
5 #
5 #
6 # Distributed under the terms of the BSD License. The full license is in
6 # Distributed under the terms of the BSD License. The full license is in
7 # the file COPYING, distributed as part of this software.
7 # the file COPYING, distributed as part of this software.
8 #-----------------------------------------------------------------------------
8 #-----------------------------------------------------------------------------
9
9
10 #-----------------------------------------------------------------------------
10 #-----------------------------------------------------------------------------
11 # Imports
11 # Imports
12 #-----------------------------------------------------------------------------
12 #-----------------------------------------------------------------------------
13
13
14 import os
14 import os
15 import subprocess
15 import subprocess
16 import sys
16 import sys
17
17
18 #-----------------------------------------------------------------------------
18 #-----------------------------------------------------------------------------
19 # Globals
19 # Globals
20 #-----------------------------------------------------------------------------
20 #-----------------------------------------------------------------------------
21
21
22 pjoin = os.path.join
22 pjoin = os.path.join
23
23
24 #-----------------------------------------------------------------------------
24 #-----------------------------------------------------------------------------
25 # Code
25 # Code
26 #-----------------------------------------------------------------------------
26 #-----------------------------------------------------------------------------
27
27
28 def ipython_parent():
28 def ipython_parent():
29 """return IPython's parent (i.e. root if run from git)"""
29 """return IPython's parent (i.e. root if run from git)"""
30 from IPython.utils.path import get_ipython_package_dir
30 from IPython.utils.path import get_ipython_package_dir
31 return os.path.abspath(os.path.dirname(get_ipython_package_dir()))
31 return os.path.abspath(os.path.dirname(get_ipython_package_dir()))
32
32
33 def ipython_submodules(root):
33 def ipython_submodules(root):
34 """return IPython submodules relative to root"""
34 """return IPython submodules relative to root"""
35 from IPython.frontend.html.notebook import DEFAULT_STATIC_FILES_PATH
35 return [
36 return [
36 pjoin(root, 'IPython', 'frontend', 'html', 'notebook', 'static', 'components'),
37 pjoin(DEFAULT_STATIC_FILES_PATH, 'components')
37 ]
38 ]
38
39
39 def is_repo(d):
40 def is_repo(d):
40 """is d a git repo?"""
41 """is d a git repo?"""
41 return os.path.exists(pjoin(d, '.git'))
42 return os.path.exists(pjoin(d, '.git'))
42
43
44 def is_package():
45 """Is a package manager responsible for the static files path?"""
46 from IPython.utils.path import get_ipython_package_dir
47 from IPython.frontend.html.notebook import DEFAULT_STATIC_FILES_PATH
48 return not DEFAULT_STATIC_FILES_PATH.startswith(get_ipython_package_dir())
49
43 def check_submodule_status(root=None):
50 def check_submodule_status(root=None):
44 """check submodule status
51 """check submodule status
45
52
46 Has three return values:
53 Has three return values:
47
54
48 'missing' - submodules are absent
55 'missing' - submodules are absent
49 'unclean' - submodules have unstaged changes
56 'unclean' - submodules have unstaged changes
50 'clean' - all submodules are up to date
57 'clean' - all submodules are up to date
51 """
58 """
52
59
53 if hasattr(sys, "frozen"):
60 if hasattr(sys, "frozen"):
54 # frozen via py2exe or similar, don't bother
61 # frozen via py2exe or similar, don't bother
55 return 'clean'
62 return 'clean'
56
63
64 if is_package():
65 # package manager is responsible for static files, don't bother
66 return 'clean'
67
57 if not root:
68 if not root:
58 root = ipython_parent()
69 root = ipython_parent()
59
70
60 submodules = ipython_submodules(root)
71 submodules = ipython_submodules(root)
61
72
62 for submodule in submodules:
73 for submodule in submodules:
63 if not os.path.exists(submodule):
74 if not os.path.exists(submodule):
64 return 'missing'
75 return 'missing'
65
76
66 if not is_repo(root):
77 if not is_repo(root):
67 # not in git, assume clean
78 # not in git, assume clean
68 return 'clean'
79 return 'clean'
69
80
70 # check with git submodule status
81 # check with git submodule status
71 proc = subprocess.Popen('git submodule status',
82 proc = subprocess.Popen('git submodule status',
72 stdout=subprocess.PIPE,
83 stdout=subprocess.PIPE,
73 stderr=subprocess.PIPE,
84 stderr=subprocess.PIPE,
74 shell=True,
85 shell=True,
75 cwd=root,
86 cwd=root,
76 )
87 )
77 status, _ = proc.communicate()
88 status, _ = proc.communicate()
78 status = status.decode("ascii")
89 status = status.decode("ascii")
79
90
80 for line in status.splitlines():
91 for line in status.splitlines():
81 if status.startswith('-'):
92 if status.startswith('-'):
82 return 'missing'
93 return 'missing'
83 elif status.startswith('+'):
94 elif status.startswith('+'):
84 return 'unclean'
95 return 'unclean'
85
96
86 return 'clean'
97 return 'clean'
87
98
88 def update_submodules(repo_dir):
99 def update_submodules(repo_dir):
89 """update submodules in a repo"""
100 """update submodules in a repo"""
90 subprocess.check_call("git submodule init", cwd=repo_dir, shell=True)
101 subprocess.check_call("git submodule init", cwd=repo_dir, shell=True)
91 subprocess.check_call("git submodule update --recursive", cwd=repo_dir, shell=True)
102 subprocess.check_call("git submodule update --recursive", cwd=repo_dir, shell=True)
92
103
General Comments 0
You need to be logged in to leave comments. Login now