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
bc3b0608
Kaydet (Commit)
bc3b0608
authored
Agu 24, 2005
tarafından
Martin v. Löwis
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Patch #1262036: Make tarfile name absolute. Fixes #1257255.
Will backport to 2.4.
üst
94ac1975
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
9 additions
and
20 deletions
+9
-20
tarfile.py
Lib/tarfile.py
+7
-20
NEWS
Misc/NEWS
+2
-0
No files found.
Lib/tarfile.py
Dosyayı görüntüle @
bc3b0608
...
@@ -849,7 +849,7 @@ class TarFile(object):
...
@@ -849,7 +849,7 @@ class TarFile(object):
can be determined, `mode' is overridden by `fileobj's mode.
can be determined, `mode' is overridden by `fileobj's mode.
`fileobj' is not closed, when TarFile is closed.
`fileobj' is not closed, when TarFile is closed.
"""
"""
self
.
name
=
name
self
.
name
=
os
.
path
.
abspath
(
name
)
if
len
(
mode
)
>
1
or
mode
not
in
"raw"
:
if
len
(
mode
)
>
1
or
mode
not
in
"raw"
:
raise
ValueError
,
"mode must be 'r', 'a' or 'w'"
raise
ValueError
,
"mode must be 'r', 'a' or 'w'"
...
@@ -861,7 +861,7 @@ class TarFile(object):
...
@@ -861,7 +861,7 @@ class TarFile(object):
self
.
_extfileobj
=
False
self
.
_extfileobj
=
False
else
:
else
:
if
self
.
name
is
None
and
hasattr
(
fileobj
,
"name"
):
if
self
.
name
is
None
and
hasattr
(
fileobj
,
"name"
):
self
.
name
=
fileobj
.
name
self
.
name
=
os
.
path
.
abspath
(
fileobj
.
name
)
if
hasattr
(
fileobj
,
"mode"
):
if
hasattr
(
fileobj
,
"mode"
):
self
.
mode
=
fileobj
.
mode
self
.
mode
=
fileobj
.
mode
self
.
_extfileobj
=
True
self
.
_extfileobj
=
True
...
@@ -998,22 +998,18 @@ class TarFile(object):
...
@@ -998,22 +998,18 @@ class TarFile(object):
raise
CompressionError
,
"gzip module is not available"
raise
CompressionError
,
"gzip module is not available"
pre
,
ext
=
os
.
path
.
splitext
(
name
)
pre
,
ext
=
os
.
path
.
splitext
(
name
)
pre
=
os
.
path
.
basename
(
pre
)
if
ext
==
".tgz"
:
if
ext
==
".tgz"
:
ext
=
".tar"
ext
=
".tar"
if
ext
==
".gz"
:
if
ext
==
".gz"
:
ext
=
""
ext
=
""
tarname
=
pre
+
ext
tarname
=
os
.
path
.
basename
(
pre
+
ext
)
if
fileobj
is
None
:
if
fileobj
is
None
:
fileobj
=
file
(
name
,
mode
+
"b"
)
fileobj
=
file
(
name
,
mode
+
"b"
)
if
mode
!=
"r"
:
name
=
tarname
try
:
try
:
t
=
cls
.
taropen
(
tar
name
,
mode
,
t
=
cls
.
taropen
(
name
,
mode
,
gzip
.
GzipFile
(
name
,
mode
,
compresslevel
,
fileobj
)
gzip
.
GzipFile
(
tar
name
,
mode
,
compresslevel
,
fileobj
)
)
)
except
IOError
:
except
IOError
:
raise
ReadError
,
"not a gzip file"
raise
ReadError
,
"not a gzip file"
...
@@ -1033,19 +1029,11 @@ class TarFile(object):
...
@@ -1033,19 +1029,11 @@ class TarFile(object):
except
ImportError
:
except
ImportError
:
raise
CompressionError
,
"bz2 module is not available"
raise
CompressionError
,
"bz2 module is not available"
pre
,
ext
=
os
.
path
.
splitext
(
name
)
pre
=
os
.
path
.
basename
(
pre
)
if
ext
==
".tbz2"
:
ext
=
".tar"
if
ext
==
".bz2"
:
ext
=
""
tarname
=
pre
+
ext
if
fileobj
is
not
None
:
if
fileobj
is
not
None
:
raise
ValueError
,
"no support for external file objects"
raise
ValueError
,
"no support for external file objects"
try
:
try
:
t
=
cls
.
taropen
(
tar
name
,
mode
,
bz2
.
BZ2File
(
name
,
mode
,
compresslevel
=
compresslevel
))
t
=
cls
.
taropen
(
name
,
mode
,
bz2
.
BZ2File
(
name
,
mode
,
compresslevel
=
compresslevel
))
except
IOError
:
except
IOError
:
raise
ReadError
,
"not a bzip2 file"
raise
ReadError
,
"not a bzip2 file"
t
.
_extfileobj
=
False
t
.
_extfileobj
=
False
...
@@ -1250,8 +1238,7 @@ class TarFile(object):
...
@@ -1250,8 +1238,7 @@ class TarFile(object):
arcname
=
name
arcname
=
name
# Skip if somebody tries to archive the archive...
# Skip if somebody tries to archive the archive...
if
self
.
name
is
not
None
\
if
self
.
name
is
not
None
and
os
.
path
.
samefile
(
name
,
self
.
name
):
and
os
.
path
.
abspath
(
name
)
==
os
.
path
.
abspath
(
self
.
name
):
self
.
_dbg
(
2
,
"tarfile: Skipped
%
r"
%
name
)
self
.
_dbg
(
2
,
"tarfile: Skipped
%
r"
%
name
)
return
return
...
...
Misc/NEWS
Dosyayı görüntüle @
bc3b0608
...
@@ -188,6 +188,8 @@ Extension Modules
...
@@ -188,6 +188,8 @@ Extension Modules
Library
Library
-------
-------
-
Patch
#
1262036
:
Make
tarfile
name
absolute
.
Fixes
#
1257255.
-
Patch
#
827386
:
Support
absolute
source
paths
in
msvccompiler
.
py
.
-
Patch
#
827386
:
Support
absolute
source
paths
in
msvccompiler
.
py
.
-
Patch
#
1105730
:
Apply
the
new
implementation
of
commonprefix
in
posixpath
-
Patch
#
1105730
:
Apply
the
new
implementation
of
commonprefix
in
posixpath
...
...
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