Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
setuptools
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Jérome Perrin
setuptools
Commits
070b4e89
Commit
070b4e89
authored
Oct 28, 2016
by
Jason R. Coombs
Committed by
GitHub
Oct 28, 2016
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #832 from pypa/namespace-module
Add a namespace module.
parents
1e368654
2e8ebcb6
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
101 additions
and
59 deletions
+101
-59
CHANGES.rst
CHANGES.rst
+6
-0
setuptools/command/install_egg_info.py
setuptools/command/install_egg_info.py
+2
-59
setuptools/namespaces.py
setuptools/namespaces.py
+93
-0
No files found.
CHANGES.rst
View file @
070b4e89
...
...
@@ -2,6 +2,12 @@
CHANGES
=======
v28
.7.0
-------
*
Moved
much
of
the
namespace
package
handling
functionality
into
a
separate
module
for
re
-
use
in
something
like
#
789.
v28
.6.1
-------
...
...
setuptools/command/install_egg_info.py
View file @
070b4e89
from
distutils
import
log
,
dir_util
import
os
from
setuptools.extern.six.moves
import
map
from
setuptools
import
Command
from
setuptools
import
namespaces
from
setuptools.archive_util
import
unpack_archive
import
pkg_resources
class
install_egg_info
(
Command
):
class
install_egg_info
(
namespaces
.
Installer
,
Command
):
"""Install an .egg-info directory for the package"""
description
=
"Install an .egg-info directory for the package"
...
...
@@ -61,59 +60,3 @@ class install_egg_info(Command):
return
dst
unpack_archive
(
self
.
source
,
self
.
target
,
skimmer
)
def
install_namespaces
(
self
):
nsp
=
self
.
_get_all_ns_packages
()
if
not
nsp
:
return
filename
,
ext
=
os
.
path
.
splitext
(
self
.
target
)
filename
+=
'-nspkg.pth'
self
.
outputs
.
append
(
filename
)
log
.
info
(
"Installing %s"
,
filename
)
lines
=
map
(
self
.
_gen_nspkg_line
,
nsp
)
if
self
.
dry_run
:
# always generate the lines, even in dry run
list
(
lines
)
return
with
open
(
filename
,
'wt'
)
as
f
:
f
.
writelines
(
lines
)
_nspkg_tmpl
=
(
"import sys, types, os"
,
"pep420 = sys.version_info > (3, 3)"
,
"p = os.path.join(sys._getframe(1).f_locals['sitedir'], *%(pth)r)"
,
"ie = os.path.exists(os.path.join(p,'__init__.py'))"
,
"m = not ie and not pep420 and "
"sys.modules.setdefault(%(pkg)r, types.ModuleType(%(pkg)r))"
,
"mp = (m or []) and m.__dict__.setdefault('__path__',[])"
,
"(p not in mp) and mp.append(p)"
,
)
"lines for the namespace installer"
_nspkg_tmpl_multi
=
(
'm and setattr(sys.modules[%(parent)r], %(child)r, m)'
,
)
"additional line(s) when a parent package is indicated"
@
classmethod
def
_gen_nspkg_line
(
cls
,
pkg
):
# ensure pkg is not a unicode string under Python 2.7
pkg
=
str
(
pkg
)
pth
=
tuple
(
pkg
.
split
(
'.'
))
tmpl_lines
=
cls
.
_nspkg_tmpl
parent
,
sep
,
child
=
pkg
.
rpartition
(
'.'
)
if
parent
:
tmpl_lines
+=
cls
.
_nspkg_tmpl_multi
return
';'
.
join
(
tmpl_lines
)
%
locals
()
+
'
\
n
'
def
_get_all_ns_packages
(
self
):
"""Return sorted list of all package namespaces"""
nsp
=
set
()
for
pkg
in
self
.
distribution
.
namespace_packages
or
[]:
pkg
=
pkg
.
split
(
'.'
)
while
pkg
:
nsp
.
add
(
'.'
.
join
(
pkg
))
pkg
.
pop
()
return
sorted
(
nsp
)
setuptools/namespaces.py
0 → 100755
View file @
070b4e89
import
os
from
distutils
import
log
import
itertools
from
setuptools.extern.six.moves
import
map
flatten
=
itertools
.
chain
.
from_iterable
class
Installer
:
nspkg_ext
=
'-nspkg.pth'
def
install_namespaces
(
self
):
nsp
=
self
.
_get_all_ns_packages
()
if
not
nsp
:
return
filename
,
ext
=
os
.
path
.
splitext
(
self
.
_get_target
())
filename
+=
self
.
nspkg_ext
self
.
outputs
.
append
(
filename
)
log
.
info
(
"Installing %s"
,
filename
)
lines
=
map
(
self
.
_gen_nspkg_line
,
nsp
)
if
self
.
dry_run
:
# always generate the lines, even in dry run
list
(
lines
)
return
with
open
(
filename
,
'wt'
)
as
f
:
f
.
writelines
(
lines
)
def
_get_target
(
self
):
return
self
.
target
_nspkg_tmpl
=
(
"import sys, types, os"
,
"pep420 = sys.version_info > (3, 3)"
,
"p = os.path.join(%(root)s, *%(pth)r)"
,
"ie = os.path.exists(os.path.join(p,'__init__.py'))"
,
"m = not ie and not pep420 and "
"sys.modules.setdefault(%(pkg)r, types.ModuleType(%(pkg)r))"
,
"mp = (m or []) and m.__dict__.setdefault('__path__',[])"
,
"(p not in mp) and mp.append(p)"
,
)
"lines for the namespace installer"
_nspkg_tmpl_multi
=
(
'm and setattr(sys.modules[%(parent)r], %(child)r, m)'
,
)
"additional line(s) when a parent package is indicated"
def
_get_root
(
self
):
return
"sys._getframe(1).f_locals['sitedir']"
def
_gen_nspkg_line
(
self
,
pkg
):
# ensure pkg is not a unicode string under Python 2.7
pkg
=
str
(
pkg
)
pth
=
tuple
(
pkg
.
split
(
'.'
))
root
=
self
.
_get_root
()
tmpl_lines
=
self
.
_nspkg_tmpl
parent
,
sep
,
child
=
pkg
.
rpartition
(
'.'
)
if
parent
:
tmpl_lines
+=
self
.
_nspkg_tmpl_multi
return
';'
.
join
(
tmpl_lines
)
%
locals
()
+
'
\
n
'
def
_get_all_ns_packages
(
self
):
"""Return sorted list of all package namespaces"""
pkgs
=
self
.
distribution
.
namespace_packages
or
[]
return
sorted
(
flatten
(
map
(
self
.
_pkg_names
,
pkgs
)))
@
staticmethod
def
_pkg_names
(
pkg
):
"""
Given a namespace package, yield the components of that
package.
>>> names = Installer._pkg_names('a.b.c')
>>> set(names) == set(['a', 'a.b', 'a.b.c'])
True
"""
parts
=
pkg
.
split
(
'.'
)
while
parts
:
yield
'.'
.
join
(
parts
)
parts
.
pop
()
class
DevelopInstaller
(
Installer
):
def
_get_root
(
self
):
return
repr
(
str
(
self
.
egg_path
))
def
_get_target
(
self
):
return
self
.
egg_link
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment