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
etersoft
eepm
Commits
c0b4132a
Commit
c0b4132a
authored
Aug 16, 2021
by
Vitaly Lipatov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
commit packed 3.10.1
parent
d6931e74
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
48 additions
and
70 deletions
+48
-70
epm.sh
packed/epm.sh
+28
-37
serv.sh
packed/serv.sh
+20
-33
No files found.
packed/epm.sh
View file @
c0b4132a
...
@@ -4793,6 +4793,7 @@ __check_system()
...
@@ -4793,6 +4793,7 @@ __check_system()
docmd epm
--skip-installed
install
systemd
||
fatal
docmd epm
--skip-installed
install
systemd
||
fatal
fi
fi
# FIXME: will GUI closed during that changes?
# switch from prefdm: https://bugzilla.altlinux.org/show_bug.cgi?id=26405#c52
# switch from prefdm: https://bugzilla.altlinux.org/show_bug.cgi?id=26405#c52
if
is_active_systemd systemd
&&
serv display-manager status
>
/dev/null
||
serv prefdm status
>
/dev/null
;
then
if
is_active_systemd systemd
&&
serv display-manager status
>
/dev/null
||
serv prefdm status
>
/dev/null
;
then
docmd systemctl disable prefdm.service
docmd systemctl disable prefdm.service
...
@@ -4807,6 +4808,7 @@ __check_system()
...
@@ -4807,6 +4808,7 @@ __check_system()
__epm_ru_update
()
__epm_ru_update
()
{
{
docmd epm update
&&
return
docmd epm update
&&
return
# TODO: there can be errors due obsoleted alt-gpgkeys
epm update 2>&1 |
grep
"E: Unknown vendor ID"
||
return
epm update 2>&1 |
grep
"E: Unknown vendor ID"
||
return
info
"Drop vendor signs"
info
"Drop vendor signs"
__alt_replace_sign_name
""
__alt_replace_sign_name
""
...
@@ -4912,7 +4914,7 @@ __switch_alt_to_distro()
...
@@ -4912,7 +4914,7 @@ __switch_alt_to_distro()
docmd epm update-kernel
||
fatal
docmd epm update-kernel
||
fatal
info
"Run epm release-upgrade again for update to p10"
info
"Run epm release-upgrade again for update to p10"
;;
;;
"p9"
|
"p9 p10"
|
"p10 p10"
)
"p9"
|
"p9 p10"
|
"p
9.1 p10"
|
"p9.2 p10"
|
"p
10 p10"
)
confirm_info
"Upgrade
$DISTRNAME
from
$FROM
to
$TO
..."
confirm_info
"Upgrade
$DISTRNAME
from
$FROM
to
$TO
..."
docmd epm
install
rpm apt
"
$(
get_fix_release_pkg
"
$FROM
"
)
"
||
fatal
docmd epm
install
rpm apt
"
$(
get_fix_release_pkg
"
$FROM
"
)
"
||
fatal
__switch_repo_to
$TO
__switch_repo_to
$TO
...
@@ -5000,7 +5002,9 @@ __switch_alt_to_distro()
...
@@ -5000,7 +5002,9 @@ __switch_alt_to_distro()
trap
- EXIT
trap
- EXIT
return
1
return
1
esac
esac
info
"Done."
epm clean
info
"Note: You can try epm autoremove and epm autoorphans commands to remove obsoleted and unused packages."
info
"Done. The system has been successfully upgraded to the next release."
trap
- EXIT
trap
- EXIT
}
}
...
@@ -5795,7 +5799,7 @@ __epm_repack_to_rpm()
...
@@ -5795,7 +5799,7 @@ __epm_repack_to_rpm()
VERSION
=
''
VERSION
=
''
# convert tarballs to tar (for alien)
# convert tarballs to tar (for alien)
if
!
echo
"
$pkg
"
|
grep
-q
"
\.
rpm"
&&
!
echo
"
$pkg
"
|
grep
-q
"
\.
deb"
;
then
if
!
echo
"
$pkg
"
|
grep
-q
"
\.
rpm"
&&
!
echo
"
$pkg
"
|
grep
-q
"
\.
deb"
;
then
VERSION
=
"
$(
echo
"
$alpkg
"
|
grep
-o
-P
"
([0-9])(
\.
[0-9])*"
|
head
-n1
)
"
#"
VERSION
=
"
$(
echo
"
$alpkg
"
|
grep
-o
-P
"
[-_.]([0-9])(
\.
[0-9])*"
|
head
-n1
|
sed
-e
's|^[-_.]||'
)
"
#"
if
[
-n
"
$VERSION
"
]
;
then
if
[
-n
"
$VERSION
"
]
;
then
PKGNAME
=
"
$(
echo
"
$alpkg
"
|
sed
-e
"s|[-_.]
$VERSION
.*||"
)
"
PKGNAME
=
"
$(
echo
"
$alpkg
"
|
sed
-e
"s|[-_.]
$VERSION
.*||"
)
"
pkgtype
=
"
$(
a
=
erc
type
$alpkg
)
"
pkgtype
=
"
$(
a
=
erc
type
$alpkg
)
"
...
@@ -8826,7 +8830,6 @@ scat()
...
@@ -8826,7 +8830,6 @@ scat()
{
{
$CURL
-L
$CURLQ
"
$1
"
$CURL
-L
$CURLQ
"
$1
"
}
}
# download to default name of to $2
# download to default name of to $2
sget
()
sget
()
{
{
...
@@ -8851,6 +8854,12 @@ if [ "$1" = "--latest" ] ; then
...
@@ -8851,6 +8854,12 @@ if [ "$1" = "--latest" ] ; then
shift
shift
fi
fi
fatal
()
{
echo
"
$*
"
>
&2
exit
1
}
# check man glob
# check man glob
filter_glob
()
filter_glob
()
{
{
...
@@ -8903,39 +8912,23 @@ get_github_urls()
...
@@ -8903,39 +8912,23 @@ get_github_urls()
local
project
=
"
$(
echo
"
$1
"
|
sed
-e
"s|^https://github.com/
$owner
/||"
-e
"s|/.*||"
)
"
#"
local
project
=
"
$(
echo
"
$1
"
|
sed
-e
"s|^https://github.com/
$owner
/||"
-e
"s|/.*||"
)
"
#"
[
-n
"
$owner
"
]
||
fatal
"Can't get owner from
$1
"
[
-n
"
$owner
"
]
||
fatal
"Can't get owner from
$1
"
[
-n
"
$project
"
]
||
fatal
"Can't get project from
$1
"
[
-n
"
$project
"
]
||
fatal
"Can't get project from
$1
"
local
URL
=
"https://api.github.com/repos/
$owner
/
$project
/releases
/latest
"
local
URL
=
"https://api.github.com/repos/
$owner
/
$project
/releases"
scat
$URL
|
\
scat
$URL
|
\
grep
-i
-o
-E
'"browser_download_url": "https://.*"'
|
cut
-d
'"'
-f4
grep
-i
-o
-E
'"browser_download_url": "https://.*"'
|
cut
-d
'"'
-f4
}
}
# mask allowed only in the last part of path
if
echo
"
$1
"
|
grep
-q
"^https://github.com/"
;
then
MASK
=
$(
basename
"
$1
"
)
NOMASK
=
''
# If have no wildcard symbol like asterisk, just download
if
echo
"
$MASK
"
|
grep
-qv
"[*?]"
||
echo
"
$MASK
"
|
grep
-q
"[?].*="
;
then
NOMASK
=
'1'
fi
if
echo
"
$1
"
|
grep
-q
"^https://github.com/"
&&
!
echo
"
$1
"
|
grep
-q
"/releases/download/"
;
then
MASK
=
"
$2
"
MASK
=
"
$2
"
if
[
-n
"
$LISTONLY
"
]
;
then
if
[
-n
"
$LISTONLY
"
]
;
then
fn
=
''
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
for
fn
in
$(
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
)
;
do
echo
"
$fn
"
done
test
-n
"
$fn
"
return
return
fi
fi
ERROR
=
0
fn
=
''
for
fn
in
$(
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
)
;
do
for
fn
in
$(
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
)
;
do
sget
"
$fn
"
||
ERROR
=
1
sget
"
$fn
"
||
ERROR
=
1
done
done
test
-n
"
$fn
"
||
ERROR
=
1
return
return
$ERROR
fi
fi
...
@@ -8952,41 +8945,39 @@ if echo "$1" | grep -q "^ftp://" ; then
...
@@ -8952,41 +8945,39 @@ if echo "$1" | grep -q "^ftp://" ; then
fi
fi
# drop mask part
# drop mask part
URL
=
"
$(
dirname
"
$1
"
)
"
URL
=
"
$(
dirname
"
$1
"
)
/
"
if
echo
"
$URL
"
|
grep
-q
"[*?]"
;
then
if
echo
"
$URL
"
|
grep
-q
"[*?]"
;
then
fatal
"Error: there are globbing symbols (*?) in
$URL
"
fatal
"Error: there are globbing symbols (*?) in
$URL
"
fi
fi
# mask allowed only in the last part of path
MASK
=
$(
basename
"
$1
"
)
# If have no wildcard symbol like asterisk, just download
# If have no wildcard symbol like asterisk, just download
if
[
-n
"
$NOMASK
"
]
;
then
if
echo
"
$MASK
"
|
grep
-qv
"[*?]"
||
echo
"
$MASK
"
|
grep
-q
"[?].*="
;
then
sget
"
$1
"
"
$TARGETFILE
"
sget
"
$1
"
"
$TARGETFILE
"
return
return
fi
fi
get_urls
()
get_urls
()
{
{
scat
$URL
/
|
\
scat
$URL
|
\
grep
-i
-o
-
P
'href="(.*?)"'
|
cut
-d
'"'
-f2
|
sed
-e
"s|^./||"
grep
-i
-o
-
E
'href="([^\*/"#]+)"'
|
cut
-d
'"'
-f2
}
}
if
[
-n
"
$LISTONLY
"
]
;
then
if
[
-n
"
$LISTONLY
"
]
;
then
fn
=
''
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
# TODO: return full url? someone use old behaviour?
# TODO: return full url? someone use old behaviour?
echo
"
$
fn
"
|
sed
-e
"s|
$URL
/||
"
echo
"
$
(
basename
"
$fn
"
)
"
done
done
test
-n
"
$fn
"
return
return
fi
fi
ERROR
=
0
ERROR
=
0
fn
=
''
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
echo
"
$fn
"
|
grep
-q
"://"
&&
furl
=
$fn
||
furl
=
"
$URL
/
$fn
"
sget
"
$URL
/
$(
basename
"
$fn
"
)
"
||
ERROR
=
1
sget
"
$furl
"
||
ERROR
=
1
done
done
test
-n
"
$fn
"
||
ERROR
=
1
return
$ERROR
return
$ERROR
}
}
...
@@ -9546,7 +9537,7 @@ Examples:
...
@@ -9546,7 +9537,7 @@ Examples:
print_version
()
print_version
()
{
{
echo
"EPM package manager version 3.10.
0
https://wiki.etersoft.ru/Epm"
echo
"EPM package manager version 3.10.
1
https://wiki.etersoft.ru/Epm"
echo
"Running on
$(
$DISTRVENDOR
-e
)
('
$PMTYPE
' package manager uses '
$PKGFORMAT
' package format)"
echo
"Running on
$(
$DISTRVENDOR
-e
)
('
$PMTYPE
' package manager uses '
$PKGFORMAT
' package format)"
echo
"Copyright (c) Etersoft 2012-2020"
echo
"Copyright (c) Etersoft 2012-2020"
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."
...
@@ -9556,7 +9547,7 @@ print_version()
...
@@ -9556,7 +9547,7 @@ print_version()
Usage
=
"Usage: epm [options] <command> [package name(s), package files]..."
Usage
=
"Usage: epm [options] <command> [package name(s), package files]..."
Descr
=
"epm - EPM package manager"
Descr
=
"epm - EPM package manager"
EPMVERSION
=
3.10.
0
EPMVERSION
=
3.10.
1
verbose
=
verbose
=
quiet
=
quiet
=
nodeps
=
nodeps
=
...
...
packed/serv.sh
View file @
c0b4132a
...
@@ -2045,7 +2045,6 @@ scat()
...
@@ -2045,7 +2045,6 @@ scat()
{
{
$CURL
-L
$CURLQ
"
$1
"
$CURL
-L
$CURLQ
"
$1
"
}
}
# download to default name of to $2
# download to default name of to $2
sget
()
sget
()
{
{
...
@@ -2070,6 +2069,12 @@ if [ "$1" = "--latest" ] ; then
...
@@ -2070,6 +2069,12 @@ if [ "$1" = "--latest" ] ; then
shift
shift
fi
fi
fatal
()
{
echo
"
$*
"
>
&2
exit
1
}
# check man glob
# check man glob
filter_glob
()
filter_glob
()
{
{
...
@@ -2122,39 +2127,23 @@ get_github_urls()
...
@@ -2122,39 +2127,23 @@ get_github_urls()
local
project
=
"
$(
echo
"
$1
"
|
sed
-e
"s|^https://github.com/
$owner
/||"
-e
"s|/.*||"
)
"
#"
local
project
=
"
$(
echo
"
$1
"
|
sed
-e
"s|^https://github.com/
$owner
/||"
-e
"s|/.*||"
)
"
#"
[
-n
"
$owner
"
]
||
fatal
"Can't get owner from
$1
"
[
-n
"
$owner
"
]
||
fatal
"Can't get owner from
$1
"
[
-n
"
$project
"
]
||
fatal
"Can't get project from
$1
"
[
-n
"
$project
"
]
||
fatal
"Can't get project from
$1
"
local
URL
=
"https://api.github.com/repos/
$owner
/
$project
/releases
/latest
"
local
URL
=
"https://api.github.com/repos/
$owner
/
$project
/releases"
scat
$URL
|
\
scat
$URL
|
\
grep
-i
-o
-E
'"browser_download_url": "https://.*"'
|
cut
-d
'"'
-f4
grep
-i
-o
-E
'"browser_download_url": "https://.*"'
|
cut
-d
'"'
-f4
}
}
# mask allowed only in the last part of path
if
echo
"
$1
"
|
grep
-q
"^https://github.com/"
;
then
MASK
=
$(
basename
"
$1
"
)
NOMASK
=
''
# If have no wildcard symbol like asterisk, just download
if
echo
"
$MASK
"
|
grep
-qv
"[*?]"
||
echo
"
$MASK
"
|
grep
-q
"[?].*="
;
then
NOMASK
=
'1'
fi
if
echo
"
$1
"
|
grep
-q
"^https://github.com/"
&&
!
echo
"
$1
"
|
grep
-q
"/releases/download/"
;
then
MASK
=
"
$2
"
MASK
=
"
$2
"
if
[
-n
"
$LISTONLY
"
]
;
then
if
[
-n
"
$LISTONLY
"
]
;
then
fn
=
''
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
for
fn
in
$(
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
)
;
do
echo
"
$fn
"
done
test
-n
"
$fn
"
return
return
fi
fi
ERROR
=
0
fn
=
''
for
fn
in
$(
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
)
;
do
for
fn
in
$(
get_github_urls
"
$1
"
| filter_glob
"
$MASK
"
| filter_order
)
;
do
sget
"
$fn
"
||
ERROR
=
1
sget
"
$fn
"
||
ERROR
=
1
done
done
test
-n
"
$fn
"
||
ERROR
=
1
return
return
$ERROR
fi
fi
...
@@ -2171,41 +2160,39 @@ if echo "$1" | grep -q "^ftp://" ; then
...
@@ -2171,41 +2160,39 @@ if echo "$1" | grep -q "^ftp://" ; then
fi
fi
# drop mask part
# drop mask part
URL
=
"
$(
dirname
"
$1
"
)
"
URL
=
"
$(
dirname
"
$1
"
)
/
"
if
echo
"
$URL
"
|
grep
-q
"[*?]"
;
then
if
echo
"
$URL
"
|
grep
-q
"[*?]"
;
then
fatal
"Error: there are globbing symbols (*?) in
$URL
"
fatal
"Error: there are globbing symbols (*?) in
$URL
"
fi
fi
# mask allowed only in the last part of path
MASK
=
$(
basename
"
$1
"
)
# If have no wildcard symbol like asterisk, just download
# If have no wildcard symbol like asterisk, just download
if
[
-n
"
$NOMASK
"
]
;
then
if
echo
"
$MASK
"
|
grep
-qv
"[*?]"
||
echo
"
$MASK
"
|
grep
-q
"[?].*="
;
then
sget
"
$1
"
"
$TARGETFILE
"
sget
"
$1
"
"
$TARGETFILE
"
return
return
fi
fi
get_urls
()
get_urls
()
{
{
scat
$URL
/
|
\
scat
$URL
|
\
grep
-i
-o
-
P
'href="(.*?)"'
|
cut
-d
'"'
-f2
|
sed
-e
"s|^./||"
grep
-i
-o
-
E
'href="([^\*/"#]+)"'
|
cut
-d
'"'
-f2
}
}
if
[
-n
"
$LISTONLY
"
]
;
then
if
[
-n
"
$LISTONLY
"
]
;
then
fn
=
''
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
# TODO: return full url? someone use old behaviour?
# TODO: return full url? someone use old behaviour?
echo
"
$
fn
"
|
sed
-e
"s|
$URL
/||
"
echo
"
$
(
basename
"
$fn
"
)
"
done
done
test
-n
"
$fn
"
return
return
fi
fi
ERROR
=
0
ERROR
=
0
fn
=
''
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
for
fn
in
$(
get_urls | filter_glob
"
$MASK
"
| filter_order
)
;
do
echo
"
$fn
"
|
grep
-q
"://"
&&
furl
=
$fn
||
furl
=
"
$URL
/
$fn
"
sget
"
$URL
/
$(
basename
"
$fn
"
)
"
||
ERROR
=
1
sget
"
$furl
"
||
ERROR
=
1
done
done
test
-n
"
$fn
"
||
ERROR
=
1
return
$ERROR
return
$ERROR
}
}
...
@@ -2831,7 +2818,7 @@ print_version()
...
@@ -2831,7 +2818,7 @@ print_version()
local
on_text
=
"(host system)"
local
on_text
=
"(host system)"
local
virt
=
"
$(
$DISTRVENDOR
-i
)
"
local
virt
=
"
$(
$DISTRVENDOR
-i
)
"
[
"
$virt
"
=
"(unknown)"
]
||
[
"
$virt
"
=
"(host system)"
]
||
on_text
=
"(under
$virt
)"
[
"
$virt
"
=
"(unknown)"
]
||
[
"
$virt
"
=
"(host system)"
]
||
on_text
=
"(under
$virt
)"
echo
"Service manager version 3.10.
0
https://wiki.etersoft.ru/Epm"
echo
"Service manager version 3.10.
1
https://wiki.etersoft.ru/Epm"
echo
"Running on
$(
$DISTRVENDOR
-e
)
$on_text
with
$SERVICETYPE
"
echo
"Running on
$(
$DISTRVENDOR
-e
)
$on_text
with
$SERVICETYPE
"
echo
"Copyright (c) Etersoft 2012-2019"
echo
"Copyright (c) Etersoft 2012-2019"
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