Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
eepm
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Nurlan
eepm
Commits
c46c41ad
Commit
c46c41ad
authored
Jul 11, 2013
by
Vitaly Lipatov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update packed
parent
0d186c4d
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
105 additions
and
35 deletions
+105
-35
epm.sh
packed/epm.sh
+103
-33
serv.sh
packed/serv.sh
+2
-2
No files found.
packed/epm.sh
View file @
c46c41ad
...
@@ -212,7 +212,7 @@ set_sudo()
...
@@ -212,7 +212,7 @@ set_sudo()
get_help
()
get_help
()
{
{
grep
-
-
"#
$1
"
$0
|
while
read
n
;
do
grep
-
v
--
"^#"
$0
|
grep
--
"#
$1
"
|
while
read
n
;
do
opt
=
$(
echo
$n
|
sed
-e
"s|) #
$1
:.*||g"
)
opt
=
$(
echo
$n
|
sed
-e
"s|) #
$1
:.*||g"
)
desc
=
$(
echo
$n
|
sed
-e
"s|.*) #
$1
:||g"
)
desc
=
$(
echo
$n
|
sed
-e
"s|.*) #
$1
:||g"
)
printf
" %-20s %s
\n
"
$opt
"
$desc
"
printf
" %-20s %s
\n
"
$opt
"
$desc
"
...
@@ -491,9 +491,9 @@ case $PMTYPE in
...
@@ -491,9 +491,9 @@ case $PMTYPE in
emerge
)
emerge
)
sudocmd revdep-rebuild
sudocmd revdep-rebuild
;;
;;
urpm-rpm
)
#
urpm-rpm)
#
sudocmd urpme --auto-orphans
#
sudocmd urpme --auto-orphans
;;
#
;;
zypper-rpm
)
zypper-rpm
)
sudocmd zypper verify
||
exit
sudocmd zypper verify
||
exit
;;
;;
...
@@ -1047,7 +1047,11 @@ epm_install_files()
...
@@ -1047,7 +1047,11 @@ epm_install_files()
sudocmd pacman
-U
$force
$@
sudocmd pacman
-U
$force
$@
return
;;
return
;;
slackpkg
)
slackpkg
)
sudocmd /sbin/installpkg
$@
# FIXME: check for full package name
separate_installed
$@
# FIXME: broken status when use batch and default answer
[
-n
"
$pkg_noninstalled
"
]
&&
sudocmd_foreach
"/sbin/installpkg"
$pkg_noninstalled
[
-n
"
$pkg_installed
"
]
&&
sudocmd_foreach
"/sbin/upgradepkg"
$pkg_installed
return
;;
return
;;
esac
esac
...
@@ -1238,7 +1242,8 @@ case $PMTYPE in
...
@@ -1238,7 +1242,8 @@ case $PMTYPE in
[
-n
"
$short
"
]
&&
CMD
=
"rpm -qa --queryformat %{name}
\n
$pkg_filenames
"
[
-n
"
$short
"
]
&&
CMD
=
"rpm -qa --queryformat %{name}
\n
$pkg_filenames
"
;;
;;
apt-dpkg
)
apt-dpkg
)
CMD
=
"dpkg -l
$pkg_filenames
"
#CMD="dpkg -l $pkg_filenames"
CMD
=
"dpkg-query -W --showformat=
\$
{Package}-
\$
{Version}
\n
$pkg_filenames
"
[
-n
"
$short
"
]
&&
CMD
=
"dpkg-query -W --showformat=
\$
{Package}
\n
$pkg_filenames
"
[
-n
"
$short
"
]
&&
CMD
=
"dpkg-query -W --showformat=
\$
{Package}
\n
$pkg_filenames
"
;;
;;
yum-rpm|urpm-rpm|zypper-rpm|dnf-rpm
)
yum-rpm|urpm-rpm|zypper-rpm|dnf-rpm
)
...
@@ -1299,6 +1304,7 @@ epm_programs()
...
@@ -1299,6 +1304,7 @@ epm_programs()
# File bin/epm-provides:
# File bin/epm-provides:
epm_provides
()
epm_provides
()
{
{
local
CMD
local
CMD
...
@@ -1351,14 +1357,60 @@ _query_via_packages_list()
...
@@ -1351,14 +1357,60 @@ _query_via_packages_list()
local
res
=
0
local
res
=
0
local
firstpkg
=
$1
local
firstpkg
=
$1
shift
shift
# separate first line for print out command
# separate first line for print out command
short
=
1
pkg_filenames
=
$firstpkg
epm_packages |
grep
--
"^
$firstpkg
$"
||
res
=
1
pkg_filenames
=
$firstpkg
epm_packages |
grep
--
"^
$firstpkg
$"
||
res
=
1
for
pkg
in
"
$@
"
;
do
for
pkg
in
"
$@
"
;
do
short
=
1
pkg_filenames
=
$pkg
epm_packages 2>/dev/null |
grep
--
"^
$pkg
$"
||
res
=
1
pkg_filenames
=
$pkg
epm_packages 2>/dev/null |
grep
--
"^
$pkg
$"
||
res
=
1
done
done
return
$res
return
$res
}
}
__epm_get_hilevel_nameform
()
{
[
-n
"
$*
"
]
||
return
case
$PMTYPE
in
apt-rpm
)
# use # as delimeter for apt
local
pkg
pkg
=
$(
rpm
-q
--queryformat
"%{NAME}#%{SERIAL}:%{VERSION}-%{RELEASE}
\n
"
$1
)
echo
$pkg
|
grep
-q
"(none)"
&&
pkg
=
$(
rpm
-q
--queryformat
"%{NAME}#%{VERSION}-%{RELEASE}
\n
"
$1
)
# HACK: can use only for multiple install packages like kernel
echo
$pkg
|
grep
-q
kernel
||
return
1
echo
$pkg
return
;;
yum-rpm
)
# just use strict version with Epoch and Serial
local
pkg
pkg
=
$(
rpm
-q
--queryformat
"%{EPOCH}:%{NAME}%{VERSION}-%{RELEASE}.
${
ARCH
}
\n
"
$1
)
echo
$pkg
|
grep
-q
"(none)"
&&
pkg
=
$(
rpm
-q
--queryformat
"%{NAME}-%{VERSION}-%{RELEASE}.
${
ARCH
}
\n
"
$1
)
echo
$pkg
return
;;
*
)
return
1
;;
esac
}
__epm_get_hilevel_name
()
{
local
i
for
i
in
$@
;
do
local
pkg
# get short form in pkg
quiet
=
1
short
=
1
pkg
=
$(
__epm_query_name
$i
)
# if already short form, skipped
[
"
$pkg
"
=
"
$i
"
]
&&
echo
"
$i
"
&&
continue
# try get long form or use short form
__epm_get_hilevel_nameform
$i
||
echo
$pkg
done
}
__epm_query_file
()
__epm_query_file
()
{
{
local
CMD
local
CMD
...
@@ -1368,13 +1420,11 @@ __epm_query_file()
...
@@ -1368,13 +1420,11 @@ __epm_query_file()
case
$PMTYPE
in
case
$PMTYPE
in
*
-rpm
)
*
-rpm
)
CMD
=
"rpm -qp"
CMD
=
"rpm -qp"
[
-n
"
$short
"
]
&&
CMD
=
"rpm -qp --queryformat %{name}
\n
"
;;
;;
apt-dpkg
)
apt-dpkg
)
CMD
=
"dpkg-deb --show"
CMD
=
"dpkg-deb --show --showformat=
\$
{Package}-
\$
{Version}
\n
"
# TODO: make rpm-like output
[
-n
"
$short
"
]
&&
CMD
=
"dpkg-query --show --showformat=
\$
{Package}
\n
"
#showcmd dpkg -l $pkg_filenames
#dpkg -l $pkg_filenames | grep "^ii"
#return
;;
;;
*
)
*
)
fatal
"Do not know command for query file package"
fatal
"Do not know command for query file package"
...
@@ -1393,14 +1443,12 @@ __epm_query_name()
...
@@ -1393,14 +1443,12 @@ __epm_query_name()
case
$PMTYPE
in
case
$PMTYPE
in
*
-rpm
)
*
-rpm
)
CMD
=
"rpm -q"
CMD
=
"rpm -q"
[
-n
"
$short
"
]
&&
CMD
=
"rpm -q --queryformat %{name}
\n
"
;;
;;
apt-dpkg
)
apt-dpkg
)
#docmd dpkg -l $@
#docmd dpkg -l $@ | grep "^ii"
docmd dpkg
-l
$@
|
grep
"^ii"
CMD
=
"dpkg-query -W --showformat=
\$
{Package}-
\$
{Version}
\n
"
# TODO: make rpm-like output
[
-n
"
$short
"
]
&&
CMD
=
"dpkg-query -W --showformat=
\$
{Package}
\n
"
#showcmd dpkg -l $pkg_filenames
#dpkg -l $pkg_filenames | grep "^ii"
return
;;
;;
npackd
)
npackd
)
CMD
=
"npackdcl path --package=
$@
"
CMD
=
"npackdcl path --package=
$@
"
...
@@ -1692,6 +1740,7 @@ epm_release_upgrade()
...
@@ -1692,6 +1740,7 @@ epm_release_upgrade()
# File bin/epm-remove:
# File bin/epm-remove:
epm_remove_low
()
epm_remove_low
()
{
{
[
-z
"
$1
"
]
&&
return
[
-z
"
$1
"
]
&&
return
...
@@ -1844,19 +1893,23 @@ epm_remove()
...
@@ -1844,19 +1893,23 @@ epm_remove()
return
return
fi
fi
[
-n
"
$pkg_files
"
]
&&
fatal
"FIXME: remove by package file is not supported yet"
# get full package name(s) from the package file(s)
[
-n
"
$pkg_files
"
]
&&
pkg_names
=
"
$pkg_names
$(
epm query
$pkg_files
)
"
[
-n
"
$pkg_names
"
]
||
fatal
"Run remove without args"
epm_remove_low
$pkg_names
&&
return
[
-n
"
$pkg_filenames
"
]
||
fatal
"Run remove without args"
# get package name for hi level package management command (with version if supported and if possible)
epm_remove_low
$pkg_filenames
&&
return
pkg_names
=
$(
__epm_get_hilevel_name
$pkg_names
)
if
[
-n
"
$non_interactive
"
]
;
then
if
[
-n
"
$non_interactive
"
]
;
then
epm_remove_nonint
$pkg_
file
names
epm_remove_nonint
$pkg_names
local
RET
=
$?
local
RET
=
$?
# if not separate command, use usual command
# if not separate command, use usual command
[
"
$RET
"
=
"5"
]
||
return
$RET
[
"
$RET
"
=
"5"
]
||
return
$RET
fi
fi
epm_remove_names
$pkg_
file
names
epm_remove_names
$pkg_names
}
}
...
@@ -1965,8 +2018,10 @@ case $PMTYPE in
...
@@ -1965,8 +2018,10 @@ case $PMTYPE in
CMD
=
"rpm -q --requires -p"
CMD
=
"rpm -q --requires -p"
;;
;;
apt-dpkg
)
apt-dpkg
)
# FIXME: need package base
showcmd dpkg
-s
$pkg_files
showcmd dpkg
-s
$pkg_files
a
=
dpkg
-s
$pkg_names
|
grep
"^Depends:"
|
sed
"s|^Depends:||g"
a
=
dpkg
-s
$pkg_names
|
grep
"^Depends:"
|
sed
"s|^Depends:||g"
# FIXME: we need execute package name section too
return
return
;;
;;
*
)
*
)
...
@@ -2154,6 +2209,15 @@ __check_yum_result()
...
@@ -2154,6 +2209,15 @@ __check_yum_result()
return
$2
return
$2
}
}
__check_pacman_result
()
{
grep
"^error: target not found:"
$1
&&
return
1
grep
"^Total Installed Size:"
$1
&&
return
0
grep
"^Total Download Size:"
$1
&&
return
0
# return default result by default
return
$2
}
_epm_do_simulate
()
_epm_do_simulate
()
{
{
...
@@ -2170,7 +2234,9 @@ _epm_do_simulate()
...
@@ -2170,7 +2234,9 @@ _epm_do_simulate()
LC_ALL
=
C store_output sudocmd yum
--assumeno
install
$filenames
LC_ALL
=
C store_output sudocmd yum
--assumeno
install
$filenames
__check_yum_result
$RC_STDOUT
$?
__check_yum_result
$RC_STDOUT
$?
else
else
LC_ALL
=
C
echo
n | store_output sudocmd yum
install
$filenames
LC_ALL
=
C store_output sudocmd yum
install
$filenames
<<
EOF
n
EOF
__check_yum_result
$RC_STDOUT
$?
__check_yum_result
$RC_STDOUT
$?
fi
fi
RES
=
$?
RES
=
$?
...
@@ -2196,9 +2262,13 @@ _epm_do_simulate()
...
@@ -2196,9 +2262,13 @@ _epm_do_simulate()
done
done
return
$res
;;
return
$res
;;
pacman
)
pacman
)
showcmd
$SUDO
pacman
-v
-S
$filenames
LC_ALL
=
C store_output sudocmd pacman
-v
-S
$filenames
<<
EOF
echo
no |
$SUDO
pacman
-v
-S
$filenames
no
return
;;
EOF
__check_pacman_result
$RC_STDOUT
$?
RES
=
$?
clean_store_output
return
$RES
;;
slackpkg
)
slackpkg
)
#docmd /usr/sbin/slackpkg -batch=on -default_answer=yes download
#docmd /usr/sbin/slackpkg -batch=on -default_answer=yes download
# just try search every package
# just try search every package
...
@@ -2273,7 +2343,7 @@ case $PMTYPE in
...
@@ -2273,7 +2343,7 @@ case $PMTYPE in
sudocmd emerge
--sync
sudocmd emerge
--sync
;;
;;
slackpkg
)
slackpkg
)
sudocmd /usr/sbin/slackpkg update
sudocmd /usr/sbin/slackpkg
-batch
=
on
update
;;
;;
deepsolver-rpm
)
deepsolver-rpm
)
sudocmd ds-update
sudocmd ds-update
...
@@ -2713,7 +2783,7 @@ $(get_help HELPOPT)
...
@@ -2713,7 +2783,7 @@ $(get_help HELPOPT)
print_version
()
print_version
()
{
{
echo
"EPM package manager version 1.
2.8
"
echo
"EPM package manager version 1.
3.0
"
echo
"Running on
$(
$DISTRVENDOR
)
('
$PMTYPE
' package manager uses '
$PKGFORMAT
' package format)"
echo
"Running on
$(
$DISTRVENDOR
)
('
$PMTYPE
' package manager uses '
$PKGFORMAT
' package format)"
echo
"Copyright (c) Etersoft 2012-2013"
echo
"Copyright (c) Etersoft 2012-2013"
echo
"This program may be freely redistributed under the terms of the GNU AGPLv3."
echo
"This program may be freely redistributed under the terms of the GNU AGPLv3."
...
@@ -2811,7 +2881,7 @@ check_command()
...
@@ -2811,7 +2881,7 @@ check_command()
Install
)
# HELPCMD: perform update package repo info and install package(s) via install command
Install
)
# HELPCMD: perform update package repo info and install package(s) via install command
epm_cmd
=
Install
epm_cmd
=
Install
;;
;;
-q
|
installed
)
# HELPCMD: check presence of package(s
)
-q
|
installed
|query
)
# HELPCMD: check presence of package(s) and print this name (also --short is supported
)
epm_cmd
=
query
epm_cmd
=
query
;;
;;
-sf
|
sf|filesearch
)
# HELPCMD: search in which package a file is included
-sf
|
sf|filesearch
)
# HELPCMD: search in which package a file is included
...
@@ -2861,7 +2931,7 @@ check_command()
...
@@ -2861,7 +2931,7 @@ check_command()
release-upgrade
)
# HELPCMD: update whole system to the next release
release-upgrade
)
# HELPCMD: update whole system to the next release
epm_cmd
=
release_upgrade
epm_cmd
=
release_upgrade
;;
;;
kernel-update|kernel-upgrade|update-kernel
)
# HELPCMD: update system kernel to the last repo version
kernel-update|kernel-upgrade|update-kernel
|upgrade-kernel
)
# HELPCMD: update system kernel to the last repo version
epm_cmd
=
kernel_update
epm_cmd
=
kernel_update
;;
;;
...
@@ -2921,7 +2991,7 @@ check_option()
...
@@ -2921,7 +2991,7 @@ check_option()
--force
)
# HELPOPT: force install/remove package (f.i., override)
--force
)
# HELPOPT: force install/remove package (f.i., override)
force
=
"--force"
force
=
"--force"
;;
;;
--short
)
# HELPOPT: short output (
package instead package-version-release
)
--short
)
# HELPOPT: short output (
just 'package' instead 'package-version-release'
)
short
=
"--short"
short
=
"--short"
;;
;;
--auto
)
# HELPOPT: non interactive mode
--auto
)
# HELPOPT: non interactive mode
...
...
packed/serv.sh
View file @
c46c41ad
...
@@ -210,7 +210,7 @@ set_sudo()
...
@@ -210,7 +210,7 @@ set_sudo()
get_help
()
get_help
()
{
{
grep
-
-
"#
$1
"
$0
|
while
read
n
;
do
grep
-
v
--
"^#"
$0
|
grep
--
"#
$1
"
|
while
read
n
;
do
opt
=
$(
echo
$n
|
sed
-e
"s|) #
$1
:.*||g"
)
opt
=
$(
echo
$n
|
sed
-e
"s|) #
$1
:.*||g"
)
desc
=
$(
echo
$n
|
sed
-e
"s|.*) #
$1
:||g"
)
desc
=
$(
echo
$n
|
sed
-e
"s|.*) #
$1
:||g"
)
printf
" %-20s %s
\n
"
$opt
"
$desc
"
printf
" %-20s %s
\n
"
$opt
"
$desc
"
...
@@ -966,7 +966,7 @@ $(get_help HELPOPT)
...
@@ -966,7 +966,7 @@ $(get_help HELPOPT)
print_version
()
print_version
()
{
{
echo
"Service manager version 1.
2.8
"
echo
"Service manager version 1.
3.0
"
echo
"Running on
$(
$DISTRVENDOR
)
"
echo
"Running on
$(
$DISTRVENDOR
)
"
echo
"Copyright (c) Etersoft 2012, 2013"
echo
"Copyright (c) Etersoft 2012, 2013"
echo
"This program may be freely redistributed under the terms of the GNU AGPLv3."
echo
"This program may be freely redistributed under the terms of the GNU AGPLv3."
...
...
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