Linux ip-172-26-7-228 5.4.0-1103-aws #111~18.04.1-Ubuntu SMP Tue May 23 20:04:10 UTC 2023 x86_64
Apache
: 172.26.7.228 | : 3.140.198.3
Cant Read [ /etc/named.conf ]
5.6.40-24+ubuntu18.04.1+deb.sury.org+1
www-data
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
snap /
core /
17200 /
usr /
bin /
[ HOME SHELL ]
Name
Size
Permission
Action
2to3-3.5
96
B
-rwxr-xr-x
[
50.7
KB
-rwxr-xr-x
aa-enabled
22.16
KB
-rwxr-xr-x
abootimg
18.27
KB
-rwxr-xr-x
abootimg-pack-initrd
362
B
-rwxr-xr-x
abootimg-unpack-initrd
272
B
-rwxr-xr-x
addpart
18.45
KB
-rwxr-xr-x
arch
30.7
KB
-rwxr-xr-x
awk
642.72
KB
-rwxr-xr-x
base32
38.73
KB
-rwxr-xr-x
base64
38.73
KB
-rwxr-xr-x
basename
30.67
KB
-rwxr-xr-x
bashbug
6.79
KB
-rwxr-xr-x
bootctl
74.44
KB
-rwxr-xr-x
busctl
363.21
KB
-rwxr-xr-x
c_rehash
6.05
KB
-rwxr-xr-x
captoinfo
70.71
KB
-rwxr-xr-x
catchsegv
3.26
KB
-rwxr-xr-x
cautious-launcher
853
B
-rwxr-xr-x
cgm
17.99
KB
-rwxr-xr-x
chacl
13.99
KB
-rwxr-xr-x
chage
60.88
KB
-rwxr-sr-x
chardet3
309
B
-rwxr-xr-x
chardetect3
309
B
-rwxr-xr-x
chattr
10.34
KB
-rwxr-xr-x
chcon
62.92
KB
-rwxr-xr-x
chfn
70.14
KB
-rwsr-xr-x
chrt
26.67
KB
-rwxr-xr-x
chsh
39.48
KB
-rwsr-xr-x
ckbcomp
144.19
KB
-rwxr-xr-x
cksum
30.67
KB
-rwxr-xr-x
clear
6.08
KB
-rwxr-xr-x
clear_console
10.27
KB
-rwxr-xr-x
cloud-id
310
B
-rwxr-xr-x
cloud-init
314
B
-rwxr-xr-x
cloud-init-per
2.06
KB
-rwxr-xr-x
cmp
42.67
KB
-rwxr-xr-x
codepage
10.29
KB
-rwxr-xr-x
comm
34.7
KB
-rwxr-xr-x
compose
17.55
KB
-rwxr-xr-x
console-conf
2.86
KB
-rwxr-xr-x
crontab
35.23
KB
-rwxr-sr-x
csplit
46.86
KB
-rwxr-xr-x
ctstat
18.68
KB
-rwxr-xr-x
cut
38.8
KB
-rwxr-xr-x
dbus-cleanup-sockets
9.98
KB
-rwxr-xr-x
dbus-daemon
218.95
KB
-rwxr-xr-x
dbus-monitor
21.99
KB
-rwxr-xr-x
dbus-run-session
9.98
KB
-rwxr-xr-x
dbus-send
21.98
KB
-rwxr-xr-x
dbus-update-activation-environ...
13.98
KB
-rwxr-xr-x
dbus-uuidgen
9.98
KB
-rwxr-xr-x
deallocvt
10.3
KB
-rwxr-xr-x
deb-systemd-helper
17.99
KB
-rwxr-xr-x
deb-systemd-invoke
4.37
KB
-rwxr-xr-x
debconf
2.79
KB
-rwxr-xr-x
debconf-apt-progress
11.27
KB
-rwxr-xr-x
debconf-communicate
608
B
-rwxr-xr-x
debconf-copydb
1.68
KB
-rwxr-xr-x
debconf-escape
647
B
-rwxr-xr-x
debconf-set-selections
2.87
KB
-rwxr-xr-x
debconf-show
1.78
KB
-rwxr-xr-x
delpart
18.45
KB
-rwxr-xr-x
dh_bash-completion
2.49
KB
-rwxr-xr-x
dh_pypy
11.71
KB
-rwxr-xr-x
dh_python3
11.91
KB
-rwxr-xr-x
diff
123.08
KB
-rwxr-xr-x
diff3
54.86
KB
-rwxr-xr-x
dircolors
38.71
KB
-rwxr-xr-x
dirname
30.67
KB
-rwxr-xr-x
dotlockfile
14.51
KB
-rwxr-sr-x
dpkg-deb
131.43
KB
-rwxr-xr-x
du
119.17
KB
-rwxr-xr-x
dumpimage
139.06
KB
-rwxr-xr-x
dumpkeys
166.52
KB
-rwxr-xr-x
ec2metadata
7.12
KB
-rwxr-xr-x
edit
17.55
KB
-rwxr-xr-x
editor
1.02
MB
-rwxr-xr-x
env
30.67
KB
-rwxr-xr-x
envsubst
34.51
KB
-rwxr-xr-x
ex
1.02
MB
-rwxr-xr-x
expand
30.73
KB
-rwxr-xr-x
expiry
22.23
KB
-rwxr-sr-x
expr
38.73
KB
-rwxr-xr-x
factor
70.77
KB
-rwxr-xr-x
faillog
18.25
KB
-rwxr-xr-x
fallocate
22.56
KB
-rwxr-xr-x
finalrd
2.1
KB
-rwxr-xr-x
find
216.57
KB
-rwxr-xr-x
flock
26.71
KB
-rwxr-xr-x
fmt
38.7
KB
-rwxr-xr-x
fold
34.7
KB
-rwxr-xr-x
free
18.37
KB
-rwxr-xr-x
fw_printenv
36.29
KB
-rwxr-xr-x
fw_setenv
36.29
KB
-rwxr-xr-x
fwupdate
13.99
KB
-rwxr-xr-x
gawk
642.72
KB
-rwxr-xr-x
gdbserver
408.53
KB
-rwxr-xr-x
getconf
22.41
KB
-rwxr-xr-x
getent
27.3
KB
-rwxr-xr-x
getfacl
22.62
KB
-rwxr-xr-x
getkeycodes
10.3
KB
-rwxr-xr-x
getopt
14.43
KB
-rwxr-xr-x
gettext
34.48
KB
-rwxr-xr-x
gettext.sh
4.52
KB
-rwxr-xr-x
gpasswd
73.54
KB
-rwsr-xr-x
gpg
984.87
KB
-rwxr-xr-x
gpg-zip
3.23
KB
-rwxr-xr-x
gpgsplit
58.76
KB
-rwxr-xr-x
gpgv
363.63
KB
-rwxr-xr-x
groups
30.7
KB
-rwxr-xr-x
growpart
20.99
KB
-rwxr-xr-x
grub-editenv
228.78
KB
-rwxr-xr-x
head
38.73
KB
-rwxr-xr-x
helpztags
2.46
KB
-rwxr-xr-x
hostid
26.64
KB
-rwxr-xr-x
hostnamectl
287.2
KB
-rwxr-xr-x
i386
14.38
KB
-rwxr-xr-x
iconv
59
KB
-rwxr-xr-x
id
38.83
KB
-rwxr-xr-x
igawk
3.11
KB
-rwxr-xr-x
infocmp
54.57
KB
-rwxr-xr-x
infotocap
70.71
KB
-rwxr-xr-x
install
135.59
KB
-rwxr-xr-x
ionice
22.59
KB
-rwxr-xr-x
ipcmk
22.69
KB
-rwxr-xr-x
ipcrm
26.54
KB
-rwxr-xr-x
ipcs
46.71
KB
-rwxr-xr-x
iptables-xml
92.74
KB
-rwxr-xr-x
ischroot
10.34
KB
-rwxr-xr-x
join
46.77
KB
-rwxr-xr-x
jsondiff
976
B
-rwxr-xr-x
jsonpatch
3.58
KB
-rwxr-xr-x
jsonpointer
1.31
KB
-rwxr-xr-x
jwt3
288
B
-rwxr-xr-x
kbdinfo
10.31
KB
-rwxr-xr-x
kwboot
14.33
KB
-rwxr-xr-x
last
38.84
KB
-rwxr-xr-x
lastb
38.84
KB
-rwxr-xr-x
lastlog
14.03
KB
-rwxr-xr-x
lcf
7.6
KB
-rwxr-xr-x
ldd
5.3
KB
-rwxr-xr-x
less
166.76
KB
-rwxr-xr-x
lessecho
10.02
KB
-rwxr-xr-x
lessfile
8.36
KB
-rwxr-xr-x
lesskey
19.39
KB
-rwxr-xr-x
lesspipe
8.36
KB
-rwxr-xr-x
line
10.32
KB
-rwxr-xr-x
link
26.64
KB
-rwxr-xr-x
linux-check-removal
3.99
KB
-rwxr-xr-x
linux-update-symlinks
6.17
KB
-rwxr-xr-x
linux-version
2.63
KB
-rwxr-xr-x
linux32
14.38
KB
-rwxr-xr-x
linux64
14.38
KB
-rwxr-xr-x
lnstat
18.68
KB
-rwxr-xr-x
loadkeys
206.57
KB
-rwxr-xr-x
loadunimap
26.66
KB
-rwxr-xr-x
locale
37.91
KB
-rwxr-xr-x
localectl
295.22
KB
-rwxr-xr-x
localedef
315.71
KB
-rwxr-xr-x
lockfile-check
14.25
KB
-rwxr-xr-x
lockfile-create
14.25
KB
-rwxr-xr-x
lockfile-remove
14.25
KB
-rwxr-xr-x
lockfile-touch
14.25
KB
-rwxr-xr-x
logger
35.35
KB
-rwxr-xr-x
logname
26.67
KB
-rwxr-xr-x
lsattr
10.33
KB
-rwxr-xr-x
lscpu
55.12
KB
-rwxr-xr-x
lsinitramfs
2.43
KB
-rwxr-xr-x
lsipc
59
KB
-rwxr-xr-x
lslocks
31.09
KB
-rwxr-xr-x
lslogins
51.15
KB
-rwxr-xr-x
lspgpot
1.06
KB
-rwxr-xr-x
lzcat
67.11
KB
-rwxr-xr-x
lzcmp
5.39
KB
-rwxr-xr-x
lzdiff
5.39
KB
-rwxr-xr-x
lzegrep
5.56
KB
-rwxr-xr-x
lzfgrep
5.56
KB
-rwxr-xr-x
lzgrep
5.56
KB
-rwxr-xr-x
lzless
1.78
KB
-rwxr-xr-x
lzma
67.11
KB
-rwxr-xr-x
lzmainfo
10.31
KB
-rwxr-xr-x
lzmore
2.12
KB
-rwxr-xr-x
mail-lock
14.25
KB
-rwxr-sr-x
mail-touchlock
14.25
KB
-rwxr-sr-x
mail-unlock
14.25
KB
-rwxr-sr-x
mapscrn
18.66
KB
-rwxr-xr-x
mawk
115.01
KB
-rwxr-xr-x
mcookie
26.71
KB
-rwxr-xr-x
md5sum
42.77
KB
-rwxr-xr-x
md5sum.textutils
42.77
KB
-rwxr-xr-x
mesg
10.37
KB
-rwxr-xr-x
mk_modmap
15.78
KB
-rwxr-xr-x
mkenvimage
14.2
KB
-rwxr-xr-x
mkfifo
58.95
KB
-rwxr-xr-x
mkimage
143.06
KB
-rwxr-xr-x
mkknlimg
5.87
KB
-rwxr-xr-x
mksquashfs
174.12
KB
-rwxr-xr-x
mksunxiboot
6.12
KB
-rwxr-xr-x
mkswapfile
865
B
-rwxr-xr-x
namei
26.58
KB
-rwxr-xr-x
nawk
642.72
KB
-rwxr-xr-x
newgrp
38.97
KB
-rwsr-xr-x
ngettext
34.5
KB
-rwxr-xr-x
nice
34.7
KB
-rwxr-xr-x
nl
38.83
KB
-rwxr-xr-x
nohup
30.7
KB
-rwxr-xr-x
nproc
30.7
KB
-rwxr-xr-x
nsenter
26.88
KB
-rwxr-xr-x
nstat
22.47
KB
-rwxr-xr-x
numfmt
58.86
KB
-rwxr-xr-x
od
66.83
KB
-rwxr-xr-x
openssl
545.97
KB
-rwxr-xr-x
pager
166.73
KB
-rwxr-xr-x
partx
75.63
KB
-rwxr-xr-x
passwd
52.98
KB
-rwsr-xr-x
paste
30.7
KB
-rwxr-xr-x
pathchk
30.67
KB
-rwxr-xr-x
pdb3
59.56
KB
-rwxr-xr-x
pdb3.5
59.56
KB
-rwxr-xr-x
perl
1.82
MB
-rwxr-xr-x
perl5.22.1
1.82
MB
-rwxr-xr-x
pg
38.91
KB
-rwxr-xr-x
pgrep
26.63
KB
-rwxr-xr-x
pinky
34.86
KB
-rwxr-xr-x
pkill
26.63
KB
-rwxr-xr-x
pldd
14.59
KB
-rwxr-xr-x
plog
146
B
-rwxr-xr-x
pmap
30.61
KB
-rwxr-xr-x
poff
2.77
KB
-rwxr-xr-x
pon
1.33
KB
-rwxr-xr-x
pr
74.95
KB
-rwxr-xr-x
print
17.55
KB
-rwxr-xr-x
printenv
30.64
KB
-rwxr-xr-x
printf
46.73
KB
-rwxr-xr-x
prlimit
31.3
KB
-rwxr-xr-x
probert
2.09
KB
-rwxr-xr-x
psfaddtable
18.42
KB
-rwxr-xr-x
psfgettable
18.42
KB
-rwxr-xr-x
psfstriptable
18.42
KB
-rwxr-xr-x
psfxtable
18.42
KB
-rwxr-xr-x
ptx
66.95
KB
-rwxr-xr-x
pwdx
10.36
KB
-rwxr-xr-x
py3clean
7.62
KB
-rwxr-xr-x
py3compile
11.83
KB
-rwxr-xr-x
py3versions
11.44
KB
-rwxr-xr-x
pybuild
21.33
KB
-rwxr-xr-x
pydoc3
79
B
-rwxr-xr-x
pydoc3.5
79
B
-rwxr-xr-x
pygettext3
21.73
KB
-rwxr-xr-x
pygettext3.5
21.73
KB
-rwxr-xr-x
python3
4.25
MB
-rwxr-xr-x
python3-jsondiff
976
B
-rwxr-xr-x
python3-jsonpatch
3.58
KB
-rwxr-xr-x
python3-jsonpointer
1.31
KB
-rwxr-xr-x
python3.5
4.25
MB
-rwxr-xr-x
python3.5m
4.25
MB
-rwxr-xr-x
python3m
4.25
MB
-rwxr-xr-x
rcp
86.14
KB
-rwxr-xr-x
realpath
58.83
KB
-rwxr-xr-x
rename.ul
14.41
KB
-rwxr-xr-x
renice
10.38
KB
-rwxr-xr-x
reset
18.42
KB
-rwxr-xr-x
resizecons
18.6
KB
-rwxr-xr-x
resizepart
34.86
KB
-rwxr-xr-x
rev
10.38
KB
-rwxr-xr-x
rgrep
30
B
-rwxr-xr-x
rlogin
690.67
KB
-rwxr-xr-x
routef
173
B
-rwxr-xr-x
routel
1.23
KB
-rwxr-xr-x
rsh
690.67
KB
-rwxr-xr-x
rtstat
18.68
KB
-rwxr-xr-x
run-mailcap
17.55
KB
-rwxr-xr-x
runcon
34.8
KB
-rwxr-xr-x
rview
1.02
MB
-rwxr-xr-x
savelog
10.22
KB
-rwxr-xr-x
sc-logresolve
816
B
-rwxr-xr-x
scmp_sys_resolver
10.26
KB
-rwxr-xr-x
scp
86.14
KB
-rwxr-xr-x
screendump
10.33
KB
-rwxr-xr-x
script
22.66
KB
-rwxr-xr-x
scriptreplay
14.4
KB
-rwxr-xr-x
sdiff
46.78
KB
-rwxr-xr-x
see
17.55
KB
-rwxr-xr-x
select-editor
1.19
KB
-rwxr-xr-x
sensible-browser
1.11
KB
-rwxr-xr-x
sensible-editor
1.08
KB
-rwxr-xr-x
sensible-pager
288
B
-rwxr-xr-x
seq
46.73
KB
-rwxr-xr-x
setarch
14.38
KB
-rwxr-xr-x
setfacl
34.68
KB
-rwxr-xr-x
setkeycodes
10.29
KB
-rwxr-xr-x
setleds
10.32
KB
-rwxr-xr-x
setlogcons
10.27
KB
-rwxr-xr-x
setmetamode
10.37
KB
-rwxr-xr-x
setsid
10.38
KB
-rwxr-xr-x
setterm
34.61
KB
-rwxr-xr-x
sftp
134.36
KB
-rwxr-xr-x
sg
38.97
KB
-rwsr-xr-x
sha1sum
42.77
KB
-rwxr-xr-x
sha224sum
50.77
KB
-rwxr-xr-x
sha256sum
50.77
KB
-rwxr-xr-x
sha384sum
54.77
KB
-rwxr-xr-x
sha512sum
54.77
KB
-rwxr-xr-x
showconsolefont
18.4
KB
-rwxr-xr-x
showkey
14.34
KB
-rwxr-xr-x
shred
54.92
KB
-rwxr-xr-x
shuf
54.83
KB
-rwxr-xr-x
skill
22.61
KB
-rwxr-xr-x
slabtop
18.47
KB
-rwxr-xr-x
slogin
690.67
KB
-rwxr-xr-x
snap
15.85
MB
-rwxr-xr-x
snapctl
6.13
MB
-rwxr-xr-x
snapfuse
38.61
KB
-rwxr-xr-x
snice
22.61
KB
-rwxr-xr-x
sort
107.46
KB
-rwxr-xr-x
split
67.41
KB
-rwxr-xr-x
splitfont
10.27
KB
-rwxr-xr-x
ssh
690.67
KB
-rwxr-xr-x
ssh-add
330.21
KB
-rwxr-xr-x
ssh-agent
350.22
KB
-rwxr-sr-x
ssh-argv0
1.42
KB
-rwxr-xr-x
ssh-copy-id
10.12
KB
-rwxr-xr-x
ssh-keygen
390.23
KB
-rwxr-xr-x
ssh-keyscan
406.23
KB
-rwxr-xr-x
stat
79.05
KB
-rwxr-xr-x
stdbuf
62.83
KB
-rwxr-xr-x
sudo
133.6
KB
-rwsr-xr-x
sudoedit
133.6
KB
-rwsr-xr-x
sudoreplay
46.56
KB
-rwxr-xr-x
sum
38.74
KB
-rwxr-xr-x
systemd-analyze
1.43
MB
-rwxr-xr-x
systemd-cat
34.43
KB
-rwxr-xr-x
systemd-cgls
291.22
KB
-rwxr-xr-x
systemd-cgtop
303.3
KB
-rwxr-xr-x
systemd-delta
62.59
KB
-rwxr-xr-x
systemd-detect-virt
34.42
KB
-rwxr-xr-x
systemd-path
42.42
KB
-rwxr-xr-x
systemd-resolve
327.21
KB
-rwxr-xr-x
systemd-run
367.52
KB
-rwxr-xr-x
systemd-stdio-bridge
343.2
KB
-rwxr-xr-x
tabs
14.23
KB
-rwxr-xr-x
tac
34.73
KB
-rwxr-xr-x
tail
62.92
KB
-rwxr-xr-x
taskset
30.68
KB
-rwxr-xr-x
tee
34.73
KB
-rwxr-xr-x
test
46.7
KB
-rwxr-xr-x
tic
70.71
KB
-rwxr-xr-x
timedatectl
813
B
-rwxr-xr-x
timedatectl.real
295.22
KB
-rwxr-xr-x
timeout
55.38
KB
-rwxr-xr-x
tload
14.44
KB
-rwxr-xr-x
toe
14.34
KB
-rwxr-xr-x
top
106.51
KB
-rwxr-xr-x
touch
86.21
KB
-rwxr-xr-x
tput
14.3
KB
-rwxr-xr-x
tr
46.73
KB
-rwxr-xr-x
truncate
50.8
KB
-rwxr-xr-x
tset
18.42
KB
-rwxr-xr-x
tsort
34.67
KB
-rwxr-xr-x
tty
26.67
KB
-rwxr-xr-x
tzselect
14.86
KB
-rwxr-xr-x
ubuntu-core-launcher
124.53
KB
-rwsr-xr-x
ucf
39.68
KB
-rwxr-xr-x
ucfq
18.91
KB
-rwxr-xr-x
ucfr
10.47
KB
-rwxr-xr-x
unexpand
30.73
KB
-rwxr-xr-x
unicode_stop
530
B
-rwxr-xr-x
uniq
42.77
KB
-rwxr-xr-x
unlink
26.64
KB
-rwxr-xr-x
unlzma
67.11
KB
-rwxr-xr-x
unshare
18.72
KB
-rwxr-xr-x
unsquashfs
92.65
KB
-rwxr-xr-x
unxz
67.11
KB
-rwxr-xr-x
update-alternatives
46.61
KB
-rwxr-xr-x
uptime
10.33
KB
-rwxr-xr-x
users
30.7
KB
-rwxr-xr-x
utmpdump
14.52
KB
-rwxr-xr-x
vcs-run
6.75
KB
-rwxr-xr-x
vi
1.02
MB
-rwxr-xr-x
view
1.02
MB
-rwxr-xr-x
vim.tiny
1.02
MB
-rwxr-xr-x
vmstat
30.48
KB
-rwxr-xr-x
w
18.48
KB
-rwxr-xr-x
w.procps
18.48
KB
-rwxr-xr-x
wall
26.73
KB
-rwxr-sr-x
watch
23.14
KB
-rwxr-xr-x
wc
42.8
KB
-rwxr-xr-x
whereis
23.09
KB
-rwxr-xr-x
which
946
B
-rwxr-xr-x
who
46.86
KB
-rwxr-xr-x
whoami
26.67
KB
-rwxr-xr-x
wpa_passphrase
58
KB
-rwxr-xr-x
x86_64
14.38
KB
-rwxr-xr-x
xargs
66.21
KB
-rwxr-xr-x
xdelta3
150.84
KB
-rwxr-xr-x
xdg-open
38
B
-rwxr-xr-x
xdg-settings
886
B
-rwxr-xr-x
xxd
18.12
KB
-rwxr-xr-x
xz
67.11
KB
-rwxr-xr-x
xzcat
67.11
KB
-rwxr-xr-x
xzcmp
5.39
KB
-rwxr-xr-x
xzdiff
5.39
KB
-rwxr-xr-x
xzegrep
5.56
KB
-rwxr-xr-x
xzfgrep
5.56
KB
-rwxr-xr-x
xzgrep
5.56
KB
-rwxr-xr-x
xzless
1.78
KB
-rwxr-xr-x
xzmore
2.12
KB
-rwxr-xr-x
yes
30.67
KB
-rwxr-xr-x
zdump
14.42
KB
-rwxr-xr-x
Delete
Unzip
Zip
${this.title}
Close
Code Editor : pybuild
#! /usr/bin/python3 # vim: et ts=4 sw=4 # Copyright © 2012-2013 Piotr Ożarowski <piotr@debian.org> # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal # in the Software without restriction, including without limitation the rights # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell # copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN # THE SOFTWARE. import logging import argparse import sys from os import environ, getcwd, makedirs, remove from os.path import abspath, exists, join from shutil import rmtree logging.basicConfig(format='%(levelname).1s: pybuild ' '%(module)s:%(lineno)d: %(message)s') log = logging.getLogger('dhpython') def main(cfg): log.debug('cfg: %s', cfg) from dhpython import build from dhpython.version import Version, build_sorted, get_requested_versions from dhpython.interpreter import Interpreter from dhpython.tools import execute, move_matching_files if cfg.list_systems: for name, Plugin in sorted(build.plugins.items()): print(name, '\t', Plugin.DESCRIPTION) exit(0) nocheck = False if 'DEB_BUILD_OPTIONS' in environ: nocheck = 'nocheck' in environ['DEB_BUILD_OPTIONS'] env = environ.copy() if 'LC_ALL' not in env: env['LC_ALL'] = 'C.UTF-8' if 'no_proxy' not in env: env['no_proxy'] = 'localhost' if 'http_proxy' not in env: env['http_proxy'] = 'http://127.0.0.1:9/' elif not env['http_proxy']: del env['http_proxy'] # some tools don't like empty var. if 'https_proxy' not in env: env['https_proxy'] = 'https://127.0.0.1:9/' elif not env['https_proxy']: del env['https_proxy'] # some tools don't like empty var. if cfg.system: certainty = 99 Plugin = build.plugins.get(cfg.system) if not Plugin: log.error('unrecognized build system: %s', cfg.system) exit(10) plugin = Plugin(cfg) context = {'ENV': env, 'args': {}, 'dir': cfg.dir} plugin.detect(context) else: plugin, certainty, context = None, 0, None for Plugin in build.plugins.values(): try: tmp_plugin = Plugin(cfg) except Exception as err: log.warn('cannot initialize %s plugin: %s', Plugin.NAME, err, exc_info=cfg.verbose) continue tmp_context = {'ENV': env, 'args': {}, 'dir': cfg.dir} tmp_certainty = tmp_plugin.detect(tmp_context) if tmp_certainty and tmp_certainty > certainty: plugin, certainty, context = tmp_plugin, tmp_certainty, tmp_context del Plugin if not plugin: log.error('cannot detect build system, please use --system option' ' or set PYBUILD_SYSTEM env. variable') exit(11) for interpreter in cfg.interpreter: if plugin.SUPPORTED_INTERPRETERS is not True and interpreter not in plugin.SUPPORTED_INTERPRETERS: log.error('interpreter %s not supported by %s', interpreter, plugin) exit(12) log.debug('detected build system: %s (certainty: %s%%)', plugin.NAME, certainty) if cfg.detect_only: if not cfg.really_quiet: print(plugin.NAME) exit(0) # reversed so that default Python version will be last versions = cfg.versions if not versions: log.debug('defaulting to all supported Python 3.X versions') versions = list(get_requested_versions('cpython3', available=True)) versions = [Version(v) for v in versions] def get_option(name, interpreter=None, version=None, default=None): if interpreter: # try PYBUILD_NAME_python3.3-dbg (or hardcoded interpreter) i = interpreter.format(version=version or '') opt = "PYBUILD_{}_{}".format(name.upper(), i) if opt in environ: return environ[opt] # try PYBUILD_NAME_python3-dbg (if not checked above) if '{version}' in interpreter and version: i = interpreter.format(version=version.major) opt = "PYBUILD_{}_{}".format(name.upper(), i) if opt in environ: return environ[opt] # try PYBUILD_NAME opt = "PYBUILD_{}".format(name.upper()) if opt in environ: return environ[opt] # try command line args return getattr(cfg, name, default) or default def get_args(context, step, version, interpreter): i = interpreter.format(version=version) home_dir = '.pybuild/{}_{}'.format(interpreter.format(version='X.Y'), version) build_dir = get_option('build_dir', interpreter, version, default=join(home_dir, 'build')) ipreter = Interpreter(i) destdir = context['destdir'].format(version=version, interpreter=i) if cfg.name: package = ipreter.suggest_pkg_name(cfg.name) else: package = 'PYBUILD_NAME_not_set' if cfg.name and destdir.rstrip('/').endswith('debian/tmp'): destdir = "debian/{}".format(package) destdir = abspath(destdir) args = dict(context['args']) args.update({ 'package': package, 'interpreter': ipreter, 'version': version, 'args': get_option("%s_args" % step, interpreter, version, ''), 'dir': abspath(context['dir'].format(version=version, interpreter=i)), 'destdir': destdir, 'build_dir': abspath(build_dir.format(version=version, interpreter=i)), # versioned dist-packages even for Python 3.X - dh_python3 will fix it later # (and will have a chance to compare files) 'install_dir': get_option('install_dir', interpreter, version, '/usr/lib/python{version}/dist-packages' ).format(version=version, interpreter=i), 'home_dir': abspath(home_dir)}) if interpreter == 'pypy': args['install_dir'] = '/usr/lib/pypy/dist-packages/' if step in {'build', 'test'}: pp = context['ENV'].get('PYTHONPATH') pp = pp.split(':') if pp else [] if step == 'test': args['test_dir'] = join(args['destdir'], args['install_dir'].lstrip('/')) if args['test_dir'] not in pp: pp.append(args['test_dir']) if args['build_dir'] not in pp: pp.append(args['build_dir']) args['PYTHONPATH'] = ':'.join(pp) if not exists(args['build_dir']): makedirs(args['build_dir']) return args def is_disabled(step, interpreter, version): i = interpreter prefix = "{}/".format(step) disabled = (get_option('disable', i, version) or '').split() for item in disabled: if item in (step, '1'): log.debug('disabling {} step for {} {}'.format(step, i, version)) return True if item.startswith(prefix): disabled.append(item[len(prefix):]) if i in disabled or str(version) in disabled or \ i.format(version=version) in disabled or \ i.format(version=version.major) in disabled: log.debug('disabling {} step for {} {}'.format(step, i, version)) return True return False def run(func, interpreter, version, context): step = func.__func__.__name__ args = get_args(context, step, version, interpreter) if 'PYTHONPATH' in args: env = dict(context['ENV']) env['PYTHONPATH'] = args['PYTHONPATH'] else: env = context['ENV'] before_cmd = get_option('before_{}'.format(step), interpreter, version) if before_cmd: if cfg.quiet: log_file = join(args['home_dir'], 'before_{}_cmd.log'.format(step)) else: log_file = False command = before_cmd.format(**args) output = execute(command, context['dir'], env, log_file) if output['returncode'] != 0: msg = 'exit code={}: {}'.format(output['returncode'], command) raise Exception(msg) fpath = join(args['home_dir'], 'build_dirs_to_rm_before_install') if step == 'install' and exists(fpath): with open(fpath) as fp: for line in fp: dpath = join(args['build_dir'], line.strip('\n')) if exists(dpath): rmtree(dpath) remove(fpath) result = func(context, args) after_cmd = get_option('after_{}'.format(step), interpreter, version) if after_cmd: if cfg.quiet: log_file = join(args['home_dir'], 'after_{}_cmd.log'.format(step)) else: log_file = False command = after_cmd.format(**args) output = execute(command, context['dir'], env, log_file) if output['returncode'] != 0: msg = 'exit code={}: {}'.format(output['returncode'], command) raise Exception(msg) return result func = None if cfg.clean_only: func = plugin.clean elif cfg.configure_only: func = plugin.configure elif cfg.build_only: func = plugin.build elif cfg.install_only: func = plugin.install elif cfg.test_only: func = plugin.test ### one function for each interpreter at a time mode ### if func: step = func.__func__.__name__ if step == 'test' and nocheck: exit(0) for i in cfg.interpreter: ipreter = Interpreter(interpreter.format(version=versions[0])) iversions = build_sorted(versions, impl=ipreter.impl) if '{version}' not in i and len(versions) > 1: log.info('limiting Python versions to %s due to missing {version}' ' in interpreter string', str(versions[-1])) iversions = versions[-1:] # just the default or closest to default for version in iversions: if is_disabled(step, i, version): continue c = dict(context) c['dir'] = get_option('dir', i, version, cfg.dir) c['destdir'] = get_option('destdir', i, version, cfg.destdir) try: run(func, i, version, c) except Exception as err: log.error('%s: plugin %s failed with: %s', step, plugin.NAME, err, exc_info=cfg.verbose) exit(13) if step == 'install': ext_destdir = get_option('ext_destdir', i, version) if ext_destdir: move_matching_files(c['destdir'], ext_destdir, get_option('ext_pattern', i, version)) exit(0) ### all functions for interpreters in batches mode ### try: context_map = {} for i in cfg.interpreter: ipreter = Interpreter(interpreter.format(version=versions[0])) iversions = build_sorted(versions, impl=ipreter.impl) if '{version}' not in i and len(versions) > 1: log.info('limiting Python versions to %s due to missing {version}' ' in interpreter string', str(versions[-1])) iversions = versions[-1:] # just the default or closest to default for version in iversions: key = (i, version) if key in context_map: c = context_map[key] else: c = dict(context) c['dir'] = get_option('dir', i, version, cfg.dir) c['destdir'] = get_option('destdir', i, version, cfg.destdir) context_map[key] = c if not is_disabled('clean', i, version): run(plugin.clean, i, version, c) if not is_disabled('configure', i, version): run(plugin.configure, i, version, c) if not is_disabled('build', i, version): run(plugin.build, i, version, c) if not is_disabled('install', i, version): run(plugin.install, i, version, c) ext_destdir = get_option('ext_destdir', i, version) if ext_destdir: move_matching_files(c['destdir'], ext_destdir, get_option('ext_pattern', i, version)) if not nocheck and not is_disabled('test', i, version): run(plugin.test, i, version, c) except Exception as err: log.error('plugin %s failed: %s', plugin.NAME, err, exc_info=cfg.verbose) exit(14) def parse_args(argv): usage = '%(prog)s [ACTION] [BUILD SYSTEM ARGS] [DIRECTORIES] [OPTIONS]' parser = argparse.ArgumentParser(usage=usage) parser.add_argument('-v', '--verbose', action='store_true', default=environ.get('PYBUILD_VERBOSE') == '1', help='turn verbose mode on') parser.add_argument('-q', '--quiet', action='store_true', default=environ.get('PYBUILD_QUIET') == '1', help='doesn\'t show external command\'s output') parser.add_argument('-qq', '--really-quiet', action='store_true', default=environ.get('PYBUILD_RQUIET') == '1', help='be quiet') parser.add_argument('--version', action='version', version='%(prog)s 2.20151103ubuntu1.2') action = parser.add_argument_group('ACTION', '''The default is to build, install and test the library using detected build system version by version. Selecting one of following actions, will invoke given action for all versions - one by one - which (contrary to the default action) in some build systems can overwrite previous results.''') action.add_argument('--detect', action='store_true', dest='detect_only', help='return the name of detected build system') action.add_argument('--clean', action='store_true', dest='clean_only', help='clean files using auto-detected build system specific methods') action.add_argument('--configure', action='store_true', dest='configure_only', help='invoke configure step for all requested Python versions') action.add_argument('--build', action='store_true', dest='build_only', help='invoke build step for all requested Python versions') action.add_argument('--install', action='store_true', dest='install_only', help='invoke install step for all requested Python versions') action.add_argument('--test', action='store_true', dest='test_only', help='invoke tests for auto-detected build system') action.add_argument('--list-systems', action='store_true', help='list available build systems and exit') arguments = parser.add_argument_group('BUILD SYSTEM ARGS', ''' Additional arguments passed to the build system. --system=custom requires complete command.''') arguments.add_argument('--before-clean', metavar='CMD', help='invoked before the clean command') arguments.add_argument('--clean-args', metavar='ARGS') arguments.add_argument('--after-clean', metavar='CMD', help='invoked after the clean command') arguments.add_argument('--before-configure', metavar='CMD', help='invoked before the configure command') arguments.add_argument('--configure-args', metavar='ARGS') arguments.add_argument('--after-configure', metavar='CMD', help='invoked after the configure command') arguments.add_argument('--before-build', metavar='CMD', help='invoked before the build command') arguments.add_argument('--build-args', metavar='ARGS') arguments.add_argument('--after-build', metavar='CMD', help='invoked after the build command') arguments.add_argument('--before-install', metavar='CMD', help='invoked before the install command') arguments.add_argument('--install-args', metavar='ARGS') arguments.add_argument('--after-install', metavar='CMD', help='invoked after the install command') arguments.add_argument('--before-test', metavar='CMD', help='invoked before the test command') arguments.add_argument('--test-args', metavar='ARGS') arguments.add_argument('--after-test', metavar='CMD', help='invoked after the test command') tests = parser.add_argument_group('TESTS', '''\ unittest\'s discover is used by default (if available)''') tests.add_argument('--test-nose', action='store_true', default=environ.get('PYBUILD_TEST_NOSE') == '1', help='use nose module in --test step') tests.add_argument('--test-pytest', action='store_true', default=environ.get('PYBUILD_TEST_PYTEST') == '1', help='use pytest module in --test step') tests.add_argument('--test-tox', action='store_true', default=environ.get('PYBUILD_TEST_TOX') == '1', help='use tox in --test step') dirs = parser.add_argument_group('DIRECTORIES') dirs.add_argument('-d', '--dir', action='store', metavar='DIR', default=getcwd(), help='source files directory - base for other relative dirs [default: CWD]') dirs.add_argument('--dest-dir', action='store', metavar='DIR', dest='destdir', default=environ.get('DESTDIR', 'debian/tmp'), help='destination directory [default: debian/tmp]') dirs.add_argument('--ext-dest-dir', action='store', metavar='DIR', dest='ext_destdir', default=environ.get('EXT_DESTDIR'), help='destination directory for .so files') dirs.add_argument('--ext-pattern', action='store', metavar='PATTERN', default=environ.get('EXT_PATTERN', r'\.so(\.[^/]*)?$'), help='regular expression for files that should be moved' ' if --ext-dest-dir is set [default: .so files]') dirs.add_argument('--install-dir', action='store', metavar='DIR', help='installation directory [default: .../dist-packages]') dirs.add_argument('--name', action='store', default=environ.get('PYBUILD_NAME'), help='use this name to guess destination directories') limit = parser.add_argument_group('LIMITATIONS') limit.add_argument('-s', '--system', default=environ.get('PYBUILD_SYSTEM'), help='select a build system [default: auto-detection]') limit.add_argument('-p', '--pyver', action='append', dest='versions', help='''build for Python VERSION. This option can be used multiple times [default: all supported Python 3.X versions]''') limit.add_argument('-i', '--interpreter', action='append', help='change interpreter [default: python{version}]') limit.add_argument('--disable', metavar='ITEMS', help='disable action, interpreter or version') args = parser.parse_args() if not args.interpreter: args.interpreter = environ.get('PYBUILD_INTERPRETERS', 'python{version}').split() if not args.versions: args.versions = environ.get('PYBUILD_VERSIONS', '').split() else: # add support for -p `pyversions -rv` versions = [] for version in args.versions: versions.extend(version.split()) args.versions = versions if args.test_nose or args.test_pytest or args.test_tox\ or args.system == 'custom': args.custom_tests = True else: args.custom_tests = False return args if __name__ == '__main__': cfg = parse_args(sys.argv) if cfg.really_quiet: cfg.quiet = True log.setLevel(logging.CRITICAL) elif cfg.verbose: log.setLevel(logging.DEBUG) else: log.setLevel(logging.INFO) log.debug('version: 2.20151103ubuntu1.2') log.debug(sys.argv) main(cfg) # let dh/cdbs clean the .pybuild dir # rmtree(join(cfg.dir, '.pybuild'))
Close