Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
0bbbb005
Kaydet (Commit)
0bbbb005
authored
Nis 28, 2006
tarafından
Neal Norwitz
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Add some whitespace to be more consistent.
üst
076ba212
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
11 deletions
+13
-11
pkgutil.py
Lib/pkgutil.py
+13
-11
No files found.
Lib/pkgutil.py
Dosyayı görüntüle @
0bbbb005
...
@@ -31,7 +31,7 @@ def read_code(stream):
...
@@ -31,7 +31,7 @@ def read_code(stream):
def
simplegeneric
(
func
):
def
simplegeneric
(
func
):
"""Make a trivial single-dispatch generic function"""
"""Make a trivial single-dispatch generic function"""
registry
=
{}
registry
=
{}
def
wrapper
(
*
args
,
**
kw
):
def
wrapper
(
*
args
,
**
kw
):
ob
=
args
[
0
]
ob
=
args
[
0
]
try
:
try
:
cls
=
ob
.
__class__
cls
=
ob
.
__class__
...
@@ -41,18 +41,19 @@ def simplegeneric(func):
...
@@ -41,18 +41,19 @@ def simplegeneric(func):
mro
=
cls
.
__mro__
mro
=
cls
.
__mro__
except
AttributeError
:
except
AttributeError
:
try
:
try
:
class
cls
(
cls
,
object
):
pass
class
cls
(
cls
,
object
):
pass
mro
=
cls
.
__mro__
[
1
:]
mro
=
cls
.
__mro__
[
1
:]
except
TypeError
:
except
TypeError
:
mro
=
object
,
# must be an ExtensionClass or some such :(
mro
=
object
,
# must be an ExtensionClass or some such :(
for
t
in
mro
:
for
t
in
mro
:
if
t
in
registry
:
if
t
in
registry
:
return
registry
[
t
](
*
args
,
**
kw
)
return
registry
[
t
](
*
args
,
**
kw
)
else
:
else
:
return
func
(
*
args
,
**
kw
)
return
func
(
*
args
,
**
kw
)
try
:
try
:
wrapper
.
__name__
=
func
.
__name__
wrapper
.
__name__
=
func
.
__name__
except
(
TypeError
,
AttributeError
):
except
(
TypeError
,
AttributeError
):
pass
# Python 2.3 doesn't allow functions to be renamed
pass
# Python 2.3 doesn't allow functions to be renamed
def
register
(
typ
,
func
=
None
):
def
register
(
typ
,
func
=
None
):
...
@@ -70,8 +71,9 @@ def simplegeneric(func):
...
@@ -70,8 +71,9 @@ def simplegeneric(func):
def
walk_packages
(
path
=
None
,
prefix
=
''
,
onerror
=
None
):
def
walk_packages
(
path
=
None
,
prefix
=
''
,
onerror
=
None
):
"""Yield submodule names+loaders recursively, for path or sys.path"""
"""Yield submodule names+loaders recursively, for path or sys.path"""
def
seen
(
p
,
m
=
{}):
def
seen
(
p
,
m
=
{}):
if
p
in
m
:
return
True
if
p
in
m
:
return
True
m
[
p
]
=
True
m
[
p
]
=
True
for
importer
,
name
,
ispkg
in
iter_modules
(
path
,
prefix
):
for
importer
,
name
,
ispkg
in
iter_modules
(
path
,
prefix
):
...
@@ -110,7 +112,7 @@ def iter_modules(path=None, prefix=''):
...
@@ -110,7 +112,7 @@ def iter_modules(path=None, prefix=''):
#@simplegeneric
#@simplegeneric
def
iter_importer_modules
(
importer
,
prefix
=
''
):
def
iter_importer_modules
(
importer
,
prefix
=
''
):
if
not
hasattr
(
importer
,
'iter_modules'
):
if
not
hasattr
(
importer
,
'iter_modules'
):
return
[]
return
[]
return
importer
.
iter_modules
(
prefix
)
return
importer
.
iter_modules
(
prefix
)
...
@@ -336,7 +338,7 @@ def get_importer(path_item):
...
@@ -336,7 +338,7 @@ def get_importer(path_item):
pass
pass
else
:
else
:
importer
=
None
importer
=
None
sys
.
path_importer_cache
.
setdefault
(
path_item
,
importer
)
sys
.
path_importer_cache
.
setdefault
(
path_item
,
importer
)
if
importer
is
None
:
if
importer
is
None
:
try
:
try
:
...
@@ -377,7 +379,7 @@ def iter_importers(fullname=""):
...
@@ -377,7 +379,7 @@ def iter_importers(fullname=""):
pkg
=
'.'
.
join
(
fullname
.
split
(
'.'
)[:
-
1
])
pkg
=
'.'
.
join
(
fullname
.
split
(
'.'
)[:
-
1
])
if
pkg
not
in
sys
.
modules
:
if
pkg
not
in
sys
.
modules
:
__import__
(
pkg
)
__import__
(
pkg
)
path
=
getattr
(
sys
.
modules
[
pkg
],
'__path__'
,
None
)
or
[]
path
=
getattr
(
sys
.
modules
[
pkg
],
'__path__'
,
None
)
or
[]
else
:
else
:
for
importer
in
sys
.
meta_path
:
for
importer
in
sys
.
meta_path
:
yield
importer
yield
importer
...
@@ -404,7 +406,7 @@ def get_loader(module_or_name):
...
@@ -404,7 +406,7 @@ def get_loader(module_or_name):
module_or_name
=
sys
.
modules
[
module_or_name
]
module_or_name
=
sys
.
modules
[
module_or_name
]
if
isinstance
(
module_or_name
,
ModuleType
):
if
isinstance
(
module_or_name
,
ModuleType
):
module
=
module_or_name
module
=
module_or_name
loader
=
getattr
(
module
,
'__loader__'
,
None
)
loader
=
getattr
(
module
,
'__loader__'
,
None
)
if
loader
is
not
None
:
if
loader
is
not
None
:
return
loader
return
loader
fullname
=
module
.
__name__
fullname
=
module
.
__name__
...
...
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