1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
# Copyright 1999-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
inherit desktop java-pkg-2
DESCRIPTION="Oracle SQL Developer is a graphical tool for database development"
HOMEPAGE="https://www.oracle.com/technetwork/developer-tools/sql-developer/overview/index.html"
SRC_URI="${P}-no-jre.zip"
S=${WORKDIR}/${PN}
LICENSE="OTN"
SLOT="0"
KEYWORDS="-* ~amd64"
IUSE="mssql mysql postgres sybase"
RESTRICT="bindist fetch"
RDEPEND="
dev-java/openjdk:11[javafx]
virtual/jre:11
mssql? ( dev-java/jtds:1.3 )
mysql? ( dev-java/jdbc-mysql:0 )
postgres? ( dev-java/jdbc-postgresql:0 )
sybase? ( dev-java/jtds:1.3 )
"
BDEPEND="app-arch/unzip"
QA_PREBUILT="
opt/${PN}/netbeans/platform/modules/lib/amd64/linux/libjnidispatch-422.so
"
pkg_nofetch() {
einfo "Please go to"
einfo " https://www.oracle.com/tools/downloads/sqldev-downloads.html"
einfo "and download"
einfo " Oracle SQL Developer for other platforms"
einfo " ${SRC_URI}"
einfo "and move it to /var/cache/distfiles"
}
src_prepare() {
default
find ./ \( -iname "*.exe" -or -iname "*.dll" -or -iname "*.bat" \) -exec rm {} + || die
sed -i 's|"`dirname $0`"|/opt/sqldeveloper|' sqldeveloper.sh || die
rm -r netbeans/platform/modules/lib/i386 || die
rm -r modules/javafx || die
# they both use jtds, enabling one of them also enables the other one
if use mssql && ! use sybase; then
einfo "You requested MSSQL support, this also enables Sybase support."
fi
if use sybase && ! use mssql; then
einfo "You requested Sybase support, this also enables MSSQL support."
fi
if use mssql || use sybase; then
echo "AddJavaLibFile $(java-pkg_getjars jtds-1.3)" >> sqldeveloper/bin/sqldeveloper.conf || die
fi
if use mysql; then
echo "AddJavaLibFile $(java-pkg_getjars jdbc-mysql)" >> sqldeveloper/bin/sqldeveloper.conf || die
fi
if use postgres; then
echo "AddJavaLibFile $(java-pkg_getjars jdbc-postgresql)" >> sqldeveloper/bin/sqldeveloper.conf || die
fi
}
src_install() {
insinto /opt/${PN}
doins -r {configuration,d{ataminer,ropins},e{quinox,xternal},ide,j{avavm,d{bc,ev},lib,views},modules,netbeans,rdbms,s{leepycat,ql{developer,j},vnkit}}
fperms +x /opt/${PN}/netbeans/platform/modules/lib/amd64/linux/libjnidispatch-422.so
dodir /opt/sqldeveloper/sqldeveloper/extensions/oracle.datamodeler/log
fperms 1777 /opt/sqldeveloper/sqldeveloper/extensions/oracle.datamodeler/log
newbin "${FILESDIR}"/${PN}-r1 ${PN}
newicon icon.png ${PN}-32x32.png
make_desktop_entry ${PN} "Oracle SQL Developer" ${PN}-32x32
# This is normally called automatically by java-pkg_dojar, which
# hasn't been used above. We need to create package.env to help the
# launcher select the correct VM.
java-pkg_do_write_
}
pkg_postinst() {
echo
einfo "If you want to use the TNS connection type you need to set up the"
einfo "TNS_ADMIN environment variable to point to the directory your"
einfo "tnsnames.ora resides in."
echo
}
|