commit 98e71a609638fd200fbc5c08babfc4c40b9959f3 Author: SMLinux Date: Fri Jan 28 23:06:05 2022 +0530 Initial commit diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..47caa6c --- /dev/null +++ b/.gitignore @@ -0,0 +1,29 @@ +*.tar.xz +*.tar.gz +*.tar.bz2 +*.tar.lz +*.txz +*.tbz +*.tgz +*.sh.xz +*.zip +*.bak +*.gz +DEPS.* +*.diff.gz +packages +COMPILER +incomplete +incomplete.n +waf-2.0.9 +*.img.xz +gcc +libreoffice +others +networkmanager +pending +testing +virt +webkitgtk +youtube-viewer +*.buildlog diff --git a/CREDITS b/CREDITS new file mode 100644 index 0000000..40e700e --- /dev/null +++ b/CREDITS @@ -0,0 +1,12 @@ +Location: irc.freenode.net: +The People on my distro channel #smlinux +The People (and bots too, perhaps) and their works of ##slackware +The People (and bots too, perhaps) and their works of #openwrt +The People (and bots too, perhaps) and their works of #musl +The People (and bots too, perhaps) and their works of #sabotage +The People (and bots too, perhaps) and their works of #alpine-linux +The People (and bots too, perhaps) and their works on #sta.li on 2f30.org. + +Dhruv Vyas (https://github.com/dhruvvyas90) for his 32bit ARM versatilepb raspberry qemu kernel + +And many many more untold places on the internet.... diff --git a/README b/README new file mode 100644 index 0000000..2d8d37d --- /dev/null +++ b/README @@ -0,0 +1,19 @@ +Welcome to SMLinux! + +SMLinux is an experimental linux distribution based on the musl C library using a +Slackware-based build/packaging system, aimed at intermediate and advanced users. In +some packages, SMLinux uses patches from other linux distros for bug fixing, better +support and consistency with the musl C library. + +SMLinux currently supports only x86_64 and aarch64 (arm64) CPU architectures. + +SMLinux Guide can be found on: +http://pktsurf.in/guide + +Complete source, including build files and source tarballs, and binary packages +can be found on: +http://slackware.uk/smlinux/ + +You can contact us in the #smlinux channel of irc.freenode.net. + +Happy Slacking! diff --git a/base/.buildlist.base b/base/.buildlist.base new file mode 100644 index 0000000..cf5de98 --- /dev/null +++ b/base/.buildlist.base @@ -0,0 +1,315 @@ +initfs +gcc-libs +which +wiringpi +dcron +cpio +gsl +ijs +ed +bc +kbd +db +netbsd-curses +readline +busybox +dmidecode +pkgconf +make +m4 +ccache +musl +libsodium +libunistring +bzip2 +libffi +libgpg-error +libgcrypt +mksh +mdadm +mtools +lzip +lzlib +tarlz +plzip +expat +perl +perl-modules +nasm +intltool +diffutils +autoconf +automake +argp-standalone +bison +flex +less +vim +bash +bash-completion +tree +attr +acl +patch +libpcap +smartmontools +zlib +gzip +xz +pigz +findutils +file +pcre +pcre2 +grep +tar +sysklogd +gawk +sed +zip +unzip +popt +tzdb +pciutils +openssl +sqlite +python3 +libxml2 +libxslt +xmlto +wayland +wayland-protocols +kmod +python-setuptools +python-pip +python-lxml +python-markupsafe +python-mako +python-six +python-cheetah +gettext +iso-codes +libtool +docbook +itstool +yasm +makeself +gperf +alsa-lib +portaudio +libao +libaio +libarchive +ninja +meson +glib +eudev +libusb +usbutils +dialog +lvm +parted +mlocate +groff +mandoc +pinfo +haveged +procps-ng +util-linux +coreutils +dosfstools +cryptsetup +logrotate +e2fsprogs +gptfdisk +gmp +mpfr +libcroco +libpng +libexif +fribidi +lzo +libidn +libidn2 +libnl +libmnl +libnfnetlink +libtasn1 +nettle +lame +nghttp2 +libssh2 +curl +libnetfilter_conntrack +iptables +libelf-compat +gnu-efi +libevent +texinfo +cmake +libjpeg-turbo +libcap +libcap-ng +libvpx +libogg +libvorbis +libtheora +physfs +brotli +hyphen +fuse +gnutls +libsndfile +libtorrent +libetpan +opus +opusfile +libpthread-stubs +aspell +aspell6 +json-c +json-glib +libmypaint +mypaint-brushes +jbig2dec +libvncserver +jansson +libnxml +libmrss +libassuan +libasr +fdk-aac +asciidoc +git +desktop-file-utils +gstreamer +icu +hunspell +enchant +htop +nano +ncdu +pwgen +tofrodos +i2c-tools +sudo +alsa-utils +alsa-plugins +libical +giflib +keyutils +libtirpc +lsof +ntfs-3g +ca-certificates +mpg123 +exiv2 +chrony +libopenal +p7zip +x264 +libseccomp +scons +jam +lm-sensors +gdbm +ruby +syslinux +hdparm +neon +wavpack +libcddb +libcdio +libcdio-paranoia +libmms +libcue +fftw +flac +libsamplerate +soxr +faad2 +libmodplug +libmtp +npth +libksba +gpgme +gmime +gnupg2 +id3lib +libid3tag +woff2 +libsecret +p11-kit +miniupnpc +gloox +libuv +zsh +pm-utils +boost +rpi-userland +slapt-get +pv +libgc +guile +strace +gdb +acpid +libdaemon +gyp +mozilla-nss +c-ares +sbc +speexdsp +lz4 +zstd +lua +lua53 +toluapp +libkate +libminizip +libshout +twolame +exfat-utils +bubblewrap +qpdf +libnfs +sysstat +enet +chrpath +libgit2 +oniguruma +sysfsutils +swig +python-future +python-typing +python-m2crypto +wireless-regdb +crda +cython +time +signify +python-markdown +python-pyyaml +python-tornado +python-lunr +python-livereload +python-jinja2 +python-click +python-wheel +python-importlib-metadata +python-typing-extensions +python-zipp +python-tqdm +python-regex +python-joblib +python-nltk +python-mkdocs +kernel-source +kernel-headers +highlight +llvm +clang +rust +lld +sccache +nodejs diff --git a/base/acl/acl.SMBuild b/base/acl/acl.SMBuild new file mode 100755 index 0000000..caa4b0a --- /dev/null +++ b/base/acl/acl.SMBuild @@ -0,0 +1,31 @@ +APP=acl +VERSION=2.2.53 +BUILD=1sml +HOMEPAGE="http://savannah.nongnu.org/projects/acl" +DOWNLOAD='' +REQUIRES="attr" +DESC="Tools and libraries for manipulating POSIX Access Control Lists" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + mv $PKG/share/doc/$APP/* $PKGDOCS/ + rm -rf $PKG/share/doc + + mkfinalpkg +} + +SHA512SUMS=" +7b41ad53b4499bf59cb4d37b51db147a9aef8e72855f28044ae73dd8528272a0762e1e4a769919ca72b6cd1cec31161c166f6707e5534b85ed7718c6f57e8895 acl-2.2.53.tar.lz +" diff --git a/base/acpid/acpi_handler.sh b/base/acpid/acpi_handler.sh new file mode 100644 index 0000000..386fa8d --- /dev/null +++ b/base/acpid/acpi_handler.sh @@ -0,0 +1,19 @@ +#!/bin/sh +# Default acpi script that takes an entry for all actions + +IFS=${IFS}/ +set $@ + +case "$1" in + button) + case "$2" in + power) /sbin/init 0 + ;; + *) logger "ACPI action $2 is not defined" + ;; + esac + ;; + *) + logger "ACPI group $1 / action $2 is not defined" + ;; +esac diff --git a/base/acpid/acpid.SMBuild b/base/acpid/acpid.SMBuild new file mode 100755 index 0000000..6a685c9 --- /dev/null +++ b/base/acpid/acpid.SMBuild @@ -0,0 +1,37 @@ +APP=acpid +VERSION=2.0.32 +BUILD=1sml +HOMEPAGE='http://sourceforge.net/projects/acpid2/' +DOWNLOAD='' +DESC="Tools and daemon for implementing ACPI standard on Linux" + +build() { + compileonlyfor x86_64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin + + make + make install DESTDIR=$PKG + + install -Dm 755 $SRCDIR/acpi_handler.sh $PKG/etc/acpi/acpi_handler.sh.new + install -Dm 644 $SRCDIR/default $PKG/etc/acpi/events/default + install -Dm 755 $SRCDIR/rc.acpid $PKG/etc/rc.d/rc.acpid + + cp COPYING $PKGDOCS/ + head -n 100 Changelog > $PKGDOCS/CHANGELOG + + mkfinalpkg +} + +SHA512SUMS=" +c7afffdf9818504e1ac03b0ad693a05f772bfd07af9808262b3b6bb82ca4dabe6253c94e6dc59e5be6f0da9e815e8bcf2d3e16f02b23d0248b6bad4509e78be7 acpid-2.0.32.tar.xz +" diff --git a/base/acpid/default b/base/acpid/default new file mode 100644 index 0000000..f902218 --- /dev/null +++ b/base/acpid/default @@ -0,0 +1,18 @@ +# This is the ACPID default configuration, it takes all +# events and passes them to /etc/acpi/default.sh for further +# processing. + +# event keeps a regular expression matching the event. To get +# power events only, just use something like "event=button power.*" +# to catch it. +# action keeps the command to be executed after an event occurs +# In case of the power event above, your entry may look this way: +#event=button power.* +#action=/bin/init 0 + +# Optionally you can specify the placeholder %e. It will pass +# through the whole kernel event message to the program you've +# specified. + +event=.* +action=/etc/acpi/acpi_handler.sh %e diff --git a/base/acpid/doinst.sh b/base/acpid/doinst.sh new file mode 100644 index 0000000..dfc78d6 --- /dev/null +++ b/base/acpid/doinst.sh @@ -0,0 +1,13 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/acpi/acpi_handler.sh.new diff --git a/base/acpid/rc.acpid b/base/acpid/rc.acpid new file mode 100644 index 0000000..3860e2e --- /dev/null +++ b/base/acpid/rc.acpid @@ -0,0 +1,40 @@ +#!/bin/sh +# Start/stop/restart acpid. + +# Start acpid: +acpid_start() { + if [ -x /bin/acpid -a -d /proc/acpi ]; then + echo "Starting ACPI daemon: /bin/acpid" + /bin/acpid + fi +} + +# Stop acpid: +acpid_stop() { + if [ -r /var/run/acpid.pid ]; then + kill $(cat /var/run/acpid.pid) + else + killall acpid + fi +} + +# Restart acpid: +acpid_restart() { + acpid_stop + sleep 1 + acpid_start +} + +case "$1" in +'start') + acpid_start + ;; +'stop') + acpid_stop + ;; +'restart') + acpid_restart + ;; +*) + echo "usage $0 start|stop|restart" +esac diff --git a/base/alsa-lib/alsa-lib.SMBuild b/base/alsa-lib/alsa-lib.SMBuild new file mode 100755 index 0000000..72d6366 --- /dev/null +++ b/base/alsa-lib/alsa-lib.SMBuild @@ -0,0 +1,53 @@ +APP=alsa-lib +VERSION=1.2.3.1 +BUILD=1sml +HOMEPAGE="http://alsa-project.org" +DOWNLOAD='' +DESC="Advanced Linux Sound Architecture provides audio and MIDI functionality for Linux" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/remove-test.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-python \ + --disable-static \ + --disable-resmgr \ + --enable-seq \ + --enable-aload \ + --disable-dependency-tracking \ + --without-versioned + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + ( cd $PKG + mv share/alsa/alsa.conf share/alsa/alsa.conf.new + # create a blank asound.conf.new + mkdir -p etc ; touch etc/asound.conf.new + ) + + if [ "$ARCH" = "aarch64" ]; then + # Provide some sample conf files for using USB audio by overwriting the above file + cp $SRCDIR/alsa.conf.rpi.usbaudio $PKG/share/alsa/alsa.conf.new + cp $SRCDIR/asound.conf.rpi $PKG/etc/asound.conf.new + fi + + mkfinalpkg +} + +SHA512SUMS=" +ed0a81371117a91a5024f3bef5a881ffa9521399eab5e016924669a3f1eba2d6a02efa284b160089bc581717d39d15325ebb2faf162e4d3dabe4c29785a5fb58 alsa-lib-1.2.3.1.tar.bz2 +e15318431fe2d5bd1e42ef793f223e3e5995890d7befe6daa3d7456ccf5cb2f51eb79171539cecae13032a9b8a798ea35e04c89b27c7ef9567e2c03fb8db4512 remove-test.patch +" diff --git a/base/alsa-lib/alsa.conf.rpi.usbaudio b/base/alsa-lib/alsa.conf.rpi.usbaudio new file mode 100644 index 0000000..ad9a1ad --- /dev/null +++ b/base/alsa-lib/alsa.conf.rpi.usbaudio @@ -0,0 +1,642 @@ +# +# ALSA library configuration file +# + +# pre-load the configuration files + +@hooks [ + { + func load + files [ + "/etc/alsa/conf.d" + "/etc/asound.conf" + "~/.asoundrc" + { + @func concat + strings [ + { + @func getenv + vars [ + XDG_CONFIG_HOME + ] + default "~/.config" + } + "/alsa/asoundrc" + ] + } + ] + errors false + } +] + +# load card-specific configuration files (on request) + +cards.@hooks [ + { + func load + files [ + { + @func concat + strings [ + { @func datadir } + "/cards/aliases.conf" + ] + } + ] + } + { + func load_for_all_cards + files [ + { + @func concat + strings [ + { @func datadir } + "/cards/" + { @func private_string } + ".conf" + ] + } + ] + errors false + } +] + +# +# defaults +# + +# show all name hints also for definitions without hint {} section +defaults.namehint.showall off +# show just basic name hints +defaults.namehint.basic on +# show extended name hints +defaults.namehint.extended off +# +defaults.ctl.card 1 +defaults.pcm.card 1 +defaults.pcm.device 0 +defaults.pcm.subdevice -1 +defaults.pcm.nonblock 1 +defaults.pcm.compat 0 +defaults.pcm.minperiodtime 5000 # in us +defaults.pcm.ipc_key 5678293 +defaults.pcm.ipc_gid audio +defaults.pcm.ipc_perm 0660 +defaults.pcm.tstamp_type default +defaults.pcm.dmix.max_periods 0 +defaults.pcm.dmix.channels 2 +defaults.pcm.dmix.rate 48000 +defaults.pcm.dmix.format unchanged +defaults.pcm.dmix.card defaults.pcm.card +defaults.pcm.dmix.device defaults.pcm.device +defaults.pcm.dsnoop.card defaults.pcm.card +defaults.pcm.dsnoop.device defaults.pcm.device +defaults.pcm.front.card defaults.pcm.card +defaults.pcm.front.device defaults.pcm.device +defaults.pcm.rear.card defaults.pcm.card +defaults.pcm.rear.device defaults.pcm.device +defaults.pcm.center_lfe.card defaults.pcm.card +defaults.pcm.center_lfe.device defaults.pcm.device +defaults.pcm.side.card defaults.pcm.card +defaults.pcm.side.device defaults.pcm.device +defaults.pcm.surround21.card defaults.pcm.card +defaults.pcm.surround21.device defaults.pcm.device +defaults.pcm.surround40.card defaults.pcm.card +defaults.pcm.surround40.device defaults.pcm.device +defaults.pcm.surround41.card defaults.pcm.card +defaults.pcm.surround41.device defaults.pcm.device +defaults.pcm.surround50.card defaults.pcm.card +defaults.pcm.surround50.device defaults.pcm.device +defaults.pcm.surround51.card defaults.pcm.card +defaults.pcm.surround51.device defaults.pcm.device +defaults.pcm.surround71.card defaults.pcm.card +defaults.pcm.surround71.device defaults.pcm.device +defaults.pcm.iec958.card defaults.pcm.card +defaults.pcm.iec958.device defaults.pcm.device +defaults.pcm.modem.card defaults.pcm.card +defaults.pcm.modem.device defaults.pcm.device +defaults.pcm.file_format raw +defaults.pcm.file_truncate true # truncate files via file or tee PCM +defaults.rawmidi.card 0 +defaults.rawmidi.device 0 +defaults.rawmidi.subdevice -1 +defaults.hwdep.card 0 +defaults.hwdep.device 0 +defaults.timer.class 2 +defaults.timer.sclass 0 +defaults.timer.card 0 +defaults.timer.device 0 +defaults.timer.subdevice 0 + +# +# PCM interface +# + +pcm.hw { + @args [ CARD DEV SUBDEV ] + @args.CARD { + type string + default { + @func getenv + vars [ + ALSA_PCM_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.pcm.card + } + } + } + @args.DEV { + type integer + default { + @func igetenv + vars [ + ALSA_PCM_DEVICE + ] + default { + @func refer + name defaults.pcm.device + } + } + } + @args.SUBDEV { + type integer + default { + @func refer + name defaults.pcm.subdevice + } + } + type hw + card $CARD + device $DEV + subdevice $SUBDEV + hint { + show { + @func refer + name defaults.namehint.extended + } + description "Direct hardware device without any conversions" + } +} + +pcm.plughw { + @args [ CARD DEV SUBDEV ] + @args.CARD { + type string + default { + @func getenv + vars [ + ALSA_PCM_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.pcm.card + } + } + } + @args.DEV { + type integer + default { + @func igetenv + vars [ + ALSA_PCM_DEVICE + ] + default { + @func refer + name defaults.pcm.device + } + } + } + @args.SUBDEV { + type integer + default { + @func refer + name defaults.pcm.subdevice + } + } + type plug + slave.pcm { + type hw + card $CARD + device $DEV + subdevice $SUBDEV + } + hint { + show { + @func refer + name defaults.namehint.extended + } + description "Hardware device with all software conversions" + } +} + +pcm.plug { + @args [ SLAVE ] + @args.SLAVE { + type string + } + type plug + slave.pcm $SLAVE +} + +pcm.shm { + @args [ SOCKET PCM ] + @args.SOCKET { + type string + } + @args.PCM { + type string + } + type shm + server $SOCKET + pcm $PCM +} + +pcm.tee { + @args [ SLAVE FILE FORMAT ] + @args.SLAVE { + type string + } + @args.FILE { + type string + } + @args.FORMAT { + type string + default { + @func refer + name defaults.pcm.file_format + } + } + type file + slave.pcm $SLAVE + file $FILE + format $FORMAT + truncate { + @func refer + name defaults.pcm.file_truncate + } +} + +pcm.file { + @args [ FILE FORMAT ] + @args.FILE { + type string + } + @args.FORMAT { + type string + default { + @func refer + name defaults.pcm.file_format + } + } + type file + slave.pcm null + file $FILE + format $FORMAT + truncate { + @func refer + name defaults.pcm.file_truncate + } +} + +pcm.null { + type null + hint { + show { + @func refer + name defaults.namehint.basic + } + description "Discard all samples (playback) or generate zero samples (capture)" + } +} + +# redirect to load-on-demand extended pcm definitions +pcm.cards cards.pcm + +pcm.default cards.pcm.default +pcm.sysdefault cards.pcm.default +pcm.front cards.pcm.front +pcm.rear cards.pcm.rear +pcm.center_lfe cards.pcm.center_lfe +pcm.side cards.pcm.side +pcm.surround21 cards.pcm.surround21 +pcm.surround40 cards.pcm.surround40 +pcm.surround41 cards.pcm.surround41 +pcm.surround50 cards.pcm.surround50 +pcm.surround51 cards.pcm.surround51 +pcm.surround71 cards.pcm.surround71 +pcm.iec958 cards.pcm.iec958 +pcm.spdif iec958 +pcm.hdmi cards.pcm.hdmi +pcm.dmix cards.pcm.dmix +pcm.dsnoop cards.pcm.dsnoop +pcm.modem cards.pcm.modem +pcm.phoneline cards.pcm.phoneline + +# +# Control interface +# + +ctl.sysdefault { + type hw + card { + @func getenv + vars [ + ALSA_CTL_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.ctl.card + } + } + hint.description "Default control device" +} +ctl.default ctl.sysdefault + +ctl.hw { + @args [ CARD ] + @args.CARD { + type string + default { + @func getenv + vars [ + ALSA_CTL_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.ctl.card + } + } + } + type hw + card $CARD + hint.description "Direct control device" +} + +ctl.shm { + @args [ SOCKET CTL ] + @args.SOCKET { + type string + } + @args.CTL { + type string + } + type shm + server $SOCKET + ctl $CTL +} + +# +# RawMidi interface +# + +rawmidi.default { + type hw + card { + @func getenv + vars [ + ALSA_RAWMIDI_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.rawmidi.card + } + } + device { + @func igetenv + vars [ + ALSA_RAWMIDI_DEVICE + ] + default { + @func refer + name defaults.rawmidi.device + } + } + hint.description "Default raw MIDI device" +} + +rawmidi.hw { + @args [ CARD DEV SUBDEV ] + @args.CARD { + type string + default { + @func getenv + vars [ + ALSA_RAWMIDI_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.rawmidi.card + } + } + } + @args.DEV { + type integer + default { + @func igetenv + vars [ + ALSA_RAWMIDI_DEVICE + ] + default { + @func refer + name defaults.rawmidi.device + } + } + } + @args.SUBDEV { + type integer + default -1 + } + type hw + card $CARD + device $DEV + subdevice $SUBDEV + hint { + description "Direct rawmidi driver device" + device $DEV + } +} + +rawmidi.virtual { + @args [ MERGE ] + @args.MERGE { + type string + default 1 + } + type virtual + merge $MERGE +} + +# +# Sequencer interface +# + +seq.default { + type hw + hint.description "Default sequencer device" +} + +seq.hw { + type hw +} + +# +# HwDep interface +# + +hwdep.default { + type hw + card { + @func getenv + vars [ + ALSA_HWDEP_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.hwdep.card + } + } + device { + @func igetenv + vars [ + ALSA_HWDEP_DEVICE + ] + default { + @func refer + name defaults.hwdep.device + } + } + hint.description "Default hardware dependent device" +} + +hwdep.hw { + @args [ CARD DEV ] + @args.CARD { + type string + default { + @func getenv + vars [ + ALSA_HWDEP_CARD + ALSA_CARD + ] + default { + @func refer + name defaults.hwdep.card + } + } + } + @args.DEV { + type integer + default { + @func igetenv + vars [ + ALSA_HWDEP_DEVICE + ] + default { + @func refer + name defaults.hwdep.device + } + } + } + type hw + card $CARD + device $DEV + hint { + description "Direct hardware dependent device" + device $DEV + } +} + +# +# Timer interface +# + +timer_query.default { + type hw +} + +timer_query.hw { + type hw +} + +timer.default { + type hw + class { + @func refer + name defaults.timer.class + } + sclass { + @func refer + name defaults.timer.sclass + } + card { + @func refer + name defaults.timer.card + } + device { + @func refer + name defaults.timer.device + } + subdevice { + @func refer + name defaults.timer.subdevice + } + hint.description "Default timer device" +} + +timer.hw { + @args [ CLASS SCLASS CARD DEV SUBDEV ] + @args.CLASS { + type integer + default { + @func refer + name defaults.timer.class + } + } + @args.SCLASS { + type integer + default { + @func refer + name defaults.timer.sclass + } + } + @args.CARD { + type string + default { + @func refer + name defaults.timer.card + } + } + @args.DEV { + type integer + default { + @func refer + name defaults.timer.device + } + } + @args.SUBDEV { + type integer + default { + @func refer + name defaults.timer.subdevice + } + } + type hw + class $CLASS + sclass $SCLASS + card $CARD + device $DEV + subdevice $SUBDEV + hint { + description "Direct timer device" + device $DEV + } +} diff --git a/base/alsa-lib/asound.conf.rpi b/base/alsa-lib/asound.conf.rpi new file mode 100644 index 0000000..94cfabc --- /dev/null +++ b/base/alsa-lib/asound.conf.rpi @@ -0,0 +1,8 @@ +pcm.!default { + type hw + card 1 +} +ctl.!default { + type hw + card 1 +} diff --git a/base/alsa-lib/doinst.sh b/base/alsa-lib/doinst.sh new file mode 100644 index 0000000..5caad19 --- /dev/null +++ b/base/alsa-lib/doinst.sh @@ -0,0 +1,14 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +config share/alsa/alsa.conf.new +config etc/asound.conf.new diff --git a/base/alsa-lib/remove-test.patch b/base/alsa-lib/remove-test.patch new file mode 100644 index 0000000..9745de0 --- /dev/null +++ b/base/alsa-lib/remove-test.patch @@ -0,0 +1,85 @@ +diff --git a/test/Makefile.am b/test/Makefile.am +index 99c2c4f..ac7bae1 100644 +--- a/test/Makefile.am ++++ b/test/Makefile.am +@@ -2,7 +2,7 @@ SUBDIRS=. lsb + + check_PROGRAMS=control pcm pcm_min latency seq \ + playmidi1 timer rawmidi midiloop \ +- oldapi queue_timer namehint client_event_filter \ ++ queue_timer namehint client_event_filter \ + chmap audio_time user-ctl-element-set pcm-multi-thread + + control_LDADD=../src/libasound.la +@@ -16,7 +16,6 @@ playmidi1_LDADD=../src/libasound.la + timer_LDADD=../src/libasound.la + rawmidi_LDADD=../src/libasound.la + midiloop_LDADD=../src/libasound.la +-oldapi_LDADD=../src/libasound.la + queue_timer_LDADD=../src/libasound.la + namehint_LDADD=../src/libasound.la + client_event_filter_LDADD=../src/libasound.la +diff --git a/test/Makefile.in b/test/Makefile.in +index d096226..699ae45 100644 +--- a/test/Makefile.in ++++ b/test/Makefile.in +@@ -90,7 +90,7 @@ host_triplet = @host@ + check_PROGRAMS = control$(EXEEXT) pcm$(EXEEXT) pcm_min$(EXEEXT) \ + latency$(EXEEXT) seq$(EXEEXT) playmidi1$(EXEEXT) \ + timer$(EXEEXT) rawmidi$(EXEEXT) midiloop$(EXEEXT) \ +- oldapi$(EXEEXT) queue_timer$(EXEEXT) namehint$(EXEEXT) \ ++ queue_timer$(EXEEXT) namehint$(EXEEXT) \ + client_event_filter$(EXEEXT) chmap$(EXEEXT) \ + audio_time$(EXEEXT) user-ctl-element-set$(EXEEXT) \ + pcm-multi-thread$(EXEEXT) +@@ -136,9 +136,6 @@ midiloop_DEPENDENCIES = ../src/libasound.la + namehint_SOURCES = namehint.c + namehint_OBJECTS = namehint.$(OBJEXT) + namehint_DEPENDENCIES = ../src/libasound.la +-oldapi_SOURCES = oldapi.c +-oldapi_OBJECTS = oldapi.$(OBJEXT) +-oldapi_DEPENDENCIES = ../src/libasound.la + pcm_SOURCES = pcm.c + pcm_OBJECTS = pcm.$(OBJEXT) + pcm_DEPENDENCIES = ../src/libasound.la +@@ -222,11 +219,11 @@ am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) + am__v_CCLD_0 = @echo " CCLD " $@; + am__v_CCLD_1 = + SOURCES = audio_time.c chmap.c client_event_filter.c control.c \ +- latency.c midiloop.c namehint.c oldapi.c pcm.c \ ++ latency.c midiloop.c namehint.c pcm.c \ + pcm-multi-thread.c pcm_min.c playmidi1.c queue_timer.c \ + rawmidi.c seq.c timer.c user-ctl-element-set.c + DIST_SOURCES = audio_time.c chmap.c client_event_filter.c control.c \ +- latency.c midiloop.c namehint.c oldapi.c pcm.c \ ++ latency.c midiloop.c namehint.c pcm.c \ + pcm-multi-thread.c pcm_min.c playmidi1.c queue_timer.c \ + rawmidi.c seq.c timer.c user-ctl-element-set.c + RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ +@@ -439,7 +436,6 @@ playmidi1_LDADD = ../src/libasound.la + timer_LDADD = ../src/libasound.la + rawmidi_LDADD = ../src/libasound.la + midiloop_LDADD = ../src/libasound.la +-oldapi_LDADD = ../src/libasound.la + queue_timer_LDADD = ../src/libasound.la + namehint_LDADD = ../src/libasound.la + client_event_filter_LDADD = ../src/libasound.la +@@ -524,10 +520,6 @@ namehint$(EXEEXT): $(namehint_OBJECTS) $(namehint_DEPENDENCIES) $(EXTRA_namehint + @rm -f namehint$(EXEEXT) + $(AM_V_CCLD)$(LINK) $(namehint_OBJECTS) $(namehint_LDADD) $(LIBS) + +-oldapi$(EXEEXT): $(oldapi_OBJECTS) $(oldapi_DEPENDENCIES) $(EXTRA_oldapi_DEPENDENCIES) +- @rm -f oldapi$(EXEEXT) +- $(AM_V_CCLD)$(LINK) $(oldapi_OBJECTS) $(oldapi_LDADD) $(LIBS) +- + pcm$(EXEEXT): $(pcm_OBJECTS) $(pcm_DEPENDENCIES) $(EXTRA_pcm_DEPENDENCIES) + @rm -f pcm$(EXEEXT) + $(AM_V_CCLD)$(pcm_LINK) $(pcm_OBJECTS) $(pcm_LDADD) $(LIBS) +@@ -577,7 +569,6 @@ distclean-compile: + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/latency.Po@am__quote@ # am--include-marker + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/midiloop.Po@am__quote@ # am--include-marker + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/namehint.Po@am__quote@ # am--include-marker +-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/oldapi.Po@am__quote@ # am--include-marker + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pcm-multi-thread.Po@am__quote@ # am--include-marker + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pcm.Po@am__quote@ # am--include-marker + @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pcm_min.Po@am__quote@ # am--include-marker diff --git a/base/alsa-plugins/alsa-plugins.SMBuild b/base/alsa-plugins/alsa-plugins.SMBuild new file mode 100755 index 0000000..610695f --- /dev/null +++ b/base/alsa-plugins/alsa-plugins.SMBuild @@ -0,0 +1,31 @@ +APP=alsa-plugins +VERSION=1.2.2 +BUILD=1sml +HOMEPAGE="http://www.alsa-project.org" +DOWNLOAD="" +DESC="Plugins for ALSA" +REQUIRES="alsa-lib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --libdir=/lib + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +25a7dfaa64be024447d889b5cde668f1308d197f54880548a82d50beb4ac0dbff33b415da1e26dc5229408c934247a9bd38acfb0f82ca388deac0d77ab3cdadb alsa-plugins-1.2.2.tar.bz2 +" diff --git a/base/alsa-utils/alsa-utils.SMBuild b/base/alsa-utils/alsa-utils.SMBuild new file mode 100755 index 0000000..0123840 --- /dev/null +++ b/base/alsa-utils/alsa-utils.SMBuild @@ -0,0 +1,36 @@ +APP=alsa-utils +VERSION=1.2.3 +BUILD=1sml +HOMEPAGE='http://alsa-project.org' +DOWNLOAD='' +REQUIRES="netbsd-curses alsa-lib" +DESC="Utilities for ALSA such as alsactl, amixer, alsamixer, aplay and arecord" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --bindir=/bin \ + --sbindir=/bin \ + --mandir="/share/man" \ + --disable-nls \ + --disable-xmlto + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +5aeba2e5b7279c62d4df85b61a26b3f41e5465bac5a0b94c7bbe1299f7aa38e8cf2a1f749f618289a63b61f76609fe54169fcbe70792b45adc8957811b672012 alsa-utils-1.2.3.tar.bz2 +" diff --git a/base/alsa-utils/rc.alsa b/base/alsa-utils/rc.alsa new file mode 100644 index 0000000..077966d --- /dev/null +++ b/base/alsa-utils/rc.alsa @@ -0,0 +1,87 @@ +#!/bin/sh +# Load the mixer settings and OSS compatibility (if enabled) for ALSA. +# (the Advanced Linux Sound Architecture) + +# A function to load the ALSA mixer settings: +load_alsa_mixer() { + if [ -r /var/lib/alsa/asound.state ]; then + echo "Loading ALSA mixer settings: /usr/sbin/alsactl restore" + /usr/sbin/alsactl restore + else + # It's possible a user might not want to set a default sound state. + # In that case, do this: touch /var/lib/alsa/no.asound.state + if [ ! -r /var/lib/alsa/no.asound.state ]; then + echo "Setting default ALSA mixer settings." + # set default mixer volumes for ALSA + # Taken from the alsaconf script. + amixer -s -q <flags & OPTION_DOC) + return 0; +@@ -582,7 +582,7 @@ + } + + ARGP_EI int +-__option_is_end (__const struct argp_option *__opt) __THROW ++__option_is_end (__const struct argp_option *__opt) + { + return !__opt->key && !__opt->name && !__opt->doc && !__opt->group; + } +--- argp-standalone-1.4-test2/argp-parse.c.orig 2006-01-06 02:47:48.000000000 +0100 ++++ argp-standalone-1.4-test2/argp-parse.c 2006-01-06 02:48:16.000000000 +0100 +@@ -1290,13 +1290,13 @@ + /* Defined here, in case a user is not inlining the definitions in + * argp.h */ + void +-__argp_usage (__const struct argp_state *__state) __THROW ++__argp_usage (__const struct argp_state *__state) + { + __argp_state_help (__state, stderr, ARGP_HELP_STD_USAGE); + } + + int +-__option_is_short (__const struct argp_option *__opt) __THROW ++__option_is_short (__const struct argp_option *__opt) + { + if (__opt->flags & OPTION_DOC) + return 0; +@@ -1310,7 +1310,7 @@ + } + + int +-__option_is_end (__const struct argp_option *__opt) __THROW ++__option_is_end (__const struct argp_option *__opt) + { + return !__opt->key && !__opt->name && !__opt->doc && !__opt->group; + } diff --git a/base/argp-standalone/argp-standalone.SMBuild b/base/argp-standalone/argp-standalone.SMBuild new file mode 100755 index 0000000..22fca8a --- /dev/null +++ b/base/argp-standalone/argp-standalone.SMBuild @@ -0,0 +1,38 @@ +APP=argp-standalone +VERSION=1.3 +BUILD=1sml +HOMEPAGE='http://www.lysator.liu.se/~nisse/misc/' +DOWNLOAD='' +DESC="Hierarchical argument parsing library broken out of glibc" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/gnu89-inline.patch + patch -p1 < $SRCDIR/001-throw-in-funcdef.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + + install -Dm 644 argp.h $PKG/include/argp.h + install -Dm 755 libargp.a $PKG/lib/libargp.a + + head -n 100 ChangeLog > $PKGDOCS/CHANGELOG + + mkfinalpkg +} + +SHA512SUMS=" +b6bb0416d19cc2bc582158ea4b7d143fa13a2dacfac25b7f9adea68b4dd6b06548a4a81f1691036f04feae86ca87f45e6c1dae12cf2d6d6a74e16b2d2ee556dd argp-standalone-1.3.tar.lz +5e4cdeeb16e6a4fb46a00ab95f3da9276ee554eec00bb2a05da7467961234ba3f9a630aafa7ceb5feb429a84ece8bf03b869fa996b86468f4716935a914c79a4 001-throw-in-funcdef.patch +69f1d8a4fcd542346f98bc1fb7151db748483fc2f331c8c35114e0891d867b41c603ddaa5f3130aaaf1c640e02c51ac71cee71b62c09301b146812e9059e9ade gnu89-inline.patch +" diff --git a/base/argp-standalone/gnu89-inline.patch b/base/argp-standalone/gnu89-inline.patch new file mode 100644 index 0000000..71978eb --- /dev/null +++ b/base/argp-standalone/gnu89-inline.patch @@ -0,0 +1,22 @@ +diff --git a/configure.ac b/configure.ac +index 4658839..09f0267 100644 +--- a/configure.ac ++++ b/configure.ac +@@ -79,16 +79,10 @@ AC_CHECK_DECLS([program_invocation_name, program_invocation_short_name], + + # Set these flags *last*, or else the test programs won't compile + if test x$GCC = xyes ; then +- # Using -ggdb3 makes (some versions of) Redhat's gcc-2.96 dump core +- if "$CC" --version | grep '^2\.96$' 1>/dev/null 2>&1; then +- true +- else +- CFLAGS="$CFLAGS -ggdb3" +- fi + CFLAGS="$CFLAGS -Wall -W \ + -Wmissing-prototypes -Wmissing-declarations -Wstrict-prototypes \ + -Waggregate-return \ +- -Wpointer-arith -Wbad-function-cast -Wnested-externs" ++ -Wpointer-arith -Wbad-function-cast -Wnested-externs -fgnu89-inline" + fi + + CPPFLAGS="$CPPFLAGS -I$srcdir" diff --git a/base/asciidoc/asciidoc.SMBuild b/base/asciidoc/asciidoc.SMBuild new file mode 100755 index 0000000..87d51f5 --- /dev/null +++ b/base/asciidoc/asciidoc.SMBuild @@ -0,0 +1,31 @@ +APP=asciidoc +VERSION=9.0.4 +BUILD=1sml +HOMEPAGE="https://github.com/asciidoc/asciidoc-py3" +DOWNLOAD='' +DESC="Text document format for writing notes and documentation" +REQUIRES="python3 libxslt docbook" + +build() { + mkandenterbuilddir + rm -rf $APP-"py3"-$VERSION + + tar xf $SRCDIR/$APP-"py3"-$VERSION.tar.?z* + cd $APP-"py3"-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYRIGHT LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +df71bb8a35fc0099c34dcfbcfe8c182b59c5a8e86326a994fe722fea2c902fb56d221d8ae42a7b967daa4acc8cadd82ec9c85add48a8013ad04d295bf1d728c4 asciidoc-py3-9.0.4.tar.lz +" diff --git a/base/aspell/aspell.SMBuild b/base/aspell/aspell.SMBuild new file mode 100755 index 0000000..b3d3eb7 --- /dev/null +++ b/base/aspell/aspell.SMBuild @@ -0,0 +1,35 @@ +APP=aspell +VERSION=0.60.7 +BUILD=1sml +HOMEPAGE="http://aspell.net/" +REQUIRES="gcc-libs netbsd-curses perl" +DESC="Spell checker for GNU Linux" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc/aspell \ + --libdir=/lib \ + --enable-pkgdatadir=/lib/aspell \ + --enable-data-dir=/lib/aspell \ + --enable-pkglibdir=/lib/aspell \ + --enable-dict-dir=/lib/aspell + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b02d4f5e82f5a001a6dd626088405cc0987036f735585d4ad1a025e59f009c631318c8a9480096c552ef647b59d0050f8503af28aa1e7b858d1598d3495ba509 aspell-0.60.7.tar.lz +" diff --git a/base/aspell6/aspell6.SMBuild b/base/aspell6/aspell6.SMBuild new file mode 100755 index 0000000..9076541 --- /dev/null +++ b/base/aspell6/aspell6.SMBuild @@ -0,0 +1,29 @@ +APP=aspell6 +VERSION=en +BUILD=1sml +HOMEPAGE="https://ftp.gnu.org/gnu/aspell/dict/0index.html" +DOWNLOAD="" +REQUIRES="aspell" +DESC="Dictionary files for aspell spelling checker" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION-2018.04.16-0.tar.bz2 + cd "$APP-$VERSION-2018.04.16-0" + fixbuilddirpermissions + + ./configure + + make + make install DESTDIR=$PKG + + cp Copyright $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +70447f5f11a6a2d96e58376ac06e78add59e4eb237ca40ed0752f481dabe1a6e9e227fd20ba95a5612de1bb4357cd65760a31c94efe66f8499b9ed031e9846c2 aspell6-en-2018.04.16-0.tar.bz2 +" diff --git a/base/attr/attr-cdefs.patch b/base/attr/attr-cdefs.patch new file mode 100644 index 0000000..8bf2990 --- /dev/null +++ b/base/attr/attr-cdefs.patch @@ -0,0 +1,27 @@ +--- attr-2.4.47.org/include/xattr.h ++++ attr-2.4.47/include/xattr.h +@@ -30,8 +30,13 @@ + #define XATTR_CREATE 0x1 /* set value, fail if attr already exists */ + #define XATTR_REPLACE 0x2 /* set value, fail if attr does not exist */ + ++#ifndef __THROW ++#define __THROW ++#endif + +-__BEGIN_DECLS ++#ifdef __cplusplus ++extern "C" { ++#endif + + extern int setxattr (const char *__path, const char *__name, + const void *__value, size_t __size, int __flags) __THROW; +@@ -58,6 +63,8 @@ + extern int lremovexattr (const char *__path, const char *__name) __THROW; + extern int fremovexattr (int __filedes, const char *__name) __THROW; + +-__END_DECLS ++#ifdef __cplusplus ++} ++#endif + + #endif /* __XATTR_H__ */ diff --git a/base/attr/attr.SMBuild b/base/attr/attr.SMBuild new file mode 100755 index 0000000..18f1deb --- /dev/null +++ b/base/attr/attr.SMBuild @@ -0,0 +1,45 @@ +APP=attr +VERSION=2.4.47 +BUILD=1sml +HOMEPAGE="http://savannah.nongnu.org/projects/attr" +DOWNLOAD="" +REQUIRES="musl" +DESC="Tools for manipulating extended attributes on filesystems" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i 's@-o $(PKG_USER) -g $(PKG_GROUP)@@' include/buildmacros + sed -i 's@CHOWN=_chown@CHOWN=true@' include/install-sh + patch -p1 < $SRCDIR/attr-cdefs.patch + + make clean + + CFLAGS="-static" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-gettext=no + + for i in po ; do + printf 'all:\n\ttrue\ninstall:\n\ttrue\ninstall-lib:\n\ttrue\ninstall-dev:\n\ttrue\nclean:\n\ttrue\n' > "$i"/Makefile + done + + make LDFLAGS=-all-static + + make DESTDIR="$PKG" install install-lib install-dev + + cp doc/{COPYING,COPYING.LGPL} $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8d1c8b506db2e0c8290d49dc2672a59d7fb5a8e74e784835132d706ebd0c52a14d848fde8fe629c551b51bdc098152f0e5ee0290d0ef51dd5f90dca3c113d24b attr-2.4.47.tar.lz +28236fb6bd7021d249bb2f4fc98a4445f86d336afd4289708b3580d126f08c0c952595f78aa14b203f857df06e5c7262348b660c0e206de3efb1caecf6d19f8c attr-cdefs.patch +" diff --git a/base/autoconf/autoconf.SMBuild b/base/autoconf/autoconf.SMBuild new file mode 100755 index 0000000..ed79255 --- /dev/null +++ b/base/autoconf/autoconf.SMBuild @@ -0,0 +1,30 @@ +APP=autoconf +VERSION=2.69 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/autoconf' +DOWNLOAD='' +REQUIRES="m4 perl perl-modules diffutils gawk" +DESC="m4 macros extension to produce scripts for software packaging" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +9ab9a95fdba7bed86440ec77d3bc976f30c08fb688c699e68c017c741a3792534ec96f0d1f61e5d0f242b77d0ae29fd541a29653fea82d6fd1b983b192033cb6 autoconf-2.69.tar.lz +" diff --git a/base/automake/automake.SMBuild b/base/automake/automake.SMBuild new file mode 100755 index 0000000..ad3269d --- /dev/null +++ b/base/automake/automake.SMBuild @@ -0,0 +1,30 @@ +APP=automake +VERSION=1.16.1 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/automake' +DOWNLOAD='https://ftp.gnu.org/gnu/automake/automake-1.16.1.tar.xz' +DESC="GNU Makefile generator" +REQUIRES="autoconf perl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +cde49f49251a4110b6d6bf71a87c70a02761b937575825049953a5ccb6031e4ee9f4d7ec00b4713e0f1267ddb3265de659e268b09697c4fd401c606910e4605f automake-1.16.1.tar.lz +" diff --git a/base/bash-completion/bash-completion.SMBuild b/base/bash-completion/bash-completion.SMBuild new file mode 100755 index 0000000..916f13d --- /dev/null +++ b/base/bash-completion/bash-completion.SMBuild @@ -0,0 +1,35 @@ +APP=bash-completion +VERSION=2.11 +BUILD=1sml +HOMEPAGE='https://github.com/scop/bash-completion' +DOWNLOAD='https://github.com/scop/bash-completion/archive/refs/tags/2.11.tar.gz' +REQUIRES="bash" +DESC="Programmable completion for the bash shell" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + # Thank you slackware + patch -p1 < $SRCDIR/fixup-sh-script-completions.diff + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +551638e4b97be74ec97624bb9b952dd093a0f6b41f85932efc6a2b914d3a58a9e34b3efd0f4f49ed20fc089e2c93cb0997a0017fefaa7aa3b78d83878d58eda2 bash-completion-2.11.tar.lz +313db416a83f811d52ed7ea530a45851b34ed736eb119ff539127983f300cfd9d4fef95c5e134255f55b082e3f41e9129f48eb85d81c87e8321b735d4d83a483 fixup-sh-script-completions.diff +" diff --git a/base/bash-completion/fixup-sh-script-completions.diff b/base/bash-completion/fixup-sh-script-completions.diff new file mode 100644 index 0000000..2d74595 --- /dev/null +++ b/base/bash-completion/fixup-sh-script-completions.diff @@ -0,0 +1,18 @@ +The 'sh' completion file only completes on *.sh files. This breaks the +expectation (on Slackware, at least) that e.g. "sh /etc/rc.d/rc.my" +will complete to rc.mysql. This patch fixes that, but a consequence is that +"sh" will complete on *any* filename. IMHO, that's not a regression at all, +since stock bash without bash-completion does that already... --rworkman + +Acked-by: volkerdi + +--- ./completions/sh.orig 2020-07-25 12:37:24.175001592 -0500 ++++ ./completions/sh 2020-07-25 12:38:34.061003155 -0500 +@@ -31,6 +31,6 @@ + ((args == 1)) && ext="sh" + _filedir $ext + } && +- complete -F _sh sh ++ complete -F _sh + + # ex: filetype=sh diff --git a/base/bash/bash.SMBuild b/base/bash/bash.SMBuild new file mode 100755 index 0000000..0ed0ba6 --- /dev/null +++ b/base/bash/bash.SMBuild @@ -0,0 +1,42 @@ +APP=bash +VERSION=5.0 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/bash/bash.html' +DOWNLOAD='https://ftp.gnu.org/gnu/bash/bash-5.0.tar.gz' +REQUIRES="netbsd-curses" +DESC="GNU Bourne-Again SHell" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + bash_cv_getenv_redef=no \ + bash_cv_sys_named_pipes=yes \ + ac_cv_rl_version=5.0 \ + LDFLAGS="-static" \ + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sysconfdir=/etc \ + --without-bash-malloc \ + --disable-rpath \ + --enable-history \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + ( cd $PKG/bin ; ln -s bash sh ) + + mkfinalpkg +} + +SHA512SUMS=" +5795c200a1f930caa1b984006498ea1ecae6fd9f73aa039ccc02403e4b2db0cc0999d47b00dc92eefe1ae25b189b43ca5e3d052606b535ea8712f3e3f6f39470 bash-5.0.tar.lz +" diff --git a/base/bc/bc.SMBuild b/base/bc/bc.SMBuild new file mode 100755 index 0000000..6b5a219 --- /dev/null +++ b/base/bc/bc.SMBuild @@ -0,0 +1,29 @@ +APP=bc +VERSION=1.2.5 +BUILD=1sml +HOMEPAGE="https://www.gnu.org/software/bc/" +DOWNLOAD='' +DESC="Arbitrary precision numeric processing language" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z** + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure.sh -EHNG + + make all + make install DESTDIR=$PKG BINDIR="/bin" MAN1DIR="/share/man/man1" + + cp LICENSE.md $PKGDOCS + + mkfinalpkg +} + +SHA512SUMS=" +3e3f56daf1ec3622ef59de067a6497637d09adcec862eb1f90ea1fb901b113e072c1c2b7473fbb6cbff8e340db22bfe041d43b9e83e6b1bb55bf1f5a2bc40d52 bc-1.2.5.tar.lz +" diff --git a/base/bison/bison.SMBuild b/base/bison/bison.SMBuild new file mode 100755 index 0000000..782e623 --- /dev/null +++ b/base/bison/bison.SMBuild @@ -0,0 +1,29 @@ +APP=bison +VERSION=3.1 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/bison/bison.html' +DOWNLOAD='https://ftp.gnu.org/gnu/bison/bison-3.1.tar.xz' +DESC="parser generator similar to yacc" +REQUIRES="m4" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-nls + + make + make install DESTDIR=$PKG + + mkfinalpkg +} + +SHA512SUMS=" +cfc0fd081892dfde34f0f1d5530db02c6160fb9c9efdc7da774c9150848456b14877fcc5f67e384cb6b1a85d174dd9cfb55ce852739fd949304f880a854765fe bison-3.1.tar.lz +" diff --git a/base/boost/boost-execinfo.patch b/base/boost/boost-execinfo.patch new file mode 100644 index 0000000..8e0d63d --- /dev/null +++ b/base/boost/boost-execinfo.patch @@ -0,0 +1,11 @@ +--- boost_1_60_0.org/tools/build/src/engine/execunix.c 2013-01-04 09:45:43.165000002 +0000 ++++ boost_1_60_0/tools/build/src/engine/execunix.c 2013-01-04 09:46:20.095000004 +0000 +@@ -18,7 +18,7 @@ + #include + #include + +-#if defined(sun) || defined(__sun) ++#if defined(sun) || defined(__sun) || defined(__GLIBC__) + #include + #endif + diff --git a/base/boost/boost.SMBuild b/base/boost/boost.SMBuild new file mode 100755 index 0000000..00695ff --- /dev/null +++ b/base/boost/boost.SMBuild @@ -0,0 +1,36 @@ +APP=boost +VERSION=1_69_0 +BUILD=1sml +HOMEPAGE='https://www.boost.org/' +REQUIRES="bzip2 zlib findutils python3 icu xz" +DESC="Huge collection of free peer-reviewed portable C++ source libraries" + +build() { + mkandenterbuilddir + rm -rf "$APP"_"$VERSION" + + tar xf $SRCDIR/"$APP"_"$VERSION".tar.?z* + cd "$APP"_"$VERSION" + chown -R root.root . + + patch -p1 < $SRCDIR/boost-execinfo.patch + + unset CXX + # Also symlink -gcc-6.3.0 to gcc-6.3.0 and -g++ to g++-6.3.0 + + CC="$CC" \ + ./bootstrap.sh \ + --prefix="$PKG" \ + + ./b2 -j3 toolset=gcc-foo -d+2 stage threading=multi link=shared || true + ./b2 -j3 -d+2 install threading=multi link=shared || true + + cp LICENSE_1_0.txt $PKGDOCS/LICENSE + + mkfinalpkg +} + +SHA512SUMS=" +d0e9bb858c44880d56c0291afef6a1b011a62f659a2d8f58dcb6147ea0899f9157bd8db3097896618fee0116847ebeac78b6d0f0fec8a92c3469500828bbe552 boost_1_69_0.tar.bz2 +16d8d072adb9073f240e3f7ff73591d3867681c4ba47f6f9f7d064e367b45a97e1f757ff01e489d0d834382670f9e9658755754d0e0dce62b08e6045c1f8605a boost-execinfo.patch +" diff --git a/base/brotli/brotli.SMBuild b/base/brotli/brotli.SMBuild new file mode 100755 index 0000000..8124cf0 --- /dev/null +++ b/base/brotli/brotli.SMBuild @@ -0,0 +1,32 @@ +APP=brotli +VERSION=1.0.7 +BUILD=1sml +HOMEPAGE="https://github.com/google/brotli" +DOWNLOAD="https://github.com/google/brotli/archive/refs/tags/v1.0.7.tar.gz" +REQUIRES="musl" +DESC="Generic-purpose lossless compression algorithm based on LZ77, Huffman coding and 2nd order context modeling" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./bootstrap + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +74c138ff3cd31185daed65666afb163279d2766d367bff9f3133252467772e47450b4b5dee9476d2cad4198d8e613739673de54648252b9d5e0887be5d87ca5d brotli-1.0.7.tar.lz +" diff --git a/base/bubblewrap/bubblewrap.SMBuild b/base/bubblewrap/bubblewrap.SMBuild new file mode 100755 index 0000000..68f2087 --- /dev/null +++ b/base/bubblewrap/bubblewrap.SMBuild @@ -0,0 +1,37 @@ +APP=bubblewrap +VERSION=0.4.1 +BUILD=1sml +HOMEPAGE='https://github.com/containers/bubblewrap' +DOWNLOAD='' +DESC="Unprivileged sandboxing tool to reduce attack surfaces" +REQUIRES="libcap" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/realpath-workaround.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --localstatedir=/var \ + --with-priv-mode=setuid \ + --disable-man + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0ff46dc0fda2d0cffbb36cc52ff43951b30cbd835a42cc56806acbbbd827796bfadbb1cfafc84d6b47a72c031ca44abe1c377acc0cc25fe3b33e854f5f687d35 bubblewrap-0.4.1.tar.xz +7e8395aa7801263056b0c072194240f0ae1ee1a3b0acd874baf112a7b7b5e53ac5f688ece9099067bfc1e28e52e81f107964a3288a615cc1eedb1af5f82bbd8e realpath-workaround.patch +" diff --git a/base/bubblewrap/realpath-workaround.patch b/base/bubblewrap/realpath-workaround.patch new file mode 100644 index 0000000..8474faf --- /dev/null +++ b/base/bubblewrap/realpath-workaround.patch @@ -0,0 +1,53 @@ +Musl realpath() implementation currently depends on /proc which is +not available when setting up pivot root. For the time being just +fallback to a naive normalization algorithm originated from +VoidLinux' xbps. If there was path that would have required advanced +normalizing as provided by realpath() the following parse_mountinfo() +will fail. + + +diff --git bind-mount.c.orig bind-mount.c +index 045fa0e..d05b540 100644 +--- ./bind-mount.c.orig ++++ ./bind-mount.c +@@ -23,6 +23,28 @@ + #include "utils.h" + #include "bind-mount.h" + ++#ifndef __GLIBC__ ++static char * ++normpath(char *path) ++{ ++ char *seg = NULL, *p = NULL; ++ ++ for (p = path, seg = NULL; *p; p++) { ++ if (strncmp(p, "/../", 4) == 0 || strncmp(p, "/..", 4) == 0) { ++ memmove(seg ? seg : p, p+3, strlen(p+3) + 1); ++ return normpath(path); ++ } else if (strncmp(p, "/./", 3) == 0 || strncmp(p, "/.", 3) == 0) { ++ memmove(p, p+2, strlen(p+2) + 1); ++ } else if (strncmp(p, "//", 2) == 0 || strncmp(p, "/", 2) == 0) { ++ memmove(p, p+1, strlen(p+1) + 1); ++ } ++ if (*p == '/') ++ seg = p; ++ } ++ return path; ++} ++#endif ++ + static char * + skip_token (char *line, bool eat_whitespace) + { +@@ -397,7 +419,11 @@ bind_mount (int proc_fd, + path, so to find it in the mount table we need to do that too. */ + resolved_dest = realpath (dest, NULL); + if (resolved_dest == NULL) ++#ifdef __GLIBC__ + return 2; ++#else ++ resolved_dest = normpath(strdup(dest)); ++#endif + + mount_tab = parse_mountinfo (proc_fd, resolved_dest); + if (mount_tab[0].mountpoint == NULL) diff --git a/base/busybox/busybox-blowfish.patch b/base/busybox/busybox-blowfish.patch new file mode 100644 index 0000000..990da01 --- /dev/null +++ b/base/busybox/busybox-blowfish.patch @@ -0,0 +1,47 @@ +--- a/libbb/pw_encrypt.c ++++ b/libbb/pw_encrypt.c +@@ -57,9 +57,20 @@ + * Need to be case-insensitive in the code below. + */ + if ((algo[0]|0x20) != 'd') { /* not des */ +- len = 8/2; /* so far assuming md5 */ + *salt_ptr++ = '$'; +- *salt_ptr++ = '1'; ++ if(algo[0] == 'b') { ++ // blowfish ++ *salt_ptr++ = '2'; ++ *salt_ptr++ = 'a'; ++ *salt_ptr++ = '$'; ++ // 8 rounds ++ *salt_ptr++ = '0'; ++ *salt_ptr++ = '8'; ++ len = 22/2; ++ } else { ++ *salt_ptr++ = '1'; ++ if (algo[0] == 'm') len = 8/2; /* so far assuming md5 */ ++ } + *salt_ptr++ = '$'; + #if !ENABLE_USE_BB_CRYPT || ENABLE_USE_BB_CRYPT_SHA + if ((algo[0]|0x20) == 's') { /* sha */ +@@ -99,6 +110,11 @@ + /* Other advanced crypt ids (TODO?): */ + /* $2$ or $2a$: Blowfish */ + ++static char *bf_crypt(const char *key, const char *salt) { ++ // use musl-builtin crypt ++ return crypt(key, salt); ++} ++ + static struct const_des_ctx *des_cctx; + static struct des_ctx *des_ctx; + +@@ -113,7 +129,8 @@ + if (salt[1] == '5' || salt[1] == '6') + return sha_crypt((char*)key, (char*)salt); + #endif +- } ++ } else if (salt[0] == '$' && salt[1] == '2' && salt[2] == 'a' && salt[3] == '$') ++ return bf_crypt(key, salt); + + if (!des_cctx) + des_cctx = const_des_init(); diff --git a/base/busybox/busybox-fdisk-sector-size.patch b/base/busybox/busybox-fdisk-sector-size.patch new file mode 100644 index 0000000..ec13cc9 --- /dev/null +++ b/base/busybox/busybox-fdisk-sector-size.patch @@ -0,0 +1,22 @@ +--- a/util-linux/fdisk.c ++++ b/util-linux/fdisk.c +@@ -166,17 +166,8 @@ + + + typedef unsigned long long ullong; +-/* Used for sector numbers. Partition formats we know +- * do not support more than 2^32 sectors +- */ +-typedef uint32_t sector_t; +-#if UINT_MAX == 4294967295 +-# define SECT_FMT "" +-#elif ULONG_MAX == 4294967295 +-# define SECT_FMT "l" +-#else +-# error Cant detect sizeof(uint32_t) +-#endif ++typedef uint64_t sector_t; ++#define SECT_FMT "ll" + + struct hd_geometry { + unsigned char heads; diff --git a/base/busybox/busybox-libbb-make-unicode-printable.patch b/base/busybox/busybox-libbb-make-unicode-printable.patch new file mode 100644 index 0000000..7c576c7 --- /dev/null +++ b/base/busybox/busybox-libbb-make-unicode-printable.patch @@ -0,0 +1,20 @@ +--- a/libbb/printable_string.c ++++ b/libbb/printable_string.c +@@ -28,8 +28,6 @@ + } + if (c < ' ') + break; +- if (c >= 0x7f) +- break; + s++; + } + +@@ -42,7 +40,7 @@ + unsigned char c = *d; + if (c == '\0') + break; +- if (c < ' ' || c >= 0x7f) ++ if (c < ' ') + *d = '?'; + d++; + } diff --git a/base/busybox/busybox-ping.patch b/base/busybox/busybox-ping.patch new file mode 100644 index 0000000..4a25f94 --- /dev/null +++ b/base/busybox/busybox-ping.patch @@ -0,0 +1,191 @@ +diff --git a/networking/ping.c b/networking/ping.c +index 94fb007..0d83b66 100644 +--- a/networking/ping.c ++++ b/networking/ping.c +@@ -155,6 +155,7 @@ enum { + pingsock = 0, + }; + ++static int using_dgram; + static void + #if ENABLE_PING6 + create_icmp_socket(len_and_sockaddr *lsa) +@@ -171,9 +172,23 @@ create_icmp_socket(void) + #endif + sock = socket(AF_INET, SOCK_RAW, 1); /* 1 == ICMP */ + if (sock < 0) { +- if (errno == EPERM) +- bb_error_msg_and_die(bb_msg_perm_denied_are_you_root); +- bb_perror_msg_and_die(bb_msg_can_not_create_raw_socket); ++ if (errno != EPERM) ++ bb_perror_msg_and_die(bb_msg_can_not_create_raw_socket); ++#if defined(__linux__) || defined(__APPLE__) ++ /* We don't have root privileges. Try SOCK_DGRAM instead. ++ * Linux needs net.ipv4.ping_group_range for this to work. ++ * MacOSX allows ICMP_ECHO, ICMP_TSTAMP or ICMP_MASKREQ ++ */ ++#if ENABLE_PING6 ++ if (lsa->u.sa.sa_family == AF_INET6) ++ sock = socket(AF_INET6, SOCK_DGRAM, IPPROTO_ICMPV6); ++ else ++#endif ++ sock = socket(AF_INET, SOCK_DGRAM, 1); /* 1 == ICMP */ ++ if (sock < 0) ++#endif ++ bb_error_msg_and_die(bb_msg_perm_denied_are_you_root); ++ using_dgram = 1; + } + + xmove_fd(sock, pingsock); +@@ -226,12 +241,14 @@ static void ping4(len_and_sockaddr *lsa) + bb_perror_msg("recvfrom"); + continue; + } +- if (c >= 76) { /* ip + icmp */ +- struct iphdr *iphdr = (struct iphdr *) G.packet; +- +- pkt = (struct icmp *) (G.packet + (iphdr->ihl << 2)); /* skip ip hdr */ +- if (pkt->icmp_id != G.myid) +- continue; /* not our ping */ ++ if (c >= 76 || using_dgram && (c == 64)) { /* ip + icmp */ ++ if(!using_dgram) { ++ struct iphdr *iphdr = (struct iphdr *) G.packet; ++ ++ pkt = (struct icmp *) (G.packet + (iphdr->ihl << 2)); /* skip ip hdr */ ++ if (pkt->icmp_id != G.myid) ++ continue; /* not our ping */ ++ } else pkt = (struct icmp *) G.packet; + if (pkt->icmp_type == ICMP_ECHOREPLY) + break; + } +@@ -627,19 +644,21 @@ static void unpack_tail(int sz, uint32_t *tp, + } + static void unpack4(char *buf, int sz, struct sockaddr_in *from) + { +- struct icmp *icmppkt; + struct iphdr *iphdr; ++ struct icmp *icmppkt; + int hlen; + + /* discard if too short */ + if (sz < (datalen + ICMP_MINLEN)) + return; ++ if(!using_dgram) { ++ /* check IP header */ ++ iphdr = (struct iphdr *) buf; ++ hlen = iphdr->ihl << 2; ++ sz -= hlen; ++ icmppkt = (struct icmp *) (buf + hlen); ++ } else icmppkt = (struct icmp *) buf; + +- /* check IP header */ +- iphdr = (struct iphdr *) buf; +- hlen = iphdr->ihl << 2; +- sz -= hlen; +- icmppkt = (struct icmp *) (buf + hlen); + if (icmppkt->icmp_id != myid) + return; /* not our ping */ + +@@ -651,7 +670,7 @@ static void unpack4(char *buf, int sz, struct sockaddr_in *from) + tp = (uint32_t *) icmppkt->icmp_data; + unpack_tail(sz, tp, + inet_ntoa(*(struct in_addr *) &from->sin_addr.s_addr), +- recv_seq, iphdr->ttl); ++ recv_seq, using_dgram ? 42 : iphdr->ttl); + } else if (icmppkt->icmp_type != ICMP_ECHO) { + bb_error_msg("warning: got ICMP %d (%s)", + icmppkt->icmp_type, +@@ -695,11 +714,31 @@ static void ping4(len_and_sockaddr *lsa) + int sockopt; + + pingaddr.sin = lsa->u.sin; +- if (source_lsa) { ++ if (source_lsa && !using_dgram) { + if (setsockopt(pingsock, IPPROTO_IP, IP_MULTICAST_IF, + &source_lsa->u.sa, source_lsa->len)) + bb_error_msg_and_die("can't set multicast source interface"); + xbind(pingsock, &source_lsa->u.sa, source_lsa->len); ++ } else if(using_dgram) { ++ struct sockaddr_in sa; ++ socklen_t sl; ++ ++ sa.sin_family = AF_INET; ++ sa.sin_port = 0; ++ sa.sin_addr.s_addr = source_lsa ? ++ source_lsa->u.sin.sin_addr.s_addr : 0; ++ sl = sizeof(sa); ++ ++ if (bind(pingsock, (struct sockaddr *) &sa, sl) == -1) { ++ perror("bind"); ++ exit(2); ++ } ++ ++ if (getsockname(pingsock, (struct sockaddr *) &sa, &sl) == -1) { ++ perror("getsockname"); ++ exit(2); ++ } ++ myid = sa.sin_port; + } + + /* enable broadcast pings */ +@@ -716,6 +755,15 @@ static void ping4(len_and_sockaddr *lsa) + setsockopt_int(pingsock, IPPROTO_IP, IP_MULTICAST_TTL, opt_ttl); + } + ++ if(using_dgram) { ++ int hold = 65536; ++ if (setsockopt(pingsock, SOL_IP, IP_RECVTTL, (char *)&hold, sizeof(hold))) ++ perror("WARNING: setsockopt(IP_RECVTTL)"); ++ if (setsockopt(pingsock, SOL_IP, IP_RETOPTS, (char *)&hold, sizeof(hold))) ++ perror("WARNING: setsockopt(IP_RETOPTS)"); ++ ++ } ++ + signal(SIGINT, print_stats_and_exit); + + /* start the ping's going ... */ +@@ -749,10 +797,33 @@ static void ping6(len_and_sockaddr *lsa) + char control_buf[CMSG_SPACE(36)]; + + pingaddr.sin6 = lsa->u.sin6; +- if (source_lsa) ++ if (source_lsa && !using_dgram) + xbind(pingsock, &source_lsa->u.sa, source_lsa->len); ++ else if(using_dgram) { ++ struct sockaddr_in6 sa = {0}; ++ socklen_t sl; ++ ++ sa.sin6_family = AF_INET6; ++ sa.sin6_port = 0; ++ if(source_lsa) { ++ memcpy(&sa.sin6_addr, &source_lsa->u.sin6.sin6_addr, sizeof(struct in6_addr)); ++ } ++ sl = sizeof(sa); ++ ++ if (bind(pingsock, (struct sockaddr *) &sa, sl) == -1) { ++ perror("bind"); ++ exit(2); ++ } ++ ++ if (getsockname(pingsock, (struct sockaddr *) &sa, &sl) == -1) { ++ perror("getsockname"); ++ exit(2); ++ } ++ myid = sa.sin6_port; ++ } + + #ifdef ICMP6_FILTER ++ if(!using_dgram) + { + struct icmp6_filter filt; + if (!(option_mask32 & OPT_VERBOSE)) { +@@ -880,7 +951,7 @@ static int common_ping_main(int opt, char **argv) + if (opt & OPT_p) + G.pattern = xstrtou_range(str_p, 16, 0, 255); + +- myid = (uint16_t) getpid(); ++ if(!using_dgram) myid = (uint16_t) getpid(); + hostname = argv[optind]; + #if ENABLE_PING6 + { + diff --git a/base/busybox/busybox.SMBuild b/base/busybox/busybox.SMBuild new file mode 100755 index 0000000..dbb4c83 --- /dev/null +++ b/base/busybox/busybox.SMBuild @@ -0,0 +1,59 @@ +APP=busybox +VERSION=1.27.2 +BUILD=1sml +HOMEPAGE="https://www.busybox.net/" +DOWNLOAD="https://www.busybox.net/downloads/busybox-1.27.2.tar.bz2" +REQUIRES="musl" +DESC="Swiss army knife of embedded linux providing subsets of common UNIX utilities" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # taken from sabotage linux + patch -p1 < $SRCDIR/busybox-blowfish.patch + patch -p1 < $SRCDIR/busybox-fdisk-sector-size.patch + patch -p1 < $SRCDIR/busybox-libbb-make-unicode-printable.patch + patch -p1 < $SRCDIR/busybox-ping.patch + + cp $SRCDIR/busybox.config .config + make CC="$CC" + + install -Dm 755 busybox $PKG/bin/busybox + + cp LICENSE $PKGDOCS/ + + cd $PKG/bin + + for f in ntpd hwclock passwd udhcpc udhcpd route ifconfig \ + telnet telnetd tftp microcom netstat killall5 setfont \ + loadkmap wall ipcalc iostat brctl arp \ + su login init chpst sv svc runsv runsvdir halt reboot poweroff getty \ + adduser addgroup deluser delgroup mdev rev; + do ln -s busybox "$f"; + done + + install -Dm 755 $SRCDIR/udhcpc-script $PKG/etc/udhcpc-script + install -Dm 755 $SRCDIR/dhclient $PKG/bin/dhclient + + mkdir -p $PKG/share/man/man8 + for f in sv runsvchdir chpst runsvdir runit runsv runit ; + do cp $SRCDIR/runit-man/$f.8 $PKG/share/man/man8/ + done + + echo "server pool.ntp.org" > $PKG/etc/ntp.conf + + mkfinalpkg +} + +SHA512SUMS=" +b75f66680a0fa6fd409f5070ced57d8babd02bdf3e1a194d749a2acbc5842d2474d98e5368fe9831e5e560ed5320a914357a96b2f0a0b9653c2540f7801ea198 busybox-1.27.2.tar.lz +4380794dab5bc3e6a82b18d2556bbe647503382acb33d3c82baacae166d3a6fc877b4d07b15512678c2c9868fb28f67b43b0fd804b72e3c4ee441d9108f5c5b4 busybox-blowfish.patch +8e1c116cde322f35b2a122f0c333ef36ef06334c7c0c504a8abd7f9c805d2d3c25d455d8e20ed46e960ed6dec4b543973528c948cf24ac1e02c9730d894802a5 busybox-fdisk-sector-size.patch +bee4d54bd2e740866c0eb21777767813c5789b233ed85878a96cfd459338f710abc5107fb5abb412e22f7be895c914818729fe6453cddecd99eb3241528c0d48 busybox-libbb-make-unicode-printable.patch +1057badba69fbdf98392253ae777f92c991af35cc09f094329e509cb18e668a47f0c4b2cfc7fd698c2c93c07b02833862dbc008381b753715ef6f0904b7f9b23 busybox-ping.patch +" diff --git a/base/busybox/busybox.config b/base/busybox/busybox.config new file mode 100644 index 0000000..41a83ca --- /dev/null +++ b/base/busybox/busybox.config @@ -0,0 +1,1135 @@ +# +# Automatically generated make config: don't edit +# Busybox version: 1.27.2 +# Sat Nov 2 12:43:14 2019 +# +CONFIG_HAVE_DOT_CONFIG=y + +# +# Busybox Settings +# +CONFIG_DESKTOP=y +# CONFIG_EXTRA_COMPAT is not set +# CONFIG_FEDORA_COMPAT is not set +CONFIG_INCLUDE_SUSv2=y +# CONFIG_USE_PORTABLE_CODE is not set +CONFIG_SHOW_USAGE=y +CONFIG_FEATURE_VERBOSE_USAGE=y +CONFIG_FEATURE_COMPRESS_USAGE=y +CONFIG_BUSYBOX=y +CONFIG_FEATURE_INSTALLER=y +CONFIG_INSTALL_NO_USR=y +# CONFIG_PAM is not set +CONFIG_LONG_OPTS=y +CONFIG_FEATURE_DEVPTS=y +# CONFIG_FEATURE_CLEAN_UP is not set +# CONFIG_FEATURE_UTMP is not set +# CONFIG_FEATURE_WTMP is not set +CONFIG_FEATURE_PIDFILE=y +CONFIG_PID_FILE_PATH="/var/run" +CONFIG_FEATURE_SUID=y +CONFIG_FEATURE_SUID_CONFIG=y +CONFIG_FEATURE_SUID_CONFIG_QUIET=y +# CONFIG_SELINUX is not set +# CONFIG_FEATURE_PREFER_APPLETS is not set +CONFIG_BUSYBOX_EXEC_PATH="/proc/self/exe" +CONFIG_FEATURE_SYSLOG=y +# CONFIG_FEATURE_HAVE_RPC is not set +CONFIG_PLATFORM_LINUX=y + +# +# Build Options +# +CONFIG_STATIC=y +# CONFIG_PIE is not set +# CONFIG_NOMMU is not set +# CONFIG_BUILD_LIBBUSYBOX is not set +# CONFIG_FEATURE_INDIVIDUAL is not set +# CONFIG_FEATURE_SHARED_BUSYBOX is not set +CONFIG_LFS=y +CONFIG_CROSS_COMPILER_PREFIX="" +CONFIG_SYSROOT="" +CONFIG_EXTRA_CFLAGS="-D__musl__ -static" +CONFIG_EXTRA_LDFLAGS="" +CONFIG_EXTRA_LDLIBS="" + +# +# Installation Options ("make install" behavior) +# +CONFIG_INSTALL_APPLET_SYMLINKS=y +# CONFIG_INSTALL_APPLET_HARDLINKS is not set +# CONFIG_INSTALL_APPLET_SCRIPT_WRAPPERS is not set +# CONFIG_INSTALL_APPLET_DONT is not set +# CONFIG_INSTALL_SH_APPLET_SYMLINK is not set +# CONFIG_INSTALL_SH_APPLET_HARDLINK is not set +# CONFIG_INSTALL_SH_APPLET_SCRIPT_WRAPPER is not set +CONFIG_PREFIX="./_install" + +# +# Debugging Options +# +# CONFIG_DEBUG is not set +# CONFIG_DEBUG_PESSIMIZE is not set +# CONFIG_DEBUG_SANITIZE is not set +# CONFIG_UNIT_TEST is not set +# CONFIG_WERROR is not set +CONFIG_NO_DEBUG_LIB=y +# CONFIG_DMALLOC is not set +# CONFIG_EFENCE is not set + +# +# Busybox Library Tuning +# +# CONFIG_FEATURE_USE_BSS_TAIL is not set +CONFIG_FEATURE_RTMINMAX=y +CONFIG_FEATURE_BUFFERS_USE_MALLOC=y +# CONFIG_FEATURE_BUFFERS_GO_ON_STACK is not set +# CONFIG_FEATURE_BUFFERS_GO_IN_BSS is not set +CONFIG_PASSWORD_MINLEN=6 +CONFIG_MD5_SMALL=1 +CONFIG_SHA3_SMALL=1 +CONFIG_FEATURE_FAST_TOP=y +# CONFIG_FEATURE_ETC_NETWORKS is not set +CONFIG_FEATURE_EDITING=y +CONFIG_FEATURE_EDITING_MAX_LEN=1024 +# CONFIG_FEATURE_EDITING_VI is not set +CONFIG_FEATURE_EDITING_HISTORY=255 +CONFIG_FEATURE_EDITING_SAVEHISTORY=y +CONFIG_FEATURE_EDITING_SAVE_ON_EXIT=y +CONFIG_FEATURE_REVERSE_SEARCH=y +CONFIG_FEATURE_TAB_COMPLETION=y +CONFIG_FEATURE_USERNAME_COMPLETION=y +CONFIG_FEATURE_EDITING_FANCY_PROMPT=y +# CONFIG_FEATURE_EDITING_ASK_TERMINAL is not set +# CONFIG_LOCALE_SUPPORT is not set +CONFIG_UNICODE_SUPPORT=y +# CONFIG_UNICODE_USING_LOCALE is not set +# CONFIG_FEATURE_CHECK_UNICODE_IN_ENV is not set +CONFIG_SUBST_WCHAR=63 +CONFIG_LAST_SUPPORTED_WCHAR=767 +# CONFIG_UNICODE_COMBINING_WCHARS is not set +# CONFIG_UNICODE_WIDE_WCHARS is not set +# CONFIG_UNICODE_BIDI_SUPPORT is not set +# CONFIG_UNICODE_NEUTRAL_TABLE is not set +# CONFIG_UNICODE_PRESERVE_BROKEN is not set +CONFIG_FEATURE_NON_POSIX_CP=y +# CONFIG_FEATURE_VERBOSE_CP_MESSAGE is not set +CONFIG_FEATURE_USE_SENDFILE=y +CONFIG_FEATURE_COPYBUF_KB=4 +CONFIG_FEATURE_SKIP_ROOTFS=y +CONFIG_MONOTONIC_SYSCALL=y +CONFIG_IOCTL_HEX2STR_ERROR=y +CONFIG_FEATURE_HWIB=y + +# +# Applets +# + +# +# Archival Utilities +# +CONFIG_FEATURE_SEAMLESS_XZ=y +CONFIG_FEATURE_SEAMLESS_LZMA=y +CONFIG_FEATURE_SEAMLESS_BZ2=y +CONFIG_FEATURE_SEAMLESS_GZ=y +# CONFIG_FEATURE_SEAMLESS_Z is not set +# CONFIG_AR is not set +# CONFIG_FEATURE_AR_LONG_FILENAMES is not set +# CONFIG_FEATURE_AR_CREATE is not set +# CONFIG_UNCOMPRESS is not set +CONFIG_GUNZIP=y +CONFIG_ZCAT=y +CONFIG_FEATURE_GUNZIP_LONG_OPTIONS=y +CONFIG_BUNZIP2=y +CONFIG_BZCAT=y +CONFIG_UNLZMA=y +CONFIG_LZCAT=y +CONFIG_LZMA=y +CONFIG_FEATURE_LZMA_FAST=y +CONFIG_UNXZ=y +CONFIG_XZCAT=y +CONFIG_XZ=y +CONFIG_BZIP2=y +CONFIG_FEATURE_BZIP2_DECOMPRESS=y +CONFIG_CPIO=y +CONFIG_FEATURE_CPIO_O=y +CONFIG_FEATURE_CPIO_P=y +# CONFIG_DPKG is not set +# CONFIG_DPKG_DEB is not set +CONFIG_GZIP=y +CONFIG_FEATURE_GZIP_LONG_OPTIONS=y +CONFIG_GZIP_FAST=0 +# CONFIG_FEATURE_GZIP_LEVELS is not set +CONFIG_FEATURE_GZIP_DECOMPRESS=y +CONFIG_LZOP=y +CONFIG_UNLZOP=y +CONFIG_LZOPCAT=y +# CONFIG_LZOP_COMPR_HIGH is not set +# CONFIG_RPM is not set +# CONFIG_RPM2CPIO is not set +CONFIG_TAR=y +CONFIG_FEATURE_TAR_LONG_OPTIONS=y +CONFIG_FEATURE_TAR_CREATE=y +CONFIG_FEATURE_TAR_AUTODETECT=y +CONFIG_FEATURE_TAR_FROM=y +CONFIG_FEATURE_TAR_OLDGNU_COMPATIBILITY=y +CONFIG_FEATURE_TAR_OLDSUN_COMPATIBILITY=y +CONFIG_FEATURE_TAR_GNU_EXTENSIONS=y +CONFIG_FEATURE_TAR_TO_COMMAND=y +CONFIG_FEATURE_TAR_UNAME_GNAME=y +CONFIG_FEATURE_TAR_NOPRESERVE_TIME=y +# CONFIG_FEATURE_TAR_SELINUX is not set +CONFIG_UNZIP=y +CONFIG_FEATURE_UNZIP_CDF=y +CONFIG_FEATURE_UNZIP_BZIP2=y +CONFIG_FEATURE_UNZIP_LZMA=y +CONFIG_FEATURE_UNZIP_XZ=y + +# +# Coreutils +# +CONFIG_BASENAME=y +CONFIG_CAT=y +CONFIG_FEATURE_CATV=y +CONFIG_CHGRP=y +CONFIG_CHMOD=y +CONFIG_CHOWN=y +CONFIG_FEATURE_CHOWN_LONG_OPTIONS=y +CONFIG_CHROOT=y +CONFIG_CKSUM=y +CONFIG_COMM=y +CONFIG_CP=y +CONFIG_FEATURE_CP_LONG_OPTIONS=y +CONFIG_CUT=y +CONFIG_DATE=y +CONFIG_FEATURE_DATE_ISOFMT=y +# CONFIG_FEATURE_DATE_NANO is not set +CONFIG_FEATURE_DATE_COMPAT=y +CONFIG_DD=y +CONFIG_FEATURE_DD_SIGNAL_HANDLING=y +CONFIG_FEATURE_DD_THIRD_STATUS_LINE=y +CONFIG_FEATURE_DD_IBS_OBS=y +CONFIG_FEATURE_DD_STATUS=y +CONFIG_DF=y +CONFIG_FEATURE_DF_FANCY=y +CONFIG_DIRNAME=y +CONFIG_DOS2UNIX=y +CONFIG_UNIX2DOS=y +CONFIG_DU=y +CONFIG_FEATURE_DU_DEFAULT_BLOCKSIZE_1K=y +CONFIG_ECHO=y +CONFIG_FEATURE_FANCY_ECHO=y +CONFIG_ENV=y +CONFIG_FEATURE_ENV_LONG_OPTIONS=y +CONFIG_EXPAND=y +CONFIG_FEATURE_EXPAND_LONG_OPTIONS=y +CONFIG_UNEXPAND=y +CONFIG_FEATURE_UNEXPAND_LONG_OPTIONS=y +CONFIG_EXPR=y +CONFIG_EXPR_MATH_SUPPORT_64=y +CONFIG_FACTOR=y +CONFIG_FALSE=y +CONFIG_FOLD=y +CONFIG_FSYNC=y +CONFIG_HEAD=y +CONFIG_FEATURE_FANCY_HEAD=y +CONFIG_HOSTID=y +CONFIG_ID=y +CONFIG_GROUPS=y +CONFIG_INSTALL=y +CONFIG_FEATURE_INSTALL_LONG_OPTIONS=y +CONFIG_LINK=y +CONFIG_LN=y +CONFIG_LOGNAME=y +CONFIG_LS=y +CONFIG_FEATURE_LS_FILETYPES=y +CONFIG_FEATURE_LS_FOLLOWLINKS=y +CONFIG_FEATURE_LS_RECURSIVE=y +CONFIG_FEATURE_LS_WIDTH=y +CONFIG_FEATURE_LS_SORTFILES=y +CONFIG_FEATURE_LS_TIMESTAMPS=y +CONFIG_FEATURE_LS_USERNAME=y +CONFIG_FEATURE_LS_COLOR=y +CONFIG_FEATURE_LS_COLOR_IS_DEFAULT=y +CONFIG_MD5SUM=y +CONFIG_SHA1SUM=y +CONFIG_SHA256SUM=y +CONFIG_SHA512SUM=y +CONFIG_SHA3SUM=y + +# +# Common options for md5sum, sha1sum, sha256sum, sha512sum, sha3sum +# +CONFIG_FEATURE_MD5_SHA1_SUM_CHECK=y +CONFIG_MKDIR=y +CONFIG_FEATURE_MKDIR_LONG_OPTIONS=y +CONFIG_MKFIFO=y +CONFIG_MKNOD=y +CONFIG_MKTEMP=y +CONFIG_MV=y +CONFIG_FEATURE_MV_LONG_OPTIONS=y +CONFIG_NICE=y +CONFIG_NL=y +CONFIG_NOHUP=y +CONFIG_NPROC=y +CONFIG_OD=y +CONFIG_PASTE=y +CONFIG_PRINTENV=y +CONFIG_PRINTF=y +CONFIG_PWD=y +CONFIG_READLINK=y +CONFIG_FEATURE_READLINK_FOLLOW=y +CONFIG_REALPATH=y +CONFIG_RM=y +CONFIG_RMDIR=y +CONFIG_FEATURE_RMDIR_LONG_OPTIONS=y +CONFIG_SEQ=y +CONFIG_SHRED=y +CONFIG_SHUF=y +CONFIG_SLEEP=y +CONFIG_FEATURE_FANCY_SLEEP=y +CONFIG_FEATURE_FLOAT_SLEEP=y +CONFIG_SORT=y +CONFIG_FEATURE_SORT_BIG=y +CONFIG_SPLIT=y +CONFIG_FEATURE_SPLIT_FANCY=y +CONFIG_STAT=y +CONFIG_FEATURE_STAT_FORMAT=y +CONFIG_FEATURE_STAT_FILESYSTEM=y +CONFIG_STTY=y +CONFIG_SUM=y +CONFIG_SYNC=y +CONFIG_FEATURE_SYNC_FANCY=y +CONFIG_TAC=y +CONFIG_TAIL=y +CONFIG_FEATURE_FANCY_TAIL=y +CONFIG_TEE=y +CONFIG_FEATURE_TEE_USE_BLOCK_IO=y +CONFIG_TEST=y +CONFIG_TEST1=y +CONFIG_TEST2=y +CONFIG_FEATURE_TEST_64=y +CONFIG_TIMEOUT=y +CONFIG_TOUCH=y +CONFIG_FEATURE_TOUCH_NODEREF=y +CONFIG_FEATURE_TOUCH_SUSV3=y +CONFIG_TR=y +CONFIG_FEATURE_TR_CLASSES=y +CONFIG_FEATURE_TR_EQUIV=y +CONFIG_TRUE=y +CONFIG_TRUNCATE=y +CONFIG_TTY=y +CONFIG_UNAME=y +CONFIG_UNAME_OSNAME="GNU/Linux" +CONFIG_UNIQ=y +CONFIG_UNLINK=y +CONFIG_USLEEP=y +CONFIG_UUDECODE=y +CONFIG_BASE64=y +CONFIG_UUENCODE=y +CONFIG_WC=y +CONFIG_FEATURE_WC_LARGE=y +# CONFIG_WHO is not set +# CONFIG_W is not set +# CONFIG_USERS is not set +CONFIG_WHOAMI=y +CONFIG_YES=y + +# +# Common options +# +CONFIG_FEATURE_VERBOSE=y + +# +# Common options for cp and mv +# +CONFIG_FEATURE_PRESERVE_HARDLINKS=y + +# +# Common options for df, du, ls +# +CONFIG_FEATURE_HUMAN_READABLE=y + +# +# Console Utilities +# +CONFIG_CHVT=y +CONFIG_CLEAR=y +CONFIG_DEALLOCVT=y +CONFIG_DUMPKMAP=y +CONFIG_FGCONSOLE=y +CONFIG_KBD_MODE=y +CONFIG_LOADFONT=y +CONFIG_SETFONT=y +CONFIG_FEATURE_SETFONT_TEXTUAL_MAP=y +CONFIG_DEFAULT_SETFONT_DIR="" + +# +# Common options for loadfont and setfont +# +CONFIG_FEATURE_LOADFONT_PSF2=y +CONFIG_FEATURE_LOADFONT_RAW=y +CONFIG_LOADKMAP=y +CONFIG_OPENVT=y +CONFIG_RESET=y +CONFIG_RESIZE=y +CONFIG_FEATURE_RESIZE_PRINT=y +CONFIG_SETCONSOLE=y +CONFIG_FEATURE_SETCONSOLE_LONG_OPTIONS=y +CONFIG_SETKEYCODES=y +CONFIG_SETLOGCONS=y +CONFIG_SHOWKEY=y + +# +# Debian Utilities +# +CONFIG_PIPE_PROGRESS=y +CONFIG_RUN_PARTS=y +CONFIG_FEATURE_RUN_PARTS_LONG_OPTIONS=y +CONFIG_FEATURE_RUN_PARTS_FANCY=y +CONFIG_START_STOP_DAEMON=y +CONFIG_FEATURE_START_STOP_DAEMON_LONG_OPTIONS=y +CONFIG_FEATURE_START_STOP_DAEMON_FANCY=y +CONFIG_WHICH=y + +# +# Editors +# +CONFIG_AWK=y +CONFIG_FEATURE_AWK_LIBM=y +CONFIG_FEATURE_AWK_GNU_EXTENSIONS=y +CONFIG_CMP=y +CONFIG_DIFF=y +CONFIG_FEATURE_DIFF_LONG_OPTIONS=y +CONFIG_FEATURE_DIFF_DIR=y +CONFIG_ED=y +CONFIG_PATCH=y +CONFIG_SED=y +CONFIG_VI=y +CONFIG_FEATURE_VI_MAX_LEN=4096 +# CONFIG_FEATURE_VI_8BIT is not set +CONFIG_FEATURE_VI_COLON=y +CONFIG_FEATURE_VI_YANKMARK=y +CONFIG_FEATURE_VI_SEARCH=y +# CONFIG_FEATURE_VI_REGEX_SEARCH is not set +CONFIG_FEATURE_VI_USE_SIGNALS=y +CONFIG_FEATURE_VI_DOT_CMD=y +CONFIG_FEATURE_VI_READONLY=y +CONFIG_FEATURE_VI_SETOPTS=y +CONFIG_FEATURE_VI_SET=y +CONFIG_FEATURE_VI_WIN_RESIZE=y +CONFIG_FEATURE_VI_ASK_TERMINAL=y +CONFIG_FEATURE_VI_UNDO=y +CONFIG_FEATURE_VI_UNDO_QUEUE=y +CONFIG_FEATURE_VI_UNDO_QUEUE_MAX=256 +CONFIG_FEATURE_ALLOW_EXEC=y + +# +# Finding Utilities +# +CONFIG_FIND=y +CONFIG_FEATURE_FIND_PRINT0=y +CONFIG_FEATURE_FIND_MTIME=y +CONFIG_FEATURE_FIND_MMIN=y +CONFIG_FEATURE_FIND_PERM=y +CONFIG_FEATURE_FIND_TYPE=y +CONFIG_FEATURE_FIND_XDEV=y +CONFIG_FEATURE_FIND_MAXDEPTH=y +CONFIG_FEATURE_FIND_NEWER=y +CONFIG_FEATURE_FIND_INUM=y +CONFIG_FEATURE_FIND_EXEC=y +CONFIG_FEATURE_FIND_EXEC_PLUS=y +CONFIG_FEATURE_FIND_USER=y +CONFIG_FEATURE_FIND_GROUP=y +CONFIG_FEATURE_FIND_NOT=y +CONFIG_FEATURE_FIND_DEPTH=y +CONFIG_FEATURE_FIND_PAREN=y +CONFIG_FEATURE_FIND_SIZE=y +CONFIG_FEATURE_FIND_PRUNE=y +CONFIG_FEATURE_FIND_DELETE=y +CONFIG_FEATURE_FIND_PATH=y +CONFIG_FEATURE_FIND_REGEX=y +# CONFIG_FEATURE_FIND_CONTEXT is not set +CONFIG_FEATURE_FIND_LINKS=y +CONFIG_GREP=y +CONFIG_EGREP=y +CONFIG_FGREP=y +CONFIG_FEATURE_GREP_CONTEXT=y +CONFIG_XARGS=y +CONFIG_FEATURE_XARGS_SUPPORT_CONFIRMATION=y +CONFIG_FEATURE_XARGS_SUPPORT_QUOTES=y +CONFIG_FEATURE_XARGS_SUPPORT_TERMOPT=y +CONFIG_FEATURE_XARGS_SUPPORT_ZERO_TERM=y +CONFIG_FEATURE_XARGS_SUPPORT_REPL_STR=y + +# +# Init Utilities +# +# CONFIG_BOOTCHARTD is not set +# CONFIG_FEATURE_BOOTCHARTD_BLOATED_HEADER is not set +# CONFIG_FEATURE_BOOTCHARTD_CONFIG_FILE is not set +CONFIG_HALT=y +CONFIG_POWEROFF=y +CONFIG_REBOOT=y +# CONFIG_FEATURE_CALL_TELINIT is not set +CONFIG_TELINIT_PATH="" +CONFIG_INIT=y +# CONFIG_LINUXRC is not set +CONFIG_FEATURE_USE_INITTAB=y +# CONFIG_FEATURE_KILL_REMOVED is not set +CONFIG_FEATURE_KILL_DELAY=0 +CONFIG_FEATURE_INIT_SCTTY=y +CONFIG_FEATURE_INIT_SYSLOG=y +CONFIG_FEATURE_INIT_QUIET=y +# CONFIG_FEATURE_INIT_COREDUMPS is not set +CONFIG_INIT_TERMINAL_TYPE="linux" +CONFIG_FEATURE_INIT_MODIFY_CMDLINE=y + +# +# Login/Password Management Utilities +# +CONFIG_FEATURE_SHADOWPASSWDS=y +CONFIG_USE_BB_PWD_GRP=y +CONFIG_USE_BB_SHADOW=y +CONFIG_USE_BB_CRYPT=y +CONFIG_USE_BB_CRYPT_SHA=y +CONFIG_ADD_SHELL=y +CONFIG_REMOVE_SHELL=y +CONFIG_ADDGROUP=y +CONFIG_FEATURE_ADDGROUP_LONG_OPTIONS=y +CONFIG_FEATURE_ADDUSER_TO_GROUP=y +CONFIG_ADDUSER=y +CONFIG_FEATURE_ADDUSER_LONG_OPTIONS=y +# CONFIG_FEATURE_CHECK_NAMES is not set +CONFIG_LAST_ID=60000 +CONFIG_FIRST_SYSTEM_ID=100 +CONFIG_LAST_SYSTEM_ID=999 +CONFIG_CHPASSWD=y +CONFIG_FEATURE_DEFAULT_PASSWD_ALGO="des" +CONFIG_CRYPTPW=y +CONFIG_MKPASSWD=y +CONFIG_DELUSER=y +CONFIG_DELGROUP=y +CONFIG_FEATURE_DEL_USER_FROM_GROUP=y +CONFIG_GETTY=y +CONFIG_LOGIN=y +# CONFIG_LOGIN_SESSION_AS_CHILD is not set +CONFIG_LOGIN_SCRIPTS=y +CONFIG_FEATURE_NOLOGIN=y +# CONFIG_FEATURE_SECURETTY is not set +CONFIG_PASSWD=y +CONFIG_FEATURE_PASSWD_WEAK_CHECK=y +CONFIG_SU=y +CONFIG_FEATURE_SU_SYSLOG=y +CONFIG_FEATURE_SU_CHECKS_SHELLS=y +# CONFIG_FEATURE_SU_BLANK_PW_NEEDS_SECURE_TTY is not set +CONFIG_SULOGIN=y +CONFIG_VLOCK=y + +# +# Linux Ext2 FS Progs +# +CONFIG_CHATTR=y +# CONFIG_FSCK is not set +CONFIG_LSATTR=y +CONFIG_TUNE2FS=y + +# +# Linux Module Utilities +# +# CONFIG_MODPROBE_SMALL is not set +CONFIG_DEPMOD=y +CONFIG_INSMOD=y +CONFIG_LSMOD=y +CONFIG_FEATURE_LSMOD_PRETTY_2_6_OUTPUT=y +CONFIG_MODINFO=y +CONFIG_MODPROBE=y +CONFIG_FEATURE_MODPROBE_BLACKLIST=y +CONFIG_RMMOD=y + +# +# Options common to multiple modutils +# +CONFIG_FEATURE_CMDLINE_MODULE_OPTIONS=y +# CONFIG_FEATURE_MODPROBE_SMALL_CHECK_ALREADY_LOADED is not set +# CONFIG_FEATURE_2_4_MODULES is not set +# CONFIG_FEATURE_INSMOD_VERSION_CHECKING is not set +# CONFIG_FEATURE_INSMOD_KSYMOOPS_SYMBOLS is not set +# CONFIG_FEATURE_INSMOD_LOADINKMEM is not set +# CONFIG_FEATURE_INSMOD_LOAD_MAP is not set +# CONFIG_FEATURE_INSMOD_LOAD_MAP_FULL is not set +CONFIG_FEATURE_CHECK_TAINTED_MODULE=y +# CONFIG_FEATURE_INSMOD_TRY_MMAP is not set +CONFIG_FEATURE_MODUTILS_ALIAS=y +CONFIG_FEATURE_MODUTILS_SYMBOLS=y +CONFIG_DEFAULT_MODULES_DIR="/lib/modules" +CONFIG_DEFAULT_DEPMOD_FILE="modules.dep" + +# +# Linux System Utilities +# +CONFIG_ACPID=y +CONFIG_FEATURE_ACPID_COMPAT=y +CONFIG_BLKDISCARD=y +CONFIG_BLKID=y +# CONFIG_FEATURE_BLKID_TYPE is not set +CONFIG_BLOCKDEV=y +CONFIG_CAL=y +CONFIG_CHRT=y +CONFIG_DMESG=y +CONFIG_FEATURE_DMESG_PRETTY=y +CONFIG_EJECT=y +CONFIG_FEATURE_EJECT_SCSI=y +CONFIG_FALLOCATE=y +CONFIG_FATATTR=y +CONFIG_FBSET=y +CONFIG_FEATURE_FBSET_FANCY=y +CONFIG_FEATURE_FBSET_READMODE=y +CONFIG_FDFORMAT=y +CONFIG_FDISK=y +# CONFIG_FDISK_SUPPORT_LARGE_DISKS is not set +CONFIG_FEATURE_FDISK_WRITABLE=y +# CONFIG_FEATURE_AIX_LABEL is not set +# CONFIG_FEATURE_SGI_LABEL is not set +# CONFIG_FEATURE_SUN_LABEL is not set +# CONFIG_FEATURE_OSF_LABEL is not set +CONFIG_FEATURE_GPT_LABEL=y +CONFIG_FEATURE_FDISK_ADVANCED=y +CONFIG_FINDFS=y +CONFIG_FLOCK=y +CONFIG_FDFLUSH=y +CONFIG_FREERAMDISK=y +# CONFIG_FSCK_MINIX is not set +CONFIG_FSFREEZE=y +CONFIG_FSTRIM=y +CONFIG_GETOPT=y +CONFIG_FEATURE_GETOPT_LONG=y +CONFIG_HEXDUMP=y +CONFIG_FEATURE_HEXDUMP_REVERSE=y +CONFIG_HD=y +CONFIG_XXD=y +CONFIG_HWCLOCK=y +CONFIG_FEATURE_HWCLOCK_LONG_OPTIONS=y +# CONFIG_FEATURE_HWCLOCK_ADJTIME_FHS is not set +CONFIG_IONICE=y +CONFIG_IPCRM=y +CONFIG_IPCS=y +# CONFIG_LAST is not set +# CONFIG_FEATURE_LAST_FANCY is not set +CONFIG_LOSETUP=y +CONFIG_LSPCI=y +CONFIG_LSUSB=y +CONFIG_MDEV=y +CONFIG_FEATURE_MDEV_CONF=y +CONFIG_FEATURE_MDEV_RENAME=y +CONFIG_FEATURE_MDEV_RENAME_REGEXP=y +CONFIG_FEATURE_MDEV_EXEC=y +CONFIG_FEATURE_MDEV_LOAD_FIRMWARE=y +CONFIG_MESG=y +CONFIG_FEATURE_MESG_ENABLE_ONLY_GROUP=y +CONFIG_MKE2FS=y +CONFIG_MKFS_EXT2=y +# CONFIG_MKFS_MINIX is not set +# CONFIG_FEATURE_MINIX2 is not set +# CONFIG_MKFS_REISER is not set +CONFIG_MKDOSFS=y +CONFIG_MKFS_VFAT=y +CONFIG_MKSWAP=y +CONFIG_FEATURE_MKSWAP_UUID=y +CONFIG_MORE=y +CONFIG_MOUNT=y +CONFIG_FEATURE_MOUNT_FAKE=y +CONFIG_FEATURE_MOUNT_VERBOSE=y +# CONFIG_FEATURE_MOUNT_HELPERS is not set +CONFIG_FEATURE_MOUNT_LABEL=y +# CONFIG_FEATURE_MOUNT_NFS is not set +CONFIG_FEATURE_MOUNT_CIFS=y +CONFIG_FEATURE_MOUNT_FLAGS=y +CONFIG_FEATURE_MOUNT_FSTAB=y +CONFIG_FEATURE_MOUNT_OTHERTAB=y +CONFIG_MOUNTPOINT=y +CONFIG_NSENTER=y +CONFIG_FEATURE_NSENTER_LONG_OPTS=y +# CONFIG_PIVOT_ROOT is not set +CONFIG_RDATE=y +CONFIG_RDEV=y +CONFIG_READPROFILE=y +CONFIG_RENICE=y +CONFIG_REV=y +CONFIG_RTCWAKE=y +CONFIG_SCRIPT=y +CONFIG_SCRIPTREPLAY=y +# CONFIG_SETARCH is not set +CONFIG_LINUX32=y +CONFIG_LINUX64=y +CONFIG_SETPRIV=y +CONFIG_SETSID=y +CONFIG_SWAPON=y +CONFIG_FEATURE_SWAPON_DISCARD=y +CONFIG_FEATURE_SWAPON_PRI=y +CONFIG_SWAPOFF=y +CONFIG_SWITCH_ROOT=y +CONFIG_TASKSET=y +CONFIG_FEATURE_TASKSET_FANCY=y +CONFIG_UEVENT=y +CONFIG_UMOUNT=y +CONFIG_FEATURE_UMOUNT_ALL=y +CONFIG_UNSHARE=y +# CONFIG_WALL is not set + +# +# Common options for mount/umount +# +CONFIG_FEATURE_MOUNT_LOOP=y +CONFIG_FEATURE_MOUNT_LOOP_CREATE=y +# CONFIG_FEATURE_MTAB_SUPPORT is not set +CONFIG_VOLUMEID=y + +# +# Filesystem/Volume identification +# +CONFIG_FEATURE_VOLUMEID_BCACHE=y +CONFIG_FEATURE_VOLUMEID_BTRFS=y +CONFIG_FEATURE_VOLUMEID_CRAMFS=y +CONFIG_FEATURE_VOLUMEID_EXFAT=y +CONFIG_FEATURE_VOLUMEID_EXT=y +CONFIG_FEATURE_VOLUMEID_F2FS=y +CONFIG_FEATURE_VOLUMEID_FAT=y +CONFIG_FEATURE_VOLUMEID_HFS=y +CONFIG_FEATURE_VOLUMEID_ISO9660=y +CONFIG_FEATURE_VOLUMEID_JFS=y +CONFIG_FEATURE_VOLUMEID_LINUXRAID=y +CONFIG_FEATURE_VOLUMEID_LINUXSWAP=y +CONFIG_FEATURE_VOLUMEID_LUKS=y +CONFIG_FEATURE_VOLUMEID_NILFS=y +CONFIG_FEATURE_VOLUMEID_NTFS=y +CONFIG_FEATURE_VOLUMEID_OCFS2=y +CONFIG_FEATURE_VOLUMEID_REISERFS=y +CONFIG_FEATURE_VOLUMEID_ROMFS=y +# CONFIG_FEATURE_VOLUMEID_SQUASHFS is not set +CONFIG_FEATURE_VOLUMEID_SYSV=y +CONFIG_FEATURE_VOLUMEID_UBIFS=y +CONFIG_FEATURE_VOLUMEID_UDF=y +CONFIG_FEATURE_VOLUMEID_XFS=y + +# +# Miscellaneous Utilities +# +CONFIG_ADJTIMEX=y +CONFIG_BBCONFIG=y +CONFIG_FEATURE_COMPRESS_BBCONFIG=y +CONFIG_BEEP=y +CONFIG_FEATURE_BEEP_FREQ=4000 +CONFIG_FEATURE_BEEP_LENGTH_MS=30 +CONFIG_CHAT=y +CONFIG_FEATURE_CHAT_NOFAIL=y +# CONFIG_FEATURE_CHAT_TTY_HIFI is not set +CONFIG_FEATURE_CHAT_IMPLICIT_CR=y +CONFIG_FEATURE_CHAT_SWALLOW_OPTS=y +CONFIG_FEATURE_CHAT_SEND_ESCAPES=y +CONFIG_FEATURE_CHAT_VAR_ABORT_LEN=y +CONFIG_FEATURE_CHAT_CLR_ABORT=y +CONFIG_CONSPY=y +CONFIG_CROND=y +CONFIG_FEATURE_CROND_D=y +CONFIG_FEATURE_CROND_CALL_SENDMAIL=y +CONFIG_FEATURE_CROND_DIR="/var/spool/cron" +CONFIG_CRONTAB=y +CONFIG_DC=y +CONFIG_FEATURE_DC_LIBM=y +# CONFIG_DEVFSD is not set +# CONFIG_DEVFSD_MODLOAD is not set +# CONFIG_DEVFSD_FG_NP is not set +# CONFIG_DEVFSD_VERBOSE is not set +# CONFIG_FEATURE_DEVFS is not set +CONFIG_DEVMEM=y +# CONFIG_FBSPLASH is not set +# CONFIG_FLASH_ERASEALL is not set +# CONFIG_FLASH_LOCK is not set +# CONFIG_FLASH_UNLOCK is not set +# CONFIG_FLASHCP is not set +# CONFIG_HDPARM is not set +# CONFIG_FEATURE_HDPARM_GET_IDENTITY is not set +# CONFIG_FEATURE_HDPARM_HDIO_SCAN_HWIF is not set +# CONFIG_FEATURE_HDPARM_HDIO_UNREGISTER_HWIF is not set +# CONFIG_FEATURE_HDPARM_HDIO_DRIVE_RESET is not set +# CONFIG_FEATURE_HDPARM_HDIO_TRISTATE_HWIF is not set +# CONFIG_FEATURE_HDPARM_HDIO_GETSET_DMA is not set +CONFIG_I2CGET=y +CONFIG_I2CSET=y +CONFIG_I2CDUMP=y +CONFIG_I2CDETECT=y +CONFIG_INOTIFYD=y +CONFIG_LESS=y +CONFIG_FEATURE_LESS_MAXLINES=9999999 +CONFIG_FEATURE_LESS_BRACKETS=y +CONFIG_FEATURE_LESS_FLAGS=y +CONFIG_FEATURE_LESS_TRUNCATE=y +CONFIG_FEATURE_LESS_MARKS=y +CONFIG_FEATURE_LESS_REGEXP=y +CONFIG_FEATURE_LESS_WINCH=y +CONFIG_FEATURE_LESS_ASK_TERMINAL=y +CONFIG_FEATURE_LESS_DASHCMD=y +CONFIG_FEATURE_LESS_LINENUMS=y +CONFIG_LSSCSI=y +CONFIG_MAKEDEVS=y +# CONFIG_FEATURE_MAKEDEVS_LEAF is not set +CONFIG_FEATURE_MAKEDEVS_TABLE=y +CONFIG_MAN=y +CONFIG_MICROCOM=y +# CONFIG_MT is not set +# CONFIG_NANDWRITE is not set +# CONFIG_NANDDUMP is not set +CONFIG_PARTPROBE=y +CONFIG_RAIDAUTORUN=y +CONFIG_READAHEAD=y +# CONFIG_RFKILL is not set +# CONFIG_RUNLEVEL is not set +CONFIG_RX=y +CONFIG_SETSERIAL=y +CONFIG_STRINGS=y +CONFIG_TIME=y +CONFIG_TTYSIZE=y +# CONFIG_UBIATTACH is not set +# CONFIG_UBIDETACH is not set +CONFIG_UBIMKVOL=y +CONFIG_UBIRMVOL=y +CONFIG_UBIRSVOL=y +CONFIG_UBIUPDATEVOL=y +CONFIG_UBIRENAME=y +CONFIG_VOLNAME=y +CONFIG_WATCHDOG=y + +# +# Networking Utilities +# +CONFIG_FEATURE_IPV6=y +# CONFIG_FEATURE_UNIX_LOCAL is not set +CONFIG_FEATURE_PREFER_IPV4_ADDRESS=y +CONFIG_VERBOSE_RESOLUTION_ERRORS=y +# CONFIG_ARP is not set +# CONFIG_ARPING is not set +CONFIG_BRCTL=y +CONFIG_FEATURE_BRCTL_FANCY=y +CONFIG_FEATURE_BRCTL_SHOW=y +# CONFIG_DNSD is not set +# CONFIG_ETHER_WAKE is not set +CONFIG_FTPD=y +CONFIG_FEATURE_FTPD_WRITE=y +CONFIG_FEATURE_FTPD_ACCEPT_BROKEN_LIST=y +CONFIG_FEATURE_FTPD_AUTHENTICATION=y +CONFIG_FTPGET=y +CONFIG_FTPPUT=y +CONFIG_FEATURE_FTPGETPUT_LONG_OPTIONS=y +CONFIG_HOSTNAME=y +CONFIG_DNSDOMAINNAME=y +# CONFIG_HTTPD is not set +# CONFIG_FEATURE_HTTPD_RANGES is not set +# CONFIG_FEATURE_HTTPD_SETUID is not set +# CONFIG_FEATURE_HTTPD_BASIC_AUTH is not set +# CONFIG_FEATURE_HTTPD_AUTH_MD5 is not set +# CONFIG_FEATURE_HTTPD_CGI is not set +# CONFIG_FEATURE_HTTPD_CONFIG_WITH_SCRIPT_INTERPR is not set +# CONFIG_FEATURE_HTTPD_SET_REMOTE_PORT_TO_ENV is not set +# CONFIG_FEATURE_HTTPD_ENCODE_URL_STR is not set +# CONFIG_FEATURE_HTTPD_ERROR_PAGES is not set +# CONFIG_FEATURE_HTTPD_PROXY is not set +# CONFIG_FEATURE_HTTPD_GZIP is not set +CONFIG_IFCONFIG=y +CONFIG_FEATURE_IFCONFIG_STATUS=y +CONFIG_FEATURE_IFCONFIG_SLIP=y +CONFIG_FEATURE_IFCONFIG_MEMSTART_IOADDR_IRQ=y +CONFIG_FEATURE_IFCONFIG_HW=y +CONFIG_FEATURE_IFCONFIG_BROADCAST_PLUS=y +CONFIG_IFENSLAVE=y +# CONFIG_IFPLUGD is not set +CONFIG_IFUP=y +CONFIG_IFDOWN=y +CONFIG_IFUPDOWN_IFSTATE_PATH="" +# CONFIG_FEATURE_IFUPDOWN_IP is not set +# CONFIG_FEATURE_IFUPDOWN_IPV4 is not set +# CONFIG_FEATURE_IFUPDOWN_IPV6 is not set +# CONFIG_FEATURE_IFUPDOWN_MAPPING is not set +# CONFIG_FEATURE_IFUPDOWN_EXTERNAL_DHCP is not set +CONFIG_INETD=y +CONFIG_FEATURE_INETD_SUPPORT_BUILTIN_ECHO=y +CONFIG_FEATURE_INETD_SUPPORT_BUILTIN_DISCARD=y +CONFIG_FEATURE_INETD_SUPPORT_BUILTIN_TIME=y +CONFIG_FEATURE_INETD_SUPPORT_BUILTIN_DAYTIME=y +CONFIG_FEATURE_INETD_SUPPORT_BUILTIN_CHARGEN=y +# CONFIG_FEATURE_INETD_RPC is not set +CONFIG_IP=y +CONFIG_IPADDR=y +CONFIG_IPLINK=y +CONFIG_IPROUTE=y +CONFIG_IPTUNNEL=y +CONFIG_IPRULE=y +CONFIG_IPNEIGH=y +CONFIG_FEATURE_IP_ADDRESS=y +CONFIG_FEATURE_IP_LINK=y +CONFIG_FEATURE_IP_ROUTE=y +CONFIG_FEATURE_IP_ROUTE_DIR="/etc/iproute2" +CONFIG_FEATURE_IP_TUNNEL=y +CONFIG_FEATURE_IP_RULE=y +CONFIG_FEATURE_IP_NEIGH=y +# CONFIG_FEATURE_IP_RARE_PROTOCOLS is not set +CONFIG_IPCALC=y +CONFIG_FEATURE_IPCALC_LONG_OPTIONS=y +CONFIG_FEATURE_IPCALC_FANCY=y +CONFIG_FAKEIDENTD=y +# CONFIG_NAMEIF is not set +# CONFIG_FEATURE_NAMEIF_EXTENDED is not set +CONFIG_NBDCLIENT=y +CONFIG_NC=y +CONFIG_NC_SERVER=y +CONFIG_NC_EXTRA=y +# CONFIG_NC_110_COMPAT is not set +CONFIG_NETSTAT=y +CONFIG_FEATURE_NETSTAT_WIDE=y +CONFIG_FEATURE_NETSTAT_PRG=y +CONFIG_NSLOOKUP=y +CONFIG_NTPD=y +CONFIG_FEATURE_NTPD_SERVER=y +CONFIG_FEATURE_NTPD_CONF=y +CONFIG_PING=y +CONFIG_PING6=y +CONFIG_FEATURE_FANCY_PING=y +CONFIG_PSCAN=y +CONFIG_ROUTE=y +CONFIG_SLATTACH=y +CONFIG_SSL_CLIENT=y +CONFIG_TCPSVD=y +CONFIG_UDPSVD=y +CONFIG_TELNET=y +CONFIG_FEATURE_TELNET_TTYPE=y +CONFIG_FEATURE_TELNET_AUTOLOGIN=y +CONFIG_FEATURE_TELNET_WIDTH=y +CONFIG_TELNETD=y +CONFIG_FEATURE_TELNETD_STANDALONE=y +CONFIG_FEATURE_TELNETD_INETD_WAIT=y +CONFIG_TFTP=y +# CONFIG_TFTPD is not set + +# +# Common options for tftp/tftpd +# +CONFIG_FEATURE_TFTP_GET=y +CONFIG_FEATURE_TFTP_PUT=y +CONFIG_FEATURE_TFTP_BLOCKSIZE=y +CONFIG_FEATURE_TFTP_PROGRESS_BAR=y +# CONFIG_TFTP_DEBUG is not set +CONFIG_TLS=y +CONFIG_TRACEROUTE=y +CONFIG_TRACEROUTE6=y +CONFIG_FEATURE_TRACEROUTE_VERBOSE=y +CONFIG_FEATURE_TRACEROUTE_USE_ICMP=y +CONFIG_TUNCTL=y +CONFIG_FEATURE_TUNCTL_UG=y +CONFIG_VCONFIG=y +CONFIG_WGET=y +CONFIG_FEATURE_WGET_LONG_OPTIONS=y +CONFIG_FEATURE_WGET_STATUSBAR=y +CONFIG_FEATURE_WGET_AUTHENTICATION=y +CONFIG_FEATURE_WGET_TIMEOUT=y +CONFIG_FEATURE_WGET_HTTPS=y +CONFIG_FEATURE_WGET_OPENSSL=y +CONFIG_WHOIS=y +# CONFIG_ZCIP is not set +# CONFIG_UDHCPC6 is not set +# CONFIG_FEATURE_UDHCPC6_RFC3646 is not set +# CONFIG_FEATURE_UDHCPC6_RFC4704 is not set +# CONFIG_FEATURE_UDHCPC6_RFC4833 is not set +CONFIG_UDHCPD=y +CONFIG_FEATURE_UDHCPD_WRITE_LEASES_EARLY=y +# CONFIG_FEATURE_UDHCPD_BASE_IP_ON_MAC is not set +CONFIG_DHCPD_LEASES_FILE="/var/lib/misc/udhcpd.leases" +CONFIG_DUMPLEASES=y +# CONFIG_DHCPRELAY is not set +CONFIG_UDHCPC=y +CONFIG_FEATURE_UDHCPC_ARPING=y +CONFIG_FEATURE_UDHCPC_SANITIZEOPT=y +CONFIG_UDHCPC_DEFAULT_SCRIPT="/usr/share/udhcpc/default.script" +# CONFIG_FEATURE_UDHCP_PORT is not set +CONFIG_UDHCP_DEBUG=9 +CONFIG_FEATURE_UDHCP_RFC3397=y +CONFIG_FEATURE_UDHCP_8021Q=y +CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS=80 +CONFIG_IFUPDOWN_UDHCPC_CMD_OPTIONS="-R -n" + +# +# Print Utilities +# +CONFIG_LPD=y +CONFIG_LPR=y +CONFIG_LPQ=y + +# +# Mail Utilities +# +CONFIG_MAKEMIME=y +CONFIG_POPMAILDIR=y +CONFIG_FEATURE_POPMAILDIR_DELIVERY=y +CONFIG_REFORMIME=y +CONFIG_FEATURE_REFORMIME_COMPAT=y +CONFIG_SENDMAIL=y +CONFIG_FEATURE_MIME_CHARSET="us-ascii" + +# +# Process Utilities +# +CONFIG_FREE=y +CONFIG_FUSER=y +CONFIG_IOSTAT=y +CONFIG_KILL=y +CONFIG_KILLALL=y +CONFIG_KILLALL5=y +CONFIG_LSOF=y +CONFIG_MPSTAT=y +CONFIG_NMETER=y +CONFIG_PGREP=y +CONFIG_PKILL=y +CONFIG_PIDOF=y +CONFIG_FEATURE_PIDOF_SINGLE=y +CONFIG_FEATURE_PIDOF_OMIT=y +CONFIG_PMAP=y +CONFIG_POWERTOP=y +CONFIG_FEATURE_POWERTOP_INTERACTIVE=y +CONFIG_PS=y +# CONFIG_FEATURE_PS_WIDE is not set +# CONFIG_FEATURE_PS_LONG is not set +CONFIG_FEATURE_PS_TIME=y +# CONFIG_FEATURE_PS_UNUSUAL_SYSTEMS is not set +CONFIG_FEATURE_PS_ADDITIONAL_COLUMNS=y +CONFIG_PSTREE=y +CONFIG_PWDX=y +CONFIG_SMEMCAP=y +CONFIG_BB_SYSCTL=y +CONFIG_TOP=y +CONFIG_FEATURE_TOP_INTERACTIVE=y +CONFIG_FEATURE_TOP_CPU_USAGE_PERCENTAGE=y +CONFIG_FEATURE_TOP_CPU_GLOBAL_PERCENTS=y +CONFIG_FEATURE_TOP_SMP_CPU=y +CONFIG_FEATURE_TOP_DECIMALS=y +CONFIG_FEATURE_TOP_SMP_PROCESS=y +CONFIG_FEATURE_TOPMEM=y +CONFIG_UPTIME=y +# CONFIG_FEATURE_UPTIME_UTMP_SUPPORT is not set +CONFIG_WATCH=y +CONFIG_FEATURE_SHOW_THREADS=y + +# +# Runit Utilities +# +CONFIG_CHPST=y +CONFIG_SETUIDGID=y +CONFIG_ENVUIDGID=y +CONFIG_ENVDIR=y +CONFIG_SOFTLIMIT=y +CONFIG_RUNSV=y +CONFIG_RUNSVDIR=y +# CONFIG_FEATURE_RUNSVDIR_LOG is not set +CONFIG_SV=y +CONFIG_SV_DEFAULT_SERVICE_DIR="/var/service" +CONFIG_SVC=y +CONFIG_SVLOGD=y +# CONFIG_CHCON is not set +# CONFIG_FEATURE_CHCON_LONG_OPTIONS is not set +# CONFIG_GETENFORCE is not set +# CONFIG_GETSEBOOL is not set +# CONFIG_LOAD_POLICY is not set +# CONFIG_MATCHPATHCON is not set +# CONFIG_RUNCON is not set +# CONFIG_FEATURE_RUNCON_LONG_OPTIONS is not set +# CONFIG_SELINUXENABLED is not set +# CONFIG_SESTATUS is not set +# CONFIG_SETENFORCE is not set +# CONFIG_SETFILES is not set +# CONFIG_FEATURE_SETFILES_CHECK_OPTION is not set +# CONFIG_RESTORECON is not set +# CONFIG_SETSEBOOL is not set + +# +# Shells +# +CONFIG_SH_IS_ASH=y +# CONFIG_SH_IS_HUSH is not set +# CONFIG_SH_IS_NONE is not set +# CONFIG_BASH_IS_ASH is not set +# CONFIG_BASH_IS_HUSH is not set +CONFIG_BASH_IS_NONE=y +CONFIG_ASH=y +CONFIG_ASH_OPTIMIZE_FOR_SIZE=y +CONFIG_ASH_INTERNAL_GLOB=y +CONFIG_ASH_BASH_COMPAT=y +CONFIG_ASH_JOB_CONTROL=y +CONFIG_ASH_ALIAS=y +CONFIG_ASH_RANDOM_SUPPORT=y +CONFIG_ASH_EXPAND_PRMT=y +# CONFIG_ASH_IDLE_TIMEOUT is not set +# CONFIG_ASH_MAIL is not set +CONFIG_ASH_ECHO=y +CONFIG_ASH_PRINTF=y +CONFIG_ASH_TEST=y +CONFIG_ASH_HELP=y +CONFIG_ASH_GETOPTS=y +CONFIG_ASH_CMDCMD=y +CONFIG_CTTYHACK=y +# CONFIG_HUSH is not set +# CONFIG_HUSH_BASH_COMPAT is not set +# CONFIG_HUSH_BRACE_EXPANSION is not set +# CONFIG_HUSH_INTERACTIVE is not set +# CONFIG_HUSH_SAVEHISTORY is not set +# CONFIG_HUSH_JOB is not set +# CONFIG_HUSH_TICK is not set +# CONFIG_HUSH_IF is not set +# CONFIG_HUSH_LOOPS is not set +# CONFIG_HUSH_CASE is not set +# CONFIG_HUSH_FUNCTIONS is not set +# CONFIG_HUSH_LOCAL is not set +# CONFIG_HUSH_RANDOM_SUPPORT is not set +# CONFIG_HUSH_MODE_X is not set +# CONFIG_HUSH_ECHO is not set +# CONFIG_HUSH_PRINTF is not set +# CONFIG_HUSH_TEST is not set +# CONFIG_HUSH_HELP is not set +# CONFIG_HUSH_EXPORT is not set +# CONFIG_HUSH_EXPORT_N is not set +# CONFIG_HUSH_KILL is not set +# CONFIG_HUSH_WAIT is not set +# CONFIG_HUSH_TRAP is not set +# CONFIG_HUSH_TYPE is not set +# CONFIG_HUSH_READ is not set +# CONFIG_HUSH_SET is not set +# CONFIG_HUSH_UNSET is not set +# CONFIG_HUSH_ULIMIT is not set +# CONFIG_HUSH_UMASK is not set +# CONFIG_HUSH_MEMLEAK is not set +# CONFIG_MSH is not set + +# +# Options common to all shells +# +CONFIG_FEATURE_SH_MATH=y +CONFIG_FEATURE_SH_MATH_64=y +CONFIG_FEATURE_SH_EXTRA_QUIET=y +# CONFIG_FEATURE_SH_STANDALONE is not set +# CONFIG_FEATURE_SH_NOFORK is not set +CONFIG_FEATURE_SH_HISTFILESIZE=y + +# +# System Logging Utilities +# +# CONFIG_KLOGD is not set +# CONFIG_FEATURE_KLOGD_KLOGCTL is not set +# CONFIG_LOGGER is not set +# CONFIG_LOGREAD is not set +# CONFIG_FEATURE_LOGREAD_REDUCED_LOCKING is not set +# CONFIG_SYSLOGD is not set +# CONFIG_FEATURE_ROTATE_LOGFILE is not set +# CONFIG_FEATURE_REMOTE_LOG is not set +# CONFIG_FEATURE_SYSLOGD_DUP is not set +# CONFIG_FEATURE_SYSLOGD_CFG is not set +CONFIG_FEATURE_SYSLOGD_READ_BUFFER_SIZE=0 +# CONFIG_FEATURE_IPC_SYSLOG is not set +CONFIG_FEATURE_IPC_SYSLOG_BUFFER_SIZE=0 +# CONFIG_FEATURE_KMSG_SYSLOG is not set diff --git a/base/busybox/dhclient b/base/busybox/dhclient new file mode 100755 index 0000000..f1c64e3 --- /dev/null +++ b/base/busybox/dhclient @@ -0,0 +1,11 @@ +#!/bin/sh +if [ -z "$1" ] ; then + echo usage: $0 [interface] + echo i.e. $0 eth0 + echo i.e. $0 wlan0 + exit 1 +fi +interface="$1" +retries=3 +/bin/udhcpc -t $retries -n -i "$interface" -s /etc/udhcpc-script -x hostname=$(hostname) + diff --git a/base/busybox/runit-man/chpst.8 b/base/busybox/runit-man/chpst.8 new file mode 100644 index 0000000..43c0b8d --- /dev/null +++ b/base/busybox/runit-man/chpst.8 @@ -0,0 +1,265 @@ +.TH chpst 8 +.SH NAME +chpst \- runs a program with a changed process state +.SH SYNOPSIS +.B chpst +[\-vP012] +[\-u +.IR user ] +[\-U +.IR user ] +[\-b +.IR argv0 ] +[-e +.IR dir ] +[\-/ +.IR root ] +[\-n +.IR inc ] +[-l|-L +.IR lock ] +[-m +.IR bytes ] +[-d +.IR bytes ] +[-o +.IR n ] +[-p +.IR n ] +[-f +.IR bytes ] +[-c +.IR bytes ] +.I prog +.SH DESCRIPTION +.I prog +consists of one or more arguments. +.P +.B chpst +changes the process state according to the given options, and runs +.IR prog . +.SH OPTIONS +.TP +.B \-u \fI[:]user[:group] +setuidgid. +Set uid and gid to the +.IR user 's +uid and gid, as found in +.IR /etc/passwd . +If +.I user +is followed by a colon and a +.IR group , +set the gid to +.IR group 's +gid, as found in +.IR /etc/group , +instead of +.IR user 's +gid. +If +.I group +consists of a colon-separated list of group names, +.B chpst +sets the group ids of all listed groups. +If +.I user +is prefixed with a colon, the +.I user +and all +.I group +arguments are interpreted as uid and gids respectivly, and not looked up in +the password or group file. +All initial supplementary groups are removed. +.TP +.B \-U \fI[:]user[:group] +envuidgid. +Set the environment variables $UID and $GID to the +.IR user 's +uid and gid, as found in +.IR /etc/passwd . +If +.I user +is followed by a colon and a +.IR group , +set $GID to the +.IR group 's +gid, as found in +.IR /etc/group , +instead of +.IR user 's +gid. +If +.I user +is prefixed with a colon, the +.I user +and +.I group +arguments are interpreted as uid and gid respectivly, and not looked up in +the password or group file. +.TP +.B \-b \fIargv0 +argv0. +Run +.I prog +with +.I argv0 +as the 0th argument. +.TP +.B \-e \fIdir +envdir. +Set various environment variables as specified by files in the directory +.IR dir : +If +.I dir +contains a file named +.I k +whose first line is +.IR v , +.B chpst +removes the environment variable +.I k +if it exists, and then adds the environment variable +.I k +with the value +.IR v . +The name +.I k +must not contain =. +Spaces and tabs at the end of +.I v +are removed, and nulls in +.I v +are changed to newlines. +If the file +.I k +is empty (0 bytes long), +.B chpst +removes the environment variable +.I k +if it exists, without adding a new variable. +.TP +.B \-/ \fIroot +chroot. +Change the root directory to +.I root +before starting +.IR prog . +.TP +.B \-n \fIinc +nice. +Add +.I inc +to the +.BR nice (2) +value before starting +.IR prog . +.I inc +must be an integer, and may start with a minus or plus. +.TP +.B \-l \fIlock +lock. +Open the file +.I lock +for writing, and obtain an exclusive lock on it. +.I lock +will be created if it does not exist. +If +.I lock +is locked by another process, wait until a new lock can be obtained. +.TP +.B \-L \fIlock +The same as \-l, but fail immediately if +.I lock +is locked by another process. +.TP +.B \-m \fIbytes +limit memory. +Limit the data segment, stack segment, locked physical pages, and total of +all segment per process to +.I bytes +bytes each. +.TP +.B \-d \fIbytes +limit data segment. +Limit the data segment per process to +.I bytes +bytes. +.TP +.B \-o \fIn +limit open files. +Limit the number of open file descriptors per process to +.IR n . +.TP +.B \-p \fIn +limit processes. +Limit the number of processes per uid to +.IR n . +.TP +.B \-f \fIbytes +limit output size. +Limit the output file size to +.I bytes +bytes. +.TP +.B \-c \fIbytes +limit core size. +Limit the core file size to +.I bytes +bytes. +.TP +.B \-v +verbose. +Print verbose messages to standard error. +This includes warnings about limits unsupported by the system. +.TP +.B \-P +pgrphack. +Run +.I prog +in a new process group. +.TP +.B \-0 +Close standard input before starting +.IR prog . +.TP +.B \-1 +Close standard output before starting +.IR prog . +.TP +.B \-2 +Close standard error before starting +.IR prog . +.SH EXIT CODES +.B chpst +exits 100 when called with wrong options. +It prints an error message and exits 111 if it has trouble changing the +process state. +Otherwise its exit code is the same as that of +.IR prog . +.SH EMULATION +If +.B chpst +is called as +.BR envdir , +.BR envuidgid , +.BR pgrphack , +.BR setlock , +.BR setuidgid , +or +.BR softlimit , +it emulates the functionality of these programs from the daemontools package +respectively. +.SH SEE ALSO +sv(8), +runsv(8), +setsid(2), +runit(8), +runit-init(8), +runsvdir(8), +runsvchdir(8) +.P + http://smarden.org/runit/ + http://cr.yp.to/daemontools.html +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/runit-init.8 b/base/busybox/runit-man/runit-init.8 new file mode 100644 index 0000000..4ea33c2 --- /dev/null +++ b/base/busybox/runit-man/runit-init.8 @@ -0,0 +1,63 @@ +.TH runit-init 8 +.SH NAME +init \- a UNIX process no 1 +.SH SYNOPSIS +.B init +[ 0 | 6 ] +.SH DESCRIPTION +.B runit-init +is the first process the kernel starts. +If +.B runit-init +is started as process no 1, it runs and replaces itself with +.BR runit (8). +.P +If +.B runit-init +is started while the system is up, it must be either called as +.B init 0 +or +.B init 6\fR: +.TP +.B init 0 +tells the Unix process no 1 to shutdown and halt the system. +To signal +.BR runit (8) +the system halt request, +.B runit-init +removes all permissions of the file +.I /etc/runit/reboot +(chmod 0), and sets the execute by owner permission of the file +.I /etc/runit/stopit +(chmod 100). +Then a CONT signal is sent to +.BR runit (8). +.TP +.B init 6 +tells the Unix process no 1 to shutdown and reboot the system. +To signal +.BR runit (8) +the system reboot request, +.B runit-init +sets the execute by owner permission of the files +.I /etc/runit/reboot +and +.I /etc/runit/stopit +(chmod 100). Then a CONT signal is sent to +.BR runit (8). +.SH EXIT CODES +.B runit-init +returns 111 on error, 0 in all other cases. +.SH SEE ALSO +runit(8), +runsvdir(8), +runsvchdir(8), +sv(8), +runsv(8), +chpst(8), +utmpset(8), +svlogd(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/runit.8 b/base/busybox/runit-man/runit.8 new file mode 100644 index 0000000..a53cf6e --- /dev/null +++ b/base/busybox/runit-man/runit.8 @@ -0,0 +1,88 @@ +.TH runit 8 +.SH NAME +runit \- a UNIX process no 1 +.SH SYNOPSIS +.B runit +.SH DESCRIPTION +.B runit +must be run as Unix process no 1. +It performs the system's booting, running, and shutdown in three stages: +.SH STAGE 1 +.B runit +runs +.I /etc/runit/1 +and waits for it to terminate. +The system's one time tasks are done here. +.I /etc/runit/1 +has full control of +.I /dev/console +to be able to start an emergency shell if the one time initialization tasks +fail. If +.I /etc/runit/1 +crashes, or exits 100, +.B runit +will skip stage 2 and enter stage 3. +.SH STAGE 2 +.B runit +runs +.IR /etc/runit/2 , +which should not return until system shutdown; if it crashes, or exits 111, +it will be restarted. +Normally +.I /etc/runit/2 +starts +.BR runsvdir (8). +.B runit +is able to handle the ctrl-alt-del keyboard request in stage 2, see below. +.SH STAGE 3 +If +.B runit +is told to shutdown the system, or stage 2 returns, it terminates stage 2 if +it is running, and runs +.IR /etc/runit/3 . +The systems tasks to shutdown and possibly halt or reboot the system are +done here. +If stage 3 returns, +.B runit +checks if the file +.I /etc/runit/reboot +exists and has the execute by owner permission set. +If so, the system is rebooted, it's halted otherwise. +.SH CTRL-ALT-DEL +If +.B runit +receives the ctrl-alt-del keyboard request and the file +.I /etc/runit/ctrlaltdel +exists and has the execute by owner permission set, +.B runit +runs +.IR /etc/runit/ctrlaltdel , +waits for it to terminate, and then sends itself a CONT signal. +.SH SIGNALS +.B runit +only accepts signals in stage 2. +.P +If +.B runit +receives a CONT signal and the file +.I /etc/runit/stopit +exists and has the execute by owner permission set, +.B runit +is told to shutdown the system. +.P +if +.B runit +receives an INT signal, a ctrl-alt-del keyboard request is triggered. +.SH SEE ALSO +runit-init(8), +runsvdir(8), +runsvchdir(8), +sv(8), +runsv(8), +chpst(8), +utmpset(8), +svlogd(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/runsv.8 b/base/busybox/runit-man/runsv.8 new file mode 100644 index 0000000..7c5abfc --- /dev/null +++ b/base/busybox/runit-man/runsv.8 @@ -0,0 +1,225 @@ +.TH runsv 8 +.SH NAME +runsv \- starts and monitors a service and optionally an appendant log +service +.SH SYNOPSIS +.B runsv +.I service +.SH DESCRIPTION +.I service +must be a directory. +.P +.B runsv +switches to the directory +.I service +and starts ./run. +If ./run exits and ./finish exists, +.B runsv +starts ./finish. +If ./finish doesn't exist or ./finish exits, +.B runsv +restarts ./run. +.P +If ./run or ./finish exit immediately, +.B runsv +waits a second before starting ./finish or restarting ./run. +.P +Two arguments are given to ./finish. +The first one is ./run's exit code, or -1 if ./run didn't exit normally. +The second one is the least significant byte of the exit status as +determined by +.BR waitpid (2); +for instance it is 0 if ./run exited normally, and the signal number +if ./run was terminated by a signal. +If +.B runsv +cannot start ./run for some reason, the exit code is 111 and the status is 0. +.P +If the file +.IR service /down +exists, +.B runsv +does not start ./run immediately. +The control interface (see below) can be used to start the service and to +give other commands to +.BR runsv . +.P +If the directory +.IR service /log +exists, +.B runsv +creates a pipe, redirects +.IR service /run's +and +.IR service /finish's +standard output to the pipe, switches to the directory +.IR service /log +and starts ./run (and ./finish) exactly as described above for the +.I service +directory. +The standard input of the log service is redirected to read from the pipe. +.P +.B runsv +maintains status information in a binary format (compatible to the +daemontools' +.B supervise +program) in +.IR service /supervise/status +and +.IR service /log/supervise/status, +and in a human-readable format in +.IR service /supervise/stat, +.IR service /log/supervise/stat, +.IR service /supervise/pid, +.IR service /log/supervise/pid. +.SH CONTROL +The named pipes +.IR service /supervise/control, +and (optionally) +.IR service /log/supervise/control +are provided to give commands to +.BR runsv . +You can use +.BR sv (8) +to control the service or just write one of the following characters to +the named pipe: +.TP +.B u +Up. +If the service is not running, start it. +If the service stops, restart it. +.TP +.B d +Down. +If the service is running, send it a TERM signal, and then a CONT signal. +If ./run exits, start ./finish if it exists. +After it stops, do not restart service. +.TP +.B o +Once. +If the service is not running, start it. +Do not restart it if it stops. +.TP +.B p +Pause. +If the service is running, send it a STOP signal. +.TP +.B c +Continue. +If the service is running, send it a CONT signal. +.TP +.B h +Hangup. +If the service is running, send it a HUP signal. +.TP +.B a +Alarm. +If the service is running, send it a ALRM signal. +.TP +.B i +Interrupt. +If the service is running, send it a INT signal. +.TP +.B q +Quit. +If the service is running, send it a QUIT signal. +.TP +.B 1 +User-defined 1. +If the service is running, send it a USR1 signal. +.TP +.B 2 +User-defined 2. +If the service is running, send it a USR2 signal. +.TP +.B t +Terminate. +If the service is running, send it a TERM signal. +.TP +.B k +Kill. +If the service is running, send it a KILL signal. +.TP +.B x +Exit. +If the service is running, send it a TERM signal, and then a CONT signal. +Do not restart the service. +If the service is down, and no log service exists, +.B runsv +exits. +If the service is down and a log service exists, +.B runsv +closes the standard input of the log service, and waits for it to terminate. +If the log service is down, +.B runsv +exits. +This command is ignored if it is given to +.IR service /log/supervise/control. +.P +Example: to send a TERM signal to the socklog-unix service, either do + # sv term /service/socklog-unix + or + # printf t >/service/socklog-unix/supervise/control +.P +.BR printf (1) +usually blocks if no +.B runsv +process is running in the service directory. +.SH CUSTOMIZE CONTROL +For each control character +.I c +sent to the control pipe, +.B runsv +first checks if +.I service\fR/control/\fIc +exists and is executable. +If so, it starts +.I service\fR/control/\fIc +and waits for it to terminate, before interpreting the command. +If the program exits with return code 0, +.B runsv +refrains from sending the service the corresponding signal. +The command +.I o +is always considered as command +.IR u . +On command +.I d +first +.I service\fR/control/t +is checked, and then +.I service\fR/control/d. +On command +.I x +first +.I service\fR/control/t +is checked, and then +.I service\fR/control/x. +The control of the optional log service cannot be customized. +.SH SIGNALS +If +.B runsv +receives a TERM signal, it acts as if the character x was written to the +control pipe. +.SH EXIT CODES +.B runsv +exits 111 on an error on startup or if another +.B runsv +is running in +.IR service . +.P +.B runsv +exits 0 if it was told to exit. +.SH SEE ALSO +sv(8), +chpst(8), +svlogd(8), +runit(8), +runit-init(8), +runsvdir(8), +runsvchdir(8), +utmpset(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/runsvchdir.8 b/base/busybox/runit-man/runsvchdir.8 new file mode 100644 index 0000000..f7f94dc --- /dev/null +++ b/base/busybox/runit-man/runsvchdir.8 @@ -0,0 +1,55 @@ +.TH runsvchdir 8 +.SH NAME +runsvchdir \- change services directory of runsvdir(8) +.SH SYNOPSIS +.B runsvchdir +.I dir +.SH DESCRIPTION +.I dir +is a services directory for the use with +.BR runsvdir (8). +If +.I dir +does not start with a slash, it is searched in /etc/runit/runsvdir/. +.I dir +must not start with a dot. +.P +.B runsvchdir +switches to the directory +.IR /etc/runit/runsvdir/ , +copies +.I current +to +.IR previous , +and replaces +.I current +with a symlink pointing to +.IR dir . +.P +Normally +.I /service +is a symlink to +.IR current , +and +.BR runsvdir (8) +is running +.IR /service/ . +.SH EXIT CODES +.B runsvchdir +prints an error message and exits 111 on error. +.B runsvchdir +exits 0 on success. +.SH FILES + /etc/runit/runsvdir/previous + /etc/runit/runsvdir/current + /etc/runit/runsvdir/current.new +.SH SEE ALSO +runsvdir(8), +runit(8), +runit-init(8), +sv(8), +runsv(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/runsvdir.8 b/base/busybox/runit-man/runsvdir.8 new file mode 100644 index 0000000..adfa587 --- /dev/null +++ b/base/busybox/runit-man/runsvdir.8 @@ -0,0 +1,102 @@ +.TH runsvdir 8 +.SH NAME +runsvdir \- starts and monitors a collection of runsv(8) processes +.SH SYNOPSIS +.B runsvdir +[\-P] +.I dir +[ +.I log +] +.SH DESCRIPTION +.I dir +must be a directory. +.I log +is a space holder for a readproctitle log, and must be at least seven +characters long or absent. +.P +.B runsvdir +starts a +.BR runsv (8) +process for each subdirectory, or symlink to a directory, in the services +directory +.IR dir , +up to a limit of 1000 subdirectories, +and restarts a +.BR runsv (8) +process if it terminates. +.B runsvdir +skips subdirectory names starting with dots. +.BR runsv (8) +must be in +.BR runsvdir 's +PATH. +.P +At least every five seconds +.B runsvdir +checks whether the time of last modification, the inode, or the device, of +the services directory +.I dir +has changed. +If so, it re-scans the service directory, and if it sees a new subdirectory, +or new symlink to a directory, in +.IR dir , +it starts a new +.BR runsv (8) +process; +if +.B runsvdir +sees a subdirectory being removed that was previously there, it sends the +corresponding +.BR runsv (8) +process a TERM signal, stops monitoring this process, and so does not +restart the +.BR runsv (8) +process if it exits. +.P +If the +.I log +argument is given to +.BR runsvdir , +all output to standard error is redirected to this +.IR log , +which is similar to the daemontools' +.B readproctitle +log. +To see the most recent error messages, use a process-listing tool such as +.BR ps (1). +.B runsvdir +writes a dot to the readproctitle log every 15 minutes so that old error +messages expire. +.SH OPTIONS +.TP +.B \-P +use +.BR setsid (2) +to run each +.BR runsv (8) +process in a new session and separate process group. +.SH SIGNALS +If +.B runsvdir +receives a TERM signal, it exits with 0 immediately. +.P +If +.B runsvdir +receives a HUP signal, it sends a TERM signal to each +.BR runsv (8) +process it is monitoring and then exits with 111. +.SH SEE ALSO +sv(8), +runsv(8), +runsvchdir(8), +runit(8), +runit-init(8), +chpst(8), +svlogd(8), +utmpset(8), +setsid(2) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/sv.8 b/base/busybox/runit-man/sv.8 new file mode 100644 index 0000000..7ed9852 --- /dev/null +++ b/base/busybox/runit-man/sv.8 @@ -0,0 +1,285 @@ +.TH sv 8 +.SH NAME +sv \- control and manage services monitored by +.BR runsv (8) +.SH SYNOPSIS +.B sv +[\-v] [\-w +.I sec\fR] +.I command +.I services +.P +.BI /etc/init.d/ service +[\-w +.I sec\fR] +.I command +.SH DESCRIPTION +The +.B sv +program reports the current status and controls the state of services +monitored by the +.BR runsv (8) +supervisor. +.P +.I services +consists of one or more arguments, each argument naming a directory +.I service +used by +.BR runsv (8). +If +.I service +doesn't start with a dot or slash and doesn't end with a slash, it is +searched in the default services directory +.IR /service/ , +otherwise relative to the current directory. +.P +.I command +is one of up, down, status, once, pause, cont, hup, alarm, interrupt, 1, 2, +term, kill, or exit, or start, stop, restart, shutdown, force-stop, +force-reload, force-restart, force-shutdown. +.P +The +.B sv +program can be sym-linked to +.I /etc/init.d/ +to provide an LSB init script interface. +The +.I service +to be controlled then is specified by the base name of the ``init script''. +.SH COMMANDS +.TP +.B status +Report the current status of the service, and the appendant log service if +available, to standard output. +.TP +.B up +If the service is not running, start it. +If the service stops, restart it. +.TP +.B down +If the service is running, send it the TERM signal, and the CONT signal. +If ./run exits, start ./finish if it exists. +After it stops, do not restart service. +.TP +.B once +If the service is not running, start it. +Do not restart it if it stops. +.TP +.B pause cont hup alarm interrupt quit 1 2 term kill +If the service is running, send it the STOP, CONT, HUP, ALRM, INT, QUIT, +USR1, USR2, TERM, or KILL signal respectively. +.TP +.B exit +If the service is running, send it the TERM signal, and the CONT signal. +Do not restart the service. +If the service is down, and no log service exists, +.BR runsv (8) +exits. +If the service is down and a log service exists, +.BR runsv (8) +closes the standard input of the log service and waits for it to terminate. +If the log service is down, +.BR runsv (8) +exits. +This command is ignored if it is given to an appendant log service. +.P +.BR sv +actually looks only at the first character of these +.IR command s. +.SS Commands compatible to LSB init script actions +.TP +.B status +Same as +.IR status . +.TP +.B start +Same as +.IR up , +but wait up to 7 seconds for the command to take effect. +Then report the status or timeout. +If the script +.I ./check +exists in the service directory, +.B sv +runs this script to check whether the service is up and available; +it's considered to be available if +.I ./check +exits with 0. +.TP +.B stop +Same as +.IR down , +but wait up to 7 seconds for the service to become down. +Then report the status or timeout. +.TP +.B reload +Same as +.IR hup , +and additionally report the status afterwards. +.TP +.B restart +Send the commands +.IR term , +.IR cont , +and +.I up +to the service, and wait up to 7 seconds for the service to restart. +Then report the status or timeout. +If the script +.I ./check +exists in the service directory, +.B sv +runs this script to check whether the service is up and available again; +it's considered to be available if +.I ./check +exits with 0. +.TP +.B shutdown +Same as +.IR exit , +but wait up to 7 seconds for the +.BR runsv (8) +process to terminate. +Then report the status or timeout. +.TP +.B force-stop +Same as +.IR down , +but wait up to 7 seconds for the service to become down. +Then report the status, and on timeout send the service the +.I kill +command. +.TP +.B force-reload +Send the service the +.I term +and +.I cont +commands, and wait up to 7 seconds for the service to restart. +Then report the status, and on timeout send the service the +.I kill +command. +.TP +.B force-restart +Send the service the +.IR term , +.I cont +and +.I up +commands, and wait up to 7 seconds for the service to restart. +Then report the status, and on timeout send the service the +.I kill +command. +If the script +.I ./check +exists in the service directory, +.B sv +runs this script to check whether the service is up and available again; +it's considered to be available if +.I ./check +exits with 0. +.TP +.B force-shutdown +Same as +.IR exit , +but wait up to 7 seconds for the +.BR runsv (8) +process to terminate. +Then report the status, and on timeout send the service the +.I kill +command. +.TP +.B try-restart +if the service is running, send it the +.I term +and +.I cont +commands, and wait up to 7 seconds for the service to restart. +Then report the status or timeout. + +.SS Additional Commands +.TP +.B check +Check for the service to be in the state that's been requested. +Wait up to 7 seconds for the service to reach the requested state, then +report the status or timeout. +If the requested state of the service is +.IR up , +and the script +.I ./check +exists in the service directory, +.B sv +runs this script to check whether the service is up and running; it's +considered to be up if +.I ./check +exits with 0. +.SH OPTIONS +.TP +.B \-v +If the +.I command +is up, down, term, once, cont, or exit, then wait up to 7 seconds for the +command to take effect. +Then report the status or timeout. +.TP +.B \-w \fIsec +Override the default timeout of 7 seconds with +.I sec +seconds. +This option implies +.IR \-v . +.SH ENVIRONMENT +.TP +.B SVDIR +The environment variable $SVDIR overrides the default services directory +.IR /service/ . +.TP +.B SVWAIT +The environment variable $SVWAIT overrides the default 7 seconds to wait +for a command to take effect. +It is overridden by the \-w option. +.SH EXIT CODES +.B sv +exits 0, if the +.I command +was successfully sent to all +.IR services , +and, if it was told to wait, the +.I command +has taken effect to all services. +.P +For each +.I service +that caused an error (e.g. the directory is not controlled by a +.BR runsv (8) +process, or +.B sv +timed out while waiting), +.B sv +increases the exit code by one and exits non zero. +The maximum is 99. +.B sv +exits 100 on error. +.P +If +.B sv +is called with a base name other than +.BR sv : +it exits 1 on timeout or trouble sending the command; if the +.I command +is +.BR status , +it exits 3 if the service is down, and 4 if the status is unknown; +it exits 2 on wrong usage, and 151 on error. +.SH SEE ALSO +runsv(8), +chpst(8), +svlogd(8), +runsvdir(8), +runsvchdir(8), +runit(8), +runit-init(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/svlogd.8 b/base/busybox/runit-man/svlogd.8 new file mode 100644 index 0000000..01b2324 --- /dev/null +++ b/base/busybox/runit-man/svlogd.8 @@ -0,0 +1,464 @@ +.TH svlogd 8 +.SH NAME +svlogd \- runit's service logging daemon +.SH SYNOPSIS +.B svlogd +[\-tttv] [\-r +.I c\fR] [\-R +.I xyz\fR] [\-l +.I len\fR] [\-b +.I buflen\fR] +.I logs +.SH DESCRIPTION +.I logs +consists of one or more arguments, each specifying a directory. +.P +.B svlogd +continuously reads log data from its standard input, optionally filters log +messages, and writes the data to one or more automatically rotated +.IR logs . +.P +Recent log files can automatically be processed by an arbitrary processor +program when they are rotated, and +.B svlogd +can be told to alert selected log messages to standard error, and through +udp. +.P +.B svlogd +runs until it sees end-of-file on standard input or is sent a TERM signal, +see below. +.SS LOG DIRECTORY +A log directory +.I log +contains some number of old log files, and the current log file +.IR current . +Old log files have a file name starting with +.I @ +followed by a precise timestamp (see the daemontools' +.B tai64n +program), indicating when +.I current +was rotated and renamed to this file. +.P +A log directory additionally contains the lock file +.IR lock , +maybe +.I state +and +.IR newstate , +and optionally the file +.IR config . +.B svlogd +creates necessary files if they don't exist. +.P +If +.B svlogd +has trouble opening a log directory, it prints a warning, and ignores this +log directory. +If +.B svlogd +is unable to open all log directories given at the command line, it exits +with an error. +This can happen on start-up or after receiving a HUP signal. +.SS LOG FILE ROTATION +.B svlogd +appends selected log messages to the +.I current +log file. +If +.I current +has +.I size +bytes or more (or there is a new-line within the last +.I len +of +.I size +bytes), or is older than a specified amount of +.IR time , +.I current +is rotated: +.P +.B svlogd +closes +.IR current , +changes permission of +.I current +to 0755, renames +.I current +to +.RI @ timestamp\fR.s, +and starts with a new empty +.IR current . +If +.B svlogd +sees +.I num +or more old log files in the log directory, it removes the oldest one. +Note that this doesn't decrease the number of log files if there are +already more than +.I num +log files, this must be done manually, e.g. for keeping 10 log files: +.P + ls \-1 \\@* |sort |sed \-ne '10,$p' |xargs rm +.SS PROCESSOR +If +.B svlogd +is told to process recent log files, it saves +.I current +to +.RI @ timestamp\fR.u, +feeds +.RI @ timestamp\fR.u +through ``sh \-c "\fIprocessor\fR"'' +and writes the output to +.RI @ timestamp\fR.t. +If the +.I processor +finishes successfully, +.RI @ timestamp\fR.t +is renamed to +.RI @ timestamp\fR.s, +and +.RI @ timestamp\fR.u +is deleted; otherwise +.RI @ timestamp\fR.t +is deleted and the +.I processor +is started again. +.B svlogd +also saves any output that the +.I processor +writes to file descriptor 5, and makes that output available on file +descriptor 4 when running +.I processor +on the next log file rotation. +.P +A +.I processor +is run in the background. +If +.B svlogd +sees a previously started +.I processor +still running when trying to start a new one for the same +.IR log , +it blocks until the currently running +.I processor +has finished successfully. +Only the HUP signal works in that situation. +Note that this may block any program feeding its log data to +.BR svlogd. + +.SS CONFIG +On startup, and after receiving a HUP signal, +.B svlogd +checks for each log directory +.I log +if the configuration file +.I log/config +exists, and if so, reads the file line by line and adjusts configuration for +.I log +as follows: +.P +If the line is empty, or starts with a ``#'', it is ignored. +A line of the form +.TP +.RI s size +sets the maximum file size of +.I current +when +.B svlogd +should rotate the current log file to +.I size +bytes. +Default is 1000000. +If +.I size +is zero, +.B svlogd +doesn't rotate log files. +You should set +.I size +to at least (2 * +.IR len ). +.TP +.RI n num +sets the number of old log files +.B svlogd +should maintain to +.IR num . +If +.B svlogd +sees more that +.I num +old log files in +.I log +after log file rotation, it deletes the oldest one. +Default is 10. +If +.I num +is zero, +.B svlogd +doesn't remove old log files. +.TP +.RI N min +sets the minimum number of old log files +.B svlogd +should maintain to +.IR min . +.I min +must be less than +.IR num . +If +.I min +is set, and +.B svlogd +cannot write to +.I current +because the filesystem is full, and it sees more than +.I min +old log files, it deletes the oldest one. +.TP +.RI t timeout +sets the maximum age of the +.I current +log file when +.B svlogd +should rotate the current log file to +.I timeout +seconds. +If +.I current +is +.I timeout +seconds old, and is not empty, +.B svlogd +forces log file rotation. +.TP +.RI ! processor +tells +.B svlogd +to feed each recent log file through +.I processor +(see above) on log file rotation. +By default log files are not processed. +.TP +.RI u a.b.c.d[:port] +tells +.B svlogd +to transmit the first +.I len +characters of selected log messages to the IP address +.IR a.b.c.d , +port number +.IR port . +If +.I port +isn't set, the default port for syslog is used (514). +.I len +can be set through the \-l option, see below. +If +.B svlogd +has trouble sending udp packets, it writes error messages to the log +directory. +Attention: +logging through udp is unreliable, and should be used in private networks +only. +.TP +.RI U a.b.c.d[:port] +is the same as the +.I u +line above, but the log messages are no longer written to the log directory, +but transmitted through udp only. +Error messages from +.B svlogd +concerning sending udp packages still go to the log directory. +.TP +.RI p prefix +tells +.B svlogd +to prefix each line to be written to the log directory, to standard error, +or through UDP, with +.IR prefix . +.P +If a line starts with a +.IR \- , +.IR + , +.IR e , +or +.IR E , +.B svlogd +matches the first +.I len +characters of each log message against +.I pattern +and acts accordingly: +.TP +.RI \- pattern +the log message is deselected. +.TP +.RI + pattern +the log message is selected. +.TP +.RI e pattern +the log message is selected to be printed to standard error. +.TP +.RI E pattern +the log message is deselected to be printed to standard error. +.P +Initially each line is selected to be written to +.IR log/current . +Deselected log messages are discarded from +.IR log . +Initially each line is deselected to be written to standard err. +Log messages selected for standard error are written to standard error. +.SH PATTERN MATCHING +.B svlogd +matches a log message against the string +.I pattern +as follows: +.P +.I pattern +is applied to the log message one character by one, starting with the first. +A character not a star (``*'') and not a plus (``+'') matches itself. +A plus matches the next character in +.I pattern +in the log message one or more times. +A star before the end of +.I pattern +matches any string in the log message that does not include the next +character in +.IR pattern . +A star at the end of +.I pattern +matches any string. +.P +Timestamps optionally added by +.B svlogd +are not considered part of the log message. +.P +An +.B svlogd +pattern is not a regular expression. +For example consider a log message like this +.P + 2005-12-18_09:13:50.97618 tcpsvd: info: pid 1977 from 10.4.1.14 +.P +The following pattern doesn't match +.P + -*pid* +.P +because the first star matches up to the first p in tcpsvd, and then the +match fails because i is not s. +To match this log message, you can use a pattern like this instead +.P + -*: *: pid * +.SH OPTIONS +.TP +.B \-t +timestamp. +Prefix each selected line with a precise timestamp (see the daemontools' +.B tai64n +program) when writing to +.I log +or to standard error. +.TP +.B \-tt +timestamp. +Prefix each selected line with a human readable, sortable UTC timestamp of +the form YYYY-MM-DD_HH:MM:SS.xxxxx when writing to +.I log +or to standard error. +.TP +.B \-ttt +timestamp. +Prefix each selected line with a human readable, sortable UTC timestamp of +the form YYYY-MM-DDTHH:MM:SS.xxxxx when writing to +.I log +or to standard error. +.TP +.B \-r \fIc +replace. +.I c +must be a single character. +Replace non-printable characters in log messages with +.IR c . +Characters are replaced before pattern matching is applied. +.TP +.B \-R \fIxyz +replace charset. +Additionally to non-printable characters, replace all characters found in +.I xyz +with +.I c +(default ``_''). +.TP +.B \-l \fIlen +line length. +Pattern matching applies to the first +.I len +characters of a log message only. +Default is 1000. +.TP +.B \-b \fIbuflen +buffer size. +Set the size of the buffer +.B svlogd +uses when reading from standard input and writing to +.I logs +to +.IR buflen . +Default is 1024. +.I buflen +must be greater than +.IR len . +For +.B svlogd +instances that process a lot of data in short time, the buffer size should +be increased to improve performance. +.TP +.B \-v +verbose. +Print verbose messages to standard error. +.SH SIGNALS +If +.B svlogd +is sent a HUP signal, it closes and reopens all +.IR logs , +and updates their configuration according to +.IR log/config . +If +.B svlogd +has trouble opening a log directory, it prints a warning, and discards this +log directory. +If +.B svlogd +is unable to open all log directories given at the command line, it exits +with an error. +.P +If +.B svlogd +is sent a TERM signal, or if it sees end-of-file on standard input, it stops +reading standard input, processes the data in the buffer, waits for all +.I processor +subprocesses to finish if any, and exits 0 as soon as possible. +.P +If +.B svlogd +is sent an ALRM signal, it forces log file rotation for all +.I logs +with a non empty +.I current +log file. +.SH SEE ALSO +sv(8), +runsv(8), +chpst(8), +runit(8), +runit-init(8), +runsvdir(8), +runsvchdir(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/runit-man/utmpset.8 b/base/busybox/runit-man/utmpset.8 new file mode 100644 index 0000000..4f9b4ef --- /dev/null +++ b/base/busybox/runit-man/utmpset.8 @@ -0,0 +1,63 @@ +.TH utmpset 8 +.SH NAME +utmpset \- logout a line from utmp and wtmp file +.SH SYNOPSIS +.B utmpset +[ +.B \-w +] +.I line +.SH DESCRIPTION +The +.B utmpset +program modifies the user accounting database +.BR utmp (5) +and optionally +.BR wtmp (5) +to indicate that the user on the terminal +.I line +has logged out. +.P +Ordinary +.BR init (8) +processes handle utmp file records for local login accounting. +The +.BR runit (8) +program doesn't include code to update the utmp file, the +.BR getty (8) +processes are handled the same as all other services. +.P +To enable local login accounting, add +.B utmpset +to the +.BR getty (8) +.I finish +scripts, e.g.: +.P + $ cat /service/getty-5/finish + #!/bin/sh + exec utmpset \-w tty5 + $ +.SH OPTIONS +.TP +.B \-w +wtmp. Additionally to the utmp file, write an empty record for +.I line +to the wtmp file. +.SH EXIT CODES +.B utmpset +returns 111 on error, 1 on wrong usage, 0 in all other cases. +.SH SEE ALSO +sv(8), +runsv(8), +runit(8), +runit-init(8) +runsvdir(8), +runsvchdir(8), +chpst(8), +svlogd(8), +getty(8) +.P +http://smarden.org/runit/ +.SH AUTHOR +Gerrit Pape diff --git a/base/busybox/udhcpc-script b/base/busybox/udhcpc-script new file mode 100755 index 0000000..0b79050 --- /dev/null +++ b/base/busybox/udhcpc-script @@ -0,0 +1,30 @@ +#!/bin/sh +# udhcpc script edited by Tim Riker +[ -z "$1" ] && echo "Error: should be called from udhcpc" && exit 1 +RESOLV_CONF="/etc/resolv.conf" +[ -n "$broadcast" ] && BROADCAST="broadcast $broadcast" +[ -n "$subnet" ] && NETMASK="netmask $subnet" +case "$1" in + deconfig) + /sbin/ifconfig $interface 0.0.0.0 + ;; + renew|bound) + /sbin/ifconfig $interface $ip $BROADCAST $NETMASK + if [ -n "$router" ] ; then + echo "deleting routers" + while route del default gw 0.0.0.0 dev $interface ; do + : + done + for i in $router ; do + route add default gw $i dev $interface + done + fi + echo -n > $RESOLV_CONF + [ -n "$domain" ] && echo search $domain >> $RESOLV_CONF + for i in $dns ; do + echo adding dns $i + echo nameserver $i >> $RESOLV_CONF + done + ;; +esac +exit 0 diff --git a/base/bzip2/bzip2-flags.patch b/base/bzip2/bzip2-flags.patch new file mode 100644 index 0000000..c292043 --- /dev/null +++ b/base/bzip2/bzip2-flags.patch @@ -0,0 +1,21 @@ +--- bzip2-1.0.6.old/Makefile-libbz2_so ++++ bzip2-1.0.6/Makefile-libbz2_so +@@ -25,6 +25,7 @@ + CC=gcc + BIGFILES=-D_FILE_OFFSET_BITS=64 + CFLAGS=-fpic -fPIC -Wall -Winline -O2 -g $(BIGFILES) ++LDFLAGS= + + OBJS= blocksort.o \ + huffman.o \ +@@ -35,8 +36,8 @@ + bzlib.o + + all: $(OBJS) +- $(CC) -shared -Wl,-soname -Wl,libbz2.so.1.0 -o libbz2.so.1.0.6 $(OBJS) +- $(CC) $(CFLAGS) -o bzip2-shared bzip2.c libbz2.so.1.0.6 ++ $(CC) $(CFLAGS) -shared $(LDFLAGS) -Wl,-soname -Wl,libbz2.so.1.0 -o libbz2.so.1.0.6 $(OBJS) ++ $(CC) $(CFLAGS) $(LDFLAGS) -o bzip2-shared bzip2.c libbz2.so.1.0.6 + rm -f libbz2.so.1.0 + ln -s libbz2.so.1.0.6 libbz2.so.1.0 + diff --git a/base/bzip2/bzip2.SMBuild b/base/bzip2/bzip2.SMBuild new file mode 100755 index 0000000..850680a --- /dev/null +++ b/base/bzip2/bzip2.SMBuild @@ -0,0 +1,43 @@ +APP=bzip2 +VERSION=1.0.6 +BUILD=1sml +HOMEPAGE='https://sourceware.org/bzip2/' +DOWNLOAD='https://sourceware.org/pub/bzip2/bzip2-1.0.6.tar.gz' +REQUIRES="musl" +DESC="block-sorting file compressor based on Burrows-Wheeler text compression algorithm" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Taken from sabotage + + patch -p1 < $SRCDIR/bzip2-flags.patch + + sed -i 's@$(PREFIX)@$(DESTDIR)$(PREFIX)@g' Makefile + sed -i 's@$(PREFIX)/man@$(PREFIX)/share/man@g' Makefile + + sed -i 's@all: libbz2.a bzip2 bzip2recover test@all: libbz2.a bzip2 bzip2recover@' Makefile + make -f Makefile-libbz2_so + make PREFIX="/" CFLAGS="-fPIC" + + make install DESTDIR=$PKG PREFIX="/" + install -m 0644 libbz2.so.1.0.6 $PKG/lib + + cp LICEN?E $PKGDOCS/ + + cd $PKG/lib + ln -sf libbz2.so.1.0.6 libbz2.so.1.0 + ln -sf libbz2.so.1.0.6 libbz2.so + + mkfinalpkg +} + +SHA512SUMS=" +a8e36dd2987acb7f39fbfecc5207e9a18f5029b9254c75b0b832b72fa443a227f1e5490739707129ca325a6fab8acfd8fed9fec3330cdc67f4594147f84a1ba0 bzip2-1.0.6.tar.lz +8b8eff6348994c5d67691d3b4d53bd3e66785138c613737c1f38ac8c245412cde4efe44e671e9ee05c7216e9f895d7ef7212c1f76d31724f5016a3720aad335d bzip2-flags.patch +" diff --git a/base/c-ares/LICENSE b/base/c-ares/LICENSE new file mode 100644 index 0000000..e3f5b64 --- /dev/null +++ b/base/c-ares/LICENSE @@ -0,0 +1,10 @@ +Copyright 1998 by the Massachusetts Institute of Technology. + +Permission to use, copy, modify, and distribute this software and its +documentation for any purpose and without fee is hereby granted, provided that +the above copyright notice appear in all copies and that both that copyright +notice and this permission notice appear in supporting documentation, and that +the name of M.I.T. not be used in advertising or publicity pertaining to +distribution of the software without specific, written prior permission. +M.I.T. makes no representations about the suitability of this software for any +purpose. It is provided "as is" without express or implied warranty. diff --git a/base/c-ares/c-ares.SMBuild b/base/c-ares/c-ares.SMBuild new file mode 100755 index 0000000..4efd725 --- /dev/null +++ b/base/c-ares/c-ares.SMBuild @@ -0,0 +1,31 @@ +APP=c-ares +VERSION=1.16.1 +BUILD=1sml +HOMEPAGE='https://c-ares.haxx.se/' +DOWNLOAD='https://c-ares.haxx.se/download/c-ares-1.16.1.tar.gz' +DESC="C library for asynchronous DNS requests including name resolves" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-shared + + make + make install DESTDIR=$PKG + + cp $SRCDIR/LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4ac2a5d5c6da74eb1d6155c4eadc7127ab1b53a8d13caec41bd6172db5417a79f3ab022e77ba37d8b13da6893d7ced5fd8baf5cc3950a4154b4de8743ad31471 c-ares-1.16.1.tar.gz +" diff --git a/base/ca-certificates/ca-certificates.SMBuild b/base/ca-certificates/ca-certificates.SMBuild new file mode 100755 index 0000000..153ef18 --- /dev/null +++ b/base/ca-certificates/ca-certificates.SMBuild @@ -0,0 +1,48 @@ +APP=ca-certificates +VERSION=20210308 +BUILD=1sml +HOMEPAGE='https://ftp.debian.org/debian/pool/main/c/ca-certificates/' +DOWNLOAD='' +DESC="PEM Files of CA Certificates" +REQUIRES="musl curl" + +build() { + mkandenterbuilddir + tar xf $SRCDIR/$APP.tar.?z* + + cd $APP + fixbuilddirpermissions + + # Patch to remove incompatible arguments from run-parts + patch -p1 < $SRCDIR/fixup_update-ca-certificates.diff + + # Update to certdata.txt from $SRCDIR: + xzcat $SRCDIR/certdata-${VERSION}.txt.xz > mozilla/certdata.txt + + mkdir -p $PKG/share/ca-certificates $PKG/bin $PKG/usr/sbin + + make + make install DESTDIR=$PKG CERTSDIR=/share/ca-certificates + cp docs/copyright $PKGDOCS/COPYRIGHT + + mkdir -p $PKG/etc/ca-certificates/update.d + printf "# Automatically generated by $APP-$VERSION \n#\n" \ + > $PKG/etc/ca-certificates.conf.new + ( cd $PKG/share/ca-certificates + find . -name '*.crt' | sort | cut -b3- + ) >> $PKG/etc/ca-certificates.conf.new + + install -Dm 755 $SRCDIR/setup.11.cacerts $PKG/var/log/setup/setup.11.cacerts + install -Dm 644 sbin/update-ca-certificates.8 $PKG/share/man/man8/update-ca-certificates.8 + + # Why do people hardcode paths in Makefiles! + mv $PKG/usr/sbin/* $PKG/bin/ + rm -rf $PKG/usr + + mkfinalpkg +} + +SHA512SUMS=" +c1310a6c1f3af3838b56a9e55382261d60d3f1b5da5dbf612c5d5119e2a398dbbbdfbf7c88034aea901c752cf1c7624e3e7903746de6d8c72fc94bcccf9d06b7 ca-certificates.tar.lz +c57ee9319db07b66a7f89fe518d318b47b31cb9e5f73ae4125f9e0f05e26fceaaa2decf2263716500e5403732f5446d0779a5cfb4b962328fb32dcc371347688 fixup_update-ca-certificates.diff +" diff --git a/base/ca-certificates/doinst.sh b/base/ca-certificates/doinst.sh new file mode 100644 index 0000000..8841133 --- /dev/null +++ b/base/ca-certificates/doinst.sh @@ -0,0 +1,19 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +config etc/ca-certificates.conf.new + +if [ -x /bin/update-ca-certificates ]; then + /bin/update-ca-certificates --fresh 1> /dev/null 2> /dev/null +fi + diff --git a/base/ca-certificates/fixup_update-ca-certificates.diff b/base/ca-certificates/fixup_update-ca-certificates.diff new file mode 100644 index 0000000..1c39405 --- /dev/null +++ b/base/ca-certificates/fixup_update-ca-certificates.diff @@ -0,0 +1,12 @@ +diff -urN ca-certificates-20150426.orig/sbin/update-ca-certificates ca-certificates-20150426/sbin/update-ca-certificates +--- ca-certificates-20150426.orig/sbin/update-ca-certificates 2015-04-01 13:47:25.000000000 +0100 ++++ ca-certificates-20150426/sbin/update-ca-certificates 2015-09-14 22:51:39.856021883 +0100 +@@ -193,7 +193,7 @@ + echo "Running hooks in $HOOKSDIR..." + VERBOSE_ARG= + [ "$verbose" = 0 ] || VERBOSE_ARG="--verbose" +- eval run-parts "$VERBOSE_ARG" --test -- "$HOOKSDIR" | while read hook ++ eval run-parts "$HOOKSDIR" | while read hook + do + ( cat "$ADDED" + cat "$REMOVED" ) | "$hook" || echo "E: $hook exited with code $?." diff --git a/base/ca-certificates/setup.11.cacerts b/base/ca-certificates/setup.11.cacerts new file mode 100644 index 0000000..328b61c --- /dev/null +++ b/base/ca-certificates/setup.11.cacerts @@ -0,0 +1,3 @@ +#!/bin/sh +#BLURB="Rebuild SSL certificate database." +chroot . usr/sbin/update-ca-certificates --fresh 1> /dev/null 2> /dev/null diff --git a/base/ccache/ccache.SMBuild b/base/ccache/ccache.SMBuild new file mode 100755 index 0000000..11f7082 --- /dev/null +++ b/base/ccache/ccache.SMBuild @@ -0,0 +1,31 @@ +APP=ccache +VERSION=3.7.9 +BUILD=1sml +HOMEPAGE='https://ccache.dev/' +DOWNLOAD='https://github.com/ccache/ccache/releases/download/v3.7.9/ccache-3.7.9.tar.xz' +DESC="Compiler cache to speed up re-compilation of C/C++ code by caching previous compiles" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + LDFLAGS="-static" \ + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp GPL* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0944846a6543947251e500576dd69f0b88d69c9a7535de5be8d6a17505489d8ec658bac8a71b8a8c70f341e3e174968e99ebfaadfd1e64b2e791f4d567b1a0c9 ccache-3.7.9.tar.lz +" diff --git a/base/chrony/README b/base/chrony/README new file mode 100644 index 0000000..4d49d75 --- /dev/null +++ b/base/chrony/README @@ -0,0 +1,45 @@ +chrony is a versatile implementation of the Network Time Protocol +(NTP). It can synchronise the system clock with NTP servers, reference +clocks (e.g. GPS receiver), and manual input using wristwatch and +keyboard. It can also operate as an NTPv4 (RFC 5905) server and peer +to provide a time service to other computers in the network. + +It is designed to perform well in a wide range of conditions, including +intermittent network connections, heavily congested networks, changing +temperatures (ordinary computer clocks are sensitive to temperature), +and systems that do not run continuously, or run on a virtual machine. + +Two programs are included in chrony, chronyd is a daemon that is +started at boot time and chronyc is a command-line interface program +which can be used to monitor chronyd's performance and to change +various operating parameters whilst it is running. + +Note 1: +You must have the 'chrony' group and user to run this script: + $ groupadd -g 354 chrony + $ useradd -u 354 -d /var/lib/chrony -s /bin/false -g chrony chrony +Feel free to use a different uid and gid if desired, but 354 is +recommended to avoid conflicts with other stuff from SlackBuilds.org. + +Note 2: +If you are upgrading from previous version, where the daemon was +running under 'root' user as opposed to 'chrony' user, you need to +ensure correct permissions for /var/run/chrony directory and files +under /var/lib/chrony directory. + +If possible (i.e. you don't have any precious files there), before +starting the daemon, remove /var/run/chrony directory (cronyd will +recreate it) and remove files under /var/lib/chrony directory (cronyd +will recreate them). + +Note 3: +The provided configuration file sets up chrony to operate in the most +common scenario, that is NTP client for synchronising local machine +time with the remote NTP server(s) time (using pool.ntp.org by +default). See the man pages for chronyd and chrony.conf (and the +contrib and examples directories) for more details on possible +configuration options. + +Note 4: +The provided /etc/rc.d/rc.chrony script can be used to launch the +daemon at boot and to stop it at shutdown. diff --git a/base/chrony/chrony.SMBuild b/base/chrony/chrony.SMBuild new file mode 100755 index 0000000..cbb39f8 --- /dev/null +++ b/base/chrony/chrony.SMBuild @@ -0,0 +1,44 @@ +APP=chrony +VERSION=3.5 +BUILD=1sml +HOMEPAGE='https://chrony.tuxfamily.org/' +DOWNLOAD='https://download.tuxfamily.org/chrony/chrony-3.5.tar.gz' +DESC="Lightweight program to maintain accuracy of the real time clock via NTP" +REQUIRES="nettle libcap" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sbindir=/bin \ + --mandir=/share/man \ + --without-readline \ + --without-nss + + make $MAKEFLAGS + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + cp $SRCDIR/chrony.conf $PKG/etc/ + # raspberry pi example + cp $SRCDIR/chrony.conf.rpi $PKG/etc/ + cp $SRCDIR/README $PKG/etc/chrony.README + + mkdir -p $PKG/var/lib/chrony + + preprunitservice chrony down + + mkfinalpkg +} + +SHA512SUMS=" +bdfeb8a5d478ff575b5bff6f9d298fb1102c9d74f2636499e124a8d9273a9d8c2b9b51bd037ef7054fd12c02a8371160a486f08a2f0c8fa2b97ed0410a9f3cf0 chrony-3.5.tar.lz +" diff --git a/base/chrony/chrony.conf b/base/chrony/chrony.conf new file mode 100644 index 0000000..7176667 --- /dev/null +++ b/base/chrony/chrony.conf @@ -0,0 +1,15 @@ +# NTP server to pool from +#pool pool.ntp.org iburst maxsources 2 +server pool.ntp.org iburst +# Location of the drift file +driftfile /var/lib/chrony/drift +# Enable the server and set the stratum level +local stratum 1 +# Allow only hosts from this subnet to sync +allow 192.168.1.0/24 +# Speed up initial clock correction when started +makestep 1.0 3 +manual +dumpdir /var/run/chrony +logdir /var/log +rtcsync diff --git a/base/chrony/chrony.conf.rpi b/base/chrony/chrony.conf.rpi new file mode 100644 index 0000000..aaea5e7 --- /dev/null +++ b/base/chrony/chrony.conf.rpi @@ -0,0 +1,14 @@ +# Typical raspberry pi configuration for chrony +# Uncomment to enable server and set the stratum level +local stratum 2 +# Uncomment to allow hosts from the following subnets to sync +allow 192.168.1.0/24 +# NTP server to pool from +# pool 0.europe.ntp.org iburst maxsources 2 +server pool.ntp.org iburst +initstepslew 30 pool.ntp.org +# Location of the drift file +driftfile /var/lib/chrony/drift +# Location to store measurement data +dumpdir /var/run/chrony +logdir /var/log diff --git a/base/chrony/chrony.run b/base/chrony/chrony.run new file mode 100644 index 0000000..acf286e --- /dev/null +++ b/base/chrony/chrony.run @@ -0,0 +1,3 @@ +#!/bin/sh +PATH="/bin" +exec chronyd -n 2>&1 diff --git a/base/chrony/doinst.sh b/base/chrony/doinst.sh new file mode 100644 index 0000000..deb41ab --- /dev/null +++ b/base/chrony/doinst.sh @@ -0,0 +1,13 @@ +config() { + NEW="$1" + OLD="`dirname $NEW`/`basename $NEW .new`" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/chrony.conf.new +config etc/chrony.conf.rpi.new diff --git a/base/chrpath/chrpath.SMBuild b/base/chrpath/chrpath.SMBuild new file mode 100755 index 0000000..1729be3 --- /dev/null +++ b/base/chrpath/chrpath.SMBuild @@ -0,0 +1,31 @@ +APP=chrpath +VERSION=0.16 +BUILD=1sml +HOMEPAGE='https://chrpath.alioth.debian.org/' +DOWNLOAD='https://alioth.debian.org/frs/download.php/latestfile/813/chrpath-0.16.tar.gz' +DESC="Program to modify rpath aka dynamic library load path of binaries" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --mandir=/share/man + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +aa04d490f78bff20a56fe20539cec10218c0772a668909eda8324ca825f51e8ef92001e95d9c316e79a145a043c9c327ec94d1a82e104ab408ca1021832745aa chrpath-0.16.tar.gz +" diff --git a/base/clang/10-add-musl-triples.patch b/base/clang/10-add-musl-triples.patch new file mode 100644 index 0000000..fd3f3cd --- /dev/null +++ b/base/clang/10-add-musl-triples.patch @@ -0,0 +1,37 @@ +diff --git a/lib/Driver/ToolChains/Gnu.cpp b/lib/Driver/ToolChains/Gnu.cpp +index da197e47..505439ea 100644 +--- a/lib/Driver/ToolChains/Gnu.cpp ++++ b/lib/Driver/ToolChains/Gnu.cpp +@@ -1997,6 +1997,7 @@ void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes( + static const char *const AArch64LibDirs[] = {"/lib64", "/lib"}; + static const char *const AArch64Triples[] = { + "aarch64-none-linux-gnu", "aarch64-linux-gnu", "aarch64-redhat-linux", ++ "aarch64-linux-musl", + "aarch64-suse-linux", "aarch64-linux-android"}; + static const char *const AArch64beLibDirs[] = {"/lib"}; + static const char *const AArch64beTriples[] = {"aarch64_be-none-linux-gnu", +@@ -2006,6 +2007,8 @@ void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes( + static const char *const ARMTriples[] = {"arm-linux-gnueabi", + "arm-linux-androideabi"}; + static const char *const ARMHFTriples[] = {"arm-linux-gnueabihf", ++ "arm-linux-musleabihf", ++ "armv7l-linux-musleabihf", + "armv7hl-redhat-linux-gnueabi", + "armv6hl-suse-linux-gnueabi", + "armv7hl-suse-linux-gnueabi"}; +@@ -2025,6 +2028,7 @@ void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes( + "x86_64-redhat-linux", "x86_64-suse-linux", + "x86_64-manbo-linux-gnu", "x86_64-linux-gnu", + "x86_64-slackware-linux", "x86_64-unknown-linux", ++ "x86_64-linux-musl", + "x86_64-amazon-linux", "x86_64-linux-android"}; + static const char *const X32LibDirs[] = {"/libx32"}; + static const char *const X86LibDirs[] = {"/lib32", "/lib"}; +@@ -2034,6 +2038,7 @@ void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes( + "i586-redhat-linux", "i386-redhat-linux", "i586-suse-linux", + "i486-slackware-linux", "i686-montavista-linux", "i586-linux-gnu", + "i686-linux-android", "i386-gnu", "i486-gnu", ++ "i686-linux-musl", + "i586-gnu", "i686-gnu"}; + + static const char *const MIPSLibDirs[] = {"/lib"}; diff --git a/base/clang/30-fix-python-shebangs.patch b/base/clang/30-fix-python-shebangs.patch new file mode 100644 index 0000000..41bee37 --- /dev/null +++ b/base/clang/30-fix-python-shebangs.patch @@ -0,0 +1,391 @@ +diff --git a/bindings/python/examples/cindex/cindex-dump.py b/bindings/python/examples/cindex/cindex-dump.py +index 46073b28..fc513c7e 100644 +--- a/bindings/python/examples/cindex/cindex-dump.py ++++ b/bindings/python/examples/cindex/cindex-dump.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + #===- cindex-dump.py - cindex/Python Source Dump -------------*- python -*--===# + # +diff --git a/bindings/python/examples/cindex/cindex-includes.py b/bindings/python/examples/cindex/cindex-includes.py +index ec1fbc0c..be600342 100644 +--- a/bindings/python/examples/cindex/cindex-includes.py ++++ b/bindings/python/examples/cindex/cindex-includes.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + #===- cindex-includes.py - cindex/Python Inclusion Graph -----*- python -*--===# + # +diff --git a/docs/tools/dump_ast_matchers.py b/docs/tools/dump_ast_matchers.py +index c96c1ca2..26cf4156 100755 +--- a/docs/tools/dump_ast_matchers.py ++++ b/docs/tools/dump_ast_matchers.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # A tool to parse ASTMatchers.h and update the documentation in + # ../LibASTMatchersReference.html automatically. Run from the + # directory in which this file is located to update the docs. +diff --git a/docs/tools/dump_format_style.py b/docs/tools/dump_format_style.py +index 5feb793a..e18a2ffb 100755 +--- a/docs/tools/dump_format_style.py ++++ b/docs/tools/dump_format_style.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # A tool to parse the FormatStyle struct from Format.h and update the + # documentation in ../ClangFormatStyleOptions.rst automatically. + # Run from the directory in which this file is located to update the docs. +diff --git a/test/AST/gen_ast_dump_json_test.py b/test/AST/gen_ast_dump_json_test.py +index 975039ea..9a6ee94c 100644 +--- a/test/AST/gen_ast_dump_json_test.py ++++ b/test/AST/gen_ast_dump_json_test.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + from collections import OrderedDict + from sets import Set +diff --git a/tools/clang-format/clang-format-diff.py b/tools/clang-format/clang-format-diff.py +index 3ba0abef..6b0425a7 100755 +--- a/tools/clang-format/clang-format-diff.py ++++ b/tools/clang-format/clang-format-diff.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # + #===- clang-format-diff.py - ClangFormat Diff Reformatter ----*- python -*--===# + # +diff --git a/tools/clang-format/git-clang-format b/tools/clang-format/git-clang-format +index ef7f22d0..4ea4521f 100755 +--- a/tools/clang-format/git-clang-format ++++ b/tools/clang-format/git-clang-format +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # + #===- git-clang-format - ClangFormat Git Integration ---------*- python -*--===# + # +diff --git a/tools/scan-build-py/bin/analyze-build b/tools/scan-build-py/bin/analyze-build +index 6c285874..5b270d54 100755 +--- a/tools/scan-build-py/bin/analyze-build ++++ b/tools/scan-build-py/bin/analyze-build +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-build-py/bin/analyze-c++ b/tools/scan-build-py/bin/analyze-c++ +index 564e2abf..b2b60a44 100755 +--- a/tools/scan-build-py/bin/analyze-c++ ++++ b/tools/scan-build-py/bin/analyze-c++ +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-build-py/bin/analyze-cc b/tools/scan-build-py/bin/analyze-cc +index 564e2abf..b2b60a44 100755 +--- a/tools/scan-build-py/bin/analyze-cc ++++ b/tools/scan-build-py/bin/analyze-cc +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-build-py/bin/intercept-build b/tools/scan-build-py/bin/intercept-build +index 23f51047..fe45c545 100755 +--- a/tools/scan-build-py/bin/intercept-build ++++ b/tools/scan-build-py/bin/intercept-build +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-build-py/bin/intercept-c++ b/tools/scan-build-py/bin/intercept-c++ +index 4230c803..0cba3a3c 100755 +--- a/tools/scan-build-py/bin/intercept-c++ ++++ b/tools/scan-build-py/bin/intercept-c++ +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-build-py/bin/intercept-cc b/tools/scan-build-py/bin/intercept-cc +index 4230c803..0cba3a3c 100755 +--- a/tools/scan-build-py/bin/intercept-cc ++++ b/tools/scan-build-py/bin/intercept-cc +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-build-py/bin/scan-build b/tools/scan-build-py/bin/scan-build +index 156da064..4fa08175 100755 +--- a/tools/scan-build-py/bin/scan-build ++++ b/tools/scan-build-py/bin/scan-build +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + # Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. + # See https://llvm.org/LICENSE.txt for license information. +diff --git a/tools/scan-view/bin/scan-view b/tools/scan-view/bin/scan-view +index 6165432e..07effbca 100755 +--- a/tools/scan-view/bin/scan-view ++++ b/tools/scan-view/bin/scan-view +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + from __future__ import print_function + +diff --git a/tools/scan-view/share/Reporter.py b/tools/scan-view/share/Reporter.py +index b1ff1614..d6300e78 100644 +--- a/tools/scan-view/share/Reporter.py ++++ b/tools/scan-view/share/Reporter.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + + """Methods for reporting bugs.""" +diff --git a/tools/scan-view/share/startfile.py b/tools/scan-view/share/startfile.py +index 9eb548bc..cdf3db27 100644 +--- a/tools/scan-view/share/startfile.py ++++ b/tools/scan-view/share/startfile.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # -*- coding: utf-8 -*- + + """Utility for opening a file using the default application in a cross-platform +diff --git a/utils/ABITest/ABITestGen.py b/utils/ABITest/ABITestGen.py +index 93a6de93..efb35fa7 100755 +--- a/utils/ABITest/ABITestGen.py ++++ b/utils/ABITest/ABITestGen.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + from __future__ import absolute_import, division, print_function + from pprint import pprint +diff --git a/utils/CIndex/completion_logger_server.py b/utils/CIndex/completion_logger_server.py +index 20166711..02d7cd6f 100755 +--- a/utils/CIndex/completion_logger_server.py ++++ b/utils/CIndex/completion_logger_server.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + from __future__ import absolute_import, division, print_function + import sys + from socket import * +diff --git a/utils/CaptureCmd b/utils/CaptureCmd +index 705585c3..5ffdfe56 100755 +--- a/utils/CaptureCmd ++++ b/utils/CaptureCmd +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """CaptureCmd - A generic tool for capturing information about the + invocations of another program. +diff --git a/utils/CmpDriver b/utils/CmpDriver +index 12ce7a32..c2b6ab5e 100755 +--- a/utils/CmpDriver ++++ b/utils/CmpDriver +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + A simple utility that compares tool invocations and exit codes issued by +diff --git a/utils/FindSpecRefs b/utils/FindSpecRefs +index 9097f93f..3ad581b3 100755 +--- a/utils/FindSpecRefs ++++ b/utils/FindSpecRefs +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + import os + import re +diff --git a/utils/FuzzTest b/utils/FuzzTest +index 0e043df7..c4c956b6 100755 +--- a/utils/FuzzTest ++++ b/utils/FuzzTest +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + This is a generic fuzz testing tool, see --help for more information. +diff --git a/utils/TestUtils/deep-stack.py b/utils/TestUtils/deep-stack.py +index 10bf47ac..5fb8d0df 100755 +--- a/utils/TestUtils/deep-stack.py ++++ b/utils/TestUtils/deep-stack.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + from __future__ import absolute_import, division, print_function + def pcall(f, N): +diff --git a/utils/analyzer/CmpRuns.py b/utils/analyzer/CmpRuns.py +index 3fab6ef5..9baa7a48 100755 +--- a/utils/analyzer/CmpRuns.py ++++ b/utils/analyzer/CmpRuns.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + CmpRuns - A simple tool for comparing two static analyzer runs to determine +diff --git a/utils/analyzer/SATestAdd.py b/utils/analyzer/SATestAdd.py +index 52089f4e..d087a90b 100755 +--- a/utils/analyzer/SATestAdd.py ++++ b/utils/analyzer/SATestAdd.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + Static Analyzer qualification infrastructure: adding a new project to +diff --git a/utils/analyzer/SATestBuild.py b/utils/analyzer/SATestBuild.py +index 691ded80..b17b3db1 100755 +--- a/utils/analyzer/SATestBuild.py ++++ b/utils/analyzer/SATestBuild.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + Static Analyzer qualification infrastructure. +diff --git a/utils/analyzer/SATestUpdateDiffs.py b/utils/analyzer/SATestUpdateDiffs.py +index ea3c08cc..08e3f82f 100755 +--- a/utils/analyzer/SATestUpdateDiffs.py ++++ b/utils/analyzer/SATestUpdateDiffs.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + Update reference results for static analyzer. +diff --git a/utils/analyzer/SumTimerInfo.py b/utils/analyzer/SumTimerInfo.py +index 36e519ad..d1934f19 100644 +--- a/utils/analyzer/SumTimerInfo.py ++++ b/utils/analyzer/SumTimerInfo.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """ + Script to Summarize statistics in the scan-build output. +diff --git a/utils/analyzer/exploded-graph-rewriter.py b/utils/analyzer/exploded-graph-rewriter.py +index 5ce56d61..808f21c9 100755 +--- a/utils/analyzer/exploded-graph-rewriter.py ++++ b/utils/analyzer/exploded-graph-rewriter.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # + #===- exploded-graph-rewriter.py - ExplodedGraph dump tool -----*- python -*--# + # +diff --git a/utils/check_cfc/check_cfc.py b/utils/check_cfc/check_cfc.py +index 311f502f..0bbbc088 100755 +--- a/utils/check_cfc/check_cfc.py ++++ b/utils/check_cfc/check_cfc.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """Check CFC - Check Compile Flow Consistency + +diff --git a/utils/check_cfc/obj_diff.py b/utils/check_cfc/obj_diff.py +index a0951c5b..b3866948 100755 +--- a/utils/check_cfc/obj_diff.py ++++ b/utils/check_cfc/obj_diff.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + from __future__ import absolute_import, division, print_function + +diff --git a/utils/check_cfc/test_check_cfc.py b/utils/check_cfc/test_check_cfc.py +index 0808252a..6f149ebc 100755 +--- a/utils/check_cfc/test_check_cfc.py ++++ b/utils/check_cfc/test_check_cfc.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + """Test internal functions within check_cfc.py.""" + +diff --git a/utils/creduce-clang-crash.py b/utils/creduce-clang-crash.py +index be16211c..e56f3697 100755 +--- a/utils/creduce-clang-crash.py ++++ b/utils/creduce-clang-crash.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + """Calls C-Reduce to create a minimal reproducer for clang crashes. + + Output files: +diff --git a/utils/hmaptool/hmaptool b/utils/hmaptool/hmaptool +index 58baab2f..00296f11 100755 +--- a/utils/hmaptool/hmaptool ++++ b/utils/hmaptool/hmaptool +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + from __future__ import absolute_import, division, print_function + + import json +diff --git a/utils/modfuzz.py b/utils/modfuzz.py +index 61ca3272..19a9807b 100644 +--- a/utils/modfuzz.py ++++ b/utils/modfuzz.py +@@ -1,4 +1,4 @@ +-#! /usr/bin/env python ++#! /usr/bin/env python3 + + # To use: + # 1) Update the 'decls' list below with your fuzzing configuration. +diff --git a/utils/token-delta.py b/utils/token-delta.py +index 62b4eb3c..022fb2f8 100755 +--- a/utils/token-delta.py ++++ b/utils/token-delta.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + from __future__ import absolute_import, division, print_function + import os +diff --git a/www/builtins.py b/www/builtins.py +index f0bcf196..54901487 100755 +--- a/www/builtins.py ++++ b/www/builtins.py +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + import sys, fileinput + +diff --git a/www/make_cxx_dr_status b/www/make_cxx_dr_status +index 2d7c1f32..bc24cd12 100755 +--- a/www/make_cxx_dr_status ++++ b/www/make_cxx_dr_status +@@ -1,4 +1,4 @@ +-#! /usr/bin/env python ++#! /usr/bin/env python3 + import sys, os, re + + index = 'cwg_index.html' + diff --git a/base/clang/clang.SMBuild b/base/clang/clang.SMBuild new file mode 100755 index 0000000..78c412e --- /dev/null +++ b/base/clang/clang.SMBuild @@ -0,0 +1,52 @@ +APP=clang +VERSION=10.0.1 +BUILD=1sml +HOMEPAGE='https://clang.llvm.org/' +DOWNLOAD="" +REQUIRES="llvm" +DESC="LLVM project-based C language family front-end" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION".src" + + tar xf $SRCDIR/$APP-$VERSION".src".tar.?z* + cd $APP-$VERSION".src" + fixbuilddirpermissions + + patch -p1 < $SRCDIR/10-add-musl-triples.patch + patch -p1 < $SRCDIR/30-fix-python-shebangs.patch + + unset CFLAGS CXXFLAGS + + mkdir -p smbuild && cd smbuild + cmake .. -G Ninja -Wno-dev \ + -DCMAKE_BUILD_TYPE=MinSizeRel \ + -DCMAKE_INSTALL_PREFIX="" \ + -DCLANG_BUILD_EXAMPLES=OFF \ + -DLLVM_LINK_LLVM_DYLIB=ON \ + -DCLANG_LINK_CLANG_DYLIB=ON \ + -DLLVM_INCLUDE_DOCS=OFF \ + -DCMAKE_VERBOSE_MAKEFILE=OFF \ + -DCLANG_INCLUDE_TESTS=ON \ + -DCLANG_PLUGIN_SUPPORT=ON \ + -DLIBCLANG_BUILD_STATIC=ON \ + -DLLVM_ENABLE_EH=ON \ + -DLLVM_ENABLE_RTTI=ON \ + -DCLANG_VENDOR=SMLinux + + ninja clang-tblgen + ninja $MAKEFLAGS + + DESTDIR="$PKG" ninja install + + cp ../LICENSE.TXT $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c6712d491ce5e166ef72724cf855d742d88da825ffc25585612d7f2eb7770343e3ae48fa78e0af3e5d5efdde3a9686a7361dac3b546a4378de22448ea6e4026c clang-10.0.1.src.tar.xz +533558863dc7247202b2a739e1bd2d81a99a16be329370cb734d338284b5408ecd14fe78ac836aaf922e377334b7a3ebef532cf8395d91aafe346bf71eb8b7fc 10-add-musl-triples.patch +c7f34b425b0dcea9752eeb7ff3d3a33af9cc45740fd3e77d52e4d610c5fd3daaa4d59138a255b057ef886915615a77ec1e6a447f3818b4b2724129c0ba354932 30-fix-python-shebangs.patch +" diff --git a/base/cmake/cmake.SMBuild b/base/cmake/cmake.SMBuild new file mode 100755 index 0000000..cda1977 --- /dev/null +++ b/base/cmake/cmake.SMBuild @@ -0,0 +1,40 @@ +APP=cmake +VERSION=3.17.3 +BUILD=1sml +HOMEPAGE='http://www.cmake.org' +DOWNLOAD='https://cmake.org/files/v3.17/cmake-3.17.3.tar.gz' +DESC="Cross-platform, open-source make system" +REQUIRES="gcc-libs openssl libunistring libidn2" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + para="$(echo $MAKEFLAGS | sed 's/-j//')" + + ./bootstrap \ + --prefix="" \ + --no-system-curl \ + --no-system-expat \ + --no-system-jsoncpp \ + --no-system-zlib \ + --no-system-bzip2 \ + --no-system-libarchive \ + --no-qt-gui \ + --parallel="$para" + + make + make install DESTDIR=$PKG + + cp Licenses/* Copyright.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e68eb80a294a4ee441f5e29b95a6450677ef8d7a8aa40e29e7475db9aa7566edd903ce4bfb57a0795f8e31dd29f16620f588b81b5fd9f74e80f996de980bccd3 cmake-3.17.3.tar.lz +" diff --git a/base/coreutils/coreutils.SMBuild b/base/coreutils/coreutils.SMBuild new file mode 100755 index 0000000..841372a --- /dev/null +++ b/base/coreutils/coreutils.SMBuild @@ -0,0 +1,39 @@ +APP=coreutils +VERSION=8.32 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/coreutils/coreutils.html' +DOWNLOAD='http://ftp.gnu.org/gnu/coreutils/coreutils-8.32.tar.xz' +DESC="Core GNU utilities" +REQUIRES="attr acl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/ls.patch + + FORCE_UNSAFE_CONFIGURE=1 \ + CFLAGS="$CFLAGS -static" \ + ./configure \ + --prefix="" \ + --bindir=/bin \ + --libexecdir=/lib \ + --without-gmp \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e4473c87948904b017fef23d1c81cafdf0d6d282cd6dd9d402d3dc718642f392029933cd7b161f73d6b69523ca12458066ba2804201a1ce256da753fa521f54c coreutils-8.32.tar.lz +2742d74c45bdb52c524d415fb0787ed63164aec2c22980a1c46b40b7db2f0911008161b1219d5b571cc25de274bacc20c8be3f651906967a032a3ac9859cffce ls.patch +" diff --git a/base/coreutils/ls.patch b/base/coreutils/ls.patch new file mode 100644 index 0000000..0e2057c --- /dev/null +++ b/base/coreutils/ls.patch @@ -0,0 +1,25 @@ +../src/ls.c: In function 'print_dir': + +../src/ls.c:3026:24: error: 'SYS_getdents' undeclared (first use in this function); did you mean 'SYS_getdents64'? + + 3026 | if (syscall (SYS_getdents, dirfd (dirp), NULL, 0) == -1 + + | ^~~~~~~~~~~~ + + | SYS_getdents64 + +../src/ls.c:3026:24: note: each undeclared identifier is reported only once for each function it appears in + +diff --git a/src/ls.c b/src/ls.c +index 24b9832..64ecf40 100644 +--- a/src/ls.c ++++ b/src/ls.c +@@ -3018,7 +3018,7 @@ print_dir (char const *name, char const *realname, bool command_line_arg) + if (errno != EOVERFLOW) + break; + } +-#ifdef __linux__ ++#if defined(__linux__) && defined(__x86_64__) + else if (! found_any_entries) + { + /* If readdir finds no directory entries at all, not even "." or diff --git a/base/cpio/cpio.SMBuild b/base/cpio/cpio.SMBuild new file mode 100755 index 0000000..58bd773 --- /dev/null +++ b/base/cpio/cpio.SMBuild @@ -0,0 +1,32 @@ +APP=cpio +VERSION=2.13 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/cpio/' +DOWNLOAD='https://ftp.gnu.org/gnu/cpio/cpio-2.13.tar.gz' +DESC="Backup and archiving utility" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="$CFLAGS -fcommon" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp -a COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +078d5d0ab398adb76b0a4e83a07821edf2cca5e84308ef547fd530c6c6c3d4b8577833581614aedfd23ca697cab058672dba7886642d8a3eb9ae769c10d672e8 cpio-2.13.tar.lz +" diff --git a/base/crda/01-Makefile-dont-run-ldconfig.patch b/base/crda/01-Makefile-dont-run-ldconfig.patch new file mode 100644 index 0000000..d1e7477 --- /dev/null +++ b/base/crda/01-Makefile-dont-run-ldconfig.patch @@ -0,0 +1,10 @@ +--- a/Makefile 2014-12-11 00:51:29.000000000 +0100 ++++ b/Makefile 2016-04-23 03:03:33.785974265 +0200 +@@ -127,7 +127,6 @@ + $(NQ) ' INSTALL libreg' + $(Q)mkdir -p $(DESTDIR)/$(LIBDIR) + $(Q)cp $(LIBREG) $(DESTDIR)/$(LIBDIR)/ +- $(Q)ldconfig + + %.o: %.c regdb.h $(LIBREG) + $(NQ) ' CC ' $@ diff --git a/base/crda/crda-4.14-python-3.patch b/base/crda/crda-4.14-python-3.patch new file mode 100644 index 0000000..8dc7aec --- /dev/null +++ b/base/crda/crda-4.14-python-3.patch @@ -0,0 +1,95 @@ +diff --git a/utils/key2pub.py b/utils/key2pub.py +index 9bb04cd..632e6a6 100755 +--- a/utils/key2pub.py ++++ b/utils/key2pub.py +@@ -3,20 +3,20 @@ + import sys + try: + from M2Crypto import RSA +-except ImportError, e: ++except ImportError as e: + sys.stderr.write('ERROR: Failed to import the "M2Crypto" module: %s\n' % e.message) + sys.stderr.write('Please install the "M2Crypto" Python module.\n') + sys.stderr.write('On Debian GNU/Linux the package is called "python-m2crypto".\n') + sys.exit(1) + + def print_ssl_64(output, name, val): +- while val[0] == '\0': ++ while val[0:1] == b'\0': + val = val[1:] + while len(val) % 8: +- val = '\0' + val ++ val = b'\0' + val + vnew = [] + while len(val): +- vnew.append((val[0], val[1], val[2], val[3], val[4], val[5], val[6], val[7])) ++ vnew.append((val[0:1], val[1:2], val[2:3], val[3:4], val[4:5], val[5:6], val[6:7], val[7:8])) + val = val[8:] + vnew.reverse() + output.write('static BN_ULONG %s[%d] = {\n' % (name, len(vnew))) +@@ -34,13 +34,13 @@ def print_ssl_64(output, name, val): + output.write('};\n\n') + + def print_ssl_32(output, name, val): +- while val[0] == '\0': ++ while val[0:1] == b'\0': + val = val[1:] + while len(val) % 4: +- val = '\0' + val ++ val = b'\0' + val + vnew = [] + while len(val): +- vnew.append((val[0], val[1], val[2], val[3], )) ++ vnew.append((val[0:1], val[1:2], val[2:3], val[3:4])) + val = val[4:] + vnew.reverse() + output.write('static BN_ULONG %s[%d] = {\n' % (name, len(vnew))) +@@ -80,21 +80,21 @@ struct pubkey { + + static struct pubkey keys[] = { + ''') +- for n in xrange(n + 1): ++ for n in range(n + 1): + output.write(' KEYS(e_%d, n_%d),\n' % (n, n)) + output.write('};\n') + pass + + def print_gcrypt(output, name, val): + output.write('#include \n') +- while val[0] == '\0': ++ while val[0:1] == b'\0': + val = val[1:] + output.write('static const uint8_t %s[%d] = {\n' % (name, len(val))) + idx = 0 + for v in val: + if not idx: + output.write('\t') +- output.write('0x%.2x, ' % ord(v)) ++ output.write('0x%.2x, ' % (v if sys.version_info[0] >=3 else ord(v))) + idx += 1 + if idx == 8: + idx = 0 +@@ -117,7 +117,7 @@ struct key_params { + + static const struct key_params __attribute__ ((unused)) keys[] = { + ''') +- for n in xrange(n + 1): ++ for n in range(n + 1): + output.write(' KEYS(e_%d, n_%d),\n' % (n, n)) + output.write('};\n') + +@@ -135,7 +135,7 @@ except IndexError: + mode = None + + if not mode in modes: +- print 'Usage: %s [%s] input-file... output-file' % (sys.argv[0], '|'.join(modes.keys())) ++ print('Usage: %s [%s] input-file... output-file' % (sys.argv[0], '|'.join(modes.keys()))) + sys.exit(2) + + output = open(outfile, 'w') +@@ -153,3 +153,5 @@ for f in files: + idx += 1 + + modes[mode][1](output, idx - 1) ++ ++output.close() diff --git a/base/crda/crda.SMBuild b/base/crda/crda.SMBuild new file mode 100755 index 0000000..15aa394 --- /dev/null +++ b/base/crda/crda.SMBuild @@ -0,0 +1,35 @@ +APP=crda +VERSION=4.14 +BUILD=2sml +REQUIRES="libnl libgcrypt python-m2crypto" +DESC="Udev wrapper for communicating between kernel and userspace" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Thank you alpine linux + patch -p1 < $SRCDIR/01-Makefile-dont-run-ldconfig.patch + # Thank you arch linux + patch -p1 < $SRCDIR/crda-4.14-python-3.patch + + # Disable -Werror, just in case + sed -i 's@-Werror@@g' Makefile + + make V=1 PREFIX="/" SBINDIR="/bin" + make install PREFIX="/" SBINDIR="/bin" DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d75990625c8ccc04beb7d300d519d18b715c8cc0a2ba231dc0dd6b9fe2906f20cd53609ef8f07ae74f4c2437dea47d8246b6319e9b02e4c905359854ca5db9b7 crda-4.14.tar.xz +c642976b193722c0050c13331a010b466cea8391bb5f945832604a556e274ea1a4b289c78f74ff5d502fae800f18219db3d10ff10c0528eefc5e9443a963640f 01-Makefile-dont-run-ldconfig.patch +6ab136d1a8fe59a6e1d92d8e07d2074bad7c663162e03b00916bb26c382ef66876b61b0f11b86a5705cc493d666497fd96d94b9d3f469b4bdedc37acf391d5e1 crda-4.14-python-3.patch +" diff --git a/base/cryptsetup/cryptsetup.SMBuild b/base/cryptsetup/cryptsetup.SMBuild new file mode 100755 index 0000000..b7f7205 --- /dev/null +++ b/base/cryptsetup/cryptsetup.SMBuild @@ -0,0 +1,33 @@ +APP=cryptsetup +VERSION=1.7.4 +BUILD=1sml +HOMEPAGE="https://github.com/mbroz/cryptsetup" +DOWNLOAD="https://github.com/mbroz/cryptsetup/archive/refs/tags/v1_7_4.tar.gz" +DESC="Utility for setting up encrypted filesystems" +REQUIRES="popt util-linux libgpg-error libgcrypt lvm" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sbindir=/bin \ + --libdir=/lib \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b4fc1a2be208ebc795057964fd3d1d3756af9b07f0ae33bdd185ff1415961be70f380b0d98583a25e044dee3605997b96cdc3ea3e34ed3a4cb14cf1f48f65446 cryptsetup-1.7.4.tar.lz +" diff --git a/base/curl/cacert-fetch.sh b/base/curl/cacert-fetch.sh new file mode 100755 index 0000000..d0f156e --- /dev/null +++ b/base/curl/cacert-fetch.sh @@ -0,0 +1 @@ +lftpget http://curl.haxx.se/ca/cacert.pem && rm cacert.pem.bz2 && bzip2 -9 cacert.pem diff --git a/base/curl/cacert.pem b/base/curl/cacert.pem new file mode 100644 index 0000000..09b4ce1 --- /dev/null +++ b/base/curl/cacert.pem @@ -0,0 +1,3401 @@ +## +## Bundle of CA Root Certificates +## +## Certificate data from Mozilla as of: Wed Jan 23 04:12:09 2019 GMT +## +## This is a bundle of X.509 certificates of public Certificate Authorities +## (CA). These were automatically extracted from Mozilla's root certificates +## file (certdata.txt). This file can be found in the mozilla source tree: +## https://hg.mozilla.org/releases/mozilla-release/raw-file/default/security/nss/lib/ckfw/builtins/certdata.txt +## +## It contains the certificates in PEM format and therefore +## can be directly used with curl / libcurl / php_curl, or with +## an Apache+mod_ssl webserver for SSL client authentication. +## Just configure this file as the SSLCACertificateFile. +## +## Conversion done with mk-ca-bundle.pl version 1.27. +## SHA256: 18372117493b5b7ec006c31d966143fc95a9464a2b5f8d5188e23c5557b2292d +## + + +GlobalSign Root CA +================== +-----BEGIN CERTIFICATE----- +MIIDdTCCAl2gAwIBAgILBAAAAAABFUtaw5QwDQYJKoZIhvcNAQEFBQAwVzELMAkGA1UEBhMCQkUx +GTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2ExEDAOBgNVBAsTB1Jvb3QgQ0ExGzAZBgNVBAMTEkds +b2JhbFNpZ24gUm9vdCBDQTAeFw05ODA5MDExMjAwMDBaFw0yODAxMjgxMjAwMDBaMFcxCzAJBgNV +BAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRAwDgYDVQQLEwdSb290IENBMRswGQYD +VQQDExJHbG9iYWxTaWduIFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDa +DuaZjc6j40+Kfvvxi4Mla+pIH/EqsLmVEQS98GPR4mdmzxzdzxtIK+6NiY6arymAZavpxy0Sy6sc +THAHoT0KMM0VjU/43dSMUBUc71DuxC73/OlS8pF94G3VNTCOXkNz8kHp1Wrjsok6Vjk4bwY8iGlb +Kk3Fp1S4bInMm/k8yuX9ifUSPJJ4ltbcdG6TRGHRjcdGsnUOhugZitVtbNV4FpWi6cgKOOvyJBNP +c1STE4U6G7weNLWLBYy5d4ux2x8gkasJU26Qzns3dLlwR5EiUWMWea6xrkEmCMgZK9FGqkjWZCrX +gzT/LCrBbBlDSgeF59N89iFo7+ryUp9/k5DPAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNV +HRMBAf8EBTADAQH/MB0GA1UdDgQWBBRge2YaRQ2XyolQL30EzTSo//z9SzANBgkqhkiG9w0BAQUF +AAOCAQEA1nPnfE920I2/7LqivjTFKDK1fPxsnCwrvQmeU79rXqoRSLblCKOzyj1hTdNGCbM+w6Dj +Y1Ub8rrvrTnhQ7k4o+YviiY776BQVvnGCv04zcQLcFGUl5gE38NflNUVyRRBnMRddWQVDf9VMOyG +j/8N7yy5Y0b2qvzfvGn9LhJIZJrglfCm7ymPAbEVtQwdpf5pLGkkeB6zpxxxYu7KyJesF12KwvhH +hm4qxFYxldBniYUr+WymXUadDKqC5JlR3XC321Y9YeRq4VzW9v493kHMB65jUr9TU/Qr6cf9tveC +X4XSQRjbgbMEHMUfpIBvFSDJ3gyICh3WZlXi/EjJKSZp4A== +-----END CERTIFICATE----- + +GlobalSign Root CA - R2 +======================= +-----BEGIN CERTIFICATE----- +MIIDujCCAqKgAwIBAgILBAAAAAABD4Ym5g0wDQYJKoZIhvcNAQEFBQAwTDEgMB4GA1UECxMXR2xv +YmFsU2lnbiBSb290IENBIC0gUjIxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2Jh +bFNpZ24wHhcNMDYxMjE1MDgwMDAwWhcNMjExMjE1MDgwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxT +aWduIFJvb3QgQ0EgLSBSMjETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2ln +bjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKbPJA6+Lm8omUVCxKs+IVSbC9N/hHD6 +ErPLv4dfxn+G07IwXNb9rfF73OX4YJYJkhD10FPe+3t+c4isUoh7SqbKSaZeqKeMWhG8eoLrvozp +s6yWJQeXSpkqBy+0Hne/ig+1AnwblrjFuTosvNYSuetZfeLQBoZfXklqtTleiDTsvHgMCJiEbKjN +S7SgfQx5TfC4LcshytVsW33hoCmEofnTlEnLJGKRILzdC9XZzPnqJworc5HGnRusyMvo4KD0L5CL +TfuwNhv2GXqF4G3yYROIXJ/gkwpRl4pazq+r1feqCapgvdzZX99yqWATXgAByUr6P6TqBwMhAo6C +ygPCm48CAwEAAaOBnDCBmTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E +FgQUm+IHV2ccHsBqBt5ZtJot39wZhi4wNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5nbG9i +YWxzaWduLm5ldC9yb290LXIyLmNybDAfBgNVHSMEGDAWgBSb4gdXZxwewGoG3lm0mi3f3BmGLjAN +BgkqhkiG9w0BAQUFAAOCAQEAmYFThxxol4aR7OBKuEQLq4GsJ0/WwbgcQ3izDJr86iw8bmEbTUsp +9Z8FHSbBuOmDAGJFtqkIk7mpM0sYmsL4h4hO291xNBrBVNpGP+DTKqttVCL1OmLNIG+6KYnX3ZHu +01yiPqFbQfXf5WRDLenVOavSot+3i9DAgBkcRcAtjOj4LaR0VknFBbVPFd5uRHg5h6h+u/N5GJG7 +9G+dwfCMNYxdAfvDbbnvRG15RjF+Cv6pgsH/76tuIMRQyV+dTZsXjAzlAcmgQWpzU/qlULRuJQ/7 +TBj0/VLZjmmx6BEP3ojY+x1J96relc8geMJgEtslQIxq/H5COEBkEveegeGTLg== +-----END CERTIFICATE----- + +Verisign Class 3 Public Primary Certification Authority - G3 +============================================================ +-----BEGIN CERTIFICATE----- +MIIEGjCCAwICEQCbfgZJoz5iudXukEhxKe9XMA0GCSqGSIb3DQEBBQUAMIHKMQswCQYDVQQGEwJV +UzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdv +cmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl +IG9ubHkxRTBDBgNVBAMTPFZlcmlTaWduIENsYXNzIDMgUHVibGljIFByaW1hcnkgQ2VydGlmaWNh +dGlvbiBBdXRob3JpdHkgLSBHMzAeFw05OTEwMDEwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMIHKMQsw +CQYDVQQGEwJVUzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRy +dXN0IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAxOTk5IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhv +cml6ZWQgdXNlIG9ubHkxRTBDBgNVBAMTPFZlcmlTaWduIENsYXNzIDMgUHVibGljIFByaW1hcnkg +Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC +ggEBAMu6nFL8eB8aHm8bN3O9+MlrlBIwT/A2R/XQkQr1F8ilYcEWQE37imGQ5XYgwREGfassbqb1 +EUGO+i2tKmFZpGcmTNDovFJbcCAEWNF6yaRpvIMXZK0Fi7zQWM6NjPXr8EJJC52XJ2cybuGukxUc +cLwgTS8Y3pKI6GyFVxEa6X7jJhFUokWWVYPKMIno3Nij7SqAP395ZVc+FSBmCC+Vk7+qRy+oRpfw +EuL+wgorUeZ25rdGt+INpsyow0xZVYnm6FNcHOqd8GIWC6fJXwzw3sJ2zq/3avL6QaaiMxTJ5Xpj +055iN9WFZZ4O5lMkdBteHRJTW8cs54NJOxWuimi5V5cCAwEAATANBgkqhkiG9w0BAQUFAAOCAQEA +ERSWwauSCPc/L8my/uRan2Te2yFPhpk0djZX3dAVL8WtfxUfN2JzPtTnX84XA9s1+ivbrmAJXx5f +j267Cz3qWhMeDGBvtcC1IyIuBwvLqXTLR7sdwdela8wv0kL9Sd2nic9TutoAWii/gt/4uhMdUIaC +/Y4wjylGsB49Ndo4YhYYSq3mtlFs3q9i6wHQHiT+eo8SGhJouPtmmRQURVyu565pF4ErWjfJXir0 +xuKhXFSbplQAz/DxwceYMBo7Nhbbo27q/a2ywtrvAkcTisDxszGtTxzhT5yvDwyd93gN2PQ1VoDa +t20Xj50egWTh/sVFuq1ruQp6Tk9LhO5L8X3dEQ== +-----END CERTIFICATE----- + +Entrust.net Premium 2048 Secure Server CA +========================================= +-----BEGIN CERTIFICATE----- +MIIEKjCCAxKgAwIBAgIEOGPe+DANBgkqhkiG9w0BAQUFADCBtDEUMBIGA1UEChMLRW50cnVzdC5u +ZXQxQDA+BgNVBAsUN3d3dy5lbnRydXN0Lm5ldC9DUFNfMjA0OCBpbmNvcnAuIGJ5IHJlZi4gKGxp +bWl0cyBsaWFiLikxJTAjBgNVBAsTHChjKSAxOTk5IEVudHJ1c3QubmV0IExpbWl0ZWQxMzAxBgNV +BAMTKkVudHJ1c3QubmV0IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ICgyMDQ4KTAeFw05OTEyMjQx +NzUwNTFaFw0yOTA3MjQxNDE1MTJaMIG0MRQwEgYDVQQKEwtFbnRydXN0Lm5ldDFAMD4GA1UECxQ3 +d3d3LmVudHJ1c3QubmV0L0NQU18yMDQ4IGluY29ycC4gYnkgcmVmLiAobGltaXRzIGxpYWIuKTEl +MCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRlZDEzMDEGA1UEAxMqRW50cnVzdC5u +ZXQgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgKDIwNDgpMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEArU1LqRKGsuqjIAcVFmQqK0vRvwtKTY7tgHalZ7d4QMBzQshowNtTK91euHaYNZOL +Gp18EzoOH1u3Hs/lJBQesYGpjX24zGtLA/ECDNyrpUAkAH90lKGdCCmziAv1h3edVc3kw37XamSr +hRSGlVuXMlBvPci6Zgzj/L24ScF2iUkZ/cCovYmjZy/Gn7xxGWC4LeksyZB2ZnuU4q941mVTXTzW +nLLPKQP5L6RQstRIzgUyVYr9smRMDuSYB3Xbf9+5CFVghTAp+XtIpGmG4zU/HoZdenoVve8AjhUi +VBcAkCaTvA5JaJG/+EfTnZVCwQ5N328mz8MYIWJmQ3DW1cAH4QIDAQABo0IwQDAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUVeSB0RGAvtiJuQijMfmhJAkWuXAwDQYJ +KoZIhvcNAQEFBQADggEBADubj1abMOdTmXx6eadNl9cZlZD7Bh/KM3xGY4+WZiT6QBshJ8rmcnPy +T/4xmf3IDExoU8aAghOY+rat2l098c5u9hURlIIM7j+VrxGrD9cv3h8Dj1csHsm7mhpElesYT6Yf +zX1XEC+bBAlahLVu2B064dae0Wx5XnkcFMXj0EyTO2U87d89vqbllRrDtRnDvV5bu/8j72gZyxKT +J1wDLW8w0B62GqzeWvfRqqgnpv55gcR5mTNXuhKwqeBCbJPKVt7+bYQLCIt+jerXmCHG8+c8eS9e +nNFMFY3h7CI3zJpDC5fcgJCNs2ebb0gIFVbPv/ErfF6adulZkMV8gzURZVE= +-----END CERTIFICATE----- + +Baltimore CyberTrust Root +========================= +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIEAgAAuTANBgkqhkiG9w0BAQUFADBaMQswCQYDVQQGEwJJRTESMBAGA1UE +ChMJQmFsdGltb3JlMRMwEQYDVQQLEwpDeWJlclRydXN0MSIwIAYDVQQDExlCYWx0aW1vcmUgQ3li +ZXJUcnVzdCBSb290MB4XDTAwMDUxMjE4NDYwMFoXDTI1MDUxMjIzNTkwMFowWjELMAkGA1UEBhMC +SUUxEjAQBgNVBAoTCUJhbHRpbW9yZTETMBEGA1UECxMKQ3liZXJUcnVzdDEiMCAGA1UEAxMZQmFs +dGltb3JlIEN5YmVyVHJ1c3QgUm9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKME +uyKrmD1X6CZymrV51Cni4eiVgLGw41uOKymaZN+hXe2wCQVt2yguzmKiYv60iNoS6zjrIZ3AQSsB +UnuId9Mcj8e6uYi1agnnc+gRQKfRzMpijS3ljwumUNKoUMMo6vWrJYeKmpYcqWe4PwzV9/lSEy/C +G9VwcPCPwBLKBsua4dnKM3p31vjsufFoREJIE9LAwqSuXmD+tqYF/LTdB1kC1FkYmGP1pWPgkAx9 +XbIGevOF6uvUA65ehD5f/xXtabz5OTZydc93Uk3zyZAsuT3lySNTPx8kmCFcB5kpvcY67Oduhjpr +l3RjM71oGDHweI12v/yejl0qhqdNkNwnGjkCAwEAAaNFMEMwHQYDVR0OBBYEFOWdWTCCR1jMrPoI +VDaGezq1BE3wMBIGA1UdEwEB/wQIMAYBAf8CAQMwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEB +BQUAA4IBAQCFDF2O5G9RaEIFoN27TyclhAO992T9Ldcw46QQF+vaKSm2eT929hkTI7gQCvlYpNRh +cL0EYWoSihfVCr3FvDB81ukMJY2GQE/szKN+OMY3EU/t3WgxjkzSswF07r51XgdIGn9w/xZchMB5 +hbgF/X++ZRGjD8ACtPhSNzkE1akxehi/oCr0Epn3o0WC4zxe9Z2etciefC7IpJ5OCBRLbf1wbWsa +Y71k5h+3zvDyny67G7fyUIhzksLi4xaNmjICq44Y3ekQEe5+NauQrz4wlHrQMz2nZQ/1/I6eYs9H +RCwBXbsdtTLSR9I4LtD+gdwyah617jzV/OeBHRnDJELqYzmp +-----END CERTIFICATE----- + +AddTrust External Root +====================== +-----BEGIN CERTIFICATE----- +MIIENjCCAx6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBvMQswCQYDVQQGEwJTRTEUMBIGA1UEChML +QWRkVHJ1c3QgQUIxJjAkBgNVBAsTHUFkZFRydXN0IEV4dGVybmFsIFRUUCBOZXR3b3JrMSIwIAYD +VQQDExlBZGRUcnVzdCBFeHRlcm5hbCBDQSBSb290MB4XDTAwMDUzMDEwNDgzOFoXDTIwMDUzMDEw +NDgzOFowbzELMAkGA1UEBhMCU0UxFDASBgNVBAoTC0FkZFRydXN0IEFCMSYwJAYDVQQLEx1BZGRU +cnVzdCBFeHRlcm5hbCBUVFAgTmV0d29yazEiMCAGA1UEAxMZQWRkVHJ1c3QgRXh0ZXJuYWwgQ0Eg +Um9vdDCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALf3GjPm8gAELTngTlvtH7xsD821 ++iO2zt6bETOXpClMfZOfvUq8k+0DGuOPz+VtUFrWlymUWoCwSXrbLpX9uMq/NzgtHj6RQa1wVsfw +Tz/oMp50ysiQVOnGXw94nZpAPA6sYapeFI+eh6FqUNzXmk6vBbOmcZSccbNQYArHE504B4YCqOmo +aSYYkKtMsE8jqzpPhNjfzp/haW+710LXa0Tkx63ubUFfclpxCDezeWWkWaCUN/cALw3CknLa0Dhy +2xSoRcRdKn23tNbE7qzNE0S3ySvdQwAl+mG5aWpYIxG3pzOPVnVZ9c0p10a3CitlttNCbxWyuHv7 +7+ldU9U0WicCAwEAAaOB3DCB2TAdBgNVHQ4EFgQUrb2YejS0Jvf6xCZU7wO94CTLVBowCwYDVR0P +BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wgZkGA1UdIwSBkTCBjoAUrb2YejS0Jvf6xCZU7wO94CTL +VBqhc6RxMG8xCzAJBgNVBAYTAlNFMRQwEgYDVQQKEwtBZGRUcnVzdCBBQjEmMCQGA1UECxMdQWRk +VHJ1c3QgRXh0ZXJuYWwgVFRQIE5ldHdvcmsxIjAgBgNVBAMTGUFkZFRydXN0IEV4dGVybmFsIENB +IFJvb3SCAQEwDQYJKoZIhvcNAQEFBQADggEBALCb4IUlwtYj4g+WBpKdQZic2YR5gdkeWxQHIzZl +j7DYd7usQWxHYINRsPkyPef89iYTx4AWpb9a/IfPeHmJIZriTAcKhjW88t5RxNKWt9x+Tu5w/Rw5 +6wwCURQtjr0W4MHfRnXnJK3s9EK0hZNwEGe6nQY1ShjTK3rMUUKhemPR5ruhxSvCNr4TDea9Y355 +e6cJDUCrat2PisP29owaQgVR1EX1n6diIWgVIEM8med8vSTYqZEXc4g/VhsxOBi0cQ+azcgOno4u +G+GMmIPLHzHxREzGBHNJdmAPx/i9F4BrLunMTA5amnkPIAou1Z5jJh5VkpTYghdae9C8x49OhgQ= +-----END CERTIFICATE----- + +Entrust Root Certification Authority +==================================== +-----BEGIN CERTIFICATE----- +MIIEkTCCA3mgAwIBAgIERWtQVDANBgkqhkiG9w0BAQUFADCBsDELMAkGA1UEBhMCVVMxFjAUBgNV +BAoTDUVudHJ1c3QsIEluYy4xOTA3BgNVBAsTMHd3dy5lbnRydXN0Lm5ldC9DUFMgaXMgaW5jb3Jw +b3JhdGVkIGJ5IHJlZmVyZW5jZTEfMB0GA1UECxMWKGMpIDIwMDYgRW50cnVzdCwgSW5jLjEtMCsG +A1UEAxMkRW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTA2MTEyNzIwMjM0 +MloXDTI2MTEyNzIwNTM0MlowgbAxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1FbnRydXN0LCBJbmMu +MTkwNwYDVQQLEzB3d3cuZW50cnVzdC5uZXQvQ1BTIGlzIGluY29ycG9yYXRlZCBieSByZWZlcmVu +Y2UxHzAdBgNVBAsTFihjKSAyMDA2IEVudHJ1c3QsIEluYy4xLTArBgNVBAMTJEVudHJ1c3QgUm9v +dCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB +ALaVtkNC+sZtKm9I35RMOVcF7sN5EUFoNu3s/poBj6E4KPz3EEZmLk0eGrEaTsbRwJWIsMn/MYsz +A9u3g3s+IIRe7bJWKKf44LlAcTfFy0cOlypowCKVYhXbR9n10Cv/gkvJrT7eTNuQgFA/CYqEAOww +Cj0Yzfv9KlmaI5UXLEWeH25DeW0MXJj+SKfFI0dcXv1u5x609mhF0YaDW6KKjbHjKYD+JXGIrb68 +j6xSlkuqUY3kEzEZ6E5Nn9uss2rVvDlUccp6en+Q3X0dgNmBu1kmwhH+5pPi94DkZfs0Nw4pgHBN +rziGLp5/V6+eF67rHMsoIV+2HNjnogQi+dPa2MsCAwEAAaOBsDCBrTAOBgNVHQ8BAf8EBAMCAQYw +DwYDVR0TAQH/BAUwAwEB/zArBgNVHRAEJDAigA8yMDA2MTEyNzIwMjM0MlqBDzIwMjYxMTI3MjA1 +MzQyWjAfBgNVHSMEGDAWgBRokORnpKZTgMeGZqTx90tD+4S9bTAdBgNVHQ4EFgQUaJDkZ6SmU4DH +hmak8fdLQ/uEvW0wHQYJKoZIhvZ9B0EABBAwDhsIVjcuMTo0LjADAgSQMA0GCSqGSIb3DQEBBQUA +A4IBAQCT1DCw1wMgKtD5Y+iRDAUgqV8ZyntyTtSx29CW+1RaGSwMCPeyvIWonX9tO1KzKtvn1ISM +Y/YPyyYBkVBs9F8U4pN0wBOeMDpQ47RgxRzwIkSNcUesyBrJ6ZuaAGAT/3B+XxFNSRuzFVJ7yVTa +v52Vr2ua2J7p8eRDjeIRRDq/r72DQnNSi6q7pynP9WQcCk3RvKqsnyrQ/39/2n3qse0wJcGE2jTS +W3iDVuycNsMm4hH2Z0kdkquM++v/eu6FSqdQgPCnXEqULl8FmTxSQeDNtGPPAUO6nIPcj2A781q0 +tHuu2guQOHXvgR1m0vdXcDazv/wor3ElhVsT/h5/WrQ8 +-----END CERTIFICATE----- + +GeoTrust Global CA +================== +-----BEGIN CERTIFICATE----- +MIIDVDCCAjygAwIBAgIDAjRWMA0GCSqGSIb3DQEBBQUAMEIxCzAJBgNVBAYTAlVTMRYwFAYDVQQK +Ew1HZW9UcnVzdCBJbmMuMRswGQYDVQQDExJHZW9UcnVzdCBHbG9iYWwgQ0EwHhcNMDIwNTIxMDQw +MDAwWhcNMjIwNTIxMDQwMDAwWjBCMQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5j +LjEbMBkGA1UEAxMSR2VvVHJ1c3QgR2xvYmFsIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB +CgKCAQEA2swYYzD99BcjGlZ+W988bDjkcbd4kdS8odhM+KhDtgPpTSEHCIjaWC9mOSm9BXiLnTjo +BbdqfnGk5sRgprDvgOSJKA+eJdbtg/OtppHHmMlCGDUUna2YRpIuT8rxh0PBFpVXLVDviS2Aelet +8u5fa9IAjbkU+BQVNdnARqN7csiRv8lVK83Qlz6cJmTM386DGXHKTubU1XupGc1V3sjs0l44U+Vc +T4wt/lAjNvxm5suOpDkZALeVAjmRCw7+OC7RHQWa9k0+bw8HHa8sHo9gOeL6NlMTOdReJivbPagU +vTLrGAMoUgRx5aszPeE4uwc2hGKceeoWMPRfwCvocWvk+QIDAQABo1MwUTAPBgNVHRMBAf8EBTAD +AQH/MB0GA1UdDgQWBBTAephojYn7qwVkDBF9qn1luMrMTjAfBgNVHSMEGDAWgBTAephojYn7qwVk +DBF9qn1luMrMTjANBgkqhkiG9w0BAQUFAAOCAQEANeMpauUvXVSOKVCUn5kaFOSPeCpilKInZ57Q +zxpeR+nBsqTP3UEaBU6bS+5Kb1VSsyShNwrrZHYqLizz/Tt1kL/6cdjHPTfStQWVYrmm3ok9Nns4 +d0iXrKYgjy6myQzCsplFAMfOEVEiIuCl6rYVSAlk6l5PdPcFPseKUgzbFbS9bZvlxrFUaKnjaZC2 +mqUPuLk/IH2uSrW4nOQdtqvmlKXBx4Ot2/Unhw4EbNX/3aBd7YdStysVAq45pmp06drE57xNNB6p +XE0zX5IJL4hmXXeXxx12E6nV5fEWCRE11azbJHFwLJhWC9kXtNHjUStedejV0NxPNO3CBWaAocvm +Mw== +-----END CERTIFICATE----- + +GeoTrust Universal CA +===================== +-----BEGIN CERTIFICATE----- +MIIFaDCCA1CgAwIBAgIBATANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQGEwJVUzEWMBQGA1UEChMN +R2VvVHJ1c3QgSW5jLjEeMBwGA1UEAxMVR2VvVHJ1c3QgVW5pdmVyc2FsIENBMB4XDTA0MDMwNDA1 +MDAwMFoXDTI5MDMwNDA1MDAwMFowRTELMAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IElu +Yy4xHjAcBgNVBAMTFUdlb1RydXN0IFVuaXZlcnNhbCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIP +ADCCAgoCggIBAKYVVaCjxuAfjJ0hUNfBvitbtaSeodlyWL0AG0y/YckUHUWCq8YdgNY96xCcOq9t +JPi8cQGeBvV8Xx7BDlXKg5pZMK4ZyzBIle0iN430SppyZj6tlcDgFgDgEB8rMQ7XlFTTQjOgNB0e +RXbdT8oYN+yFFXoZCPzVx5zw8qkuEKmS5j1YPakWaDwvdSEYfyh3peFhF7em6fgemdtzbvQKoiFs +7tqqhZJmr/Z6a4LauiIINQ/PQvE1+mrufislzDoR5G2vc7J2Ha3QsnhnGqQ5HFELZ1aD/ThdDc7d +8Lsrlh/eezJS/R27tQahsiFepdaVaH/wmZ7cRQg+59IJDTWU3YBOU5fXtQlEIGQWFwMCTFMNaN7V +qnJNk22CDtucvc+081xdVHppCZbW2xHBjXWotM85yM48vCR85mLK4b19p71XZQvk/iXttmkQ3Cga +Rr0BHdCXteGYO8A3ZNY9lO4L4fUorgtWv3GLIylBjobFS1J72HGrH4oVpjuDWtdYAVHGTEHZf9hB +Z3KiKN9gg6meyHv8U3NyWfWTehd2Ds735VzZC1U0oqpbtWpU5xPKV+yXbfReBi9Fi1jUIxaS5BZu +KGNZMN9QAZxjiRqf2xeUgnA3wySemkfWWspOqGmJch+RbNt+nhutxx9z3SxPGWX9f5NAEC7S8O08 +ni4oPmkmM8V7AgMBAAGjYzBhMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNq7LqqwDLiIJlF0 +XG0D08DYj3rWMB8GA1UdIwQYMBaAFNq7LqqwDLiIJlF0XG0D08DYj3rWMA4GA1UdDwEB/wQEAwIB +hjANBgkqhkiG9w0BAQUFAAOCAgEAMXjmx7XfuJRAyXHEqDXsRh3ChfMoWIawC/yOsjmPRFWrZIRc +aanQmjg8+uUfNeVE44B5lGiku8SfPeE0zTBGi1QrlaXv9z+ZhP015s8xxtxqv6fXIwjhmF7DWgh2 +qaavdy+3YL1ERmrvl/9zlcGO6JP7/TG37FcREUWbMPEaiDnBTzynANXH/KttgCJwpQzgXQQpAvvL +oJHRfNbDflDVnVi+QTjruXU8FdmbyUqDWcDaU/0zuzYYm4UPFd3uLax2k7nZAY1IEKj79TiG8dsK +xr2EoyNB3tZ3b4XUhRxQ4K5RirqNPnbiucon8l+f725ZDQbYKxek0nxru18UGkiPGkzns0ccjkxF +KyDuSN/n3QmOGKjaQI2SJhFTYXNd673nxE0pN2HrrDktZy4W1vUAg4WhzH92xH3kt0tm7wNFYGm2 +DFKWkoRepqO1pD4r2czYG0eq8kTaT/kD6PAUyz/zg97QwVTjt+gKN02LIFkDMBmhLMi9ER/frslK +xfMnZmaGrGiR/9nmUxwPi1xpZQomyB40w11Re9epnAahNt3ViZS82eQtDF4JbAiXfKM9fJP/P6EU +p8+1Xevb2xzEdt+Iub1FBZUbrvxGakyvSOPOrg/SfuvmbJxPgWp6ZKy7PtXny3YuxadIwVyQD8vI +P/rmMuGNG2+k5o7Y+SlIis5z/iw= +-----END CERTIFICATE----- + +GeoTrust Universal CA 2 +======================= +-----BEGIN CERTIFICATE----- +MIIFbDCCA1SgAwIBAgIBATANBgkqhkiG9w0BAQUFADBHMQswCQYDVQQGEwJVUzEWMBQGA1UEChMN +R2VvVHJ1c3QgSW5jLjEgMB4GA1UEAxMXR2VvVHJ1c3QgVW5pdmVyc2FsIENBIDIwHhcNMDQwMzA0 +MDUwMDAwWhcNMjkwMzA0MDUwMDAwWjBHMQswCQYDVQQGEwJVUzEWMBQGA1UEChMNR2VvVHJ1c3Qg +SW5jLjEgMB4GA1UEAxMXR2VvVHJ1c3QgVW5pdmVyc2FsIENBIDIwggIiMA0GCSqGSIb3DQEBAQUA +A4ICDwAwggIKAoICAQCzVFLByT7y2dyxUxpZKeexw0Uo5dfR7cXFS6GqdHtXr0om/Nj1XqduGdt0 +DE81WzILAePb63p3NeqqWuDW6KFXlPCQo3RWlEQwAx5cTiuFJnSCegx2oG9NzkEtoBUGFF+3Qs17 +j1hhNNwqCPkuwwGmIkQcTAeC5lvO0Ep8BNMZcyfwqph/Lq9O64ceJHdqXbboW0W63MOhBW9Wjo8Q +JqVJwy7XQYci4E+GymC16qFjwAGXEHm9ADwSbSsVsaxLse4YuU6W3Nx2/zu+z18DwPw76L5GG//a +QMJS9/7jOvdqdzXQ2o3rXhhqMcceujwbKNZrVMaqW9eiLBsZzKIC9ptZvTdrhrVtgrrY6slWvKk2 +WP0+GfPtDCapkzj4T8FdIgbQl+rhrcZV4IErKIM6+vR7IVEAvlI4zs1meaj0gVbi0IMJR1FbUGrP +20gaXT73y/Zl92zxlfgCOzJWgjl6W70viRu/obTo/3+NjN8D8WBOWBFM66M/ECuDmgFz2ZRthAAn +ZqzwcEAJQpKtT5MNYQlRJNiS1QuUYbKHsu3/mjX/hVTK7URDrBs8FmtISgocQIgfksILAAX/8sgC +SqSqqcyZlpwvWOB94b67B9xfBHJcMTTD7F8t4D1kkCLm0ey4Lt1ZrtmhN79UNdxzMk+MBB4zsslG +8dhcyFVQyWi9qLo2CQIDAQABo2MwYTAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBR281Xh+qQ2 ++/CfXGJx7Tz0RzgQKzAfBgNVHSMEGDAWgBR281Xh+qQ2+/CfXGJx7Tz0RzgQKzAOBgNVHQ8BAf8E +BAMCAYYwDQYJKoZIhvcNAQEFBQADggIBAGbBxiPz2eAubl/oz66wsCVNK/g7WJtAJDday6sWSf+z +dXkzoS9tcBc0kf5nfo/sm+VegqlVHy/c1FEHEv6sFj4sNcZj/NwQ6w2jqtB8zNHQL1EuxBRa3ugZ +4T7GzKQp5y6EqgYweHZUcyiYWTjgAA1i00J9IZ+uPTqM1fp3DRgrFg5fNuH8KrUwJM/gYwx7WBr+ +mbpCErGR9Hxo4sjoryzqyX6uuyo9DRXcNJW2GHSoag/HtPQTxORb7QrSpJdMKu0vbBKJPfEncKpq +A1Ihn0CoZ1Dy81of398j9tx4TuaYT1U6U+Pv8vSfx3zYWK8pIpe44L2RLrB27FcRz+8pRPPphXpg +Y+RdM4kX2TGq2tbzGDVyz4crL2MjhF2EjD9XoIj8mZEoJmmZ1I+XRL6O1UixpCgp8RW04eWe3fiP +pm8m1wk8OhwRDqZsN/etRIcsKMfYdIKz0G9KV7s1KSegi+ghp4dkNl3M2Basx7InQJJVOCiNUW7d +FGdTbHFcJoRNdVq2fmBWqU2t+5sel/MN2dKXVHfaPRK34B7vCAas+YWH6aLcr34YEoP9VhdBLtUp +gn2Z9DH2canPLAEnpQW5qrJITirvn5NSUZU8UnOOVkwXQMAJKOSLakhT2+zNVVXxxvjpoixMptEm +X36vWkzaH6byHCx+rgIW0lbQL1dTR+iS +-----END CERTIFICATE----- + +Comodo AAA Services root +======================== +-----BEGIN CERTIFICATE----- +MIIEMjCCAxqgAwIBAgIBATANBgkqhkiG9w0BAQUFADB7MQswCQYDVQQGEwJHQjEbMBkGA1UECAwS +R3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHDAdTYWxmb3JkMRowGAYDVQQKDBFDb21vZG8gQ0Eg +TGltaXRlZDEhMB8GA1UEAwwYQUFBIENlcnRpZmljYXRlIFNlcnZpY2VzMB4XDTA0MDEwMTAwMDAw +MFoXDTI4MTIzMTIzNTk1OVowezELMAkGA1UEBhMCR0IxGzAZBgNVBAgMEkdyZWF0ZXIgTWFuY2hl +c3RlcjEQMA4GA1UEBwwHU2FsZm9yZDEaMBgGA1UECgwRQ29tb2RvIENBIExpbWl0ZWQxITAfBgNV +BAMMGEFBQSBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC +ggEBAL5AnfRu4ep2hxxNRUSOvkbIgwadwSr+GB+O5AL686tdUIoWMQuaBtDFcCLNSS1UY8y2bmhG +C1Pqy0wkwLxyTurxFa70VJoSCsN6sjNg4tqJVfMiWPPe3M/vg4aijJRPn2jymJBGhCfHdr/jzDUs +i14HZGWCwEiwqJH5YZ92IFCokcdmtet4YgNW8IoaE+oxox6gmf049vYnMlhvB/VruPsUK6+3qszW +Y19zjNoFmag4qMsXeDZRrOme9Hg6jc8P2ULimAyrL58OAd7vn5lJ8S3frHRNG5i1R8XlKdH5kBjH +Ypy+g8cmez6KJcfA3Z3mNWgQIJ2P2N7Sw4ScDV7oL8kCAwEAAaOBwDCBvTAdBgNVHQ4EFgQUoBEK +Iz6W8Qfs4q8p74Klf9AwpLQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wewYDVR0f +BHQwcjA4oDagNIYyaHR0cDovL2NybC5jb21vZG9jYS5jb20vQUFBQ2VydGlmaWNhdGVTZXJ2aWNl +cy5jcmwwNqA0oDKGMGh0dHA6Ly9jcmwuY29tb2RvLm5ldC9BQUFDZXJ0aWZpY2F0ZVNlcnZpY2Vz +LmNybDANBgkqhkiG9w0BAQUFAAOCAQEACFb8AvCb6P+k+tZ7xkSAzk/ExfYAWMymtrwUSWgEdujm +7l3sAg9g1o1QGE8mTgHj5rCl7r+8dFRBv/38ErjHT1r0iWAFf2C3BUrz9vHCv8S5dIa2LX1rzNLz +Rt0vxuBqw8M0Ayx9lt1awg6nCpnBBYurDC/zXDrPbDdVCYfeU0BsWO/8tqtlbgT2G9w84FoVxp7Z +8VlIMCFlA2zs6SFz7JsDoeA3raAVGI/6ugLOpyypEBMs1OUIJqsil2D4kF501KKaU73yqWjgom7C +12yxow+ev+to51byrvLjKzg6CYG1a4XXvi3tPxq3smPi9WIsgtRqAEFQ8TmDn5XpNpaYbg== +-----END CERTIFICATE----- + +QuoVadis Root CA +================ +-----BEGIN CERTIFICATE----- +MIIF0DCCBLigAwIBAgIEOrZQizANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJCTTEZMBcGA1UE +ChMQUXVvVmFkaXMgTGltaXRlZDElMCMGA1UECxMcUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0 +eTEuMCwGA1UEAxMlUXVvVmFkaXMgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wMTAz +MTkxODMzMzNaFw0yMTAzMTcxODMzMzNaMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRp +cyBMaW1pdGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYDVQQD +EyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEAv2G1lVO6V/z68mcLOhrfEYBklbTRvM16z/Ypli4kVEAkOPcahdxYTMuk +J0KX0J+DisPkBgNbAKVRHnAEdOLB1Dqr1607BxgFjv2DrOpm2RgbaIr1VxqYuvXtdj182d6UajtL +F8HVj71lODqV0D1VNk7feVcxKh7YWWVJWCCYfqtffp/p1k3sg3Spx2zY7ilKhSoGFPlU5tPaZQeL +YzcS19Dsw3sgQUSj7cugF+FxZc4dZjH3dgEZyH0DWLaVSR2mEiboxgx24ONmy+pdpibu5cxfvWen +AScOospUxbF6lR1xHkopigPcakXBpBlebzbNw6Kwt/5cOOJSvPhEQ+aQuwIDAQABo4ICUjCCAk4w +PQYIKwYBBQUHAQEEMTAvMC0GCCsGAQUFBzABhiFodHRwczovL29jc3AucXVvdmFkaXNvZmZzaG9y +ZS5jb20wDwYDVR0TAQH/BAUwAwEB/zCCARoGA1UdIASCAREwggENMIIBCQYJKwYBBAG+WAABMIH7 +MIHUBggrBgEFBQcCAjCBxxqBxFJlbGlhbmNlIG9uIHRoZSBRdW9WYWRpcyBSb290IENlcnRpZmlj +YXRlIGJ5IGFueSBwYXJ0eSBhc3N1bWVzIGFjY2VwdGFuY2Ugb2YgdGhlIHRoZW4gYXBwbGljYWJs +ZSBzdGFuZGFyZCB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB1c2UsIGNlcnRpZmljYXRpb24gcHJh +Y3RpY2VzLCBhbmQgdGhlIFF1b1ZhZGlzIENlcnRpZmljYXRlIFBvbGljeS4wIgYIKwYBBQUHAgEW +Fmh0dHA6Ly93d3cucXVvdmFkaXMuYm0wHQYDVR0OBBYEFItLbe3TKbkGGew5Oanwl4Rqy+/fMIGu +BgNVHSMEgaYwgaOAFItLbe3TKbkGGew5Oanwl4Rqy+/foYGEpIGBMH8xCzAJBgNVBAYTAkJNMRkw +FwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0 +aG9yaXR5MS4wLAYDVQQDEyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggQ6 +tlCLMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAitQUtf70mpKnGdSkfnIYj9lo +fFIk3WdvOXrEql494liwTXCYhGHoG+NpGA7O+0dQoE7/8CQfvbLO9Sf87C9TqnN7Az10buYWnuul +LsS/VidQK2K6vkscPFVcQR0kvoIgR13VRH56FmjffU1RcHhXHTMe/QKZnAzNCgVPx7uOpHX6Sm2x +gI4JVrmcGmD+XcHXetwReNDWXcG31a0ymQM6isxUJTkxgXsTIlG6Rmyhu576BGxJJnSP0nPrzDCi +5upZIof4l/UO/erMkqQWxFIY6iHOsfHmhIHluqmGKPJDWl0Snawe2ajlCmqnf6CHKc/yiU3U7MXi +5nrQNiOKSnQ2+Q== +-----END CERTIFICATE----- + +QuoVadis Root CA 2 +================== +-----BEGIN CERTIFICATE----- +MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoT +EFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJvb3QgQ0EgMjAeFw0wNjExMjQx +ODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMRswGQYDVQQDExJRdW9WYWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQCaGMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6 +XJxgFyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55JWpzmM+Yk +lvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bBrrcCaoF6qUWD4gXmuVbB +lDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp+ARz8un+XJiM9XOva7R+zdRcAitMOeGy +lZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt +66/3FsvbzSUr5R/7mp/iUcw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1Jdxn +wQ5hYIizPtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og/zOh +D7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UHoycR7hYQe7xFSkyy +BNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuIyV77zGHcizN300QyNQliBJIWENie +J0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1Ud +DgQWBBQahGK8SEwzJQTU7tD2A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGU +a6FJpEcwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT +ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2fBluornFdLwUv +Z+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzng/iN/Ae42l9NLmeyhP3ZRPx3 +UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2BlfF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodm +VjB3pjd4M1IQWK4/YY7yarHvGH5KWWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK ++JDSV6IZUaUtl0HaB0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrW +IozchLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPRTUIZ3Ph1 +WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWDmbA4CD/pXvk1B+TJYm5X +f6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0ZohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II +4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8 +VCLAAVBpQ570su9t+Oza8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u +-----END CERTIFICATE----- + +QuoVadis Root CA 3 +================== +-----BEGIN CERTIFICATE----- +MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoT +EFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJvb3QgQ0EgMzAeFw0wNjExMjQx +OTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMRswGQYDVQQDExJRdW9WYWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQDMV0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNgg +DhoB4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUrH556VOij +KTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd8lyyBTNvijbO0BNO/79K +DDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9CabwvvWhDFlaJKjdhkf2mrk7AyxRllDdLkgbv +BNDInIjbC3uBr7E9KsRlOni27tyAsdLTmZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwp +p5ijJUMv7/FfJuGITfhebtfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8 +nT8KKdjcT5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDtWAEX +MJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZc6tsgLjoC2SToJyM +Gf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A4iLItLRkT9a6fUg+qGkM17uGcclz +uD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYDVR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHT +BgkrBgEEAb5YAAMwgcUwgZMGCCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmlj +YXRlIGNvbnN0aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0 +aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVudC4wLQYIKwYB +BQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2NwczALBgNVHQ8EBAMCAQYwHQYD +VR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4GA1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4 +ywLQoUmkRzBFMQswCQYDVQQGEwJCTTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UE +AxMSUXVvVmFkaXMgUm9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZV +qyM07ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSemd1o417+s +hvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd+LJ2w/w4E6oM3kJpK27z +POuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2 +Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadNt54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp +8kokUvd0/bpO5qgdAm6xDYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBC +bjPsMZ57k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6szHXu +g/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0jWy10QJLZYxkNc91p +vGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeTmJlglFwjz1onl14LBQaTNx47aTbr +qZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK4SVhM7JZG+Ju1zdXtg2pEto= +-----END CERTIFICATE----- + +Security Communication Root CA +============================== +-----BEGIN CERTIFICATE----- +MIIDWjCCAkKgAwIBAgIBADANBgkqhkiG9w0BAQUFADBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMP +U0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEw +HhcNMDMwOTMwMDQyMDQ5WhcNMjMwOTMwMDQyMDQ5WjBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMP +U0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEw +ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCzs/5/022x7xZ8V6UMbXaKL0u/ZPtM7orw +8yl89f/uKuDp6bpbZCKamm8sOiZpUQWZJtzVHGpxxpp9Hp3dfGzGjGdnSj74cbAZJ6kJDKaVv0uM +DPpVmDvY6CKhS3E4eayXkmmziX7qIWgGmBSWh9JhNrxtJ1aeV+7AwFb9Ms+k2Y7CI9eNqPPYJayX +5HA49LY6tJ07lyZDo6G8SVlyTCMwhwFY9k6+HGhWZq/NQV3Is00qVUarH9oe4kA92819uZKAnDfd +DJZkndwi92SL32HeFZRSFaB9UslLqCHJxrHty8OVYNEP8Ktw+N/LTX7s1vqr2b1/VPKl6Xn62dZ2 +JChzAgMBAAGjPzA9MB0GA1UdDgQWBBSgc0mZaNyFW2XjmygvV5+9M7wHSDALBgNVHQ8EBAMCAQYw +DwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAaECpqLvkT115swW1F7NgE+vGkl3g +0dNq/vu+m22/xwVtWSDEHPC32oRYAmP6SBbvT6UL90qY8j+eG61Ha2POCEfrUj94nK9NrvjVT8+a +mCoQQTlSxN3Zmw7vkwGusi7KaEIkQmywszo+zenaSMQVy+n5Bw+SUEmK3TGXX8npN6o7WWWXlDLJ +s58+OmJYxUmtYg5xpTKqL8aJdkNAExNnPaJUJRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ +6rBK+1YWc26sTfcioU+tHXotRSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAi +FL39vmwLAw== +-----END CERTIFICATE----- + +Sonera Class 2 Root CA +====================== +-----BEGIN CERTIFICATE----- +MIIDIDCCAgigAwIBAgIBHTANBgkqhkiG9w0BAQUFADA5MQswCQYDVQQGEwJGSTEPMA0GA1UEChMG +U29uZXJhMRkwFwYDVQQDExBTb25lcmEgQ2xhc3MyIENBMB4XDTAxMDQwNjA3Mjk0MFoXDTIxMDQw +NjA3Mjk0MFowOTELMAkGA1UEBhMCRkkxDzANBgNVBAoTBlNvbmVyYTEZMBcGA1UEAxMQU29uZXJh +IENsYXNzMiBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJAXSjWdyvANlsdE+hY3 +/Ei9vX+ALTU74W+oZ6m/AxxNjG8yR9VBaKQTBME1DJqEQ/xcHf+Js+gXGM2RX/uJ4+q/Tl18GybT +dXnt5oTjV+WtKcT0OijnpXuENmmz/V52vaMtmdOQTiMofRhj8VQ7Jp12W5dCsv+u8E7s3TmVToMG +f+dJQMjFAbJUWmYdPfz56TwKnoG4cPABi+QjVHzIrviQHgCWctRUz2EjvOr7nQKV0ba5cTppCD8P +tOFCx4j1P5iop7oc4HFx71hXgVB6XGt0Rg6DA5jDjqhu8nYybieDwnPz3BjotJPqdURrBGAgcVeH +nfO+oJAjPYok4doh28MCAwEAAaMzMDEwDwYDVR0TAQH/BAUwAwEB/zARBgNVHQ4ECgQISqCqWITT +XjwwCwYDVR0PBAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQBazof5FnIVV0sd2ZvnoiYw7JNn39Yt +0jSv9zilzqsWuasvfDXLrNAPtEwr/IDva4yRXzZ299uzGxnq9LIR/WFxRL8oszodv7ND6J+/3DEI +cbCdjdY0RzKQxmUk96BKfARzjzlvF4xytb1LyHr4e4PDKE6cCepnP7JnBBvDFNr450kkkdAdavph +Oe9r5yF1BgfYErQhIHBCcYHaPJo2vqZbDWpsmh+Re/n570K6Tk6ezAyNlNzZRZxe7EJQY670XcSx +EtzKO6gunRRaBXW37Ndj4ro1tgQIkejanZz2ZrUYrAqmVCY0M9IbwdR/GjqOC6oybtv8TyWf2TLH +llpwrN9M +-----END CERTIFICATE----- + +XRamp Global CA Root +==================== +-----BEGIN CERTIFICATE----- +MIIEMDCCAxigAwIBAgIQUJRs7Bjq1ZxN1ZfvdY+grTANBgkqhkiG9w0BAQUFADCBgjELMAkGA1UE +BhMCVVMxHjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2Vj +dXJpdHkgU2VydmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwHhcNMDQxMTAxMTcxNDA0WhcNMzUwMTAxMDUzNzE5WjCBgjELMAkGA1UEBhMCVVMx +HjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2VjdXJpdHkg +U2VydmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBBdXRob3Jp +dHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCYJB69FbS638eMpSe2OAtp87ZOqCwu +IR1cRN8hXX4jdP5efrRKt6atH67gBhbim1vZZ3RrXYCPKZ2GG9mcDZhtdhAoWORlsH9KmHmf4MMx +foArtYzAQDsRhtDLooY2YKTVMIJt2W7QDxIEM5dfT2Fa8OT5kavnHTu86M/0ay00fOJIYRyO82FE +zG+gSqmUsE3a56k0enI4qEHMPJQRfevIpoy3hsvKMzvZPTeL+3o+hiznc9cKV6xkmxnr9A8ECIqs +AxcZZPRaJSKNNCyy9mgdEm3Tih4U2sSPpuIjhdV6Db1q4Ons7Be7QhtnqiXtRYMh/MHJfNViPvry +xS3T/dRlAgMBAAGjgZ8wgZwwEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1Ud +EwEB/wQFMAMBAf8wHQYDVR0OBBYEFMZPoj0GY4QJnM5i5ASsjVy16bYbMDYGA1UdHwQvMC0wK6Ap +oCeGJWh0dHA6Ly9jcmwueHJhbXBzZWN1cml0eS5jb20vWEdDQS5jcmwwEAYJKwYBBAGCNxUBBAMC +AQEwDQYJKoZIhvcNAQEFBQADggEBAJEVOQMBG2f7Shz5CmBbodpNl2L5JFMn14JkTpAuw0kbK5rc +/Kh4ZzXxHfARvbdI4xD2Dd8/0sm2qlWkSLoC295ZLhVbO50WfUfXN+pfTXYSNrsf16GBBEYgoyxt +qZ4Bfj8pzgCT3/3JknOJiWSe5yvkHJEs0rnOfc5vMZnT5r7SHpDwCRR5XCOrTdLaIR9NmXmd4c8n +nxCbHIgNsIpkQTG4DmyQJKSbXHGPurt+HBvbaoAPIbzp26a3QPSyi6mx5O+aGtA9aZnuqCij4Tyz +8LIRnM98QObd50N9otg6tamN8jSZxNQQ4Qb9CYQQO+7ETPTsJ3xCwnR8gooJybQDJbw= +-----END CERTIFICATE----- + +Go Daddy Class 2 CA +=================== +-----BEGIN CERTIFICATE----- +MIIEADCCAuigAwIBAgIBADANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMY +VGhlIEdvIERhZGR5IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5MB4XDTA0MDYyOTE3MDYyMFoXDTM0MDYyOTE3MDYyMFowYzELMAkG +A1UEBhMCVVMxITAfBgNVBAoTGFRoZSBHbyBEYWRkeSBHcm91cCwgSW5jLjExMC8GA1UECxMoR28g +RGFkZHkgQ2xhc3MgMiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASAwDQYJKoZIhvcNAQEBBQAD +ggENADCCAQgCggEBAN6d1+pXGEmhW+vXX0iG6r7d/+TvZxz0ZWizV3GgXne77ZtJ6XCAPVYYYwhv +2vLM0D9/AlQiVBDYsoHUwHU9S3/Hd8M+eKsaA7Ugay9qK7HFiH7Eux6wwdhFJ2+qN1j3hybX2C32 +qRe3H3I2TqYXP2WYktsqbl2i/ojgC95/5Y0V4evLOtXiEqITLdiOr18SPaAIBQi2XKVlOARFmR6j +YGB0xUGlcmIbYsUfb18aQr4CUWWoriMYavx4A6lNf4DD+qta/KFApMoZFv6yyO9ecw3ud72a9nmY +vLEHZ6IVDd2gWMZEewo+YihfukEHU1jPEX44dMX4/7VpkI+EdOqXG68CAQOjgcAwgb0wHQYDVR0O +BBYEFNLEsNKR1EwRcbNhyz2h/t2oatTjMIGNBgNVHSMEgYUwgYKAFNLEsNKR1EwRcbNhyz2h/t2o +atTjoWekZTBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYVGhlIEdvIERhZGR5IEdyb3VwLCBJbmMu +MTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwG +A1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBADJL87LKPpH8EsahB4yOd6AzBhRckB4Y9wim +PQoZ+YeAEW5p5JYXMP80kWNyOO7MHAGjHZQopDH2esRU1/blMVgDoszOYtuURXO1v0XJJLXVggKt +I3lpjbi2Tc7PTMozI+gciKqdi0FuFskg5YmezTvacPd+mSYgFFQlq25zheabIZ0KbIIOqPjCDPoQ +HmyW74cNxA9hi63ugyuV+I6ShHI56yDqg+2DzZduCLzrTia2cyvk0/ZM/iZx4mERdEr/VxqHD3VI +Ls9RaRegAhJhldXRQLIQTO7ErBBDpqWeCtWVYpoNz4iCxTIM5CufReYNnyicsbkqWletNw+vHX/b +vZ8= +-----END CERTIFICATE----- + +Starfield Class 2 CA +==================== +-----BEGIN CERTIFICATE----- +MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzElMCMGA1UEChMc +U3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZpZWxkIENsYXNzIDIg +Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQwNjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBo +MQswCQYDVQQGEwJVUzElMCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAG +A1UECxMpU3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqG +SIb3DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf8MOh2tTY +bitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN+lq2cwQlZut3f+dZxkqZ +JRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVm +epsZGD3/cVE8MC5fvj13c7JdBmzDI1aaK4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSN +F4Azbl5KXZnJHoe0nRrA1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HF +MIHCMB0GA1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fRzt0f +hvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNo +bm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBDbGFzcyAyIENlcnRpZmljYXRpb24g +QXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGs +afPzWdqbAYcaT1epoXkJKtv3L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLM +PUxA2IGvd56Deruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl +xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynpVSJYACPq4xJD +KVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEYWQPJIrSPnNVeKtelttQKbfi3 +QBFGmh95DmK/D5fs4C8fF5Q= +-----END CERTIFICATE----- + +Taiwan GRCA +=========== +-----BEGIN CERTIFICATE----- +MIIFcjCCA1qgAwIBAgIQH51ZWtcvwgZEpYAIaeNe9jANBgkqhkiG9w0BAQUFADA/MQswCQYDVQQG +EwJUVzEwMC4GA1UECgwnR292ZXJubWVudCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4X +DTAyMTIwNTEzMjMzM1oXDTMyMTIwNTEzMjMzM1owPzELMAkGA1UEBhMCVFcxMDAuBgNVBAoMJ0dv +dmVybm1lbnQgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQAD +ggIPADCCAgoCggIBAJoluOzMonWoe/fOW1mKydGGEghU7Jzy50b2iPN86aXfTEc2pBsBHH8eV4qN +w8XRIePaJD9IK/ufLqGU5ywck9G/GwGHU5nOp/UKIXZ3/6m3xnOUT0b3EEk3+qhZSV1qgQdW8or5 +BtD3cCJNtLdBuTK4sfCxw5w/cP1T3YGq2GN49thTbqGsaoQkclSGxtKyyhwOeYHWtXBiCAEuTk8O +1RGvqa/lmr/czIdtJuTJV6L7lvnM4T9TjGxMfptTCAtsF/tnyMKtsc2AtJfcdgEWFelq16TheEfO +htX7MfP6Mb40qij7cEwdScevLJ1tZqa2jWR+tSBqnTuBto9AAGdLiYa4zGX+FVPpBMHWXx1E1wov +J5pGfaENda1UhhXcSTvxls4Pm6Dso3pdvtUqdULle96ltqqvKKyskKw4t9VoNSZ63Pc78/1Fm9G7 +Q3hub/FCVGqY8A2tl+lSXunVanLeavcbYBT0peS2cWeqH+riTcFCQP5nRhc4L0c/cZyu5SHKYS1t +B6iEfC3uUSXxY5Ce/eFXiGvviiNtsea9P63RPZYLhY3Naye7twWb7LuRqQoHEgKXTiCQ8P8NHuJB +O9NAOueNXdpm5AKwB1KYXA6OM5zCppX7VRluTI6uSw+9wThNXo+EHWbNxWCWtFJaBYmOlXqYwZE8 +lSOyDvR5tMl8wUohAgMBAAGjajBoMB0GA1UdDgQWBBTMzO/MKWCkO7GStjz6MmKPrCUVOzAMBgNV +HRMEBTADAQH/MDkGBGcqBwAEMTAvMC0CAQAwCQYFKw4DAhoFADAHBgVnKgMAAAQUA5vwIhP/lSg2 +09yewDL7MTqKUWUwDQYJKoZIhvcNAQEFBQADggIBAECASvomyc5eMN1PhnR2WPWus4MzeKR6dBcZ +TulStbngCnRiqmjKeKBMmo4sIy7VahIkv9Ro04rQ2JyftB8M3jh+Vzj8jeJPXgyfqzvS/3WXy6Tj +Zwj/5cAWtUgBfen5Cv8b5Wppv3ghqMKnI6mGq3ZW6A4M9hPdKmaKZEk9GhiHkASfQlK3T8v+R0F2 +Ne//AHY2RTKbxkaFXeIksB7jSJaYV0eUVXoPQbFEJPPB/hprv4j9wabak2BegUqZIJxIZhm1AHlU +D7gsL0u8qV1bYH+Mh6XgUmMqvtg7hUAV/h62ZT/FS9p+tXo1KaMuephgIqP0fSdOLeq0dDzpD6Qz +DxARvBMB1uUO07+1EqLhRSPAzAhuYbeJq4PjJB7mXQfnHyA+z2fI56wwbSdLaG5LKlwCCDTb+Hbk +Z6MmnD+iMsJKxYEYMRBWqoTvLQr/uB930r+lWKBi5NdLkXWNiYCYfm3LU05er/ayl4WXudpVBrkk +7tfGOB5jGxI7leFYrPLfhNVfmS8NVVvmONsuP3LpSIXLuykTjx44VbnzssQwmSNOXfJIoRIM3BKQ +CZBUkQM8R+XVyWXgt0t97EfTsws+rZ7QdAAO671RrcDeLMDDav7v3Aun+kbfYNucpllQdSNpc5Oy ++fwC00fmcc4QAu4njIT/rEUNE1yDMuAlpYYsfPQS +-----END CERTIFICATE----- + +DigiCert Assured ID Root CA +=========================== +-----BEGIN CERTIFICATE----- +MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBlMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSQw +IgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzEx +MTEwMDAwMDAwWjBlMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQL +ExB3d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0Ew +ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7cJpSIqvTO +9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYPmDI2dsze3Tyoou9q+yHy +UmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW +/lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpy +oeb6pNnVFzF1roV9Iq4/AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whf +GHdPAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRF +66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd823IDzANBgkq +hkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRCdWKuh+vy1dneVrOfzM4UKLkNl2Bc +EkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTffwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38Fn +SbNd67IJKusm7Xi+fT8r87cmNW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i +8b5QZ7dsvfPxH2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe ++o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g== +-----END CERTIFICATE----- + +DigiCert Global Root CA +======================= +-----BEGIN CERTIFICATE----- +MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBhMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSAw +HgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBDQTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAw +MDAwMDBaMGExCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3 +dy5kaWdpY2VydC5jb20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkq +hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsBCSDMAZOn +TjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97nh6Vfe63SKMI2tavegw5 +BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt43C/dxC//AH2hdmoRBBYMql1GNXRor5H +4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7PT19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y +7vrTC0LUq7dBMtoM1O/4gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQAB +o2MwYTAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbRTLtm +8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUwDQYJKoZIhvcNAQEF +BQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/EsrhMAtudXH/vTBH1jLuG2cenTnmCmr +EbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIt +tep3Sp+dWOIrWcBAI+0tKIJFPnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886 +UAb3LujEV0lsYSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk +CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4= +-----END CERTIFICATE----- + +DigiCert High Assurance EV Root CA +================================== +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBsMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSsw +KQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5jZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAw +MFoXDTMxMTExMDAwMDAwMFowbDELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZ +MBcGA1UECxMQd3d3LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFu +Y2UgRVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm+9S75S0t +Mqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTWPNt0OKRKzE0lgvdKpVMS +OO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEMxChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3 +MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFBIk5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQ +NAQTXKFx01p8VdteZOE3hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUe +h10aUAsgEsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMB +Af8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaAFLE+w2kD+L9HAdSY +JhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3NecnzyIZgYIVyHbIUf4KmeqvxgydkAQ +V8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6zeM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFp +myPInngiK3BD41VHMWEZ71jFhS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkK +mNEVX58Svnw2Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe +vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep+OkuE6N36B9K +-----END CERTIFICATE----- + +Certplus Class 2 Primary CA +=========================== +-----BEGIN CERTIFICATE----- +MIIDkjCCAnqgAwIBAgIRAIW9S/PY2uNp9pTXX8OlRCMwDQYJKoZIhvcNAQEFBQAwPTELMAkGA1UE +BhMCRlIxETAPBgNVBAoTCENlcnRwbHVzMRswGQYDVQQDExJDbGFzcyAyIFByaW1hcnkgQ0EwHhcN +OTkwNzA3MTcwNTAwWhcNMTkwNzA2MjM1OTU5WjA9MQswCQYDVQQGEwJGUjERMA8GA1UEChMIQ2Vy +dHBsdXMxGzAZBgNVBAMTEkNsYXNzIDIgUHJpbWFyeSBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEP +ADCCAQoCggEBANxQltAS+DXSCHh6tlJw/W/uz7kRy1134ezpfgSN1sxvc0NXYKwzCkTsA18cgCSR +5aiRVhKC9+Ar9NuuYS6JEI1rbLqzAr3VNsVINyPi8Fo3UjMXEuLRYE2+L0ER4/YXJQyLkcAbmXuZ +Vg2v7tK8R1fjeUl7NIknJITesezpWE7+Tt9avkGtrAjFGA7v0lPubNCdEgETjdyAYveVqUSISnFO +YFWe2yMZeVYHDD9jC1yw4r5+FfyUM1hBOHTE4Y+L3yasH7WLO7dDWWuwJKZtkIvEcupdM5i3y95e +e++U8Rs+yskhwcWYAqqi9lt3m/V+llU0HGdpwPFC40es/CgcZlUCAwEAAaOBjDCBiTAPBgNVHRME +CDAGAQH/AgEKMAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQU43Mt38sOKAze3bOkynm4jrvoMIkwEQYJ +YIZIAYb4QgEBBAQDAgEGMDcGA1UdHwQwMC4wLKAqoCiGJmh0dHA6Ly93d3cuY2VydHBsdXMuY29t +L0NSTC9jbGFzczIuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQCnVM+IRBnL39R/AN9WM2K191EBkOvD +P9GIROkkXe/nFL0gt5o8AP5tn9uQ3Nf0YtaLcF3n5QRIqWh8yfFC82x/xXp8HVGIutIKPidd3i1R +TtMTZGnkLuPT55sJmabglZvOGtd/vjzOUrMRFcEPF80Du5wlFbqidon8BvEY0JNLDnyCt6X09l/+ +7UCmnYR0ObncHoUW2ikbhiMAybuJfm6AiB4vFLQDJKgybwOaRywwvlbGp0ICcBvqQNi6BQNwB6SW +//1IMwrh3KWBkJtN3X3n57LNXMhqlfil9o3EXXgIvnsG1knPGTZQIy4I5p4FTUcY1Rbpsda2ENW7 +l7+ijrRU +-----END CERTIFICATE----- + +DST Root CA X3 +============== +-----BEGIN CERTIFICATE----- +MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/MSQwIgYDVQQK +ExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMTDkRTVCBSb290IENBIFgzMB4X +DTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVowPzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1 +cmUgVHJ1c3QgQ28uMRcwFQYDVQQDEw5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQAD +ggEPADCCAQoCggEBAN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmT +rE4Orz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEqOLl5CjH9 +UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9bxiqKqy69cK3FCxolkHRy +xXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40d +utolucbY38EVAjqr2m7xPi71XAicPNaDaeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0T +AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQ +MA0GCSqGSIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69ikug +dB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXrAvHRAosZy5Q6XkjE +GB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZzR8srzJmwN0jP41ZL9c8PDHIyh8bw +RLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubS +fZGL+T0yjWW06XyxV3bqxbYoOb8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ +-----END CERTIFICATE----- + +SwissSign Gold CA - G2 +====================== +-----BEGIN CERTIFICATE----- +MIIFujCCA6KgAwIBAgIJALtAHEP1Xk+wMA0GCSqGSIb3DQEBBQUAMEUxCzAJBgNVBAYTAkNIMRUw +EwYDVQQKEwxTd2lzc1NpZ24gQUcxHzAdBgNVBAMTFlN3aXNzU2lnbiBHb2xkIENBIC0gRzIwHhcN +MDYxMDI1MDgzMDM1WhcNMzYxMDI1MDgzMDM1WjBFMQswCQYDVQQGEwJDSDEVMBMGA1UEChMMU3dp +c3NTaWduIEFHMR8wHQYDVQQDExZTd2lzc1NpZ24gR29sZCBDQSAtIEcyMIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEAr+TufoskDhJuqVAtFkQ7kpJcyrhdhJJCEyq8ZVeCQD5XJM1QiyUq +t2/876LQwB8CJEoTlo8jE+YoWACjR8cGp4QjK7u9lit/VcyLwVcfDmJlD909Vopz2q5+bbqBHH5C +jCA12UNNhPqE21Is8w4ndwtrvxEvcnifLtg+5hg3Wipy+dpikJKVyh+c6bM8K8vzARO/Ws/BtQpg +vd21mWRTuKCWs2/iJneRjOBiEAKfNA+k1ZIzUd6+jbqEemA8atufK+ze3gE/bk3lUIbLtK/tREDF +ylqM2tIrfKjuvqblCqoOpd8FUrdVxyJdMmqXl2MT28nbeTZ7hTpKxVKJ+STnnXepgv9VHKVxaSvR +AiTysybUa9oEVeXBCsdtMDeQKuSeFDNeFhdVxVu1yzSJkvGdJo+hB9TGsnhQ2wwMC3wLjEHXuend +jIj3o02yMszYF9rNt85mndT9Xv+9lz4pded+p2JYryU0pUHHPbwNUMoDAw8IWh+Vc3hiv69yFGkO +peUDDniOJihC8AcLYiAQZzlG+qkDzAQ4embvIIO1jEpWjpEA/I5cgt6IoMPiaG59je883WX0XaxR +7ySArqpWl2/5rX3aYT+YdzylkbYcjCbaZaIJbcHiVOO5ykxMgI93e2CaHt+28kgeDrpOVG2Y4OGi +GqJ3UM/EY5LsRxmd6+ZrzsECAwEAAaOBrDCBqTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUWyV7lqRlUX64OfPAeGZe6Drn8O4wHwYDVR0jBBgwFoAUWyV7lqRlUX64 +OfPAeGZe6Drn8O4wRgYDVR0gBD8wPTA7BglghXQBWQECAQEwLjAsBggrBgEFBQcCARYgaHR0cDov +L3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBACe645R88a7A3hfm +5djV9VSwg/S7zV4Fe0+fdWavPOhWfvxyeDgD2StiGwC5+OlgzczOUYrHUDFu4Up+GC9pWbY9ZIEr +44OE5iKHjn3g7gKZYbge9LgriBIWhMIxkziWMaa5O1M/wySTVltpkuzFwbs4AOPsF6m43Md8AYOf +Mke6UiI0HTJ6CVanfCU2qT1L2sCCbwq7EsiHSycR+R4tx5M/nttfJmtS2S6K8RTGRI0Vqbe/vd6m +Gu6uLftIdxf+u+yvGPUqUfA5hJeVbG4bwyvEdGB5JbAKJ9/fXtI5z0V9QkvfsywexcZdylU6oJxp +mo/a77KwPJ+HbBIrZXAVUjEaJM9vMSNQH4xPjyPDdEFjHFWoFN0+4FFQz/EbMFYOkrCChdiDyyJk +vC24JdVUorgG6q2SpCSgwYa1ShNqR88uC1aVVMvOmttqtKay20EIhid392qgQmwLOM7XdVAyksLf +KzAiSNDVQTglXaTpXZ/GlHXQRf0wl0OPkKsKx4ZzYEppLd6leNcG2mqeSz53OiATIgHQv2ieY2Br +NU0LbbqhPcCT4H8js1WtciVORvnSFu+wZMEBnunKoGqYDs/YYPIvSbjkQuE4NRb0yG5P94FW6Lqj +viOvrv1vA+ACOzB2+httQc8Bsem4yWb02ybzOqR08kkkW8mw0FfB+j564ZfJ +-----END CERTIFICATE----- + +SwissSign Silver CA - G2 +======================== +-----BEGIN CERTIFICATE----- +MIIFvTCCA6WgAwIBAgIITxvUL1S7L0swDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCQ0gxFTAT +BgNVBAoTDFN3aXNzU2lnbiBBRzEhMB8GA1UEAxMYU3dpc3NTaWduIFNpbHZlciBDQSAtIEcyMB4X +DTA2MTAyNTA4MzI0NloXDTM2MTAyNTA4MzI0NlowRzELMAkGA1UEBhMCQ0gxFTATBgNVBAoTDFN3 +aXNzU2lnbiBBRzEhMB8GA1UEAxMYU3dpc3NTaWduIFNpbHZlciBDQSAtIEcyMIICIjANBgkqhkiG +9w0BAQEFAAOCAg8AMIICCgKCAgEAxPGHf9N4Mfc4yfjDmUO8x/e8N+dOcbpLj6VzHVxumK4DV644 +N0MvFz0fyM5oEMF4rhkDKxD6LHmD9ui5aLlV8gREpzn5/ASLHvGiTSf5YXu6t+WiE7brYT7QbNHm ++/pe7R20nqA1W6GSy/BJkv6FCgU+5tkL4k+73JU3/JHpMjUi0R86TieFnbAVlDLaYQ1HTWBCrpJH +6INaUFjpiou5XaHc3ZlKHzZnu0jkg7Y360g6rw9njxcH6ATK72oxh9TAtvmUcXtnZLi2kUpCe2Uu +MGoM9ZDulebyzYLs2aFK7PayS+VFheZteJMELpyCbTapxDFkH4aDCyr0NQp4yVXPQbBH6TCfmb5h +qAaEuSh6XzjZG6k4sIN/c8HDO0gqgg8hm7jMqDXDhBuDsz6+pJVpATqJAHgE2cn0mRmrVn5bi4Y5 +FZGkECwJMoBgs5PAKrYYC51+jUnyEEp/+dVGLxmSo5mnJqy7jDzmDrxHB9xzUfFwZC8I+bRHHTBs +ROopN4WSaGa8gzj+ezku01DwH/teYLappvonQfGbGHLy9YR0SslnxFSuSGTfjNFusB3hB48IHpmc +celM2KX3RxIfdNFRnobzwqIjQAtz20um53MGjMGg6cFZrEb65i/4z3GcRm25xBWNOHkDRUjvxF3X +CO6HOSKGsg0PWEP3calILv3q1h8CAwEAAaOBrDCBqTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQUF6DNweRBtjpbO8tFnb0cwpj6hlgwHwYDVR0jBBgwFoAUF6DNweRB +tjpbO8tFnb0cwpj6hlgwRgYDVR0gBD8wPTA7BglghXQBWQEDAQEwLjAsBggrBgEFBQcCARYgaHR0 +cDovL3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBAHPGgeAn0i0P +4JUw4ppBf1AsX19iYamGamkYDHRJ1l2E6kFSGG9YrVBWIGrGvShpWJHckRE1qTodvBqlYJ7YH39F +kWnZfrt4csEGDyrOj4VwYaygzQu4OSlWhDJOhrs9xCrZ1x9y7v5RoSJBsXECYxqCsGKrXlcSH9/L +3XWgwF15kIwb4FDm3jH+mHtwX6WQ2K34ArZv02DdQEsixT2tOnqfGhpHkXkzuoLcMmkDlm4fS/Bx +/uNncqCxv1yL5PqZIseEuRuNI5c/7SXgz2W79WEE790eslpBIlqhn10s6FvJbakMDHiqYMZWjwFa +DGi8aRl5xB9+lwW/xekkUV7U1UtT7dkjWjYDZaPBA61BMPNGG4WQr2W11bHkFlt4dR2Xem1ZqSqP +e97Dh4kQmUlzeMg9vVE1dCrV8X5pGyq7O70luJpaPXJhkGaH7gzWTdQRdAtq/gsD/KNVV4n+Ssuu +WxcFyPKNIzFTONItaj+CuY0IavdeQXRuwxF+B6wpYJE/OMpXEA29MC/HpeZBoNquBYeaoKRlbEwJ +DIm6uNO5wJOKMPqN5ZprFQFOZ6raYlY+hAhm0sQ2fac+EPyI4NSA5QC9qvNOBqN6avlicuMJT+ub +DgEj8Z+7fNzcbBGXJbLytGMU0gYqZ4yD9c7qB9iaah7s5Aq7KkzrCWA5zspi2C5u +-----END CERTIFICATE----- + +GeoTrust Primary Certification Authority +======================================== +-----BEGIN CERTIFICATE----- +MIIDfDCCAmSgAwIBAgIQGKy1av1pthU6Y2yv2vrEoTANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQG +EwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjExMC8GA1UEAxMoR2VvVHJ1c3QgUHJpbWFyeSBD +ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjExMjcwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMFgx +CzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTEwLwYDVQQDEyhHZW9UcnVzdCBQ +cmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB +CgKCAQEAvrgVe//UfH1nrYNke8hCUy3f9oQIIGHWAVlqnEQRr+92/ZV+zmEwu3qDXwK9AWbK7hWN +b6EwnL2hhZ6UOvNWiAAxz9juapYC2e0DjPt1befquFUWBRaa9OBesYjAZIVcFU2Ix7e64HXprQU9 +nceJSOC7KMgD4TCTZF5SwFlwIjVXiIrxlQqD17wxcwE07e9GceBrAqg1cmuXm2bgyxx5X9gaBGge +RwLmnWDiNpcB3841kt++Z8dtd1k7j53WkBWUvEI0EME5+bEnPn7WinXFsq+W06Lem+SYvn3h6YGt +tm/81w7a4DSwDRp35+MImO9Y+pyEtzavwt+s0vQQBnBxNQIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQULNVQQZcVi/CPNmFbSvtr2ZnJM5IwDQYJKoZI +hvcNAQEFBQADggEBAFpwfyzdtzRP9YZRqSa+S7iq8XEN3GHHoOo0Hnp3DwQ16CePbJC/kRYkRj5K +Ts4rFtULUh38H2eiAkUxT87z+gOneZ1TatnaYzr4gNfTmeGl4b7UVXGYNTq+k+qurUKykG/g/CFN +NWMziUnWm07Kx+dOCQD32sfvmWKZd7aVIl6KoKv0uHiYyjgZmclynnjNS6yvGaBzEi38wkG6gZHa +Floxt/m0cYASSJlyc1pZU8FjUjPtp8nSOQJw+uCxQmYpqptR7TBUIhRf2asdweSU8Pj1K/fqynhG +1riR/aYNKxoUAT6A8EKglQdebc3MS6RFjasS6LPeWuWgfOgPIh1a6Vk= +-----END CERTIFICATE----- + +thawte Primary Root CA +====================== +-----BEGIN CERTIFICATE----- +MIIEIDCCAwigAwIBAgIQNE7VVyDV7exJ9C/ON9srbTANBgkqhkiG9w0BAQUFADCBqTELMAkGA1UE +BhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2 +aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhv +cml6ZWQgdXNlIG9ubHkxHzAdBgNVBAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwHhcNMDYxMTE3 +MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCBqTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwg +SW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMv +KGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxHzAdBgNVBAMT +FnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCs +oPD7gFnUnMekz52hWXMJEEUMDSxuaPFsW0hoSVk3/AszGcJ3f8wQLZU0HObrTQmnHNK4yZc2AreJ +1CRfBsDMRJSUjQJib+ta3RGNKJpchJAQeg29dGYvajig4tVUROsdB58Hum/u6f1OCyn1PoSgAfGc +q/gcfomk6KHYcWUNo1F77rzSImANuVud37r8UVsLr5iy6S7pBOhih94ryNdOwUxkHt3Ph1i6Sk/K +aAcdHJ1KxtUvkcx8cXIcxcBn6zL9yZJclNqFwJu/U30rCfSMnZEfl2pSy94JNqR32HuHUETVPm4p +afs5SSYeCaWAe0At6+gnhcn+Yf1+5nyXHdWdAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBR7W0XPr87Lev0xkhpqtvNG61dIUDANBgkqhkiG9w0BAQUF +AAOCAQEAeRHAS7ORtvzw6WfUDW5FvlXok9LOAz/t2iWwHVfLHjp2oEzsUHboZHIMpKnxuIvW1oeE +uzLlQRHAd9mzYJ3rG9XRbkREqaYB7FViHXe4XI5ISXycO1cRrK1zN44veFyQaEfZYGDm/Ac9IiAX +xPcW6cTYcvnIc3zfFi8VqT79aie2oetaupgf1eNNZAqdE8hhuvU5HIe6uL17In/2/qxAeeWsEG89 +jxt5dovEN7MhGITlNgDrYyCZuen+MwS7QcjBAvlEYyCegc5C09Y/LHbTY5xZ3Y+m4Q6gLkH3LpVH +z7z9M/P2C2F+fpErgUfCJzDupxBdN49cOSvkBPB7jVaMaA== +-----END CERTIFICATE----- + +VeriSign Class 3 Public Primary Certification Authority - G5 +============================================================ +-----BEGIN CERTIFICATE----- +MIIE0zCCA7ugAwIBAgIQGNrRniZ96LtKIVjNzGs7SjANBgkqhkiG9w0BAQUFADCByjELMAkGA1UE +BhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBO +ZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVk +IHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5IC0gRzUwHhcNMDYxMTA4MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCB +yjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2ln +biBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2lnbiwgSW5jLiAtIEZvciBh +dXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmlt +YXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw +ggEKAoIBAQCvJAgIKXo1nmAMqudLO07cfLw8RRy7K+D+KQL5VwijZIUVJ/XxrcgxiV0i6CqqpkKz +j/i5Vbext0uz/o9+B1fs70PbZmIVYc9gDaTY3vjgw2IIPVQT60nKWVSFJuUrjxuf6/WhkcIzSdhD +Y2pSS9KP6HBRTdGJaXvHcPaz3BJ023tdS1bTlr8Vd6Gw9KIl8q8ckmcY5fQGBO+QueQA5N06tRn/ +Arr0PO7gi+s3i+z016zy9vA9r911kTMZHRxAy3QkGSGT2RT+rCpSx4/VBEnkjWNHiDxpg8v+R70r +fk/Fla4OndTRQ8Bnc+MUCH7lP59zuDMKz10/NIeWiu5T6CUVAgMBAAGjgbIwga8wDwYDVR0TAQH/ +BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2Uv +Z2lmMCEwHzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVy +aXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFH/TZafC3ey78DAJ80M5+gKvMzEzMA0GCSqG +SIb3DQEBBQUAA4IBAQCTJEowX2LP2BqYLz3q3JktvXf2pXkiOOzEp6B4Eq1iDkVwZMXnl2YtmAl+ +X6/WzChl8gGqCBpH3vn5fJJaCGkgDdk+bW48DW7Y5gaRQBi5+MHt39tBquCWIMnNZBU4gcmU7qKE +KQsTb47bDN0lAtukixlE0kF6BWlKWE9gyn6CagsCqiUXObXbf+eEZSqVir2G3l6BFoMtEMze/aiC +Km0oHw0LxOXnGiYZ4fQRbxC1lfznQgUy286dUV4otp6F01vvpX1FQHKOtw5rDgb7MzVIcbidJ4vE +ZV8NhnacRHr2lVz2XTIIM6RUthg/aFzyQkqFOFSDX9HoLPKsEdao7WNq +-----END CERTIFICATE----- + +SecureTrust CA +============== +-----BEGIN CERTIFICATE----- +MIIDuDCCAqCgAwIBAgIQDPCOXAgWpa1Cf/DrJxhZ0DANBgkqhkiG9w0BAQUFADBIMQswCQYDVQQG +EwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xFzAVBgNVBAMTDlNlY3VyZVRy +dXN0IENBMB4XDTA2MTEwNzE5MzExOFoXDTI5MTIzMTE5NDA1NVowSDELMAkGA1UEBhMCVVMxIDAe +BgNVBAoTF1NlY3VyZVRydXN0IENvcnBvcmF0aW9uMRcwFQYDVQQDEw5TZWN1cmVUcnVzdCBDQTCC +ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKukgeWVzfX2FI7CT8rU4niVWJxB4Q2ZQCQX +OZEzZum+4YOvYlyJ0fwkW2Gz4BERQRwdbvC4u/jep4G6pkjGnx29vo6pQT64lO0pGtSO0gMdA+9t +DWccV9cGrcrI9f4Or2YlSASWC12juhbDCE/RRvgUXPLIXgGZbf2IzIaowW8xQmxSPmjL8xk037uH +GFaAJsTQ3MBv396gwpEWoGQRS0S8Hvbn+mPeZqx2pHGj7DaUaHp3pLHnDi+BeuK1cobvomuL8A/b +01k/unK8RCSc43Oz969XL0Imnal0ugBS8kvNU3xHCzaFDmapCJcWNFfBZveA4+1wVMeT4C4oFVmH +ursCAwEAAaOBnTCBmjATBgkrBgEEAYI3FAIEBh4EAEMAQTALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQUQjK2FvoE/f5dS3rD/fdMQB1aQ68wNAYDVR0fBC0wKzApoCegJYYj +aHR0cDovL2NybC5zZWN1cmV0cnVzdC5jb20vU1RDQS5jcmwwEAYJKwYBBAGCNxUBBAMCAQAwDQYJ +KoZIhvcNAQEFBQADggEBADDtT0rhWDpSclu1pqNlGKa7UTt36Z3q059c4EVlew3KW+JwULKUBRSu +SceNQQcSc5R+DCMh/bwQf2AQWnL1mA6s7Ll/3XpvXdMc9P+IBWlCqQVxyLesJugutIxq/3HcuLHf +mbx8IVQr5Fiiu1cprp6poxkmD5kuCLDv/WnPmRoJjeOnnyvJNjR7JLN4TJUXpAYmHrZkUjZfYGfZ +nMUFdAvnZyPSCPyI6a6Lf+Ew9Dd+/cYy2i2eRDAwbO4H3tI0/NL/QPZL9GZGBlSm8jIKYyYwa5vR +3ItHuuG51WLQoqD0ZwV4KWMabwTW+MZMo5qxN7SN5ShLHZ4swrhovO0C7jE= +-----END CERTIFICATE----- + +Secure Global CA +================ +-----BEGIN CERTIFICATE----- +MIIDvDCCAqSgAwIBAgIQB1YipOjUiolN9BPI8PjqpTANBgkqhkiG9w0BAQUFADBKMQswCQYDVQQG +EwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBH +bG9iYWwgQ0EwHhcNMDYxMTA3MTk0MjI4WhcNMjkxMjMxMTk1MjA2WjBKMQswCQYDVQQGEwJVUzEg +MB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwg +Q0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvNS7YrGxVaQZx5RNoJLNP2MwhR/jx +YDiJiQPpvepeRlMJ3Fz1Wuj3RSoC6zFh1ykzTM7HfAo3fg+6MpjhHZevj8fcyTiW89sa/FHtaMbQ +bqR8JNGuQsiWUGMu4P51/pinX0kuleM5M2SOHqRfkNJnPLLZ/kG5VacJjnIFHovdRIWCQtBJwB1g +8NEXLJXr9qXBkqPFwqcIYA1gBBCWeZ4WNOaptvolRTnIHmX5k/Wq8VLcmZg9pYYaDDUz+kulBAYV +HDGA76oYa8J719rO+TMg1fW9ajMtgQT7sFzUnKPiXB3jqUJ1XnvUd+85VLrJChgbEplJL4hL/VBi +0XPnj3pDAgMBAAGjgZ0wgZowEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1Ud +EwEB/wQFMAMBAf8wHQYDVR0OBBYEFK9EBMJBfkiD2045AuzshHrmzsmkMDQGA1UdHwQtMCswKaAn +oCWGI2h0dHA6Ly9jcmwuc2VjdXJldHJ1c3QuY29tL1NHQ0EuY3JsMBAGCSsGAQQBgjcVAQQDAgEA +MA0GCSqGSIb3DQEBBQUAA4IBAQBjGghAfaReUw132HquHw0LURYD7xh8yOOvaliTFGCRsoTciE6+ +OYo68+aCiV0BN7OrJKQVDpI1WkpEXk5X+nXOH0jOZvQ8QCaSmGwb7iRGDBezUqXbpZGRzzfTb+cn +CDpOGR86p1hcF895P4vkp9MmI50mD1hp/Ed+stCNi5O/KU9DaXR2Z0vPB4zmAve14bRDtUstFJ/5 +3CYNv6ZHdAbYiNE6KTCEztI5gGIbqMdXSbxqVVFnFUq+NQfk1XWYN3kwFNspnWzFacxHVaIw98xc +f8LDmBxrThaA63p4ZUWiABqvDA1VZDRIuJK58bRQKfJPIx/abKwfROHdI3hRW8cW +-----END CERTIFICATE----- + +COMODO Certification Authority +============================== +-----BEGIN CERTIFICATE----- +MIIEHTCCAwWgAwIBAgIQToEtioJl4AsC7j41AkblPTANBgkqhkiG9w0BAQUFADCBgTELMAkGA1UE +BhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgG +A1UEChMRQ09NT0RPIENBIExpbWl0ZWQxJzAlBgNVBAMTHkNPTU9ETyBDZXJ0aWZpY2F0aW9uIEF1 +dGhvcml0eTAeFw0wNjEyMDEwMDAwMDBaFw0yOTEyMzEyMzU5NTlaMIGBMQswCQYDVQQGEwJHQjEb +MBkGA1UECBMSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFD +T01PRE8gQ0EgTGltaXRlZDEnMCUGA1UEAxMeQ09NT0RPIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0ECLi3LjkRv3UcEbVASY06m/weaKXTuH ++7uIzg3jLz8GlvCiKVCZrts7oVewdFFxze1CkU1B/qnI2GqGd0S7WWaXUF601CxwRM/aN5VCaTww +xHGzUvAhTaHYujl8HJ6jJJ3ygxaYqhZ8Q5sVW7euNJH+1GImGEaaP+vB+fGQV+useg2L23IwambV +4EajcNxo2f8ESIl33rXp+2dtQem8Ob0y2WIC8bGoPW43nOIv4tOiJovGuFVDiOEjPqXSJDlqR6sA +1KGzqSX+DT+nHbrTUcELpNqsOO9VUCQFZUaTNE8tja3G1CEZ0o7KBWFxB3NH5YoZEr0ETc5OnKVI +rLsm9wIDAQABo4GOMIGLMB0GA1UdDgQWBBQLWOWLxkwVN6RAqTCpIb5HNlpW/zAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zBJBgNVHR8EQjBAMD6gPKA6hjhodHRwOi8vY3JsLmNvbW9k +b2NhLmNvbS9DT01PRE9DZXJ0aWZpY2F0aW9uQXV0aG9yaXR5LmNybDANBgkqhkiG9w0BAQUFAAOC +AQEAPpiem/Yb6dc5t3iuHXIYSdOH5EOC6z/JqvWote9VfCFSZfnVDeFs9D6Mk3ORLgLETgdxb8CP +OGEIqB6BCsAvIC9Bi5HcSEW88cbeunZrM8gALTFGTO3nnc+IlP8zwFboJIYmuNg4ON8qa90SzMc/ +RxdMosIGlgnW2/4/PEZB31jiVg88O8EckzXZOFKs7sjsLjBOlDW0JB9LeGna8gI4zJVSk/BwJVmc +IGfE7vmLV2H0knZ9P4SNVbfo5azV8fUZVqZa+5Acr5Pr5RzUZ5ddBA6+C4OmF4O5MBKgxTMVBbkN ++8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IBZQ== +-----END CERTIFICATE----- + +Network Solutions Certificate Authority +======================================= +-----BEGIN CERTIFICATE----- +MIID5jCCAs6gAwIBAgIQV8szb8JcFuZHFhfjkDFo4DANBgkqhkiG9w0BAQUFADBiMQswCQYDVQQG +EwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMuMTAwLgYDVQQDEydOZXR3b3Jr +IFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcNMDYxMjAxMDAwMDAwWhcNMjkxMjMx +MjM1OTU5WjBiMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMu +MTAwLgYDVQQDEydOZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDkvH6SMG3G2I4rC7xGzuAnlt7e+foS0zwzc7MEL7xx +jOWftiJgPl9dzgn/ggwbmlFQGiaJ3dVhXRncEg8tCqJDXRfQNJIg6nPPOCwGJgl6cvf6UDL4wpPT +aaIjzkGxzOTVHzbRijr4jGPiFFlp7Q3Tf2vouAPlT2rlmGNpSAW+Lv8ztumXWWn4Zxmuk2GWRBXT +crA/vGp97Eh/jcOrqnErU2lBUzS1sLnFBgrEsEX1QV1uiUV7PTsmjHTC5dLRfbIR1PtYMiKagMnc +/Qzpf14Dl847ABSHJ3A4qY5usyd2mFHgBeMhqxrVhSI8KbWaFsWAqPS7azCPL0YCorEMIuDTAgMB +AAGjgZcwgZQwHQYDVR0OBBYEFCEwyfsA106Y2oeqKtCnLrFAMadMMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MFIGA1UdHwRLMEkwR6BFoEOGQWh0dHA6Ly9jcmwubmV0c29sc3NsLmNv +bS9OZXR3b3JrU29sdXRpb25zQ2VydGlmaWNhdGVBdXRob3JpdHkuY3JsMA0GCSqGSIb3DQEBBQUA +A4IBAQC7rkvnt1frf6ott3NHhWrB5KUd5Oc86fRZZXe1eltajSU24HqXLjjAV2CDmAaDn7l2em5Q +4LqILPxFzBiwmZVRDuwduIj/h1AcgsLj4DKAv6ALR8jDMe+ZZzKATxcheQxpXN5eNK4CtSbqUN9/ +GGUsyfJj4akH/nxxH2szJGoeBfcFaMBqEssuXmHLrijTfsK0ZpEmXzwuJF/LWA/rKOyvEZbz3Htv +wKeI8lN3s2Berq4o2jUsbzRF0ybh3uxbTydrFny9RAQYgrOJeRcQcT16ohZO9QHNpGxlaKFJdlxD +ydi8NmdspZS11My5vWo1ViHe2MPr+8ukYEywVaCge1ey +-----END CERTIFICATE----- + +COMODO ECC Certification Authority +================================== +-----BEGIN CERTIFICATE----- +MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTELMAkGA1UEBhMC +R0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UE +ChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwHhcNMDgwMzA2MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0Ix +GzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR +Q09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRo +b3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSRFtSrYpn1PlILBs5BAH+X +4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0JcfRK9ChQtP6IHG4/bC8vCVlbpVsLM5ni +wz2J+Wos77LTBumjQjBAMB0GA1UdDgQWBBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VG +FAkK+qDmfQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdvGDeA +U/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY= +-----END CERTIFICATE----- + +OISTE WISeKey Global Root GA CA +=============================== +-----BEGIN CERTIFICATE----- +MIID8TCCAtmgAwIBAgIQQT1yx/RrH4FDffHSKFTfmjANBgkqhkiG9w0BAQUFADCBijELMAkGA1UE +BhMCQ0gxEDAOBgNVBAoTB1dJU2VLZXkxGzAZBgNVBAsTEkNvcHlyaWdodCAoYykgMjAwNTEiMCAG +A1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBH +bG9iYWwgUm9vdCBHQSBDQTAeFw0wNTEyMTExNjAzNDRaFw0zNzEyMTExNjA5NTFaMIGKMQswCQYD +VQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEbMBkGA1UECxMSQ29weXJpZ2h0IChjKSAyMDA1MSIw +IAYDVQQLExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5 +IEdsb2JhbCBSb290IEdBIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAy0+zAJs9 +Nt350UlqaxBJH+zYK7LG+DKBKUOVTJoZIyEVRd7jyBxRVVuuk+g3/ytr6dTqvirdqFEr12bDYVxg +Asj1znJ7O7jyTmUIms2kahnBAbtzptf2w93NvKSLtZlhuAGio9RN1AU9ka34tAhxZK9w8RxrfvbD +d50kc3vkDIzh2TbhmYsFmQvtRTEJysIA2/dyoJaqlYfQjse2YXMNdmaM3Bu0Y6Kff5MTMPGhJ9vZ +/yxViJGg4E8HsChWjBgbl0SOid3gF27nKu+POQoxhILYQBRJLnpB5Kf+42TMwVlxSywhp1t94B3R +LoGbw9ho972WG6xwsRYUC9tguSYBBQIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUswN+rja8sHnR3JQmthG+IbJphpQwEAYJKwYBBAGCNxUBBAMCAQAwDQYJ +KoZIhvcNAQEFBQADggEBAEuh/wuHbrP5wUOxSPMowB0uyQlB+pQAHKSkq0lPjz0e701vvbyk9vIm +MMkQyh2I+3QZH4VFvbBsUfk2ftv1TDI6QU9bR8/oCy22xBmddMVHxjtqD6wU2zz0c5ypBd8A3HR4 ++vg1YFkCExh8vPtNsCBtQ7tgMHpnM1zFmdH4LTlSc/uMqpclXHLZCB6rTjzjgTGfA6b7wP4piFXa +hNVQA7bihKOmNqoROgHhGEvWRGizPflTdISzRpFGlgC3gCy24eMQ4tui5yiPAZZiFj4A4xylNoEY +okxSdsARo27mHbrjWr42U8U+dY+GaSlYU7Wcu2+fXMUY7N0v4ZjJ/L7fCg0= +-----END CERTIFICATE----- + +Certigna +======== +-----BEGIN CERTIFICATE----- +MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNVBAYTAkZSMRIw +EAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4XDTA3MDYyOTE1MTMwNVoXDTI3 +MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwI +Q2VydGlnbmEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7q +XOEm7RFHYeGifBZ4QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyH +GxnygQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbwzBfsV1/p +ogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q130yGLMLLGq/jj8UEYkg +DncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKf +Irjxwo1p3Po6WAbfAgMBAAGjgbwwgbkwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQ +tCRZvgHyUtVF9lo53BEwZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJ +BgNVBAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzjAQ/J +SP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG9w0BAQUFAAOCAQEA +hQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8hbV6lUmPOEvjvKtpv6zf+EwLHyzs+ +ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFncfca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1klu +PBS1xp81HlDQwY9qcEQCYsuuHWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY +1gkIl2PlwS6wt0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw +WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== +-----END CERTIFICATE----- + +Deutsche Telekom Root CA 2 +========================== +-----BEGIN CERTIFICATE----- +MIIDnzCCAoegAwIBAgIBJjANBgkqhkiG9w0BAQUFADBxMQswCQYDVQQGEwJERTEcMBoGA1UEChMT +RGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxlU2VjIFRydXN0IENlbnRlcjEjMCEG +A1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290IENBIDIwHhcNOTkwNzA5MTIxMTAwWhcNMTkwNzA5 +MjM1OTAwWjBxMQswCQYDVQQGEwJERTEcMBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0G +A1UECxMWVC1UZWxlU2VjIFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBS +b290IENBIDIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCrC6M14IspFLEUha88EOQ5 +bzVdSq7d6mGNlUn0b2SjGmBmpKlAIoTZ1KXleJMOaAGtuU1cOs7TuKhCQN/Po7qCWWqSG6wcmtoI +KyUn+WkjR/Hg6yx6m/UTAtB+NHzCnjwAWav12gz1MjwrrFDa1sPeg5TKqAyZMg4ISFZbavva4VhY +AUlfckE8FQYBjl2tqriTtM2e66foai1SNNs671x1Udrb8zH57nGYMsRUFUQM+ZtV7a3fGAigo4aK +Se5TBY8ZTNXeWHmb0mocQqvF1afPaA+W5OFhmHZhyJF81j4A4pFQh+GdCuatl9Idxjp9y7zaAzTV +jlsB9WoHtxa2bkp/AgMBAAGjQjBAMB0GA1UdDgQWBBQxw3kbuvVT1xfgiXotF2wKsyudMzAPBgNV +HRMECDAGAQH/AgEFMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAlGRZrTlk5ynr +E/5aw4sTV8gEJPB0d8Bg42f76Ymmg7+Wgnxu1MM9756AbrsptJh6sTtU6zkXR34ajgv8HzFZMQSy +zhfzLMdiNlXiItiJVbSYSKpk+tYcNthEeFpaIzpXl/V6ME+un2pMSyuOoAPjPuCp1NJ70rOo4nI8 +rZ7/gFnkm0W09juwzTkZmDLl6iFhkOQxIY40sfcvNUqFENrnijchvllj4PKFiDFT1FQUhXB59C4G +dyd1Lx+4ivn+xbrYNuSD7Odlt79jWvNGr4GUN9RBjNYj1h7P9WgbRGOiWrqnNVmh5XAFmw4jV5mU +Cm26OWMohpLzGITY+9HPBVZkVw== +-----END CERTIFICATE----- + +Cybertrust Global Root +====================== +-----BEGIN CERTIFICATE----- +MIIDoTCCAomgAwIBAgILBAAAAAABD4WqLUgwDQYJKoZIhvcNAQEFBQAwOzEYMBYGA1UEChMPQ3li +ZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2JhbCBSb290MB4XDTA2MTIxNTA4 +MDAwMFoXDTIxMTIxNTA4MDAwMFowOzEYMBYGA1UEChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQD +ExZDeWJlcnRydXN0IEdsb2JhbCBSb290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA ++Mi8vRRQZhP/8NN57CPytxrHjoXxEnOmGaoQ25yiZXRadz5RfVb23CO21O1fWLE3TdVJDm71aofW +0ozSJ8bi/zafmGWgE07GKmSb1ZASzxQG9Dvj1Ci+6A74q05IlG2OlTEQXO2iLb3VOm2yHLtgwEZL +AfVJrn5GitB0jaEMAs7u/OePuGtm839EAL9mJRQr3RAwHQeWP032a7iPt3sMpTjr3kfb1V05/Iin +89cqdPHoWqI7n1C6poxFNcJQZZXcY4Lv3b93TZxiyWNzFtApD0mpSPCzqrdsxacwOUBdrsTiXSZT +8M4cIwhhqJQZugRiQOwfOHB3EgZxpzAYXSUnpQIDAQABo4GlMIGiMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBS2CHsNesysIEyGVjJez6tuhS1wVzA/BgNVHR8EODA2 +MDSgMqAwhi5odHRwOi8vd3d3Mi5wdWJsaWMtdHJ1c3QuY29tL2NybC9jdC9jdHJvb3QuY3JsMB8G +A1UdIwQYMBaAFLYIew16zKwgTIZWMl7Pq26FLXBXMA0GCSqGSIb3DQEBBQUAA4IBAQBW7wojoFRO +lZfJ+InaRcHUowAl9B8Tq7ejhVhpwjCt2BWKLePJzYFa+HMjWqd8BfP9IjsO0QbE2zZMcwSO5bAi +5MXzLqXZI+O4Tkogp24CJJ8iYGd7ix1yCcUxXOl5n4BHPa2hCwcUPUf/A2kaDAtE52Mlp3+yybh2 +hO0j9n0Hq0V+09+zv+mKts2oomcrUtW3ZfA5TGOgkXmTUg9U3YO7n9GPp1Nzw8v/MOx8BLjYRB+T +X3EJIrduPuocA06dGiBh+4E37F78CkWr1+cXVdCg6mCbpvbjjFspwgZgFJ0tl0ypkxWdYcQBX0jW +WL1WMRJOEcgh4LMRkWXbtKaIOM5V +-----END CERTIFICATE----- + +ePKI Root Certification Authority +================================= +-----BEGIN CERTIFICATE----- +MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBeMQswCQYDVQQG +EwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0ZC4xKjAoBgNVBAsMIWVQS0kg +Um9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMx +MjdaMF4xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEq +MCgGA1UECwwhZVBLSSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAHSyZbCUNs +IZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAhijHyl3SJCRImHJ7K2RKi +lTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3XDZoTM1PRYfl61dd4s5oz9wCGzh1NlDiv +qOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX +12ruOzjjK9SXDrkb5wdJfzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0O +WQqraffAsgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uUWH1+ +ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLSnT0IFaUQAS2zMnao +lQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pHdmX2Os+PYhcZewoozRrSgx4hxyy/ +vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJipNiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXi +Zo1jDiVN1Rmy5nk3pyKdVDECAwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/Qkqi +MAwGA1UdEwQFMAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH +ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGBuvl2ICO1J2B0 +1GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6YlPwZpVnPDimZI+ymBV3QGypzq +KOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkPJXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdV +xrsStZf0X4OFunHB2WyBEXYKCrC/gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEP +NXubrjlpC2JgQCA2j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+r +GNm65ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUBo2M3IUxE +xJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS/jQ6fbjpKdx2qcgw+BRx +gMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2zGp1iro2C6pSe3VkQw63d4k3jMdXH7Ojy +sP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTEW9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmOD +BCEIZ43ygknQW/2xzQ+DhNQ+IIX3Sj0rnP0qCglN6oH4EZw= +-----END CERTIFICATE----- + +certSIGN ROOT CA +================ +-----BEGIN CERTIFICATE----- +MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYTAlJPMREwDwYD +VQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTAeFw0wNjA3MDQxNzIwMDRa +Fw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UE +CxMQY2VydFNJR04gUk9PVCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7I +JUqOtdu0KBuqV5Do0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHH +rfAQUySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5dRdY4zTW2 +ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQOA7+j0xbm0bqQfWwCHTD +0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwvJoIQ4uNllAoEwF73XVv4EOLQunpL+943 +AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8B +Af8EBAMCAcYwHQYDVR0OBBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IB +AQA+0hyJLjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecYMnQ8 +SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ44gx+FkagQnIl6Z0 +x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6IJd1hJyMctTEHBDa0GpC9oHRxUIlt +vBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNwi/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7Nz +TogVZ96edhBiIL5VaZVDADlN9u6wWk5JRFRYX0KD +-----END CERTIFICATE----- + +GeoTrust Primary Certification Authority - G3 +============================================= +-----BEGIN CERTIFICATE----- +MIID/jCCAuagAwIBAgIQFaxulBmyeUtB9iepwxgPHzANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UE +BhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChjKSAyMDA4IEdlb1RydXN0 +IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFy +eSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEczMB4XDTA4MDQwMjAwMDAwMFoXDTM3MTIwMTIz +NTk1OVowgZgxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAo +YykgMjAwOCBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNVBAMT +LUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMzCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBANziXmJYHTNXOTIz+uvLh4yn1ErdBojqZI4xmKU4kB6Yzy5j +K/BGvESyiaHAKAxJcCGVn2TAppMSAmUmhsalifD614SgcK9PGpc/BkTVyetyEH3kMSj7HGHmKAdE +c5IiaacDiGydY8hS2pgn5whMcD60yRLBxWeDXTPzAxHsatBT4tG6NmCUgLthY2xbF37fQJQeqw3C +IShwiP/WJmxsYAQlTlV+fe+/lEjetx3dcI0FX4ilm/LC7urRQEFtYjgdVgbFA0dRIBn8exALDmKu +dlW/X3e+PkkBUz2YJQN2JFodtNuJ6nnltrM7P7pMKEF/BqxqjsHQ9gUdfeZChuOl1UcCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMR5yo6hTgMdHNxr +2zFblD4/MH8tMA0GCSqGSIb3DQEBCwUAA4IBAQAtxRPPVoB7eni9n64smefv2t+UXglpp+duaIy9 +cr5HqQ6XErhK8WTTOd8lNNTBzU6B8A8ExCSzNJbGpqow32hhc9f5joWJ7w5elShKKiePEI4ufIbE +Ap7aDHdlDkQNkv39sxY2+hENHYwOB4lqKVb3cvTdFZx3NWZXqxNT2I7BQMXXExZacse3aQHEerGD +AWh9jUGhlBjBJVz88P6DAod8DQ3PLghcSkANPuyBYeYk28rgDi0Hsj5W3I31QYUHSJsMC8tJP33s +t/3LjWeJGqvtux6jAAgIFyqCXDFdRootD4abdNlF+9RAsXqqaC2Gspki4cErx5z481+oghLrGREt +-----END CERTIFICATE----- + +thawte Primary Root CA - G2 +=========================== +-----BEGIN CERTIFICATE----- +MIICiDCCAg2gAwIBAgIQNfwmXNmET8k9Jj1Xm67XVjAKBggqhkjOPQQDAzCBhDELMAkGA1UEBhMC +VVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjE4MDYGA1UECxMvKGMpIDIwMDcgdGhhd3RlLCBJbmMu +IC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAiBgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3Qg +Q0EgLSBHMjAeFw0wNzExMDUwMDAwMDBaFw0zODAxMTgyMzU5NTlaMIGEMQswCQYDVQQGEwJVUzEV +MBMGA1UEChMMdGhhd3RlLCBJbmMuMTgwNgYDVQQLEy8oYykgMjAwNyB0aGF3dGUsIEluYy4gLSBG +b3IgYXV0aG9yaXplZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAt +IEcyMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEotWcgnuVnfFSeIf+iha/BebfowJPDQfGAFG6DAJS +LSKkQjnE/o/qycG+1E3/n3qe4rF8mq2nhglzh9HnmuN6papu+7qzcMBniKI11KOasf2twu8x+qi5 +8/sIxpHR+ymVo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQU +mtgAMADna3+FGO6Lts6KDPgR4bswCgYIKoZIzj0EAwMDaQAwZgIxAN344FdHW6fmCsO99YCKlzUN +G4k8VIZ3KMqh9HneteY4sPBlcIx/AlTCv//YoT7ZzwIxAMSNlPzcU9LcnXgWHxUzI1NS41oxXZ3K +rr0TKUQNJ1uo52icEvdYPy5yAlejj6EULg== +-----END CERTIFICATE----- + +thawte Primary Root CA - G3 +=========================== +-----BEGIN CERTIFICATE----- +MIIEKjCCAxKgAwIBAgIQYAGXt0an6rS0mtZLL/eQ+zANBgkqhkiG9w0BAQsFADCBrjELMAkGA1UE +BhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2 +aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIwMDggdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhv +cml6ZWQgdXNlIG9ubHkxJDAiBgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMzAeFw0w +ODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIGuMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhh +d3RlLCBJbmMuMSgwJgYDVQQLEx9DZXJ0aWZpY2F0aW9uIFNlcnZpY2VzIERpdmlzaW9uMTgwNgYD +VQQLEy8oYykgMjAwOCB0aGF3dGUsIEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTEkMCIG +A1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAtIEczMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAsr8nLPvb2FvdeHsbnndmgcs+vHyu86YnmjSjaDFxODNi5PNxZnmxqWWjpYvVj2At +P0LMqmsywCPLLEHd5N/8YZzic7IilRFDGF/Eth9XbAoFWCLINkw6fKXRz4aviKdEAhN0cXMKQlkC ++BsUa0Lfb1+6a4KinVvnSr0eAXLbS3ToO39/fR8EtCab4LRarEc9VbjXsCZSKAExQGbY2SS99irY +7CFJXJv2eul/VTV+lmuNk5Mny5K76qxAwJ/C+IDPXfRa3M50hqY+bAtTyr2SzhkGcuYMXDhpxwTW +vGzOW/b3aJzcJRVIiKHpqfiYnODz1TEoYRFsZ5aNOZnLwkUkOQIDAQABo0IwQDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUrWyqlGCc7eT/+j4KdCtjA/e2Wb8wDQYJ +KoZIhvcNAQELBQADggEBABpA2JVlrAmSicY59BDlqQ5mU1143vokkbvnRFHfxhY0Cu9qRFHqKweK +A3rD6z8KLFIWoCtDuSWQP3CpMyVtRRooOyfPqsMpQhvfO0zAMzRbQYi/aytlryjvsvXDqmbOe1bu +t8jLZ8HJnBoYuMTDSQPxYA5QzUbF83d597YV4Djbxy8ooAw/dyZ02SUS2jHaGh7cKUGRIjxpp7sC +8rZcJwOJ9Abqm+RyguOhCcHpABnTPtRwa7pxpqpYrvS76Wy274fMm7v/OeZWYdMKp8RcTGB7BXcm +er/YB1IsYvdwY9k5vG8cwnncdimvzsUsZAReiDZuMdRAGmI0Nj81Aa6sY6A= +-----END CERTIFICATE----- + +GeoTrust Primary Certification Authority - G2 +============================================= +-----BEGIN CERTIFICATE----- +MIICrjCCAjWgAwIBAgIQPLL0SAoA4v7rJDteYD7DazAKBggqhkjOPQQDAzCBmDELMAkGA1UEBhMC +VVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChjKSAyMDA3IEdlb1RydXN0IElu +Yy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBD +ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEcyMB4XDTA3MTEwNTAwMDAwMFoXDTM4MDExODIzNTk1 +OVowgZgxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykg +MjAwNyBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNVBAMTLUdl +b1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMjB2MBAGByqGSM49AgEG +BSuBBAAiA2IABBWx6P0DFUPlrOuHNxFi79KDNlJ9RVcLSo17VDs6bl8VAsBQps8lL33KSLjHUGMc +KiEIfJo22Av+0SbFWDEwKCXzXV2juLaltJLtbCyf691DiaI8S0iRHVDsJt/WYC69IaNCMEAwDwYD +VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBVfNVdRVfslsq0DafwBo/q+ +EVXVMAoGCCqGSM49BAMDA2cAMGQCMGSWWaboCd6LuvpaiIjwH5HTRqjySkwCY/tsXzjbLkGTqQ7m +ndwxHLKgpxgceeHHNgIwOlavmnRs9vuD4DPTCF+hnMJbn0bWtsuRBmOiBuczrD6ogRLQy7rQkgu2 +npaqBA+K +-----END CERTIFICATE----- + +VeriSign Universal Root Certification Authority +=============================================== +-----BEGIN CERTIFICATE----- +MIIEuTCCA6GgAwIBAgIQQBrEZCGzEyEDDrvkEhrFHTANBgkqhkiG9w0BAQsFADCBvTELMAkGA1UE +BhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBO +ZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwOCBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVk +IHVzZSBvbmx5MTgwNgYDVQQDEy9WZXJpU2lnbiBVbml2ZXJzYWwgUm9vdCBDZXJ0aWZpY2F0aW9u +IEF1dGhvcml0eTAeFw0wODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIG9MQswCQYDVQQGEwJV +UzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdv +cmsxOjA4BgNVBAsTMShjKSAyMDA4IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl +IG9ubHkxODA2BgNVBAMTL1ZlcmlTaWduIFVuaXZlcnNhbCBSb290IENlcnRpZmljYXRpb24gQXV0 +aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx2E3XrEBNNti1xWb/1hajCMj +1mCOkdeQmIN65lgZOIzF9uVkhbSicfvtvbnazU0AtMgtc6XHaXGVHzk8skQHnOgO+k1KxCHfKWGP +MiJhgsWHH26MfF8WIFFE0XBPV+rjHOPMee5Y2A7Cs0WTwCznmhcrewA3ekEzeOEz4vMQGn+HLL72 +9fdC4uW/h2KJXwBL38Xd5HVEMkE6HnFuacsLdUYI0crSK5XQz/u5QGtkjFdN/BMReYTtXlT2NJ8I +AfMQJQYXStrxHXpma5hgZqTZ79IugvHw7wnqRMkVauIDbjPTrJ9VAMf2CGqUuV/c4DPxhGD5WycR +tPwW8rtWaoAljQIDAQABo4GyMIGvMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMG0G +CCsGAQUFBwEMBGEwX6FdoFswWTBXMFUWCWltYWdlL2dpZjAhMB8wBwYFKw4DAhoEFI/l0xqGrI2O +a8PPgGrUSBgsexkuMCUWI2h0dHA6Ly9sb2dvLnZlcmlzaWduLmNvbS92c2xvZ28uZ2lmMB0GA1Ud +DgQWBBS2d/ppSEefUxLVwuoHMnYH0ZcHGTANBgkqhkiG9w0BAQsFAAOCAQEASvj4sAPmLGd75JR3 +Y8xuTPl9Dg3cyLk1uXBPY/ok+myDjEedO2Pzmvl2MpWRsXe8rJq+seQxIcaBlVZaDrHC1LGmWazx +Y8u4TB1ZkErvkBYoH1quEPuBUDgMbMzxPcP1Y+Oz4yHJJDnp/RVmRvQbEdBNc6N9Rvk97ahfYtTx +P/jgdFcrGJ2BtMQo2pSXpXDrrB2+BxHw1dvd5Yzw1TKwg+ZX4o+/vqGqvz0dtdQ46tewXDpPaj+P +wGZsY6rp2aQW9IHRlRQOfc2VNNnSj3BzgXucfr2YYdhFh5iQxeuGMMY1v/D/w1WIg0vvBZIGcfK4 +mJO37M2CYfE45k+XmCpajQ== +-----END CERTIFICATE----- + +VeriSign Class 3 Public Primary Certification Authority - G4 +============================================================ +-----BEGIN CERTIFICATE----- +MIIDhDCCAwqgAwIBAgIQL4D+I4wOIg9IZxIokYesszAKBggqhkjOPQQDAzCByjELMAkGA1UEBhMC +VVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBOZXR3 +b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVz +ZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5IC0gRzQwHhcNMDcxMTA1MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCByjEL +MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBU +cnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRo +b3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5 +IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASnVnp8 +Utpkmw4tXNherJI9/gHmGUo9FANL+mAnINmDiWn6VMaaGF5VKmTeBvaNSjutEDxlPZCIBIngMGGz +rl0Bp3vefLK+ymVhAIau2o970ImtTR1ZmkGxvEeA3J5iw/mjgbIwga8wDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2UvZ2lmMCEw +HzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVyaXNpZ24u +Y29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFLMWkf3upm7ktS5Jj4d4gYDs5bG1MAoGCCqGSM49BAMD +A2gAMGUCMGYhDBgmYFo4e1ZC4Kf8NoRRkSAsdk1DPcQdhCPQrNZ8NQbOzWm9kA3bbEhCHQ6qQgIx +AJw9SDkjOVgaFRJZap7v1VmyHVIsmXHNxynfGyphe3HR3vPA5Q06Sqotp9iGKt0uEA== +-----END CERTIFICATE----- + +NetLock Arany (Class Gold) Főtanúsítvány +======================================== +-----BEGIN CERTIFICATE----- +MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQGEwJIVTERMA8G +A1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3MDUGA1UECwwuVGFuw7pzw610 +dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNlcnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBB +cmFueSAoQ2xhc3MgR29sZCkgRsWRdGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgx +MjA2MTUwODIxWjCBpzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxO +ZXRMb2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlmaWNhdGlv +biBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNzIEdvbGQpIEbFkXRhbsO6 +c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxCRec75LbRTDofTjl5Bu +0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrTlF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw +/HpYzY6b7cNGbIRwXdrzAZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAk +H3B5r9s5VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRGILdw +fzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2BJtr+UBdADTHLpl1 +neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAGAQH/AgEEMA4GA1UdDwEB/wQEAwIB +BjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2MU9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwW +qZw8UQCgwBEIBaeZ5m8BiFRhbvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTta +YtOUZcTh5m2C+C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC +bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2FuLjbvrW5Kfna +NwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2XjG4Kvte9nHfRCaexOYNkbQu +dZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E= +-----END CERTIFICATE----- + +Staat der Nederlanden Root CA - G2 +================================== +-----BEGIN CERTIFICATE----- +MIIFyjCCA7KgAwIBAgIEAJiWjDANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJOTDEeMBwGA1UE +CgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFhdCBkZXIgTmVkZXJsYW5kZW4g +Um9vdCBDQSAtIEcyMB4XDTA4MDMyNjExMTgxN1oXDTIwMDMyNTExMDMxMFowWjELMAkGA1UEBhMC +TkwxHjAcBgNVBAoMFVN0YWF0IGRlciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5l +ZGVybGFuZGVuIFJvb3QgQ0EgLSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMVZ +5291qj5LnLW4rJ4L5PnZyqtdj7U5EILXr1HgO+EASGrP2uEGQxGZqhQlEq0i6ABtQ8SpuOUfiUtn +vWFI7/3S4GCI5bkYYCjDdyutsDeqN95kWSpGV+RLufg3fNU254DBtvPUZ5uW6M7XxgpT0GtJlvOj +CwV3SPcl5XCsMBQgJeN/dVrlSPhOewMHBPqCYYdu8DvEpMfQ9XQ+pV0aCPKbJdL2rAQmPlU6Yiil +e7Iwr/g3wtG61jj99O9JMDeZJiFIhQGp5Rbn3JBV3w/oOM2ZNyFPXfUib2rFEhZgF1XyZWampzCR +OME4HYYEhLoaJXhena/MUGDWE4dS7WMfbWV9whUYdMrhfmQpjHLYFhN9C0lK8SgbIHRrxT3dsKpI +CT0ugpTNGmXZK4iambwYfp/ufWZ8Pr2UuIHOzZgweMFvZ9C+X+Bo7d7iscksWXiSqt8rYGPy5V65 +48r6f1CGPqI0GAwJaCgRHOThuVw+R7oyPxjMW4T182t0xHJ04eOLoEq9jWYv6q012iDTiIJh8BIi +trzQ1aTsr1SIJSQ8p22xcik/Plemf1WvbibG/ufMQFxRRIEKeN5KzlW/HdXZt1bv8Hb/C3m1r737 +qWmRRpdogBQ2HbN/uymYNqUg+oJgYjOk7Na6B6duxc8UpufWkjTYgfX8HV2qXB72o007uPc5AgMB +AAGjgZcwgZQwDwYDVR0TAQH/BAUwAwEB/zBSBgNVHSAESzBJMEcGBFUdIAAwPzA9BggrBgEFBQcC +ARYxaHR0cDovL3d3dy5wa2lvdmVyaGVpZC5ubC9wb2xpY2llcy9yb290LXBvbGljeS1HMjAOBgNV +HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJFoMocVHYnitfGsNig0jQt8YojrMA0GCSqGSIb3DQEBCwUA +A4ICAQCoQUpnKpKBglBu4dfYszk78wIVCVBR7y29JHuIhjv5tLySCZa59sCrI2AGeYwRTlHSeYAz ++51IvuxBQ4EffkdAHOV6CMqqi3WtFMTC6GY8ggen5ieCWxjmD27ZUD6KQhgpxrRW/FYQoAUXvQwj +f/ST7ZwaUb7dRUG/kSS0H4zpX897IZmflZ85OkYcbPnNe5yQzSipx6lVu6xiNGI1E0sUOlWDuYaN +kqbG9AclVMwWVxJKgnjIFNkXgiYtXSAfea7+1HAWFpWD2DU5/1JddRwWxRNVz0fMdWVSSt7wsKfk +CpYL+63C4iWEst3kvX5ZbJvw8NjnyvLplzh+ib7M+zkXYT9y2zqR2GUBGR2tUKRXCnxLvJxxcypF +URmFzI79R6d0lR2o0a9OF7FpJsKqeFdbxU2n5Z4FF5TKsl+gSRiNNOkmbEgeqmiSBeGCc1qb3Adb +CG19ndeNIdn8FCCqwkXfP+cAslHkwvgFuXkajDTznlvkN1trSt8sV4pAWja63XVECDdCcAz+3F4h +oKOKwJCcaNpQ5kUQR3i2TtJlycM33+FCY7BXN0Ute4qcvwXqZVUz9zkQxSgqIXobisQk+T8VyJoV +IPVVYpbtbZNQvOSqeK3Zywplh6ZmwcSBo3c6WB4L7oOLnR7SUqTMHW+wmG2UMbX4cQrcufx9MmDm +66+KAQ== +-----END CERTIFICATE----- + +Hongkong Post Root CA 1 +======================= +-----BEGIN CERTIFICATE----- +MIIDMDCCAhigAwIBAgICA+gwDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCSEsxFjAUBgNVBAoT +DUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3QgUm9vdCBDQSAxMB4XDTAzMDUx +NTA1MTMxNFoXDTIzMDUxNTA0NTIyOVowRzELMAkGA1UEBhMCSEsxFjAUBgNVBAoTDUhvbmdrb25n +IFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3QgUm9vdCBDQSAxMIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEArP84tulmAknjorThkPlAj3n54r15/gK97iSSHSL22oVyaf7XPwnU3ZG1 +ApzQjVrhVcNQhrkpJsLj2aDxaQMoIIBFIi1WpztUlVYiWR8o3x8gPW2iNr4joLFutbEnPzlTCeqr +auh0ssJlXI6/fMN4hM2eFvz1Lk8gKgifd/PFHsSaUmYeSF7jEAaPIpjhZY4bXSNmO7ilMlHIhqqh +qZ5/dpTCpmy3QfDVyAY45tQM4vM7TG1QjMSDJ8EThFk9nnV0ttgCXjqQesBCNnLsak3c78QA3xMY +V18meMjWCnl3v/evt3a5pQuEF10Q6m/hq5URX208o1xNg1vysxmKgIsLhwIDAQABoyYwJDASBgNV +HRMBAf8ECDAGAQH/AgEDMA4GA1UdDwEB/wQEAwIBxjANBgkqhkiG9w0BAQUFAAOCAQEADkbVPK7i +h9legYsCmEEIjEy82tvuJxuC52pF7BaLT4Wg87JwvVqWuspube5Gi27nKi6Wsxkz67SfqLI37pio +l7Yutmcn1KZJ/RyTZXaeQi/cImyaT/JaFTmxcdcrUehtHJjA2Sr0oYJ71clBoiMBdDhViw+5Lmei +IAQ32pwL0xch4I+XeTRvhEgCIDMb5jREn5Fw9IBehEPCKdJsEhTkYY2sEJCehFC78JZvRZ+K88ps +T/oROhUVRsPNH4NbLUES7VBnQRM9IauUiqpOfMGx+6fWtScvl6tu4B3i0RwsH0Ti/L6RoZz71ilT +c4afU9hDDl3WY4JxHYB0yvbiAmvZWg== +-----END CERTIFICATE----- + +SecureSign RootCA11 +=================== +-----BEGIN CERTIFICATE----- +MIIDbTCCAlWgAwIBAgIBATANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQGEwJKUDErMCkGA1UEChMi +SmFwYW4gQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcywgSW5jLjEcMBoGA1UEAxMTU2VjdXJlU2lnbiBS +b290Q0ExMTAeFw0wOTA0MDgwNDU2NDdaFw0yOTA0MDgwNDU2NDdaMFgxCzAJBgNVBAYTAkpQMSsw +KQYDVQQKEyJKYXBhbiBDZXJ0aWZpY2F0aW9uIFNlcnZpY2VzLCBJbmMuMRwwGgYDVQQDExNTZWN1 +cmVTaWduIFJvb3RDQTExMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA/XeqpRyQBTvL +TJszi1oURaTnkBbR31fSIRCkF/3frNYfp+TbfPfs37gD2pRY/V1yfIw/XwFndBWW4wI8h9uuywGO +wvNmxoVF9ALGOrVisq/6nL+k5tSAMJjzDbaTj6nU2DbysPyKyiyhFTOVMdrAG/LuYpmGYz+/3ZMq +g6h2uRMft85OQoWPIucuGvKVCbIFtUROd6EgvanyTgp9UK31BQ1FT0Zx/Sg+U/sE2C3XZR1KG/rP +O7AxmjVuyIsG0wCR8pQIZUyxNAYAeoni8McDWc/V1uinMrPmmECGxc0nEovMe863ETxiYAcjPitA +bpSACW22s293bzUIUPsCh8U+iQIDAQABo0IwQDAdBgNVHQ4EFgQUW/hNT7KlhtQ60vFjmqC+CfZX +t94wDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAKCh +OBZmLqdWHyGcBvod7bkixTgm2E5P7KN/ed5GIaGHd48HCJqypMWvDzKYC3xmKbabfSVSSUOrTC4r +bnpwrxYO4wJs+0LmGJ1F2FXI6Dvd5+H0LgscNFxsWEr7jIhQX5Ucv+2rIrVls4W6ng+4reV6G4pQ +Oh29Dbx7VFALuUKvVaAYga1lme++5Jy/xIWrQbJUb9wlze144o4MjQlJ3WN7WmmWAiGovVJZ6X01 +y8hSyn+B/tlr0/cR7SXf+Of5pPpyl4RTDaXQMhhRdlkUbA/r7F+AjHVDg8OFmP9Mni0N5HeDk061 +lgeLKBObjBmNQSdJQO7e5iNEOdyhIta6A/I= +-----END CERTIFICATE----- + +Microsec e-Szigno Root CA 2009 +============================== +-----BEGIN CERTIFICATE----- +MIIECjCCAvKgAwIBAgIJAMJ+QwRORz8ZMA0GCSqGSIb3DQEBCwUAMIGCMQswCQYDVQQGEwJIVTER +MA8GA1UEBwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jv +c2VjIGUtU3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5o +dTAeFw0wOTA2MTYxMTMwMThaFw0yOTEyMzAxMTMwMThaMIGCMQswCQYDVQQGEwJIVTERMA8GA1UE +BwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUt +U3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5odTCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOn4j/NjrdqG2KfgQvvPkd6mJviZpWNwrZuuyjNA +fW2WbqEORO7hE52UQlKavXWFdCyoDh2Tthi3jCyoz/tccbna7P7ofo/kLx2yqHWH2Leh5TvPmUpG +0IMZfcChEhyVbUr02MelTTMuhTlAdX4UfIASmFDHQWe4oIBhVKZsTh/gnQ4H6cm6M+f+wFUoLAKA +pxn1ntxVUwOXewdI/5n7N4okxFnMUBBjjqqpGrCEGob5X7uxUG6k0QrM1XF+H6cbfPVTbiJfyyvm +1HxdrtbCxkzlBQHZ7Vf8wSN5/PrIJIOV87VqUQHQd9bpEqH5GoP7ghu5sJf0dgYzQ0mg/wu1+rUC +AwEAAaOBgDB+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTLD8bf +QkPMPcu1SCOhGnqmKrs0aDAfBgNVHSMEGDAWgBTLD8bfQkPMPcu1SCOhGnqmKrs0aDAbBgNVHREE +FDASgRBpbmZvQGUtc3ppZ25vLmh1MA0GCSqGSIb3DQEBCwUAA4IBAQDJ0Q5eLtXMs3w+y/w9/w0o +lZMEyL/azXm4Q5DwpL7v8u8hmLzU1F0G9u5C7DBsoKqpyvGvivo/C3NqPuouQH4frlRheesuCDfX +I/OMn74dseGkddug4lQUsbocKaQY9hK6ohQU4zE1yED/t+AFdlfBHFny+L/k7SViXITwfn4fs775 +tyERzAMBVnCnEJIeGzSBHq2cGsMEPO0CYdYeBvNfOofyK/FFh+U9rNHHV4S9a67c2Pm2G2JwCz02 +yULyMtd6YebS2z3PyKnJm9zbWETXbzivf3jTo60adbocwTZ8jx5tHMN1Rq41Bab2XD0h7lbwyYIi +LXpUq3DDfSJlgnCW +-----END CERTIFICATE----- + +GlobalSign Root CA - R3 +======================= +-----BEGIN CERTIFICATE----- +MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4GA1UECxMXR2xv +YmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2Jh +bFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxT +aWduIFJvb3QgQ0EgLSBSMzETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2ln +bjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWt +iHL8RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsTgHeMCOFJ +0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmmKPZpO/bLyCiR5Z2KYVc3 +rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zdQQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjl +OCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZXriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2 +xmmFghcCAwEAAaNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYE +FI/wS3+oLkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZURUm7 +lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMpjjM5RcOO5LlXbKr8 +EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK6fBdRoyV3XpYKBovHd7NADdBj+1E +bddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQXmcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18 +YIvDQVETI53O9zJrlAGomecsMx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7r +kpeDMdmztcpHWD9f +-----END CERTIFICATE----- + +Autoridad de Certificacion Firmaprofesional CIF A62634068 +========================================================= +-----BEGIN CERTIFICATE----- +MIIGFDCCA/ygAwIBAgIIU+w77vuySF8wDQYJKoZIhvcNAQEFBQAwUTELMAkGA1UEBhMCRVMxQjBA +BgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2 +MjYzNDA2ODAeFw0wOTA1MjAwODM4MTVaFw0zMDEyMzEwODM4MTVaMFExCzAJBgNVBAYTAkVTMUIw +QAYDVQQDDDlBdXRvcmlkYWQgZGUgQ2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBB +NjI2MzQwNjgwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDD +Utd9thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQMcas9UX4P +B99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefGL9ItWY16Ck6WaVICqjaY +7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15iNA9wBj4gGFrO93IbJWyTdBSTo3OxDqqH +ECNZXyAFGUftaI6SEspd/NYrspI8IM/hX68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyI +plD9amML9ZMWGxmPsu2bm8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctX +MbScyJCyZ/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirjaEbsX +LZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/TKI8xWVvTyQKmtFLK +bpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF6NkBiDkal4ZkQdU7hwxu+g/GvUgU +vzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVhOSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMBIGA1Ud +EwEB/wQIMAYBAf8CAQEwDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRlzeurNR4APn7VdMActHNH +DhpkLzCBpgYDVR0gBIGeMIGbMIGYBgRVHSAAMIGPMC8GCCsGAQUFBwIBFiNodHRwOi8vd3d3LmZp +cm1hcHJvZmVzaW9uYWwuY29tL2NwczBcBggrBgEFBQcCAjBQHk4AUABhAHMAZQBvACAAZABlACAA +bABhACAAQgBvAG4AYQBuAG8AdgBhACAANAA3ACAAQgBhAHIAYwBlAGwAbwBuAGEAIAAwADgAMAAx +ADcwDQYJKoZIhvcNAQEFBQADggIBABd9oPm03cXF661LJLWhAqvdpYhKsg9VSytXjDvlMd3+xDLx +51tkljYyGOylMnfX40S2wBEqgLk9am58m9Ot/MPWo+ZkKXzR4Tgegiv/J2Wv+xYVxC5xhOW1//qk +R71kMrv2JYSiJ0L1ILDCExARzRAVukKQKtJE4ZYm6zFIEv0q2skGz3QeqUvVhyj5eTSSPi5E6PaP +T481PyWzOdxjKpBrIF/EUhJOlywqrJ2X3kjyo2bbwtKDlaZmp54lD+kLM5FlClrD2VQS3a/DTg4f +Jl4N3LON7NWBcN7STyQF82xO9UxJZo3R/9ILJUFI/lGExkKvgATP0H5kSeTy36LssUzAKh3ntLFl +osS88Zj0qnAHY7S42jtM+kAiMFsRpvAFDsYCA0irhpuF3dvd6qJ2gHN99ZwExEWN57kci57q13XR +crHedUTnQn3iV2t93Jm8PYMo6oCTjcVMZcFwgbg4/EMxsvYDNEeyrPsiBsse3RdHHF9mudMaotoR +saS8I8nkvof/uZS2+F0gStRf571oe2XyFR7SOqkt6dhrJKyXWERHrVkY8SFlcN7ONGCoQPHzPKTD +KCOM/iczQ0CgFzzr6juwcqajuUpLXhZI9LK8yIySxZ2frHI2vDSANGupi5LAuBft7HZT9SQBjLMi +6Et8Vcad+qMUu2WFbm5PEn4KPJ2V +-----END CERTIFICATE----- + +Izenpe.com +========== +-----BEGIN CERTIFICATE----- +MIIF8TCCA9mgAwIBAgIQALC3WhZIX7/hy/WL1xnmfTANBgkqhkiG9w0BAQsFADA4MQswCQYDVQQG +EwJFUzEUMBIGA1UECgwLSVpFTlBFIFMuQS4xEzARBgNVBAMMCkl6ZW5wZS5jb20wHhcNMDcxMjEz +MTMwODI4WhcNMzcxMjEzMDgyNzI1WjA4MQswCQYDVQQGEwJFUzEUMBIGA1UECgwLSVpFTlBFIFMu +QS4xEzARBgNVBAMMCkl6ZW5wZS5jb20wggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDJ +03rKDx6sp4boFmVqscIbRTJxldn+EFvMr+eleQGPicPK8lVx93e+d5TzcqQsRNiekpsUOqHnJJAK +ClaOxdgmlOHZSOEtPtoKct2jmRXagaKH9HtuJneJWK3W6wyyQXpzbm3benhB6QiIEn6HLmYRY2xU ++zydcsC8Lv/Ct90NduM61/e0aL6i9eOBbsFGb12N4E3GVFWJGjMxCrFXuaOKmMPsOzTFlUFpfnXC +PCDFYbpRR6AgkJOhkEvzTnyFRVSa0QUmQbC1TR0zvsQDyCV8wXDbO/QJLVQnSKwv4cSsPsjLkkxT +OTcj7NMB+eAJRE1NZMDhDVqHIrytG6P+JrUV86f8hBnp7KGItERphIPzidF0BqnMC9bC3ieFUCbK +F7jJeodWLBoBHmy+E60QrLUk9TiRodZL2vG70t5HtfG8gfZZa88ZU+mNFctKy6lvROUbQc/hhqfK +0GqfvEyNBjNaooXlkDWgYlwWTvDjovoDGrQscbNYLN57C9saD+veIR8GdwYDsMnvmfzAuU8Lhij+ +0rnq49qlw0dpEuDb8PYZi+17cNcC1u2HGCgsBCRMd+RIihrGO5rUD8r6ddIBQFqNeb+Lz0vPqhbB +leStTIo+F5HUsWLlguWABKQDfo2/2n+iD5dPDNMN+9fR5XJ+HMh3/1uaD7euBUbl8agW7EekFwID +AQABo4H2MIHzMIGwBgNVHREEgagwgaWBD2luZm9AaXplbnBlLmNvbaSBkTCBjjFHMEUGA1UECgw+ +SVpFTlBFIFMuQS4gLSBDSUYgQTAxMzM3MjYwLVJNZXJjLlZpdG9yaWEtR2FzdGVpeiBUMTA1NSBG +NjIgUzgxQzBBBgNVBAkMOkF2ZGEgZGVsIE1lZGl0ZXJyYW5lbyBFdG9yYmlkZWEgMTQgLSAwMTAx +MCBWaXRvcmlhLUdhc3RlaXowDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0O +BBYEFB0cZQ6o8iV7tJHP5LGx5r1VdGwFMA0GCSqGSIb3DQEBCwUAA4ICAQB4pgwWSp9MiDrAyw6l +Fn2fuUhfGI8NYjb2zRlrrKvV9pF9rnHzP7MOeIWblaQnIUdCSnxIOvVFfLMMjlF4rJUT3sb9fbga +kEyrkgPH7UIBzg/YsfqikuFgba56awmqxinuaElnMIAkejEWOVt+8Rwu3WwJrfIxwYJOubv5vr8q +hT/AQKM6WfxZSzwoJNu0FXWuDYi6LnPAvViH5ULy617uHjAimcs30cQhbIHsvm0m5hzkQiCeR7Cs +g1lwLDXWrzY0tM07+DKo7+N4ifuNRSzanLh+QBxh5z6ikixL8s36mLYp//Pye6kfLqCTVyvehQP5 +aTfLnnhqBbTFMXiJ7HqnheG5ezzevh55hM6fcA5ZwjUukCox2eRFekGkLhObNA5me0mrZJfQRsN5 +nXJQY6aYWwa9SG3YOYNw6DXwBdGqvOPbyALqfP2C2sJbUjWumDqtujWTI6cfSN01RpiyEGjkpTHC +ClguGYEQyVB1/OpaFs4R1+7vUIgtYf8/QnMFlEPVjjxOAToZpR9GTnfQXeWBIiGH/pR9hNiTrdZo +Q0iy2+tzJOeRf1SktoA+naM8THLCV8Sg1Mw4J87VBp6iSNnpn86CcDaTmjvfliHjWbcM2pE38P1Z +WrOZyGlsQyYBNWNgVYkDOnXYukrZVP/u3oDYLdE41V4tC5h9Pmzb/CaIxw== +-----END CERTIFICATE----- + +Chambers of Commerce Root - 2008 +================================ +-----BEGIN CERTIFICATE----- +MIIHTzCCBTegAwIBAgIJAKPaQn6ksa7aMA0GCSqGSIb3DQEBBQUAMIGuMQswCQYDVQQGEwJFVTFD +MEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNv +bS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMu +QS4xKTAnBgNVBAMTIENoYW1iZXJzIG9mIENvbW1lcmNlIFJvb3QgLSAyMDA4MB4XDTA4MDgwMTEy +Mjk1MFoXDTM4MDczMTEyMjk1MFowga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNl +ZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29tL2FkZHJlc3MpMRIwEAYDVQQF +EwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVyZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJl +cnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDgwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC +AQCvAMtwNyuAWko6bHiUfaN/Gh/2NdW928sNRHI+JrKQUrpjOyhYb6WzbZSm891kDFX29ufyIiKA +XuFixrYp4YFs8r/lfTJqVKAyGVn+H4vXPWCGhSRv4xGzdz4gljUha7MI2XAuZPeEklPWDrCQiorj +h40G072QDuKZoRuGDtqaCrsLYVAGUvGef3bsyw/QHg3PmTA9HMRFEFis1tPo1+XqxQEHd9ZR5gN/ +ikilTWh1uem8nk4ZcfUyS5xtYBkL+8ydddy/Js2Pk3g5eXNeJQ7KXOt3EgfLZEFHcpOrUMPrCXZk +NNI5t3YRCQ12RcSprj1qr7V9ZS+UWBDsXHyvfuK2GNnQm05aSd+pZgvMPMZ4fKecHePOjlO+Bd5g +D2vlGts/4+EhySnB8esHnFIbAURRPHsl18TlUlRdJQfKFiC4reRB7noI/plvg6aRArBsNlVq5331 +lubKgdaX8ZSD6e2wsWsSaR6s+12pxZjptFtYer49okQ6Y1nUCyXeG0+95QGezdIp1Z8XGQpvvwyQ +0wlf2eOKNcx5Wk0ZN5K3xMGtr/R5JJqyAQuxr1yW84Ay+1w9mPGgP0revq+ULtlVmhduYJ1jbLhj +ya6BXBg14JC7vjxPNyK5fuvPnnchpj04gftI2jE9K+OJ9dC1vX7gUMQSibMjmhAxhduub+84Mxh2 +EQIDAQABo4IBbDCCAWgwEgYDVR0TAQH/BAgwBgEB/wIBDDAdBgNVHQ4EFgQU+SSsD7K1+HnA+mCI +G8TZTQKeFxkwgeMGA1UdIwSB2zCB2IAU+SSsD7K1+HnA+mCIG8TZTQKeFxmhgbSkgbEwga4xCzAJ +BgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNlZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNh +bWVyZmlybWEuY29tL2FkZHJlc3MpMRIwEAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENh +bWVyZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDiC +CQCj2kJ+pLGu2jAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCowKAYIKwYBBQUH +AgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZIhvcNAQEFBQADggIBAJASryI1 +wqM58C7e6bXpeHxIvj99RZJe6dqxGfwWPJ+0W2aeaufDuV2I6A+tzyMP3iU6XsxPpcG1Lawk0lgH +3qLPaYRgM+gQDROpI9CF5Y57pp49chNyM/WqfcZjHwj0/gF/JM8rLFQJ3uIrbZLGOU8W6jx+ekbU +RWpGqOt1glanq6B8aBMz9p0w8G8nOSQjKpD9kCk18pPfNKXG9/jvjA9iSnyu0/VU+I22mlaHFoI6 +M6taIgj3grrqLuBHmrS1RaMFO9ncLkVAO+rcf+g769HsJtg1pDDFOqxXnrN2pSB7+R5KBWIBpih1 +YJeSDW4+TTdDDZIVnBgizVGZoCkaPF+KMjNbMMeJL0eYD6MDxvbxrN8y8NmBGuScvfaAFPDRLLmF +9dijscilIeUcE5fuDr3fKanvNFNb0+RqE4QGtjICxFKuItLcsiFCGtpA8CnJ7AoMXOLQusxI0zcK +zBIKinmwPQN/aUv0NCB9szTqjktk9T79syNnFQ0EuPAtwQlRPLJsFfClI9eDdOTlLsn+mCdCxqvG +nrDQWzilm1DefhiYtUU79nm06PcaewaD+9CL2rvHvRirCG88gGtAPxkZumWK5r7VXNM21+9AUiRg +OGcEMeyP84LG3rlV8zsxkVrctQgVrXYlCg17LofiDKYGvCYQbTed7N14jHyAxfDZd0jQ +-----END CERTIFICATE----- + +Global Chambersign Root - 2008 +============================== +-----BEGIN CERTIFICATE----- +MIIHSTCCBTGgAwIBAgIJAMnN0+nVfSPOMA0GCSqGSIb3DQEBBQUAMIGsMQswCQYDVQQGEwJFVTFD +MEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNv +bS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMu +QS4xJzAlBgNVBAMTHkdsb2JhbCBDaGFtYmVyc2lnbiBSb290IC0gMjAwODAeFw0wODA4MDExMjMx +NDBaFw0zODA3MzExMjMxNDBaMIGsMQswCQYDVQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUg +Y3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJ +QTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAlBgNVBAMTHkdsb2JhbCBD +aGFtYmVyc2lnbiBSb290IC0gMjAwODCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMDf +VtPkOpt2RbQT2//BthmLN0EYlVJH6xedKYiONWwGMi5HYvNJBL99RDaxccy9Wglz1dmFRP+RVyXf +XjaOcNFccUMd2drvXNL7G706tcuto8xEpw2uIRU/uXpbknXYpBI4iRmKt4DS4jJvVpyR1ogQC7N0 +ZJJ0YPP2zxhPYLIj0Mc7zmFLmY/CDNBAspjcDahOo7kKrmCgrUVSY7pmvWjg+b4aqIG7HkF4ddPB +/gBVsIdU6CeQNR1MM62X/JcumIS/LMmjv9GYERTtY/jKmIhYF5ntRQOXfjyGHoiMvvKRhI9lNNgA +TH23MRdaKXoKGCQwoze1eqkBfSbW+Q6OWfH9GzO1KTsXO0G2Id3UwD2ln58fQ1DJu7xsepeY7s2M +H/ucUa6LcL0nn3HAa6x9kGbo1106DbDVwo3VyJ2dwW3Q0L9R5OP4wzg2rtandeavhENdk5IMagfe +Ox2YItaswTXbo6Al/3K1dh3ebeksZixShNBFks4c5eUzHdwHU1SjqoI7mjcv3N2gZOnm3b2u/GSF +HTynyQbehP9r6GsaPMWis0L7iwk+XwhSx2LE1AVxv8Rk5Pihg+g+EpuoHtQ2TS9x9o0o9oOpE9Jh +wZG7SMA0j0GMS0zbaRL/UJScIINZc+18ofLx/d33SdNDWKBWY8o9PeU1VlnpDsogzCtLkykPAgMB +AAGjggFqMIIBZjASBgNVHRMBAf8ECDAGAQH/AgEMMB0GA1UdDgQWBBS5CcqcHtvTbDprru1U8VuT +BjUuXjCB4QYDVR0jBIHZMIHWgBS5CcqcHtvTbDprru1U8VuTBjUuXqGBsqSBrzCBrDELMAkGA1UE +BhMCRVUxQzBBBgNVBAcTOk1hZHJpZCAoc2VlIGN1cnJlbnQgYWRkcmVzcyBhdCB3d3cuY2FtZXJm +aXJtYS5jb20vYWRkcmVzcykxEjAQBgNVBAUTCUE4Mjc0MzI4NzEbMBkGA1UEChMSQUMgQ2FtZXJm +aXJtYSBTLkEuMScwJQYDVQQDEx5HbG9iYWwgQ2hhbWJlcnNpZ24gUm9vdCAtIDIwMDiCCQDJzdPp +1X0jzjAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCowKAYIKwYBBQUHAgEWHGh0 +dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZIhvcNAQEFBQADggIBAICIf3DekijZBZRG +/5BXqfEv3xoNa/p8DhxJJHkn2EaqbylZUohwEurdPfWbU1Rv4WCiqAm57OtZfMY18dwY6fFn5a+6 +ReAJ3spED8IXDneRRXozX1+WLGiLwUePmJs9wOzL9dWCkoQ10b42OFZyMVtHLaoXpGNR6woBrX/s +dZ7LoR/xfxKxueRkf2fWIyr0uDldmOghp+G9PUIadJpwr2hsUF1Jz//7Dl3mLEfXgTpZALVza2Mg +9jFFCDkO9HB+QHBaP9BrQql0PSgvAm11cpUJjUhjxsYjV5KTXjXBjfkK9yydYhz2rXzdpjEetrHH +foUm+qRqtdpjMNHvkzeyZi99Bffnt0uYlDXA2TopwZ2yUDMdSqlapskD7+3056huirRXhOukP9Du +qqqHW2Pok+JrqNS4cnhrG+055F3Lm6qH1U9OAP7Zap88MQ8oAgF9mOinsKJknnn4SPIVqczmyETr +P3iZ8ntxPjzxmKfFGBI/5rsoM0LpRQp8bfKGeS/Fghl9CYl8slR2iK7ewfPM4W7bMdaTrpmg7yVq +c5iJWzouE4gev8CSlDQb4ye3ix5vQv/n6TebUB0tovkC7stYWDpxvGjjqsGvHCgfotwjZT+B6q6Z +09gwzxMNTxXJhLynSC34MCN32EZLeW32jO06f2ARePTpm67VVMB0gNELQp/B +-----END CERTIFICATE----- + +Go Daddy Root Certificate Authority - G2 +======================================== +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMxEDAOBgNVBAgT +B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoTEUdvRGFkZHkuY29tLCBJbmMu +MTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5 +MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6 +b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8G +A1UEAxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKDE6bFIEMBO4Tx5oVJnyfq +9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD ++qK+ihVqf94Lw7YZFAXK6sOoBJQ7RnwyDfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutd +fMh8+7ArU6SSYmlRJQVhGkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMl +NAJWJwGRtDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFDqahQcQZyi27/a9 +BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmXWWcDYfF+OwYxdS2hII5PZYe096ac +vNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r +5N9ss4UXnT3ZJE95kTXWXwTrgIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYV +N8Gb5DKj7Tjo2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO +LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI4uJEvlz36hz1 +-----END CERTIFICATE----- + +Starfield Root Certificate Authority - G2 +========================================= +-----BEGIN CERTIFICATE----- +MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMxEDAOBgNVBAgT +B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNobm9s +b2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVsZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0 +eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAw +DgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQg +VGVjaG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZpY2F0ZSBB +dXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL3twQP89o/8ArFv +W59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMgnLRJdzIpVv257IzdIvpy3Cdhl+72WoTs +bhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNk +N3mSwOxGXn/hbVNMYq/NHwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7Nf +ZTD4p7dNdloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0HZbU +JtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0GCSqGSIb3DQEBCwUAA4IBAQARWfol +TwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjUsHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx +4mcujJUDJi5DnUox9g61DLu34jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUw +F5okxBDgBPfg8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K +pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1mMpYjn0q7pBZ +c2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0 +-----END CERTIFICATE----- + +Starfield Services Root Certificate Authority - G2 +================================================== +-----BEGIN CERTIFICATE----- +MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMxEDAOBgNVBAgT +B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNobm9s +b2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVsZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRl +IEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNV +BAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxT +dGFyZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2VydmljZXMg +Um9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +AQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20pOsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2 +h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm28xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4Pa +hHQUw2eeBGg6345AWh1KTs9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLP +LJGmpufehRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk6mFB +rMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAwDwYDVR0TAQH/BAUw +AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+qAdcwKziIorhtSpzyEZGDMA0GCSqG +SIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMIbw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPP +E95Dz+I0swSdHynVv/heyNXBve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTy +xQGjhdByPq1zqwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd +iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn0q23KXB56jza +YyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCNsSi6 +-----END CERTIFICATE----- + +AffirmTrust Commercial +====================== +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIId3cGJyapsXwwDQYJKoZIhvcNAQELBQAwRDELMAkGA1UEBhMCVVMxFDAS +BgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBDb21tZXJjaWFsMB4XDTEw +MDEyOTE0MDYwNloXDTMwMTIzMTE0MDYwNlowRDELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmly +bVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBDb21tZXJjaWFsMIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEA9htPZwcroRX1BiLLHwGy43NFBkRJLLtJJRTWzsO3qyxPxkEylFf6Eqdb +DuKPHx6GGaeqtS25Xw2Kwq+FNXkyLbscYjfysVtKPcrNcV/pQr6U6Mje+SJIZMblq8Yrba0F8PrV +C8+a5fBQpIs7R6UjW3p6+DM/uO+Zl+MgwdYoic+U+7lF7eNAFxHUdPALMeIrJmqbTFeurCA+ukV6 +BfO9m2kVrn1OIGPENXY6BwLJN/3HR+7o8XYdcxXyl6S1yHp52UKqK39c/s4mT6NmgTWvRLpUHhww +MmWd5jyTXlBOeuM61G7MGvv50jeuJCqrVwMiKA1JdX+3KNp1v47j3A55MQIDAQABo0IwQDAdBgNV +HQ4EFgQUnZPGU4teyq8/nx4P5ZmVvCT2lI8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQELBQADggEBAFis9AQOzcAN/wr91LoWXym9e2iZWEnStB03TX8nfUYGXUPG +hi4+c7ImfU+TqbbEKpqrIZcUsd6M06uJFdhrJNTxFq7YpFzUf1GO7RgBsZNjvbz4YYCanrHOQnDi +qX0GJX0nof5v7LMeJNrjS1UaADs1tDvZ110w/YETifLCBivtZ8SOyUOyXGsViQK8YvxO8rUzqrJv +0wqiUOP2O+guRMLbZjipM1ZI8W0bM40NjD9gN53Tym1+NH4Nn3J2ixufcv1SNUFFApYvHLKac0kh +sUlHRUe072o0EclNmsxZt9YCnlpOZbWUrhvfKbAW8b8Angc6F2S1BLUjIZkKlTuXfO8= +-----END CERTIFICATE----- + +AffirmTrust Networking +====================== +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIIfE8EORzUmS0wDQYJKoZIhvcNAQEFBQAwRDELMAkGA1UEBhMCVVMxFDAS +BgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBOZXR3b3JraW5nMB4XDTEw +MDEyOTE0MDgyNFoXDTMwMTIzMTE0MDgyNFowRDELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmly +bVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBOZXR3b3JraW5nMIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEAtITMMxcua5Rsa2FSoOujz3mUTOWUgJnLVWREZY9nZOIG41w3SfYvm4SE +Hi3yYJ0wTsyEheIszx6e/jarM3c1RNg1lho9Nuh6DtjVR6FqaYvZ/Ls6rnla1fTWcbuakCNrmreI +dIcMHl+5ni36q1Mr3Lt2PpNMCAiMHqIjHNRqrSK6mQEubWXLviRmVSRLQESxG9fhwoXA3hA/Pe24 +/PHxI1Pcv2WXb9n5QHGNfb2V1M6+oF4nI979ptAmDgAp6zxG8D1gvz9Q0twmQVGeFDdCBKNwV6gb +h+0t+nvujArjqWaJGctB+d1ENmHP4ndGyH329JKBNv3bNPFyfvMMFr20FQIDAQABo0IwQDAdBgNV +HQ4EFgQUBx/S55zawm6iQLSwelAQUHTEyL0wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQEFBQADggEBAIlXshZ6qML91tmbmzTCnLQyFE2npN/svqe++EPbkTfOtDIu +UFUaNU52Q3Eg75N3ThVwLofDwR1t3Mu1J9QsVtFSUzpE0nPIxBsFZVpikpzuQY0x2+c06lkh1QF6 +12S4ZDnNye2v7UsDSKegmQGA3GWjNq5lWUhPgkvIZfFXHeVZLgo/bNjR9eUJtGxUAArgFU2HdW23 +WJZa3W3SAKD0m0i+wzekujbgfIeFlxoVot4uolu9rxj5kFDNcFn4J2dHy8egBzp90SxdbBk6ZrV9 +/ZFvgrG+CJPbFEfxojfHRZ48x3evZKiT3/Zpg4Jg8klCNO1aAFSFHBY2kgxc+qatv9s= +-----END CERTIFICATE----- + +AffirmTrust Premium +=================== +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIIbYwURrGmCu4wDQYJKoZIhvcNAQEMBQAwQTELMAkGA1UEBhMCVVMxFDAS +BgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVzdCBQcmVtaXVtMB4XDTEwMDEy +OTE0MTAzNloXDTQwMTIzMTE0MTAzNlowQTELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRy +dXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVzdCBQcmVtaXVtMIICIjANBgkqhkiG9w0BAQEFAAOCAg8A +MIICCgKCAgEAxBLfqV/+Qd3d9Z+K4/as4Tx4mrzY8H96oDMq3I0gW64tb+eT2TZwamjPjlGjhVtn +BKAQJG9dKILBl1fYSCkTtuG+kU3fhQxTGJoeJKJPj/CihQvL9Cl/0qRY7iZNyaqoe5rZ+jjeRFcV +5fiMyNlI4g0WJx0eyIOFJbe6qlVBzAMiSy2RjYvmia9mx+n/K+k8rNrSs8PhaJyJ+HoAVt70VZVs ++7pk3WKL3wt3MutizCaam7uqYoNMtAZ6MMgpv+0GTZe5HMQxK9VfvFMSF5yZVylmd2EhMQcuJUmd +GPLu8ytxjLW6OQdJd/zvLpKQBY0tL3d770O/Nbua2Plzpyzy0FfuKE4mX4+QaAkvuPjcBukumj5R +p9EixAqnOEhss/n/fauGV+O61oV4d7pD6kh/9ti+I20ev9E2bFhc8e6kGVQa9QPSdubhjL08s9NI +S+LI+H+SqHZGnEJlPqQewQcDWkYtuJfzt9WyVSHvutxMAJf7FJUnM7/oQ0dG0giZFmA7mn7S5u04 +6uwBHjxIVkkJx0w3AJ6IDsBz4W9m6XJHMD4Q5QsDyZpCAGzFlH5hxIrff4IaC1nEWTJ3s7xgaVY5 +/bQGeyzWZDbZvUjthB9+pSKPKrhC9IK31FOQeE4tGv2Bb0TXOwF0lkLgAOIua+rF7nKsu7/+6qqo ++Nz2snmKtmcCAwEAAaNCMEAwHQYDVR0OBBYEFJ3AZ6YMItkm9UWrpmVSESfYRaxjMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBDAUAA4ICAQCzV00QYk465KzquByv +MiPIs0laUZx2KI15qldGF9X1Uva3ROgIRL8YhNILgM3FEv0AVQVhh0HctSSePMTYyPtwni94loMg +Nt58D2kTiKV1NpgIpsbfrM7jWNa3Pt668+s0QNiigfV4Py/VpfzZotReBA4Xrf5B8OWycvpEgjNC +6C1Y91aMYj+6QrCcDFx+LmUmXFNPALJ4fqENmS2NuB2OosSw/WDQMKSOyARiqcTtNd56l+0OOF6S +L5Nwpamcb6d9Ex1+xghIsV5n61EIJenmJWtSKZGc0jlzCFfemQa0W50QBuHCAKi4HEoCChTQwUHK ++4w1IX2COPKpVJEZNZOUbWo6xbLQu4mGk+ibyQ86p3q4ofB4Rvr8Ny/lioTz3/4E2aFooC8k4gmV +BtWVyuEklut89pMFu+1z6S3RdTnX5yTb2E5fQ4+e0BQ5v1VwSJlXMbSc7kqYA5YwH2AG7hsj/oFg +IxpHYoWlzBk0gG+zrBrjn/B7SK3VAdlntqlyk+otZrWyuOQ9PLLvTIzq6we/qzWaVYa8GKa1qF60 +g2xraUDTn9zxw2lrueFtCfTxqlB2Cnp9ehehVZZCmTEJ3WARjQUwfuaORtGdFNrHF+QFlozEJLUb +zxQHskD4o55BhrwE0GuWyCqANP2/7waj3VjFhT0+j/6eKeC2uAloGRwYQw== +-----END CERTIFICATE----- + +AffirmTrust Premium ECC +======================= +-----BEGIN CERTIFICATE----- +MIIB/jCCAYWgAwIBAgIIdJclisc/elQwCgYIKoZIzj0EAwMwRTELMAkGA1UEBhMCVVMxFDASBgNV +BAoMC0FmZmlybVRydXN0MSAwHgYDVQQDDBdBZmZpcm1UcnVzdCBQcmVtaXVtIEVDQzAeFw0xMDAx +MjkxNDIwMjRaFw00MDEyMzExNDIwMjRaMEUxCzAJBgNVBAYTAlVTMRQwEgYDVQQKDAtBZmZpcm1U +cnVzdDEgMB4GA1UEAwwXQWZmaXJtVHJ1c3QgUHJlbWl1bSBFQ0MwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAQNMF4bFZ0D0KF5Nbc6PJJ6yhUczWLznCZcBz3lVPqj1swS6vQUX+iOGasvLkjmrBhDeKzQ +N8O9ss0s5kfiGuZjuD0uL3jET9v0D6RoTFVya5UdThhClXjMNzyR4ptlKymjQjBAMB0GA1UdDgQW +BBSaryl6wBE1NSZRMADDav5A1a7WPDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAK +BggqhkjOPQQDAwNnADBkAjAXCfOHiFBar8jAQr9HX/VsaobgxCd05DhT1wV/GzTjxi+zygk8N53X +57hG8f2h4nECMEJZh0PUUd+60wkyWs6Iflc9nF9Ca/UHLbXwgpP5WW+uZPpY5Yse42O+tYHNbwKM +eQ== +-----END CERTIFICATE----- + +Certum Trusted Network CA +========================= +-----BEGIN CERTIFICATE----- +MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBMMSIwIAYDVQQK +ExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBUcnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIy +MTIwNzM3WhcNMjkxMjMxMTIwNzM3WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBU +ZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +MSIwIAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0BAQEFAAOC +AQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rHUV+rpDKmYYe2bg+G0jAC +l/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LMTXPb865Px1bVWqeWifrzq2jUI4ZZJ88J +J7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVUBBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4 +fOQtf/WsX+sWn7Et0brMkUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0 +cvW0QM8xAcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNVHRMB +Af8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNVHQ8BAf8EBAMCAQYw +DQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15ysHhE49wcrwn9I0j6vSrEuVUEtRCj +jSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfLI9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1 +mS1FhIrlQgnXdAIv94nYmem8J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5aj +Zt3hrvJBW8qYVoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI +03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw= +-----END CERTIFICATE----- + +TWCA Root Certification Authority +================================= +-----BEGIN CERTIFICATE----- +MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJ +VEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlmaWNh +dGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMzWhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQG +EwJUVzESMBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NB +IFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK +AoIBAQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFEAcK0HMMx +QhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HHK3XLfJ+utdGdIzdjp9xC +oi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeXRfwZVzsrb+RH9JlF/h3x+JejiB03HFyP +4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/zrX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1r +y+UPizgN7gr8/g+YnzAx3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIB +BjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkqhkiG +9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeCMErJk/9q56YAf4lC +mtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdlsXebQ79NqZp4VKIV66IIArB6nCWlW +QtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62Dlhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVY +T0bf+215WfKEIlKuD8z7fDvnaspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocny +Yh0igzyXxfkZYiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw== +-----END CERTIFICATE----- + +Security Communication RootCA2 +============================== +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDElMCMGA1UEChMc +U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMeU2VjdXJpdHkgQ29tbXVuaWNh +dGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoXDTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMC +SlAxJTAjBgNVBAoTHFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3Vy +aXR5IENvbW11bmljYXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB +ANAVOVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGrzbl+dp++ ++T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVMVAX3NuRFg3sUZdbcDE3R +3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQhNBqyjoGADdH5H5XTz+L62e4iKrFvlNV +spHEfbmwhRkGeC7bYRr6hfVKkaHnFtWOojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1K +EOtOghY6rCcMU/Gt1SSwawNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8 +QIH4D5csOPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEB +CwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpFcoJxDjrSzG+ntKEj +u/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXcokgfGT+Ok+vx+hfuzU7jBBJV1uXk +3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6q +tnRGEmyR7jTV7JqR50S+kDFy1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29 +mvVXIwAHIRc/SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 +-----END CERTIFICATE----- + +EC-ACC +====== +-----BEGIN CERTIFICATE----- +MIIFVjCCBD6gAwIBAgIQ7is969Qh3hSoYqwE893EATANBgkqhkiG9w0BAQUFADCB8zELMAkGA1UE +BhMCRVMxOzA5BgNVBAoTMkFnZW5jaWEgQ2F0YWxhbmEgZGUgQ2VydGlmaWNhY2lvIChOSUYgUS0w +ODAxMTc2LUkpMSgwJgYDVQQLEx9TZXJ2ZWlzIFB1YmxpY3MgZGUgQ2VydGlmaWNhY2lvMTUwMwYD +VQQLEyxWZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAoYykwMzE1MDMGA1UE +CxMsSmVyYXJxdWlhIEVudGl0YXRzIGRlIENlcnRpZmljYWNpbyBDYXRhbGFuZXMxDzANBgNVBAMT +BkVDLUFDQzAeFw0wMzAxMDcyMzAwMDBaFw0zMTAxMDcyMjU5NTlaMIHzMQswCQYDVQQGEwJFUzE7 +MDkGA1UEChMyQWdlbmNpYSBDYXRhbGFuYSBkZSBDZXJ0aWZpY2FjaW8gKE5JRiBRLTA4MDExNzYt +SSkxKDAmBgNVBAsTH1NlcnZlaXMgUHVibGljcyBkZSBDZXJ0aWZpY2FjaW8xNTAzBgNVBAsTLFZl +Z2V1IGh0dHBzOi8vd3d3LmNhdGNlcnQubmV0L3ZlcmFycmVsIChjKTAzMTUwMwYDVQQLEyxKZXJh +cnF1aWEgRW50aXRhdHMgZGUgQ2VydGlmaWNhY2lvIENhdGFsYW5lczEPMA0GA1UEAxMGRUMtQUND +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsyLHT+KXQpWIR4NA9h0X84NzJB5R85iK +w5K4/0CQBXCHYMkAqbWUZRkiFRfCQ2xmRJoNBD45b6VLeqpjt4pEndljkYRm4CgPukLjbo73FCeT +ae6RDqNfDrHrZqJyTxIThmV6PttPB/SnCWDaOkKZx7J/sxaVHMf5NLWUhdWZXqBIoH7nF2W4onW4 +HvPlQn2v7fOKSGRdghST2MDk/7NQcvJ29rNdQlB50JQ+awwAvthrDk4q7D7SzIKiGGUzE3eeml0a +E9jD2z3Il3rucO2n5nzbcc8tlGLfbdb1OL4/pYUKGbio2Al1QnDE6u/LDsg0qBIimAy4E5S2S+zw +0JDnJwIDAQABo4HjMIHgMB0GA1UdEQQWMBSBEmVjX2FjY0BjYXRjZXJ0Lm5ldDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUoMOLRKo3pUW/l4Ba0fF4opvpXY0wfwYD +VR0gBHgwdjB0BgsrBgEEAfV4AQMBCjBlMCwGCCsGAQUFBwIBFiBodHRwczovL3d3dy5jYXRjZXJ0 +Lm5ldC92ZXJhcnJlbDA1BggrBgEFBQcCAjApGidWZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5l +dC92ZXJhcnJlbCAwDQYJKoZIhvcNAQEFBQADggEBAKBIW4IB9k1IuDlVNZyAelOZ1Vr/sXE7zDkJ +lF7W2u++AVtd0x7Y/X1PzaBB4DSTv8vihpw3kpBWHNzrKQXlxJ7HNd+KDM3FIUPpqojlNcAZQmNa +Al6kSBg6hW/cnbw/nZzBh7h6YQjpdwt/cKt63dmXLGQehb+8dJahw3oS7AwaboMMPOhyRp/7SNVe +l+axofjk70YllJyJ22k4vuxcDlbHZVHlUIiIv0LVKz3l+bqeLrPK9HOSAgu+TGbrIP65y7WZf+a2 +E/rKS03Z7lNGBjvGTq2TWoF+bCpLagVFjPIhpDGQh2xlnJ2lYJU6Un/10asIbvPuW/mIPX64b24D +5EI= +-----END CERTIFICATE----- + +Hellenic Academic and Research Institutions RootCA 2011 +======================================================= +-----BEGIN CERTIFICATE----- +MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1IxRDBCBgNVBAoT +O0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9y +aXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25z +IFJvb3RDQSAyMDExMB4XDTExMTIwNjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYT +AkdSMUQwQgYDVQQKEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25z +IENlcnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2VhcmNo +IEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB +AKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPzdYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI +1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJfel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa +71HFK9+WXesyHgLacEnsbgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u +8yBRQlqD75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSPFEDH +3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNVHRMBAf8EBTADAQH/ +MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp5dgTBCPuQSUwRwYDVR0eBEAwPqA8 +MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQub3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQu +b3JnMA0GCSqGSIb3DQEBBQUAA4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVt +XdMiKahsog2p6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8 +TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7dIsXRSZMFpGD +/md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8AcysNnq/onN694/BtZqhFLKPM58N +7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXIl7WdmplNsDz4SgCbZN2fOUvRJ9e4 +-----END CERTIFICATE----- + +Actalis Authentication Root CA +============================== +-----BEGIN CERTIFICATE----- +MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UEBhMCSVQxDjAM +BgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1ODUyMDk2NzEnMCUGA1UE +AwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDky +MjExMjIwMlowazELMAkGA1UEBhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlz +IFMucC5BLi8wMzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 +IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNvUTufClrJ +wkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX4ay8IMKx4INRimlNAJZa +by/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9KK3giq0itFZljoZUj5NDKd45RnijMCO6 +zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1f +YVEiVRvjRuPjPdA1YprbrxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2 +oxgkg4YQ51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2Fbe8l +EfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxeKF+w6D9Fz8+vm2/7 +hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4Fv6MGn8i1zeQf1xcGDXqVdFUNaBr8 +EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbnfpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5 +jF66CyCU3nuDuP/jVo23Eek7jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLY +iDrIn3hm7YnzezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt +ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQALe3KHwGCmSUyI +WOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70jsNjLiNmsGe+b7bAEzlgqqI0 +JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDzWochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKx +K3JCaKygvU5a2hi/a5iB0P2avl4VSM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+ +Xlff1ANATIGk0k9jpwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC +4yyXX04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+OkfcvHlXHo +2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7RK4X9p2jIugErsWx0Hbhz +lefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btUZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXem +OR/qnuOf0GZvBeyqdn6/axag67XH/JJULysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9 +vwGYT7JZVEc+NHt4bVaTLnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== +-----END CERTIFICATE----- + +Trustis FPS Root CA +=================== +-----BEGIN CERTIFICATE----- +MIIDZzCCAk+gAwIBAgIQGx+ttiD5JNM2a/fH8YygWTANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQG +EwJHQjEYMBYGA1UEChMPVHJ1c3RpcyBMaW1pdGVkMRwwGgYDVQQLExNUcnVzdGlzIEZQUyBSb290 +IENBMB4XDTAzMTIyMzEyMTQwNloXDTI0MDEyMTExMzY1NFowRTELMAkGA1UEBhMCR0IxGDAWBgNV +BAoTD1RydXN0aXMgTGltaXRlZDEcMBoGA1UECxMTVHJ1c3RpcyBGUFMgUm9vdCBDQTCCASIwDQYJ +KoZIhvcNAQEBBQADggEPADCCAQoCggEBAMVQe547NdDfxIzNjpvto8A2mfRC6qc+gIMPpqdZh8mQ +RUN+AOqGeSoDvT03mYlmt+WKVoaTnGhLaASMk5MCPjDSNzoiYYkchU59j9WvezX2fihHiTHcDnlk +H5nSW7r+f2C/revnPDgpai/lkQtV/+xvWNUtyd5MZnGPDNcE2gfmHhjjvSkCqPoc4Vu5g6hBSLwa +cY3nYuUtsuvffM/bq1rKMfFMIvMFE/eC+XN5DL7XSxzA0RU8k0Fk0ea+IxciAIleH2ulrG6nS4zt +o3Lmr2NNL4XSFDWaLk6M6jKYKIahkQlBOrTh4/L68MkKokHdqeMDx4gVOxzUGpTXn2RZEm0CAwEA +AaNTMFEwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBS6+nEleYtXQSUhhgtx67JkDoshZzAd +BgNVHQ4EFgQUuvpxJXmLV0ElIYYLceuyZA6LIWcwDQYJKoZIhvcNAQEFBQADggEBAH5Y//01GX2c +GE+esCu8jowU/yyg2kdbw++BLa8F6nRIW/M+TgfHbcWzk88iNVy2P3UnXwmWzaD+vkAMXBJV+JOC +yinpXj9WV4s4NvdFGkwozZ5BuO1WTISkQMi4sKUraXAEasP41BIy+Q7DsdwyhEQsb8tGD+pmQQ9P +8Vilpg0ND2HepZ5dfWWhPBfnqFVO76DH7cZEf1T1o+CP8HxVIo8ptoGj4W1OLBuAZ+ytIJ8MYmHV +l/9D7S3B2l0pKoU/rGXuhg8FjZBf3+6f9L/uHfuY5H+QK4R4EA5sSVPvFVtlRkpdr7r7OnIdzfYl +iB6XzCGcKQENZetX2fNXlrtIzYE= +-----END CERTIFICATE----- + +Buypass Class 2 Root CA +======================= +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU +QnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3MgQ2xhc3MgMiBSb290IENBMB4X +DTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1owTjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1 +eXBhc3MgQVMtOTgzMTYzMzI3MSAwHgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIw +DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1 +g1Lr6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPVL4O2fuPn +9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC911K2GScuVr1QGbNgGE41b +/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHxMlAQTn/0hpPshNOOvEu/XAFOBz3cFIqU +CqTqc/sLUegTBxj6DvEr0VQVfTzh97QZQmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeff +awrbD02TTqigzXsu8lkBarcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgI +zRFo1clrUs3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLiFRhn +Bkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRSP/TizPJhk9H9Z2vX +Uq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN9SG9dKpN6nIDSdvHXx1iY8f93ZHs +M+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxPAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYD +VR0OBBYEFMmAd+BikoL1RpzzuvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF +AAOCAgEAU18h9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s +A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3tOluwlN5E40EI +osHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo+fsicdl9sz1Gv7SEr5AcD48S +aq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYd +DnkM/crqJIByw5c/8nerQyIKx+u2DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWD +LfJ6v9r9jv6ly0UsH8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0 +oyLQI+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK75t98biGC +wWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h3PFaTWwyI0PurKju7koS +CTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPzY11aWOIv4x3kqdbQCtCev9eBCfHJxyYN +rJgWVqA= +-----END CERTIFICATE----- + +Buypass Class 3 Root CA +======================= +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU +QnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3MgQ2xhc3MgMyBSb290IENBMB4X +DTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFowTjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1 +eXBhc3MgQVMtOTgzMTYzMzI3MSAwHgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIw +DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRH +sJ8YZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3EN3coTRiR +5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9tznDDgFHmV0ST9tD+leh +7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX0DJq1l1sDPGzbjniazEuOQAnFN44wOwZ +ZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH +2xc519woe2v1n/MuwU8XKhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV +/afmiSTYzIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvSO1UQ +RwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D34xFMFbG02SrZvPA +Xpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgPK9Dx2hzLabjKSWJtyNBjYt1gD1iq +j6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYD +VR0OBBYEFEe4zf/lb+74suwvTg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF +AAOCAgEAACAjQTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV +cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXSIGrs/CIBKM+G +uIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2HJLw5QY33KbmkJs4j1xrG0aG +Q0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsaO5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8 +ZORK15FTAaggiG6cX0S5y2CBNOxv033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2 +KSb12tjE8nVhz36udmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz +6MkEkbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg413OEMXbug +UZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvDu79leNKGef9JOxqDDPDe +eOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq4/g7u9xN12TyUb7mqqta6THuBrxzvxNi +Cp/HuZc= +-----END CERTIFICATE----- + +T-TeleSec GlobalRoot Class 3 +============================ +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoM +IlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBU +cnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgx +MDAxMTAyOTU2WhcNMzMxMDAxMjM1OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lz +dGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBD +ZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN8ELg63iIVl6bmlQdTQyK +9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/RLyTPWGrTs0NvvAgJ1gORH8EGoel15YU +NpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZF +iP0Zf3WHHx+xGwpzJFu5ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W +0eDrXltMEnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGjQjBA +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1A/d2O2GCahKqGFPr +AyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOyWL6ukK2YJ5f+AbGwUgC4TeQbIXQb +fsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzT +ucpH9sry9uetuUg/vBa3wW306gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7h +P0HHRwA11fXT91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml +e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4pTpPDpFQUWw== +-----END CERTIFICATE----- + +EE Certification Centre Root CA +=============================== +-----BEGIN CERTIFICATE----- +MIIEAzCCAuugAwIBAgIQVID5oHPtPwBMyonY43HmSjANBgkqhkiG9w0BAQUFADB1MQswCQYDVQQG +EwJFRTEiMCAGA1UECgwZQVMgU2VydGlmaXRzZWVyaW1pc2tlc2t1czEoMCYGA1UEAwwfRUUgQ2Vy +dGlmaWNhdGlvbiBDZW50cmUgUm9vdCBDQTEYMBYGCSqGSIb3DQEJARYJcGtpQHNrLmVlMCIYDzIw +MTAxMDMwMTAxMDMwWhgPMjAzMDEyMTcyMzU5NTlaMHUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKDBlB +UyBTZXJ0aWZpdHNlZXJpbWlza2Vza3VzMSgwJgYDVQQDDB9FRSBDZXJ0aWZpY2F0aW9uIENlbnRy +ZSBSb290IENBMRgwFgYJKoZIhvcNAQkBFglwa2lAc2suZWUwggEiMA0GCSqGSIb3DQEBAQUAA4IB +DwAwggEKAoIBAQDIIMDs4MVLqwd4lfNE7vsLDP90jmG7sWLqI9iroWUyeuuOF0+W2Ap7kaJjbMeM +TC55v6kF/GlclY1i+blw7cNRfdCT5mzrMEvhvH2/UpvObntl8jixwKIy72KyaOBhU8E2lf/slLo2 +rpwcpzIP5Xy0xm90/XsY6KxX7QYgSzIwWFv9zajmofxwvI6Sc9uXp3whrj3B9UiHbCe9nyV0gVWw +93X2PaRka9ZP585ArQ/dMtO8ihJTmMmJ+xAdTX7Nfh9WDSFwhfYggx/2uh8Ej+p3iDXE/+pOoYtN +P2MbRMNE1CV2yreN1x5KZmTNXMWcg+HCCIia7E6j8T4cLNlsHaFLAgMBAAGjgYowgYcwDwYDVR0T +AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBLyWj7qVhy/zQas8fElyalL1BSZ +MEUGA1UdJQQ+MDwGCCsGAQUFBwMCBggrBgEFBQcDAQYIKwYBBQUHAwMGCCsGAQUFBwMEBggrBgEF +BQcDCAYIKwYBBQUHAwkwDQYJKoZIhvcNAQEFBQADggEBAHv25MANqhlHt01Xo/6tu7Fq1Q+e2+Rj +xY6hUFaTlrg4wCQiZrxTFGGVv9DHKpY5P30osxBAIWrEr7BSdxjhlthWXePdNl4dp1BUoMUq5KqM +lIpPnTX/dqQGE5Gion0ARD9V04I8GtVbvFZMIi5GQ4okQC3zErg7cBqklrkar4dBGmoYDQZPxz5u +uSlNDUmJEYcyW+ZLBMjkXOZ0c5RdFpgTlf7727FE5TpwrDdr5rMzcijJs1eg9gIWiAYLtqZLICjU +3j2LrTcFU3T+bsy8QxdxXvnFzBqpYe73dgzzcvRyrc9yAjYHR8/vGVCJYMzpJJUPwssd8m92kMfM +dcGWxZ0= +-----END CERTIFICATE----- + +D-TRUST Root Class 3 CA 2 2009 +============================== +-----BEGIN CERTIFICATE----- +MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQK +DAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTAe +Fw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NThaME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxE +LVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOAD +ER03UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42tSHKXzlA +BF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9RySPocq60vFYJfxLLHLGv +KZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsMlFqVlNpQmvH/pStmMaTJOKDfHR+4CS7z +p+hnUquVH+BGPtikw8paxTGA6Eian5Rp/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUC +AwEAAaOCARowggEWMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ +4PGEMA4GA1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVjdG9y +eS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUyMENBJTIwMiUyMDIw +MDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRlcmV2b2NhdGlvbmxpc3QwQ6BBoD+G +PWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3JsL2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAw +OS5jcmwwDQYJKoZIhvcNAQELBQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm +2H6NMLVwMeniacfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0 +o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4KzCUqNQT4YJEV +dT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8PIWmawomDeCTmGCufsYkl4ph +X5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3YJohw1+qRzT65ysCQblrGXnRl11z+o+I= +-----END CERTIFICATE----- + +D-TRUST Root Class 3 CA 2 EV 2009 +================================= +-----BEGIN CERTIFICATE----- +MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQK +DAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAw +OTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUwNDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQK +DAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAw +OTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfS +egpnljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM03TP1YtHh +zRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6ZqQTMFexgaDbtCHu39b+T +7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lRp75mpoo6Kr3HGrHhFPC+Oh25z1uxav60 +sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure35 +11H3a6UCAwEAAaOCASQwggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyv +cop9NteaHNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFwOi8v +ZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xhc3MlMjAzJTIwQ0El +MjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1ERT9jZXJ0aWZpY2F0ZXJldm9jYXRp +b25saXN0MEagRKBChkBodHRwOi8vd3d3LmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xh +c3NfM19jYV8yX2V2XzIwMDkuY3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+ +PPoeUSbrh/Yp3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05 +nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNFCSuGdXzfX2lX +ANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7naxpeG0ILD5EJt/rDiZE4OJudA +NCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqXKVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVv +w9y4AyHqnxbxLFS1 +-----END CERTIFICATE----- + +CA Disig Root R2 +================ +-----BEGIN CERTIFICATE----- +MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNVBAYTAlNLMRMw +EQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMuMRkwFwYDVQQDExBDQSBEaXNp +ZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQyMDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sx +EzARBgNVBAcTCkJyYXRpc2xhdmExEzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERp +c2lnIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbC +w3OeNcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNHPWSb6Wia +xswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3Ix2ymrdMxp7zo5eFm1tL7 +A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbeQTg06ov80egEFGEtQX6sx3dOy1FU+16S +GBsEWmjGycT6txOgmLcRK7fWV8x8nhfRyyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqV +g8NTEQxzHQuyRpDRQjrOQG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa +5Beny912H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJQfYE +koopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUDi/ZnWejBBhG93c+A +Ak9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORsnLMOPReisjQS1n6yqEm70XooQL6i +Fh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5u +Qu0wDQYJKoZIhvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM +tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqfGopTpti72TVV +sRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkblvdhuDvEK7Z4bLQjb/D907Je +dR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka+elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W8 +1k/BfDxujRNt+3vrMNDcTa/F1balTFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjx +mHHEt38OFdAlab0inSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01 +utI3gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18DrG5gPcFw0 +sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3OszMOl6W8KjptlwlCFtaOg +UxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8xL4ysEr3vQCj8KWefshNPZiTEUxnpHikV +7+ZtsH8tZ/3zbBt1RqPlShfppNcL +-----END CERTIFICATE----- + +ACCVRAIZ1 +========= +-----BEGIN CERTIFICATE----- +MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UEAwwJQUNDVlJB +SVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQswCQYDVQQGEwJFUzAeFw0xMTA1 +MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQBgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwH +UEtJQUNDVjENMAsGA1UECgwEQUNDVjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQCbqau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gM +jmoYHtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWoG2ioPej0 +RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpAlHPrzg5XPAOBOp0KoVdD +aaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhrIA8wKFSVf+DuzgpmndFALW4ir50awQUZ +0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDG +WuzndN9wrqODJerWx5eHk6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs7 +8yM2x/474KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMOm3WR +5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpacXpkatcnYGMN285J +9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPluUsXQA+xtrn13k/c4LOsOxFwYIRK +Q26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYIKwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRw +Oi8vd3d3LmFjY3YuZXMvZmlsZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEu +Y3J0MB8GCCsGAQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2 +VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeTVfZW6oHlNsyM +Hj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIGCCsGAQUFBwICMIIBFB6CARAA +QQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUAcgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBh +AO0AegAgAGQAZQAgAGwAYQAgAEEAQwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUA +YwBuAG8AbABvAGcA7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBj +AHQAcgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAAQwBQAFMA +IABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUAczAwBggrBgEFBQcCARYk +aHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2MuaHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0 +dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRtaW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2 +MV9kZXIuY3JsMA4GA1UdDwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZI +hvcNAQEFBQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdpD70E +R9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gUJyCpZET/LtZ1qmxN +YEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+mAM/EKXMRNt6GGT6d7hmKG9Ww7Y49 +nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepDvV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJ +TS+xJlsndQAJxGJ3KQhfnlmstn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3 +sCPdK6jT2iWH7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h +I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szAh1xA2syVP1Xg +Nce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xFd3+YJ5oyXSrjhO7FmGYvliAd +3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2HpPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3p +EfbRD0tVNEYqi4Y7 +-----END CERTIFICATE----- + +TWCA Global Root CA +=================== +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcxEjAQBgNVBAoT +CVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMTVFdDQSBHbG9iYWwgUm9vdCBD +QTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQK +EwlUQUlXQU4tQ0ExEDAOBgNVBAsTB1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3Qg +Q0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2C +nJfF10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz0ALfUPZV +r2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfChMBwqoJimFb3u/Rk28OKR +Q4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbHzIh1HrtsBv+baz4X7GGqcXzGHaL3SekV +tTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1W +KKD+u4ZqyPpcC1jcxkt2yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99 +sy2sbZCilaLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYPoA/p +yJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQABDzfuBSO6N+pjWxn +kjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcEqYSjMq+u7msXi7Kx/mzhkIyIqJdI +zshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMC +AQYwDwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6g +cFGn90xHNcgL1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn +LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WFH6vPNOw/KP4M +8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNoRI2T9GRwoD2dKAXDOXC4Ynsg +/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlg +lPx4mI88k1HtQJAH32RjJMtOcQWh15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryP +A9gK8kxkRr05YuWW6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3m +i4TWnsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5jwa19hAM8 +EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWzaGHQRiapIVJpLesux+t3 +zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmyKwbQBM0= +-----END CERTIFICATE----- + +TeliaSonera Root CA v1 +====================== +-----BEGIN CERTIFICATE----- +MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAwNzEUMBIGA1UE +CgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJvb3QgQ0EgdjEwHhcNMDcxMDE4 +MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYDVQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwW +VGVsaWFTb25lcmEgUm9vdCBDQSB2MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+ +6yfwIaPzaSZVfp3FVRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA +3GV17CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+XZ75Ljo1k +B1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+/jXh7VB7qTCNGdMJjmhn +Xb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxH +oLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkmdtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3 +F0fUTPHSiXk+TT2YqGHeOh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJ +oWjiUIMusDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4pgd7 +gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fsslESl1MpWtTwEhDc +TwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQarMCpgKIv7NHfirZ1fpoeDVNAgMB +AAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qW +DNXr+nuqF+gTEjANBgkqhkiG9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNm +zqjMDfz1mgbldxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx +0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1TjTQpgcmLNkQfW +pb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBedY2gea+zDTYa4EzAvXUYNR0PV +G6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpc +c41teyWRyu5FrgZLAMzTsVlQ2jqIOylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOT +JsjrDNYmiLbAJM+7vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2 +qReWt88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcnHL/EVlP6 +Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVxSK236thZiNSQvxaz2ems +WWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY= +-----END CERTIFICATE----- + +E-Tugra Certification Authority +=============================== +-----BEGIN CERTIFICATE----- +MIIGSzCCBDOgAwIBAgIIamg+nFGby1MwDQYJKoZIhvcNAQELBQAwgbIxCzAJBgNVBAYTAlRSMQ8w +DQYDVQQHDAZBbmthcmExQDA+BgNVBAoMN0UtVHXEn3JhIEVCRyBCaWxpxZ9pbSBUZWtub2xvamls +ZXJpIHZlIEhpem1ldGxlcmkgQS7Fni4xJjAkBgNVBAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBN +ZXJrZXppMSgwJgYDVQQDDB9FLVR1Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTEzMDMw +NTEyMDk0OFoXDTIzMDMwMzEyMDk0OFowgbIxCzAJBgNVBAYTAlRSMQ8wDQYDVQQHDAZBbmthcmEx +QDA+BgNVBAoMN0UtVHXEn3JhIEVCRyBCaWxpxZ9pbSBUZWtub2xvamlsZXJpIHZlIEhpem1ldGxl +cmkgQS7Fni4xJjAkBgNVBAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBNZXJrZXppMSgwJgYDVQQD +DB9FLVR1Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0BAQEFAAOCAg8A +MIICCgKCAgEA4vU/kwVRHoViVF56C/UYB4Oufq9899SKa6VjQzm5S/fDxmSJPZQuVIBSOTkHS0vd +hQd2h8y/L5VMzH2nPbxHD5hw+IyFHnSOkm0bQNGZDbt1bsipa5rAhDGvykPL6ys06I+XawGb1Q5K +CKpbknSFQ9OArqGIW66z6l7LFpp3RMih9lRozt6Plyu6W0ACDGQXwLWTzeHxE2bODHnv0ZEoq1+g +ElIwcxmOj+GMB6LDu0rw6h8VqO4lzKRG+Bsi77MOQ7osJLjFLFzUHPhdZL3Dk14opz8n8Y4e0ypQ +BaNV2cvnOVPAmJ6MVGKLJrD3fY185MaeZkJVgkfnsliNZvcHfC425lAcP9tDJMW/hkd5s3kc91r0 +E+xs+D/iWR+V7kI+ua2oMoVJl0b+SzGPWsutdEcf6ZG33ygEIqDUD13ieU/qbIWGvaimzuT6w+Gz +rt48Ue7LE3wBf4QOXVGUnhMMti6lTPk5cDZvlsouDERVxcr6XQKj39ZkjFqzAQqptQpHF//vkUAq +jqFGOjGY5RH8zLtJVor8udBhmm9lbObDyz51Sf6Pp+KJxWfXnUYTTjF2OySznhFlhqt/7x3U+Lzn +rFpct1pHXFXOVbQicVtbC/DP3KBhZOqp12gKY6fgDT+gr9Oq0n7vUaDmUStVkhUXU8u3Zg5mTPj5 +dUyQ5xJwx0UCAwEAAaNjMGEwHQYDVR0OBBYEFC7j27JJ0JxUeVz6Jyr+zE7S6E5UMA8GA1UdEwEB +/wQFMAMBAf8wHwYDVR0jBBgwFoAULuPbsknQnFR5XPonKv7MTtLoTlQwDgYDVR0PAQH/BAQDAgEG +MA0GCSqGSIb3DQEBCwUAA4ICAQAFNzr0TbdF4kV1JI+2d1LoHNgQk2Xz8lkGpD4eKexd0dCrfOAK +kEh47U6YA5n+KGCRHTAduGN8qOY1tfrTYXbm1gdLymmasoR6d5NFFxWfJNCYExL/u6Au/U5Mh/jO +XKqYGwXgAEZKgoClM4so3O0409/lPun++1ndYYRP0lSWE2ETPo+Aab6TR7U1Q9Jauz1c77NCR807 +VRMGsAnb/WP2OogKmW9+4c4bU2pEZiNRCHu8W1Ki/QY3OEBhj0qWuJA3+GbHeJAAFS6LrVE1Uweo +a2iu+U48BybNCAVwzDk/dr2l02cmAYamU9JgO3xDf1WKvJUawSg5TB9D0pH0clmKuVb8P7Sd2nCc +dlqMQ1DujjByTd//SffGqWfZbawCEeI6FiWnWAjLb1NBnEg4R2gz0dfHj9R0IdTDBZB6/86WiLEV +KV0jq9BgoRJP3vQXzTLlyb/IQ639Lo7xr+L0mPoSHyDYwKcMhcWQ9DstliaxLL5Mq+ux0orJ23gT +Dx4JnW2PAJ8C2sH6H3p6CcRK5ogql5+Ji/03X186zjhZhkuvcQu02PJwT58yE+Owp1fl2tpDy4Q0 +8ijE6m30Ku/Ba3ba+367hTzSU8JNvnHhRdH9I2cNE3X7z2VnIp2usAnRCf8dNL/+I5c30jn6PQ0G +C7TbO6Orb1wdtn7os4I07QZcJA== +-----END CERTIFICATE----- + +T-TeleSec GlobalRoot Class 2 +============================ +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoM +IlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBU +cnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwHhcNMDgx +MDAxMTA0MDE0WhcNMzMxMDAxMjM1OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lz +dGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBD +ZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQCqX9obX+hzkeXaXPSi5kfl82hVYAUdAqSzm1nzHoqvNK38DcLZ +SBnuaY/JIPwhqgcZ7bBcrGXHX+0CfHt8LRvWurmAwhiCFoT6ZrAIxlQjgeTNuUk/9k9uN0goOA/F +vudocP05l03Sx5iRUKrERLMjfTlH6VJi1hKTXrcxlkIF+3anHqP1wvzpesVsqXFP6st4vGCvx970 +2cu+fjOlbpSD8DT6IavqjnKgP6TeMFvvhk1qlVtDRKgQFRzlAVfFmPHmBiiRqiDFt1MmUUOyCxGV +WOHAD3bZwI18gfNycJ5v/hqO2V81xrJvNHy+SE/iWjnX2J14np+GPgNeGYtEotXHAgMBAAGjQjBA +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS/WSA2AHmgoCJrjNXy +YdK4LMuCSjANBgkqhkiG9w0BAQsFAAOCAQEAMQOiYQsfdOhyNsZt+U2e+iKo4YFWz827n+qrkRk4 +r6p8FU3ztqONpfSO9kSpp+ghla0+AGIWiPACuvxhI+YzmzB6azZie60EI4RYZeLbK4rnJVM3YlNf +vNoBYimipidx5joifsFvHZVwIEoHNN/q/xWA5brXethbdXwFeilHfkCoMRN3zUA7tFFHei4R40cR +3p1m0IvVVGb6g1XqfMIpiRvpb7PO4gWEyS8+eIVibslfwXhjdFjASBgMmTnrpMwatXlajRWc2BQN +9noHV8cigwUtPJslJj0Ys6lDfMjIq2SPDqO/nBudMNva0Bkuqjzx+zOAduTNrRlPBSeOE6Fuwg== +-----END CERTIFICATE----- + +Atos TrustedRoot 2011 +===================== +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIIXDPLYixfszIwDQYJKoZIhvcNAQELBQAwPDEeMBwGA1UEAwwVQXRvcyBU +cnVzdGVkUm9vdCAyMDExMQ0wCwYDVQQKDARBdG9zMQswCQYDVQQGEwJERTAeFw0xMTA3MDcxNDU4 +MzBaFw0zMDEyMzEyMzU5NTlaMDwxHjAcBgNVBAMMFUF0b3MgVHJ1c3RlZFJvb3QgMjAxMTENMAsG +A1UECgwEQXRvczELMAkGA1UEBhMCREUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCV +hTuXbyo7LjvPpvMpNb7PGKw+qtn4TaA+Gke5vJrf8v7MPkfoepbCJI419KkM/IL9bcFyYie96mvr +54rMVD6QUM+A1JX76LWC1BTFtqlVJVfbsVD2sGBkWXppzwO3bw2+yj5vdHLqqjAqc2K+SZFhyBH+ +DgMq92og3AIVDV4VavzjgsG1xZ1kCWyjWZgHJ8cblithdHFsQ/H3NYkQ4J7sVaE3IqKHBAUsR320 +HLliKWYoyrfhk/WklAOZuXCFteZI6o1Q/NnezG8HDt0Lcp2AMBYHlT8oDv3FdU9T1nSatCQujgKR +z3bFmx5VdJx4IbHwLfELn8LVlhgf8FQieowHAgMBAAGjfTB7MB0GA1UdDgQWBBSnpQaxLKYJYO7R +l+lwrrw7GWzbITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKelBrEspglg7tGX6XCuvDsZ +bNshMBgGA1UdIAQRMA8wDQYLKwYBBAGwLQMEAQEwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEB +CwUAA4IBAQAmdzTblEiGKkGdLD4GkGDEjKwLVLgfuXvTBznk+j57sj1O7Z8jvZfza1zv7v1Apt+h +k6EKhqzvINB5Ab149xnYJDE0BAGmuhWawyfc2E8PzBhj/5kPDpFrdRbhIfzYJsdHt6bPWHJxfrrh +TZVHO8mvbaG0weyJ9rQPOLXiZNwlz6bb65pcmaHFCN795trV1lpFDMS3wrUU77QR/w4VtfX128a9 +61qn8FYiqTxlVMYVqL2Gns2Dlmh6cYGJ4Qvh6hEbaAjMaZ7snkGeRDImeuKHCnE96+RapNLbxc3G +3mB/ufNPRJLvKrcYPqcZ2Qt9sTdBQrC6YB3y/gkRsPCHe6ed +-----END CERTIFICATE----- + +QuoVadis Root CA 1 G3 +===================== +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIUeFhfLq0sGUvjNwc1NBMotZbUZZMwDQYJKoZIhvcNAQELBQAwSDELMAkG +A1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAcBgNVBAMTFVF1b1ZhZGlzIFJv +b3QgQ0EgMSBHMzAeFw0xMjAxMTIxNzI3NDRaFw00MjAxMTIxNzI3NDRaMEgxCzAJBgNVBAYTAkJN +MRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDEg +RzMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCgvlAQjunybEC0BJyFuTHK3C3kEakE +PBtVwedYMB0ktMPvhd6MLOHBPd+C5k+tR4ds7FtJwUrVu4/sh6x/gpqG7D0DmVIB0jWerNrwU8lm +PNSsAgHaJNM7qAJGr6Qc4/hzWHa39g6QDbXwz8z6+cZM5cOGMAqNF34168Xfuw6cwI2H44g4hWf6 +Pser4BOcBRiYz5P1sZK0/CPTz9XEJ0ngnjybCKOLXSoh4Pw5qlPafX7PGglTvF0FBM+hSo+LdoIN +ofjSxxR3W5A2B4GbPgb6Ul5jxaYA/qXpUhtStZI5cgMJYr2wYBZupt0lwgNm3fME0UDiTouG9G/l +g6AnhF4EwfWQvTA9xO+oabw4m6SkltFi2mnAAZauy8RRNOoMqv8hjlmPSlzkYZqn0ukqeI1RPToV +7qJZjqlc3sX5kCLliEVx3ZGZbHqfPT2YfF72vhZooF6uCyP8Wg+qInYtyaEQHeTTRCOQiJ/GKubX +9ZqzWB4vMIkIG1SitZgj7Ah3HJVdYdHLiZxfokqRmu8hqkkWCKi9YSgxyXSthfbZxbGL0eUQMk1f +iyA6PEkfM4VZDdvLCXVDaXP7a3F98N/ETH3Goy7IlXnLc6KOTk0k+17kBL5yG6YnLUlamXrXXAkg +t3+UuU/xDRxeiEIbEbfnkduebPRq34wGmAOtzCjvpUfzUwIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUo5fW816iEOGrRZ88F2Q87gFwnMwwDQYJKoZI +hvcNAQELBQADggIBABj6W3X8PnrHX3fHyt/PX8MSxEBd1DKquGrX1RUVRpgjpeaQWxiZTOOtQqOC +MTaIzen7xASWSIsBx40Bz1szBpZGZnQdT+3Btrm0DWHMY37XLneMlhwqI2hrhVd2cDMT/uFPpiN3 +GPoajOi9ZcnPP/TJF9zrx7zABC4tRi9pZsMbj/7sPtPKlL92CiUNqXsCHKnQO18LwIE6PWThv6ct +Tr1NxNgpxiIY0MWscgKCP6o6ojoilzHdCGPDdRS5YCgtW2jgFqlmgiNR9etT2DGbe+m3nUvriBbP ++V04ikkwj+3x6xn0dxoxGE1nVGwvb2X52z3sIexe9PSLymBlVNFxZPT5pqOBMzYzcfCkeF9OrYMh +3jRJjehZrJ3ydlo28hP0r+AJx2EqbPfgna67hkooby7utHnNkDPDs3b69fBsnQGQ+p6Q9pxyz0fa +wx/kNSBT8lTR32GDpgLiJTjehTItXnOQUl1CxM49S+H5GYQd1aJQzEH7QRTDvdbJWqNjZgKAvQU6 +O0ec7AAmTPWIUb+oI38YB7AL7YsmoWTTYUrrXJ/es69nA7Mf3W1daWhpq1467HxpvMc7hU6eFbm0 +FU/DlXpY18ls6Wy58yljXrQs8C097Vpl4KlbQMJImYFtnh8GKjwStIsPm6Ik8KaN1nrgS7ZklmOV +hMJKzRwuJIczYOXD +-----END CERTIFICATE----- + +QuoVadis Root CA 2 G3 +===================== +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIURFc0JFuBiZs18s64KztbpybwdSgwDQYJKoZIhvcNAQELBQAwSDELMAkG +A1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAcBgNVBAMTFVF1b1ZhZGlzIFJv +b3QgQ0EgMiBHMzAeFw0xMjAxMTIxODU5MzJaFw00MjAxMTIxODU5MzJaMEgxCzAJBgNVBAYTAkJN +MRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDIg +RzMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQChriWyARjcV4g/Ruv5r+LrI3HimtFh +ZiFfqq8nUeVuGxbULX1QsFN3vXg6YOJkApt8hpvWGo6t/x8Vf9WVHhLL5hSEBMHfNrMWn4rjyduY +NM7YMxcoRvynyfDStNVNCXJJ+fKH46nafaF9a7I6JaltUkSs+L5u+9ymc5GQYaYDFCDy54ejiK2t +oIz/pgslUiXnFgHVy7g1gQyjO/Dh4fxaXc6AcW34Sas+O7q414AB+6XrW7PFXmAqMaCvN+ggOp+o +MiwMzAkd056OXbxMmO7FGmh77FOm6RQ1o9/NgJ8MSPsc9PG/Srj61YxxSscfrf5BmrODXfKEVu+l +V0POKa2Mq1W/xPtbAd0jIaFYAI7D0GoT7RPjEiuA3GfmlbLNHiJuKvhB1PLKFAeNilUSxmn1uIZo +L1NesNKqIcGY5jDjZ1XHm26sGahVpkUG0CM62+tlXSoREfA7T8pt9DTEceT/AFr2XK4jYIVz8eQQ +sSWu1ZK7E8EM4DnatDlXtas1qnIhO4M15zHfeiFuuDIIfR0ykRVKYnLP43ehvNURG3YBZwjgQQvD +6xVu+KQZ2aKrr+InUlYrAoosFCT5v0ICvybIxo/gbjh9Uy3l7ZizlWNof/k19N+IxWA1ksB8aRxh +lRbQ694Lrz4EEEVlWFA4r0jyWbYW8jwNkALGcC4BrTwV1wIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQU7edvdlq/YOxJW8ald7tyFnGbxD0wDQYJKoZI +hvcNAQELBQADggIBAJHfgD9DCX5xwvfrs4iP4VGyvD11+ShdyLyZm3tdquXK4Qr36LLTn91nMX66 +AarHakE7kNQIXLJgapDwyM4DYvmL7ftuKtwGTTwpD4kWilhMSA/ohGHqPHKmd+RCroijQ1h5fq7K +pVMNqT1wvSAZYaRsOPxDMuHBR//47PERIjKWnML2W2mWeyAMQ0GaW/ZZGYjeVYg3UQt4XAoeo0L9 +x52ID8DyeAIkVJOviYeIyUqAHerQbj5hLja7NQ4nlv1mNDthcnPxFlxHBlRJAHpYErAK74X9sbgz +dWqTHBLmYF5vHX/JHyPLhGGfHoJE+V+tYlUkmlKY7VHnoX6XOuYvHxHaU4AshZ6rNRDbIl9qxV6X +U/IyAgkwo1jwDQHVcsaxfGl7w/U2Rcxhbl5MlMVerugOXou/983g7aEOGzPuVBj+D77vfoRrQ+Nw +mNtddbINWQeFFSM51vHfqSYP1kjHs6Yi9TM3WpVHn3u6GBVv/9YUZINJ0gpnIdsPNWNgKCLjsZWD +zYWm3S8P52dSbrsvhXz1SnPnxT7AvSESBT/8twNJAlvIJebiVDj1eYeMHVOyToV7BjjHLPj4sHKN +JeV3UvQDHEimUF+IIDBu8oJDqz2XhOdT+yHBTw8imoa4WSr2Rz0ZiC3oheGe7IUIarFsNMkd7Egr +O3jtZsSOeWmD3n+M +-----END CERTIFICATE----- + +QuoVadis Root CA 3 G3 +===================== +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIULvWbAiin23r/1aOp7r0DoM8Sah0wDQYJKoZIhvcNAQELBQAwSDELMAkG +A1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxHjAcBgNVBAMTFVF1b1ZhZGlzIFJv +b3QgQ0EgMyBHMzAeFw0xMjAxMTIyMDI2MzJaFw00MjAxMTIyMDI2MzJaMEgxCzAJBgNVBAYTAkJN +MRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMR4wHAYDVQQDExVRdW9WYWRpcyBSb290IENBIDMg +RzMwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCzyw4QZ47qFJenMioKVjZ/aEzHs286 +IxSR/xl/pcqs7rN2nXrpixurazHb+gtTTK/FpRp5PIpM/6zfJd5O2YIyC0TeytuMrKNuFoM7pmRL +Mon7FhY4futD4tN0SsJiCnMK3UmzV9KwCoWdcTzeo8vAMvMBOSBDGzXRU7Ox7sWTaYI+FrUoRqHe +6okJ7UO4BUaKhvVZR74bbwEhELn9qdIoyhA5CcoTNs+cra1AdHkrAj80//ogaX3T7mH1urPnMNA3 +I4ZyYUUpSFlob3emLoG+B01vr87ERRORFHAGjx+f+IdpsQ7vw4kZ6+ocYfx6bIrc1gMLnia6Et3U +VDmrJqMz6nWB2i3ND0/kA9HvFZcba5DFApCTZgIhsUfei5pKgLlVj7WiL8DWM2fafsSntARE60f7 +5li59wzweyuxwHApw0BiLTtIadwjPEjrewl5qW3aqDCYz4ByA4imW0aucnl8CAMhZa634RylsSqi +Md5mBPfAdOhx3v89WcyWJhKLhZVXGqtrdQtEPREoPHtht+KPZ0/l7DxMYIBpVzgeAVuNVejH38DM +dyM0SXV89pgR6y3e7UEuFAUCf+D+IOs15xGsIs5XPd7JMG0QA4XN8f+MFrXBsj6IbGB/kE+V9/Yt +rQE5BwT6dYB9v0lQ7e/JxHwc64B+27bQ3RP+ydOc17KXqQIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUxhfQvKjqAkPyGwaZXSuQILnXnOQwDQYJKoZI +hvcNAQELBQADggIBADRh2Va1EodVTd2jNTFGu6QHcrxfYWLopfsLN7E8trP6KZ1/AvWkyaiTt3px +KGmPc+FSkNrVvjrlt3ZqVoAh313m6Tqe5T72omnHKgqwGEfcIHB9UqM+WXzBusnIFUBhynLWcKzS +t/Ac5IYp8M7vaGPQtSCKFWGafoaYtMnCdvvMujAWzKNhxnQT5WvvoxXqA/4Ti2Tk08HS6IT7SdEQ +TXlm66r99I0xHnAUrdzeZxNMgRVhvLfZkXdxGYFgu/BYpbWcC/ePIlUnwEsBbTuZDdQdm2NnL9Du +DcpmvJRPpq3t/O5jrFc/ZSXPsoaP0Aj/uHYUbt7lJ+yreLVTubY/6CD50qi+YUbKh4yE8/nxoGib +Ih6BJpsQBJFxwAYf3KDTuVan45gtf4Od34wrnDKOMpTwATwiKp9Dwi7DmDkHOHv8XgBCH/MyJnmD +hPbl8MFREsALHgQjDFSlTC9JxUrRtm5gDWv8a4uFJGS3iQ6rJUdbPM9+Sb3H6QrG2vd+DhcI00iX +0HGS8A85PjRqHH3Y8iKuu2n0M7SmSFXRDw4m6Oy2Cy2nhTXN/VnIn9HNPlopNLk9hM6xZdRZkZFW +dSHBd575euFgndOtBBj0fOtek49TSiIp+EgrPk2GrFt/ywaZWWDYWGWVjUTR939+J399roD1B0y2 +PpxxVJkES/1Y+Zj0 +-----END CERTIFICATE----- + +DigiCert Assured ID Root G2 +=========================== +-----BEGIN CERTIFICATE----- +MIIDljCCAn6gAwIBAgIQC5McOtY5Z+pnI7/Dr5r0SzANBgkqhkiG9w0BAQsFADBlMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSQw +IgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzIwHhcNMTMwODAxMTIwMDAwWhcNMzgw +MTE1MTIwMDAwWjBlMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQL +ExB3d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzIw +ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDZ5ygvUj82ckmIkzTz+GoeMVSAn61UQbVH +35ao1K+ALbkKz3X9iaV9JPrjIgwrvJUXCzO/GU1BBpAAvQxNEP4HteccbiJVMWWXvdMX0h5i89vq +bFCMP4QMls+3ywPgym2hFEwbid3tALBSfK+RbLE4E9HpEgjAALAcKxHad3A2m67OeYfcgnDmCXRw +VWmvo2ifv922ebPynXApVfSr/5Vh88lAbx3RvpO704gqu52/clpWcTs/1PPRCv4o76Pu2ZmvA9OP +YLfykqGxvYmJHzDNw6YuYjOuFgJ3RFrngQo8p0Quebg/BLxcoIfhG69Rjs3sLPr4/m3wOnyqi+Rn +lTGNAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBTO +w0q5mVXyuNtgv6l+vVa1lzan1jANBgkqhkiG9w0BAQsFAAOCAQEAyqVVjOPIQW5pJ6d1Ee88hjZv +0p3GeDgdaZaikmkuOGybfQTUiaWxMTeKySHMq2zNixya1r9I0jJmwYrA8y8678Dj1JGG0VDjA9tz +d29KOVPt3ibHtX2vK0LRdWLjSisCx1BL4GnilmwORGYQRI+tBev4eaymG+g3NJ1TyWGqolKvSnAW +hsI6yLETcDbYz+70CjTVW0z9B5yiutkBclzzTcHdDrEcDcRjvq30FPuJ7KJBDkzMyFdA0G4Dqs0M +jomZmWzwPDCvON9vvKO+KSAnq3T/EyJ43pdSVR6DtVQgA+6uwE9W3jfMw3+qBCe703e4YtsXfJwo +IhNzbM8m9Yop5w== +-----END CERTIFICATE----- + +DigiCert Assured ID Root G3 +=========================== +-----BEGIN CERTIFICATE----- +MIICRjCCAc2gAwIBAgIQC6Fa+h3foLVJRK/NJKBs7DAKBggqhkjOPQQDAzBlMQswCQYDVQQGEwJV +UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSQwIgYD +VQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzMwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1 +MTIwMDAwWjBlMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgRzMwdjAQ +BgcqhkjOPQIBBgUrgQQAIgNiAAQZ57ysRGXtzbg/WPuNsVepRC0FFfLvC/8QdJ+1YlJfZn4f5dwb +RXkLzMZTCp2NXQLZqVneAlr2lSoOjThKiknGvMYDOAdfVdp+CW7if17QRSAPWXYQ1qAk8C3eNvJs +KTmjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBTL0L2p4ZgF +UaFNN6KDec6NHSrkhDAKBggqhkjOPQQDAwNnADBkAjAlpIFFAmsSS3V0T8gj43DydXLefInwz5Fy +YZ5eEJJZVrmDxxDnOOlYJjZ91eQ0hjkCMHw2U/Aw5WJjOpnitqM7mzT6HtoQknFekROn3aRukswy +1vUhZscv6pZjamVFkpUBtA== +-----END CERTIFICATE----- + +DigiCert Global Root G2 +======================= +-----BEGIN CERTIFICATE----- +MIIDjjCCAnagAwIBAgIQAzrx5qcRqaC7KGSxHQn65TANBgkqhkiG9w0BAQsFADBhMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSAw +HgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBHMjAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUx +MjAwMDBaMGExCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3 +dy5kaWdpY2VydC5jb20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEcyMIIBIjANBgkq +hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAuzfNNNx7a8myaJCtSnX/RrohCgiN9RlUyfuI2/Ou8jqJ +kTx65qsGGmvPrC3oXgkkRLpimn7Wo6h+4FR1IAWsULecYxpsMNzaHxmx1x7e/dfgy5SDN67sH0NO +3Xss0r0upS/kqbitOtSZpLYl6ZtrAGCSYP9PIUkY92eQq2EGnI/yuum06ZIya7XzV+hdG82MHauV +BJVJ8zUtluNJbd134/tJS7SsVQepj5WztCO7TG1F8PapspUwtP1MVYwnSlcUfIKdzXOS0xZKBgyM +UNGPHgm+F6HmIcr9g+UQvIOlCsRnKPZzFBQ9RnbDhxSJITRNrw9FDKZJobq7nMWxM4MphQIDAQAB +o0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUTiJUIBiV5uNu +5g/6+rkS7QYXjzkwDQYJKoZIhvcNAQELBQADggEBAGBnKJRvDkhj6zHd6mcY1Yl9PMWLSn/pvtsr +F9+wX3N3KjITOYFnQoQj8kVnNeyIv/iPsGEMNKSuIEyExtv4NeF22d+mQrvHRAiGfzZ0JFrabA0U +WTW98kndth/Jsw1HKj2ZL7tcu7XUIOGZX1NGFdtom/DzMNU+MeKNhJ7jitralj41E6Vf8PlwUHBH +QRFXGU7Aj64GxJUTFy8bJZ918rGOmaFvE7FBcf6IKshPECBV1/MUReXgRPTqh5Uykw7+U0b6LJ3/ +iyK5S9kJRaTepLiaWN0bfVKfjllDiIGknibVb63dDcY3fe0Dkhvld1927jyNxF1WW6LZZm6zNTfl +MrY= +-----END CERTIFICATE----- + +DigiCert Global Root G3 +======================= +-----BEGIN CERTIFICATE----- +MIICPzCCAcWgAwIBAgIQBVVWvPJepDU1w6QP1atFcjAKBggqhkjOPQQDAzBhMQswCQYDVQQGEwJV +UzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSAwHgYD +VQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBHMzAeFw0xMzA4MDExMjAwMDBaFw0zODAxMTUxMjAw +MDBaMGExCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5k +aWdpY2VydC5jb20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IEczMHYwEAYHKoZIzj0C +AQYFK4EEACIDYgAE3afZu4q4C/sLfyHS8L6+c/MzXRq8NOrexpu80JX28MzQC7phW1FGfp4tn+6O +YwwX7Adw9c+ELkCDnOg/QW07rdOkFFk2eJ0DQ+4QE2xy3q6Ip6FrtUPOZ9wj/wMco+I+o0IwQDAP +BgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUs9tIpPmhxdiuNkHMEWNp +Yim8S8YwCgYIKoZIzj0EAwMDaAAwZQIxAK288mw/EkrRLTnDCgmXc/SINoyIJ7vmiI1Qhadj+Z4y +3maTD/HMsQmP3Wyr+mt/oAIwOWZbwmSNuJ5Q3KjVSaLtx9zRSX8XAbjIho9OjIgrqJqpisXRAL34 +VOKa5Vt8sycX +-----END CERTIFICATE----- + +DigiCert Trusted Root G4 +======================== +-----BEGIN CERTIFICATE----- +MIIFkDCCA3igAwIBAgIQBZsbV56OITLiOQe9p3d1XDANBgkqhkiG9w0BAQwFADBiMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSEw +HwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwHhcNMTMwODAxMTIwMDAwWhcNMzgwMTE1 +MTIwMDAwWjBiMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3 +d3cuZGlnaWNlcnQuY29tMSEwHwYDVQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwggIiMA0G +CSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC/5pBzaN675F1KPDAiMGkz7MKnJS7JIT3yithZwuEp +pz1Yq3aaza57G4QNxDAf8xukOBbrVsaXbR2rsnnyyhHS5F/WBTxSD1Ifxp4VpX6+n6lXFllVcq9o +k3DCsrp1mWpzMpTREEQQLt+C8weE5nQ7bXHiLQwb7iDVySAdYyktzuxeTsiT+CFhmzTrBcZe7Fsa +vOvJz82sNEBfsXpm7nfISKhmV1efVFiODCu3T6cw2Vbuyntd463JT17lNecxy9qTXtyOj4DatpGY +QJB5w3jHtrHEtWoYOAMQjdjUN6QuBX2I9YI+EJFwq1WCQTLX2wRzKm6RAXwhTNS8rhsDdV14Ztk6 +MUSaM0C/CNdaSaTC5qmgZ92kJ7yhTzm1EVgX9yRcRo9k98FpiHaYdj1ZXUJ2h4mXaXpI8OCiEhtm +mnTK3kse5w5jrubU75KSOp493ADkRSWJtppEGSt+wJS00mFt6zPZxd9LBADMfRyVw4/3IbKyEbe7 +f/LVjHAsQWCqsWMYRJUadmJ+9oCw++hkpjPRiQfhvbfmQ6QYuKZ3AeEPlAwhHbJUKSWJbOUOUlFH +dL4mrLZBdd56rF+NP8m800ERElvlEFDrMcXKchYiCd98THU/Y+whX8QgUWtvsauGi0/C1kVfnSD8 +oR7FwI+isX4KJpn15GkvmB0t9dmpsh3lGwIDAQABo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1Ud +DwEB/wQEAwIBhjAdBgNVHQ4EFgQU7NfjgtJxXWRM3y5nP+e6mK4cD08wDQYJKoZIhvcNAQEMBQAD +ggIBALth2X2pbL4XxJEbw6GiAI3jZGgPVs93rnD5/ZpKmbnJeFwMDF/k5hQpVgs2SV1EY+CtnJYY +ZhsjDT156W1r1lT40jzBQ0CuHVD1UvyQO7uYmWlrx8GnqGikJ9yd+SeuMIW59mdNOj6PWTkiU0Tr +yF0Dyu1Qen1iIQqAyHNm0aAFYF/opbSnr6j3bTWcfFqK1qI4mfN4i/RN0iAL3gTujJtHgXINwBQy +7zBZLq7gcfJW5GqXb5JQbZaNaHqasjYUegbyJLkJEVDXCLG4iXqEI2FCKeWjzaIgQdfRnGTZ6iah +ixTXTBmyUEFxPT9NcCOGDErcgdLMMpSEDQgJlxxPwO5rIHQw0uA5NBCFIRUBCOhVMt5xSdkoF1BN +5r5N0XWs0Mr7QbhDparTwwVETyw2m+L64kW4I1NsBm9nVX9GtUw/bihaeSbSpKhil9Ie4u1Ki7wb +/UdKDd9nZn6yW0HQO+T0O/QEY+nvwlQAUaCKKsnOeMzV6ocEGLPOr0mIr/OSmbaz5mEP0oUA51Aa +5BuVnRmhuZyxm7EAHu/QD09CbMkKvO5D+jpxpchNJqU1/YldvIViHTLSoCtU7ZpXwdv6EM8Zt4tK +G48BtieVU+i2iW1bvGjUI+iLUaJW+fCmgKDWHrO8Dw9TdSmq6hN35N6MgSGtBxBHEa2HPQfRdbzP +82Z+ +-----END CERTIFICATE----- + +COMODO RSA Certification Authority +================================== +-----BEGIN CERTIFICATE----- +MIIF2DCCA8CgAwIBAgIQTKr5yttjb+Af907YWwOGnTANBgkqhkiG9w0BAQwFADCBhTELMAkGA1UE +BhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgG +A1UEChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkwHhcNMTAwMTE5MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMC +R0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UE +ChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBSU0EgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCR6FSS0gpWsawNJN3Fz0Rn +dJkrN6N9I3AAcbxT38T6KhKPS38QVr2fcHK3YX/JSw8Xpz3jsARh7v8Rl8f0hj4K+j5c+ZPmNHrZ +FGvnnLOFoIJ6dq9xkNfs/Q36nGz637CC9BR++b7Epi9Pf5l/tfxnQ3K9DADWietrLNPtj5gcFKt+ +5eNu/Nio5JIk2kNrYrhV/erBvGy2i/MOjZrkm2xpmfh4SDBF1a3hDTxFYPwyllEnvGfDyi62a+pG +x8cgoLEfZd5ICLqkTqnyg0Y3hOvozIFIQ2dOciqbXL1MGyiKXCJ7tKuY2e7gUYPDCUZObT6Z+pUX +2nwzV0E8jVHtC7ZcryxjGt9XyD+86V3Em69FmeKjWiS0uqlWPc9vqv9JWL7wqP/0uK3pN/u6uPQL +OvnoQ0IeidiEyxPx2bvhiWC4jChWrBQdnArncevPDt09qZahSL0896+1DSJMwBGB7FY79tOi4lu3 +sgQiUpWAk2nojkxl8ZEDLXB0AuqLZxUpaVICu9ffUGpVRr+goyhhf3DQw6KqLCGqR84onAZFdr+C +GCe01a60y1Dma/RMhnEw6abfFobg2P9A3fvQQoh/ozM6LlweQRGBY84YcWsr7KaKtzFcOmpH4MN5 +WdYgGq/yapiqcrxXStJLnbsQ/LBMQeXtHT1eKJ2czL+zUdqnR+WEUwIDAQABo0IwQDAdBgNVHQ4E +FgQUu69+Aj36pvE8hI6t7jiY7NkyMtQwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8w +DQYJKoZIhvcNAQEMBQADggIBAArx1UaEt65Ru2yyTUEUAJNMnMvlwFTPoCWOAvn9sKIN9SCYPBMt +rFaisNZ+EZLpLrqeLppysb0ZRGxhNaKatBYSaVqM4dc+pBroLwP0rmEdEBsqpIt6xf4FpuHA1sj+ +nq6PK7o9mfjYcwlYRm6mnPTXJ9OV2jeDchzTc+CiR5kDOF3VSXkAKRzH7JsgHAckaVd4sjn8OoSg +tZx8jb8uk2IntznaFxiuvTwJaP+EmzzV1gsD41eeFPfR60/IvYcjt7ZJQ3mFXLrrkguhxuhoqEwW +sRqZCuhTLJK7oQkYdQxlqHvLI7cawiiFwxv/0Cti76R7CZGYZ4wUAc1oBmpjIXUDgIiKboHGhfKp +pC3n9KUkEEeDys30jXlYsQab5xoq2Z0B15R97QNKyvDb6KkBPvVWmckejkk9u+UJueBPSZI9FoJA +zMxZxuY67RIuaTxslbH9qh17f4a+Hg4yRvv7E491f0yLS0Zj/gA0QHDBw7mh3aZw4gSzQbzpgJHq +ZJx64SIDqZxubw5lT2yHh17zbqD5daWbQOhTsiedSrnAdyGN/4fy3ryM7xfft0kL0fJuMAsaDk52 +7RH89elWsn2/x20Kk4yl0MC2Hb46TpSi125sC8KKfPog88Tk5c0NqMuRkrF8hey1FGlmDoLnzc7I +LaZRfyHBNVOFBkpdn627G190 +-----END CERTIFICATE----- + +USERTrust RSA Certification Authority +===================================== +-----BEGIN CERTIFICATE----- +MIIF3jCCA8agAwIBAgIQAf1tMPyjylGoG7xkDjUDLTANBgkqhkiG9w0BAQwFADCBiDELMAkGA1UE +BhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQK +ExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2VydGlmaWNh +dGlvbiBBdXRob3JpdHkwHhcNMTAwMjAxMDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UE +BhMCVVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQK +ExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBSU0EgQ2VydGlmaWNh +dGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCAEmUXNg7D2wiz +0KxXDXbtzSfTTK1Qg2HiqiBNCS1kCdzOiZ/MPans9s/B3PHTsdZ7NygRK0faOca8Ohm0X6a9fZ2j +Y0K2dvKpOyuR+OJv0OwWIJAJPuLodMkYtJHUYmTbf6MG8YgYapAiPLz+E/CHFHv25B+O1ORRxhFn +RghRy4YUVD+8M/5+bJz/Fp0YvVGONaanZshyZ9shZrHUm3gDwFA66Mzw3LyeTP6vBZY1H1dat//O ++T23LLb2VN3I5xI6Ta5MirdcmrS3ID3KfyI0rn47aGYBROcBTkZTmzNg95S+UzeQc0PzMsNT79uq +/nROacdrjGCT3sTHDN/hMq7MkztReJVni+49Vv4M0GkPGw/zJSZrM233bkf6c0Plfg6lZrEpfDKE +Y1WJxA3Bk1QwGROs0303p+tdOmw1XNtB1xLaqUkL39iAigmTYo61Zs8liM2EuLE/pDkP2QKe6xJM +lXzzawWpXhaDzLhn4ugTncxbgtNMs+1b/97lc6wjOy0AvzVVdAlJ2ElYGn+SNuZRkg7zJn0cTRe8 +yexDJtC/QV9AqURE9JnnV4eeUB9XVKg+/XRjL7FQZQnmWEIuQxpMtPAlR1n6BB6T1CZGSlCBst6+ +eLf8ZxXhyVeEHg9j1uliutZfVS7qXMYoCAQlObgOK6nyTJccBz8NUvXt7y+CDwIDAQABo0IwQDAd +BgNVHQ4EFgQUU3m/WqorSs9UgOHYm8Cd8rIDZsswDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQF +MAMBAf8wDQYJKoZIhvcNAQEMBQADggIBAFzUfA3P9wF9QZllDHPFUp/L+M+ZBn8b2kMVn54CVVeW +FPFSPCeHlCjtHzoBN6J2/FNQwISbxmtOuowhT6KOVWKR82kV2LyI48SqC/3vqOlLVSoGIG1VeCkZ +7l8wXEskEVX/JJpuXior7gtNn3/3ATiUFJVDBwn7YKnuHKsSjKCaXqeYalltiz8I+8jRRa8YFWSQ +Eg9zKC7F4iRO/Fjs8PRF/iKz6y+O0tlFYQXBl2+odnKPi4w2r78NBc5xjeambx9spnFixdjQg3IM +8WcRiQycE0xyNN+81XHfqnHd4blsjDwSXWXavVcStkNr/+XeTWYRUc+ZruwXtuhxkYzeSf7dNXGi +FSeUHM9h4ya7b6NnJSFd5t0dCy5oGzuCr+yDZ4XUmFF0sbmZgIn/f3gZXHlKYC6SQK5MNyosycdi +yA5d9zZbyuAlJQG03RoHnHcAP9Dc1ew91Pq7P8yF1m9/qS3fuQL39ZeatTXaw2ewh0qpKJ4jjv9c +J2vhsE/zB+4ALtRZh8tSQZXq9EfX7mRBVXyNWQKV3WKdwrnuWih0hKWbt5DHDAff9Yk2dDLWKMGw +sAvgnEzDHNb842m1R0aBL6KCq9NjRHDEjf8tM7qtj3u1cIiuPhnPQCjY/MiQu12ZIvVS5ljFH4gx +Q+6IHdfGjjxDah2nGN59PRbxYvnKkKj9 +-----END CERTIFICATE----- + +USERTrust ECC Certification Authority +===================================== +-----BEGIN CERTIFICATE----- +MIICjzCCAhWgAwIBAgIQXIuZxVqUxdJxVt7NiYDMJjAKBggqhkjOPQQDAzCBiDELMAkGA1UEBhMC +VVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVU +aGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBFQ0MgQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkwHhcNMTAwMjAxMDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBiDELMAkGA1UEBhMC +VVMxEzARBgNVBAgTCk5ldyBKZXJzZXkxFDASBgNVBAcTC0plcnNleSBDaXR5MR4wHAYDVQQKExVU +aGUgVVNFUlRSVVNUIE5ldHdvcmsxLjAsBgNVBAMTJVVTRVJUcnVzdCBFQ0MgQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQarFRaqfloI+d61SRvU8Za2EurxtW2 +0eZzca7dnNYMYf3boIkDuAUU7FfO7l0/4iGzzvfUinngo4N+LZfQYcTxmdwlkWOrfzCjtHDix6Ez +nPO/LlxTsV+zfTJ/ijTjeXmjQjBAMB0GA1UdDgQWBBQ64QmG1M8ZwpZ2dEl23OA1xmNjmjAOBgNV +HQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjA2Z6EWCNzklwBB +HU6+4WMBzzuqQhFkoJ2UOQIReVx7Hfpkue4WQrO/isIJxOzksU0CMQDpKmFHjFJKS04YcPbWRNZu +9YO6bVi9JNlWSOrvxKJGgYhqOkbRqZtNyWHa0V1Xahg= +-----END CERTIFICATE----- + +GlobalSign ECC Root CA - R4 +=========================== +-----BEGIN CERTIFICATE----- +MIIB4TCCAYegAwIBAgIRKjikHJYKBN5CsiilC+g0mAIwCgYIKoZIzj0EAwIwUDEkMCIGA1UECxMb +R2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI0MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQD +EwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoXDTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMb +R2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI0MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQD +EwpHbG9iYWxTaWduMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEuMZ5049sJQ6fLjkZHAOkrprl +OQcJFspjsbmG+IpXwVfOQvpzofdlQv8ewQCybnMO/8ch5RikqtlxP6jUuc6MHaNCMEAwDgYDVR0P +AQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFFSwe61FuOJAf/sKbvu+M8k8o4TV +MAoGCCqGSM49BAMCA0gAMEUCIQDckqGgE6bPA7DmxCGXkPoUVy0D7O48027KqGx2vKLeuwIgJ6iF +JzWbVsaj8kfSt24bAgAXqmemFZHe+pTsewv4n4Q= +-----END CERTIFICATE----- + +GlobalSign ECC Root CA - R5 +=========================== +-----BEGIN CERTIFICATE----- +MIICHjCCAaSgAwIBAgIRYFlJ4CYuu1X5CneKcflK2GwwCgYIKoZIzj0EAwMwUDEkMCIGA1UECxMb +R2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI1MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQD +EwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoXDTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMb +R2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI1MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQD +EwpHbG9iYWxTaWduMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAER0UOlvt9Xb/pOdEh+J8LttV7HpI6 +SFkc8GIxLcB6KP4ap1yztsyX50XUWPrRd21DosCHZTQKH3rd6zwzocWdTaRvQZU4f8kehOvRnkmS +h5SHDDqFSmafnVmTTZdhBoZKo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAd +BgNVHQ4EFgQUPeYpSJvqB8ohREom3m7e0oPQn1kwCgYIKoZIzj0EAwMDaAAwZQIxAOVpEslu28Yx +uglB4Zf4+/2a4n0Sye18ZNPLBSWLVtmg515dTguDnFt2KaAJJiFqYgIwcdK1j1zqO+F4CYWodZI7 +yFz9SO8NdCKoCOJuxUnOxwy8p2Fp8fc74SrL+SvzZpA3 +-----END CERTIFICATE----- + +Staat der Nederlanden Root CA - G3 +================================== +-----BEGIN CERTIFICATE----- +MIIFdDCCA1ygAwIBAgIEAJiiOTANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJOTDEeMBwGA1UE +CgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFhdCBkZXIgTmVkZXJsYW5kZW4g +Um9vdCBDQSAtIEczMB4XDTEzMTExNDExMjg0MloXDTI4MTExMzIzMDAwMFowWjELMAkGA1UEBhMC +TkwxHjAcBgNVBAoMFVN0YWF0IGRlciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5l +ZGVybGFuZGVuIFJvb3QgQ0EgLSBHMzCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL4y +olQPcPssXFnrbMSkUeiFKrPMSjTysF/zDsccPVMeiAho2G89rcKezIJnByeHaHE6n3WWIkYFsO2t +x1ueKt6c/DrGlaf1F2cY5y9JCAxcz+bMNO14+1Cx3Gsy8KL+tjzk7FqXxz8ecAgwoNzFs21v0IJy +EavSgWhZghe3eJJg+szeP4TrjTgzkApyI/o1zCZxMdFyKJLZWyNtZrVtB0LrpjPOktvA9mxjeM3K +Tj215VKb8b475lRgsGYeCasH/lSJEULR9yS6YHgamPfJEf0WwTUaVHXvQ9Plrk7O53vDxk5hUUur +mkVLoR9BvUhTFXFkC4az5S6+zqQbwSmEorXLCCN2QyIkHxcE1G6cxvx/K2Ya7Irl1s9N9WMJtxU5 +1nus6+N86U78dULI7ViVDAZCopz35HCz33JvWjdAidiFpNfxC95DGdRKWCyMijmev4SH8RY7Ngzp +07TKbBlBUgmhHbBqv4LvcFEhMtwFdozL92TkA1CvjJFnq8Xy7ljY3r735zHPbMk7ccHViLVlvMDo +FxcHErVc0qsgk7TmgoNwNsXNo42ti+yjwUOH5kPiNL6VizXtBznaqB16nzaeErAMZRKQFWDZJkBE +41ZgpRDUajz9QdwOWke275dhdU/Z/seyHdTtXUmzqWrLZoQT1Vyg3N9udwbRcXXIV2+vD3dbAgMB +AAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRUrfrHkleu +yjWcLhL75LpdINyUVzANBgkqhkiG9w0BAQsFAAOCAgEAMJmdBTLIXg47mAE6iqTnB/d6+Oea31BD +U5cqPco8R5gu4RV78ZLzYdqQJRZlwJ9UXQ4DO1t3ApyEtg2YXzTdO2PCwyiBwpwpLiniyMMB8jPq +KqrMCQj3ZWfGzd/TtiunvczRDnBfuCPRy5FOCvTIeuXZYzbB1N/8Ipf3YF3qKS9Ysr1YvY2WTxB1 +v0h7PVGHoTx0IsL8B3+A3MSs/mrBcDCw6Y5p4ixpgZQJut3+TcCDjJRYwEYgr5wfAvg1VUkvRtTA +8KCWAg8zxXHzniN9lLf9OtMJgwYh/WA9rjLA0u6NpvDntIJ8CsxwyXmA+P5M9zWEGYox+wrZ13+b +8KKaa8MFSu1BYBQw0aoRQm7TIwIEC8Zl3d1Sd9qBa7Ko+gE4uZbqKmxnl4mUnrzhVNXkanjvSr0r +mj1AfsbAddJu+2gw7OyLnflJNZoaLNmzlTnVHpL3prllL+U9bTpITAjc5CgSKL59NVzq4BZ+Extq +1z7XnvwtdbLBFNUjA9tbbws+eC8N3jONFrdI54OagQ97wUNNVQQXOEpR1VmiiXTTn74eS9fGbbeI +JG9gkaSChVtWQbzQRKtqE77RLFi3EjNYsjdj3BP1lB0/QFH1T/U67cjF68IeHRaVesd+QnGTbksV +tzDfqu1XhUisHWrdOWnk4Xl4vs4Fv6EM94B7IWcnMFk= +-----END CERTIFICATE----- + +Staat der Nederlanden EV Root CA +================================ +-----BEGIN CERTIFICATE----- +MIIFcDCCA1igAwIBAgIEAJiWjTANBgkqhkiG9w0BAQsFADBYMQswCQYDVQQGEwJOTDEeMBwGA1UE +CgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSkwJwYDVQQDDCBTdGFhdCBkZXIgTmVkZXJsYW5kZW4g +RVYgUm9vdCBDQTAeFw0xMDEyMDgxMTE5MjlaFw0yMjEyMDgxMTEwMjhaMFgxCzAJBgNVBAYTAk5M +MR4wHAYDVQQKDBVTdGFhdCBkZXIgTmVkZXJsYW5kZW4xKTAnBgNVBAMMIFN0YWF0IGRlciBOZWRl +cmxhbmRlbiBFViBSb290IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA48d+ifkk +SzrSM4M1LGns3Amk41GoJSt5uAg94JG6hIXGhaTK5skuU6TJJB79VWZxXSzFYGgEt9nCUiY4iKTW +O0Cmws0/zZiTs1QUWJZV1VD+hq2kY39ch/aO5ieSZxeSAgMs3NZmdO3dZ//BYY1jTw+bbRcwJu+r +0h8QoPnFfxZpgQNH7R5ojXKhTbImxrpsX23Wr9GxE46prfNeaXUmGD5BKyF/7otdBwadQ8QpCiv8 +Kj6GyzyDOvnJDdrFmeK8eEEzduG/L13lpJhQDBXd4Pqcfzho0LKmeqfRMb1+ilgnQ7O6M5HTp5gV +XJrm0w912fxBmJc+qiXbj5IusHsMX/FjqTf5m3VpTCgmJdrV8hJwRVXj33NeN/UhbJCONVrJ0yPr +08C+eKxCKFhmpUZtcALXEPlLVPxdhkqHz3/KRawRWrUgUY0viEeXOcDPusBCAUCZSCELa6fS/ZbV +0b5GnUngC6agIk440ME8MLxwjyx1zNDFjFE7PZQIZCZhfbnDZY8UnCHQqv0XcgOPvZuM5l5Tnrmd +74K74bzickFbIZTTRTeU0d8JOV3nI6qaHcptqAqGhYqCvkIH1vI4gnPah1vlPNOePqc7nvQDs/nx +fRN0Av+7oeX6AHkcpmZBiFxgV6YuCcS6/ZrPpx9Aw7vMWgpVSzs4dlG4Y4uElBbmVvMCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFP6rAJCYniT8qcwa +ivsnuL8wbqg7MA0GCSqGSIb3DQEBCwUAA4ICAQDPdyxuVr5Os7aEAJSrR8kN0nbHhp8dB9O2tLsI +eK9p0gtJ3jPFrK3CiAJ9Brc1AsFgyb/E6JTe1NOpEyVa/m6irn0F3H3zbPB+po3u2dfOWBfoqSmu +c0iH55vKbimhZF8ZE/euBhD/UcabTVUlT5OZEAFTdfETzsemQUHSv4ilf0X8rLiltTMMgsT7B/Zq +5SWEXwbKwYY5EdtYzXc7LMJMD16a4/CrPmEbUCTCwPTxGfARKbalGAKb12NMcIxHowNDXLldRqAN +b/9Zjr7dn3LDWyvfjFvO5QxGbJKyCqNMVEIYFRIYvdr8unRu/8G2oGTYqV9Vrp9canaW2HNnh/tN +f1zuacpzEPuKqf2evTY4SUmH9A4U8OmHuD+nT3pajnnUk+S7aFKErGzp85hwVXIy+TSrK0m1zSBi +5Dp6Z2Orltxtrpfs/J92VoguZs9btsmksNcFuuEnL5O7Jiqik7Ab846+HUCjuTaPPoIaGl6I6lD4 +WeKDRikL40Rc4ZW2aZCaFG+XroHPaO+Zmr615+F/+PoTRxZMzG0IQOeLeG9QgkRQP2YGiqtDhFZK +DyAthg710tvSeopLzaXoTvFeJiUBWSOgftL2fiFX1ye8FVdMpEbB4IMeDExNH08GGeL5qPQ6gqGy +eUN51q1veieQA6TqJIc/2b3Z6fJfUEkc7uzXLg== +-----END CERTIFICATE----- + +IdenTrust Commercial Root CA 1 +============================== +-----BEGIN CERTIFICATE----- +MIIFYDCCA0igAwIBAgIQCgFCgAAAAUUjyES1AAAAAjANBgkqhkiG9w0BAQsFADBKMQswCQYDVQQG +EwJVUzESMBAGA1UEChMJSWRlblRydXN0MScwJQYDVQQDEx5JZGVuVHJ1c3QgQ29tbWVyY2lhbCBS +b290IENBIDEwHhcNMTQwMTE2MTgxMjIzWhcNMzQwMTE2MTgxMjIzWjBKMQswCQYDVQQGEwJVUzES +MBAGA1UEChMJSWRlblRydXN0MScwJQYDVQQDEx5JZGVuVHJ1c3QgQ29tbWVyY2lhbCBSb290IENB +IDEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCnUBneP5k91DNG8W9RYYKyqU+PZ4ld +hNlT3Qwo2dfw/66VQ3KZ+bVdfIrBQuExUHTRgQ18zZshq0PirK1ehm7zCYofWjK9ouuU+ehcCuz/ +mNKvcbO0U59Oh++SvL3sTzIwiEsXXlfEU8L2ApeN2WIrvyQfYo3fw7gpS0l4PJNgiCL8mdo2yMKi +1CxUAGc1bnO/AljwpN3lsKImesrgNqUZFvX9t++uP0D1bVoE/c40yiTcdCMbXTMTEl3EASX2MN0C +XZ/g1Ue9tOsbobtJSdifWwLziuQkkORiT0/Br4sOdBeo0XKIanoBScy0RnnGF7HamB4HWfp1IYVl +3ZBWzvurpWCdxJ35UrCLvYf5jysjCiN2O/cz4ckA82n5S6LgTrx+kzmEB/dEcH7+B1rlsazRGMzy +NeVJSQjKVsk9+w8YfYs7wRPCTY/JTw436R+hDmrfYi7LNQZReSzIJTj0+kuniVyc0uMNOYZKdHzV +WYfCP04MXFL0PfdSgvHqo6z9STQaKPNBiDoT7uje/5kdX7rL6B7yuVBgwDHTc+XvvqDtMwt0viAg +xGds8AgDelWAf0ZOlqf0Hj7h9tgJ4TNkK2PXMl6f+cB7D3hvl7yTmvmcEpB4eoCHFddydJxVdHix +uuFucAS6T6C6aMN7/zHwcz09lCqxC0EOoP5NiGVreTO01wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMC +AQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU7UQZwNPwBovupHu+QucmVMiONnYwDQYJKoZI +hvcNAQELBQADggIBAA2ukDL2pkt8RHYZYR4nKM1eVO8lvOMIkPkp165oCOGUAFjvLi5+U1KMtlwH +6oi6mYtQlNeCgN9hCQCTrQ0U5s7B8jeUeLBfnLOic7iPBZM4zY0+sLj7wM+x8uwtLRvM7Kqas6pg +ghstO8OEPVeKlh6cdbjTMM1gCIOQ045U8U1mwF10A0Cj7oV+wh93nAbowacYXVKV7cndJZ5t+qnt +ozo00Fl72u1Q8zW/7esUTTHHYPTa8Yec4kjixsU3+wYQ+nVZZjFHKdp2mhzpgq7vmrlR94gjmmmV +YjzlVYA211QC//G5Xc7UI2/YRYRKW2XviQzdFKcgyxilJbQN+QHwotL0AMh0jqEqSI5l2xPE4iUX +feu+h1sXIFRRk0pTAwvsXcoz7WL9RccvW9xYoIA55vrX/hMUpu09lEpCdNTDd1lzzY9GvlU47/ro +kTLql1gEIt44w8y8bckzOmoKaT+gyOpyj4xjhiO9bTyWnpXgSUyqorkqG5w2gXjtw+hG4iZZRHUe +2XWJUc0QhJ1hYMtd+ZciTY6Y5uN/9lu7rs3KSoFrXgvzUeF0K+l+J6fZmUlO+KWA2yUPHGNiiskz +Z2s8EIPGrd6ozRaOjfAHN3Gf8qv8QfXBi+wAN10J5U6A7/qxXDgGpRtK4dw4LTzcqx+QGtVKnO7R +cGzM7vRX+Bi6hG6H +-----END CERTIFICATE----- + +IdenTrust Public Sector Root CA 1 +================================= +-----BEGIN CERTIFICATE----- +MIIFZjCCA06gAwIBAgIQCgFCgAAAAUUjz0Z8AAAAAjANBgkqhkiG9w0BAQsFADBNMQswCQYDVQQG +EwJVUzESMBAGA1UEChMJSWRlblRydXN0MSowKAYDVQQDEyFJZGVuVHJ1c3QgUHVibGljIFNlY3Rv +ciBSb290IENBIDEwHhcNMTQwMTE2MTc1MzMyWhcNMzQwMTE2MTc1MzMyWjBNMQswCQYDVQQGEwJV +UzESMBAGA1UEChMJSWRlblRydXN0MSowKAYDVQQDEyFJZGVuVHJ1c3QgUHVibGljIFNlY3RvciBS +b290IENBIDEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2IpT8pEiv6EdrCvsnduTy +P4o7ekosMSqMjbCpwzFrqHd2hCa2rIFCDQjrVVi7evi8ZX3yoG2LqEfpYnYeEe4IFNGyRBb06tD6 +Hi9e28tzQa68ALBKK0CyrOE7S8ItneShm+waOh7wCLPQ5CQ1B5+ctMlSbdsHyo+1W/CD80/HLaXI +rcuVIKQxKFdYWuSNG5qrng0M8gozOSI5Cpcu81N3uURF/YTLNiCBWS2ab21ISGHKTN9T0a9SvESf +qy9rg3LvdYDaBjMbXcjaY8ZNzaxmMc3R3j6HEDbhuaR672BQssvKplbgN6+rNBM5Jeg5ZuSYeqoS +mJxZZoY+rfGwyj4GD3vwEUs3oERte8uojHH01bWRNszwFcYr3lEXsZdMUD2xlVl8BX0tIdUAvwFn +ol57plzy9yLxkA2T26pEUWbMfXYD62qoKjgZl3YNa4ph+bz27nb9cCvdKTz4Ch5bQhyLVi9VGxyh +LrXHFub4qjySjmm2AcG1hp2JDws4lFTo6tyePSW8Uybt1as5qsVATFSrsrTZ2fjXctscvG29ZV/v +iDUqZi/u9rNl8DONfJhBaUYPQxxp+pu10GFqzcpL2UyQRqsVWaFHVCkugyhfHMKiq3IXAAaOReyL +4jM9f9oZRORicsPfIsbyVtTdX5Vy7W1f90gDW/3FKqD2cyOEEBsB5wIDAQABo0IwQDAOBgNVHQ8B +Af8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU43HgntinQtnbcZFrlJPrw6PRFKMw +DQYJKoZIhvcNAQELBQADggIBAEf63QqwEZE4rU1d9+UOl1QZgkiHVIyqZJnYWv6IAcVYpZmxI1Qj +t2odIFflAWJBF9MJ23XLblSQdf4an4EKwt3X9wnQW3IV5B4Jaj0z8yGa5hV+rVHVDRDtfULAj+7A +mgjVQdZcDiFpboBhDhXAuM/FSRJSzL46zNQuOAXeNf0fb7iAaJg9TaDKQGXSc3z1i9kKlT/YPyNt +GtEqJBnZhbMX73huqVjRI9PHE+1yJX9dsXNw0H8GlwmEKYBhHfpe/3OsoOOJuBxxFcbeMX8S3OFt +m6/n6J91eEyrRjuazr8FGF1NFTwWmhlQBJqymm9li1JfPFgEKCXAZmExfrngdbkaqIHWchezxQMx +NRF4eKLg6TCMf4DfWN88uieW4oA0beOY02QnrEh+KHdcxiVhJfiFDGX6xDIvpZgF5PgLZxYWxoK4 +Mhn5+bl53B/N66+rDt0b20XkeucC4pVd/GnwU2lhlXV5C15V5jgclKlZM57IcXR5f1GJtshquDDI +ajjDbp7hNxbqBWJMWxJH7ae0s1hWx0nzfxJoCTFx8G34Tkf71oXuxVhAGaQdp/lLQzfcaFpPz+vC +ZHTetBXZ9FRUGi8c15dxVJCO2SCdUyt/q4/i6jC8UDfv8Ue1fXwsBOxonbRJRBD0ckscZOf85muQ +3Wl9af0AVqW3rLatt8o+Ae+c +-----END CERTIFICATE----- + +Entrust Root Certification Authority - G2 +========================================= +-----BEGIN CERTIFICATE----- +MIIEPjCCAyagAwIBAgIESlOMKDANBgkqhkiG9w0BAQsFADCBvjELMAkGA1UEBhMCVVMxFjAUBgNV +BAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50cnVzdC5uZXQvbGVnYWwtdGVy +bXMxOTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3QsIEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ug +b25seTEyMDAGA1UEAxMpRW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzIw +HhcNMDkwNzA3MTcyNTU0WhcNMzAxMjA3MTc1NTU0WjCBvjELMAkGA1UEBhMCVVMxFjAUBgNVBAoT +DUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50cnVzdC5uZXQvbGVnYWwtdGVybXMx +OTA3BgNVBAsTMChjKSAyMDA5IEVudHJ1c3QsIEluYy4gLSBmb3IgYXV0aG9yaXplZCB1c2Ugb25s +eTEyMDAGA1UEAxMpRW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzIwggEi +MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC6hLZy254Ma+KZ6TABp3bqMriVQRrJ2mFOWHLP +/vaCeb9zYQYKpSfYs1/TRU4cctZOMvJyig/3gxnQaoCAAEUesMfnmr8SVycco2gvCoe9amsOXmXz +HHfV1IWNcCG0szLni6LVhjkCsbjSR87kyUnEO6fe+1R9V77w6G7CebI6C1XiUJgWMhNcL3hWwcKU +s/Ja5CeanyTXxuzQmyWC48zCxEXFjJd6BmsqEZ+pCm5IO2/b1BEZQvePB7/1U1+cPvQXLOZprE4y +TGJ36rfo5bs0vBmLrpxR57d+tVOxMyLlbc9wPBr64ptntoP0jaWvYkxN4FisZDQSA/i2jZRjJKRx +AgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqciZ6 +0B7vfec7aVHUbI2fkBJmqzANBgkqhkiG9w0BAQsFAAOCAQEAeZ8dlsa2eT8ijYfThwMEYGprmi5Z +iXMRrEPR9RP/jTkrwPK9T3CMqS/qF8QLVJ7UG5aYMzyorWKiAHarWWluBh1+xLlEjZivEtRh2woZ +Rkfz6/djwUAFQKXSt/S1mja/qYh2iARVBCuch38aNzx+LaUa2NSJXsq9rD1s2G2v1fN2D807iDgi +nWyTmsQ9v4IbZT+mD12q/OWyFcq1rca8PdCE6OoGcrBNOTJ4vz4RnAuknZoh8/CbCzB428Hch0P+ +vGOaysXCHMnHjf87ElgI5rY97HosTvuDls4MPGmHVHOkc8KT/1EQrBVUAdj8BbGJoX90g5pJ19xO +e4pIb4tF9g== +-----END CERTIFICATE----- + +Entrust Root Certification Authority - EC1 +========================================== +-----BEGIN CERTIFICATE----- +MIIC+TCCAoCgAwIBAgINAKaLeSkAAAAAUNCR+TAKBggqhkjOPQQDAzCBvzELMAkGA1UEBhMCVVMx +FjAUBgNVBAoTDUVudHJ1c3QsIEluYy4xKDAmBgNVBAsTH1NlZSB3d3cuZW50cnVzdC5uZXQvbGVn +YWwtdGVybXMxOTA3BgNVBAsTMChjKSAyMDEyIEVudHJ1c3QsIEluYy4gLSBmb3IgYXV0aG9yaXpl +ZCB1c2Ugb25seTEzMDEGA1UEAxMqRW50cnVzdCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +IC0gRUMxMB4XDTEyMTIxODE1MjUzNloXDTM3MTIxODE1NTUzNlowgb8xCzAJBgNVBAYTAlVTMRYw +FAYDVQQKEw1FbnRydXN0LCBJbmMuMSgwJgYDVQQLEx9TZWUgd3d3LmVudHJ1c3QubmV0L2xlZ2Fs +LXRlcm1zMTkwNwYDVQQLEzAoYykgMjAxMiBFbnRydXN0LCBJbmMuIC0gZm9yIGF1dGhvcml6ZWQg +dXNlIG9ubHkxMzAxBgNVBAMTKkVudHJ1c3QgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAt +IEVDMTB2MBAGByqGSM49AgEGBSuBBAAiA2IABIQTydC6bUF74mzQ61VfZgIaJPRbiWlH47jCffHy +AsWfoPZb1YsGGYZPUxBtByQnoaD41UcZYUx9ypMn6nQM72+WCf5j7HBdNq1nd67JnXxVRDqiY1Ef +9eNi1KlHBz7MIKNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYE +FLdj5xrdjekIplWDpOBqUEFlEUJJMAoGCCqGSM49BAMDA2cAMGQCMGF52OVCR98crlOZF7ZvHH3h +vxGU0QOIdeSNiaSKd0bebWHvAvX7td/M/k7//qnmpwIwW5nXhTcGtXsI/esni0qU+eH6p44mCOh8 +kmhtc9hvJqwhAriZtyZBWyVgrtBIGu4G +-----END CERTIFICATE----- + +CFCA EV ROOT +============ +-----BEGIN CERTIFICATE----- +MIIFjTCCA3WgAwIBAgIEGErM1jANBgkqhkiG9w0BAQsFADBWMQswCQYDVQQGEwJDTjEwMC4GA1UE +CgwnQ2hpbmEgRmluYW5jaWFsIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MRUwEwYDVQQDDAxDRkNB +IEVWIFJPT1QwHhcNMTIwODA4MDMwNzAxWhcNMjkxMjMxMDMwNzAxWjBWMQswCQYDVQQGEwJDTjEw +MC4GA1UECgwnQ2hpbmEgRmluYW5jaWFsIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MRUwEwYDVQQD +DAxDRkNBIEVWIFJPT1QwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDXXWvNED8fBVnV +BU03sQ7smCuOFR36k0sXgiFxEFLXUWRwFsJVaU2OFW2fvwwbwuCjZ9YMrM8irq93VCpLTIpTUnrD +7i7es3ElweldPe6hL6P3KjzJIx1qqx2hp/Hz7KDVRM8Vz3IvHWOX6Jn5/ZOkVIBMUtRSqy5J35DN +uF++P96hyk0g1CXohClTt7GIH//62pCfCqktQT+x8Rgp7hZZLDRJGqgG16iI0gNyejLi6mhNbiyW +ZXvKWfry4t3uMCz7zEasxGPrb382KzRzEpR/38wmnvFyXVBlWY9ps4deMm/DGIq1lY+wejfeWkU7 +xzbh72fROdOXW3NiGUgthxwG+3SYIElz8AXSG7Ggo7cbcNOIabla1jj0Ytwli3i/+Oh+uFzJlU9f +py25IGvPa931DfSCt/SyZi4QKPaXWnuWFo8BGS1sbn85WAZkgwGDg8NNkt0yxoekN+kWzqotaK8K +gWU6cMGbrU1tVMoqLUuFG7OA5nBFDWteNfB/O7ic5ARwiRIlk9oKmSJgamNgTnYGmE69g60dWIol +hdLHZR4tjsbftsbhf4oEIRUpdPA+nJCdDC7xij5aqgwJHsfVPKPtl8MeNPo4+QgO48BdK4PRVmrJ +tqhUUy54Mmc9gn900PvhtgVguXDbjgv5E1hvcWAQUhC5wUEJ73IfZzF4/5YFjQIDAQABo2MwYTAf +BgNVHSMEGDAWgBTj/i39KNALtbq2osS/BqoFjJP7LzAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB +/wQEAwIBBjAdBgNVHQ4EFgQU4/4t/SjQC7W6tqLEvwaqBYyT+y8wDQYJKoZIhvcNAQELBQADggIB +ACXGumvrh8vegjmWPfBEp2uEcwPenStPuiB/vHiyz5ewG5zz13ku9Ui20vsXiObTej/tUxPQ4i9q +ecsAIyjmHjdXNYmEwnZPNDatZ8POQQaIxffu2Bq41gt/UP+TqhdLjOztUmCypAbqTuv0axn96/Ua +4CUqmtzHQTb3yHQFhDmVOdYLO6Qn+gjYXB74BGBSESgoA//vU2YApUo0FmZ8/Qmkrp5nGm9BC2sG +E5uPhnEFtC+NiWYzKXZUmhH4J/qyP5Hgzg0b8zAarb8iXRvTvyUFTeGSGn+ZnzxEk8rUQElsgIfX +BDrDMlI1Dlb4pd19xIsNER9Tyx6yF7Zod1rg1MvIB671Oi6ON7fQAUtDKXeMOZePglr4UeWJoBjn +aH9dCi77o0cOPaYjesYBx4/IXr9tgFa+iiS6M+qf4TIRnvHST4D2G0CvOJ4RUHlzEhLN5mydLIhy +PDCBBpEi6lmt2hkuIsKNuYyH4Ga8cyNfIWRjgEj1oDwYPZTISEEdQLpe/v5WOaHIz16eGWRGENoX +kbcFgKyLmZJ956LYBws2J+dIeWCKw9cTXPhyQN9Ky8+ZAAoACxGV2lZFA4gKn2fQ1XmxqI1AbQ3C +ekD6819kR5LLU7m7Wc5P/dAVUwHY3+vZ5nbv0CO7O6l5s9UCKc2Jo5YPSjXnTkLAdc0Hz+Ys63su +-----END CERTIFICATE----- + +Certinomis - Root CA +==================== +-----BEGIN CERTIFICATE----- +MIIFkjCCA3qgAwIBAgIBATANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJGUjETMBEGA1UEChMK +Q2VydGlub21pczEXMBUGA1UECxMOMDAwMiA0MzM5OTg5MDMxHTAbBgNVBAMTFENlcnRpbm9taXMg +LSBSb290IENBMB4XDTEzMTAyMTA5MTcxOFoXDTMzMTAyMTA5MTcxOFowWjELMAkGA1UEBhMCRlIx +EzARBgNVBAoTCkNlcnRpbm9taXMxFzAVBgNVBAsTDjAwMDIgNDMzOTk4OTAzMR0wGwYDVQQDExRD +ZXJ0aW5vbWlzIC0gUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANTMCQos +P5L2fxSeC5yaah1AMGT9qt8OHgZbn1CF6s2Nq0Nn3rD6foCWnoR4kkjW4znuzuRZWJflLieY6pOo +d5tK8O90gC3rMB+12ceAnGInkYjwSond3IjmFPnVAy//ldu9n+ws+hQVWZUKxkd8aRi5pwP5ynap +z8dvtF4F/u7BUrJ1Mofs7SlmO/NKFoL21prbcpjp3vDFTKWrteoB4owuZH9kb/2jJZOLyKIOSY00 +8B/sWEUuNKqEUL3nskoTuLAPrjhdsKkb5nPJWqHZZkCqqU2mNAKthH6yI8H7KsZn9DS2sJVqM09x +RLWtwHkziOC/7aOgFLScCbAK42C++PhmiM1b8XcF4LVzbsF9Ri6OSyemzTUK/eVNfaoqoynHWmgE +6OXWk6RiwsXm9E/G+Z8ajYJJGYrKWUM66A0ywfRMEwNvbqY/kXPLynNvEiCL7sCCeN5LLsJJwx3t +FvYk9CcbXFcx3FXuqB5vbKziRcxXV4p1VxngtViZSTYxPDMBbRZKzbgqg4SGm/lg0h9tkQPTYKbV +PZrdd5A9NaSfD171UkRpucC63M9933zZxKyGIjK8e2uR73r4F2iw4lNVYC2vPsKD2NkJK/DAZNuH +i5HMkesE/Xa0lZrmFAYb1TQdvtj/dBxThZngWVJKYe2InmtJiUZ+IFrZ50rlau7SZRFDAgMBAAGj +YzBhMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTvkUz1pcMw6C8I +6tNxIqSSaHh02TAfBgNVHSMEGDAWgBTvkUz1pcMw6C8I6tNxIqSSaHh02TANBgkqhkiG9w0BAQsF +AAOCAgEAfj1U2iJdGlg+O1QnurrMyOMaauo++RLrVl89UM7g6kgmJs95Vn6RHJk/0KGRHCwPT5iV +WVO90CLYiF2cN/z7ZMF4jIuaYAnq1fohX9B0ZedQxb8uuQsLrbWwF6YSjNRieOpWauwK0kDDPAUw +Pk2Ut59KA9N9J0u2/kTO+hkzGm2kQtHdzMjI1xZSg081lLMSVX3l4kLr5JyTCcBMWwerx20RoFAX +lCOotQqSD7J6wWAsOMwaplv/8gzjqh8c3LigkyfeY+N/IZ865Z764BNqdeuWXGKRlI5nU7aJ+BIJ +y29SWwNyhlCVCNSNh4YVH5Uk2KRvms6knZtt0rJ2BobGVgjF6wnaNsIbW0G+YSrjcOa4pvi2WsS9 +Iff/ql+hbHY5ZtbqTFXhADObE5hjyW/QASAJN1LnDE8+zbz1X5YnpyACleAu6AdBBR8Vbtaw5Bng +DwKTACdyxYvRVB9dSsNAl35VpnzBMwQUAR1JIGkLGZOdblgi90AMRgwjY/M50n92Uaf0yKHxDHYi +I0ZSKS3io0EHVmmY0gUJvGnHWmHNj4FgFU2A3ZDifcRQ8ow7bkrHxuaAKzyBvBGAFhAn1/DNP3nM +cyrDflOR1m749fPH0FFNjkulW+YZFzvWgQncItzujrnEj1PhZ7szuIgVRs/taTX/dQ1G885x4cVr +hkIGuUE= +-----END CERTIFICATE----- + +OISTE WISeKey Global Root GB CA +=============================== +-----BEGIN CERTIFICATE----- +MIIDtTCCAp2gAwIBAgIQdrEgUnTwhYdGs/gjGvbCwDANBgkqhkiG9w0BAQsFADBtMQswCQYDVQQG +EwJDSDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNl +ZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwgUm9vdCBHQiBDQTAeFw0xNDEyMDExNTAw +MzJaFw0zOTEyMDExNTEwMzFaMG0xCzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYD +VQQLExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEds +b2JhbCBSb290IEdCIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA2Be3HEokKtaX +scriHvt9OO+Y9bI5mE4nuBFde9IllIiCFSZqGzG7qFshISvYD06fWvGxWuR51jIjK+FTzJlFXHtP +rby/h0oLS5daqPZI7H17Dc0hBt+eFf1Biki3IPShehtX1F1Q/7pn2COZH8g/497/b1t3sWtuuMlk +9+HKQUYOKXHQuSP8yYFfTvdv37+ErXNku7dCjmn21HYdfp2nuFeKUWdy19SouJVUQHMD9ur06/4o +Qnc/nSMbsrY9gBQHTC5P99UKFg29ZkM3fiNDecNAhvVMKdqOmq0NpQSHiB6F4+lT1ZvIiwNjeOvg +GUpuuy9rM2RYk61pv48b74JIxwIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB +/zAdBgNVHQ4EFgQUNQ/INmNe4qPs+TtmFc5RUuORmj0wEAYJKwYBBAGCNxUBBAMCAQAwDQYJKoZI +hvcNAQELBQADggEBAEBM+4eymYGQfp3FsLAmzYh7KzKNbrghcViXfa43FK8+5/ea4n32cZiZBKpD +dHij40lhPnOMTZTg+XHEthYOU3gf1qKHLwI5gSk8rxWYITD+KJAAjNHhy/peyP34EEY7onhCkRd0 +VQreUGdNZtGn//3ZwLWoo4rOZvUPQ82nK1d7Y0Zqqi5S2PTt4W2tKZB4SLrhI6qjiey1q5bAtEui +HZeeevJuQHHfaPFlTc58Bd9TZaml8LGXBHAVRgOY1NK/VLSgWH1Sb9pWJmLU2NuJMW8c8CLC02Ic +Nc1MaRVUGpCY3useX8p3x8uOPUNpnJpY0CQ73xtAln41rYHHTnG6iBM= +-----END CERTIFICATE----- + +SZAFIR ROOT CA2 +=============== +-----BEGIN CERTIFICATE----- +MIIDcjCCAlqgAwIBAgIUPopdB+xV0jLVt+O2XwHrLdzk1uQwDQYJKoZIhvcNAQELBQAwUTELMAkG +A1UEBhMCUEwxKDAmBgNVBAoMH0tyYWpvd2EgSXpiYSBSb3psaWN6ZW5pb3dhIFMuQS4xGDAWBgNV +BAMMD1NaQUZJUiBST09UIENBMjAeFw0xNTEwMTkwNzQzMzBaFw0zNTEwMTkwNzQzMzBaMFExCzAJ +BgNVBAYTAlBMMSgwJgYDVQQKDB9LcmFqb3dhIEl6YmEgUm96bGljemVuaW93YSBTLkEuMRgwFgYD +VQQDDA9TWkFGSVIgUk9PVCBDQTIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQC3vD5Q +qEvNQLXOYeeWyrSh2gwisPq1e3YAd4wLz32ohswmUeQgPYUM1ljj5/QqGJ3a0a4m7utT3PSQ1hNK +DJA8w/Ta0o4NkjrcsbH/ON7Dui1fgLkCvUqdGw+0w8LBZwPd3BucPbOw3gAeqDRHu5rr/gsUvTaE +2g0gv/pby6kWIK05YO4vdbbnl5z5Pv1+TW9NL++IDWr63fE9biCloBK0TXC5ztdyO4mTp4CEHCdJ +ckm1/zuVnsHMyAHs6A6KCpbns6aH5db5BSsNl0BwPLqsdVqc1U2dAgrSS5tmS0YHF2Wtn2yIANwi +ieDhZNRnvDF5YTy7ykHNXGoAyDw4jlivAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0P +AQH/BAQDAgEGMB0GA1UdDgQWBBQuFqlKGLXLzPVvUPMjX/hd56zwyDANBgkqhkiG9w0BAQsFAAOC +AQEAtXP4A9xZWx126aMqe5Aosk3AM0+qmrHUuOQn/6mWmc5G4G18TKI4pAZw8PRBEew/R40/cof5 +O/2kbytTAOD/OblqBw7rHRz2onKQy4I9EYKL0rufKq8h5mOGnXkZ7/e7DDWQw4rtTw/1zBLZpD67 +oPwglV9PJi8RI4NOdQcPv5vRtB3pEAT+ymCPoky4rc/hkA/NrgrHXXu3UNLUYfrVFdvXn4dRVOul +4+vJhaAlIDf7js4MNIThPIGyd05DpYhfhmehPea0XGG2Ptv+tyjFogeutcrKjSoS75ftwjCkySp6 ++/NNIxuZMzSgLvWpCz/UXeHPhJ/iGcJfitYgHuNztw== +-----END CERTIFICATE----- + +Certum Trusted Network CA 2 +=========================== +-----BEGIN CERTIFICATE----- +MIIF0jCCA7qgAwIBAgIQIdbQSk8lD8kyN/yqXhKN6TANBgkqhkiG9w0BAQ0FADCBgDELMAkGA1UE +BhMCUEwxIjAgBgNVBAoTGVVuaXpldG8gVGVjaG5vbG9naWVzIFMuQS4xJzAlBgNVBAsTHkNlcnR1 +bSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTEkMCIGA1UEAxMbQ2VydHVtIFRydXN0ZWQgTmV0d29y +ayBDQSAyMCIYDzIwMTExMDA2MDgzOTU2WhgPMjA0NjEwMDYwODM5NTZaMIGAMQswCQYDVQQGEwJQ +TDEiMCAGA1UEChMZVW5pemV0byBUZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENl +cnRpZmljYXRpb24gQXV0aG9yaXR5MSQwIgYDVQQDExtDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENB +IDIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC9+Xj45tWADGSdhhuWZGc/IjoedQF9 +7/tcZ4zJzFxrqZHmuULlIEub2pt7uZld2ZuAS9eEQCsn0+i6MLs+CRqnSZXvK0AkwpfHp+6bJe+o +CgCXhVqqndwpyeI1B+twTUrWwbNWuKFBOJvR+zF/j+Bf4bE/D44WSWDXBo0Y+aomEKsq09DRZ40b +Rr5HMNUuctHFY9rnY3lEfktjJImGLjQ/KUxSiyqnwOKRKIm5wFv5HdnnJ63/mgKXwcZQkpsCLL2p +uTRZCr+ESv/f/rOf69me4Jgj7KZrdxYq28ytOxykh9xGc14ZYmhFV+SQgkK7QtbwYeDBoz1mo130 +GO6IyY0XRSmZMnUCMe4pJshrAua1YkV/NxVaI2iJ1D7eTiew8EAMvE0Xy02isx7QBlrd9pPPV3WZ +9fqGGmd4s7+W/jTcvedSVuWz5XV710GRBdxdaeOVDUO5/IOWOZV7bIBaTxNyxtd9KXpEulKkKtVB +Rgkg/iKgtlswjbyJDNXXcPiHUv3a76xRLgezTv7QCdpw75j6VuZt27VXS9zlLCUVyJ4ueE742pye +hizKV/Ma5ciSixqClnrDvFASadgOWkaLOusm+iPJtrCBvkIApPjW/jAux9JG9uWOdf3yzLnQh1vM +BhBgu4M1t15n3kfsmUjxpKEV/q2MYo45VU85FrmxY53/twIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MB0GA1UdDgQWBBS2oVQ5AsOgP46KvPrU+Bym0ToO/TAOBgNVHQ8BAf8EBAMCAQYwDQYJKoZI +hvcNAQENBQADggIBAHGlDs7k6b8/ONWJWsQCYftMxRQXLYtPU2sQF/xlhMcQSZDe28cmk4gmb3DW +Al45oPePq5a1pRNcgRRtDoGCERuKTsZPpd1iHkTfCVn0W3cLN+mLIMb4Ck4uWBzrM9DPhmDJ2vuA +L55MYIR4PSFk1vtBHxgP58l1cb29XN40hz5BsA72udY/CROWFC/emh1auVbONTqwX3BNXuMp8SMo +clm2q8KMZiYcdywmdjWLKKdpoPk79SPdhRB0yZADVpHnr7pH1BKXESLjokmUbOe3lEu6LaTaM4tM +pkT/WjzGHWTYtTHkpjx6qFcL2+1hGsvxznN3Y6SHb0xRONbkX8eftoEq5IVIeVheO/jbAoJnwTnb +w3RLPTYe+SmTiGhbqEQZIfCn6IENLOiTNrQ3ssqwGyZ6miUfmpqAnksqP/ujmv5zMnHCnsZy4Ypo +J/HkD7TETKVhk/iXEAcqMCWpuchxuO9ozC1+9eB+D4Kob7a6bINDd82Kkhehnlt4Fj1F4jNy3eFm +ypnTycUm/Q1oBEauttmbjL4ZvrHG8hnjXALKLNhvSgfZyTXaQHXyxKcZb55CEJh15pWLYLztxRLX +is7VmFxWlgPF7ncGNf/P5O4/E2Hu29othfDNrp2yGAlFw5Khchf8R7agCyzxxN5DaAhqXzvwdmP7 +zAYspsbiDrW5viSP +-----END CERTIFICATE----- + +Hellenic Academic and Research Institutions RootCA 2015 +======================================================= +-----BEGIN CERTIFICATE----- +MIIGCzCCA/OgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBpjELMAkGA1UEBhMCR1IxDzANBgNVBAcT +BkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0 +aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNVBAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNl +YXJjaCBJbnN0aXR1dGlvbnMgUm9vdENBIDIwMTUwHhcNMTUwNzA3MTAxMTIxWhcNNDAwNjMwMTAx +MTIxWjCBpjELMAkGA1UEBhMCR1IxDzANBgNVBAcTBkF0aGVuczFEMEIGA1UEChM7SGVsbGVuaWMg +QWNhZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9ucyBDZXJ0LiBBdXRob3JpdHkxQDA+BgNV +BAMTN0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgUm9vdENBIDIw +MTUwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDC+Kk/G4n8PDwEXT2QNrCROnk8Zlrv +bTkBSRq0t89/TSNTt5AA4xMqKKYx8ZEA4yjsriFBzh/a/X0SWwGDD7mwX5nh8hKDgE0GPt+sr+eh +iGsxr/CL0BgzuNtFajT0AoAkKAoCFZVedioNmToUW/bLy1O8E00BiDeUJRtCvCLYjqOWXjrZMts+ +6PAQZe104S+nfK8nNLspfZu2zwnI5dMK/IhlZXQK3HMcXM1AsRzUtoSMTFDPaI6oWa7CJ06CojXd +FPQf/7J31Ycvqm59JCfnxssm5uX+Zwdj2EUN3TpZZTlYepKZcj2chF6IIbjV9Cz82XBST3i4vTwr +i5WY9bPRaM8gFH5MXF/ni+X1NYEZN9cRCLdmvtNKzoNXADrDgfgXy5I2XdGj2HUb4Ysn6npIQf1F +GQatJ5lOwXBH3bWfgVMS5bGMSF0xQxfjjMZ6Y5ZLKTBOhE5iGV48zpeQpX8B653g+IuJ3SWYPZK2 +fu/Z8VFRfS0myGlZYeCsargqNhEEelC9MoS+L9xy1dcdFkfkR2YgP/SWxa+OAXqlD3pk9Q0Yh9mu +iNX6hME6wGkoLfINaFGq46V3xqSQDqE3izEjR8EJCOtu93ib14L8hCCZSRm2Ekax+0VVFqmjZayc +Bw/qa9wfLgZy7IaIEuQt218FL+TwA9MmM+eAws1CoRc0CwIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUcRVnyMjJvXVdctA4GGqd83EkVAswDQYJKoZI +hvcNAQELBQADggIBAHW7bVRLqhBYRjTyYtcWNl0IXtVsyIe9tC5G8jH4fOpCtZMWVdyhDBKg2mF+ +D1hYc2Ryx+hFjtyp8iY/xnmMsVMIM4GwVhO+5lFc2JsKT0ucVlMC6U/2DWDqTUJV6HwbISHTGzrM +d/K4kPFox/la/vot9L/J9UUbzjgQKjeKeaO04wlshYaT/4mWJ3iBj2fjRnRUjtkNaeJK9E10A/+y +d+2VZ5fkscWrv2oj6NSU4kQoYsRL4vDY4ilrGnB+JGGTe08DMiUNRSQrlrRGar9KC/eaj8GsGsVn +82800vpzY4zvFrCopEYq+OsS7HK07/grfoxSwIuEVPkvPuNVqNxmsdnhX9izjFk0WaSrT2y7Hxjb +davYy5LNlDhhDgcGH0tGEPEVvo2FXDtKK4F5D7Rpn0lQl033DlZdwJVqwjbDG2jJ9SrcR5q+ss7F +Jej6A7na+RZukYT1HCjI/CbM1xyQVqdfbzoEvM14iQuODy+jqk+iGxI9FghAD/FGTNeqewjBCvVt +J94Cj8rDtSvK6evIIVM4pcw72Hc3MKJP2W/R8kCtQXoXxdZKNYm3QdV8hn9VTYNKpXMgwDqvkPGa +JI7ZjnHKe7iG2rKPmT4dEw0SEe7Uq/DpFXYC5ODfqiAeW2GFZECpkJcNrVPSWh2HagCXZWK0vm9q +p/UsQu0yrbYhnr68 +-----END CERTIFICATE----- + +Hellenic Academic and Research Institutions ECC RootCA 2015 +=========================================================== +-----BEGIN CERTIFICATE----- +MIICwzCCAkqgAwIBAgIBADAKBggqhkjOPQQDAjCBqjELMAkGA1UEBhMCR1IxDzANBgNVBAcTBkF0 +aGVuczFEMEIGA1UEChM7SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2VhcmNoIEluc3RpdHV0aW9u +cyBDZXJ0LiBBdXRob3JpdHkxRDBCBgNVBAMTO0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJj +aCBJbnN0aXR1dGlvbnMgRUNDIFJvb3RDQSAyMDE1MB4XDTE1MDcwNzEwMzcxMloXDTQwMDYzMDEw +MzcxMlowgaoxCzAJBgNVBAYTAkdSMQ8wDQYDVQQHEwZBdGhlbnMxRDBCBgNVBAoTO0hlbGxlbmlj +IEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9yaXR5MUQwQgYD +VQQDEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIEVDQyBSb290 +Q0EgMjAxNTB2MBAGByqGSM49AgEGBSuBBAAiA2IABJKgQehLgoRc4vgxEZmGZE4JJS+dQS8KrjVP +dJWyUWRrjWvmP3CV8AVER6ZyOFB2lQJajq4onvktTpnvLEhvTCUp6NFxW98dwXU3tNf6e3pCnGoK +Vlp8aQuqgAkkbH7BRqNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0O +BBYEFLQiC4KZJAEOnLvkDv2/+5cgk5kqMAoGCCqGSM49BAMCA2cAMGQCMGfOFmI4oqxiRaeplSTA +GiecMjvAwNW6qef4BENThe5SId6d9SWDPp5YSy/XZxMOIQIwBeF1Ad5o7SofTUwJCA3sS61kFyjn +dc5FZXIhF8siQQ6ME5g4mlRtm8rifOoCWCKR +-----END CERTIFICATE----- + +ISRG Root X1 +============ +-----BEGIN CERTIFICATE----- +MIIFazCCA1OgAwIBAgIRAIIQz7DSQONZRGPgu2OCiwAwDQYJKoZIhvcNAQELBQAwTzELMAkGA1UE +BhMCVVMxKTAnBgNVBAoTIEludGVybmV0IFNlY3VyaXR5IFJlc2VhcmNoIEdyb3VwMRUwEwYDVQQD +EwxJU1JHIFJvb3QgWDEwHhcNMTUwNjA0MTEwNDM4WhcNMzUwNjA0MTEwNDM4WjBPMQswCQYDVQQG +EwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2ggR3JvdXAxFTATBgNVBAMT +DElTUkcgUm9vdCBYMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAK3oJHP0FDfzm54r +Vygch77ct984kIxuPOZXoHj3dcKi/vVqbvYATyjb3miGbESTtrFj/RQSa78f0uoxmyF+0TM8ukj1 +3Xnfs7j/EvEhmkvBioZxaUpmZmyPfjxwv60pIgbz5MDmgK7iS4+3mX6UA5/TR5d8mUgjU+g4rk8K +b4Mu0UlXjIB0ttov0DiNewNwIRt18jA8+o+u3dpjq+sWT8KOEUt+zwvo/7V3LvSye0rgTBIlDHCN +Aymg4VMk7BPZ7hm/ELNKjD+Jo2FR3qyHB5T0Y3HsLuJvW5iB4YlcNHlsdu87kGJ55tukmi8mxdAQ +4Q7e2RCOFvu396j3x+UCB5iPNgiV5+I3lg02dZ77DnKxHZu8A/lJBdiB3QW0KtZB6awBdpUKD9jf +1b0SHzUvKBds0pjBqAlkd25HN7rOrFleaJ1/ctaJxQZBKT5ZPt0m9STJEadao0xAH0ahmbWnOlFu +hjuefXKnEgV4We0+UXgVCwOPjdAvBbI+e0ocS3MFEvzG6uBQE3xDk3SzynTnjh8BCNAw1FtxNrQH +usEwMFxIt4I7mKZ9YIqioymCzLq9gwQbooMDQaHWBfEbwrbwqHyGO0aoSCqI3Haadr8faqU9GY/r +OPNk3sgrDQoo//fb4hVC1CLQJ13hef4Y53CIrU7m2Ys6xt0nUW7/vGT1M0NPAgMBAAGjQjBAMA4G +A1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBR5tFnme7bl5AFzgAiIyBpY +9umbbjANBgkqhkiG9w0BAQsFAAOCAgEAVR9YqbyyqFDQDLHYGmkgJykIrGF1XIpu+ILlaS/V9lZL +ubhzEFnTIZd+50xx+7LSYK05qAvqFyFWhfFQDlnrzuBZ6brJFe+GnY+EgPbk6ZGQ3BebYhtF8GaV +0nxvwuo77x/Py9auJ/GpsMiu/X1+mvoiBOv/2X/qkSsisRcOj/KKNFtY2PwByVS5uCbMiogziUwt +hDyC3+6WVwW6LLv3xLfHTjuCvjHIInNzktHCgKQ5ORAzI4JMPJ+GslWYHb4phowim57iaztXOoJw +TdwJx4nLCgdNbOhdjsnvzqvHu7UrTkXWStAmzOVyyghqpZXjFaH3pO3JLF+l+/+sKAIuvtd7u+Nx +e5AW0wdeRlN8NwdCjNPElpzVmbUq4JUagEiuTDkHzsxHpFKVK7q4+63SM1N95R1NbdWhscdCb+ZA +JzVcoyi3B43njTOQ5yOf+1CceWxG1bQVs5ZufpsMljq4Ui0/1lvh+wjChP4kqKOJ2qxq4RgqsahD +YVvTH9w7jXbyLeiNdd8XM2w9U/t7y0Ff/9yi0GE44Za4rF2LN9d11TPAmRGunUHBcnWEvgJBQl9n +JEiU0Zsnvgc/ubhPgXRR4Xq37Z0j4r7g1SgEEzwxA57demyPxgcYxn/eR44/KJ4EBs+lVDR3veyJ +m+kXQ99b21/+jh5Xos1AnX5iItreGCc= +-----END CERTIFICATE----- + +AC RAIZ FNMT-RCM +================ +-----BEGIN CERTIFICATE----- +MIIFgzCCA2ugAwIBAgIPXZONMGc2yAYdGsdUhGkHMA0GCSqGSIb3DQEBCwUAMDsxCzAJBgNVBAYT +AkVTMREwDwYDVQQKDAhGTk1ULVJDTTEZMBcGA1UECwwQQUMgUkFJWiBGTk1ULVJDTTAeFw0wODEw +MjkxNTU5NTZaFw0zMDAxMDEwMDAwMDBaMDsxCzAJBgNVBAYTAkVTMREwDwYDVQQKDAhGTk1ULVJD +TTEZMBcGA1UECwwQQUMgUkFJWiBGTk1ULVJDTTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoC +ggIBALpxgHpMhm5/yBNtwMZ9HACXjywMI7sQmkCpGreHiPibVmr75nuOi5KOpyVdWRHbNi63URcf +qQgfBBckWKo3Shjf5TnUV/3XwSyRAZHiItQDwFj8d0fsjz50Q7qsNI1NOHZnjrDIbzAzWHFctPVr +btQBULgTfmxKo0nRIBnuvMApGGWn3v7v3QqQIecaZ5JCEJhfTzC8PhxFtBDXaEAUwED653cXeuYL +j2VbPNmaUtu1vZ5Gzz3rkQUCwJaydkxNEJY7kvqcfw+Z374jNUUeAlz+taibmSXaXvMiwzn15Cou +08YfxGyqxRxqAQVKL9LFwag0Jl1mpdICIfkYtwb1TplvqKtMUejPUBjFd8g5CSxJkjKZqLsXF3mw +WsXmo8RZZUc1g16p6DULmbvkzSDGm0oGObVo/CK67lWMK07q87Hj/LaZmtVC+nFNCM+HHmpxffnT +tOmlcYF7wk5HlqX2doWjKI/pgG6BU6VtX7hI+cL5NqYuSf+4lsKMB7ObiFj86xsc3i1w4peSMKGJ +47xVqCfWS+2QrYv6YyVZLag13cqXM7zlzced0ezvXg5KkAYmY6252TUtB7p2ZSysV4999AeU14EC +ll2jB0nVetBX+RvnU0Z1qrB5QstocQjpYL05ac70r8NWQMetUqIJ5G+GR4of6ygnXYMgrwTJbFaa +i0b1AgMBAAGjgYMwgYAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYE +FPd9xf3E6Jobd2Sn9R2gzL+HYJptMD4GA1UdIAQ3MDUwMwYEVR0gADArMCkGCCsGAQUFBwIBFh1o +dHRwOi8vd3d3LmNlcnQuZm5tdC5lcy9kcGNzLzANBgkqhkiG9w0BAQsFAAOCAgEAB5BK3/MjTvDD +nFFlm5wioooMhfNzKWtN/gHiqQxjAb8EZ6WdmF/9ARP67Jpi6Yb+tmLSbkyU+8B1RXxlDPiyN8+s +D8+Nb/kZ94/sHvJwnvDKuO+3/3Y3dlv2bojzr2IyIpMNOmqOFGYMLVN0V2Ue1bLdI4E7pWYjJ2cJ +j+F3qkPNZVEI7VFY/uY5+ctHhKQV8Xa7pO6kO8Rf77IzlhEYt8llvhjho6Tc+hj507wTmzl6NLrT +Qfv6MooqtyuGC2mDOL7Nii4LcK2NJpLuHvUBKwrZ1pebbuCoGRw6IYsMHkCtA+fdZn71uSANA+iW ++YJF1DngoABd15jmfZ5nc8OaKveri6E6FO80vFIOiZiaBECEHX5FaZNXzuvO+FB8TxxuBEOb+dY7 +Ixjp6o7RTUaN8Tvkasq6+yO3m/qZASlaWFot4/nUbQ4mrcFuNLwy+AwF+mWj2zs3gyLp1txyM/1d +8iC9djwj2ij3+RvrWWTV3F9yfiD8zYm1kGdNYno/Tq0dwzn+evQoFt9B9kiABdcPUXmsEKvU7ANm +5mqwujGSQkBqvjrTcuFqN1W8rB2Vt2lh8kORdOag0wokRqEIr9baRRmW1FMdW4R58MD3R++Lj8UG +rp1MYp3/RgT408m2ECVAdf4WqslKYIYvuu8wd+RU4riEmViAqhOLUTpPSPaLtrM= +-----END CERTIFICATE----- + +Amazon Root CA 1 +================ +-----BEGIN CERTIFICATE----- +MIIDQTCCAimgAwIBAgITBmyfz5m/jAo54vB4ikPmljZbyjANBgkqhkiG9w0BAQsFADA5MQswCQYD +VQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24gUm9vdCBDQSAxMB4XDTE1 +MDUyNjAwMDAwMFoXDTM4MDExNzAwMDAwMFowOTELMAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpv +bjEZMBcGA1UEAxMQQW1hem9uIFJvb3QgQ0EgMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC +ggEBALJ4gHHKeNXjca9HgFB0fW7Y14h29Jlo91ghYPl0hAEvrAIthtOgQ3pOsqTQNroBvo3bSMgH +FzZM9O6II8c+6zf1tRn4SWiw3te5djgdYZ6k/oI2peVKVuRF4fn9tBb6dNqcmzU5L/qwIFAGbHrQ +gLKm+a/sRxmPUDgH3KKHOVj4utWp+UhnMJbulHheb4mjUcAwhmahRWa6VOujw5H5SNz/0egwLX0t +dHA114gk957EWW67c4cX8jJGKLhD+rcdqsq08p8kDi1L93FcXmn/6pUCyziKrlA4b9v7LWIbxcce +VOF34GfID5yHI9Y/QCB/IIDEgEw+OyQmjgSubJrIqg0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAYYwHQYDVR0OBBYEFIQYzIU07LwMlJQuCFmcx7IQTgoIMA0GCSqGSIb3 +DQEBCwUAA4IBAQCY8jdaQZChGsV2USggNiMOruYou6r4lK5IpDB/G/wkjUu0yKGX9rbxenDIU5PM +CCjjmCXPI6T53iHTfIUJrU6adTrCC2qJeHZERxhlbI1Bjjt/msv0tadQ1wUsN+gDS63pYaACbvXy +8MWy7Vu33PqUXHeeE6V/Uq2V8viTO96LXFvKWlJbYK8U90vvo/ufQJVtMVT8QtPHRh8jrdkPSHCa +2XV4cdFyQzR1bldZwgJcJmApzyMZFo6IQ6XU5MsI+yMRQ+hDKXJioaldXgjUkK642M4UwtBV8ob2 +xJNDd2ZhwLnoQdeXeGADbkpyrqXRfboQnoZsG4q5WTP468SQvvG5 +-----END CERTIFICATE----- + +Amazon Root CA 2 +================ +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgITBmyf0pY1hp8KD+WGePhbJruKNzANBgkqhkiG9w0BAQwFADA5MQswCQYD +VQQGEwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24gUm9vdCBDQSAyMB4XDTE1 +MDUyNjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpv +bjEZMBcGA1UEAxMQQW1hem9uIFJvb3QgQ0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoC +ggIBAK2Wny2cSkxKgXlRmeyKy2tgURO8TW0G/LAIjd0ZEGrHJgw12MBvIITplLGbhQPDW9tK6Mj4 +kHbZW0/jTOgGNk3Mmqw9DJArktQGGWCsN0R5hYGCrVo34A3MnaZMUnbqQ523BNFQ9lXg1dKmSYXp +N+nKfq5clU1Imj+uIFptiJXZNLhSGkOQsL9sBbm2eLfq0OQ6PBJTYv9K8nu+NQWpEjTj82R0Yiw9 +AElaKP4yRLuH3WUnAnE72kr3H9rN9yFVkE8P7K6C4Z9r2UXTu/Bfh+08LDmG2j/e7HJV63mjrdvd +fLC6HM783k81ds8P+HgfajZRRidhW+mez/CiVX18JYpvL7TFz4QuK/0NURBs+18bvBt+xa47mAEx +kv8LV/SasrlX6avvDXbR8O70zoan4G7ptGmh32n2M8ZpLpcTnqWHsFcQgTfJU7O7f/aS0ZzQGPSS +btqDT6ZjmUyl+17vIWR6IF9sZIUVyzfpYgwLKhbcAS4y2j5L9Z469hdAlO+ekQiG+r5jqFoz7Mt0 +Q5X5bGlSNscpb/xVA1wf+5+9R+vnSUeVC06JIglJ4PVhHvG/LopyboBZ/1c6+XUyo05f7O0oYtlN +c/LMgRdg7c3r3NunysV+Ar3yVAhU/bQtCSwXVEqY0VThUWcI0u1ufm8/0i2BWSlmy5A5lREedCf+ +3euvAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSw +DPBMMPQFWAJI/TPlUq9LhONmUjANBgkqhkiG9w0BAQwFAAOCAgEAqqiAjw54o+Ci1M3m9Zh6O+oA +A7CXDpO8Wqj2LIxyh6mx/H9z/WNxeKWHWc8w4Q0QshNabYL1auaAn6AFC2jkR2vHat+2/XcycuUY ++gn0oJMsXdKMdYV2ZZAMA3m3MSNjrXiDCYZohMr/+c8mmpJ5581LxedhpxfL86kSk5Nrp+gvU5LE +YFiwzAJRGFuFjWJZY7attN6a+yb3ACfAXVU3dJnJUH/jWS5E4ywl7uxMMne0nxrpS10gxdr9HIcW +xkPo1LsmmkVwXqkLN1PiRnsn/eBG8om3zEK2yygmbtmlyTrIQRNg91CMFa6ybRoVGld45pIq2WWQ +gj9sAq+uEjonljYE1x2igGOpm/HlurR8FLBOybEfdF849lHqm/osohHUqS0nGkWxr7JOcQ3AWEbW +aQbLU8uz/mtBzUF+fUwPfHJ5elnNXkoOrJupmHN5fLT0zLm4BwyydFy4x2+IoZCn9Kr5v2c69BoV +Yh63n749sSmvZ6ES8lgQGVMDMBu4Gon2nL2XA46jCfMdiyHxtN/kHNGfZQIG6lzWE7OE76KlXIx3 +KadowGuuQNKotOrN8I1LOJwZmhsoVLiJkO/KdYE+HvJkJMcYr07/R54H9jVlpNMKVv/1F2Rs76gi +JUmTtt8AF9pYfl3uxRuw0dFfIRDH+fO6AgonB8Xx1sfT4PsJYGw= +-----END CERTIFICATE----- + +Amazon Root CA 3 +================ +-----BEGIN CERTIFICATE----- +MIIBtjCCAVugAwIBAgITBmyf1XSXNmY/Owua2eiedgPySjAKBggqhkjOPQQDAjA5MQswCQYDVQQG +EwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24gUm9vdCBDQSAzMB4XDTE1MDUy +NjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZ +MBcGA1UEAxMQQW1hem9uIFJvb3QgQ0EgMzBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABCmXp8ZB +f8ANm+gBG1bG8lKlui2yEujSLtf6ycXYqm0fc4E7O5hrOXwzpcVOho6AF2hiRVd9RFgdszflZwjr +Zt6jQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBSrttvXBp43 +rDCGB5Fwx5zEGbF4wDAKBggqhkjOPQQDAgNJADBGAiEA4IWSoxe3jfkrBqWTrBqYaGFy+uGh0Psc +eGCmQ5nFuMQCIQCcAu/xlJyzlvnrxir4tiz+OpAUFteMYyRIHN8wfdVoOw== +-----END CERTIFICATE----- + +Amazon Root CA 4 +================ +-----BEGIN CERTIFICATE----- +MIIB8jCCAXigAwIBAgITBmyf18G7EEwpQ+Vxe3ssyBrBDjAKBggqhkjOPQQDAzA5MQswCQYDVQQG +EwJVUzEPMA0GA1UEChMGQW1hem9uMRkwFwYDVQQDExBBbWF6b24gUm9vdCBDQSA0MB4XDTE1MDUy +NjAwMDAwMFoXDTQwMDUyNjAwMDAwMFowOTELMAkGA1UEBhMCVVMxDzANBgNVBAoTBkFtYXpvbjEZ +MBcGA1UEAxMQQW1hem9uIFJvb3QgQ0EgNDB2MBAGByqGSM49AgEGBSuBBAAiA2IABNKrijdPo1MN +/sGKe0uoe0ZLY7Bi9i0b2whxIdIA6GO9mif78DluXeo9pcmBqqNbIJhFXRbb/egQbeOc4OO9X4Ri +83BkM6DLJC9wuoihKqB1+IGuYgbEgds5bimwHvouXKNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNV +HQ8BAf8EBAMCAYYwHQYDVR0OBBYEFNPsxzplbszh2naaVvuc84ZtV+WBMAoGCCqGSM49BAMDA2gA +MGUCMDqLIfG9fhGt0O9Yli/W651+kI0rz2ZVwyzjKKlwCkcO8DdZEv8tmZQoTipPNU0zWgIxAOp1 +AE47xDqUEpHJWEadIRNyp4iciuRMStuW1KyLa2tJElMzrdfkviT8tQp21KW8EA== +-----END CERTIFICATE----- + +LuxTrust Global Root 2 +====================== +-----BEGIN CERTIFICATE----- +MIIFwzCCA6ugAwIBAgIUCn6m30tEntpqJIWe5rgV0xZ/u7EwDQYJKoZIhvcNAQELBQAwRjELMAkG +A1UEBhMCTFUxFjAUBgNVBAoMDUx1eFRydXN0IFMuQS4xHzAdBgNVBAMMFkx1eFRydXN0IEdsb2Jh +bCBSb290IDIwHhcNMTUwMzA1MTMyMTU3WhcNMzUwMzA1MTMyMTU3WjBGMQswCQYDVQQGEwJMVTEW +MBQGA1UECgwNTHV4VHJ1c3QgUy5BLjEfMB0GA1UEAwwWTHV4VHJ1c3QgR2xvYmFsIFJvb3QgMjCC +AiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANeFl78RmOnwYoNMPIf5U2o3C/IPPIfOb9wm +Kb3FibrJgz337spbxm1Jc7TJRqMbNBM/wYlFV/TZsfs2ZUv7COJIcRHIbjuend+JZTemhfY7RBi2 +xjcwYkSSl2l9QjAk5A0MiWtj3sXh306pFGxT4GHO9hcvHTy95iJMHZP1EMShduxq3sVs35a0VkBC +wGKSMKEtFZSg0iAGCW5qbeXrt77U8PEVfIvmTroTzEsnXpk8F12PgX8zPU/TPxvsXD/wPEx1bvKm +1Z3aLQdjAsZy6ZS8TEmVT4hSyNvoaYL4zDRbIvCGp4m9SAptZoFtyMhk+wHh9OHe2Z7d21vUKpkm +FRseTJIpgp7VkoGSQXAZ96Tlk0u8d2cx3Rz9MXANF5kM+Qw5GSoXtTBxVdUPrljhPS80m8+f9niF +wpN6cj5mj5wWEWCPnolvZ77gR1o7DJpni89Gxq44o/KnvObWhWszJHAiS8sIm7vI+AIpHb4gDEa/ +a4ebsypmQjVGbKq6rfmYe+lQVRQxv7HaLe2ArWgk+2mr2HETMOZns4dA/Yl+8kPREd8vZS9kzl8U +ubG/Mb2HeFpZZYiq/FkySIbWTLkpS5XTdvN3JW1CHDiDTf2jX5t/Lax5Gw5CMZdjpPuKadUiDTSQ +MC6otOBttpSsvItO13D8xTiOZCXhTTmQzsmHhFhxAgMBAAGjgagwgaUwDwYDVR0TAQH/BAUwAwEB +/zBCBgNVHSAEOzA5MDcGByuBKwEBAQowLDAqBggrBgEFBQcCARYeaHR0cHM6Ly9yZXBvc2l0b3J5 +Lmx1eHRydXN0Lmx1MA4GA1UdDwEB/wQEAwIBBjAfBgNVHSMEGDAWgBT/GCh2+UgFLKGu8SsbK7JT ++Et8szAdBgNVHQ4EFgQU/xgodvlIBSyhrvErGyuyU/hLfLMwDQYJKoZIhvcNAQELBQADggIBAGoZ +FO1uecEsh9QNcH7X9njJCwROxLHOk3D+sFTAMs2ZMGQXvw/l4jP9BzZAcg4atmpZ1gDlaCDdLnIN +H2pkMSCEfUmmWjfrRcmF9dTHF5kH5ptV5AzoqbTOjFu1EVzPig4N1qx3gf4ynCSecs5U89BvolbW +7MM3LGVYvlcAGvI1+ut7MV3CwRI9loGIlonBWVx65n9wNOeD4rHh4bhY79SV5GCc8JaXcozrhAIu +ZY+kt9J/Z93I055cqqmkoCUUBpvsT34tC38ddfEz2O3OuHVtPlu5mB0xDVbYQw8wkbIEa91WvpWA +VWe+2M2D2RjuLg+GLZKecBPs3lHJQ3gCpU3I+V/EkVhGFndadKpAvAefMLmx9xIX3eP/JEAdemrR +TxgKqpAd60Ae36EeRJIQmvKN4dFLRp7oRUKX6kWZ8+xm1QL68qZKJKrezrnK+T+Tb/mjuuqlPpmt +/f97mfVl7vBZKGfXkJWkE4SphMHozs51k2MavDzq1WQfLSoSOcbDWjLtR5EWDrw4wVDej8oqkDQc +7kGUnF4ZLvhFSZl0kbAEb+MEWrGrKqv+x9CWttrhSmQGbmBNvUJO/3jaJMobtNeWOWyu8Q6qp31I +iyBMz2TWuJdGsE7RKlY6oJO9r4Ak4Ap+58rVyuiFVdw2KuGUaJPHZnJED4AhMmwlxyOAgwrr +-----END CERTIFICATE----- + +TUBITAK Kamu SM SSL Kok Sertifikasi - Surum 1 +============================================= +-----BEGIN CERTIFICATE----- +MIIEYzCCA0ugAwIBAgIBATANBgkqhkiG9w0BAQsFADCB0jELMAkGA1UEBhMCVFIxGDAWBgNVBAcT +D0dlYnplIC0gS29jYWVsaTFCMEAGA1UEChM5VHVya2l5ZSBCaWxpbXNlbCB2ZSBUZWtub2xvamlr +IEFyYXN0aXJtYSBLdXJ1bXUgLSBUVUJJVEFLMS0wKwYDVQQLEyRLYW11IFNlcnRpZmlrYXN5b24g +TWVya2V6aSAtIEthbXUgU00xNjA0BgNVBAMTLVRVQklUQUsgS2FtdSBTTSBTU0wgS29rIFNlcnRp +ZmlrYXNpIC0gU3VydW0gMTAeFw0xMzExMjUwODI1NTVaFw00MzEwMjUwODI1NTVaMIHSMQswCQYD +VQQGEwJUUjEYMBYGA1UEBxMPR2ViemUgLSBLb2NhZWxpMUIwQAYDVQQKEzlUdXJraXllIEJpbGlt +c2VsIHZlIFRla25vbG9qaWsgQXJhc3Rpcm1hIEt1cnVtdSAtIFRVQklUQUsxLTArBgNVBAsTJEth +bXUgU2VydGlmaWthc3lvbiBNZXJrZXppIC0gS2FtdSBTTTE2MDQGA1UEAxMtVFVCSVRBSyBLYW11 +IFNNIFNTTCBLb2sgU2VydGlmaWthc2kgLSBTdXJ1bSAxMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAr3UwM6q7a9OZLBI3hNmNe5eA027n/5tQlT6QlVZC1xl8JoSNkvoBHToP4mQ4t4y8 +6Ij5iySrLqP1N+RAjhgleYN1Hzv/bKjFxlb4tO2KRKOrbEz8HdDc72i9z+SqzvBV96I01INrN3wc +wv61A+xXzry0tcXtAA9TNypN9E8Mg/uGz8v+jE69h/mniyFXnHrfA2eJLJ2XYacQuFWQfw4tJzh0 +3+f92k4S400VIgLI4OD8D62K18lUUMw7D8oWgITQUVbDjlZ/iSIzL+aFCr2lqBs23tPcLG07xxO9 +WSMs5uWk99gL7eqQQESolbuT1dCANLZGeA4fAJNG4e7p+exPFwIDAQABo0IwQDAdBgNVHQ4EFgQU +ZT/HiobGPN08VFw1+DrtUgxHV8gwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJ +KoZIhvcNAQELBQADggEBACo/4fEyjq7hmFxLXs9rHmoJ0iKpEsdeV31zVmSAhHqT5Am5EM2fKifh +AHe+SMg1qIGf5LgsyX8OsNJLN13qudULXjS99HMpw+0mFZx+CFOKWI3QSyjfwbPfIPP54+M638yc +lNhOT8NrF7f3cuitZjO1JVOr4PhMqZ398g26rrnZqsZr+ZO7rqu4lzwDGrpDxpa5RXI4s6ehlj2R +e37AIVNMh+3yC1SVUZPVIqUNivGTDj5UDrDYyU7c8jEyVupk+eq1nRZmQnLzf9OxMUP8pI4X8W0j +q5Rm+K37DwhuJi1/FwcJsoz7UMCflo3Ptv0AnVoUmr8CRPXBwp8iXqIPoeM= +-----END CERTIFICATE----- + +GDCA TrustAUTH R5 ROOT +====================== +-----BEGIN CERTIFICATE----- +MIIFiDCCA3CgAwIBAgIIfQmX/vBH6nowDQYJKoZIhvcNAQELBQAwYjELMAkGA1UEBhMCQ04xMjAw +BgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZIENPLixMVEQuMR8wHQYDVQQD +DBZHRENBIFRydXN0QVVUSCBSNSBST09UMB4XDTE0MTEyNjA1MTMxNVoXDTQwMTIzMTE1NTk1OVow +YjELMAkGA1UEBhMCQ04xMjAwBgNVBAoMKUdVQU5HIERPTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZ +IENPLixMVEQuMR8wHQYDVQQDDBZHRENBIFRydXN0QVVUSCBSNSBST09UMIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEA2aMW8Mh0dHeb7zMNOwZ+Vfy1YI92hhJCfVZmPoiC7XJjDp6L3TQs +AlFRwxn9WVSEyfFrs0yw6ehGXTjGoqcuEVe6ghWinI9tsJlKCvLriXBjTnnEt1u9ol2x8kECK62p +OqPseQrsXzrj/e+APK00mxqriCZ7VqKChh/rNYmDf1+uKU49tm7srsHwJ5uu4/Ts765/94Y9cnrr +pftZTqfrlYwiOXnhLQiPzLyRuEH3FMEjqcOtmkVEs7LXLM3GKeJQEK5cy4KOFxg2fZfmiJqwTTQJ +9Cy5WmYqsBebnh52nUpmMUHfP/vFBu8btn4aRjb3ZGM74zkYI+dndRTVdVeSN72+ahsmUPI2JgaQ +xXABZG12ZuGR224HwGGALrIuL4xwp9E7PLOR5G62xDtw8mySlwnNR30YwPO7ng/Wi64HtloPzgsM +R6flPri9fcebNaBhlzpBdRfMK5Z3KpIhHtmVdiBnaM8Nvd/WHwlqmuLMc3GkL30SgLdTMEZeS1SZ +D2fJpcjyIMGC7J0R38IC+xo70e0gmu9lZJIQDSri3nDxGGeCjGHeuLzRL5z7D9Ar7Rt2ueQ5Vfj4 +oR24qoAATILnsn8JuLwwoC8N9VKejveSswoAHQBUlwbgsQfZxw9cZX08bVlX5O2ljelAU58VS6Bx +9hoh49pwBiFYFIeFd3mqgnkCAwEAAaNCMEAwHQYDVR0OBBYEFOLJQJ9NzuiaoXzPDj9lxSmIahlR +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQDRSVfg +p8xoWLoBDysZzY2wYUWsEe1jUGn4H3++Fo/9nesLqjJHdtJnJO29fDMylyrHBYZmDRd9FBUb1Ov9 +H5r2XpdptxolpAqzkT9fNqyL7FeoPueBihhXOYV0GkLH6VsTX4/5COmSdI31R9KrO9b7eGZONn35 +6ZLpBN79SWP8bfsUcZNnL0dKt7n/HipzcEYwv1ryL3ml4Y0M2fmyYzeMN2WFcGpcWwlyua1jPLHd ++PwyvzeG5LuOmCd+uh8W4XAR8gPfJWIyJyYYMoSf/wA6E7qaTfRPuBRwIrHKK5DOKcFw9C+df/KQ +HtZa37dG/OaG+svgIHZ6uqbL9XzeYqWxi+7egmaKTjowHz+Ay60nugxe19CxVsp3cbK1daFQqUBD +F8Io2c9Si1vIY9RCPqAzekYu9wogRlR+ak8x8YF+QnQ4ZXMn7sZ8uI7XpTrXmKGcjBBV09tL7ECQ +8s1uV9JiDnxXk7Gnbc2dg7sq5+W2O3FYrf3RRbxake5TFW/TRQl1brqQXR4EzzffHqhmsYzmIGrv +/EhOdJhCrylvLmrH+33RZjEizIYAfmaDDEL0vTSSwxrqT8p+ck0LcIymSLumoRT2+1hEmRSuqguT +aaApJUqlyyvdimYHFngVV3Eb7PVHhPOeMTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g== +-----END CERTIFICATE----- + +TrustCor RootCert CA-1 +====================== +-----BEGIN CERTIFICATE----- +MIIEMDCCAxigAwIBAgIJANqb7HHzA7AZMA0GCSqGSIb3DQEBCwUAMIGkMQswCQYDVQQGEwJQQTEP +MA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEkMCIGA1UECgwbVHJ1c3RDb3Ig +U3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5UcnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3Jp +dHkxHzAdBgNVBAMMFlRydXN0Q29yIFJvb3RDZXJ0IENBLTEwHhcNMTYwMjA0MTIzMjE2WhcNMjkx +MjMxMTcyMzE2WjCBpDELMAkGA1UEBhMCUEExDzANBgNVBAgMBlBhbmFtYTEUMBIGA1UEBwwLUGFu +YW1hIENpdHkxJDAiBgNVBAoMG1RydXN0Q29yIFN5c3RlbXMgUy4gZGUgUi5MLjEnMCUGA1UECwwe +VHJ1c3RDb3IgQ2VydGlmaWNhdGUgQXV0aG9yaXR5MR8wHQYDVQQDDBZUcnVzdENvciBSb290Q2Vy +dCBDQS0xMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAv463leLCJhJrMxnHQFgKq1mq +jQCj/IDHUHuO1CAmujIS2CNUSSUQIpidRtLByZ5OGy4sDjjzGiVoHKZaBeYei0i/mJZ0PmnK6bV4 +pQa81QBeCQryJ3pS/C3Vseq0iWEk8xoT26nPUu0MJLq5nux+AHT6k61sKZKuUbS701e/s/OojZz0 +JEsq1pme9J7+wH5COucLlVPat2gOkEz7cD+PSiyU8ybdY2mplNgQTsVHCJCZGxdNuWxu72CVEY4h +gLW9oHPY0LJ3xEXqWib7ZnZ2+AYfYW0PVcWDtxBWcgYHpfOxGgMFZA6dWorWhnAbJN7+KIor0Gqw +/Hqi3LJ5DotlDwIDAQABo2MwYTAdBgNVHQ4EFgQU7mtJPHo/DeOxCbeKyKsZn3MzUOcwHwYDVR0j +BBgwFoAU7mtJPHo/DeOxCbeKyKsZn3MzUOcwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AYYwDQYJKoZIhvcNAQELBQADggEBACUY1JGPE+6PHh0RU9otRCkZoB5rMZ5NDp6tPVxBb5UrJKF5 +mDo4Nvu7Zp5I/5CQ7z3UuJu0h3U/IJvOcs+hVcFNZKIZBqEHMwwLKeXx6quj7LUKdJDHfXLy11yf +ke+Ri7fc7Waiz45mO7yfOgLgJ90WmMCV1Aqk5IGadZQ1nJBfiDcGrVmVCrDRZ9MZyonnMlo2HD6C +qFqTvsbQZJG2z9m2GM/bftJlo6bEjhcxwft+dtvTheNYsnd6djtsL1Ac59v2Z3kf9YKVmgenFK+P +3CghZwnS1k1aHBkcjndcw5QkPTJrS37UeJSDvjdNzl/HHk484IkzlQsPpTLWPFp5LBk= +-----END CERTIFICATE----- + +TrustCor RootCert CA-2 +====================== +-----BEGIN CERTIFICATE----- +MIIGLzCCBBegAwIBAgIIJaHfyjPLWQIwDQYJKoZIhvcNAQELBQAwgaQxCzAJBgNVBAYTAlBBMQ8w +DQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQwIgYDVQQKDBtUcnVzdENvciBT +eXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRydXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0 +eTEfMB0GA1UEAwwWVHJ1c3RDb3IgUm9vdENlcnQgQ0EtMjAeFw0xNjAyMDQxMjMyMjNaFw0zNDEy +MzExNzI2MzlaMIGkMQswCQYDVQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5h +bWEgQ2l0eTEkMCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U +cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRydXN0Q29yIFJvb3RDZXJ0 +IENBLTIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCnIG7CKqJiJJWQdsg4foDSq8Gb +ZQWU9MEKENUCrO2fk8eHyLAnK0IMPQo+QVqedd2NyuCb7GgypGmSaIwLgQ5WoD4a3SwlFIIvl9Nk +RvRUqdw6VC0xK5mC8tkq1+9xALgxpL56JAfDQiDyitSSBBtlVkxs1Pu2YVpHI7TYabS3OtB0PAx1 +oYxOdqHp2yqlO/rOsP9+aij9JxzIsekp8VduZLTQwRVtDr4uDkbIXvRR/u8OYzo7cbrPb1nKDOOb +XUm4TOJXsZiKQlecdu/vvdFoqNL0Cbt3Nb4lggjEFixEIFapRBF37120Hapeaz6LMvYHL1cEksr1 +/p3C6eizjkxLAjHZ5DxIgif3GIJ2SDpxsROhOdUuxTTCHWKF3wP+TfSvPd9cW436cOGlfifHhi5q +jxLGhF5DUVCcGZt45vz27Ud+ez1m7xMTiF88oWP7+ayHNZ/zgp6kPwqcMWmLmaSISo5uZk3vFsQP +eSghYA2FFn3XVDjxklb9tTNMg9zXEJ9L/cb4Qr26fHMC4P99zVvh1Kxhe1fVSntb1IVYJ12/+Ctg +rKAmrhQhJ8Z3mjOAPF5GP/fDsaOGM8boXg25NSyqRsGFAnWAoOsk+xWq5Gd/bnc/9ASKL3x74xdh +8N0JqSDIvgmk0H5Ew7IwSjiqqewYmgeCK9u4nBit2uBGF6zPXQIDAQABo2MwYTAdBgNVHQ4EFgQU +2f4hQG6UnrybPZx9mCAZ5YwwYrIwHwYDVR0jBBgwFoAU2f4hQG6UnrybPZx9mCAZ5YwwYrIwDwYD +VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQADggIBAJ5Fngw7tu/h +Osh80QA9z+LqBrWyOrsGS2h60COXdKcs8AjYeVrXWoSK2BKaG9l9XE1wxaX5q+WjiYndAfrs3fnp +kpfbsEZC89NiqpX+MWcUaViQCqoL7jcjx1BRtPV+nuN79+TMQjItSQzL/0kMmx40/W5ulop5A7Zv +2wnL/V9lFDfhOPXzYRZY5LVtDQsEGz9QLX+zx3oaFoBg+Iof6Rsqxvm6ARppv9JYx1RXCI/hOWB3 +S6xZhBqI8d3LT3jX5+EzLfzuQfogsL7L9ziUwOHQhQ+77Sxzq+3+knYaZH9bDTMJBzN7Bj8RpFxw +PIXAz+OQqIN3+tvmxYxoZxBnpVIt8MSZj3+/0WvitUfW2dCFmU2Umw9Lje4AWkcdEQOsQRivh7dv +DDqPys/cA8GiCcjl/YBeyGBCARsaU1q7N6a3vLqE6R5sGtRk2tRD/pOLS/IseRYQ1JMLiI+h2IYU +RpFHmygk71dSTlxCnKr3Sewn6EAes6aJInKc9Q0ztFijMDvd1GpUk74aTfOTlPf8hAs/hCBcNANE +xdqtvArBAs8e5ZTZ845b2EzwnexhF7sUMlQMAimTHpKG9n/v55IFDlndmQguLvqcAFLTxWYp5KeX +RKQOKIETNcX2b2TmQcTVL8w0RSXPQQCWPUouwpaYT05KnJe32x+SMsj/D1Fu1uwJ +-----END CERTIFICATE----- + +TrustCor ECA-1 +============== +-----BEGIN CERTIFICATE----- +MIIEIDCCAwigAwIBAgIJAISCLF8cYtBAMA0GCSqGSIb3DQEBCwUAMIGcMQswCQYDVQQGEwJQQTEP +MA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEkMCIGA1UECgwbVHJ1c3RDb3Ig +U3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5UcnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3Jp +dHkxFzAVBgNVBAMMDlRydXN0Q29yIEVDQS0xMB4XDTE2MDIwNDEyMzIzM1oXDTI5MTIzMTE3Mjgw +N1owgZwxCzAJBgNVBAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5 +MSQwIgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRydXN0Q29y +IENlcnRpZmljYXRlIEF1dGhvcml0eTEXMBUGA1UEAwwOVHJ1c3RDb3IgRUNBLTEwggEiMA0GCSqG +SIb3DQEBAQUAA4IBDwAwggEKAoIBAQDPj+ARtZ+odnbb3w9U73NjKYKtR8aja+3+XzP4Q1HpGjOR +MRegdMTUpwHmspI+ap3tDvl0mEDTPwOABoJA6LHip1GnHYMma6ve+heRK9jGrB6xnhkB1Zem6g23 +xFUfJ3zSCNV2HykVh0A53ThFEXXQmqc04L/NyFIduUd+Dbi7xgz2c1cWWn5DkR9VOsZtRASqnKmc +p0yJF4OuowReUoCLHhIlERnXDH19MURB6tuvsBzvgdAsxZohmz3tQjtQJvLsznFhBmIhVE5/wZ0+ +fyCMgMsq2JdiyIMzkX2woloPV+g7zPIlstR8L+xNxqE6FXrntl019fZISjZFZtS6mFjBAgMBAAGj +YzBhMB0GA1UdDgQWBBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAfBgNVHSMEGDAWgBREnkj1zG1I1KBL +f/5ZJC+Dl5mahjAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsF +AAOCAQEABT41XBVwm8nHc2FvcivUwo/yQ10CzsSUuZQRg2dd4mdsdXa/uwyqNsatR5Nj3B5+1t4u +/ukZMjgDfxT2AHMsWbEhBuH7rBiVDKP/mZb3Kyeb1STMHd3BOuCYRLDE5D53sXOpZCz2HAF8P11F +hcCF5yWPldwX8zyfGm6wyuMdKulMY/okYWLW2n62HGz1Ah3UKt1VkOsqEUc8Ll50soIipX1TH0Xs +J5F95yIW6MBoNtjG8U+ARDL54dHRHareqKucBK+tIA5kmE2la8BIWJZpTdwHjFGTot+fDz2LYLSC +jaoITmJF4PkL0uDgPFveXHEnJcLmA4GLEFPjx1WitJ/X5g== +-----END CERTIFICATE----- + +SSL.com Root Certification Authority RSA +======================================== +-----BEGIN CERTIFICATE----- +MIIF3TCCA8WgAwIBAgIIeyyb0xaAMpkwDQYJKoZIhvcNAQELBQAwfDELMAkGA1UEBhMCVVMxDjAM +BgNVBAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9TU0wgQ29ycG9yYXRpb24x +MTAvBgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSBSU0EwHhcNMTYw +MjEyMTczOTM5WhcNNDEwMjEyMTczOTM5WjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMx +EDAOBgNVBAcMB0hvdXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NM +LmNvbSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IFJTQTCCAiIwDQYJKoZIhvcNAQEBBQAD +ggIPADCCAgoCggIBAPkP3aMrfcvQKv7sZ4Wm5y4bunfh4/WvpOz6Sl2RxFdHaxh3a3by/ZPkPQ/C +Fp4LZsNWlJ4Xg4XOVu/yFv0AYvUiCVToZRdOQbngT0aXqhvIuG5iXmmxX9sqAn78bMrzQdjt0Oj8 +P2FI7bADFB0QDksZ4LtO7IZl/zbzXmcCC52GVWH9ejjt/uIZALdvoVBidXQ8oPrIJZK0bnoix/ge +oeOy3ZExqysdBP+lSgQ36YWkMyv94tZVNHwZpEpox7Ko07fKoZOI68GXvIz5HdkihCR0xwQ9aqkp +k8zruFvh/l8lqjRYyMEjVJ0bmBHDOJx+PYZspQ9AhnwC9FwCTyjLrnGfDzrIM/4RJTXq/LrFYD3Z +fBjVsqnTdXgDciLKOsMf7yzlLqn6niy2UUb9rwPW6mBo6oUWNmuF6R7As93EJNyAKoFBbZQ+yODJ +gUEAnl6/f8UImKIYLEJAs/lvOCdLToD0PYFH4Ih86hzOtXVcUS4cK38acijnALXRdMbX5J+tB5O2 +UzU1/Dfkw/ZdFr4hc96SCvigY2q8lpJqPvi8ZVWb3vUNiSYE/CUapiVpy8JtynziWV+XrOvvLsi8 +1xtZPCvM8hnIk2snYxnP/Okm+Mpxm3+T/jRnhE6Z6/yzeAkzcLpmpnbtG3PrGqUNxCITIJRWCk4s +bE6x/c+cCbqiM+2HAgMBAAGjYzBhMB0GA1UdDgQWBBTdBAkHovV6fVJTEpKV7jiAJQ2mWTAPBgNV +HRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFN0ECQei9Xp9UlMSkpXuOIAlDaZZMA4GA1UdDwEB/wQE +AwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAIBgRlCn7Jp0cHh5wYfGVcpNxJK1ok1iOMq8bs3AD/CUr +dIWQPXhq9LmLpZc7tRiRux6n+UBbkflVma8eEdBcHadm47GUBwwyOabqG7B52B2ccETjit3E+ZUf +ijhDPwGFpUenPUayvOUiaPd7nNgsPgohyC0zrL/FgZkxdMF1ccW+sfAjRfSda/wZY52jvATGGAsl +u1OJD7OAUN5F7kR/q5R4ZJjT9ijdh9hwZXT7DrkT66cPYakylszeu+1jTBi7qUD3oFRuIIhxdRjq +erQ0cuAjJ3dctpDqhiVAq+8zD8ufgr6iIPv2tS0a5sKFsXQP+8hlAqRSAUfdSSLBv9jra6x+3uxj +MxW3IwiPxg+NQVrdjsW5j+VFP3jbutIbQLH+cU0/4IGiul607BXgk90IH37hVZkLId6Tngr75qNJ +vTYw/ud3sqB1l7UtgYgXZSD32pAAn8lSzDLKNXz1PQ/YK9f1JmzJBjSWFupwWRoyeXkLtoh/D1JI +Pb9s2KJELtFOt3JY04kTlf5Eq/jXixtunLwsoFvVagCvXzfh1foQC5ichucmj87w7G6KVwuA406y +wKBjYZC6VWg3dGq2ktufoYYitmUnDuy2n0Jg5GfCtdpBC8TTi2EbvPofkSvXRAdeuims2cXp71NI +WuuA8ShYIc2wBlX7Jz9TkHCpBB5XJ7k= +-----END CERTIFICATE----- + +SSL.com Root Certification Authority ECC +======================================== +-----BEGIN CERTIFICATE----- +MIICjTCCAhSgAwIBAgIIdebfy8FoW6gwCgYIKoZIzj0EAwIwfDELMAkGA1UEBhMCVVMxDjAMBgNV +BAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9TU0wgQ29ycG9yYXRpb24xMTAv +BgNVBAMMKFNTTC5jb20gUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYwMjEy +MTgxNDAzWhcNNDEwMjEyMTgxNDAzWjB8MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMxEDAO +BgNVBAcMB0hvdXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjExMC8GA1UEAwwoU1NMLmNv +bSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49AgEGBSuBBAAiA2IA +BEVuqVDEpiM2nl8ojRfLliJkP9x6jh3MCLOicSS6jkm5BBtHllirLZXI7Z4INcgn64mMU1jrYor+ +8FsPazFSY0E7ic3s7LaNGdM0B9y7xgZ/wkWV7Mt/qCPgCemB+vNH06NjMGEwHQYDVR0OBBYEFILR +hXMw5zUE044CkvvlpNHEIejNMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUgtGFczDnNQTT +jgKS++Wk0cQh6M0wDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2cAMGQCMG/n61kRpGDPYbCW +e+0F+S8Tkdzt5fxQaxFGRrMcIQBiu77D5+jNB5n5DQtdcj7EqgIwH7y6C+IwJPt8bYBVCpk+gA0z +5Wajs6O7pdWLjwkspl1+4vAHCGht0nxpbl/f5Wpl +-----END CERTIFICATE----- + +SSL.com EV Root Certification Authority RSA R2 +============================================== +-----BEGIN CERTIFICATE----- +MIIF6zCCA9OgAwIBAgIIVrYpzTS8ePYwDQYJKoZIhvcNAQELBQAwgYIxCzAJBgNVBAYTAlVTMQ4w +DAYDVQQIDAVUZXhhczEQMA4GA1UEBwwHSG91c3RvbjEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9u +MTcwNQYDVQQDDC5TU0wuY29tIEVWIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIy +MB4XDTE3MDUzMTE4MTQzN1oXDTQyMDUzMDE4MTQzN1owgYIxCzAJBgNVBAYTAlVTMQ4wDAYDVQQI +DAVUZXhhczEQMA4GA1UEBwwHSG91c3RvbjEYMBYGA1UECgwPU1NMIENvcnBvcmF0aW9uMTcwNQYD +VQQDDC5TU0wuY29tIEVWIFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgUlNBIFIyMIICIjAN +BgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAjzZlQOHWTcDXtOlG2mvqM0fNTPl9fb69LT3w23jh +hqXZuglXaO1XPqDQCEGD5yhBJB/jchXQARr7XnAjssufOePPxU7Gkm0mxnu7s9onnQqG6YE3Bf7w +cXHswxzpY6IXFJ3vG2fThVUCAtZJycxa4bH3bzKfydQ7iEGonL3Lq9ttewkfokxykNorCPzPPFTO +Zw+oz12WGQvE43LrrdF9HSfvkusQv1vrO6/PgN3B0pYEW3p+pKk8OHakYo6gOV7qd89dAFmPZiw+ +B6KjBSYRaZfqhbcPlgtLyEDhULouisv3D5oi53+aNxPN8k0TayHRwMwi8qFG9kRpnMphNQcAb9Zh +CBHqurj26bNg5U257J8UZslXWNvNh2n4ioYSA0e/ZhN2rHd9NCSFg83XqpyQGp8hLH94t2S42Oim +9HizVcuE0jLEeK6jj2HdzghTreyI/BXkmg3mnxp3zkyPuBQVPWKchjgGAGYS5Fl2WlPAApiiECto +RHuOec4zSnaqW4EWG7WK2NAAe15itAnWhmMOpgWVSbooi4iTsjQc2KRVbrcc0N6ZVTsj9CLg+Slm +JuwgUHfbSguPvuUCYHBBXtSuUDkiFCbLsjtzdFVHB3mBOagwE0TlBIqulhMlQg+5U8Sb/M3kHN48 ++qvWBkofZ6aYMBzdLNvcGJVXZsb/XItW9XcCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAfBgNV +HSMEGDAWgBT5YLvU49U09rj1BoAlp3PbRmmonjAdBgNVHQ4EFgQU+WC71OPVNPa49QaAJadz20Zp +qJ4wDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEBCwUAA4ICAQBWs47LCp1Jjr+kxJG7ZhcFUZh1 +++VQLHqe8RT6q9OKPv+RKY9ji9i0qVQBDb6Thi/5Sm3HXvVX+cpVHBK+Rw82xd9qt9t1wkclf7nx +Y/hoLVUE0fKNsKTPvDxeH3jnpaAgcLAExbf3cqfeIg29MyVGjGSSJuM+LmOW2puMPfgYCdcDzH2G +guDKBAdRUNf/ktUM79qGn5nX67evaOI5JpS6aLe/g9Pqemc9YmeuJeVy6OLk7K4S9ksrPJ/psEDz +OFSz/bdoyNrGj1E8svuR3Bznm53htw1yj+KkxKl4+esUrMZDBcJlOSgYAsOCsp0FvmXtll9ldDz7 +CTUue5wT/RsPXcdtgTpWD8w74a8CLyKsRspGPKAcTNZEtF4uXBVmCeEmKf7GUmG6sXP/wwyc5Wxq +lD8UykAWlYTzWamsX0xhk23RO8yilQwipmdnRC652dKKQbNmC1r7fSOl8hqw/96bg5Qu0T/fkreR +rwU7ZcegbLHNYhLDkBvjJc40vG93drEQw/cFGsDWr3RiSBd3kmmQYRzelYB0VI8YHMPzA9C/pEN1 +hlMYegouCRw2n5H9gooiS9EOUCXdywMMF8mDAAhONU2Ki+3wApRmLER/y5UnlhetCTCstnEXbosX +9hwJ1C07mKVx01QT2WDz9UtmT/rx7iASjbSsV7FFY6GsdqnC+w== +-----END CERTIFICATE----- + +SSL.com EV Root Certification Authority ECC +=========================================== +-----BEGIN CERTIFICATE----- +MIIClDCCAhqgAwIBAgIILCmcWxbtBZUwCgYIKoZIzj0EAwIwfzELMAkGA1UEBhMCVVMxDjAMBgNV +BAgMBVRleGFzMRAwDgYDVQQHDAdIb3VzdG9uMRgwFgYDVQQKDA9TU0wgQ29ycG9yYXRpb24xNDAy +BgNVBAMMK1NTTC5jb20gRVYgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSBFQ0MwHhcNMTYw +MjEyMTgxNTIzWhcNNDEwMjEyMTgxNTIzWjB/MQswCQYDVQQGEwJVUzEOMAwGA1UECAwFVGV4YXMx +EDAOBgNVBAcMB0hvdXN0b24xGDAWBgNVBAoMD1NTTCBDb3Jwb3JhdGlvbjE0MDIGA1UEAwwrU1NM +LmNvbSBFViBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IEVDQzB2MBAGByqGSM49AgEGBSuB +BAAiA2IABKoSR5CYG/vvw0AHgyBO8TCCogbR8pKGYfL2IWjKAMTH6kMAVIbc/R/fALhBYlzccBYy +3h+Z1MzFB8gIH2EWB1E9fVwHU+M1OIzfzZ/ZLg1KthkuWnBaBu2+8KGwytAJKaNjMGEwHQYDVR0O +BBYEFFvKXuXe0oGqzagtZFG22XKbl+ZPMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUW8pe +5d7SgarNqC1kUbbZcpuX5k8wDgYDVR0PAQH/BAQDAgGGMAoGCCqGSM49BAMCA2gAMGUCMQCK5kCJ +N+vp1RPZytRrJPOwPYdGWBrssd9v+1a6cGvHOMzosYxPD/fxZ3YOg9AeUY8CMD32IygmTMZgh5Mm +m7I1HrrW9zzRHM76JTymGoEVW/MSD2zuZYrJh6j5B+BimoxcSg== +-----END CERTIFICATE----- + +GlobalSign Root CA - R6 +======================= +-----BEGIN CERTIFICATE----- +MIIFgzCCA2ugAwIBAgIORea7A4Mzw4VlSOb/RVEwDQYJKoZIhvcNAQEMBQAwTDEgMB4GA1UECxMX +R2xvYmFsU2lnbiBSb290IENBIC0gUjYxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkds +b2JhbFNpZ24wHhcNMTQxMjEwMDAwMDAwWhcNMzQxMjEwMDAwMDAwWjBMMSAwHgYDVQQLExdHbG9i +YWxTaWduIFJvb3QgQ0EgLSBSNjETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFs +U2lnbjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAJUH6HPKZvnsFMp7PPcNCPG0RQss +grRIxutbPK6DuEGSMxSkb3/pKszGsIhrxbaJ0cay/xTOURQh7ErdG1rG1ofuTToVBu1kZguSgMpE +3nOUTvOniX9PeGMIyBJQbUJmL025eShNUhqKGoC3GYEOfsSKvGRMIRxDaNc9PIrFsmbVkJq3MQbF +vuJtMgamHvm566qjuL++gmNQ0PAYid/kD3n16qIfKtJwLnvnvJO7bVPiSHyMEAc4/2ayd2F+4OqM +PKq0pPbzlUoSB239jLKJz9CgYXfIWHSw1CM69106yqLbnQneXUQtkPGBzVeS+n68UARjNN9rkxi+ +azayOeSsJDa38O+2HBNXk7besvjihbdzorg1qkXy4J02oW9UivFyVm4uiMVRQkQVlO6jxTiWm05O +WgtH8wY2SXcwvHE35absIQh1/OZhFj931dmRl4QKbNQCTXTAFO39OfuD8l4UoQSwC+n+7o/hbguy +CLNhZglqsQY6ZZZZwPA1/cnaKI0aEYdwgQqomnUdnjqGBQCe24DWJfncBZ4nWUx2OVvq+aWh2IMP +0f/fMBH5hc8zSPXKbWQULHpYT9NLCEnFlWQaYw55PfWzjMpYrZxCRXluDocZXFSxZba/jJvcE+kN +b7gu3GduyYsRtYQUigAZcIN5kZeR1BonvzceMgfYFGM8KEyvAgMBAAGjYzBhMA4GA1UdDwEB/wQE +AwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBSubAWjkxPioufi1xzWx/B/yGdToDAfBgNV +HSMEGDAWgBSubAWjkxPioufi1xzWx/B/yGdToDANBgkqhkiG9w0BAQwFAAOCAgEAgyXt6NH9lVLN +nsAEoJFp5lzQhN7craJP6Ed41mWYqVuoPId8AorRbrcWc+ZfwFSY1XS+wc3iEZGtIxg93eFyRJa0 +lV7Ae46ZeBZDE1ZXs6KzO7V33EByrKPrmzU+sQghoefEQzd5Mr6155wsTLxDKZmOMNOsIeDjHfrY +BzN2VAAiKrlNIC5waNrlU/yDXNOd8v9EDERm8tLjvUYAGm0CuiVdjaExUd1URhxN25mW7xocBFym +Fe944Hn+Xds+qkxV/ZoVqW/hpvvfcDDpw+5CRu3CkwWJ+n1jez/QcYF8AOiYrg54NMMl+68KnyBr +3TsTjxKM4kEaSHpzoHdpx7Zcf4LIHv5YGygrqGytXm3ABdJ7t+uA/iU3/gKbaKxCXcPu9czc8FB1 +0jZpnOZ7BN9uBmm23goJSFmH63sUYHpkqmlD75HHTOwY3WzvUy2MmeFe8nI+z1TIvWfspA9MRf/T +uTAjB0yPEL+GltmZWrSZVxykzLsViVO6LAUP5MSeGbEYNNVMnbrt9x+vJJUEeKgDu+6B5dpffItK +oZB0JaezPkvILFa9x8jvOOJckvB595yEunQtYQEgfn7R8k8HWV+LLUNS60YMlOH1Zkd5d9VUWx+t +JDfLRVpOoERIyNiwmcUVhAn21klJwGW45hpxbqCo8YLoRT5s1gLXCmeDBVrJpBA= +-----END CERTIFICATE----- + +OISTE WISeKey Global Root GC CA +=============================== +-----BEGIN CERTIFICATE----- +MIICaTCCAe+gAwIBAgIQISpWDK7aDKtARb8roi066jAKBggqhkjOPQQDAzBtMQswCQYDVQQGEwJD +SDEQMA4GA1UEChMHV0lTZUtleTEiMCAGA1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNlZDEo +MCYGA1UEAxMfT0lTVEUgV0lTZUtleSBHbG9iYWwgUm9vdCBHQyBDQTAeFw0xNzA1MDkwOTQ4MzRa +Fw00MjA1MDkwOTU4MzNaMG0xCzAJBgNVBAYTAkNIMRAwDgYDVQQKEwdXSVNlS2V5MSIwIAYDVQQL +ExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5IEdsb2Jh +bCBSb290IEdDIENBMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAETOlQwMYPchi82PG6s4nieUqjFqdr +VCTbUf/q9Akkwwsin8tqJ4KBDdLArzHkdIJuyiXZjHWd8dvQmqJLIX4Wp2OQ0jnUsYd4XxiWD1Ab +NTcPasbc2RNNpI6QN+a9WzGRo1QwUjAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAd +BgNVHQ4EFgQUSIcUrOPDnpBgOtfKie7TrYy0UGYwEAYJKwYBBAGCNxUBBAMCAQAwCgYIKoZIzj0E +AwMDaAAwZQIwJsdpW9zV57LnyAyMjMPdeYwbY9XJUpROTYJKcx6ygISpJcBMWm1JKWB4E+J+SOtk +AjEA2zQgMgj/mkkCtojeFK9dbJlxjRo/i9fgojaGHAeCOnZT/cKi7e97sIBPWA9LUzm9 +-----END CERTIFICATE----- + +GTS Root R1 +=========== +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQbkepxUtHDA3sM9CJuRz04TANBgkqhkiG9w0BAQwFADBHMQswCQYDVQQG +EwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJv +b3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAG +A1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx +9vaMf/vo27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vXmX7wCl7r +aKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7zUjwTcLCeoiKu7rPWRnW +r4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0PfyblqAj+lug8aJRT7oM6iCsVlgmy4HqM +LnXWnOunVmSPlk9orj2XwoSPwLxAwAtcvfaHszVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly +4cpk9+aCEI3oncKKiPo4Zor8Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr +06zqkUspzBmkMiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOORc92 +wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYWk70paDPvOmbsB4om +3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+DVrNVjzRlwW5y0vtOUucxD/SVRNu +JLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgFlQIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYD +VR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEM +BQADggIBADiWCu49tJYeX++dnAsznyvgyv3SjgofQXSlfKqE1OXyHuY3UjKcC9FhHb8owbZEKTV1 +d5iyfNm9dKyKaOOpMQkpAWBz40d8U6iQSifvS9efk+eCNs6aaAyC58/UEBZvXw6ZXPYfcX3v73sv +fuo21pdwCxXu11xWajOl40k4DLh9+42FpLFZXvRq4d2h9mREruZRgyFmxhE+885H7pwoHyXa/6xm +ld01D1zvICxi/ZG6qcz8WpyTgYMpl0p8WnK0OdC3d8t5/Wk6kjftbjhlRn7pYL15iJdfOBL07q9b +gsiG1eGZbYwE8na6SfZu6W0eX6DvJ4J2QPim01hcDyxC2kLGe4g0x8HYRZvBPsVhHdljUEn2NIVq +4BjFbkerQUIpm/ZgDdIx02OYI5NaAIFItO/Nis3Jz5nu2Z6qNuFoS3FJFDYoOj0dzpqPJeaAcWEr +tXvM+SUWgeExX6GjfhaknBZqlxi9dnKlC54dNuYvoS++cJEPqOba+MSSQGwlfnuzCdyyF62ARPBo +pY+Udf90WuioAnwMCeKpSwughQtiue+hMZL77/ZRBIls6Kl0obsXs7X9SQ98POyDGCBDTtWTurQ0 +sR8WNh8M5mQ5Fkzc4P4dyKliPUDqysU0ArSuiYgzNdwsE3PYJ/HQcu51OyLemGhmW/HGY0dVHLql +CFF1pkgl +-----END CERTIFICATE----- + +GTS Root R2 +=========== +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQbkepxlqz5yDFMJo/aFLybzANBgkqhkiG9w0BAQwFADBHMQswCQYDVQQG +EwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJv +b3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAG +A1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTuk +k3LvCvptnfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3KgGjSY6Dlo +7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9BuXvAuMC6C/Pq8tBcKSOWI +m8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOdre7kRXuJVfeKH2JShBKzwkCX44ofR5Gm +dFrS+LFjKBC4swm4VndAoiaYecb+3yXuPuWgf9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbu +ak7MkogwTZq9TwtImoS1mKPV+3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscsz +cTJGr61K8YzodDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqjx5RW +Ir9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsRnTKaG73Vululycsl +aVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0kzCqgc7dGtxRcw1PcOnlthYhGXmy +5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9OktwIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYD +VR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEM +BQADggIBALZp8KZ3/p7uC4Gt4cCpx/k1HUCCq+YEtN/L9x0Pg/B+E02NjO7jMyLDOfxA325BS0JT +vhaI8dI4XsRomRyYUpOM52jtG2pzegVATX9lO9ZY8c6DR2Dj/5epnGB3GFW1fgiTz9D2PGcDFWEJ ++YF59exTpJ/JjwGLc8R3dtyDovUMSRqodt6Sm2T4syzFJ9MHwAiApJiS4wGWAqoC7o87xdFtCjMw +c3i5T1QWvwsHoaRc5svJXISPD+AVdyx+Jn7axEvbpxZ3B7DNdehyQtaVhJ2Gg/LkkM0JR9SLA3Da +WsYDQvTtN6LwG1BUSw7YhN4ZKJmBR64JGz9I0cNv4rBgF/XuIwKl2gBbbZCr7qLpGzvpx0QnRY5r +n/WkhLx3+WuXrD5RRaIRpsyF7gpo8j5QOHokYh4XIDdtak23CZvJ/KRY9bb7nE4Yu5UC56Gtmwfu +Nmsk0jmGwZODUNKBRqhfYlcsu2xkiAhu7xNUX90txGdj08+JN7+dIPT7eoOboB6BAFDC5AwiWVIQ +7UNWhwD4FFKnHYuTjKJNRn8nxnGbJN7k2oaLDX5rIMHAnuFl2GqjpuiFizoHCBy69Y9Vmhh1fuXs +gWbRIXOhNUQLgD1bnF5vKheW0YMjiGZt5obicDIvUiLnyOd/xCxgXS/Dr55FBcOEArf9LAhST4Ld +o/DUhgkC +-----END CERTIFICATE----- + +GTS Root R3 +=========== +-----BEGIN CERTIFICATE----- +MIICDDCCAZGgAwIBAgIQbkepx2ypcyRAiQ8DVd2NHTAKBggqhkjOPQQDAzBHMQswCQYDVQQGEwJV +UzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3Qg +UjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UE +ChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcq +hkjOPQIBBgUrgQQAIgNiAAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUU +Rout736GjOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2ADDL24Cej +QjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTB8Sa6oC2uhYHP +0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEAgFukfCPAlaUs3L6JbyO5o91lAFJekazInXJ0 +glMLfalAvWhgxeG4VDvBNhcl2MG9AjEAnjWSdIUlUfUk7GRSJFClH9voy8l27OyCbvWFGFPouOOa +KaqW04MjyaR7YbPMAuhd +-----END CERTIFICATE----- + +GTS Root R4 +=========== +-----BEGIN CERTIFICATE----- +MIICCjCCAZGgAwIBAgIQbkepyIuUtui7OyrYorLBmTAKBggqhkjOPQQDAzBHMQswCQYDVQQGEwJV +UzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3Qg +UjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UE +ChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcq +hkjOPQIBBgUrgQQAIgNiAATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa +6zzuhXyiQHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/lxKvRHYqj +QjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBSATNbrdP9JNqPV +2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNnADBkAjBqUFJ0CMRw3J5QdCHojXohw0+WbhXRIjVhLfoI +N+4Zba3bssx9BzT1YBkstTTZbyACMANxsbqjYAuG7ZoIapVon+Kz4ZNkfF6Tpt95LY2F45TPI11x +zPKwTdb+mciUqXWi4w== +-----END CERTIFICATE----- + +UCA Global G2 Root +================== +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIQXd+x2lqj7V2+WmUgZQOQ7zANBgkqhkiG9w0BAQsFADA9MQswCQYDVQQG +EwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxGzAZBgNVBAMMElVDQSBHbG9iYWwgRzIgUm9vdDAeFw0x +NjAzMTEwMDAwMDBaFw00MDEyMzEwMDAwMDBaMD0xCzAJBgNVBAYTAkNOMREwDwYDVQQKDAhVbmlU +cnVzdDEbMBkGA1UEAwwSVUNBIEdsb2JhbCBHMiBSb290MIICIjANBgkqhkiG9w0BAQEFAAOCAg8A +MIICCgKCAgEAxeYrb3zvJgUno4Ek2m/LAfmZmqkywiKHYUGRO8vDaBsGxUypK8FnFyIdK+35KYmT +oni9kmugow2ifsqTs6bRjDXVdfkX9s9FxeV67HeToI8jrg4aA3++1NDtLnurRiNb/yzmVHqUwCoV +8MmNsHo7JOHXaOIxPAYzRrZUEaalLyJUKlgNAQLx+hVRZ2zA+te2G3/RVogvGjqNO7uCEeBHANBS +h6v7hn4PJGtAnTRnvI3HLYZveT6OqTwXS3+wmeOwcWDcC/Vkw85DvG1xudLeJ1uK6NjGruFZfc8o +LTW4lVYa8bJYS7cSN8h8s+1LgOGN+jIjtm+3SJUIsUROhYw6AlQgL9+/V087OpAh18EmNVQg7Mc/ +R+zvWr9LesGtOxdQXGLYD0tK3Cv6brxzks3sx1DoQZbXqX5t2Okdj4q1uViSukqSKwxW/YDrCPBe +KW4bHAyvj5OJrdu9o54hyokZ7N+1wxrrFv54NkzWbtA+FxyQF2smuvt6L78RHBgOLXMDj6DlNaBa +4kx1HXHhOThTeEDMg5PXCp6dW4+K5OXgSORIskfNTip1KnvyIvbJvgmRlld6iIis7nCs+dwp4wwc +OxJORNanTrAmyPPZGpeRaOrvjUYG0lZFWJo8DA+DuAUlwznPO6Q0ibd5Ei9Hxeepl2n8pndntd97 +8XplFeRhVmUCAwEAAaNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0O +BBYEFIHEjMz15DD/pQwIX4wVZyF0Ad/fMA0GCSqGSIb3DQEBCwUAA4ICAQATZSL1jiutROTL/7lo +5sOASD0Ee/ojL3rtNtqyzm325p7lX1iPyzcyochltq44PTUbPrw7tgTQvPlJ9Zv3hcU2tsu8+Mg5 +1eRfB70VVJd0ysrtT7q6ZHafgbiERUlMjW+i67HM0cOU2kTC5uLqGOiiHycFutfl1qnN3e92mI0A +Ds0b+gO3joBYDic/UvuUospeZcnWhNq5NXHzJsBPd+aBJ9J3O5oUb3n09tDh05S60FdRvScFDcH9 +yBIw7m+NESsIndTUv4BFFJqIRNow6rSn4+7vW4LVPtateJLbXDzz2K36uGt/xDYotgIVilQsnLAX +c47QN6MUPJiVAAwpBVueSUmxX8fjy88nZY41F7dXyDDZQVu5FLbowg+UMaeUmMxq67XhJ/UQqAHo +jhJi6IjMtX9Gl8CbEGY4GjZGXyJoPd/JxhMnq1MGrKI8hgZlb7F+sSlEmqO6SWkoaY/X5V+tBIZk +bxqgDMUIYs6Ao9Dz7GjevjPHF1t/gMRMTLGmhIrDO7gJzRSBuhjjVFc2/tsvfEehOjPI+Vg7RE+x +ygKJBJYoaMVLuCaJu9YzL1DV/pqJuhgyklTGW+Cd+V7lDSKb9triyCGyYiGqhkCyLmTTX8jjfhFn +RR8F/uOi77Oos/N9j/gMHyIfLXC0uAE0djAA5SN4p1bXUB+K+wb1whnw0A== +-----END CERTIFICATE----- + +UCA Extended Validation Root +============================ +-----BEGIN CERTIFICATE----- +MIIFWjCCA0KgAwIBAgIQT9Irj/VkyDOeTzRYZiNwYDANBgkqhkiG9w0BAQsFADBHMQswCQYDVQQG +EwJDTjERMA8GA1UECgwIVW5pVHJ1c3QxJTAjBgNVBAMMHFVDQSBFeHRlbmRlZCBWYWxpZGF0aW9u +IFJvb3QwHhcNMTUwMzEzMDAwMDAwWhcNMzgxMjMxMDAwMDAwWjBHMQswCQYDVQQGEwJDTjERMA8G +A1UECgwIVW5pVHJ1c3QxJTAjBgNVBAMMHFVDQSBFeHRlbmRlZCBWYWxpZGF0aW9uIFJvb3QwggIi +MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCpCQcoEwKwmeBkqh5DFnpzsZGgdT6o+uM4AHrs +iWogD4vFsJszA1qGxliG1cGFu0/GnEBNyr7uaZa4rYEwmnySBesFK5pI0Lh2PpbIILvSsPGP2KxF +Rv+qZ2C0d35qHzwaUnoEPQc8hQ2E0B92CvdqFN9y4zR8V05WAT558aopO2z6+I9tTcg1367r3CTu +eUWnhbYFiN6IXSV8l2RnCdm/WhUFhvMJHuxYMjMR83dksHYf5BA1FxvyDrFspCqjc/wJHx4yGVMR +59mzLC52LqGj3n5qiAno8geK+LLNEOfic0CTuwjRP+H8C5SzJe98ptfRr5//lpr1kXuYC3fUfugH +0mK1lTnj8/FtDw5lhIpjVMWAtuCeS31HJqcBCF3RiJ7XwzJE+oJKCmhUfzhTA8ykADNkUVkLo4KR +el7sFsLzKuZi2irbWWIQJUoqgQtHB0MGcIfS+pMRKXpITeuUx3BNr2fVUbGAIAEBtHoIppB/TuDv +B0GHr2qlXov7z1CymlSvw4m6WC31MJixNnI5fkkE/SmnTHnkBVfblLkWU41Gsx2VYVdWf6/wFlth +WG82UBEL2KwrlRYaDh8IzTY0ZRBiZtWAXxQgXy0MoHgKaNYs1+lvK9JKBZP8nm9rZ/+I8U6laUpS +NwXqxhaN0sSZ0YIrO7o1dfdRUVjzyAfd5LQDfwIDAQABo0IwQDAdBgNVHQ4EFgQU2XQ65DA9DfcS +3H5aBZ8eNJr34RQwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQEL +BQADggIBADaNl8xCFWQpN5smLNb7rhVpLGsaGvdftvkHTFnq88nIua7Mui563MD1sC3AO6+fcAUR +ap8lTwEpcOPlDOHqWnzcSbvBHiqB9RZLcpHIojG5qtr8nR/zXUACE/xOHAbKsxSQVBcZEhrxH9cM +aVr2cXj0lH2RC47skFSOvG+hTKv8dGT9cZr4QQehzZHkPJrgmzI5c6sq1WnIeJEmMX3ixzDx/BR4 +dxIOE/TdFpS/S2d7cFOFyrC78zhNLJA5wA3CXWvp4uXViI3WLL+rG761KIcSF3Ru/H38j9CHJrAb ++7lsq+KePRXBOy5nAliRn+/4Qh8st2j1da3Ptfb/EX3C8CSlrdP6oDyp+l3cpaDvRKS+1ujl5BOW +F3sGPjLtx7dCvHaj2GU4Kzg1USEODm8uNBNA4StnDG1KQTAYI1oyVZnJF+A83vbsea0rWBmirSwi +GpWOvpaQXUJXxPkUAzUrHC1RVwinOt4/5Mi0A3PCwSaAuwtCH60NryZy2sy+s6ODWA2CxR9GUeOc +GMyNm43sSet1UNWMKFnKdDTajAshqx7qG+XH/RU+wBeq+yNuJkbL+vmxcmtpzyKEC2IPrNkZAJSi +djzULZrtBJ4tBmIQN1IchXIbJ+XMxjHsN+xjWZsLHXbMfjKaiJUINlK73nZfdklJrX+9ZSCyycEr +dhh2n1ax +-----END CERTIFICATE----- + +Certigna Root CA +================ +-----BEGIN CERTIFICATE----- +MIIGWzCCBEOgAwIBAgIRAMrpG4nxVQMNo+ZBbcTjpuEwDQYJKoZIhvcNAQELBQAwWjELMAkGA1UE +BhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczEcMBoGA1UECwwTMDAwMiA0ODE0NjMwODEwMDAzNjEZ +MBcGA1UEAwwQQ2VydGlnbmEgUm9vdCBDQTAeFw0xMzEwMDEwODMyMjdaFw0zMzEwMDEwODMyMjda +MFoxCzAJBgNVBAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxHDAaBgNVBAsMEzAwMDIgNDgxNDYz +MDgxMDAwMzYxGTAXBgNVBAMMEENlcnRpZ25hIFJvb3QgQ0EwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQDNGDllGlmx6mQWDoyUJJV8g9PFOSbcDO8WV43X2KyjQn+Cyu3NW9sOty3tRQgX +stmzy9YXUnIo245Onoq2C/mehJpNdt4iKVzSs9IGPjA5qXSjklYcoW9MCiBtnyN6tMbaLOQdLNyz +KNAT8kxOAkmhVECe5uUFoC2EyP+YbNDrihqECB63aCPuI9Vwzm1RaRDuoXrC0SIxwoKF0vJVdlB8 +JXrJhFwLrN1CTivngqIkicuQstDuI7pmTLtipPlTWmR7fJj6o0ieD5Wupxj0auwuA0Wv8HT4Ks16 +XdG+RCYyKfHx9WzMfgIhC59vpD++nVPiz32pLHxYGpfhPTc3GGYo0kDFUYqMwy3OU4gkWGQwFsWq +4NYKpkDfePb1BHxpE4S80dGnBs8B92jAqFe7OmGtBIyT46388NtEbVncSVmurJqZNjBBe3YzIoej +wpKGbvlw7q6Hh5UbxHq9MfPU0uWZ/75I7HX1eBYdpnDBfzwboZL7z8g81sWTCo/1VTp2lc5ZmIoJ +lXcymoO6LAQ6l73UL77XbJuiyn1tJslV1c/DeVIICZkHJC1kJWumIWmbat10TWuXekG9qxf5kBdI +jzb5LdXF2+6qhUVB+s06RbFo5jZMm5BX7CO5hwjCxAnxl4YqKE3idMDaxIzb3+KhF1nOJFl0Mdp/ +/TBt2dzhauH8XwIDAQABo4IBGjCCARYwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYw +HQYDVR0OBBYEFBiHVuBud+4kNTxOc5of1uHieX4rMB8GA1UdIwQYMBaAFBiHVuBud+4kNTxOc5of +1uHieX4rMEQGA1UdIAQ9MDswOQYEVR0gADAxMC8GCCsGAQUFBwIBFiNodHRwczovL3d3d3cuY2Vy +dGlnbmEuZnIvYXV0b3JpdGVzLzBtBgNVHR8EZjBkMC+gLaArhilodHRwOi8vY3JsLmNlcnRpZ25h +LmZyL2NlcnRpZ25hcm9vdGNhLmNybDAxoC+gLYYraHR0cDovL2NybC5kaGlteW90aXMuY29tL2Nl +cnRpZ25hcm9vdGNhLmNybDANBgkqhkiG9w0BAQsFAAOCAgEAlLieT/DjlQgi581oQfccVdV8AOIt +OoldaDgvUSILSo3L6btdPrtcPbEo/uRTVRPPoZAbAh1fZkYJMyjhDSSXcNMQH+pkV5a7XdrnxIxP +TGRGHVyH41neQtGbqH6mid2PHMkwgu07nM3A6RngatgCdTer9zQoKJHyBApPNeNgJgH60BGM+RFq +7q89w1DTj18zeTyGqHNFkIwgtnJzFyO+B2XleJINugHA64wcZr+shncBlA2c5uk5jR+mUYyZDDl3 +4bSb+hxnV29qao6pK0xXeXpXIs/NX2NGjVxZOob4Mkdio2cNGJHc+6Zr9UhhcyNZjgKnvETq9Emd +8VRY+WCv2hikLyhF3HqgiIZd8zvn/yk1gPxkQ5Tm4xxvvq0OKmOZK8l+hfZx6AYDlf7ej0gcWtSS +6Cvu5zHbugRqh5jnxV/vfaci9wHYTfmJ0A6aBVmknpjZbyvKcL5kwlWj9Omvw5Ip3IgWJJk8jSaY +tlu3zM63Nwf9JtmYhST/WSMDmu2dnajkXjjO11INb9I/bbEFa0nOipFGc/T2L/Coc3cOZayhjWZS +aX5LaAzHHjcng6WMxwLkFM1JAbBzs/3GkDpv0mztO+7skb6iQ12LAEpmJURw3kAP+HwV96LOPNde +E4yBFxgX0b3xdxA61GU5wSesVywlVP+i2k+KYTlerj1KjL0= +-----END CERTIFICATE----- diff --git a/base/curl/curl.SMBuild b/base/curl/curl.SMBuild new file mode 100755 index 0000000..40d0d4e --- /dev/null +++ b/base/curl/curl.SMBuild @@ -0,0 +1,46 @@ +APP=curl +VERSION=7.77.0 +BUILD=1sml +HOMEPAGE='https://curl.se/' +DOWNLOAD='https://curl.se/download/curl-7.77.0.tar.xz' +DESC="Command line URL data transfer tool" +REQUIRES="zlib openssl brotli libssh2 libidn2 nghttp2 libunistring" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --with-libssh2 \ + --without-ca-bundle \ + --with-ca-path=/etc/ssl/certs \ + --with-openssl + + make + make install DESTDIR=$PKG + + ( cd docs/libcurl + make install-man3 DESTDIR=$PKG + cd opts + make install-man3 DESTDIR=$PKG + ) + + # We don't ship the related perl script (yet): + rm -f $PKG/share/man/man1/mk-ca-bundle.1 + + strip -g $PKG/lib/libcurl.a + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +aef92a0e3f8ce8491b258a9a1c4dcea3c07c29b139a1f68f08619caa0295cfde76335d2dfb9cdf434525daea7dd05d8acd22f203f5ccc7735bd317964ec1da76 curl-7.77.0.tar.xz +" diff --git a/base/cython/cython.SMBuild b/base/cython/cython.SMBuild new file mode 100755 index 0000000..986038f --- /dev/null +++ b/base/cython/cython.SMBuild @@ -0,0 +1,25 @@ +APP=cython +VERSION=0.29.21 +BUILD=1sml +HOMEPAGE="https://pypi.org/project/Cython" +REQUIRES="python3 python-setuptools" +DESC="C-Extensions for Python3" + +build() { + mkandenterbuilddir + rm -rf Cython-$VERSION + + tar xf $SRCDIR/Cython-$VERSION.tar.?z* + cd Cython-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + + cp COPYING.txt LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +6216e63996e83b887cdcee6cd912d42e7da853640336b9190f5115d687848a902ee5a8edd6bfaef645c066b89e17dcd80ca1387688eb80a527ec23a0a4636e8f Cython-0.29.21.tar.gz +" diff --git a/base/db/bdb-configure.patch b/base/db/bdb-configure.patch new file mode 100644 index 0000000..f1b2ee2 --- /dev/null +++ b/base/db/bdb-configure.patch @@ -0,0 +1,28 @@ +--- db-5.3.21.org/dist/configure 2012-09-29 19:57:08.668000002 +0000 ++++ db-5.3.21/dist/configure 2012-09-29 20:10:28.304000001 +0000 +@@ -21387,7 +21387,7 @@ + # x86_64/gcc: FreeBSD, NetBSD, BSD/OS, Linux + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ +- ++#include + int + main () + { +@@ -22458,7 +22458,7 @@ + if test "$db_cv_atomic" = no; then + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ +- ++#include + int + main () + { +@@ -23433,6 +23433,7 @@ + /* end confdefs.h. */ + + #include ++#include + int + main () + { diff --git a/base/db/db.SMBuild b/base/db/db.SMBuild new file mode 100755 index 0000000..9d5a0b9 --- /dev/null +++ b/base/db/db.SMBuild @@ -0,0 +1,55 @@ +APP=db +VERSION=6.2.23 +BUILD=1sml +HOMEPAGE='https://www.oracle.com/database/technologies/related/berkeleydb.html' +DOWNLOAD='http://download.oracle.com/berkeley-db/db-6.2.23.tar.gz' +DESC="Berkeley embedded database library" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + if [ "$ARCH" = "aarch64" ]; then + db_atomic=gcc-builtin + else + db_atomic=x86/gcc-assembly + fi + + patch -p1 < $SRCDIR/bdb-configure.patch + + cd build_unix + + CFLAGS="-D_GNU_SOURCE" \ + db_cv_clock_monotonic=yes \ + db_cv_build_sequence=yes \ + db_cv_mmap_extend=yes \ + db_cv_atomic="$db_atomic" \ + ../dist/configure \ + --prefix="" \ + --libdir=/lib \ + --sysconfdir=/etc \ + --enable-shared \ + --disable-static \ + --enable-dbm \ + --enable-cxx + + sed -i 's/^install_docs:/install_docs:\n\ttrue\ninstall_crap:/' Makefile + + make + make install DESTDIR=$PKG + + cd .. + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +beb17661a44a4bb3feb3e95d6670599087fe38dd604f3902f90bf0336dc1d823adc7f56be854a55caa995f1503681896842ecfcd3dd668e47370c624255bd4ee db-6.2.23.tar.lz +8a91a6ff079792bf36efc11302140eef857019ab8e66058e39ea8b9a81dc2b4837fe2941b380343cf74e219d800eba2a08194d5b76fb48afc9cf0a599f1bf919 bdb-configure.patch +" diff --git a/base/dcron/0002-README-var-spool-cron-crontabs-root.patch b/base/dcron/0002-README-var-spool-cron-crontabs-root.patch new file mode 100644 index 0000000..57b8966 --- /dev/null +++ b/base/dcron/0002-README-var-spool-cron-crontabs-root.patch @@ -0,0 +1,26 @@ +From 500f3d402a94c6950946515d76ebd72872a6d0e2 Mon Sep 17 00:00:00 2001 +From: Jim Pryor +Date: Sun, 1 May 2011 18:56:17 -0400 +Subject: [PATCH 2/9] README: /var/spool/cron/crontabs/root + +Signed-off-by: Jim Pryor +--- + README | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/README b/README +index de02958..e33b1aa 100644 +--- a/README ++++ b/README +@@ -115,7 +115,7 @@ are normally in /var/spool/cron/cronstamps. These directories normally have perm + + Here is the superuser's crontab, created using `sudo crontab -e`: + +- -rw------- 0 root root 513 Jan 6 18:58 /var/spool/cron/root ++ -rw------- 0 root root 513 Jan 6 18:58 /var/spool/cron/crontabs/root + + TESTING + ------- +-- +2.13.2 + diff --git a/base/dcron/0006-Fixed-a-bug-whereby-syncs-killed-all-waiting-jobs.patch b/base/dcron/0006-Fixed-a-bug-whereby-syncs-killed-all-waiting-jobs.patch new file mode 100644 index 0000000..090e2e5 --- /dev/null +++ b/base/dcron/0006-Fixed-a-bug-whereby-syncs-killed-all-waiting-jobs.patch @@ -0,0 +1,35 @@ +From 65d2649a7c8b72561eefcec239f97e7fd386114e Mon Sep 17 00:00:00 2001 +From: Corey Theiss +Date: Mon, 24 Mar 2014 16:25:31 -0400 +Subject: [PATCH 6/9] Fixed a bug whereby syncs killed all waiting jobs. + +--- + database.c | 11 ++++++++++- + 1 file changed, 10 insertions(+), 1 deletion(-) + +diff --git a/database.c b/database.c +index dd971ce..02c5c92 100644 +--- a/database.c ++++ b/database.c +@@ -1232,8 +1232,17 @@ CheckJobs(void) + } + } + } ++ nStillRunning += file->cf_Running; ++ } ++ /* For the purposes of this check, increase the "still running" counter if a file has lines that are waiting */ ++ if (file->cf_Running == 0) { ++ for (line = file->cf_LineBase; line; line = line->cl_Next) { ++ if (line->cl_Pid == -2) { ++ nStillRunning += 1; ++ break; ++ } ++ } + } +- nStillRunning += file->cf_Running; + } + return(nStillRunning); + } +-- +2.13.2 + diff --git a/base/dcron/0007-Update-main.c.patch b/base/dcron/0007-Update-main.c.patch new file mode 100644 index 0000000..d120f37 --- /dev/null +++ b/base/dcron/0007-Update-main.c.patch @@ -0,0 +1,27 @@ +From abf8c4bf53a84ef3de530519a3bbb6b599595f2c Mon Sep 17 00:00:00 2001 +From: robdewit +Date: Tue, 31 Mar 2015 14:24:15 +0200 +Subject: [PATCH 7/9] Update main.c + +Removed bug where cron.update is not picked up while jobs are still running. (We have long running cronjobs and experienced long overdue cron.update files) +--- + main.c | 3 ++- + 1 file changed, 2 insertions(+), 1 deletion(-) + +diff --git a/main.c b/main.c +index 595f07a..0eba280 100644 +--- a/main.c ++++ b/main.c +@@ -338,7 +338,8 @@ main(int ac, char **av) + SynchronizeDir(SCDir, "root", 0); + ReadTimestamps(NULL); + } +- } else { ++ } ++ if (rescan < 60) { + CheckUpdates(CDir, NULL, t1, t2); + CheckUpdates(SCDir, "root", t1, t2); + } +-- +2.13.2 + diff --git a/base/dcron/crontab.c.O_EXCL.diff b/base/dcron/crontab.c.O_EXCL.diff new file mode 100644 index 0000000..f705487 --- /dev/null +++ b/base/dcron/crontab.c.O_EXCL.diff @@ -0,0 +1,12 @@ +diff -Nur dcron-4.5.orig//crontab.c dcron-4.5/crontab.c +--- dcron-4.5.orig//crontab.c 2011-05-01 07:22:09.000000000 -0500 ++++ dcron-4.5/crontab.c 2011-08-22 16:26:46.778225447 -0500 +@@ -199,7 +199,7 @@ + * Read from repFd, write to fd for "$CDir/$USER.new" + */ + snprintf(path, sizeof(path), "%s.new", pas->pw_name); +- if ((fd = open(path, O_CREAT|O_TRUNC|O_EXCL|O_APPEND|O_WRONLY, 0600)) >= 0) { ++ if ((fd = open(path, O_CREAT|O_TRUNC|O_APPEND|O_WRONLY, 0600)) >= 0) { + while ((n = read(repFd, buf, sizeof(buf))) > 0) { + write(fd, buf, n); + } diff --git a/base/dcron/crontab.root b/base/dcron/crontab.root new file mode 100644 index 0000000..5b0ce8c --- /dev/null +++ b/base/dcron/crontab.root @@ -0,0 +1,22 @@ +# If you don't want the output of a cron job mailed to you, you have to direct +# any output to /dev/null. We'll do this here since these jobs should run +# properly on a newly installed system. If a script fails, run-parts will +# mail a notice to root. +# +# Run the hourly, daily, weekly, and monthly cron jobs. +# Jobs that need different timing may be entered into the crontab as before, +# but most really don't need greater granularity than this. If the exact +# times of the hourly, daily, weekly, and monthly cron jobs do not suit your +# needs, feel free to adjust them. +# +# Run hourly cron jobs at 47 minutes after the hour: +47 * * * * /usr/bin/run-parts /etc/cron.hourly 1> /dev/null +# +# Run daily cron jobs at 4:40 every day: +40 4 * * * /usr/bin/run-parts /etc/cron.daily 1> /dev/null +# +# Run weekly cron jobs at 4:30 on the first day of the week: +30 4 * * 0 /usr/bin/run-parts /etc/cron.weekly 1> /dev/null +# +# Run monthly cron jobs at 4:20 on the first day of the month: +20 4 1 * * /usr/bin/run-parts /etc/cron.monthly 1> /dev/null diff --git a/base/dcron/dcron.SMBuild b/base/dcron/dcron.SMBuild new file mode 100755 index 0000000..abd50ba --- /dev/null +++ b/base/dcron/dcron.SMBuild @@ -0,0 +1,52 @@ +APP=dcron +VERSION=4.5 +BUILD=1sml +HOMEPAGE='http://www.jimpryor.net/linux/dcron.html' +DOWNLOAD='http://www.jimpryor.net/linux/releases/dcron-4.5.tar.gz' +DESC="Dillons Cron daemon" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/0002-README-var-spool-cron-crontabs-root.patch + patch -p1 < $SRCDIR/0006-Fixed-a-bug-whereby-syncs-killed-all-waiting-jobs.patch + patch -p1 < $SRCDIR/0007-Update-main.c.patch + patch -p1 < $SRCDIR/crontab.c.O_EXCL.diff + + make PREFIX="" BINDIR=/bin SBINDIR=/bin CRONTAB_GROUP=root + + install -Dm 755 crond $PKG/bin/crond + install -Dm 4711 crontab $PKG/bin/crontab + install -Dm 755 $SRCDIR/run-parts $PKG/bin/run-parts + + install -Dm 644 crontab.1 $PKG/share/man/man1/crontab.1 + install -Dm 644 crond.8 $PKG/share/man/man8/crond.8 + install -Dm 644 $SRCDIR/run-parts.8 $PKG/share/man/man8/run-parts.8 + + # Create some other stuff we need + mkdir -p $PKG/etc/cron.{hourly,daily,weekly,monthly + install -dm 0751 $PKG/var/spool/cron + install -dm 750 $PKG/var/spool/cron/crontabs + install -dm 750 $PKG/var/spool/cron/cronstamps + install -Dm 600 $SRCDIR/crontab.root $PKG/var/spool/cron/crontabs/root.new + + # dcron will whine about "unable to scan this directory", so we'll create it + mkdir -p $PKG/etc/cron.d + + cp CHANGELOG README $PKGDOCS/ + + mkfinalpkg +} +SHA512SUMS=" +08521391d16ba5adf80278ec2a734319c26c48841fd94b119c0b27d744c2cfb3562b1a3630135a03d1c43b1668d49262713abb20ff5f7ecd397a2a19a2f6105a dcron-4.5.tar.gz +687ba63afc4bf6028a7a4f0debfcb8b8758aaacd1ddb317136d55dfae7c57c572d81edf340b4b36476280a38b71b740f23e9f56a02a95ebd0f0aacdcba735c59 0002-README-var-spool-cron-crontabs-root.patch +faf6ecee8f678298b1a8cd27f42f42e3e3396062d73ea4bfff14f930ae71e99613354d9ec234407936e19c05b1de9cec46fffbf6df9ef71d4294d8b32bdad74d 0006-Fixed-a-bug-whereby-syncs-killed-all-waiting-jobs.patch +534628dfaad83a0d746731b67756fff3dd6a5b305efb07e00e3a7acb6bac9138e7ee3cae22d1314ee3041b22b9dd3574c1342e26af39198d6d0685964318876d 0007-Update-main.c.patch +a56862ea0fc1aa2f5fa77c2d341c2e35bb5d2ac5d9942c3dee25662eac6c9078fdd293835ec471ece22b2add4ae21db596cb0d41fb765ee92fb9aa53a4252287 crontab.c.O_EXCL.diff +" diff --git a/base/dcron/doinst.sh b/base/dcron/doinst.sh new file mode 100644 index 0000000..b0ce1f1 --- /dev/null +++ b/base/dcron/doinst.sh @@ -0,0 +1,29 @@ +config() { + for infile in $1; do + NEW="$infile" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... + done +} + +preserve_perms() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + if [ -e $OLD ]; then + cp -a $OLD ${NEW}.incoming + cat $NEW > ${NEW}.incoming + mv ${NEW}.incoming $NEW + fi + config $NEW +} + +config var/spool/cron/crontabs/root.new +rm -f var/spool/cron/crontabs/root.new + diff --git a/base/dcron/run-parts b/base/dcron/run-parts new file mode 100644 index 0000000..65c778f --- /dev/null +++ b/base/dcron/run-parts @@ -0,0 +1,46 @@ +#!/bin/sh +# run-parts: Runs all the scripts found in a directory. + +# keep going when something fails +set +e + +if [ $# -lt 1 ]; then + echo "Usage: run-parts " + exit 1 +fi + +if [ ! -d $1 ]; then + echo "Not a directory: $1" + echo "Usage: run-parts " + exit 1 +fi + +# There are several types of files that we would like to +# ignore automatically, as they are likely to be backups +# of other scripts: +IGNORE_SUFFIXES="~ ^ , .bak .new .rpmsave .rpmorig .rpmnew .swp" + +# Main loop: +for SCRIPT in $1/* ; do + # If this is not a regular file, skip it: + if [ ! -f $SCRIPT ]; then + continue + fi + # Determine if this file should be skipped by suffix: + SKIP=false + for SUFFIX in $IGNORE_SUFFIXES ; do + if [ ! "$(basename $SCRIPT $SUFFIX)" = "$(basename $SCRIPT)" ]; then + SKIP=true + break + fi + done + if [ "$SKIP" = "true" ]; then + continue + fi + # If we've made it this far, then run the script if it's executable: + if [ -x $SCRIPT ]; then + $SCRIPT || echo "$SCRIPT failed." + fi +done + +exit 0 diff --git a/base/dcron/run-parts.8 b/base/dcron/run-parts.8 new file mode 100644 index 0000000..2d5e5f6 --- /dev/null +++ b/base/dcron/run-parts.8 @@ -0,0 +1,36 @@ +.\" -*- nroff -*- +.ds g \" empty +.ds G \" empty +.\" Like TP, but if specified indent is more than half +.\" the current line-length - indent, use the default indent. +.de Tp +.ie \\n(.$=0:((0\\$1)*2u>(\\n(.lu-\\n(.iu)) .TP +.el .TP "\\$1" +.. +.TH RUN-PARTS 8 "14 Apr 2002" "Slackware Version 8.1.0 +.SH NAME +run-parts \- run scripts found in a directory +.SH SYNOPSIS +.B run-parts +.LP +.SH DESCRIPTION +.B run-parts +is a utility that will run scripts that are found in a directory. For example, +it might be useful to create an /etc/cron.daily directory and put scripts in +there for daily cron jobs. Then +.B run-parts +can be called once a day from root's crontab to run all the scripts found in +/etc/cron.daily: + +40 4 * * * run-parts /etc/cron.daily + +.B run-parts +automatically skips files with certain suffixes that are generally associated +with backup or extra files. Any file that ends in one of these will be silently +ignored: ~ ^ , .bak .new .rpmsave .rpmorig .rpmnew .swp +.SH AUTHOR +Patrick J. Volkerding , with ideas borrowed from the +Red Hat and Debian versions of this utility. +.SH "SEE ALSO" +.BR crond(8), +.BR crontab(8). diff --git a/base/desktop-file-utils/desktop-file-utils.SMBuild b/base/desktop-file-utils/desktop-file-utils.SMBuild new file mode 100755 index 0000000..af94c22 --- /dev/null +++ b/base/desktop-file-utils/desktop-file-utils.SMBuild @@ -0,0 +1,34 @@ +APP=desktop-file-utils +VERSION=0.24 +BUILD=1sml +HOMEPAGE='https://www.freedesktop.org/wiki/Software/desktop-file-utils/' +DESC="Utilities for manipulating desktop files" +REQUIRES="glib pcre" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Thank you slackware + patch -p1 < $SRCDIR/desktop-file-utils.quiet.warnings.diff + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +cd662fe5d77b5feb6c1063e69a9534b4bba23a32ed5d6ff8685b71d6f26114e4374bae184407c5e407cbaaf4e87812f4c9e71dff76dbe774c23bff6ebf7983f3 desktop-file-utils-0.24.tar.lz +f8371a36c4cda77797e6f1b4463dcf1c88d9200b65aa651b37cf902db9f266b7201da370014b181f9369913572aef816bdb9184ce88172a1fd45fc99886cca55 desktop-file-utils.quiet.warnings.diff +" diff --git a/base/desktop-file-utils/desktop-file-utils.quiet.warnings.diff b/base/desktop-file-utils/desktop-file-utils.quiet.warnings.diff new file mode 100644 index 0000000..8e1f17f --- /dev/null +++ b/base/desktop-file-utils/desktop-file-utils.quiet.warnings.diff @@ -0,0 +1,18 @@ +--- ./src/update-desktop-database.c.orig 2010-03-09 20:33:41.000000000 -0600 ++++ ./src/update-desktop-database.c 2010-05-11 09:00:08.000000000 -0500 +@@ -135,15 +135,9 @@ + case MU_VALID: + break; + case MU_DISCOURAGED: +- udd_print (_("Warning in file \"%s\": usage of MIME type \"%s\" is " +- "discouraged (%s)\n"), +- desktop_file, mime_types[i], valid_error); + g_free (valid_error); + break; + case MU_INVALID: +- udd_print (_("Error in file \"%s\": \"%s\" is an invalid MIME type " +- "(%s)\n"), +- desktop_file, mime_types[i], valid_error); + g_free (valid_error); + /* not a break: we continue to the next mime type */ + continue; diff --git a/base/desktop-file-utils/doinst.sh b/base/desktop-file-utils/doinst.sh new file mode 100644 index 0000000..0174f83 --- /dev/null +++ b/base/desktop-file-utils/doinst.sh @@ -0,0 +1,4 @@ +if [ -x /bin/update-desktop-database ]; then + /bin/update-desktop-database share/applications >/dev/null 2>&1 +fi + diff --git a/base/dialog/dialog.SMBuild b/base/dialog/dialog.SMBuild new file mode 100755 index 0000000..0435112 --- /dev/null +++ b/base/dialog/dialog.SMBuild @@ -0,0 +1,34 @@ +APP=dialog +VERSION=1.3 +BUILD=1sml +HOMEPAGE='https://invisible-island.net/archives/dialog/' +DESC="display dialog boxes from shell scripts" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION-20170509.tar.?z + cd "$APP-$VERSION-20170509" + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sysconfdir=/etc \ + --disable-nls \ + --with-shared \ + --with-x + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0cfdef91212009306101a91745183639a103d5b07d33d47601197fd95431ed9187eb38b0cd75537a91d98d35c9be0c92655e33ec4670d496bf9f6cc17701ee87 dialog-1.3-20170509.tar.lz +" diff --git a/base/diffutils/diffutils.SMBuild b/base/diffutils/diffutils.SMBuild new file mode 100755 index 0000000..00f09eb --- /dev/null +++ b/base/diffutils/diffutils.SMBuild @@ -0,0 +1,38 @@ +APP=diffutils +VERSION=3.6 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/diffutils/' +DOWNLOAD='https://ftp.gnu.org/gnu/diffutils/diffutils-3.6.tar.xz' +DESC="Utilities to find and apply differences between files" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + for i in tests gnulib-tests doc ; do + printf "all:\n\ttrue\n\ninstall:\n\ttrue\n\n" > "$i"/Makefile.in + done + + CPPFLAGS="$($SRCDIR/gnulibfix lib)" \ + LDFLAGS="-static" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +356f3cdbfd575bf7ca692b2ab36aa9f6dde6d52c560823a6f76ef81c147715f7db499eb689f9ee125a50efe62ca61c0e8600714f2022013723cbc9d6cbe78d5b diffutils-3.6.tar.lz +" diff --git a/base/diffutils/gnulibfix b/base/diffutils/gnulibfix new file mode 100755 index 0000000..72b30fa --- /dev/null +++ b/base/diffutils/gnulibfix @@ -0,0 +1,185 @@ +#!/bin/sh +empty_file() { + rm -f "$1" + touch "$1" +} + +dir="$1" +# fix files breaking the build entirely +for i in freadahead.c fseterr.c ; do empty_file "$dir"/$i ; done +echo "void close_stdin(void) {}" > "$dir"/closein.c + +# fix stuff trying to reimplement libc +culprits=`cat << EOF +accept4 +acosl +alloca +alphasort +asinl +asprintf +atanl +atexit +atoll +bcopy +btowc +chown +closedir +cosl +dirfd +dprintf +dup2 +dup3 +_Exit +expl +fchdir +fchown-stub +fdatasync +fdopendir +ffs +flock +fnmatch +forkpty +fpending +fprintf +freeaddrinfo +fsync +ftell +ftruncate +futimens +gai_strerror +getaddrinfo +getdelim +getdtablesize +getgroups +gethostname +getline +getlogin +getlogin_r +getnameinfo +getpagesize +getpass +getsubopt +gettimeofday +getusershell +gmtime_r +grantpt +imaxabs +imaxdiv +inet_ntop +inet_pton +isblank +iswblank +lchmod +lchown +ldexp +ldexpl +link +linkat +logl +mbrlen +mbrtowc +mbsinit +memmove +mempcpy +mkdtemp +mkfifo +mkfifoat +mknod +mknodat +mkstemp +mktime +nanosleep +nl_langinfo +open +openat +opendir +openpty +pclose +perror +pipe +pipe2 +poll +popen +pread +pselect +ptsname +pwrite +raise +readdir +readlink +renameat +rewinddir +setenv +sigaction +sigaddset +sigdelset +sigemptyset +sigfillset +sigismember +sigpending +sigprocmask +sinl +snprintf +spawnattr_destroy +spawnattr_getdefault +spawnattr_getflags +spawnattr_getpgroup +spawnattr_getsigmask +spawnattr_init +spawnattr_setdefault.c +spawnattr_setflags +spawnattr_setpgroup +spawnattr_setsigmask +spawn_faction_addclose +spawn_faction_adddup2 +spawn_faction_addopen +spawn_faction_destroy +spawn_faction_init +spawn_factions_addopen +spawn_factions_destroy +spawn_factions_init +sprintf +sqrtl +stdio-read +stdio-write +strcasecmp +strcasestr +strchrnul +strcspn +strncasecmp +strndup +strnlen +strpbrk +strsep +strsignal +strstr +strtod +strtoimax +strtol +symlink +symlinkat +tanl +tcgetsid +timegm +time_r +times +tmpfile +uname +unlockpt +unsetenv +usleep +vasprintf +vdprintf +waitpid +wcrtomb +wctob +EOF +` +#fixme check fsusage +flags="-Drpl_tzset=tzset -Drpl_localtime=localtime -Dgnu_fnmatch=fnmatch \ + -Dposix_fnmatch=fnmatch -Drpl_gmtime=gmtime" +for i in $culprits ; do + empty_file "$dir"/$i.c + flags="$flags -Drpl_$i=$i" +done +printf "%s\n" "$flags" diff --git a/base/dmidecode/dmidecode.SMBuild b/base/dmidecode/dmidecode.SMBuild new file mode 100755 index 0000000..12fd492 --- /dev/null +++ b/base/dmidecode/dmidecode.SMBuild @@ -0,0 +1,28 @@ +APP=dmidecode +VERSION=3.2 +BUILD=1sml +HOMEPAGE='https://www.nongnu.org/dmidecode/' +DOWNLOAD='http://download.savannah.gnu.org/releases/dmidecode/dmidecode-3.2.tar.xz' +DESC="DMI table decoder" +REQUIRES="musl" + +build() { + compileonlyfor x86_64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make V=s + make install DESTDIR=$PKG prefix="" mandir="/share/man" sbindir="/bin" + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fb38256f4e577d015f7696e5bfe9bf023ce2448ba213deb40d825955da87728cef6d63050af0fe4f1f95f2b9a109629535c183f339ecb9a3ca956b6c3e2f574e dmidecode-3.2.tar.lz +" diff --git a/base/docbook/docbook.SMBuild b/base/docbook/docbook.SMBuild new file mode 100755 index 0000000..2518bd3 --- /dev/null +++ b/base/docbook/docbook.SMBuild @@ -0,0 +1,197 @@ +APP=docbook +VERSION=1.0 +BUILD=1sml +HOMEPAGE='https://docbook.org' +DOWNLOAD='' +DOCBOOKV="4.5" +XSLV="1.79.2" +DESC="DocBook DTD for XML" +REQUIRES="libxslt libxml2" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + +tar xf $SRCDIR/docbook-xml-$DOCBOOKV.tar.?z* +cd docbook-xml-$DOCBOOKV + fixbuilddirpermissions + +XML_CATALOG="$PKG/etc/xml/catalog" +XML_DOCBOOK="$PKG/etc/xml/docbook" + +cd docbook-4.5 + +install -d -m755 "$PKG"/share/xml/docbook/xml-dtd-4.5 +install -d -m755 "$PKG"/etc/xml +#rm -rf /etc/xml + +chown -R root:root . +cp -v -af docbook.cat *.dtd ent/ *.mod \ + "$PKG"/share/xml/docbook/xml-dtd-"$DOCBOOKV" + +# Create the docbook and catalog +xmlcatalog --noout --create "$XML_DOCBOOK" +xmlcatalog --noout --create "$XML_CATALOG" + +xmlcatalog --noout --add "public" \ + "-//OASIS//DTD DocBook XML V"$DOCBOOKV"//EN" \ + "http://www.oasis-open.org/docbook/xml/"$DOCBOOKV"/docbookx.dtd" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//DTD DocBook XML CALS Table Model V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/calstblx.dtd" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//DTD XML Exchange Table Model 19990315//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/soextblx.dtd" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//ELEMENTS DocBook XML Information Pool V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/dbpoolx.mod" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//ELEMENTS DocBook XML Document Hierarchy V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/dbhierx.mod" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//ELEMENTS DocBook XML HTML Tables V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/htmltblx.mod" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//ENTITIES DocBook XML Notations V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/dbnotnx.mod" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//ENTITIES DocBook XML Character Entities V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/dbcentx.mod" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "public" \ + "-//OASIS//ENTITIES DocBook XML Additional General Entities V"$DOCBOOKV"//EN" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"/dbgenent.mod" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "rewriteSystem" \ + "http://www.oasis-open.org/docbook/xml/"$DOCBOOKV"" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"" \ + "$XML_DOCBOOK" +xmlcatalog --noout --add "rewriteURI" \ + "http://www.oasis-open.org/docbook/xml/"$DOCBOOKV"" \ + "file:///share/xml/docbook/xml-dtd-"$DOCBOOKV"" \ + "$XML_DOCBOOK" + + +xmlcatalog --noout --add "delegatePublic" \ + "-//OASIS//ENTITIES DocBook XML" \ + "file:///etc/xml/docbook" \ + "$XML_CATALOG" +xmlcatalog --noout --add "delegatePublic" \ + "-//OASIS//DTD DocBook XML" \ + "file:///etc/xml/docbook" \ + "$XML_CATALOG" +xmlcatalog --noout --add "delegateSystem" \ + "http://www.oasis-open.org/docbook/" \ + "file:///etc/xml/docbook" \ + "$XML_CATALOG" +xmlcatalog --noout --add "delegateURI" \ + "http://www.oasis-open.org/docbook/" \ + "file:///etc/xml/docbook" \ + "$XML_CATALOG" + + +# Prep the older versions too +for DTDDOCBOOKV in 4.1.2 4.2 4.3 4.4 +do + xmlcatalog --noout --add "public" \ + "-//OASIS//DTD DocBook XML V$DTDDOCBOOKV//EN" \ + "http://www.oasis-open.org/docbook/xml/$DTDDOCBOOKV/docbookx.dtd" \ + "$XML_DOCBOOK" + xmlcatalog --noout --add "rewriteSystem" \ + "http://www.oasis-open.org/docbook/xml/$DTDDOCBOOKV" \ + "file:///share/xml/docbook/xml-dtd-$DOCBOOKV" \ + "$XML_DOCBOOK" + xmlcatalog --noout --add "rewriteURI" \ + "http://www.oasis-open.org/docbook/xml/$DTDDOCBOOKV" \ + "file:///share/xml/docbook/xml-dtd-$DOCBOOKV" \ + "$XML_DOCBOOK" + xmlcatalog --noout --add "delegateSystem" \ + "http://www.oasis-open.org/docbook/xml/$DTDDOCBOOKV/" \ + "file:///etc/xml/docbook" \ + "$XML_CATALOG" + xmlcatalog --noout --add "delegateURI" \ + "http://www.oasis-open.org/docbook/xml/$DTDDOCBOOKV/" \ + "file:///etc/xml/docbook" \ + "$XML_CATALOG" +done + + +tar xf $SRCDIR/docbook-xsl-nons-$XSLV.tar.?z* +cd docbook-xsl-nons-$XSLV + fixbuilddirpermissions + + +patch -p1 < $SRCDIR/non-recursive-string-subst.patch + +install -v -m755 -d "$PKG"/share/xml/docbook/xsl-stylesheets-"$XSLV" + +cp -v -R VERSION common eclipse epub extensions fo highlighting html \ + htmlhelp images javahelp lib manpages params profiling \ + roundtrip slides template tests tools webhelp website \ + xhtml xhtml-1_1 \ + "$PKG/share/xml/docbook/xsl-stylesheets-$XSLV" && +( + cd "$PKG/share/xml/docbook/xsl-stylesheets-$XSLV" + ln -s VERSION VERSION.xsl +) + +install -v -m644 -D README \ + "$PKG"/share/doc/docbook-xsl-"$XSLV"/README.txt +install -v -m644 RELEASE-NOTES* NEWS* \ + "$PKG"/share/doc/docbook-xsl-"$XSLV" + +xmlcatalog --noout --add "rewriteSystem" \ + "http://cdn.docbook.org/release/xsl-nons/"$XSLV"" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" && + +xmlcatalog --noout --add "rewriteURI" \ + "http://cdn.docbook.org/release/xsl-nons/"$XSLV"" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" + +xmlcatalog --noout --add "rewriteSystem" \ + "http://cdn.docbook.org/release/xsl-nons/current" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" && + +xmlcatalog --noout --add "rewriteURI" \ + "http://cdn.docbook.org/release/xsl-nons/current" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" + +xmlcatalog --noout --add "rewriteSystem" \ + "http://docbook.sourceforge.net/release/xsl/"$XSLV"" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" && + +xmlcatalog --noout --add "rewriteURI" \ + "http://docbook.sourceforge.net/release/xsl/"$XSLV"" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" + +xmlcatalog --noout --add "rewriteSystem" \ + "http://docbook.sourceforge.net/release/xsl/current" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" && + +xmlcatalog --noout --add "rewriteURI" \ + "http://docbook.sourceforge.net/release/xsl/current" \ + "/share/xml/docbook/xsl-stylesheets-$XSLV" \ + "$XML_CATALOG" + + mkfinalpkg +} + +SHA512SUMS=" +2408f9444d84490d31914dfe03ed53199012b9ac42f4562165c099b1e5af1a6a99037f16521b829f5833d5fc2d340cf590f48116aa856e6913f2b880d0ea56d3 docbook-xml-4.5.tar.lz +cfa54a7c499d9d964970cfdde065307a113965bac527445b87c52c32b361ca1a7e33b2611a81166ca75c223d6fed84fdec468d4deb6a6097b970dedfa110bf47 docbook-xsl-nons-1.79.2.tar.lz +3199de6b5a61ed25defa50a55fa3d138b60e1f5e4c2e3b9a14e169099189794adc3ac079fa3f62debc682f4840c6dadff40f8bd5a07fdba34fe1016ce885b9e2 non-recursive-string-subst.patch +" diff --git a/base/docbook/non-recursive-string-subst.patch b/base/docbook/non-recursive-string-subst.patch new file mode 100644 index 0000000..3a5fe80 --- /dev/null +++ b/base/docbook/non-recursive-string-subst.patch @@ -0,0 +1,33 @@ +Description: use EXSLT "replace" function when available + A recursive implementation of string.subst is problematic, + long strings with many matches will cause stack overflows. +Author: Peter De Wachter +Bug-Debian: https://bugs.debian.org/750593 + +diff --git a/lib/lib.xsl b/lib/lib.xsl +index e65776a..bc45cd8 100644 +--- a/lib/lib.xsl ++++ b/lib/lib.xsl +@@ -6,7 +6,11 @@ + + This module implements DTD-independent functions + +- ******************************************************************** --> ++ ******************************************************************** --> ++ + + + +@@ -52,6 +56,9 @@ + + + ++ ++ ++ + + + diff --git a/base/dosfstools/dosfstools.SMBuild b/base/dosfstools/dosfstools.SMBuild new file mode 100755 index 0000000..84ea16f --- /dev/null +++ b/base/dosfstools/dosfstools.SMBuild @@ -0,0 +1,34 @@ +APP=dosfstools +VERSION=4.1 +BUILD=1sml +HOMEPAGE='https://github.com/dosfstools/dosfstools' +DOWNLOAD='https://github.com/dosfstools/dosfstools/releases/download/v4.1/dosfstools-4.1.tar.gz' +DESC="Tools for working with FAT filesystems" +REQUIRES="eudev" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + LDFLAGS="-static" \ + ./configure \ + --prefix="" \ + --sbindir=/bin \ + --sysconfdir=/etc \ + --enable-compat-symlinks + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d70ee344b35e25ab7bec3feaafd412f4ccc0c744fb0275c4c97e70e575afb3dcfe70e7c714a7b9a026f180ac2b67bb492b011150309e7eb9d6acc473d1857652 dosfstools-4.1.tar.lz +" diff --git a/base/e2fsprogs/e2fsprogs.SMBuild b/base/e2fsprogs/e2fsprogs.SMBuild new file mode 100755 index 0000000..925a6ca --- /dev/null +++ b/base/e2fsprogs/e2fsprogs.SMBuild @@ -0,0 +1,44 @@ +APP=e2fsprogs +VERSION=1.45.3 +BUILD=2sml +HOMEPAGE='http://e2fsprogs.sourceforge.net/' +DOWNLOAD='https://mirrors.edge.kernel.org/pub/linux/kernel/people/tytso/e2fsprogs/v1.45.3/e2fsprogs-1.45.3.tar.xz' +DESC="Utilities for working with ext 2, 3 and 4 filesystems" +REQUIRES="util-linux" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + for i in misc/fsck.c misc/mke2fs.c e2fsck/unix.c ; do + sed -i 's@sbin@bin@g' $i + done + + ac_cv_path_mkdir="mkdir -p" \ + CFLAGS="$CFLAGS -D_GNU_SOURCE -D__uint64_t=u_int64_t -fPIC" \ + LDFLAGS="-L/lib -static" \ + ./configure \ + --prefix="" \ + --with-root-prefix="" \ + --sbindir=/bin \ + --disable-nls \ + --disable-libblkid \ + --disable-libuuid \ + --disable-uuidd + + make + make install DESTDIR=$PKG + make DESTDIR=$PKG install-libs + + cp NOTICE $PKGDOCS/LICENSE + + mkfinalpkg +} + +SHA512SUMS=" +aaa6e1ef3bce5935cdca853a91ac596f41a62b5f16f7cd944b3ad572fe5890fce9d08335a46c6fefebeab99ec32b1ef6d2df94e6b7afc19f19d244f000605103 e2fsprogs-1.45.3.tar.lz +" diff --git a/base/ed/ed.SMBuild b/base/ed/ed.SMBuild new file mode 100755 index 0000000..60ca4aa --- /dev/null +++ b/base/ed/ed.SMBuild @@ -0,0 +1,30 @@ +APP=ed +VERSION=1.14.2 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/ed' +DOWNLOAD='https://ftp.gnu.org/gnu/ed/ed-1.14.2.tar.lz' +DESC="Old-school POSIX-compliant text editor" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +653bcb89788b2d18c726336fb6f17678ac031fe6ea03a93ff248886a075c867ba5423d5471401e44cbdcce3b4cb766b621ca7b70d76881f5044ec3412767b11f ed-1.14.2.tar.lz +" diff --git a/base/enchant/enchant.SMBuild b/base/enchant/enchant.SMBuild new file mode 100755 index 0000000..4dc2362 --- /dev/null +++ b/base/enchant/enchant.SMBuild @@ -0,0 +1,39 @@ +APP=enchant +VERSION=2.2.8 +BUILD=1sml +HOMEPAGE='https://abiword.github.io/enchant/' +DOWNLOAD='https://github.com/AbiWord/enchant/releases/download/v2.2.8/enchant-2.2.8.tar.gz' +DESC="spell checking library" +REQUIRES="gcc-libs glib aspell hunspell" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + # Taken from arch linux's enchant PKGBUILD + sed -i -e 's/ -shared / -Wl,-O1,--as-needed\0/g' libtool + make + make install DESTDIR=$PKG + + cp COPYING.LIB $PKGDOCS/ + + cd $PKG + ( cd include ; ln -sfv enchant-2 enchant ) + ( cd bin ; ln -sfv enchant-2 enchant ) + ( cd lib ; ln -sfv libenchant-2.so libenchant.so ) + ( cd lib/pkgconfig ; ln -sfv enchant-2.pc enchant.pc ) + + mkfinalpkg +} + +SHA512SUMS=" +40bc7d5aa40f0460bd500ee1fbe3434ad7f5b99dc75be2dc428694b7ce2d97a4b172535f5f3010bdad77de21f98f155b774acefab8bb7a7f1872700ecf4ed48e enchant-2.2.8.tar.lz +" diff --git a/base/enet/enet.SMBuild b/base/enet/enet.SMBuild new file mode 100755 index 0000000..0e732f8 --- /dev/null +++ b/base/enet/enet.SMBuild @@ -0,0 +1,31 @@ +APP=enet +VERSION=1.3.15 +BUILD=1sml +HOMEPAGE='http://enet.bespin.org/' +DOWNLOAD='http://enet.bespin.org/download/enet-1.3.15.tar.gz' +REQUIRES="musl" +DESC="simple and robust network communication layer over UDP" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-static=no + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +41ce9bae1286e61cc2288d326c6571cce35be0fa5abf957c7a1386b785e4c6744b744792ac30c8318bfd11eae5aa4731430c973ffa6a09694bd0b0be8f8b4dae enet-1.3.15.tar.gz +" diff --git a/base/eudev/80-net-name-slot.rules b/base/eudev/80-net-name-slot.rules new file mode 100644 index 0000000..e69de29 diff --git a/base/eudev/eudev.SMBuild b/base/eudev/eudev.SMBuild new file mode 100755 index 0000000..c1720c5 --- /dev/null +++ b/base/eudev/eudev.SMBuild @@ -0,0 +1,40 @@ +APP=eudev +VERSION=3.2.9 +BUILD=1sml +HOMEPAGE='https://wiki.gentoo.org/wiki/Eudev' +DOWNLOAD='http://sources.buildroot.net/eudev/eudev-3.2.9.tar.gz' +DESC="Independent fork of udev dynamic device manager by Gentoo devs" +REQUIRES="util-linux" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sbindir=/bin \ + --sysconfdir=/etc \ + --disable-introspection + + make + make install DESTDIR=$PKG + + mkdir -p $PKG/etc/udev/rules.d + cp $SRCDIR/*.rules $PKG/etc/udev/rules.d/ + + mv $PKG/share/pkgconfig/* $PKG/lib/pkgconfig/ + rm -rf $PKG/share + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a239ca799e3b18bc058ab120dd8636e360ad9e579ea15d21718ac4eee7ad2a74720e83f66eb3dfaa22443f3ee8db64ef4e0d254dbcf98e2fbe37ecaec40075b1 eudev-3.2.9.tar.lz +" diff --git a/base/exfat-utils/exfat-utils.SMBuild b/base/exfat-utils/exfat-utils.SMBuild new file mode 100755 index 0000000..b0e2459 --- /dev/null +++ b/base/exfat-utils/exfat-utils.SMBuild @@ -0,0 +1,33 @@ +APP=exfat-utils +VERSION=1.3.0 +BUILD=1sml +HOMEPAGE='https://github.com/relan/exfat' +DOWNLOAD='https://github.com/relan/exfat/archive/refs/tags/v1.3.0.tar.gz' +DESC="Utilities to create and manipulate Microsoft exFAT filesystems" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="$CFLAGS -std=c99" \ + ./configure \ + --prefix="" \ + --sbindir=/bin \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e1c5b708f22e878d7521e3299866bba127145757e3620696ff11b18c8c7d4830522974e8ee4771234b70aa9718295d3433779cf34ca990e28ccc06cbf9325f7e exfat-utils-1.3.0.tar.gz +" diff --git a/base/exiv2/exiv2.SMBuild b/base/exiv2/exiv2.SMBuild new file mode 100755 index 0000000..f9f7c5e --- /dev/null +++ b/base/exiv2/exiv2.SMBuild @@ -0,0 +1,38 @@ +APP=exiv2 +VERSION=0.25 +BUILD=1sml +HOMEPAGE='https://exiv2.org/' +DOWNLOAD='https://exiv2.org/releases/exiv2-0.25.tar.gz' +DESC="C++ library and a utility to read and write Exif, IPTC and XMP image metadata" +REQUIRES="gcc-libs expat zlib curl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-shared=yes \ + --enable-static=no \ + --without-ssh \ + --enable-xmp \ + --enable-video \ + --enable-webready \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING* doc/{COPYING-XMPSDK,README-XMP} $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +eed430e3eb8faed9a2545ef77a45cc6de172697b1aff7b243f84b10066279a873418d66e7a821f758b42962f055670eec72d272aac388f512b61aefb77bf02c4 exiv2-0.25.tar.lz +" diff --git a/base/expat/expat.SMBuild b/base/expat/expat.SMBuild new file mode 100755 index 0000000..e95bcd2 --- /dev/null +++ b/base/expat/expat.SMBuild @@ -0,0 +1,31 @@ +APP=expat +VERSION=2.2.9 +BUILD=1sml +HOMEPAGE='https://libexpat.github.io/' +DOWNLOAD='https://github.com/libexpat/libexpat/releases/download/R_2_2_9/expat-2.2.9.tar.xz' +DESC="C library for parsing XML" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +85232a37d6b3b7aed0c16bbe30644c23faf80180d2e6c470fc60eb9e3da7fb4a315e9c97f02c5e8bbbd7e051a4e192d691763c228e388ece2ce96e1f4cb3588b expat-2.2.9.tar.lz +" diff --git a/base/faad2/faad2.SMBuild b/base/faad2/faad2.SMBuild new file mode 100755 index 0000000..66cb302 --- /dev/null +++ b/base/faad2/faad2.SMBuild @@ -0,0 +1,31 @@ +APP=faad2 +VERSION=2.9.2 +BUILD=1sml +HOMEPAGE='https://github.com/knik0/faad2' +DOWNLOAD='https://github.com/knik0/faad2/archive/refs/tags/2_9_2.tar.gz' +DESC="HE, LC, MAIN and LTP profile, MPEG2 and MPEG-4 AAC decoder" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +013af33c9c99bb93e1686312bd4497a9700ee0d6dd0eba26fde525456e9519896a61bb4762c0127e8d22a42be2eee97b78d659f312f6b32280e12a0d36fd2a5f faad2-2.9.2.tar.lz +" diff --git a/base/fdk-aac/fdk-aac.SMBuild b/base/fdk-aac/fdk-aac.SMBuild new file mode 100755 index 0000000..a69bd1b --- /dev/null +++ b/base/fdk-aac/fdk-aac.SMBuild @@ -0,0 +1,32 @@ +APP=fdk-aac +VERSION=0.1.6 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/opencore-amr/' +DOWNLOAD='https://sourceforge.net/projects/opencore-amr/files/fdk-aac/fdk-aac-0.1.6.tar.gz' +DESC="AAC audio encoding and decoding library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + cp NOTICE OWNERS $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bcd13ff7198346a7f19acc8e81d24e824f3604b5f96cc0caeacf64eedd3ac828ff78c4f4d4387b7db4e8dbdd475fb5f931ec8412bd465757711a648082e3e99c fdk-aac-0.1.6.tar.lz +" diff --git a/base/fftw/fftw.SMBuild b/base/fftw/fftw.SMBuild new file mode 100755 index 0000000..a23968c --- /dev/null +++ b/base/fftw/fftw.SMBuild @@ -0,0 +1,61 @@ +APP=fftw +VERSION=3.3.8 +BUILD=1sml +HOMEPAGE='http://www.fftw.org/' +DOWNLOAD='https://www.fftw.org/fftw-3.3.8.tar.gz' +DESC="Free collection of fast C routines for computing the Discrete Fourier Transform in one or more dimensions" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i 's@-mtune=native@$CFLAGS@g' configure + + # Default compile options + defconfopts() { + [ "$ARCH" = "aarch64" ] && \ + ADDCONFIGOPTS="--enable-openmp" + ./configure \ + --prefix="" \ + --enable-shared \ + --disable-static \ + --enable-threads \ + $ADDCONFIGOPTS \ + $LIBOPTIONS + } + + defmakeopts() { + make + make install DESTDIR=$PKG + make clean + unset LIBOPTIONS + } + + # Standard build + defconfopts + defmakeopts + + # Build with floating-point libs + LIBOPTIONS=--enable-float + defconfopts + defmakeopts + + # Build with double-precision libs + LIBOPTIONS=--enable-long-double + defconfopts + make + make install DESTDIR=$PKG + + cp COPY* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a272fd08bf852011dfe0add9f374bac8d1f52798961eb9789677177d3e2455a706e7f56ab5bb2428445c799edb72ad3851cefe298a38f226f400505cda967269 fftw-3.3.8.tar.lz +" diff --git a/base/file/doinst.sh b/base/file/doinst.sh new file mode 100644 index 0000000..d9c7f04 --- /dev/null +++ b/base/file/doinst.sh @@ -0,0 +1,5 @@ +# Compile /etc/file/magic.mgc: +chroot . /usr/bin/file --compile 1> /dev/null 2> /dev/null +if [ -r magic.mgc ]; then + mv magic.mgc etc/file +fi diff --git a/base/file/file.SMBuild b/base/file/file.SMBuild new file mode 100755 index 0000000..5f85d76 --- /dev/null +++ b/base/file/file.SMBuild @@ -0,0 +1,52 @@ +APP=file +VERSION=5.39 +BUILD=3sml +HOMEPAGE='https://www.darwinsys.com/file/' +DOWNLOAD='http://astron.com/pub/file/file-5.39.tar.gz' +DESC="Utility to determine file types" +REQUIRES="bzip2 zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/file.etc.file.diff + patch -p1 < $SRCDIR/file.short.diff + + # linking against libseccomp causes weird "Bad system call" issues + CFLAGS="--std=c99" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --datadir=/etc \ + --enable-fsect-man5 \ + --disable-libseccomp + + # Install the flat files + # We'll regenerate /etc/file/magic.mgc in the doinst.sh + rm -rf $PKG/etc/file/magic.mgc + mkdir -p $PKG/etc/file/magic + cp -a magic/Magdir/* $PKG/etc/file/magic/ + chmod 0644 $PKG/etc/file/magic/* + + install -Dm 755 $SRCDIR/recompile_magic.mgc.sh $PKG/etc/file/recompile_magic.mgc.sh + + ( cd $PKG/etc ; ln -sf file misc ) + + make CFLAGS="--std=c99" + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +706f52abe8a4140983c03bc9403987153e3996a8bfbfd20d94f82fc7781c710a54e57b8967c8885e0ceec83f86ff0acca14b6d051b854f79df7aaa626d7068b8 file-5.39.tar.lz +3d5549ee9ec1357cd016b120c519c36b3f9fc1cd5f56a34ae5437ff0a9a536a0fa678dd151604e1d0b43c995fe766df5caf950e025c1ca1471f7bcc8715eca73 file.etc.file.diff +66c7ba2a0d963c12df85408cd07d26cc55ba8cefb117ea322091e63af5aabd6df6ca389139a8f8338ea0edd244dbe43e385799381de1b8c0d33137374b3d5734 file.short.diff +" diff --git a/base/file/file.etc.file.diff b/base/file/file.etc.file.diff new file mode 100644 index 0000000..98e0754 --- /dev/null +++ b/base/file/file.etc.file.diff @@ -0,0 +1,11 @@ +--- ./configure.ac.orig 2009-05-06 15:32:25.000000000 -0500 ++++ ./configure.ac 2009-06-12 17:40:25.000000000 -0500 +@@ -47,7 +47,7 @@ + fsect=4 + ]) + +-AC_SUBST([pkgdatadir], ['$(datadir)/misc']) ++AC_SUBST([pkgdatadir], ['$(datadir)/file']) + AC_SUBST(fsect) + AM_CONDITIONAL(FSECT5, test x$fsect = x5) + diff --git a/base/file/file.short.diff b/base/file/file.short.diff new file mode 100644 index 0000000..0f6a0e7 --- /dev/null +++ b/base/file/file.short.diff @@ -0,0 +1,12 @@ +diff -Nur file-5.08.orig//src/readelf.h file-5.08/src/readelf.h +--- file-5.08.orig//src/readelf.h 2011-08-03 09:45:16.000000000 -0500 ++++ file-5.08/src/readelf.h 2011-08-23 21:10:04.228054614 -0500 +@@ -239,7 +239,7 @@ + * word[2]: minor version + * word[3]: tiny version + */ +-#define NT_GNU_VERSION 1 ++#define NT_GNU_VERSION 0 + + /* GNU OS tags */ + #define GNU_OS_LINUX 0 diff --git a/base/file/recompile_magic.mgc.sh b/base/file/recompile_magic.mgc.sh new file mode 100644 index 0000000..2ae5ca3 --- /dev/null +++ b/base/file/recompile_magic.mgc.sh @@ -0,0 +1,14 @@ +#!/bin/sh +# +# Recompile the /etc/file/magic.mgc database. +# This should be done after any additions or changes to the files +# in /etc/file/magic/. + +if [ ! "$UID" = "0" ]; then + echo "Error: must be root to recompile the system magic.mgc" + exit 1 +fi + +cd /etc/file +/usr/bin/file --compile + diff --git a/base/findutils/findutils.SMBuild b/base/findutils/findutils.SMBuild new file mode 100755 index 0000000..eeaebdf --- /dev/null +++ b/base/findutils/findutils.SMBuild @@ -0,0 +1,41 @@ +APP=findutils +VERSION=4.8.0 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/findutils/' +DOWNLOAD='https://ftp.gnu.org/gnu/findutils/findutils-4.6.0.tar.gz' +DESC="POSIX-compliant utilities to locate files" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/findutils.no.default.options.warnings.diff + patch -p1 < $SRCDIR/mountlist.c.patch + + LDFLAGS="-static" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --libexecdir=/lib + + make + make install DESTDIR=$PKG + + # Provided by mlocate + rm -f $PKG/bin/{locate,updatedb $PKG/share/man/man1/{locate.1,updatedb.1} + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +eaa2da304dbeb2cd659b9210ac37da1bde4cd665c12a818eca98541c5ed5cba1050641fc0c39c0a446a5a7a87a8d654df0e0e6b0cee21752ea485188c9f1071e findutils-4.8.0.tar.xz +bacb78a89dab3fb52297c9b36178ef8c75c6d840f57508771084b355d43cfc2c77785c6361fbf694064288cfb8452095bf7552b156b059e04c4345db8e4e4a39 mountlist.c.patch +ec9853fe85374db4a83282a99ba6aea7b8a4cefcb32e83002b773c05877be4a631a75ac208e946b20a0e22b9281f56cf1a022a1f17a287aadf523b0a22e2a02a findutils.no.default.options.warnings.diff +" diff --git a/base/findutils/findutils.no.default.options.warnings.diff b/base/findutils/findutils.no.default.options.warnings.diff new file mode 100644 index 0000000..2b10767 --- /dev/null +++ b/base/findutils/findutils.no.default.options.warnings.diff @@ -0,0 +1,11 @@ +--- ./find/util.c.orig 2008-03-10 04:37:22.000000000 -0500 ++++ ./find/util.c 2009-02-21 15:50:38.000000000 -0600 +@@ -910,7 +910,7 @@ + + if (isatty(0)) + { +- p->warnings = true; ++ p->warnings = false; + p->literal_control_chars = false; + } + else diff --git a/base/findutils/mountlist.c.patch b/base/findutils/mountlist.c.patch new file mode 100644 index 0000000..ea853ec --- /dev/null +++ b/base/findutils/mountlist.c.patch @@ -0,0 +1,11 @@ +--- a/gl/lib/mountlist.c ++++ b/gl/lib/mountlist.c +@@ -24,7 +24,7 @@ + #include + #include + #include +- ++#include + #include "xalloc.h" + + #include diff --git a/base/flac/flac.SMBuild b/base/flac/flac.SMBuild new file mode 100755 index 0000000..168c2c0 --- /dev/null +++ b/base/flac/flac.SMBuild @@ -0,0 +1,32 @@ +APP=flac +VERSION=1.3.3 +BUILD=1sml +HOMEPAGE='https://xiph.org/flac/index.html' +DOWNLOAD='https://ftp.osuosl.org/pub/xiph/releases/flac/flac-1.3.3.tar.xz' +DESC="Open-source lossless audio codec" +REQUIRES="libogg" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-sse + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +18c8cf06afe739717331f00bacf1339694855d2870b1a2c47d7721f2e1fcd7ccc432518be1bdde10f68484d9abbc19f229759acf15b44b7aa2caf79ca810f7ad flac-1.3.3.tar.lz +" diff --git a/base/flex/flex.SMBuild b/base/flex/flex.SMBuild new file mode 100755 index 0000000..bd69cd7 --- /dev/null +++ b/base/flex/flex.SMBuild @@ -0,0 +1,37 @@ +APP=flex +VERSION=2.6.4 +BUILD=1sml +HOMEPAGE='https://github.com/westes/flex' +DOWNLOAD='https://github.com/westes/flex/archive/refs/tags/v2.6.4.tar.gz' +DESC="fast lexical analyzer generator" +REQUIRES="m4" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + unset CPPFLAGS + + printf "all:\n\ttrue\n\ninstall:\n\ttrue\n\n" > tests/Makefile.in + + CPPFLAGS="-D_GNU_SOURCE -DSTDC_HEADERS" \ + ./configure \ + --prefix="" \ + --disable-nls \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +6564218510945b678bb61a1375ccaa4c254aa43fc52f0c4e3d8b784f551bca82bb8ab1889bde522c3da9b04da99904d17420ef8615862bae65b925770fae2517 flex-2.6.4.tar.lz +" diff --git a/base/fribidi/fribidi.SMBuild b/base/fribidi/fribidi.SMBuild new file mode 100755 index 0000000..f9a3f2e --- /dev/null +++ b/base/fribidi/fribidi.SMBuild @@ -0,0 +1,31 @@ +APP=fribidi +VERSION=1.0.9 +BUILD=1sml +HOMEPAGE='https://github.com/fribidi/fribidi' +DOWNLOAD='https://github.com/fribidi/fribidi/releases/download/v1.0.9/fribidi-1.0.9.tar.xz' +DESC="Unicode BiDirectional algorithm library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +88032eca39712493ffa6f2114bd75e7203b95fad1db1e619aaaf919df84a63869247a7fa56aa044c9475ae8027feff975ad35d0e6b5c3f1e85d5d8d4dd60c691 fribidi-1.0.9.tar.lz +" diff --git a/base/fuse/doinst.sh b/base/fuse/doinst.sh new file mode 100644 index 0000000..cbb9562 --- /dev/null +++ b/base/fuse/doinst.sh @@ -0,0 +1,24 @@ +#!/bin/sh + +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then + # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +# Keep same perms on rc.fuse.new: +if [ -e etc/rc.d/rc.fuse ]; then + cp -a etc/rc.d/rc.fuse etc/rc.d/rc.fuse.new.incoming + cat etc/rc.d/rc.fuse.new > etc/rc.d/rc.fuse.new.incoming + mv etc/rc.d/rc.fuse.new.incoming etc/rc.d/rc.fuse.new +fi + +config etc/rc.d/rc.fuse.new + diff --git a/base/fuse/fuse.SMBuild b/base/fuse/fuse.SMBuild new file mode 100755 index 0000000..fd4b129 --- /dev/null +++ b/base/fuse/fuse.SMBuild @@ -0,0 +1,41 @@ +APP=fuse +VERSION=2.9.5 +BUILD=1sml +HOMEPAGE='https://github.com/libfuse/libfuse' +DOWNLOAD='https://github.com/libfuse/libfuse/releases/download/fuse-2.9.5/fuse-2.9.5.tar.xz' +DESC="Interface to export virtual filesystem in userspace" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin \ + --enable-lib \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + mv $PKG/sbin/* $PKG/bin/ ; rmdir $PKG/sbin + + mkdir -p $PKG/etc/rc.d + mv $PKG/etc/init.d/fuse $PKG/etc/rc.d/rc.fuse.new + rm -rf $PKG/etc/init.d + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8d24254a26314a3c2f84108cd3aadc357b9ac943edd279f6fcd86c1821238ac01817880cfc994172b50a07bf74ead1e3bb44faf17eee81cca3baf3a6a960e823 fuse-2.9.5.tar.lz +" diff --git a/base/gawk/gawk.SMBuild b/base/gawk/gawk.SMBuild new file mode 100755 index 0000000..cacc0c2 --- /dev/null +++ b/base/gawk/gawk.SMBuild @@ -0,0 +1,35 @@ +APP=gawk +VERSION=4.2.1 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/gawk/' +DOWNLOAD='https://ftp.gnu.org/gnu/gawk/gawk-4.2.1.tar.xz' +DESC="POSIX-compliant pattern scanning and processing language" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="-static" \ + ./configure \ + --prefix="" \ + --libexecdir=/lib \ + --disable-nls \ + --without-mpfr \ + --without-readline + + make CFLAGS="-static" + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0bf7ccefea01f6249e2da3299f0478421113adb6a827272fc08b02f2691754f3a2de28478681fd97944286c2495decc7dedc99bec11bcb7ee12ea17cf246e296 gawk-4.2.1.tar.lz +" diff --git a/base/gcc-libs/gcc-libs.SMBuild b/base/gcc-libs/gcc-libs.SMBuild new file mode 100755 index 0000000..b816a77 --- /dev/null +++ b/base/gcc-libs/gcc-libs.SMBuild @@ -0,0 +1,26 @@ +APP=gcc-libs +VERSION=9.3.0 +BUILD=1sml +HOMEPAGE='https://gcc.gnu.org/' +DOWNLOAD='' +DESC="separate GCC and libstdc++ libraries" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION-$ARCH + + tar xf $SRCDIR/$APP-$VERSION-$ARCH.tar.?z + cd $APP-$VERSION-$ARCH + + mkdir -p $PKG/lib + cp -av * $PKG/lib/ + + mkfinalpkg +} + +SHA512SUMS=" +9a098fc7df9491f73d3f58474390018ad3120a36b4122b47696d3ea60c4095fcdb7d002809b1b2e7eefbae828271f85c6eba298dc16a0b9605b4601368f0c4af gcc-libs-9.3.0-aarch64.tar.lz +e3dd69faf7722270e096f093633d116d1c707d62c267e4cb5a18128f55f3a57c1572d34ed51d901fbc0da969639cffd4efd19a591f3625117ca91c7c6c82a622 gcc-libs.aarch64.tar.lz +2fc2c35ab88f97e723ea905c20fd749eacc626195fd4b4361f691aa3219ec3f88d3628a419db7fb827fa03fd54675bea2bbd1190cee5a3d89b28ab4949fcb15e gcc-libs.x86_64.tar.lz +" diff --git a/base/gdb/001-gdb-pr14523-mips-signal-number.patch b/base/gdb/001-gdb-pr14523-mips-signal-number.patch new file mode 100644 index 0000000..f78c7ed --- /dev/null +++ b/base/gdb/001-gdb-pr14523-mips-signal-number.patch @@ -0,0 +1,16 @@ +See http://sourceware.org/bugzilla/show_bug.cgi?id=14523 + +--- a/gdb/common/signals.c ++++ b/gdb/common/signals.c +@@ -348,6 +348,11 @@ gdb_signal_from_host (int hostsig) + else if (64 <= hostsig && hostsig <= 127) + return (enum gdb_signal) + (hostsig - 64 + (int) GDB_SIGNAL_REALTIME_64); ++ else if (hostsig == 128) ++ /* Some platforms, such as Linux MIPS, have NSIG == 128, in which case ++ signal 128 is the highest realtime signal. There is no constant for ++ that though. */ ++ return GDB_SIGNAL_UNKNOWN; + else + error (_("GDB bug: target.c (gdb_signal_from_host): " + "unrecognized real-time signal")); diff --git a/base/gdb/010-aarch64-headers.patch b/base/gdb/010-aarch64-headers.patch new file mode 100644 index 0000000..8f05738 --- /dev/null +++ b/base/gdb/010-aarch64-headers.patch @@ -0,0 +1,38 @@ +The signal definitions of musl and gdb collide + +The kernel defines "struct sigcontext" in asm/sigcontext.h and musl libc +defines it in signal.h which collides. +Kernel 4.14 misses the definitions of struct user_sve_header so we still +have to use the aarch64-sve-linux-sigcontext.h header file which also +provides that and make sure aarch64-sve-linux-sigcontext.h does not +provide the same headers as the kernel or musl. + +--- a/gdb/nat/aarch64-sve-linux-ptrace.h ++++ b/gdb/nat/aarch64-sve-linux-ptrace.h +@@ -25,7 +25,7 @@ + #include + #include + +-#ifndef SVE_SIG_ZREGS_SIZE ++#ifndef SVE_PT_REGS_SVE + #include "aarch64-sve-linux-sigcontext.h" + #endif + +--- a/gdb/nat/aarch64-sve-linux-sigcontext.h ++++ b/gdb/nat/aarch64-sve-linux-sigcontext.h +@@ -19,6 +19,7 @@ + #ifndef NAT_AARCH64_SVE_LINUX_SIGCONTEXT_H + #define NAT_AARCH64_SVE_LINUX_SIGCONTEXT_H + ++#ifndef SVE_MAGIC + #define SVE_MAGIC 0x53564501 + + struct sve_context { +@@ -128,6 +129,7 @@ struct sve_context { + (SVE_SIG_FFR_OFFSET(vq) + SVE_SIG_FFR_SIZE(vq) - SVE_SIG_REGS_OFFSET) + + #define SVE_SIG_CONTEXT_SIZE(vq) (SVE_SIG_REGS_OFFSET + SVE_SIG_REGS_SIZE(vq)) ++#endif + + /* SVE/FP/SIMD state (NT_ARM_SVE) */ + diff --git a/base/gdb/100-musl_fix.patch b/base/gdb/100-musl_fix.patch new file mode 100644 index 0000000..8ba6d46 --- /dev/null +++ b/base/gdb/100-musl_fix.patch @@ -0,0 +1,53 @@ +--- a/gdb/linux-nat.c ++++ b/gdb/linux-nat.c +@@ -17,6 +17,7 @@ + You should have received a copy of the GNU General Public License + along with this program. If not, see . */ + ++#include "stopcode.h" + #include "defs.h" + #include "inferior.h" + #include "infrun.h" +@@ -72,6 +73,10 @@ + #define SPUFS_MAGIC 0x23c9b64e + #endif + ++#ifndef __SIGRTMIN ++#define __SIGRTMIN SIGRTMIN ++#endif ++ + /* This comment documents high-level logic of this file. + + Waiting for events in sync mode +--- /dev/null ++++ b/gdb/stopcode.h +@@ -0,0 +1,4 @@ ++#ifndef W_STOPCODE ++#define W_STOPCODE(sig) ((sig) << 8 | 0x7f) ++#endif ++ +--- a/gdb/nat/ppc-linux.h ++++ b/gdb/nat/ppc-linux.h +@@ -18,7 +18,10 @@ + #ifndef NAT_PPC_LINUX_H + #define NAT_PPC_LINUX_H + ++#define pt_regs __pt_regs + #include ++#undef pt_regs ++ + #include + + /* This sometimes isn't defined. */ +--- a/gdb/gdbserver/linux-ppc-low.c ++++ b/gdb/gdbserver/linux-ppc-low.c +@@ -23,7 +23,9 @@ + #include "elf/common.h" + #include + #include ++#define pt_regs __pt_regs + #include ++#undef pt_regs + + #include "arch/ppc-linux-common.h" + #include "arch/ppc-linux-tdesc.h" diff --git a/base/gdb/110-shared_libgcc.patch b/base/gdb/110-shared_libgcc.patch new file mode 100644 index 0000000..f07ac8c --- /dev/null +++ b/base/gdb/110-shared_libgcc.patch @@ -0,0 +1,76 @@ +--- a/configure.ac ++++ b/configure.ac +@@ -1283,13 +1283,13 @@ if test -z "$LD"; then + fi + fi + +-# Check whether -static-libstdc++ -static-libgcc is supported. ++# Check whether -static-libstdc++ is supported. + have_static_libs=no + if test "$GCC" = yes; then + saved_LDFLAGS="$LDFLAGS" + +- LDFLAGS="$LDFLAGS -static-libstdc++ -static-libgcc" +- AC_MSG_CHECKING([whether g++ accepts -static-libstdc++ -static-libgcc]) ++ LDFLAGS="$LDFLAGS -static-libstdc++" ++ AC_MSG_CHECKING([whether g++ accepts -static-libstdc++]) + AC_LANG_PUSH(C++) + AC_LINK_IFELSE([AC_LANG_SOURCE([ + #if (__GNUC__ < 4) || (__GNUC__ == 4 && __GNUC_MINOR__ < 5) +@@ -1629,7 +1629,7 @@ AC_ARG_WITH(stage1-ldflags, + # trust that they are doing what they want. + if test "$with_static_standard_libraries" = yes -a "$stage1_libs" = "" \ + -a "$have_static_libs" = yes; then +- stage1_ldflags="-static-libstdc++ -static-libgcc" ++ stage1_ldflags="-static-libstdc++" + fi]) + AC_SUBST(stage1_ldflags) + +@@ -1658,7 +1658,7 @@ AC_ARG_WITH(boot-ldflags, + # statically. But if the user explicitly specified the libraries to + # use, trust that they are doing what they want. + if test "$poststage1_libs" = ""; then +- poststage1_ldflags="-static-libstdc++ -static-libgcc" ++ poststage1_ldflags="-static-libstdc++" + fi]) + AC_SUBST(poststage1_ldflags) + +--- a/configure ++++ b/configure +@@ -5053,14 +5053,14 @@ if test -z "$LD"; then + fi + fi + +-# Check whether -static-libstdc++ -static-libgcc is supported. ++# Check whether -static-libstdc++ is supported. + have_static_libs=no + if test "$GCC" = yes; then + saved_LDFLAGS="$LDFLAGS" + +- LDFLAGS="$LDFLAGS -static-libstdc++ -static-libgcc" +- { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether g++ accepts -static-libstdc++ -static-libgcc" >&5 +-$as_echo_n "checking whether g++ accepts -static-libstdc++ -static-libgcc... " >&6; } ++ LDFLAGS="$LDFLAGS -static-libstdc++" ++ { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether g++ accepts -static-libstdc++" >&5 ++$as_echo_n "checking whether g++ accepts -static-libstdc++... " >&6; } + ac_ext=cpp + ac_cpp='$CXXCPP $CPPFLAGS' + ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' +@@ -5861,7 +5861,7 @@ else + # trust that they are doing what they want. + if test "$with_static_standard_libraries" = yes -a "$stage1_libs" = "" \ + -a "$have_static_libs" = yes; then +- stage1_ldflags="-static-libstdc++ -static-libgcc" ++ stage1_ldflags="-static-libstdc++" + fi + fi + +@@ -5897,7 +5897,7 @@ else + # statically. But if the user explicitly specified the libraries to + # use, trust that they are doing what they want. + if test "$poststage1_libs" = ""; then +- poststage1_ldflags="-static-libstdc++ -static-libgcc" ++ poststage1_ldflags="-static-libstdc++" + fi + fi + diff --git a/base/gdb/120-sigprocmask-invalid-call.patch b/base/gdb/120-sigprocmask-invalid-call.patch new file mode 100644 index 0000000..7cb050c --- /dev/null +++ b/base/gdb/120-sigprocmask-invalid-call.patch @@ -0,0 +1,38 @@ +From 56893a61aa4f0270fa8d1197b9848247f90fce0d Mon Sep 17 00:00:00 2001 +From: Yousong Zhou +Date: Fri, 24 Mar 2017 10:36:03 +0800 +Subject: [PATCH] Fix invalid sigprocmask call + +The POSIX document says + + The pthread_sigmask() and sigprocmask() functions shall fail if: + + [EINVAL] + The value of the how argument is not equal to one of the defined values. + +and this is how musl-libc is currently doing. Fix the call to be safe +and correct + + [1] http://pubs.opengroup.org/onlinepubs/9699919799/functions/pthread_sigmask.html + +gdb/ChangeLog: +2017-03-24 Yousong Zhou + + * common/signals-state-save-restore.c (save_original_signals_state): + Fix invalid sigprocmask call. +--- + gdb/ChangeLog | 5 +++++ + gdb/common/signals-state-save-restore.c | 2 +- + 2 files changed, 6 insertions(+), 1 deletion(-) + +--- a/gdb/common/signals-state-save-restore.c ++++ b/gdb/common/signals-state-save-restore.c +@@ -41,7 +41,7 @@ save_original_signals_state (bool quiet) + int i; + int res; + +- res = sigprocmask (0, NULL, &original_signal_mask); ++ res = sigprocmask (SIG_BLOCK, NULL, &original_signal_mask); + if (res == -1) + perror_with_name (("sigprocmask")); + diff --git a/base/gdb/130-uclibc-fix.patch b/base/gdb/130-uclibc-fix.patch new file mode 100644 index 0000000..4925e66 --- /dev/null +++ b/base/gdb/130-uclibc-fix.patch @@ -0,0 +1,11 @@ +--- a/gdb/dwarf-index-write.c ++++ b/gdb/dwarf-index-write.c +@@ -701,7 +701,7 @@ public: + gdb_assert (m_abbrev_table.empty ()); + const size_t name_count = m_name_to_value_set.size (); + m_bucket_table.resize +- (std::pow (2, std::ceil (std::log2 (name_count * 4 / 3)))); ++ (std::pow (2, std::ceil (log2 (name_count * 4 / 3)))); + m_hash_table.reserve (name_count); + m_name_table_string_offs.reserve (name_count); + m_name_table_entry_offs.reserve (name_count); diff --git a/base/gdb/gdb.SMBuild b/base/gdb/gdb.SMBuild new file mode 100755 index 0000000..61c37b3 --- /dev/null +++ b/base/gdb/gdb.SMBuild @@ -0,0 +1,48 @@ +APP=gdb +VERSION=8.3.1 +BUILD=2sml +HOMEPAGE='https://www.gnu.org/software/gdb/' +DOWNLOAD='https://ftp.gnu.org/gnu/gdb/gdb-8.3.1.tar.xz' +DESC="GNU symbolic debugger" +REQUIRES="gcc-libs netbsd-curses expat xz python3 gmp mpfr" +SM_NOAUTOCONFSITE=1 + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/100-musl_fix.patch + patch -p1 < $SRCDIR/110-shared_libgcc.patch + patch -p1 < $SRCDIR/120-sigprocmask-invalid-call.patch + patch -p1 < $SRCDIR/130-uclibc-fix.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-werror \ + --with-system-readline \ + --with-system-zlib \ + --disable-sim \ + --with-python=/bin/python3 + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +9053a2dc6b9eb921907afbc4cecc75d635aa76df5e8c4f0e5824ccf57cb206b299c19b127fff000b65c334826ff8304a54ff6098428365a8e997cca886c39e9a gdb-8.3.1.tar.xz +8f266317da5ac6c0288d5254d836fb2166b78ba98714de011977a2546e1b695d28b1f5114c3faddedc113b729aac8ef0b5cafd651a5de53322be42f22e8b696f 001-gdb-pr14523-mips-signal-number.patch +a47debfd5285d9d2cbea42be9ca856c0ee44fa14b1e8a6c590908d5939c932d0f1898888ac337a27f57a49e01a884d0258c155425c0c64d9483879bc35295eda 010-aarch64-headers.patch +6b881ab5ba9807c967b74b5fc049412c1fa281926d433ee32ed04ccb205f41e94983af5242cbe04ba5a922aa38af23bd48fc4670cc2d6bf79c2cd89912d39967 100-musl_fix.patch +394f215e929bc2ea936276f8084cfb686c8d3f67cfee76ba62857a1b909a0ddf2a722dcdee2c695da0bd43e09e508db08f8eaad040062dc37364170bcfe38c16 110-shared_libgcc.patch +3aa7ff65e2d8440d2dff50fe3e8ffe7dc46f5f84c74104b99a0de52d081ecaccfaa2ffae41505103820e7da3618724fb4e9bd3a3030ab5dd406a726201f5dcaa 120-sigprocmask-invalid-call.patch +ce5e845697618c9219b7461830e9a77c95130613199911eda14ee2ce0be3bbf1154b72a73807f3614041e5ee1e6570ffb33ffc71556059f45018267f2ab9476b 130-uclibc-fix.patch +" diff --git a/base/gdbm/gdbm.SMBuild b/base/gdbm/gdbm.SMBuild new file mode 100755 index 0000000..fef6bf4 --- /dev/null +++ b/base/gdbm/gdbm.SMBuild @@ -0,0 +1,33 @@ +APP=gdbm +VERSION=1.18 +BUILD=1sml +HOMEPAGE='https://www.gnu.org.ua/software/gdbm/' +DOWNLOAD='https://ftp.gnu.org/gnu/gdbm/gdbm-1.18.tar.gz' +DESC="set of database routines that work similar to the standard UNIX dbm routines" +REQUIRES="readline" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-nls \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7e62e23fcec1351e0db6fa7a530711bd1fe8c01d72a8c69f178af2556bb9d47f4e37ea689a196e6e33d6c27b536bf9f8075f17c7e208e2892bc8d2add9e5331c gdbm-1.18.tar.lz +" diff --git a/base/gettext/gettext.SMBuild b/base/gettext/gettext.SMBuild new file mode 100755 index 0000000..ddd7295 --- /dev/null +++ b/base/gettext/gettext.SMBuild @@ -0,0 +1,32 @@ +APP=gettext +VERSION=0.20.2 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/gettext/' +DOWNLOAD='https://ftp.gnu.org/pub/gnu/gettext/gettext-0.20.2.tar.xz' +DESC="Toolkit to internationalize the messages given by shell scripts" +REQUIRES="attr acl libxml2" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make $MAKEFLAGS + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d6841381c3f3c7569a9c74bb91bd19d88838878e1b9aea5093034e501c05e992cdc7a2373d3f8d012b753916984182e5c09b247e81b41ea4ae602e41604a7454 gettext-0.20.2.tar.lz +" diff --git a/base/giflib/giflib-5.1.9-fix-missing-quantize-API-symbols.patch b/base/giflib/giflib-5.1.9-fix-missing-quantize-API-symbols.patch new file mode 100644 index 0000000..5948f45 --- /dev/null +++ b/base/giflib/giflib-5.1.9-fix-missing-quantize-API-symbols.patch @@ -0,0 +1,32 @@ +From ff8d9a59e79b79657e64430730c35835a84db619 Mon Sep 17 00:00:00 2001 +From: anthraxx +Date: Tue, 2 Apr 2019 11:46:18 +0200 +Subject: [PATCH] fix missing quantize API symbols + +GifQuantizeBuffer is required by many libs and applications +like mplayer, libgdiplus (mono) and others. +--- + Makefile | 4 ++-- + 1 file changed, 2 insertions(+), 2 deletions(-) + +diff --git a/Makefile b/Makefile +index e4ded69..17d0a5c 100644 +--- a/Makefile ++++ b/Makefile +@@ -29,11 +29,11 @@ LIBPOINT=0 + LIBVER=$(LIBMAJOR).$(LIBMINOR).$(LIBPOINT) + + SOURCES = dgif_lib.c egif_lib.c gifalloc.c gif_err.c gif_font.c \ +- gif_hash.c openbsd-reallocarray.c ++ gif_hash.c openbsd-reallocarray.c quantize.c + HEADERS = gif_hash.h gif_lib.h gif_lib_private.h + OBJECTS = $(SOURCES:.c=.o) + +-USOURCES = qprintf.c quantize.c getarg.c ++USOURCES = qprintf.c getarg.c + UHEADERS = getarg.h + UOBJECTS = $(USOURCES:.c=.o) + +-- +2.21.0 + diff --git a/base/giflib/giflib.SMBuild b/base/giflib/giflib.SMBuild new file mode 100755 index 0000000..fe48d3c --- /dev/null +++ b/base/giflib/giflib.SMBuild @@ -0,0 +1,31 @@ +APP=giflib +VERSION=5.2.1 +BUILD=1sml +HOMEPAGE='http://giflib.sourceforge.net/' +DOWNLOAD='https://sourceforge.net/projects/giflib/files/giflib-5.2.1.tar.gz' +DESC="library for manipulating GIF files" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/giflib-5.1.9-fix-missing-quantize-API-symbols.patch + + make + make install DESTDIR=$PKG PREFIX="/" + + cp COPYING $PKGDOCS/ + removestaticlibs + + mkfinalpkg +} + +SHA512SUMS=" +b87cbea325d0b13ee75ea55adc63e7ebeea7ae77af395847a38c88892a8b308fed248a57c2ec95da8cb8b3fec9efe3b2e4890006f59bb64866abe86b91ebf895 giflib-5.2.1.tar.lz +5de1e8724f5221fa3637b4e6a482f650f7608673e2c9200233290018ec8a0bf1beea049b3979b5f57dbf2b2a5fda409324e636e9af10582fd01c71d92d4de3b3 giflib-5.1.9-fix-missing-quantize-API-symbols.patch +" diff --git a/base/git/git.SMBuild b/base/git/git.SMBuild new file mode 100755 index 0000000..9b3d5dc --- /dev/null +++ b/base/git/git.SMBuild @@ -0,0 +1,34 @@ +APP=git +VERSION=2.28.1 +BUILD=1sml +HOMEPAGE='https://git-scm.com/' +DOWNLOAD='https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.28.1.tar.xz' +DESC="Fast, scalable, distributed revision control system" +REQUIRES="curl openssl pcre asciidoc" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make CC="$CC" $MAKEFLAGS \ + prefix="/" gitexecdir="/lib/git-core" \ + NO_TCLTK=1 NO_PYTHON=1 NO_EXPAT=1 NO_GETTEXT=1 \ + NO_REGEX=NeedsStartEnd \ + DESTDIR="$PKG" V=1 all install install-man + + rm -f $PKG/lib/perl5/core_perl_perllocal.pod + install -Dm 755 gitk-git/gitk $PKG/bin/gitk + install -Dm 664 perl/FromCPAN/Error.pm $PKG/lib/perl5/site_perl/Error.pm + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c7f768c987185b7af9f971577d2ce335962c8c60b50c167d8a19f937e40279eaa669a0265d5f7369041ab491dbafc62231041e362df6ce5866d7d4cd6ba66021 git-2.28.1.tar.lz +" diff --git a/base/glib/doinst.sh b/base/glib/doinst.sh new file mode 100644 index 0000000..a70665f --- /dev/null +++ b/base/glib/doinst.sh @@ -0,0 +1,5 @@ + +if [ -x /usr/bin/update-mime-database ]; then + /usr/bin/update-mime-database usr/share/mime >/dev/null 2>&1 +fi + diff --git a/base/glib/glib.SMBuild b/base/glib/glib.SMBuild new file mode 100755 index 0000000..af07829 --- /dev/null +++ b/base/glib/glib.SMBuild @@ -0,0 +1,36 @@ +APP=glib +VERSION=2.66.4 +BUILD=1sml +HOMEPAGE='https://gitlab.gnome.org/GNOME/glib' +DOWNLOAD='https://download.gnome.org/sources/glib/2.66/glib-2.66.4.tar.xz' +DESC="library of C routines" +REQUIRES="libffi util-linux pcre python3 gettext meson" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir smbuild && cd smbuild + + meson .. --prefix="/" \ + -Dman=false \ + -Dgtk_doc=false \ + -Dselinux=disabled \ + -Dnls=disabled \ + -Dinstalled_tests=false + + ninja + DESTDIR="$PKG" ninja install + + cp ../COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +40447b57dec2990e9cb8a5c273c81c4848bad036ab9bf6d7da2c9755782290acef5b085296cb98866832c8076a670ab970d113317da769f6d0da8cd0fe249118 glib-2.66.4.tar.lz +" diff --git a/base/gloox/gloox-musl.patch b/base/gloox/gloox-musl.patch new file mode 100644 index 0000000..0c423f7 --- /dev/null +++ b/base/gloox/gloox-musl.patch @@ -0,0 +1,11 @@ +--- a/src/connectiontcpserver.cpp 2017-02-21 13:32:58.000000000 +0100 ++++ b/src/connectiontcpserver.cpp 2018-01-03 08:38:57.121764510 +0100 +@@ -51,7 +51,7 @@ + #endif + + #include +-#include ++#include + + #ifndef _WIN32_WCE + # include diff --git a/base/gloox/gloox.SMBuild b/base/gloox/gloox.SMBuild new file mode 100755 index 0000000..1311a39 --- /dev/null +++ b/base/gloox/gloox.SMBuild @@ -0,0 +1,36 @@ +APP=gloox +VERSION=1.0.22 +BUILD=1sml +HOMEPAGE='https://camaya.net/gloox/' +DOWNLOAD='https://camaya.net/download/gloox-1.0.22.tar.bz2' +DESC="Rock-solid, full-featured Jabber/XMPP client library in C++" +REQUIRES="gcc-libs libidn gnutls" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/gloox-musl.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4125216628b99820eb1ee333c641d6db55944465bf97f8b6060da72027d2e76e6c9758cc3383c159780eef778fab5a6f5203b4e3d71c1a566574608e00116e62 gloox-1.0.22.tar.lz +b30ddcfea7817a4426ad38febe9f16f1db2d4552710d7e02dbe69674ab6a06f9b26678f3f2a0d07bf6f08f16724387fff2b1b3deec76bdd6742b270a3366c8de gloox-musl.patch +" \ No newline at end of file diff --git a/base/gmime/gmime.SMBuild b/base/gmime/gmime.SMBuild new file mode 100755 index 0000000..34ab600 --- /dev/null +++ b/base/gmime/gmime.SMBuild @@ -0,0 +1,32 @@ +APP=gmime +VERSION=2.6.23 +BUILD=1sml +HOMEPAGE='https://gitlab.gnome.org/GNOME/gmime' +DOWNLOAD='https://github.com/jstedfast/gmime/archive/refs/tags/2.6.23.tar.gz' +DESC="Library to parse and create messages in MIME format" +REQUIRES="netbsd-curses libffi glib util-linux pcre gpgme" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --disable-mono + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +688a9725c1d6913302211d1350406d45dbe9aca35e2bc58d297b213151c28c57c84f311f07e2386456e4537a3e6f941bc539942bf2798a9de0c0f591761cf4de gmime-2.6.23.tar.lz +" diff --git a/base/gmp/gmp.SMBuild b/base/gmp/gmp.SMBuild new file mode 100755 index 0000000..7bf24a9 --- /dev/null +++ b/base/gmp/gmp.SMBuild @@ -0,0 +1,36 @@ +APP=gmp +VERSION=6.1.2 +BUILD=1sml +DESC="GNU multiple precision arithmetic library" +REQUIRES="gcc-libs" +HOMEPAGE='https://gmplib.org/' +DOWNLOAD='https://gmplib.org/download/gmp/gmp-6.1.2.tar.lz' + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + printf "all:\n\ttrue\n\ninstall:\n\ttrue\n\n" > tests/Makefile.in + [ "$ARCH" = "aarch64" ] && BUILDDIST="--build=aarch64-musl-linux" + + ./configure \ + --prefix="" \ + --with-pic \ + --enable-cxx \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp AUTHORS COPYING* NEWS README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +20cac114b085e434e4b3c5be7a8a9caadc5ce2b0e427fb07877f33631d2ea39df6e4691bbe93e05687c169afc8e0e219c6b4d9481e38f7e98ac907da01e1b7b6 gmp-6.1.2.tar.lz +" diff --git a/base/gnu-efi/gnu-efi.SMBuild b/base/gnu-efi/gnu-efi.SMBuild new file mode 100755 index 0000000..ebae688 --- /dev/null +++ b/base/gnu-efi/gnu-efi.SMBuild @@ -0,0 +1,25 @@ +APP=gnu-efi +VERSION=3.0.8 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/gnu-efi/' +DOWNLOAD='https://sourceforge.net/projects/gnu-efi/files/gnu-efi-3.0.8.tar.bz2' +DESC="library to develop applications using GNU toolchain and EFI dev environment" +REQUIRES="libelf-compat" + +build() { + compileonlyfor x86_64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make PREFIX="/" INSTALLROOT="$PKG" -j1 all install + + mkfinalpkg +} + +SHA512SUMS=" +e4e1570bef9b3a3f4e321cd84e2f497a277b3c71e8e1d2321369f5b4c0ffede6c8a8f98bc03507cd436eb247b2e6028bd719e16db5f96a57873e2910bb38be0c gnu-efi-3.0.8.tar.lz +" diff --git a/base/gnupg2/gnupg2.SMBuild b/base/gnupg2/gnupg2.SMBuild new file mode 100755 index 0000000..eb3a5da --- /dev/null +++ b/base/gnupg2/gnupg2.SMBuild @@ -0,0 +1,32 @@ +APP=gnupg2 +VERSION=2.2.20 +BUILD=1sml +HOMEPAGE='https://gnupg.org/' +DOWNLOAD='https://gnupg.org/ftp/gcrypt/gnupg/gnupg-2.2.20.tar.bz2' +DESC="The GNU Privacy Guard version 2.x" +REQUIRES="bzip2 sqlite libassuan readline libksba libusb gnutls npth" + +build() { + mkandenterbuilddir + rm -rf gnupg-$VERSION + + tar xf $SRCDIR/gnupg-$VERSION.tar.?z* + cd gnupg-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sbindir=/bin \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f73470e4e17bf634e8cc5d680492df21a166c0b1b6ad352c4c0115e7f95c7347bed07b662d0a52ac201f86681db6deeb01b3fda81120f3326d51fe604ff12916 gnupg-2.2.20.tar.lz +" diff --git a/base/gnutls/gnutls.SMBuild b/base/gnutls/gnutls.SMBuild new file mode 100755 index 0000000..616365a --- /dev/null +++ b/base/gnutls/gnutls.SMBuild @@ -0,0 +1,33 @@ +APP=gnutls +VERSION=3.6.16 +BUILD=1sml +HOMEPAGE='https://www.gnutls.org/' +DOWNLOAD='https://www.gnupg.org/ftp/gcrypt/gnutls/v3.6/gnutls-3.6.16.tar.xz' +DESC="GNU TLS 1.0 and SSL 3.0 implementation" +REQUIRES="gcc-libs zlib gmp libidn libtasn1 nettle openssl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-openssl-compatibility \ + --disable-static \ + --without-p11-kit + + make + make install DESTDIR=$PKG + + cp LICENSE* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +72c78d7fcb024393c1d15f2a1856608ae4460ba43cc5bbbb4c29b80508cae6cb822df4638029de2363437d110187e0a3cc19a7288c3b2f44b2f648399a028438 gnutls-3.6.16.tar.xz +" diff --git a/base/gperf/gperf.SMBuild b/base/gperf/gperf.SMBuild new file mode 100755 index 0000000..212cf7f --- /dev/null +++ b/base/gperf/gperf.SMBuild @@ -0,0 +1,30 @@ +APP=gperf +VERSION=3.1 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/gperf/' +DOWNLOAD='http://ftp.gnu.org/pub/gnu/gperf/gperf-3.1.tar.gz' +DESC="perfect hash function generator in C++" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bfa6021ac95bb54737da8b6b7782fd13babacf540edb4dcb705ac841ad19225545b6ff57c78c276f457e916c89900ba3ba2e6421ed15a266e6e09d6c2a167c0f gperf-3.1.tar.lz +" diff --git a/base/gpgme/gpgme.SMBuild b/base/gpgme/gpgme.SMBuild new file mode 100755 index 0000000..f368b59 --- /dev/null +++ b/base/gpgme/gpgme.SMBuild @@ -0,0 +1,33 @@ +APP=gpgme +VERSION=1.13.1 +BUILD=1sml +HOMEPAGE='https://gnupg.org/software/gpgme/index.html' +DOWNLOAD='https://gnupg.org/ftp/gcrypt/gpgme/gpgme-1.13.1.tar.bz2' +DESC="C language library to easily add crypto to a program" +REQUIRES="gcc-libs libassuan libgpg-error" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # TODO: disable linking against qt5 + ./configure \ + --prefix="" \ + --disable-static \ + --disable-gpg-test + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +11de670c6cf512508103fe67af56d9fbb2a9dda6fc6fa3cd321371bbe337c7c2c81913ca557d07187adb2a63d37ea1a44da97ab22345bbe6022c405d0cb083b8 gpgme-1.13.1.tar.bz2 +" diff --git a/base/gptfdisk/gptfdisk.SMBuild b/base/gptfdisk/gptfdisk.SMBuild new file mode 100755 index 0000000..aae37b6 --- /dev/null +++ b/base/gptfdisk/gptfdisk.SMBuild @@ -0,0 +1,32 @@ +APP=gptfdisk +VERSION=1.0.5 +BUILD=1sml +HOMEPAGE='http://sourceforge.net/projects/gptfdisk/' +DOWNLOAD='https://sourceforge.net/projects/gptfdisk/files/gptfdisk/1.0.5/gptfdisk-1.0.5.tar.gz' +DESC="GPT fdisk utilities" +REQUIRES="gcc-libs netbsd-curses popt util-linux" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i '/^#include /s|ncursesw/||' gptcurses.cc + make + + for f in cgdisk gdisk sgdisk fixparts ; do + install -Dm 755 $f $PKG/bin/$f + install -Dm 644 $f.8 $PKG/share/man/man8/$f.8 + done + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3d3a59e3488dd3d6bda5d103b9ad8b7936752210346b9787ddc936681498fba90577b6ae950c471d09a01bf6405fce32038ff1777c52db0b21e5277737fe3703 gptfdisk-1.0.5.tar.gz +" diff --git a/base/grep/grep.SMBuild b/base/grep/grep.SMBuild new file mode 100755 index 0000000..ebfd0f3 --- /dev/null +++ b/base/grep/grep.SMBuild @@ -0,0 +1,33 @@ +APP=grep +VERSION=3.6 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/grep/' +DOWNLOAD='https://ftp.gnu.org/gnu/grep/grep-2.14.tar.xz' +DESC="print lines matching a pattern" +REQUIRES="pcre" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="-static" \ + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sysconfdir=/etc + + make CFLAGS="-static" + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8934544a19ded61344d83ff2cab501e86f17f8ae338892e0c36c2d2d8e63c76817840a0071ef5e3fcbca9115eba8a1aae0e4c46b024e75cd9a2e3bd05f933d90 grep-3.6.tar.xz +" diff --git a/base/groff/groff.SMBuild b/base/groff/groff.SMBuild new file mode 100755 index 0000000..bbac556 --- /dev/null +++ b/base/groff/groff.SMBuild @@ -0,0 +1,31 @@ +APP=groff +VERSION=1.22.2 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/groff/' +DOWNLOAD='https://ftp.gnu.org/gnu/groff/groff-1.22.2.tar.gz' +DESC="GNU replacement for nroff and troff text formatters" +REQUIRES="gcc-libs perl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --without-x + + make + make install DESTDIR=$PKG + + cp COPYING FDL LICENSES $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c379309a795f120b4b02d10765797d591be1fd938ac0c822f1e29ac8fb4b8e0a84c55e11c66febf4078f03bd981e8cc532b817a0dd7cf9614774e24741aed034 groff-1.22.2.tar.lz +" diff --git a/base/gsl/gsl.SMBuild b/base/gsl/gsl.SMBuild new file mode 100755 index 0000000..1a8798b --- /dev/null +++ b/base/gsl/gsl.SMBuild @@ -0,0 +1,32 @@ +APP=gsl +VERSION=2.6 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/gsl/gsl.html' +DOWNLOAD='https://ftp.gnu.org/gnu/gsl/gsl-2.6.tar.gz' +DESC="a numerical library for C and C++ programmers written in ANSI C" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b2f8d661282eca13417aa863136ae81b551f1919741d35de339c20616332b45b1a94f1f87aec9c496c4704cc0f88c84c50adca047846cf97eb87fef4aedc704f gsl-2.6.tar.lz +" diff --git a/base/gstreamer/gstreamer.SMBuild b/base/gstreamer/gstreamer.SMBuild new file mode 100755 index 0000000..f22c1e5 --- /dev/null +++ b/base/gstreamer/gstreamer.SMBuild @@ -0,0 +1,37 @@ +APP=gstreamer +VERSION=1.16.2 +BUILD=1sml +HOMEPAGE='https://gstreamer.freedesktop.org/' +DOWNLOAD='https://gstreamer.freedesktop.org/data/src/gstreamer/gstreamer-1.16.2.tar.xz' +DESC="streaming multimedia framework" +REQUIRES="glib pcre libffi zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + + meson .. \ + --prefix="/" \ + --sysconfdir=/etc \ + --buildtype=plain \ + -Dintrospection=disabled \ + -Dbash-completion=disabled + + ninja + DESTDIR="$PKG" ninja install + cd .. + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +34ad259bfe20f38a5c499dece285c24231c4585d6165603ec4aaa6ba3062b5560a69abcf1bc6864691982fc99c431af88c7f96fcff6db35b50b4e1463809d900 gstreamer-1.16.2.tar.lz +" diff --git a/base/guile/guile.SMBuild b/base/guile/guile.SMBuild new file mode 100755 index 0000000..995dd7f --- /dev/null +++ b/base/guile/guile.SMBuild @@ -0,0 +1,34 @@ +APP=guile +VERSION=2.2.6 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/guile/' +DOWNLOAD='https://ftp.gnu.org/gnu/guile/guile-2.2.6.tar.xz' +DESC="GNU extension language library" +REQUIRES="libtool netbsd-curses libunistring libffi gmp libgc" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-error-on-warning \ + --disable-static + + sed -i -e 's/ -shared / -Wl,-O1,--as-needed\0/g' libtool + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +68c31e47786838f4f1dda63bfa99428a0092383f1045e836b742ccd8021fbdd83ef910ba35858c2855b3d748f228d356536496742feba5b00e07fdcc0c5a5628 guile-2.2.6.tar.xz +" diff --git a/base/gyp/gyp-fix-cmake.patch b/base/gyp/gyp-fix-cmake.patch new file mode 100644 index 0000000..31bd7ac --- /dev/null +++ b/base/gyp/gyp-fix-cmake.patch @@ -0,0 +1,33 @@ +--- a/pylib/gyp/generator/cmake.py ++++ b/pylib/gyp/generator/cmake.py +@@ -40,9 +40,9 @@ + + try: + # maketrans moved to str in python3. ++ _maketrans = str.maketrans ++except NameError: + _maketrans = string.maketrans +-except NameError: +- _maketrans = str.maketrans + + generator_default_variables = { + 'EXECUTABLE_PREFIX': '', +@@ -281,7 +281,7 @@ + dirs = set(dir for dir in (os.path.dirname(o) for o in outputs) if dir) + + if int(action.get('process_outputs_as_sources', False)): +- extra_sources.extend(zip(cmake_outputs, outputs)) ++ extra_sources.extend(list(zip(cmake_outputs, outputs))) + + # add_custom_command + output.write('add_custom_command(OUTPUT ') +@@ -987,7 +987,7 @@ + + # XCode settings + xcode_settings = config.get('xcode_settings', {}) +- for xcode_setting, xcode_value in xcode_settings.viewitems(): ++ for xcode_setting, xcode_value in xcode_settings.items(): + SetTargetProperty(output, cmake_target_name, + "XCODE_ATTRIBUTE_%s" % xcode_setting, xcode_value, + '' if isinstance(xcode_value, str) else ' ') + diff --git a/base/gyp/gyp-ninja-build.patch b/base/gyp/gyp-ninja-build.patch new file mode 100644 index 0000000..74d8522 --- /dev/null +++ b/base/gyp/gyp-ninja-build.patch @@ -0,0 +1,26 @@ +diff -pruN gyp-0.1-gitfcd686f1.orig/pylib/gyp/generator/ninja.py gyp-0.1-gitfcd686f1/pylib/gyp/generator/ninja.py +--- gyp-0.1-gitfcd686f1.orig/pylib/gyp/generator/ninja.py 2019-08-14 09:05:50.000000000 +0000 ++++ gyp-0.1-gitfcd686f1/pylib/gyp/generator/ninja.py 2019-08-14 09:19:26.668031638 +0000 +@@ -2073,11 +2073,11 @@ def GenerateOutputForConfig(target_list, + # .c files. This should be handled by mspdbsrv, but rarely errors out with + # c1xx : fatal error C1033: cannot open program database + # By making the rules target separate pdb files this might be avoided. +- cc_command = ('ninja -t msvc -e $arch ' + ++ cc_command = ('ninja-build -t msvc -e $arch ' + + '-- ' + '$cc /nologo /showIncludes /FC ' + '@$out.rsp /c $in /Fo$out /Fd$pdbname_c ') +- cxx_command = ('ninja -t msvc -e $arch ' + ++ cxx_command = ('ninja-build -t msvc -e $arch ' + + '-- ' + '$cxx /nologo /showIncludes /FC ' + '@$out.rsp /c $in /Fo$out /Fd$pdbname_cc ') +@@ -2453,7 +2453,7 @@ def PerformBuild(data, configurations, p + options = params['options'] + for config in configurations: + builddir = os.path.join(options.toplevel_dir, 'out', config) +- arguments = ['ninja', '-C', builddir] ++ arguments = ['ninja-build', '-C', builddir] + print('Building [%s]: %s' % (config, arguments)) + subprocess.check_call(arguments) + diff --git a/base/gyp/gyp-python3.patch b/base/gyp/gyp-python3.patch new file mode 100644 index 0000000..6235b82 --- /dev/null +++ b/base/gyp/gyp-python3.patch @@ -0,0 +1,36 @@ +diff -pruN gyp-0.1-gitfcd686f1.orig/gyp gyp-0.1-gitfcd686f1/gyp +--- gyp-0.1-gitfcd686f1.orig/gyp 2015-04-30 09:48:21.000000000 +0000 ++++ gyp-0.1-gitfcd686f1/gyp 2019-08-14 09:41:05.343208034 +0000 +@@ -5,4 +5,4 @@ + + set -e + base=$(dirname "$0") +-exec python "${base}/gyp_main.py" "$@" ++exec python3 "${base}/gyp_main.py" "$@" +diff -pruN gyp-0.1-gitfcd686f1.orig/gyp_main.py gyp-0.1-gitfcd686f1/gyp_main.py +--- gyp-0.1-gitfcd686f1.orig/gyp_main.py 2016-10-17 02:00:37.000000000 +0000 ++++ gyp-0.1-gitfcd686f1/gyp_main.py 2019-08-14 09:41:43.380207320 +0000 +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + # Copyright (c) 2009 Google Inc. All rights reserved. + # Use of this source code is governed by a BSD-style license that can be +diff -pruN gyp-0.1-gitfcd686f1.orig/gyptest.py gyp-0.1-gitfcd686f1/gyptest.py +--- gyp-0.1-gitfcd686f1.orig/gyptest.py 2019-08-14 09:05:50.000000000 +0000 ++++ gyp-0.1-gitfcd686f1/gyptest.py 2019-08-14 09:41:48.578208719 +0000 +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + # Copyright (c) 2012 Google Inc. All rights reserved. + # Use of this source code is governed by a BSD-style license that can be + # found in the LICENSE file. +diff -pruN gyp-0.1-gitfcd686f1.orig/setup.py gyp-0.1-gitfcd686f1/setup.py +--- gyp-0.1-gitfcd686f1.orig/setup.py 2015-04-30 09:48:21.000000000 +0000 ++++ gyp-0.1-gitfcd686f1/setup.py 2019-08-14 09:41:53.510210046 +0000 +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + # Copyright (c) 2009 Google Inc. All rights reserved. + # Use of this source code is governed by a BSD-style license that can be diff --git a/base/gyp/gyp-python38.patch b/base/gyp/gyp-python38.patch new file mode 100644 index 0000000..36f1da6 --- /dev/null +++ b/base/gyp/gyp-python38.patch @@ -0,0 +1,19 @@ +commit 7b0a3fd85beb67c990da3fb1b690444a27a6ee42 +Author: Tom Hughes +Date: Fri Aug 23 09:33:14 2019 +0100 + + Fix python 3.8 warnings + +diff --git a/pylib/gyp/input.py b/pylib/gyp/input.py +index 42c279cf..013231dc 100644 +--- a/pylib/gyp/input.py ++++ b/pylib/gyp/input.py +@@ -1181,7 +1181,7 @@ def LoadVariablesFromVariablesDict(variables, the_dict, the_dict_key): + if variable_name in variables: + # If the variable is already set, don't set it. + continue +- if the_dict_key is 'variables' and variable_name in the_dict: ++ if the_dict_key == 'variables' and variable_name in the_dict: + # If the variable is set without a % in the_dict, and the_dict is a + # variables dict (making |variables| a varaibles sub-dict of a + # variables dict), use the_dict's definition. diff --git a/base/gyp/gyp-python39.patch b/base/gyp/gyp-python39.patch new file mode 100644 index 0000000..cb5f2e1 --- /dev/null +++ b/base/gyp/gyp-python39.patch @@ -0,0 +1,55 @@ +diff --git a/pylib/gyp/common.py b/pylib/gyp/common.py +index b268d229..03c99cab 100644 +--- a/pylib/gyp/common.py ++++ b/pylib/gyp/common.py +@@ -4,7 +4,6 @@ + + from __future__ import with_statement + +-import collections + import errno + import filecmp + import os.path +@@ -12,6 +11,11 @@ import re + import tempfile + import sys + ++try: ++ from collections.abc import MutableSet ++except ImportError: ++ from collections import MutableSet ++ + + # A minimal memoizing decorator. It'll blow up if the args aren't immutable, + # among other "problems". +@@ -494,7 +498,7 @@ def uniquer(seq, idfun=None): + + + # Based on http://code.activestate.com/recipes/576694/. +-class OrderedSet(collections.MutableSet): ++class OrderedSet(MutableSet): + def __init__(self, iterable=None): + self.end = end = [] + end += [None, end, end] # sentinel node for doubly linked list +diff --git a/pylib/gyp/generator/msvs.py b/pylib/gyp/generator/msvs.py +index 843e7067..327fe8d2 100644 +--- a/pylib/gyp/generator/msvs.py ++++ b/pylib/gyp/generator/msvs.py +@@ -4,7 +4,7 @@ + + from __future__ import print_function + +-import collections ++from collections import OrderedDict + import copy + import ntpath + import os +@@ -195,7 +195,7 @@ def _ConvertSourcesToFilterHierarchy(sources, prefix=None, excluded=None, + if not prefix: prefix = [] + result = [] + excluded_result = [] +- folders = collections.OrderedDict() ++ folders = OrderedDict() + # Gather files into the final result, excluded, or folders. + for s in sources: + if len(s) == 1: diff --git a/base/gyp/gyp.SMBuild b/base/gyp/gyp.SMBuild new file mode 100755 index 0000000..352c479 --- /dev/null +++ b/base/gyp/gyp.SMBuild @@ -0,0 +1,36 @@ +APP=gyp +VERSION=20200512 +BUILD=1sml +HOMEPAGE='https://gyp.gsrc.io/' +DESC="Meta-Build system that generates other build systems" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION"_caa60026" + +tar xf $SRCDIR/$APP-$VERSION"_caa60026".tar.?z* + cd $APP-$VERSION"_caa60026" + fixbuilddirpermissions + + patch -p1 < $SRCDIR/gyp-fix-cmake.patch + patch -p1 < $SRCDIR/gyp-ninja-build.patch + patch -p1 < $SRCDIR/gyp-python3.patch + patch -p1 < $SRCDIR/gyp-python38.patch + patch -p1 < $SRCDIR/gyp-python39.patch + + python3 setup.py install --prefix="" --root="$PKG" + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +23a23e85eae9c7d92acea47a7e35b359ebe7f4039521276d0bbaf0fbcabe46c75351a2276185f2a478fb1cd04ccbf77b49aa553e63d6342e2fea219644a4010e gyp-20200512_caa60026.tar.xz +09ddf9b2ae8bcaba7e419522ab51968613214928d76f386daf947f9af1f456f0979c9b22481f5747f67afd9b2cb9b8396a54148978c5c8692f22b7c68d44807e gyp-fix-cmake.patch +c8a03c7904447b8b75c98a71c5c7891acbd94479d52bd7be402dbe142430bf31a9a102fadd8b627d3c95cf72ff8321abbb282a4230af390bfb7e08e04e0af710 gyp-ninja-build.patch +ea9d5d27ec10094a27cb27a739a4be08d0c65cf0a33e3c9cecb896b7fe0502be89a93ef3aa1cc1a0938a5a89f0af96e6c6035737419d0a8b32a79bc13db479c1 gyp-python3.patch +5edaec75a092270d75cf8161f39efbef92c80b3d71e413f9ae15a5ff2b02fdb83a5b5fbed5a666ea7683cbb16fe9b203ee5aa453b76e4bfcb3a9fd977c517e97 gyp-python38.patch +4fec654f18344edd9bb8a9d4838f2405e56e6ff2aaa459cea740d5a5cfbef3176449733a00a3a70c80858e7426b651f99c8e1ad1cbe28e4b40d55612af5f6fae gyp-python39.patch +" diff --git a/base/gzip/gnulibfix b/base/gzip/gnulibfix new file mode 100755 index 0000000..72b30fa --- /dev/null +++ b/base/gzip/gnulibfix @@ -0,0 +1,185 @@ +#!/bin/sh +empty_file() { + rm -f "$1" + touch "$1" +} + +dir="$1" +# fix files breaking the build entirely +for i in freadahead.c fseterr.c ; do empty_file "$dir"/$i ; done +echo "void close_stdin(void) {}" > "$dir"/closein.c + +# fix stuff trying to reimplement libc +culprits=`cat << EOF +accept4 +acosl +alloca +alphasort +asinl +asprintf +atanl +atexit +atoll +bcopy +btowc +chown +closedir +cosl +dirfd +dprintf +dup2 +dup3 +_Exit +expl +fchdir +fchown-stub +fdatasync +fdopendir +ffs +flock +fnmatch +forkpty +fpending +fprintf +freeaddrinfo +fsync +ftell +ftruncate +futimens +gai_strerror +getaddrinfo +getdelim +getdtablesize +getgroups +gethostname +getline +getlogin +getlogin_r +getnameinfo +getpagesize +getpass +getsubopt +gettimeofday +getusershell +gmtime_r +grantpt +imaxabs +imaxdiv +inet_ntop +inet_pton +isblank +iswblank +lchmod +lchown +ldexp +ldexpl +link +linkat +logl +mbrlen +mbrtowc +mbsinit +memmove +mempcpy +mkdtemp +mkfifo +mkfifoat +mknod +mknodat +mkstemp +mktime +nanosleep +nl_langinfo +open +openat +opendir +openpty +pclose +perror +pipe +pipe2 +poll +popen +pread +pselect +ptsname +pwrite +raise +readdir +readlink +renameat +rewinddir +setenv +sigaction +sigaddset +sigdelset +sigemptyset +sigfillset +sigismember +sigpending +sigprocmask +sinl +snprintf +spawnattr_destroy +spawnattr_getdefault +spawnattr_getflags +spawnattr_getpgroup +spawnattr_getsigmask +spawnattr_init +spawnattr_setdefault.c +spawnattr_setflags +spawnattr_setpgroup +spawnattr_setsigmask +spawn_faction_addclose +spawn_faction_adddup2 +spawn_faction_addopen +spawn_faction_destroy +spawn_faction_init +spawn_factions_addopen +spawn_factions_destroy +spawn_factions_init +sprintf +sqrtl +stdio-read +stdio-write +strcasecmp +strcasestr +strchrnul +strcspn +strncasecmp +strndup +strnlen +strpbrk +strsep +strsignal +strstr +strtod +strtoimax +strtol +symlink +symlinkat +tanl +tcgetsid +timegm +time_r +times +tmpfile +uname +unlockpt +unsetenv +usleep +vasprintf +vdprintf +waitpid +wcrtomb +wctob +EOF +` +#fixme check fsusage +flags="-Drpl_tzset=tzset -Drpl_localtime=localtime -Dgnu_fnmatch=fnmatch \ + -Dposix_fnmatch=fnmatch -Drpl_gmtime=gmtime" +for i in $culprits ; do + empty_file "$dir"/$i.c + flags="$flags -Drpl_$i=$i" +done +printf "%s\n" "$flags" diff --git a/base/gzip/gzip.SMBuild b/base/gzip/gzip.SMBuild new file mode 100755 index 0000000..7e333a2 --- /dev/null +++ b/base/gzip/gzip.SMBuild @@ -0,0 +1,33 @@ +APP=gzip +VERSION=1.10 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/gzip/' +DOWNLOAD='https://ftp.gnu.org/gnu/gzip/gzip-1.10.tar.gz' +DESC="GNU file compression utility" +REQUIRES="less" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + #$SRCDIR/gnulibfix lib + #CPPFLAGS="-Drpl_fdopendir=fdopendir -DS_IRWXUGO=077 -DO_BINARY=0" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make V=1 + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7939043e74554ced0c1c05d354ab4eb36cd6dce89ad79d02ccdc5ed6b7ee390759689b2d47c07227b9b44a62851afe7c76c4cae9f92527d999f3f1b4df1cccff gzip-1.10.tar.gz +" diff --git a/base/haveged/haveged.SMBuild b/base/haveged/haveged.SMBuild new file mode 100755 index 0000000..2ebddb0 --- /dev/null +++ b/base/haveged/haveged.SMBuild @@ -0,0 +1,34 @@ +APP=haveged +VERSION=1.9.2 +BUILD=1sml +HOMEPAGE='https://github.com/jirka-h/haveged' +DOWNLOAD='http://www.issihosts.com/haveged/haveged-1.9.2.tar.gz' +DESC="entropy daemon especially suited for low-powered devices" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sbindir=/bin \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e8f934fe8acc5229338e684de32a32d1011fd7dbd64d1fd9b1f4a7b8bf1045a628fca5a2fea871ab367726c7fba834ae500c37ad7ae49742fac7e3c2c546ec5a haveged-1.9.2.tar.lz +" diff --git a/base/hdparm/hdparm.SMBuild b/base/hdparm/hdparm.SMBuild new file mode 100755 index 0000000..616fabc --- /dev/null +++ b/base/hdparm/hdparm.SMBuild @@ -0,0 +1,27 @@ +APP=hdparm +VERSION=9.58 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/hdparm' +DOWNLOAD='https://sourceforge.net/projects/hdparm/files/hdparm/hdparm-9.58.tar.gz' +DESC="hard disk information utility" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make V=s + make install DESTDIR=$PKG mandir="/share/man" sbindir="/bin" + + cp LICENSE.TXT $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2c87e03c7ccb85b57851ea2f9d69688a62c264ae76bf10e08b6bb13813cdd33b76226ad21961e44e21fedd7aff9900ecfe4992426589ff4ce8bd67a7cd141f25 hdparm-9.58.tar.lz +" diff --git a/base/highlight/highlight.SMBuild b/base/highlight/highlight.SMBuild new file mode 100755 index 0000000..c6a1e6b --- /dev/null +++ b/base/highlight/highlight.SMBuild @@ -0,0 +1,27 @@ +APP=highlight +VERSION=4.0 +BUILD=1sml +HOMEPAGE='http://www.andre-simon.de/doku/highlight/en/highlight.php' +DOWNLOAD='http://www.andre-simon.de/zip/highlight-4.0.tar.bz2' +DESC="a universal syntax highlighter" +REQUIRES="gcc-libs musl lua53 readline netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + make install PREFIX="/" DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f790e86daa0f4ab1f812f55eb374ddfdb6533870851a6b59869784d5a1a1698e22cc25b6373297f57712c5aa8f06b3614d9ef840251750cacb21070fdc038d65 highlight-4.0.tar.bz2 +" diff --git a/base/htop/htop.SMBuild b/base/htop/htop.SMBuild new file mode 100755 index 0000000..fa775ec --- /dev/null +++ b/base/htop/htop.SMBuild @@ -0,0 +1,35 @@ +APP=htop +VERSION=2.2.0 +BUILD=1sml +HOMEPAGE='https://htop.dev/' +DOWNLOAD='https://github.com/htop-dev/htop/archive/refs/tags/2.2.0.tar.gz' +DESC="ncurses-based interactive process viewer written in C" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sysconfdir=/etc \ + --disable-unicode \ + --enable-cgroup \ + --enable-taskstats + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a2f9745572bc424ff6e5290285adaf6f76f635b140f310a727b8ec551e93369a780025d336594853a1769bbc00c299d3772ca3bea5e3f74a47144be5658a41a7 htop-2.2.0.tar.lz +" diff --git a/base/hunspell/hunspell.SMBuild b/base/hunspell/hunspell.SMBuild new file mode 100755 index 0000000..039b446 --- /dev/null +++ b/base/hunspell/hunspell.SMBuild @@ -0,0 +1,32 @@ +APP=hunspell +VERSION=1.7.0 +BUILD=1sml +HOMEPAGE='http://hunspell.github.io/' +DOWNLOAD='https://github.com/hunspell/hunspell/files/2573619/hunspell-1.7.0.tar.gz' +DESC="spell checker based on OpenOffice.org myspell library" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --disable-nls + + make V=1 + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2b99cdb3c5ae2c0c797b482cc020455cb16c1f61538ac178be5f937a9c8f348fa0ba091c66619dd53b43934d0ec3548c54b33ef5be3890814b53c152d0948b7b hunspell-1.7.0.tar.lz +" diff --git a/base/hyphen/hyphen.SMBuild b/base/hyphen/hyphen.SMBuild new file mode 100755 index 0000000..34391c3 --- /dev/null +++ b/base/hyphen/hyphen.SMBuild @@ -0,0 +1,31 @@ +APP=hyphen +VERSION=2.8.8 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/hunspell/files/Hyphen/' +DOWNLOAD='https://sourceforge.net/projects/hunspell/files/Hyphen/2.8/hyphen-2.8.8.tar.gz' +DESC="TeX hyphenation library" +REQUIRES="perl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a864bd252ebe782ea8d9064bfd0a30ab398d4f44b1e0c76c3409ec8f9316886d38dc2b4dc7512faff6ee0364f814ebd344a164b933504b38ea81c9704ae73543 hyphen-2.8.8.tar.lz +" diff --git a/base/i2c-tools/i2c-tools.SMBuild b/base/i2c-tools/i2c-tools.SMBuild new file mode 100755 index 0000000..5e21256 --- /dev/null +++ b/base/i2c-tools/i2c-tools.SMBuild @@ -0,0 +1,27 @@ +APP=i2c-tools +VERSION=4.1 +BUILD=1sml +HOMEPAGE='https://i2c.wiki.kernel.org/index.php/I2C_Tools' +DOWNLOAD='https://mirrors.edge.kernel.org/pub/software/utils/i2c-tools/i2c-tools-4.1.tar.gz' +DESC="Utilties to read and program data from I2C-protocol based sensors" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + make install PREFIX="/" mandir="/share/man" DESTDIR="$PKG" sbindir="/bin" + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +476bd9172a57c20894c7e0b07e567fdc85e8c9b05697a839cddaff1ea45824843934581ed2fb738ced5bf273763e2429d27443edc89b725c3f4e98914732b1dc i2c-tools-4.1.tar.lz +" diff --git a/base/icu/icu.SMBuild b/base/icu/icu.SMBuild new file mode 100755 index 0000000..98686e8 --- /dev/null +++ b/base/icu/icu.SMBuild @@ -0,0 +1,39 @@ +APP=icu +VERSION=69.1 +BUILD=1sml +HOMEPAGE='' +DOWNLOAD='' +HOMEPAGE='http://www.icu-project.org/' +DOWNLOAD='https://github.com/unicode-org/icu/releases/download/release-67-1/icu4c-67_1-src.tgz' +DESC="International Components for Unicode" +REQUIRES="gcc-libs python3" + +build() { + mkandenterbuilddir + rm -rf "$APP" + + SVERSION="$(echo $VERSION | sed 's/\./_/g')" + tar xf $SRCDIR/icu4c-"$SVERSION"-src.tar.lz + cd icu + fixbuilddirpermissions + + cd source + CFLAGS="$CFLAGS" \ + ./configure \ + --prefix="" \ + --sbindir=/bin \ + --disable-tests \ + --disable-samples \ + --disable-static + + make + make install DESTDIR=$PKG + + cp ../LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +45767114fb41ae55589da151970f22769065cfe57ca723d95349293cb1705cb09c041f09fbb4c4aec0ced562467e5b7f6a058e18230c2aa6f15dd6f491140a6e icu4c-69_1-src.tar.lz +" diff --git a/base/id3lib/10-fix-compilation-with-cpp-headers.patch b/base/id3lib/10-fix-compilation-with-cpp-headers.patch new file mode 100644 index 0000000..9f1eb33 --- /dev/null +++ b/base/id3lib/10-fix-compilation-with-cpp-headers.patch @@ -0,0 +1,21 @@ +--- a/include/id3/id3lib_strings.h ++++ b/include/id3/id3lib_strings.h +@@ -30,6 +30,7 @@ + #define _ID3LIB_STRINGS_H_ + + #include ++#include + + #if (defined(__GNUC__) && (__GNUC__ >= 3) || (defined(_MSC_VER) && _MSC_VER > 1000)) + namespace std +--- a/include/id3/writers.h ++++ b/include/id3/writers.h +@@ -30,7 +30,7 @@ + + #include "id3/writer.h" + #include "id3/id3lib_streams.h" +-//#include ++#include + + class ID3_CPP_EXPORT ID3_OStreamWriter : public ID3_Writer + { diff --git a/base/id3lib/30-fix-utf16.patch b/base/id3lib/30-fix-utf16.patch new file mode 100644 index 0000000..3d3f50f --- /dev/null +++ b/base/id3lib/30-fix-utf16.patch @@ -0,0 +1,38 @@ +Patch from 'Spoon' to fix issues with writing certain unicode characters +--- a/ChangeLog ++++ b/ChangeLog +@@ -1,3 +1,8 @@ ++2006-02-17 Jerome Couderc ++ ++ * Patch from Spoon to fix UTF-16 writing bug ++ http://sourceforge.net/tracker/index.php?func=detail&aid=1016290&group_id=979&atid=300979 ++ + 2003-03-02 Sunday 17:38 Thijmen Klok + + * THANKS (1.20): added more people +--- a/src/io_helpers.cpp ++++ b/src/io_helpers.cpp +@@ -363,11 +363,22 @@ + // Write the BOM: 0xFEFF + unicode_t BOM = 0xFEFF; + writer.writeChars((const unsigned char*) &BOM, 2); ++ // Patch from Spoon : 2004-08-25 14:17 ++ // http://sourceforge.net/tracker/index.php?func=detail&aid=1016290&group_id=979&atid=300979 ++ // Wrong code ++ //for (size_t i = 0; i < size; i += 2) ++ //{ ++ // unicode_t ch = (data[i] << 8) | data[i+1]; ++ // writer.writeChars((const unsigned char*) &ch, 2); ++ //} ++ // Right code ++ unsigned char *pdata = (unsigned char *) data.c_str(); + for (size_t i = 0; i < size; i += 2) + { +- unicode_t ch = (data[i] << 8) | data[i+1]; ++ unicode_t ch = (pdata[i] << 8) | pdata[i+1]; + writer.writeChars((const unsigned char*) &ch, 2); + } ++ // End patch + } + return writer.getCur() - beg; + } diff --git a/base/id3lib/50-remove-outdated-check.patch b/base/id3lib/50-remove-outdated-check.patch new file mode 100644 index 0000000..386da27 --- /dev/null +++ b/base/id3lib/50-remove-outdated-check.patch @@ -0,0 +1,11 @@ +We don't actually need iomanip.h +--- a/configure.in ++++ b/configure.in +@@ -227,7 +227,6 @@ + ) + AC_CHECK_HEADERS( \ + string \ +- iomanip.h \ + ,,AC_MSG_ERROR([Missing a vital header file for id3lib]) + ) + diff --git a/base/id3lib/60-id3lib-missing-nullpointer-check.patch b/base/id3lib/60-id3lib-missing-nullpointer-check.patch new file mode 100644 index 0000000..d4ca5d2 --- /dev/null +++ b/base/id3lib/60-id3lib-missing-nullpointer-check.patch @@ -0,0 +1,12 @@ +This patch adds a check for a null pointer +--- a/src/header_tag.cpp ++++ b/src/header_tag.cpp +@@ -54,7 +54,7 @@ + { + size_t bytesUsed = ID3_TagHeader::SIZE; + +- if (_info->is_extended) ++ if (_info && _info->is_extended) + { + bytesUsed += _info->extended_bytes; + } diff --git a/base/id3lib/61-fix_vbr_stack_smash.patch b/base/id3lib/61-fix_vbr_stack_smash.patch new file mode 100644 index 0000000..441256b --- /dev/null +++ b/base/id3lib/61-fix_vbr_stack_smash.patch @@ -0,0 +1,19 @@ +Description: Fix crashes when reading VBR MP3 file. +Bug-Ubuntu: https://launchpad.net/bugs/444466 +Origin: upstream, http://sourceforge.net/tracker/?func=detail&aid=937707&group_id=979&atid=300979 +Forwarded: yes +Author: Urs Fleisch + +Index: id3lib3.8.3-3.8.3/src/mp3_parse.cpp +=================================================================== +--- a/src/mp3_parse.cpp 2009-10-06 23:12:10.381250132 +0200 ++++ b/src/mp3_parse.cpp 2009-10-06 23:14:09.545252591 +0200 +@@ -465,7 +465,7 @@ + // from http://www.xingtech.com/developer/mp3/ + + const size_t VBR_HEADER_MIN_SIZE = 8; // "xing" + flags are fixed +- const size_t VBR_HEADER_MAX_SIZE = 116; // frames, bytes, toc and scale are optional ++ const size_t VBR_HEADER_MAX_SIZE = 120; // frames, bytes, toc and scale are optional + + if (mp3size >= vbr_header_offest + VBR_HEADER_MIN_SIZE) + { diff --git a/base/id3lib/CVE-2007-4460.patch b/base/id3lib/CVE-2007-4460.patch new file mode 100644 index 0000000..7fcab02 --- /dev/null +++ b/base/id3lib/CVE-2007-4460.patch @@ -0,0 +1,55 @@ +This patch fixes an issues where temporary files were created in an insecure +way. + +It was first intruduced in version 3.8.3-7 and fixes +http://bugs.debian.org/438540 +--- a/src/tag_file.cpp ++++ b/src/tag_file.cpp +@@ -242,8 +242,8 @@ + strcpy(sTempFile, filename.c_str()); + strcat(sTempFile, sTmpSuffix.c_str()); + +-#if ((defined(__GNUC__) && __GNUC__ >= 3 ) || !defined(HAVE_MKSTEMP)) +- // This section is for Windows folk && gcc 3.x folk ++#if !defined(HAVE_MKSTEMP) ++ // This section is for Windows folk + fstream tmpOut; + createFile(sTempFile, tmpOut); + +@@ -257,7 +257,7 @@ + tmpOut.write((char *)tmpBuffer, nBytes); + } + +-#else //((defined(__GNUC__) && __GNUC__ >= 3 ) || !defined(HAVE_MKSTEMP)) ++#else //!defined(HAVE_MKSTEMP) + + // else we gotta make a temp file, copy the tag into it, copy the + // rest of the old file after the tag, delete the old file, rename +@@ -270,7 +270,7 @@ + //ID3_THROW_DESC(ID3E_NoFile, "couldn't open temp file"); + } + +- ofstream tmpOut(fd); ++ ofstream tmpOut(sTempFile); + if (!tmpOut) + { + tmpOut.close(); +@@ -285,14 +285,14 @@ + uchar tmpBuffer[BUFSIZ]; + while (file) + { +- file.read(tmpBuffer, BUFSIZ); ++ file.read((char *)tmpBuffer, BUFSIZ); + size_t nBytes = file.gcount(); +- tmpOut.write(tmpBuffer, nBytes); ++ tmpOut.write((char *)tmpBuffer, nBytes); + } + + close(fd); //closes the file + +-#endif ////((defined(__GNUC__) && __GNUC__ >= 3 ) || !defined(HAVE_MKSTEMP)) ++#endif ////!defined(HAVE_MKSTEMP) + + tmpOut.close(); + file.close(); + diff --git a/base/id3lib/id3lib.SMBuild b/base/id3lib/id3lib.SMBuild new file mode 100755 index 0000000..6b4fcc7 --- /dev/null +++ b/base/id3lib/id3lib.SMBuild @@ -0,0 +1,51 @@ +APP=id3lib +VERSION=3.8.3 +BUILD=1sml +HOMEPAGE='http://id3lib.sourceforge.net/' +DOWNLOAD='https://sourceforge.net/projects/id3lib/files/id3lib/3.8.3/id3lib-3.8.3.tar.gz' +DESC="ID3 tag manipulation library" +REQUIRES="gcc-libs zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/10-fix-compilation-with-cpp-headers.patch + patch -p1 < $SRCDIR/30-fix-utf16.patch + patch -p1 < $SRCDIR/50-remove-outdated-check.patch + patch -p1 < $SRCDIR/60-id3lib-missing-nullpointer-check.patch + patch -p1 < $SRCDIR/61-fix_vbr_stack_smash.patch + patch -p1 < $SRCDIR/CVE-2007-4460.patch + + libtoolize -fc + aclocal + autoconf + automake --add-missing --copy + + # TODO: disable static libs generation + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +51bcf7249d174b48d33bced8a814a08ce084e3d31894f6673cd0d80092fa745bcb26afdfce767c38ce4dc1c593c4eddcb8cd5ac2e1a3a0d3196647f6bc7f1181 id3lib-3.8.3.tar.lz +a21024c20abb918081ea87be2114d9dc957cfe5d776e0942d2ef2ae450fa73f36236eaf5d50e1a14e293ca927bb95328da8c65a4ae6af6f43574ace3be0ad260 10-fix-compilation-with-cpp-headers.patch +811e1cc121a965fd0b6162a8937475e3d7dc2a477289707a28f6961ca2b9886b98508a954b12a36c27206202673ebd9ae6ec37d175c947e4e560ac112309ec6d 30-fix-utf16.patch +137732ceee8ec7fc8b686e46bd43276fba6bdcbdce166e85108e7c4b456523b4a29b11ff3101a37489e2386c92dfbe7f088f79c9c054f30515095f2b68c89f48 50-remove-outdated-check.patch +ebb536a3bce83ee8752905766f93c7920d548e85262704d617b3e608a020bca0909f5c59525caa2bbc2f034e2d11fb3eb0842d2b167e00c3ef4551c9eb57adf9 60-id3lib-missing-nullpointer-check.patch +debecda3ace7b8ced35d06f33cee922b5f0c43bcf17b9bc7c859e1910a54d4ddb69930b31104ed66702d5bc011859c6724d3df6ece153cc836a992ff19300d70 61-fix_vbr_stack_smash.patch +d534a1b4ce2fa186c089969c245ffc30c75d3e2b4c67b5a5d4b61fc9a8df04f9b2d5f1e13504b0e2f45540d774d5653c3dfa6e7dee9a12c99e7668a0b35fe8b2 CVE-2007-4460.patch +" diff --git a/base/ijs/ijs.SMBuild b/base/ijs/ijs.SMBuild new file mode 100755 index 0000000..c1875d7 --- /dev/null +++ b/base/ijs/ijs.SMBuild @@ -0,0 +1,34 @@ +APP=ijs +VERSION=0.35 +BUILD=1sml +HOMEPAGE='https://www.openprinting.org/download/ijs/' +DOWNLOAD='https://www.openprinting.org/download/ijs/download/ijs-0.35.tar.bz2' +DESC="print library for transmission of raster page images" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --mandir=/share/man \ + --enable-shared \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b5f8df6fe394efea4ee7059c1ca8d7eb91588f060642da12f6591f0f40d169883aa9f7a6976a00042c89dd370b30f36afc407c4e7515cbd68537505a63c9a293 ijs-0.35.tar.bz2 +" diff --git a/base/initfs/doinst.sh b/base/initfs/doinst.sh new file mode 100644 index 0000000..4447630 --- /dev/null +++ b/base/initfs/doinst.sh @@ -0,0 +1,54 @@ +#!/bin/sh +config() { + NEW="$1" + OLD="`dirname $NEW`/`basename $NEW .new`" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/mtab.new +config etc/fstab.new +config etc/inittab.new +config etc/motd.new +config etc/group.new +config etc/profile.new +config etc/hosts.new +config etc/shadow.new +config etc/passwd.new +config etc/networks.new +config etc/hostname.new +config etc/issue.new +config etc/shells.new +config etc/services.new +config etc/resolv.conf.new +config etc/rc.d/rc.start.new +config etc/rc.d/rc.stop.new +config etc/rc.d/rc.network.new +config etc/rc.d/rc.modules.new +config etc/rc.d/rc.gtk.new +config etc/rc.d/rc.local.new + +# Clean up useless non-examples: +rm -f etc/mtab.new +rm -f etc/motd.new +rm -f etc/hosts.new +#rm -f etc/shadow.new +rm -f etc/networks.new +rm -f etc/hostname.new +rm -f etc/shells.new +rm -f etc/issue.new + +# Also ensure ownerships/perms: +chown root.shadow etc/shadow +chmod 640 etc/shadow +( cd . ; ln -sf bin sbin ) +( cd . ; ln -sf . usr ) +( cd . ; ln -sf lib lib64 ) +( cd var/service ; rm -rf tty1 ) +( cd var/service ; ln -sf ../../etc/service/tty1 tty1 ) +( cd var/service ; rm -rf tty2 ) +( cd var/service ; ln -sf ../../etc/service/tty2 tty2 ) diff --git a/base/initfs/initfs.SMBuild b/base/initfs/initfs.SMBuild new file mode 100755 index 0000000..6081d85 --- /dev/null +++ b/base/initfs/initfs.SMBuild @@ -0,0 +1,31 @@ +APP=initfs +VERSION=0.1 +BUILD=1sml +HOMEPAGE='http://git.pktsurf.in/smlinux/tree/base/initfs' +DESC="initfs - initial file system hierarchy creator" +REQUIRES="musl" +ARCH=noarch + +build() { + mkandenterbuilddir + + cd $PKG + tar xf $SRCDIR/$APP.tar.lz + + mv initfs/* . + rmdir initfs + + mkdir -p install + chmod 1777 tmp + chmod 0700 root + + cp $SRCDIR/doinst.sh install/ + + install -Dm 755 $SRCDIR/$APP.SMBuild $PKG/doc/$APP-$VERSION/$APP.SMBuild + /bin/makepkg -l n -c n $PKGDEST/$APP-$VERSION-$ARCH-$BUILD.$PKGEXT + [ "$?" = "0" ] && SM_PKGSTATUS=0 +} + +SHA512SUMS=" +85da0195b5e58c2b01f6ab91ed7a15ebff783325b08c5ed10722e6576974c1cedf55767eb30ccf58f41fc6c88171810ee63a0d7c7d09eb925c0572802d7754de initfs.tar.lz +" diff --git a/base/initfs/initfs/bin/runsvdir-start b/base/initfs/initfs/bin/runsvdir-start new file mode 100755 index 0000000..7b6047a --- /dev/null +++ b/base/initfs/initfs/bin/runsvdir-start @@ -0,0 +1,3 @@ +#!/bin/sh +PATH=/local/bin:/bin +exec runsvdir -P /var/service 'log: ................................................................................................................................................................................................................................................................' diff --git a/base/initfs/initfs/etc/DIR_COLORS b/base/initfs/initfs/etc/DIR_COLORS new file mode 100644 index 0000000..8500da6 --- /dev/null +++ b/base/initfs/initfs/etc/DIR_COLORS @@ -0,0 +1,236 @@ +# Configuration file for dircolors, a utility to help you set the +# LS_COLORS environment variable used by GNU ls with the --color option. + +# The keywords COLOR, OPTIONS, and EIGHTBIT (honored by the +# slackware version of dircolors) are recognized but ignored. +# (see the scripts in /etc/profile.d/coreutils-dircolors.* to change default +# options in the Slackware aliases) + +# Below, there should be one TERM entry for each termtype that is colorizable +TERM Eterm +TERM ansi +TERM color-xterm +TERM con132x25 +TERM con132x30 +TERM con132x43 +TERM con132x60 +TERM con80x25 +TERM con80x28 +TERM con80x30 +TERM con80x43 +TERM con80x50 +TERM con80x60 +TERM cons25 +TERM console +TERM cygwin +TERM dtterm +TERM eterm-color +TERM gnome +TERM gnome-256color +TERM jfbterm +TERM konsole +TERM kterm +TERM linux +TERM linux-c +TERM mach-color +TERM mlterm +TERM putty +TERM rxvt +TERM rxvt-256color +TERM rxvt-cygwin +TERM rxvt-cygwin-native +TERM rxvt-unicode +TERM rxvt-unicode-256color +TERM rxvt-unicode256 +TERM screen +TERM screen-256color +TERM screen-256color-bce +TERM screen-bce +TERM screen-w +TERM screen.linux +TERM screen.rxvt +TERM terminator +TERM vt100 +TERM xterm +TERM xterm-16color +TERM xterm-256color +TERM xterm-88color +TERM xterm-color +TERM xterm-debian + +# Below are the color init strings for the basic file types. A color init +# string consists of one or more of the following numeric codes: +# Attribute codes: +# 00=none 01=bold 04=underscore 05=blink 07=reverse 08=concealed +# Text color codes: +# 30=black 31=red 32=green 33=yellow 34=blue 35=magenta 36=cyan 37=white +# Background color codes: +# 40=black 41=red 42=green 43=yellow 44=blue 45=magenta 46=cyan 47=white +NORMAL 00 # global default, although everything should be something. +FILE 00 # normal file +# RESET 0 # reset to "normal" color +DIR 07;36 # directory +LINK 01;36 # symbolic link. (If you set this to 'target' instead of a + # numerical value, the color is as for the file pointed to.) +# HARDLINK 44;37 # regular file with more than one link +FIFO 40;33 # pipe +SOCK 01;35 # socket +DOOR 01;35 # door +BLK 40;33;01 # block device driver +CHR 40;33;01 # character device driver +ORPHAN 40;31;01 # symlink to nonexistent file +SETUID 37;41 # file that is setuid (u+s) +SETGID 30;43 # file that is setgid (g+s) +CAPABILITY 30;41 # file with capability +STICKY_OTHER_WRITABLE 30;42 # dir that is sticky and other-writable (+t,o+w) +OTHER_WRITABLE 34;42 # dir that is other-writable (o+w) and not sticky +STICKY 37;44 # dir with the sticky bit set (+t) and not other-writable +EXEC 01;32 # This is for files with execute permission: + +# List any file extensions like '.gz' or '.tar' that you would like ls +# to colorize below. Put the extension, a space, and the color init string. +# (and any comments you want to add after a '#') + +# DOS-style executables (bright green) +.bat 01;32 +.BAT 01;32 +.btm 01;32 +.BTM 01;32 +.cmd 01;32 +.CMD 01;32 +.com 01;32 +.COM 01;32 +.dll 01;32 +.DLL 01;32 +.exe 01;32 +.EXE 01;32 + +# archives or compressed (bright red) +.7z 01;31 +.ace 01;31 +.ACE 01;31 +.arj 01;31 +.bz2 01;31 +.cpio 01;31 +.deb 01;31 +.dz 01;31 +.gz 01;31 +.lz 01;31 +.jar 01;31 +.lzh 01;31 +.lzma 01;31 +.rar 01;31 +.RAR 01;31 +.rpm 01;31 +.rz 01;31 +.tar 01;31 +.taz 01;31 +.tb2 01;31 +.tbz2 01;31 +.tbz 01;31 +.tgz 01;31 +.tlz 01;31 +.trz 01;31 +.txz 01;31 +.tz 01;31 +.tz2 01;31 +.xz 01;31 +.z 01;31 +.Z 01;31 +.zip 01;31 +.ZIP 01;31 +.zoo 01;31 + +# multimedia (video/image/sound) file formats +.aac 01;35 +.AAC 01;35 +.anx 01;35 +.asf 01;35 +.ASF 01;35 +.au 01;35 +.axa 01;35 +.axv 01;35 +.avi 01;35 +.AVI 01;35 +.bmp 01;35 +.BMP 01;35 +.divx 01;35 +.DIVX 01;35 +.flac 01;35 +.FLAC 01;35 +.gif 01;35 +.GIF 01;35 +.jpg 01;35 +.JPG 01;35 +.jpeg 01;35 +.JPEG 01;35 +.m2a 01;35 +.M2A 01;35 +.m2v 01;35 +.M2V 01;35 +.m4a 01;35 +.M4A 01;35 +.m4p 01;35 +.M4P 01;35 +.m4v 01;35 +.M4V 01;35 +.mid 01;35 +.midi 01;35 +.mka 01;35 +.mkv 01;35 +.MKV 01;35 +.mov 01;35 +.MOV 01;35 +.mp3 01;35 +.MP3 01;35 +.mp4 01;35 +.MP4 01;35 +.mp4v 01;35 +.mpc 01;35 +.MPC 01;35 +.mpeg 01;35 +.MPEG 01;35 +.mpg 01;35 +.MPG 01;35 +.nuv 01;35 +.oga 01;35 +.ogv 01;35 +.ogx 01;35 +.ogg 01;35 +.OGG 01;35 +.pbm 01;35 +.pgm 01;35 +.png 01;35 +.PNG 01;35 +.ppm 01;35 +.qt 01;35 +.ra 01;35 +.RA 01;35 +.ram 01;35 +.RAM 01;35 +.rm 01;35 +.RM 01;35 +.spx 01;35 +.svg 01;35 +.svgz 01;35 +.tga 01;35 +.TGA 01;35 +.tif 01;35 +.TIF 01;35 +.tiff 01;35 +.TIFF 01;35 +.vob 01;35 +.VOB 01;35 +.wav 01;35 +.WAV 01;35 +.wma 01;35 +.WMA 01;35 +.wmv 01;35 +.WMV 01;35 +.xbm 01;35 +.xcf 01;35 +.xpm 01;35 +.xspf 01;35 +.xwd 01;35 +.XWD 01;35 +.xvid 01;35 diff --git a/base/initfs/initfs/etc/fstab.new b/base/initfs/initfs/etc/fstab.new new file mode 100644 index 0000000..d64eedd --- /dev/null +++ b/base/initfs/initfs/etc/fstab.new @@ -0,0 +1,10 @@ +# +# /etc/fstab: static file system information +# + +# +proc /proc proc defaults 0 0 +devpts /dev/pts devpts defaults 0 0 +shm /dev/shm tmpfs nodev,nosuid 0 0 +cgroup /sys/fs/cgroup cgroup defaults +/dev/root / ext4 defaults 0 0 diff --git a/base/initfs/initfs/etc/group.new b/base/initfs/initfs/etc/group.new new file mode 100644 index 0000000..ecd7dec --- /dev/null +++ b/base/initfs/initfs/etc/group.new @@ -0,0 +1,30 @@ +root:x:0:root +nogroup:x:1: +wheel:x:2:root +tty:x:3: +kvm:x:4: +serial:x:5: +disk:x:6:root +video:x:7: +audio:x:8: +floppy:x:9: +users:x:10: +dialout:x:11: +kmem:x:12: +input:x:13: +lp:x:14: +cdrom:x:15: +tape:x:16: +lpadmin:x:100:lp +messagebus:x:101: +postfix:x:102:postfix +postdrop:x:103: +dovecot:x:104:dovecot +dovenull:x:105:dovenull +privoxy:x:106:privoxy +tor:x:107:tor +chrony:x:108:chrony +unbound:x:109:unbound +mysql:x:110: +rpc:x:111: +www-data:x:112: diff --git a/base/initfs/initfs/etc/hostname.new b/base/initfs/initfs/etc/hostname.new new file mode 100644 index 0000000..a624e3d --- /dev/null +++ b/base/initfs/initfs/etc/hostname.new @@ -0,0 +1 @@ +darkstar diff --git a/base/initfs/initfs/etc/hosts.new b/base/initfs/initfs/etc/hosts.new new file mode 100644 index 0000000..6e33147 --- /dev/null +++ b/base/initfs/initfs/etc/hosts.new @@ -0,0 +1,21 @@ +# +# hosts This file describes a number of hostname-to-address +# mappings for the TCP/IP subsystem. It is mostly +# used at boot time, when no name servers are running. +# On small systems, this file can be used instead of a +# "named" name server. Just add the names, addresses +# and any aliases to this file... +# +# By the way, Arnt Gulbrandsen says that 127.0.0.1 +# should NEVER be named with the name of the machine. It causes problems +# for some (stupid) programs, irc and reputedly talk. :^) +# + +# For loopbacking. +127.0.0.1 localhost +# This next entry is technically wrong, but good enough to get TCP/IP apps +# to quit complaining that they can't verify the hostname on a loopback-only +# Linux box. +127.0.0.1 darkstar.example.net darkstar + +# End of hosts. diff --git a/base/initfs/initfs/etc/inittab.new b/base/initfs/initfs/etc/inittab.new new file mode 100644 index 0000000..b9a4567 --- /dev/null +++ b/base/initfs/initfs/etc/inittab.new @@ -0,0 +1,3 @@ +::sysinit:/etc/rc.d/rc.start +::respawn:/bin/runsvdir-start +::shutdown:/etc/rc.d/rc.stop diff --git a/base/initfs/initfs/etc/issue.new b/base/initfs/initfs/etc/issue.new new file mode 100644 index 0000000..b4536ba --- /dev/null +++ b/base/initfs/initfs/etc/issue.new @@ -0,0 +1,2 @@ +SMLinux \n (\s \m \r) (\l) + diff --git a/base/initfs/initfs/etc/mdev.conf b/base/initfs/initfs/etc/mdev.conf new file mode 100644 index 0000000..a517e5c --- /dev/null +++ b/base/initfs/initfs/etc/mdev.conf @@ -0,0 +1,74 @@ +# +# This is a sample mdev.conf. +# + +# Devices: +# Syntax: %s %d:%d %s +# devices user:group mode + +# null does already exist; therefore ownership has to be changed with command +null root:root 0666 @chmod 666 $MDEV +zero root:root 0666 +grsec root:root 0660 +full root:root 0666 + +random root:root 0666 +urandom root:root 0444 +hwrandom root:root 0660 + +# console does already exist; therefore ownership has to be changed with command +#console root:tty 0600 @chmod 600 $MDEV && mkdir -p vc && ln -sf ../$MDEV vc/0 +#console root:tty 0600 @mkdir -pm 755 fd && cd fd && for x in 0 1 2 3 ; do ln -sf /proc/self/fd/$x $x; done +# load frambuffer console when first frambuffer is found +#fb0 root:video 0660 @modprobe fbcon +fb0 root:video 0660 + +#fd0 root:floppy 0660 +#kmem root:root 0640 +#mem root:root 0640 +#port root:root 0640 +ptmx root:tty 0666 + +# ram.* +#ram([0-9]*) root:disk 0660 >rd/%1 +#loop([0-9]+) root:disk 0660 >loop/%1 +#sd[a-z].* root:disk 0660 */lib/mdev/usbdisk_link +#hd[a-z][0-9]* root:disk 0660 */lib/mdev/ide_links +#md[0-9] root:disk 0660 + +tty root:tty 0666 +#tty[0-9] root:root 0600 +#tty[0-9][0-9] root:tty 0660 +#ttyS[0-9]* root:serial 0660 +#pty.* root:tty 0660 +#vcs[0-9]* root:tty 0660 +#vcsa[0-9]* root:tty 0660 + + +#ttyLTM[0-9] root:root 0660 @ln -sf $MDEV modem +#ttySHSF[0-9] root:root 0660 @ln -sf $MDEV modem +#slamr root:root 0660 @ln -sf $MDEV slamr0 +#slusb root:root 0660 @ln -sf $MDEV slusb0 +#fuse root:root 0666 + +# dri device +#card[0-9] root:video 0660 =dri/ + +# alsa sound devices and audio stuff +pcm.* root:audio 0660 =snd/ +control.* root:audio 0660 =snd/ +midi.* root:audio 0660 =snd/ +seq root:audio 0660 =snd/ +timer root:audio 0660 =snd/ + +adsp root:audio 0660 >sound/ +audio root:audio 0660 >sound/ +dsp root:audio 0660 >sound/ +mixer root:audio 0660 >sound/ +sequencer.* root:audio 0660 >sound/ + +# misc stuff +#agpgart root:root 0660 >misc/ +#psaux root:root 0660 >misc/ +#rtc root:root 0664 >misc/ + diff --git a/base/initfs/initfs/etc/motd.new b/base/initfs/initfs/etc/motd.new new file mode 100644 index 0000000..5a6b4b5 --- /dev/null +++ b/base/initfs/initfs/etc/motd.new @@ -0,0 +1,3 @@ +Welcome to SMLinux! +We strongly advise you to change the default root password. +Kindly view the README file for details on changing keymaps. diff --git a/base/initfs/initfs/etc/mtab.new b/base/initfs/initfs/etc/mtab.new new file mode 100644 index 0000000..e69de29 diff --git a/base/initfs/initfs/etc/networks.new b/base/initfs/initfs/etc/networks.new new file mode 100644 index 0000000..50d5162 --- /dev/null +++ b/base/initfs/initfs/etc/networks.new @@ -0,0 +1,10 @@ +# +# networks This file describes a number of netname-to-address +# mappings for the TCP/IP subsystem. It is mostly +# used at boot time, when no name servers are running. +# + +loopback 127.0.0.0 +localnet 127.0.0.0 + +# End of networks. diff --git a/base/initfs/initfs/etc/os-release b/base/initfs/initfs/etc/os-release new file mode 100644 index 0000000..665cb7d --- /dev/null +++ b/base/initfs/initfs/etc/os-release @@ -0,0 +1,4 @@ +NAME="smlinux" +ID="smlinux" +DISTRIB_ID="smlinux" +PRETTY_NAME="SMLinux" diff --git a/base/initfs/initfs/etc/passwd.new b/base/initfs/initfs/etc/passwd.new new file mode 100644 index 0000000..9f9f710 --- /dev/null +++ b/base/initfs/initfs/etc/passwd.new @@ -0,0 +1,14 @@ +root:x:0:0:root:/root:/bin/bash +nobody:x:1:1:nobody:/var/empty:/bin/false +lp:x:100:100:Print Service User:/var/spool/cups:/bin/false +messagebus:x:101:101:User for D-Bus:/var/run/dbus:/bin/false +postfix:x:102:102:SMTP Server:/var/spool/postfix:/bin/false +dovecot:x:104:104:IMAP server:/dev/null:/bin/false +dovenull:x:105:105:IMAP server:/dev/null:/bin/false +privoxy:x:106:106:Web proxy:/dev/null:/bin/false +tor:x:107:107:The Onion Router:/dev/null:/bin/false +chrony:x:108:108:NTP Time Server:/var/lib/chrony:/bin/false +unbound:x:109:109:DNS Server:/etc/unbound:/bin/nologin +mysql:x:110:110:MySQL:/var/lib/mysql:/bin/false +rpc:x:111:111:rpc:/var/lib/rpc:/bin/false +www-data:x:112:112:www-data:/var/www:/bin/nologin diff --git a/base/initfs/initfs/etc/profile.new b/base/initfs/initfs/etc/profile.new new file mode 100644 index 0000000..2f1002a --- /dev/null +++ b/base/initfs/initfs/etc/profile.new @@ -0,0 +1,22 @@ +PATH="/bin" +MANPATH="/share/man" +EDITOR="/bin/vi" +LANG=en_US.UTF-8 +TZ="UTC" +export PATH MANPATH EDITOR LANG TZ + +COLOR=auto +OPTIONS="-F -b -T 0" +LS_OPTIONS="$OPTIONS --color=$COLOR" +export LS_OPTIONS +unset COLOR +unset OPTIONS + +if [ -f /etc/DIR_COLORS ]; then + eval `/bin/dircolors -b /etc/DIR_COLORS` +fi + +alias ls='/bin/ls $LS_OPTIONS' +alias dir='/bin/ls $LS_OPTIONS --format=vertical' + +umask 022 diff --git a/base/initfs/initfs/etc/rc.d/rc.gtk.new b/base/initfs/initfs/etc/rc.d/rc.gtk.new new file mode 100755 index 0000000..7eca5cb --- /dev/null +++ b/base/initfs/initfs/etc/rc.d/rc.gtk.new @@ -0,0 +1,48 @@ +#!/bin/sh +# Thank you slackware + +if [ -x /bin/fc-cache ]; then + echo "Updating X font indexes..." + /bin/fc-cache -f & +fi + +if [ -x /bin/update-desktop-database ]; then + echo "Updating .desktop files..." + /bin/update-desktop-database -q /share/applications >/dev/null 2>&1 +fi + +if find /share/icons -maxdepth 2 2> /dev/null | grep -q icon-theme.cache ; then + for theme_dir in /share/icons/* ; do + echo "Updating icon-theme.cache in ${theme_dir}..." + /bin/gtk-update-icon-cache -t -f ${theme_dir} >/dev/null 2>&1 + done +fi + +if [ -x /bin/update-mime-database ]; then + echo "Updating MIME database..." + /bin/update-mime-database -n /share/mime >/dev/null 2>&1 & +fi + +# Update immodules cache at /lib/gtk-2.0/2.10.0/immodules.cache +if [ -x /bin/gtk-query-immodules-2.0 ]; then + echo "Updating GTK2 Immodules..." + /bin/gtk-query-immodules-2.0 --update-cache > /dev/null 2>&1 & +fi + +# Update immodules cache at /lib/gtk-3.0/3.0.0/immodules.cache +if [ -x /bin/gtk-query-immodules-3.0 ]; then + echo "Updating GTK3 Immodules..." + /bin/gtk-query-immodules-3.0 --update-cache > /dev/null 2>&1 & +fi + +if [ -x /bin/gdk-pixbuf-query-loaders ]; then + echo "Updating GDK Pixbuf loaders..." + /bin/gdk-pixbuf-query-loaders --update-cache >/dev/null 2>&1 & +fi + +if [ -x /bin/glib-compile-schemas ]; then + echo "Compiling GSettings XML scheme files..." + /bin/glib-compile-schemas share/glib-2.0/schemas >/dev/null 2>&1 & +fi + + exit 0 diff --git a/base/initfs/initfs/etc/rc.d/rc.local.new b/base/initfs/initfs/etc/rc.d/rc.local.new new file mode 100755 index 0000000..f64bc9a --- /dev/null +++ b/base/initfs/initfs/etc/rc.d/rc.local.new @@ -0,0 +1,4 @@ +#!/bin/sh +# User-specific stuff that requires root privileges +# Runit services will start after this. +exit 0 diff --git a/base/initfs/initfs/etc/rc.d/rc.modules.new b/base/initfs/initfs/etc/rc.d/rc.modules.new new file mode 100755 index 0000000..a505818 --- /dev/null +++ b/base/initfs/initfs/etc/rc.d/rc.modules.new @@ -0,0 +1,3 @@ +#!/bin/sh +# File to load kernel modules at startup +modprobe loop diff --git a/base/initfs/initfs/etc/rc.d/rc.network.new b/base/initfs/initfs/etc/rc.d/rc.network.new new file mode 100755 index 0000000..b3ec48e --- /dev/null +++ b/base/initfs/initfs/etc/rc.d/rc.network.new @@ -0,0 +1,62 @@ +#!/bin/sh +# Network configuration for SMLinux +# For network bridges, see /etc/rc.d/rc.bridge +if grep -q nfsroot /proc/cmdline ; then + # We are booting from an NFS share already, so disable networking + NETWORKING=no +else + NETWORKING=yes +fi + +PATH=/bin +DHCP=yes +IFACE="eth0" +STATICIP="" # in 192.168.0.2/24 CIDR format +GATEWAY="" +ROUTER=no +ROUTERIFACE="" + +if [ "$NETWORKING" = "yes" ]; then + if [ "$(uname -m)" != "x86_64" ]; then + DHCP=yes + else + DHCP=no + fi + + echo "Initializing network..." + + if [ "$DHCP" = "yes" ]; then + echo "Running DHCP client..." + dhclient "$IFACE" + + elif [ "$DHCP" = "no" ]; then + if [ -z "$STATICIP" ]; then + echo "STATIC IP NOT SET!" + echo "Set it in /etc/rc.d/rc.network" + elif [ -z "$GATEWAY" ]; then + echo "GATEWAY NOT SET!" + echo "Set it in /etc/rc.d/rc.network" + else + echo "Setting static IPs" + ip link set "$IFACE" up + ip addr add "$STATICIP" dev "$IFACE" + ip route add default via "$STATICGW" + fi + fi + + if [ "$ROUTER" = "yes" ]; then + echo "Setting up router configuration" + echo 1 > /proc/sys/net/ipv4/ip_forward + iptables -t nat -A POSTROUTING -o "$ROUTERIFACE" -j MASQUERADE + fi +fi + +# For devices without an RTC +if [ ! -e /dev/rtc0 ]; then + echo "Setting time from busybox NTP" + # run at a higher frequency + busybox ntpd -N + sleep 5 +fi + +exit 0 diff --git a/base/initfs/initfs/etc/rc.d/rc.start.new b/base/initfs/initfs/etc/rc.d/rc.start.new new file mode 100755 index 0000000..c711974 --- /dev/null +++ b/base/initfs/initfs/etc/rc.d/rc.start.new @@ -0,0 +1,67 @@ +#!/bin/sh +export PATH=/bin:/sbin:/usr/bin:/usr/sbin + +echo "Starting SMLinux..." + +mount -t proc proc /proc +mount -t sysfs sysfs /sys + +mount -v -n -t tmpfs tmpfs /run -o mode=0755 + +if which udevd > /dev/null 2>&1 ; then + udevd --daemon + udevadm trigger --action=add --type=subsystems + udevadm trigger --action=add --type=devices + udevadm trigger --action=change --type=devices + udevadm settle +else + echo /sbin/mdev > /proc/sys/kernel/hotplug + mdev -s +fi + +[ -e /dev/rtc0 ] && hwclock -u -s + +echo "Mounting root device read-only." +mount -o ro,remount / + +echo "Running fsck on root file system." +fsck -V -C -A -p +mkdir -p /dev/shm /dev/pts + +echo "Mounting root device read-write." +mount -v -o remount,rw / + +rm -f /etc/mtab{,-,.tmp} && touch /etc/mtab + +# Add entry for / to /etc/mtab: +mount -f -w / + +echo "Mounting non-root local file system." +mount -a + +# Clean up some temporary files: +rm -f /var/run/* /var/run/*/* /var/run/*/*/* /etc/nologin \ + /tmp/.XAuth* 1> /dev/null 2>/dev/null + ( cd /var/log/setup/tmp && rm -rf * ) +rm -f /var/lock/* /tmp/.X*lock /tmp/.X11-unix/* 2> /dev/null + +hostname $(cat /etc/hostname) +ifconfig lo up + +[ -f /etc/random-seed ] && cat /etc/random-seed >/dev/urandom +dd if=/dev/urandom of=/etc/random-seed count=1 bs=512 2>/dev/null + +echo "Logging dmesg output to /var/log/dmesg" +dmesg > /var/log/dmesg.log + +ulimit -c unlimited + +for i in /etc/rc.d/rc.modules \ + /etc/rc.d/rc.gtk \ + /etc/rc.d/rc.network \ + /etc/rc.d/rc.local ; + do [ -x "$i" ] && "$i" ; done + +[ -x /bin/haveged ] && /bin/haveged -w 1024 +[ -x /bin/crond ] && /bin/crond -S +[ -x /etc/rc.d/rc.messagebus ] && /etc/rc.d/rc.messagebus start diff --git a/base/initfs/initfs/etc/rc.d/rc.stop.new b/base/initfs/initfs/etc/rc.d/rc.stop.new new file mode 100755 index 0000000..6ce5441 --- /dev/null +++ b/base/initfs/initfs/etc/rc.d/rc.stop.new @@ -0,0 +1,30 @@ +#!/bin/sh + +export PATH="/bin:/sbin:/usr/bin:/usr/sbin:" + +echo "Shutting down" + +[ -e /dev/rtc0 ] && hwclock -u -w + +sv down /var/service/* + +killall5 -15 +sleep 3 +killall5 -9 + +dd if=/dev/urandom of=/etc/random-seed count=1 bs=512 2>/dev/null + +rm -f /etc/mtab +swapoff -a + +echo "Unmounting filesystems" +umount -a -r -t noproc + +echo "Remounting / as read-only" +mount -o remount,ro / + +sync +sleep 1 +wait + +echo "Powered down!" diff --git a/base/initfs/initfs/etc/resolv.conf.new b/base/initfs/initfs/etc/resolv.conf.new new file mode 100644 index 0000000..1f85a23 --- /dev/null +++ b/base/initfs/initfs/etc/resolv.conf.new @@ -0,0 +1,7 @@ +# Google DNS +nameserver 8.8.8.8 +nameserver 8.8.4.4 +# Cloudflare DNS +#nameserver 1.1.1.1 +#nameserver 1.0.0.1 + diff --git a/base/initfs/initfs/etc/service/tty1/run b/base/initfs/initfs/etc/service/tty1/run new file mode 100755 index 0000000..284385d --- /dev/null +++ b/base/initfs/initfs/etc/service/tty1/run @@ -0,0 +1,2 @@ +#!/bin/sh +exec getty -L 38400 tty1 linux diff --git a/base/initfs/initfs/etc/service/tty2/run b/base/initfs/initfs/etc/service/tty2/run new file mode 100755 index 0000000..2e49f8d --- /dev/null +++ b/base/initfs/initfs/etc/service/tty2/run @@ -0,0 +1,2 @@ +#!/bin/sh +exec getty -L 38400 tty2 linux diff --git a/base/initfs/initfs/etc/services.new b/base/initfs/initfs/etc/services.new new file mode 100644 index 0000000..3b7ac77 --- /dev/null +++ b/base/initfs/initfs/etc/services.new @@ -0,0 +1,2401 @@ +# +# Network services, Internet style +# +# Note that it is presently the policy of IANA to assign a single well-known +# port number for both TCP and UDP; hence, most entries here have two entries +# even if the protocol doesn't support UDP operations. +# +# The latest IANA port assignments can be gotten from +# +# http://www.iana.org/assignments/port-numbers +# +# The Well Known Ports are those from 0 through 1023. +# The Registered Ports are those from 1024 through 49151 +# The Dynamic and/or Private Ports are those from 49152 through 65535 +# +# Kerberos services are for Kerberos v4, and are unofficial. Sites running +# v5 should uncomment v5 entries and comment v4 entries. +# +# $FreeBSD: src/etc/services,v 1.117 2010/02/01 13:30:06 ume Exp $ +# From: @(#)services 5.8 (Berkeley) 5/9/91 +# +# WELL KNOWN PORT NUMBERS +# +rtmp 1/ddp #Routing Table Maintenance Protocol +tcpmux 1/tcp #TCP Port Service Multiplexer +tcpmux 1/udp #TCP Port Service Multiplexer +nbp 2/ddp #Name Binding Protocol +compressnet 2/tcp #Management Utility +compressnet 2/udp #Management Utility +compressnet 3/tcp #Compression Process +compressnet 3/udp #Compression Process +echo 4/ddp #AppleTalk Echo Protocol +rje 5/tcp #Remote Job Entry +rje 5/udp #Remote Job Entry +zip 6/ddp #Zone Information Protocol +echo 7/tcp +echo 7/udp +discard 9/tcp sink null +discard 9/udp sink null +systat 11/tcp users #Active Users +systat 11/udp users #Active Users +daytime 13/tcp +daytime 13/udp +qotd 17/tcp quote #Quote of the Day +qotd 17/udp quote #Quote of the Day +msp 18/tcp #Message Send Protocol +msp 18/udp #Message Send Protocol +chargen 19/tcp ttytst source #Character Generator +chargen 19/udp ttytst source #Character Generator +ftp-data 20/tcp #File Transfer [Default Data] +ftp-data 20/udp #File Transfer [Default Data] +ftp 21/tcp #File Transfer [Control] +ftp 21/udp #File Transfer [Control] +ssh 22/tcp #Secure Shell Login +ssh 22/udp #Secure Shell Login +telnet 23/tcp +telnet 23/udp +# 24/tcp any private mail system +# 24/udp any private mail system +smtp 25/tcp mail #Simple Mail Transfer +smtp 25/udp mail #Simple Mail Transfer +nsw-fe 27/tcp #NSW User System FE +nsw-fe 27/udp #NSW User System FE +msg-icp 29/tcp #MSG ICP +msg-icp 29/udp #MSG ICP +msg-auth 31/tcp #MSG Authentication +msg-auth 31/udp #MSG Authentication +dsp 33/tcp #Display Support Protocol +dsp 33/udp #Display Support Protocol +# 35/tcp any private printer server +# 35/udp any private printer server +time 37/tcp timserver +time 37/udp timserver +rap 38/tcp #Route Access Protocol +rap 38/udp #Route Access Protocol +rlp 39/tcp resource #Resource Location Protocol +rlp 39/udp resource #Resource Location Protocol +graphics 41/tcp +graphics 41/udp +nameserver 42/tcp name #Host Name Server +nameserver 42/udp name #Host Name Server +nicname 43/tcp whois +nicname 43/udp whois +mpm-flags 44/tcp #MPM FLAGS Protocol +mpm-flags 44/udp #MPM FLAGS Protocol +mpm 45/tcp #Message Processing Module [recv] +mpm 45/udp #Message Processing Module [recv] +mpm-snd 46/tcp #MPM [default send] +mpm-snd 46/udp #MPM [default send] +ni-ftp 47/tcp #NI FTP +ni-ftp 47/udp #NI FTP +auditd 48/tcp #Digital Audit Daemon +auditd 48/udp #Digital Audit Daemon +tacacs 49/tcp #Login Host Protocol (TACACS) +tacacs 49/udp #Login Host Protocol (TACACS) +re-mail-ck 50/tcp #Remote Mail Checking Protocol +re-mail-ck 50/udp #Remote Mail Checking Protocol +la-maint 51/tcp #IMP Logical Address Maintenance +la-maint 51/udp #IMP Logical Address Maintenance +xns-time 52/tcp #XNS Time Protocol +xns-time 52/udp #XNS Time Protocol +domain 53/tcp #Domain Name Server +domain 53/udp #Domain Name Server +xns-ch 54/tcp #XNS Clearinghouse +xns-ch 54/udp #XNS Clearinghouse +isi-gl 55/tcp #ISI Graphics Language +isi-gl 55/udp #ISI Graphics Language +xns-auth 56/tcp #XNS Authentication +xns-auth 56/udp #XNS Authentication +# 57/tcp any private terminal access +# 57/udp any private terminal access +xns-mail 58/tcp #XNS Mail +xns-mail 58/udp #XNS Mail +# 59/tcp any private file service +# 59/udp any private file service +ni-mail 61/tcp #NI MAIL +ni-mail 61/udp #NI MAIL +acas 62/tcp #ACA Services +acas 62/udp #ACA Services +whois++ 63/tcp +whois++ 63/udp +covia 64/tcp #Communications Integrator (CI) +covia 64/udp #Communications Integrator (CI) +tacacs-ds 65/tcp #TACACS-Database Service +tacacs-ds 65/udp #TACACS-Database Service +sql*net 66/tcp #Oracle SQL*NET +sql*net 66/udp #Oracle SQL*NET +bootps 67/tcp dhcps #Bootstrap Protocol Server +bootps 67/udp dhcps #Bootstrap Protocol Server +bootpc 68/tcp dhcpc #Bootstrap Protocol Client +bootpc 68/udp dhcpc #Bootstrap Protocol Client +tftp 69/tcp #Trivial File Transfer +tftp 69/udp #Trivial File Transfer +gopher 70/tcp +gopher 70/udp +netrjs-1 71/tcp #Remote Job Service +netrjs-1 71/udp #Remote Job Service +netrjs-2 72/tcp #Remote Job Service +netrjs-2 72/udp #Remote Job Service +netrjs-3 73/tcp #Remote Job Service +netrjs-3 73/udp #Remote Job Service +netrjs-4 74/tcp #Remote Job Service +netrjs-4 74/udp #Remote Job Service +# 75/tcp any private dial out service +# 75/udp any private dial out service +deos 76/tcp #Distributed External Object Store +deos 76/udp #Distributed External Object Store +# 77/tcp any private RJE service +# 77/udp any private RJE service +vettcp 78/tcp +vettcp 78/udp +finger 79/tcp +finger 79/udp +http 80/tcp www www-http #World Wide Web HTTP +http 80/udp www www-http #World Wide Web HTTP +hosts2-ns 81/tcp #HOSTS2 Name Server +hosts2-ns 81/udp #HOSTS2 Name Server +xfer 82/tcp #XFER Utility +xfer 82/udp #XFER Utility +mit-ml-dev 83/tcp #MIT ML Device +mit-ml-dev 83/udp #MIT ML Device +ctf 84/tcp #Common Trace Facility +ctf 84/udp #Common Trace Facility +mit-ml-dev 85/tcp #MIT ML Device +mit-ml-dev 85/udp #MIT ML Device +mfcobol 86/tcp #Micro Focus Cobol +mfcobol 86/udp #Micro Focus Cobol +# 87/tcp any private terminal link +# 87/udp any private terminal link +kerberos-sec 88/tcp kerberos # krb5 # Kerberos (v5) +kerberos-sec 88/udp kerberos # krb5 # Kerberos (v5) +su-mit-tg 89/tcp #SU/MIT Telnet Gateway +su-mit-tg 89/udp #SU/MIT Telnet Gateway +dnsix 90/tcp #DNSIX Securit Attribute Token Map +dnsix 90/udp #DNSIX Securit Attribute Token Map +mit-dov 91/tcp #MIT Dover Spooler +mit-dov 91/udp #MIT Dover Spooler +npp 92/tcp #Network Printing Protocol +npp 92/udp #Network Printing Protocol +dcp 93/tcp #Device Control Protocol +dcp 93/udp #Device Control Protocol +objcall 94/tcp #Tivoli Object Dispatcher +objcall 94/udp #Tivoli Object Dispatcher +supdup 95/tcp +supdup 95/udp +dixie 96/tcp #DIXIE Protocol Specification +dixie 96/udp #DIXIE Protocol Specification +swift-rvf 97/tcp #Swift Remote Virtural File Protocol +swift-rvf 97/udp #Swift Remote Virtural File Protocol +tacnews 98/tcp #TAC News, Unofficial: Red Hat linuxconf +tacnews 98/udp #TAC News, Unofficial: Red Hat linuxconf +metagram 99/tcp #Metagram Relay +metagram 99/udp #Metagram Relay +newacct 100/tcp #[unauthorized use] +hostname 101/tcp hostnames #NIC Host Name Server +hostname 101/udp hostnames #NIC Host Name Server +iso-tsap 102/tcp tsap #ISO-TSAP Class 0 +iso-tsap 102/udp tsap #ISO-TSAP Class 0 +gppitnp 103/tcp #Genesis Point-to-Point Trans Net +gppitnp 103/udp #Genesis Point-to-Point Trans Net +acr-nema 104/tcp #ACR-NEMA Digital Imag. & Comm. 300 +acr-nema 104/udp #ACR-NEMA Digital Imag. & Comm. 300 +csnet-ns 105/tcp cso-ns cso #Mailbox Name Nameserver +csnet-ns 105/udp cso-ns cso #Mailbox Name Nameserver +pop3pw 106/tcp 3com-tsmux #Eudora compatible PW changer +3com-tsmux 106/udp +rtelnet 107/tcp #Remote Telnet Service +rtelnet 107/udp #Remote Telnet Service +snagas 108/tcp #SNA Gateway Access Server +snagas 108/udp #SNA Gateway Access Server +pop2 109/tcp postoffice #Post Office Protocol - Version 2 +pop2 109/udp postoffice #Post Office Protocol - Version 2 +pop3 110/tcp #Post Office Protocol - Version 3 +pop3 110/udp #Post Office Protocol - Version 3 +sunrpc 111/tcp rpcbind #SUN Remote Procedure Call +sunrpc 111/udp rpcbind #SUN Remote Procedure Call +mcidas 112/tcp #McIDAS Data Transmission Protocol +mcidas 112/udp #McIDAS Data Transmission Protocol +auth 113/tcp ident tap #Authentication Service +auth 113/udp ident tap #Authentication Service +sftp 115/tcp #Simple File Transfer Protocol +sftp 115/udp #Simple File Transfer Protocol +ansanotify 116/tcp #ANSA REX Notify +ansanotify 116/udp #ANSA REX Notify +uucp-path 117/tcp #UUCP Path Service +uucp-path 117/udp #UUCP Path Service +sqlserv 118/tcp #SQL Services +sqlserv 118/udp #SQL Services +nntp 119/tcp usenet #Network News Transfer Protocol +nntp 119/udp usenet #Network News Transfer Protocol +cfdptkt 120/tcp +cfdptkt 120/udp +erpc 121/tcp #Encore Expedited Remote Pro.Call +erpc 121/udp #Encore Expedited Remote Pro.Call +smakynet 122/tcp +smakynet 122/udp +ntp 123/tcp #Network Time Protocol +ntp 123/udp #Network Time Protocol +ansatrader 124/tcp #ANSA REX Trader +ansatrader 124/udp #ANSA REX Trader +locus-map 125/tcp #Locus PC-Interface Net Map Ser +locus-map 125/udp #Locus PC-Interface Net Map Ser +unitary 126/tcp #Unisys Unitary Login +unitary 126/udp #Unisys Unitary Login +locus-con 127/tcp #Locus PC-Interface Conn Server +locus-con 127/udp #Locus PC-Interface Conn Server +gss-xlicen 128/tcp #GSS X License Verification +gss-xlicen 128/udp #GSS X License Verification +pwdgen 129/tcp #Password Generator Protocol +pwdgen 129/udp #Password Generator Protocol +cisco-fna 130/tcp #cisco FNATIVE +cisco-fna 130/udp #cisco FNATIVE +cisco-tna 131/tcp #cisco TNATIVE +cisco-tna 131/udp #cisco TNATIVE +cisco-sys 132/tcp #cisco SYSMAINT +cisco-sys 132/udp #cisco SYSMAINT +statsrv 133/tcp #Statistics Service +statsrv 133/udp #Statistics Service +ingres-net 134/tcp #INGRES-NET Service +ingres-net 134/udp #INGRES-NET Service +loc-srv 135/tcp epmap #Location Service +loc-srv 135/udp epmap #Location Service +profile 136/tcp #PROFILE Naming System +profile 136/udp #PROFILE Naming System +netbios-ns 137/tcp #NETBIOS Name Service +netbios-ns 137/udp #NETBIOS Name Service +netbios-dgm 138/tcp #NETBIOS Datagram Service +netbios-dgm 138/udp #NETBIOS Datagram Service +netbios-ssn 139/tcp #NETBIOS Session Service +netbios-ssn 139/udp #NETBIOS Session Service +emfis-data 140/tcp #EMFIS Data Service +emfis-data 140/udp #EMFIS Data Service +emfis-cntl 141/tcp #EMFIS Control Service +emfis-cntl 141/udp #EMFIS Control Service +bl-idm 142/tcp #Britton-Lee IDM +bl-idm 142/udp #Britton-Lee IDM +imap 143/tcp imap2 imap4 #Interim Mail Access Protocol v2 +imap 143/udp imap2 imap4 #Interim Mail Access Protocol v2 +NeWS 144/tcp # Window System +NeWS 144/udp # Window System +#PROBLEMS!============================================================== +#uma 144/tcp #Universal Management Architecture +#uma 144/udp #Universal Management Architecture +#PROBLEMS!============================================================== +uaac 145/tcp #UAAC Protocol +uaac 145/udp #UAAC Protocol +iso-tp0 146/tcp +iso-tp0 146/udp +iso-ip 147/tcp +iso-ip 147/udp +cronus 148/tcp jargon #CRONUS-SUPPORT +cronus 148/udp jargon #CRONUS-SUPPORT +aed-512 149/tcp #AED 512 Emulation Service +aed-512 149/udp #AED 512 Emulation Service +sql-net 150/tcp +sql-net 150/udp +hems 151/tcp +hems 151/udp +bftp 152/tcp #Background File Transfer Program +bftp 152/udp #Background File Transfer Program +sgmp 153/tcp +sgmp 153/udp +netsc-prod 154/tcp +netsc-prod 154/udp +netsc-dev 155/tcp +netsc-dev 155/udp +sqlsrv 156/tcp #SQL Service +sqlsrv 156/udp #SQL Service +knet-cmp 157/tcp #KNET/VM Command/Message Protocol +knet-cmp 157/udp #KNET/VM Command/Message Protocol +pcmail-srv 158/tcp #PCMail Server +pcmail-srv 158/udp #PCMail Server +nss-routing 159/tcp +nss-routing 159/udp +sgmp-traps 160/tcp +sgmp-traps 160/udp +snmp 161/tcp +snmp 161/udp +snmptrap 162/tcp snmp-trap +snmptrap 162/udp snmp-trap +cmip-man 163/tcp #CMIP/TCP Manager +cmip-man 163/udp #CMIP/TCP Manager +cmip-agent 164/tcp #CMIP/TCP Agent +smip-agent 164/udp #CMIP/TCP Agent +xns-courier 165/tcp #Xerox +xns-courier 165/udp #Xerox +s-net 166/tcp #Sirius Systems +s-net 166/udp #Sirius Systems +namp 167/tcp +namp 167/udp +rsvd 168/tcp +rsvd 168/udp +send 169/tcp +send 169/udp +print-srv 170/tcp #Network PostScript +print-srv 170/udp #Network PostScript +multiplex 171/tcp #Network Innovations Multiplex +multiplex 171/udp #Network Innovations Multiplex +cl/1 172/tcp #Network Innovations CL/1 +cl/1 172/udp #Network Innovations CL/1 +xyplex-mux 173/tcp +xyplex-mux 173/udp +mailq 174/tcp +mailq 174/udp +vmnet 175/tcp +vmnet 175/udp +genrad-mux 176/tcp +genrad-mux 176/udp +xdmcp 177/tcp #X Display Manager Control Protocol +xdmcp 177/udp #X Display Manager Control Protocol +NextStep 178/tcp nextstep NeXTStep #NextStep Window Server +NextStep 178/udp nextstep NeXTStep #NextStep Window Server +bgp 179/tcp #Border Gateway Protocol +bgp 179/udp #Border Gateway Protocol +ris 180/tcp #Intergraph +ris 180/udp #Intergraph +unify 181/tcp +unify 181/udp +audit 182/tcp #Unisys Audit SITP +audit 182/udp #Unisys Audit SITP +ocbinder 183/tcp +ocbinder 183/udp +ocserver 184/tcp +ocserver 184/udp +remote-kis 185/tcp +remote-kis 185/udp +kis 186/tcp #KIS Protocol +kis 186/udp #KIS Protocol +aci 187/tcp #Application Communication Interface +aci 187/udp #Application Communication Interface +mumps 188/tcp #Plus Five's MUMPS +mumps 188/udp #Plus Five's MUMPS +qft 189/tcp #Queued File Transport +qft 189/udp #Queued File Transport +gacp 190/tcp #Gateway Access Control Protocol +gacp 190/udp cacp #Gateway Access Control Protocol +prospero 191/tcp #Prospero Directory Service +prospero 191/udp #Prospero Directory Service +osu-nms 192/tcp #OSU Network Monitoring System +osu-nms 192/udp #OSU Network Monitoring System +srmp 193/tcp #Spider Remote Monitoring Protocol +srmp 193/udp #Spider Remote Monitoring Protocol +irc 194/tcp #Internet Relay Chat Protocol +irc 194/udp #Internet Relay Chat Protocol +dn6-nlm-aud 195/tcp #DNSIX Network Level Module Audit +dn6-nlm-aud 195/udp #DNSIX Network Level Module Audit +dn6-smm-red 196/tcp #DNSIX Session Mgt Module Audit Redir +dn6-smm-red 196/udp #DNSIX Session Mgt Module Audit Redir +dls 197/tcp #Directory Location Service +dls 197/udp #Directory Location Service +dls-mon 198/tcp #Directory Location Service Monitor +dls-mon 198/udp #Directory Location Service Monitor +smux 199/tcp +smux 199/udp +src 200/tcp #IBM System Resource Controller +src 200/udp #IBM System Resource Controller +at-rtmp 201/tcp #AppleTalk Routing Maintenance +at-rtmp 201/udp #AppleTalk Routing Maintenance +at-nbp 202/tcp #AppleTalk Name Binding +at-nbp 202/udp #AppleTalk Name Binding +at-3 203/tcp #AppleTalk Unused +at-3 203/udp #AppleTalk Unused +at-echo 204/tcp #AppleTalk Echo +at-echo 204/udp #AppleTalk Echo +at-5 205/tcp #AppleTalk Unused +at-5 205/udp #AppleTalk Unused +at-zis 206/tcp #AppleTalk Zone Information +at-zis 206/udp #AppleTalk Zone Information +at-7 207/tcp #AppleTalk Unused +at-7 207/udp #AppleTalk Unused +at-8 208/tcp #AppleTalk Unused +at-8 208/udp #AppleTalk Unused +qmtp 209/tcp #The Quick Mail Transfer Protocol +qmtp 209/udp #The Quick Mail Transfer Protocol +#PROBLEMS!============================================================== +#tam 209/tcp #Trivial Authenticated Mail Protocol +#tam 209/udp #Trivial Authenticated Mail Protocol +#PROBLEMS!============================================================== +z39.50 210/tcp wais #ANSI Z39.50 +z39.50 210/udp wais #ANSI Z39.50 +914c/g 211/tcp #Texas Instruments 914C/G Terminal +914c/g 211/udp #Texas Instruments 914C/G Terminal +anet 212/tcp #ATEXSSTR +anet 212/udp #ATEXSSTR +ipx 213/tcp +ipx 213/udp +vmpwscs 214/tcp +vmpwscs 214/udp +softpc 215/tcp #Insignia Solutions +softpc 215/udp #Insignia Solutions +CAIlic 216/tcp atls #Computer Associates Int'l License Server +CAIlic 216/udp atls #Computer Associates Int'l License Server +dbase 217/tcp #dBASE Unix +dbase 217/udp #dBASE Unix +mpp 218/tcp #Netix Message Posting Protocol +mpp 218/udp #Netix Message Posting Protocol +uarps 219/tcp #Unisys ARPs +uarps 219/udp #Unisys ARPs +imap3 220/tcp #Interactive Mail Access Protocol v3 +imap3 220/udp #Interactive Mail Access Protocol v3 +fln-spx 221/tcp #Berkeley rlogind with SPX auth +fln-spx 221/udp #Berkeley rlogind with SPX auth +rsh-spx 222/tcp #Berkeley rshd with SPX auth +rsh-spx 222/udp #Berkeley rshd with SPX auth +cdc 223/tcp #Certificate Distribution Center +cdc 223/udp #Certificate Distribution Center +masqdialer 224/tcp +masqdialer 224/udp +direct 242/tcp +direct 242/udp +sur-meas 243/tcp #Survey Measurement +sur-meas 243/udp #Survey Measurement +dayna 244/tcp +dayna 244/udp +link 245/tcp +link 245/udp +dsp3270 246/tcp #Display Systems Protocol +dsp3270 246/udp #Display Systems Protocol +subntbcst_tftp 247/tcp #subntbcst_tftp +subntbcst_tftp 247/udp #subntbcst_tftp +bhfhs 248/tcp +bhfhs 248/udp +# 249-255 reserved +rap 256/tcp +rap 256/udp +set 257/tcp #secure electronic transaction +set 257/udp #secure electronic transaction +esro-gen 259/tcp #efficient short remote operations +esro-gen 259/udp #efficient short remote operations +openport 260/tcp +openport 260/udp +nsiiops 261/tcp #iiop name service over tls/ssl +nsiiops 261/udp #iiop name service over tls/ssl +arcisdms 262/tcp +arcisdms 262/udp +hdap 263/tcp +hdap 263/udp +bgmp 264/tcp +bgmp 264/udp +x-bone-ctl 265/tcp #X-Bone CTL +x-bone-ctl 265/udp #X-Bone CTL +sst 266/tcp #SCSI on ST +sst 266/udp #SCSI on ST +td-service 267/tcp #Tobit David Service Layer +td-service 267/udp #Tobit David Service Layer +td-replica 268/tcp #Tobit David Replica +td-replica 268/udp #Tobit David Replica +# 269-279 unassigned +http-mgmt 280/tcp +http-mgmt 280/udp +personal-link 281/tcp +personal-link 281/udp +cableport-ax 282/tcp #cable port a/x +cableport-ax 282/udp #cable port a/x +rescap 283/tcp +rescap 283/udp +corerjd 284/tcp +corerjd 284/udp +# 285 unassigned +fxp 286/tcp +fxp 286/udp +k-block 287/tcp +k-block 287/udp +# 288-307 unassigned +novastorbakcup 308/tcp #novastor backup +novastorbakcup 308/udp #novastor backup +entrusttime 309/tcp +entrusttime 309/udp +bhmds 310/tcp +bhmds 310/udp +asip-webadmin 311/tcp #appleshare ip webadmin +asip-webadmin 311/udp #appleshare ip webadmin +vslmp 312/tcp +vslmp 312/udp +magenta-logic 313/tcp +magenta-logic 313/udp +opalis-robot 314/tcp +opalis-robot 314/udp +dpsi 315/tcp +dpsi 315/udp +decauth 316/tcp +decauth 316/udp +zannet 317/tcp +zannet 317/udp +pkix-timestamp 318/tcp #PKIX TimeStamp +pkix-timestamp 318/udp #PKIX TimeStamp +ptp-event 319/tcp #PTP Event +ptp-event 319/udp #PTP Event +ptp-general 320/tcp #PTP General +ptp-general 320/udp #PTP General +pip 321/tcp +pip 321/udp +rtsps 322/tcp +rtsps 322/udp +# 323-332 #unassigned +texar 333/tcp #Texar Security Port +texar 333/udp #Texar Security Port +# 334-343 #unassigned +pdap 344/tcp #Prospero Data Access Protocol +pdap 344/udp #Prospero Data Access Protocol +pawserv 345/tcp #Perf Analysis Workbench +pawserv 345/udp #Perf Analysis Workbench +zserv 346/tcp #Zebra server +zserv 346/udp #Zebra server +fatserv 347/tcp #Fatmen Server +fatserv 347/udp #Fatmen Server +csi-sgwp 348/tcp #Cabletron Management Protocol +csi-sgwp 348/udp #Cabletron Management Protocol +mftp 349/tcp +mftp 349/udp +matip-type-a 350/tcp #MATIP Type A +matip-type-a 350/udp +matip-type-b 351/tcp #MATIP Type B +matip-type-b 351/udp +bhoetty 351/tcp #unassigned but widespread use +bhoetty 351/udp #unassigned but widespread use +dtag-ste-sb 352/tcp #DTAG +dtag-ste-sb 352/udp #DTAG +bhoedap4 352/tcp #unassigned but widespread use +bhoedap4 352/udp #unassigned but widespread use +ndsauth 353/tcp +ndsauth 353/udp +bh611 354/tcp +bh611 354/udp +datex-asn 355/tcp +datex-asn 355/udp +cloanto-net-1 356/tcp #Cloanto Net 1 +cloanto-net-1 356/udp +bhevent 357/tcp +bhevent 357/udp +shrinkwrap 358/tcp +shrinkwrap 358/udp +tenebris_nts 359/tcp #Tenebris Network Trace Service +tenebris_nts 359/udp #Tenebris Network Trace Service +scoi2odialog 360/tcp +scoi2odialog 360/udp +semantix 361/tcp +semantix 361/udp +srssend 362/tcp #SRS Send +srssend 362/udp #SRS Send +rsvp_tunnel 363/tcp +rsvp_tunnel 363/udp +aurora-cmgr 364/tcp +aurora-cmgr 364/udp +dtk 365/tcp #Deception Tool Kit - Fred Cohen +dtk 365/udp #Deception Tool Kit - Fred Cohen +odmr 366/tcp +odmr 366/udp +mortgageware 367/tcp +mortgageware 367/udp +qbikgdp 368/tcp #QbikGDP +qbikgdp 368/udp +rpc2portmap 369/tcp +rpc2portmap 369/udp +codaauth2 370/tcp +codaauth2 370/udp +clearcase 371/tcp +clearcase 371/udp +ulistserv 372/tcp ulistproc #Unix Listserv +ulistserv 372/udp ulistproc #Unix Listserv +legent-1 373/tcp #Legent Corporation (now Computer Associates Intl.) +legent-1 373/udp #Legent Corporation (now Computer Associates Intl.) +legent-2 374/tcp #Legent Corporation (now Computer Associates Intl.) +legent-2 374/udp #Legent Corporation (now Computer Associates Intl.) +hassle 375/tcp +hassle 375/udp +nip 376/tcp #Amiga Envoy Network Inquiry Proto +nip 376/udp #Amiga Envoy Network Inquiry Proto +tnETOS 377/tcp #NEC Corporation +tnETOS 377/udp #NEC Corporation +dsETOS 378/tcp #NEC Corporation +dsETOS 378/udp #NEC Corporation +is99c 379/tcp #TIA/EIA/IS-99 modem client +is99c 379/udp #TIA/EIA/IS-99 modem client +is99s 380/tcp #TIA/EIA/IS-99 modem server +is99s 380/udp #TIA/EIA/IS-99 modem server +hp-collector 381/tcp #hp performance data collector +hp-collector 381/udp #hp performance data collector +hp-managed-node 382/tcp #hp performance data managed node +hp-managed-node 382/udp #hp performance data managed node +hp-alarm-mgr 383/tcp #hp performance data alarm manager +hp-alarm-mgr 383/udp #hp performance data alarm manager +arns 384/tcp #A Remote Network Server System +arns 384/udp #A Remote Network Server System +ibm-app 385/tcp #IBM Application +ibm-app 385/udp #IBM Application +asa 386/tcp #ASA Message Router Object Def. +asa 386/udp #ASA Message Router Object Def. +aurp 387/tcp #Appletalk Update-Based Routing Pro. +aurp 387/udp #Appletalk Update-Based Routing Pro. +unidata-ldm 388/tcp #Unidata LDM Version 4 +unidata-ldm 388/udp #Unidata LDM Version 4 +ldap 389/tcp #Lightweight Directory Access Protocol +ldap 389/udp #Lightweight Directory Access Protocol +uis 390/tcp +uis 390/udp +synotics-relay 391/tcp #SynOptics SNMP Relay Port +synotics-relay 391/udp #SynOptics SNMP Relay Port +synotics-broker 392/tcp #SynOptics Port Broker Port +synotics-broker 392/udp #SynOptics Port Broker Port +dis 393/tcp #Data Interpretation System +dis 393/udp #Data Interpretation System +embl-ndt 394/tcp #EMBL Nucleic Data Transfer +embl-ndt 394/udp #EMBL Nucleic Data Transfer +netcp 395/tcp #NETscout Control Protocol +netcp 395/udp #NETscout Control Protocol +netware-ip 396/tcp #Novell Netware over IP +netware-ip 396/udp #Novell Netware over IP +mptn 397/tcp #Multi Protocol Trans. Net. +mptn 397/udp #Multi Protocol Trans. Net. +kryptolan 398/tcp +kryptolan 398/udp +iso-tsap-c2 399/tcp #ISO-TSAP Class 2 +iso-tsap-c2 399/udp #ISO-TSAP Class 2 +work-sol 400/tcp #Workstation Solutions +work-sol 400/udp #Workstation Solutions +ups 401/tcp #Uninterruptible Power Supply +ups 401/udp #Uninterruptible Power Supply +genie 402/tcp #Genie Protocol +genie 402/udp #Genie Protocol +decap 403/tcp +decap 403/udp +nced 404/tcp +nced 404/udp +ncld 405/tcp +ncld 405/udp +imsp 406/tcp #Interactive Mail Support Protocol +imsp 406/udp #Interactive Mail Support Protocol +timbuktu 407/tcp +timbuktu 407/udp +prm-sm 408/tcp #Prospero Resource Manager Sys. Man. +prm-sm 408/udp #Prospero Resource Manager Sys. Man. +prm-nm 409/tcp #Prospero Resource Manager Node Man. +prm-nm 409/udp #Prospero Resource Manager Node Man. +decladebug 410/tcp #DECLadebug Remote Debug Protocol +decladebug 410/udp #DECLadebug Remote Debug Protocol +rmt 411/tcp #Remote MT Protocol +rmt 411/udp #Remote MT Protocol +synoptics-trap 412/tcp #Trap Convention Port +synoptics-trap 412/udp #Trap Convention Port +smsp 413/tcp +smsp 413/udp +infoseek 414/tcp +infoseek 414/udp +bnet 415/tcp +bnet 415/udp +silverplatter 416/tcp +silverplatter 416/udp +onmux 417/tcp +onmux 417/udp +hyper-g 418/tcp +hyper-g 418/udp +ariel1 419/tcp +ariel1 419/udp +smpte 420/tcp +smpte 420/udp +ariel2 421/tcp +ariel2 421/udp +ariel3 422/tcp +ariel3 422/udp +opc-job-start 423/tcp #IBM Operations Planning and Control Start +opc-job-start 423/udp #IBM Operations Planning and Control Start +opc-job-track 424/tcp #IBM Operations Planning and Control Track +opc-job-track 424/udp #IBM Operations Planning and Control Track +icad-el 425/tcp +icad-el 425/udp +smartsdp 426/tcp +smartsdp 426/udp +svrloc 427/tcp #Server Location +svrloc 427/udp #Server Location +ocs_cmu 428/tcp +ocs_cmu 428/udp +ocs_amu 429/tcp +ocs_amu 429/udp +utmpsd 430/tcp +utmpsd 430/udp +utmpcd 431/tcp +utmpcd 431/udp +iasd 432/tcp +iasd 432/udp +nnsp 433/tcp +nnsp 433/udp +mobileip-agent 434/tcp +mobileip-agent 434/udp +mobilip-mn 435/tcp +mobilip-mn 435/udp +dna-cml 436/tcp +dna-cml 436/udp +comscm 437/tcp +comscm 437/udp +dsfgw 438/tcp +dsfgw 438/udp +dasp 439/tcp +dasp 439/udp +sgcp 440/tcp +sgcp 440/udp +decvms-sysmgt 441/tcp +decvms-sysmgt 441/udp +cvc_hostd 442/tcp +cvc_hostd 442/udp +https 443/tcp +https 443/udp +snpp 444/tcp #Simple Network Paging Protocol +snpp 444/udp #Simple Network Paging Protocol +# [RFC1568] +microsoft-ds 445/tcp +microsoft-ds 445/udp +ddm-rdb 446/tcp +ddm-rdb 446/udp +ddm-dfm 447/tcp +ddm-dfm 447/udp +ddm-ssl 448/tcp ddm-byte +ddm-ssl 448/udp ddm-byte +as-servermap 449/tcp #AS Server Mapper +as-servermap 449/udp #AS Server Mapper +tserver 450/tcp +tserver 450/udp +sfs-smp-net 451/tcp #Cray Network Semaphore server +sfs-smp-net 451/udp #Cray Network Semaphore server +sfs-config 452/tcp #Cray SFS config server +sfs-config 452/udp #Cray SFS config server +creativeserver 453/tcp #CreativeServer +creativeserver 453/udp #CreativeServer +contentserver 454/tcp #ContentServer +contentserver 454/udp #ContentServer +creativepartnr 455/tcp #CreativePartnr +creativepartnr 455/udp #CreativePartnr +macon-tcp 456/tcp +macon-udp 456/udp +scohelp 457/tcp +scohelp 457/udp +appleqtc 458/tcp #apple quick time +appleqtc 458/udp #apple quick time +ampr-rcmd 459/tcp +ampr-rcmd 459/udp +skronk 460/tcp +skronk 460/udp +datasurfsrv 461/tcp +datasurfsrv 461/udp +datasurfsrvsec 462/tcp +datasurfsrvsec 462/udp +alpes 463/tcp +alpes 463/udp +# +kpasswd5 464/tcp # Kerberos (v5) +kpasswd5 464/udp # Kerberos (v5) +#PROBLEMS!============================================================== +# IANA has offically assigned these two ports as ``kpasswd'' +#kpasswd 464/tcp # Kerberos (v5) +#kpasswd 464/udp # Kerberos (v5) +#PROBLEMS!============================================================== +smtps 465/tcp #smtp protocol over TLS/SSL (was ssmtp) +smtps 465/udp #smtp protocol over TLS/SSL (was ssmtp) +digital-vrc 466/tcp +digital-vrc 466/udp +mylex-mapd 467/tcp +mylex-mapd 467/udp +photuris 468/tcp +photuris 468/udp +rcp 469/tcp #Radio Control Protocol +rcp 469/udp #Radio Control Protocol +scx-proxy 470/tcp +scx-proxy 470/udp +mondex 471/tcp +mondex 471/udp +ljk-login 472/tcp +ljk-login 472/udp +hybrid-pop 473/tcp +hybrid-pop 473/udp +tn-tl-w1 474/tcp +tn-tl-w2 474/udp +tcpnethaspsrv 475/tcp +tcpnethaspsrv 475/udp +tn-tl-fd1 476/tcp +tn-tl-fd1 476/udp +ss7ns 477/tcp +ss7ns 477/udp +spsc 478/tcp +spsc 478/udp +iafserver 479/tcp +iafserver 479/udp +iafdbase 480/tcp +iafdbase 480/udp +ph 481/tcp +ph 481/udp +bgs-nsi 482/tcp +bgs-nsi 482/udp +ulpnet 483/tcp +ulpnet 483/udp +integra-sme 484/tcp #Integra Software Management Environment +integra-sme 484/udp #Integra Software Management Environment +powerburst 485/tcp #Air Soft Power Burst +powerburst 485/udp #Air Soft Power Burst +avian 486/tcp +avian 486/udp +saft 487/tcp #saft Simple Asynchronous File Transfer +saft 487/udp #saft Simple Asynchronous File Transfer +gss-http 488/tcp +gss-http 488/udp +nest-protocol 489/tcp +nest-protocol 489/udp +micom-pfs 490/tcp +micom-pfs 490/udp +go-login 491/tcp +go-login 491/udp +ticf-1 492/tcp #Transport Independent Convergence for FNA +ticf-1 492/udp #Transport Independent Convergence for FNA +ticf-2 493/tcp #Transport Independent Convergence for FNA +ticf-2 493/udp #Transport Independent Convergence for FNA +pov-ray 494/tcp +pov-ray 494/udp +intecourier 495/tcp +intecourier 495/udp +pim-rp-disc 496/tcp +pim-rp-disc 496/udp +dantz 497/tcp +dantz 497/udp +siam 498/tcp +siam 498/udp +iso-ill 499/tcp #ISO ILL Protocol +iso-ill 499/udp #ISO ILL Protocol +isakmp 500/tcp +isakmp 500/udp +stmf 501/tcp +stmf 501/udp +asa-appl-proto 502/tcp +asa-appl-proto 502/udp +intrinsa 503/tcp +intrinsa 503/udp +citadel 504/tcp +citadel 504/udp +mailbox-lm 505/tcp +mailbox-lm 505/udp +ohimsrv 506/tcp +ohimsrv 506/udp +crs 507/tcp +crs 507/udp +xvttp 508/tcp +xvttp 508/udp +snare 509/tcp +snare 509/udp +fcp 510/tcp #FirstClass Protocol +fcp 510/udp #FirstClass Protocol +passgo 511/tcp +passgo 511/udp +# +# Berkeley-specific services +# +exec 512/tcp #remote process execution; +# authentication performed using +# passwords and UNIX login names +biff 512/udp comsat #used by mail system to notify users +# of new mail received; currently +# receives messages only from +# processes on the same machine +login 513/tcp #remote login a la telnet; +# automatic authentication performed +# based on priviledged port numbers +# and distributed data bases which +# identify "authentication domains" +who 513/udp whod #maintains data bases showing who's +# logged in to machines on a local +# net and the load average of the +# machine +shell 514/tcp cmd #like exec, but automatic +# authentication is performed as for +# login server +syslog 514/udp +printer 515/tcp spooler +printer 515/udp spooler +videotex 516/tcp +videotex 516/udp +talk 517/tcp #like tenex link, but across +# machine - unfortunately, doesn't +# use link protocol (this is actually +# just a rendezvous port from which a +# tcp connection is established) +talk 517/udp #like tenex link, but across +# machine - unfortunately, doesn't +# use link protocol (this is actually +# just a rendezvous port from which a +# tcp connection is established) +ntalk 518/tcp +ntalk 518/udp +utime 519/tcp unixtime +utime 519/udp unixtime +efs 520/tcp #extended file name server +router 520/udp route routed #local routing process (on site); +# uses variant of Xerox NS routing +# information protocol +ripng 521/tcp +ripng 521/udp +ulp 522/tcp +ulp 522/udp +ibm-db2 523/tcp +ibm-db2 523/udp +ncp 524/tcp +ncp 524/udp +timed 525/tcp timeserver +timed 525/udp timeserver +tempo 526/tcp newdate +tempo 526/udp newdate +stx 527/tcp #Stock IXChange +stx 527/udp #Stock IXChange +custix 528/tcp #Customer IXChange +custix 528/udp #Customer IXChange +irc-serv 529/tcp +irc-serv 529/udp +courier 530/tcp rpc +courier 530/udp rpc +conference 531/tcp chat +conference 531/udp chat +netnews 532/tcp readnews +netnews 532/udp readnews +netwall 533/tcp #for emergency broadcasts +netwall 533/udp #for emergency broadcasts +mm-admin 534/tcp #MegaMedia Admin +mm-admin 534/udp #MegaMedia Admin +iiop 535/tcp +iiop 535/udp +opalis-rdv 536/tcp +opalis-rdv 536/udp +nmsp 537/tcp #Networked Media Streaming Protocol +nmsp 537/udp #Networked Media Streaming Protocol +gdomap 538/tcp +gdomap 538/udp +apertus-ldp 539/tcp #Apertus Technologies Load Determination +apertus-ldp 539/udp #Apertus Technologies Load Determination +uucp 540/tcp uucpd +uucp 540/udp uucpd +uucp-rlogin 541/tcp +uucp-rlogin 541/udp +commerce 542/tcp +commerce 542/udp +klogin 543/tcp # Kerberos (v4/v5) +klogin 543/udp # Kerberos (v4/v5) +kshell 544/tcp krcmd # Kerberos (v4/v5) +kshell 544/udp krcmd # Kerberos (v4/v5) +appleqtcsrvr 545/tcp +appleqtcsrvr 545/udp +dhcpv6-client 546/tcp #DHCPv6 Client +dhcpv6-client 546/udp #DHCPv6 Client +dhcpv6-server 547/tcp #DHCPv6 Server +dhcpv6-server 547/udp #DHCPv6 Server +afpovertcp 548/tcp #AFP over TCP +afpovertcp 548/udp #AFP over TCP +idfp 549/tcp +idfp 549/udp +new-rwho 550/tcp new-who +new-rwho 550/udp new-who +cybercash 551/tcp +cybercash 551/udp +deviceshare 552/tcp +deviceshare 552/udp +pirp 553/tcp +pirp 553/udp +rtsp 554/tcp #Real Time Stream Control Protocol +rtsp 554/udp #Real Time Stream Control Protocol +dsf 555/tcp +dsf 555/udp +remotefs 556/tcp rfs rfs_server # Brunhoff remote filesystem +remotefs 556/udp rfs rfs_server # Brunhoff remote filesystem +openvms-sysipc 557/tcp +openvms-sysipc 557/udp +sdnskmp 558/tcp +sdnskmp 558/udp +teedtap 559/tcp +teedtap 559/udp +rmonitor 560/tcp rmonitord +rmonitor 560/udp rmonitord +monitor 561/tcp +monitor 561/udp +chshell 562/tcp chcmd +chshell 562/udp chcmd +nntps 563/tcp snntp #nntp protocol over TLS/SSL +nntps 563/udp snntp #nntp protocol over TLS/SSL +9pfs 564/tcp #plan 9 file service +9pfs 564/udp #plan 9 file service +whoami 565/tcp +whoami 565/udp +streettalk 566/tcp +streettalk 566/udp +banyan-rpc 567/tcp +banyan-rpc 567/udp +ms-shuttle 568/tcp #Microsoft shuttle +ms-shuttle 568/udp #Microsoft shuttle +ms-rome 569/tcp #Microsoft rome +ms-rome 569/udp #Microsoft rome +meter 570/tcp #demon +meter 570/udp #demon +umeter 571/tcp #udemon +umeter 571/udp #udemon +sonar 572/tcp +sonar 572/udp +banyan-vip 573/tcp +banyan-vip 573/udp +ftp-agent 574/tcp #FTP Software Agent System +ftp-agent 574/udp #FTP Software Agent System +vemmi 575/tcp +vemmi 575/udp +ipcd 576/tcp +ipcd 576/udp +vnas 577/tcp +vnas 577/udp +ipdd 578/tcp +ipdd 578/udp +decbsrv 579/tcp +decbsrv 579/udp +sntp-heartbeat 580/tcp +sntp-heartbeat 580/udp +bdp 581/tcp #Bundle Discovery Protocol +bdp 581/udp #Bundle Discovery Protocol +scc-security 582/tcp +scc-security 582/udp +philips-vc 583/tcp #Philips Video-Conferencing +philips-vc 583/udp #Philips Video-Conferencing +keyserver 584/tcp +keyserver 584/udp +#imap4-ssl@585 never should have been allocated. See PR 46294. +#imap4-ssl 585/tcp #IMAP4+SSL (use of 585 is not recommended, +#imap4-ssl 585/udp # use 993 instead) +password-chg 586/tcp +password-chg 586/udp +submission 587/tcp +submission 587/udp +cal 588/tcp +cal 588/udp +eyelink 589/tcp +eyelink 589/udp +tns-cml 590/tcp +tns-cml 590/udp +http-alt 591/tcp #FileMaker, Inc. - HTTP Alternate (see Port 80) +http-alt 591/udp #FileMaker, Inc. - HTTP Alternate (see Port 80) +eudora-set 592/tcp +eudora-set 592/udp +http-rpc-epmap 593/tcp #HTTP RPC Ep Map +http-rpc-epmap 593/udp #HTTP RPC Ep Map +tpip 594/tcp +tpip 594/udp +cab-protocol 595/tcp +cab-protocol 595/udp +smsd 596/tcp +smsd 596/udp +ptcnameservice 597/tcp #PTC Name Service +ptcnameservice 597/udp #PTC Name Service +sco-websrvrmg3 598/tcp #SCO Web Server Manager 3 +sco-websrvrmg3 598/udp #SCO Web Server Manager 3 +acp 599/tcp #Aeolon Core Protocol +acp 599/udp #Aeolon Core Protocol +ipcserver 600/tcp #Sun IPC server +ipcserver 600/udp #Sun IPC server +syslog-conn 601/tcp #Reliable Syslog Service +syslog-conn 601/udp #Reliable Syslog Service +xmlrpc-beep 602/tcp #XML-RPC over BEEP +xmlrpc-beep 602/udp #XML-RPC over BEEP +idxp 603/tcp +idxp 603/udp +tunnel 604/tcp +tunnel 604/udp +soap-beep 605/tcp #SOAP over BEEP +soap-beep 605/udp #SOAP over BEEP +urm 606/tcp #Cray Unified Resource Manager +urm 606/udp #Cray Unified Resource Manager +nqs 607/tcp +nqs 607/udp +sift-uft 608/tcp #Sender-Initiated/Unsolicited File Transfer +sift-uft 608/udp #Sender-Initiated/Unsolicited File Transfer +npmp-trap 609/tcp +npmp-trap 609/udp +npmp-local 610/tcp +npmp-local 610/udp +npmp-gui 611/tcp +npmp-gui 611/udp +hmmp-ind 612/tcp #HMMP Indication +hmmp-ind 612/udp #HMMP Indication +hmmp-op 613/tcp #HMMP Operation +hmmp-op 613/udp #HMMP Operation +sshell 614/tcp #SSLshell +sshell 614/udp +sco-inetmgr 615/tcp #Internet Configuration Manager +sco-inetmgr 615/udp #Internet Configuration Manager +sco-sysmgr 616/tcp #SCO System Administration Server +sco-sysmgr 616/udp #SCO System Administration Server +sco-dtmgr 617/tcp #SCO Desktop Administration Server +sco-dtmgr 617/udp #SCO Desktop Administration Server +dei-icda 618/tcp +dei-icda 618/udp +compaq-evm 619/tcp #Compaq EVM +compaq-evm 619/udp #Compaq EVM +sco-websrvrmgr 620/tcp #SCO WebServer Manager +sco-websrvrmgr 620/udp #SCO WebServer Manager +escp-ip 621/tcp #ESCP +escp-ip 621/udp #ESCP +collaborator 622/tcp +collaborator 622/udp +asf-rmcp 623/tcp #ASF Remote Management and Control Protocol +asf-rmcp 623/udp #ASF Remote Management and Control Protocol +cryptoadmin 624/tcp #Crypto Admin +cryptoadmin 624/udp #Crypto Admin +dec_dlm 625/tcp #DEC DLM +dec_dlm 625/udp #DEC DLM +asia 626/tcp +asia 626/udp +passgo-tivoli 627/tcp #PassGo Tivoli +passgo-tivoli 627/udp #PassGo Tivoli +qmqp 628/tcp +qmqp 628/udp +3com-amp3 629/tcp #3Com AMP3 +3com-amp3 629/udp #3Com AMP3 +rda 630/tcp +rda 630/udp +ipp 631/tcp #IPP (Internet Printing Protocol) +ipp 631/udp #IPP (Internet Printing Protocol) +bmpp 632/tcp +bmpp 632/udp +servstat 633/tcp #Service Status update (Sterling Software) +servstat 633/udp #Service Status update (Sterling Software) +ginad 634/tcp +ginad 634/udp +rlzdbase 635/tcp #RLZ DBase +rlzdbase 635/udp #RLZ DBase +ldaps 636/tcp sldap #ldap protocol over TLS/SSL +ldaps 636/udp sldap +lanserver 637/tcp +lanserver 637/udp +mcns-sec 638/tcp +mcns-sec 638/udp +msdp 639/tcp +msdp 639/udp +entrust-sps 640/tcp +entrust-sps 640/udp +repcmd 641/tcp +repcmd 641/udp +esro-emsdp 642/tcp #ESRO-EMSDP V1.3 +esro-emsdp 642/udp #ESRO-EMSDP V1.3 +sanity 643/tcp #SANity +sanity 643/udp #SANity +dwr 644/tcp +dwr 644/udp +pssc 645/tcp +pssc 645/udp +ldp 646/tcp +ldp 646/udp +dhcp-failover 647/tcp #DHCP Failover +dhcp-failover 647/udp #DHCP Failover +rrp 648/tcp #Registry Registrar Protocol (RRP) +rrp 648/udp #Registry Registrar Protocol (RRP) +cadview-3d 649/tcp #Cadview-3d - streaming 3d models over the internet +cadview-3d 649/udp #Cadview-3d - streaming 3d models over the internet +obex 650/tcp +obex 650/udp +ieee-mms 651/tcp #IEEE MMS +ieee-mms 651/udp #IEEE MMS +hello-port 652/tcp +hello-port 652/udp +repscmd 653/tcp +repscmd 653/udp +aodv 654/tcp #Ad-Hoc On-Demand Distance Vector Routing Protocol +aodv 654/udp #Ad-Hoc On-Demand Distance Vector Routing Protocol +tinc 655/tcp +tinc 655/udp +spmp 656/tcp +spmp 656/udp +rmc 657/tcp +rmc 657/udp +tenfold 658/tcp +tenfold 658/udp +mac-srvr-admin 660/tcp #MacOS Server Admin +mac-srvr-admin 660/udp #MacOS Server Admin +hap 661/tcp +hap 661/udp +pftp 662/tcp +pftp 662/udp +purenoise 663/tcp #PureNoise +purenoise 663/udp #PureNoise +asf-secure-rmcp 664/tcp #ASF Secure Remote Management and Control Protocol +asf-secure-rmcp 664/udp #ASF Secure Remote Management and Control Protocol +sun-dr 665/tcp #Sun DR +sun-dr 665/udp #Sun DR +mdqs 666/tcp +mdqs 666/udp +#PROBLEMS!=============================================== +doom 666/tcp #doom Id Software +doom 666/udp #doom Id Software +#PROBLEMS!=============================================== +disclose 667/tcp #campaign contribution disclosures - SDR Technologies +disclose 667/udp #campaign contribution disclosures - SDR Technologies +mecomm 668/tcp +mecomm 668/udp +meregister 669/tcp +meregister 669/udp +vacdsm-sws 670/tcp +vacdsm-sws 670/udp +vacdsm-app 671/tcp +vacdsm-app 671/udp +vpps-qua 672/tcp +vpps-qua 672/udp +cimplex 673/tcp +cimplex 673/udp +acap 674/tcp #Application Configuration Access Protocol +acap 674/udp #Application Configuration Access Protocol +dctp 675/tcp +dctp 675/udp +vpps-via 676/tcp #VPPS Via +vpps-via 676/udp #VPPS Via +vpp 677/tcp #Virtual Presence Protocol +vpp 677/udp #Virtual Presence Protocol +ggf-ncp 678/tcp #GNU Generation Foundation NCP +ggf-ncp 678/udp #GNU Generation Foundation NCP +mrm 679/tcp +mrm 679/udp +entrust-aaas 680/tcp +entrust-aaas 680/udp +entrust-aams 681/tcp +entrust-aams 681/udp +xfr 682/tcp +xfr 682/udp +corba-iiop 683/tcp #CORBA IIOP +corba-iiop 683/udp #CORBA IIOP +corba-iiop-ssl 684/tcp #CORBA IIOP SSL +corba-iiop-ssl 684/udp #CORBA IIOP SSL +mdc-portmapper 685/tcp #MDC Port Mapper +mdc-portmapper 685/udp #MDC Port Mapper +hcp-wismar 686/tcp #Hardware Control Protocol Wismar +hcp-wismar 686/udp #Hardware Control Protocol Wismar +asipregistry 687/tcp +asipregistry 687/udp +realm-rusd 688/tcp #ApplianceWare managment protocol +realm-rusd 688/udp #ApplianceWare managment protocol +nmap 689/tcp +nmap 689/udp +vatp 690/tcp #Velazquez Application Transfer Protocol +vatp 690/udp #Velazquez Application Transfer Protocol +msexch-routing 691/tcp #MS Exchange Routing +msexch-routing 691/udp #MS Exchange Routing +hyperwave-isp 692/tcp #Hyperwave-ISP +hyperwave-isp 692/udp #Hyperwave-ISP +connendp 693/tcp +connendp 693/udp +ha-cluster 694/tcp +ha-cluster 694/udp +ieee-mms-ssl 695/tcp +ieee-mms-ssl 695/udp +rushd 696/tcp +rushd 696/udp +uuidgen 697/tcp +uuidgen 697/udp +olsr 698/tcp +olsr 698/udp +accessnetwork 699/tcp #Access Network +accessnetwork 699/udp #Access Network +epp 700/tcp #Extensible Provisioning Protocol +epp 700/udp #Extensible Provisioning Protocol +lmp 701/tcp #Link Management Protocol (LMP) +lmp 701/udp #Link Management Protocol (LMP) +iris-beep 702/tcp #IRIS over BEEP +iris-beep 702/udp #IRIS over BEEP +elcsd 704/tcp #errlog copy/server daemon +elcsd 704/udp #errlog copy/server daemon +agentx 705/tcp #AgentX +agentx 705/udp #AgentX +silc 706/tcp +silc 706/udp +borland-dsj 707/tcp #Borland DSJ +borland-dsj 707/udp #Borland DSJ +entrustmanager 709/tcp #EntrustManager +entrustmanager 709/udp #EntrustManager +entrust-ash 710/tcp #Entrust Administration Service Handler +entrust-ash 710/udp #Entrust Administration Service Handler +cisco-tdp 711/tcp #Cisco TDP +cisco-tdp 711/udp #Cisco TDP +tbrpf 712/tcp +tbrpf 712/udp +iris-xpc 713/tcp #IRIS over XPC +iris-xpc 713/udp #IRIS over XPC +iris-xpcs 714/tcp #IRIS over XPCS +iris-xpcs 714/udp #IRIS over XPCS +iris-lwz 715/tcp +iris-lwz 715/udp +netviewdm1 729/tcp #IBM NetView DM/6000 Server/Client +netviewdm1 729/udp #IBM NetView DM/6000 Server/Client +netviewdm2 730/tcp #IBM NetView DM/6000 send/tcp +netviewdm2 730/udp #IBM NetView DM/6000 send/tcp +netviewdm3 731/tcp #IBM NetView DM/6000 receive/tcp +netviewdm3 731/udp #IBM NetView DM/6000 receive/tcp +netgw 741/tcp +netgw 741/udp +netrcs 742/tcp #Network based Rev. Cont. Sys. +netrcs 742/udp #Network based Rev. Cont. Sys. +flexlm 744/tcp #Flexible License Manager +flexlm 744/udp #Flexible License Manager +fujitsu-dev 747/tcp #Fujitsu Device Control +fujitsu-dev 747/udp #Fujitsu Device Control +ris-cm 748/tcp #Russell Info Sci Calendar Manager +ris-cm 748/udp #Russell Info Sci Calendar Manager +kerberos-adm 749/tcp #Kerberos administration (v5) +kerberos-adm 749/udp #Kerberos administration (v5) +kerberos-iv 750/udp kdc # Kerberos (v4) +kerberos-iv 750/tcp kdc # Kerberos (v4) +#PROBLEMS!======================================================== +#rfile 750/tcp +#loadav 750/udp +#PROBLEMS!======================================================== +kerberos_master 751/tcp # Kerberos `kadmin' (v4) +kerberos_master 751/udp # Kerberos `kadmin' (v4) +#PROBLEMS!======================================================== +pump 751/tcp +pump 751/udp +#PROBLEMS!======================================================== +qrh 752/tcp +qrh 752/udp +rrh 753/tcp +rrh 753/udp +krb_prop 754/tcp krb5_prop # kerberos/v5 server propagation +#PROBLEMS!======================================================== +tell 754/tcp #send +#PROBLEMS!======================================================== +tell 754/udp #send +nlogin 758/tcp +nlogin 758/udp +con 759/tcp +con 759/udp +krbupdate 760/tcp kreg # Kerberos (v4) registration +#PROBLEMS!======================================================== +ns 760/tcp +#PROBLEMS!======================================================== +ns 760/udp +kpasswd 761/tcp kpwd # Kerberos (v4) "passwd" +#PROBLEMS!======================================================== +rxe 761/tcp +#PROBLEMS!======================================================== +rxe 761/udp +quotad 762/tcp +quotad 762/udp +cycleserv 763/tcp +cycleserv 763/udp +omserv 764/tcp +omserv 764/udp +webster 765/tcp +webster 765/udp +phonebook 767/tcp #phone +phonebook 767/udp #phone +vid 769/tcp +vid 769/udp +cadlock 770/tcp +cadlock 770/udp +rtip 771/tcp +rtip 771/udp +cycleserv2 772/tcp +cycleserv2 772/udp +submit 773/tcp +notify 773/udp +rpasswd 774/tcp +acmaint_dbd 774/udp +entomb 775/tcp +acmaint_transd 775/udp +wpages 776/tcp +wpages 776/udp +multiling-http 777/tcp #Multiling HTTP +multiling-http 777/udp #Multiling HTTP +wpgs 780/tcp +wpgs 780/udp +mdbs_daemon 800/tcp +mdbs_daemon 800/udp +device 801/tcp +device 801/udp +fcp-udp 810/tcp #FCP +fcp-udp 810/udp #FCP Datagram +itm-mcell-s 828/tcp +itm-mcell-s 828/udp +pkix-3-ca-ra 829/tcp #PKIX-3 CA/RA +pkix-3-ca-ra 829/udp #PKIX-3 CA/RA +netconf-ssh 830/tcp #NETCONF over SSH +netconf-ssh 830/udp #NETCONF over SSH +netconf-beep 831/tcp #NETCONF over BEEP +netconf-beep 831/udp #NETCONF over BEEP +netconfsoaphttp 832/tcp #NETCONF for SOAP over HTTPS +netconfsoaphttp 832/udp #NETCONF for SOAP over HTTPS +netconfsoapbeep 833/tcp #NETCONF for SOAP over BEEP +netconfsoapbeep 833/udp #NETCONF for SOAP over BEEP +dhcp-failover2 847/tcp #dhcp-failover 2 +dhcp-failover2 847/udp #dhcp-failover 2 +gdoi 848/tcp +gdoi 848/udp +iscsi 860/tcp +iscsi 860/udp +owamp-control 861/tcp +owamp-control 861/udp +supfilesrv 871/tcp # for SUP +rsync 873/tcp +rsync 873/udp +iclcnet-locate 886/tcp #ICL coNETion locate server +iclcnet-locate 886/udp #ICL coNETion locate server +iclcnet_svinfo 887/tcp #ICL coNETion server info +iclcnet_svinfo 887/udp #ICL coNETion server info +accessbuilder 888/tcp +accessbuilder 888/udp +omginitialrefs 900/tcp #OMG Initial Refs +omginitialrefs 900/udp #OMG Initial Refs +swat 901/tcp # samba web configuration tool +smpnameres 901/tcp +smpnameres 901/udp +ideafarm-chat 902/tcp +ideafarm-chat 902/udp +ideafarm-catch 903/tcp +ideafarm-catch 903/udp +kink 910/tcp #Kerberized Internet Negotiation of Keys (KINK) +kink 910/udp #Kerberized Internet Negotiation of Keys (KINK) +xact-backup 911/tcp +xact-backup 911/udp +apex-mesh 912/tcp #APEX relay-relay service +apex-mesh 912/udp #APEX relay-relay service +apex-edge 913/tcp #APEX endpoint-relay service +apex-edge 913/udp #APEX endpoint-relay service +rndc 953/tcp # named's rndc control socket +ftps-data 989/tcp # ftp protocol, data, over TLS/SSL +ftps-data 989/udp +ftps 990/tcp # ftp protocol, control, over TLS/SSL +ftps 990/udp +nas 991/tcp #Netnews Administration System +nas 991/udp #Netnews Administration System +telnets 992/tcp # telnet protocol over TLS/SSL +telnets 992/udp +imaps 993/tcp # imap4 protocol over TLS/SSL +imaps 993/udp +ircs 994/tcp # irc protocol over TLS/SSL +ircs 994/udp +pop3s 995/tcp spop3 # pop3 protocol over TLS/SSL +pop3s 995/udp spop3 +vsinet 996/tcp +vsinet 996/udp +maitrd 997/tcp +maitrd 997/udp +busboy 998/tcp +puparp 998/udp +garcon 999/tcp +applix 999/udp #Applix ac +puprouter 999/tcp +puprouter 999/udp +cadlock2 1000/tcp +cadlock2 1000/udp +surf 1010/tcp +surf 1010/udp +exp1 1021/tcp #RFC3692-style Experiment 1 (*) [RFC4727] +exp1 1021/udp #RFC3692-style Experiment 1 (*) [RFC4727] +exp2 1022/tcp #RFC3692-style Experiment 2 (*) [RFC4727] +exp2 1022/udp #RFC3692-style Experiment 2 (*) [RFC4727] +# +# REGISTERED PORT NUMBERS +# +blackjack 1025/tcp #network blackjack +blackjack 1025/udp #network blackjack +iad1 1030/tcp #BBN IAD +iad1 1030/udp #BBN IAD +iad2 1031/tcp #BBN IAD +iad2 1031/udp #BBN IAD +iad3 1032/tcp #BBN IAD +iad3 1032/udp #BBN IAD +nim 1058/tcp +nim 1058/udp +nimreg 1059/tcp +nimreg 1059/udp +instl_boots 1067/tcp #Installation Bootstrap Proto. Serv. +instl_boots 1067/udp #Installation Bootstrap Proto. Serv. +instl_bootc 1068/tcp #Installation Bootstrap Proto. Cli. +instl_bootc 1068/udp #Installation Bootstrap Proto. Cli. +socks 1080/tcp +socks 1080/udp +ansoft-lm-1 1083/tcp #Anasoft License Manager +ansoft-lm-1 1083/udp #Anasoft License Manager +ansoft-lm-2 1084/tcp #Anasoft License Manager +ansoft-lm-2 1084/udp #Anasoft License Manager +webobjects 1085/tcp #Web Objects +webobjects 1085/udp #Web Objects +kpop 1109/tcp #Unofficial +kpop 1109/udp #Unofficial +nfsd-status 1110/tcp #Cluster status info +nfsd-keepalive 1110/udp #Client status info +supfiledbg 1127/tcp # for SUP +nfa 1155/tcp #Network File Access +nfa 1155/udp #Network File Access +phone 1167/udp #conference calling +skkserv 1178/tcp #SKK (kanji input) +openvpn 1194/tcp #OpenVPN +openvpn 1194/udp #OpenVPN +lupa 1212/tcp +lupa 1212/udp +nerv 1222/tcp #SNI R&D network +nerv 1222/udp #SNI R&D network +hermes 1248/tcp +hermes 1248/udp +healthd 1281/tcp #healthd +healthd 1281/udp #healthd +alta-ana-lm 1346/tcp #Alta Analytics License Manager +alta-ana-lm 1346/udp #Alta Analytics License Manager +bbn-mmc 1347/tcp #multi media conferencing +bbn-mmc 1347/udp #multi media conferencing +bbn-mmx 1348/tcp #multi media conferencing +bbn-mmx 1348/udp #multi media conferencing +sbook 1349/tcp #Registration Network Protocol +sbook 1349/udp #Registration Network Protocol +editbench 1350/tcp #Registration Network Protocol +editbench 1350/udp #Registration Network Protocol +equationbuilder 1351/tcp #Digital Tool Works (MIT) +equationbuilder 1351/udp #Digital Tool Works (MIT) +lotusnote 1352/tcp #Lotus Note +lotusnote 1352/udp #Lotus Note +relief 1353/tcp #Relief Consulting +relief 1353/udp #Relief Consulting +rightbrain 1354/tcp #RightBrain Software +rightbrain 1354/udp #RightBrain Software +intuitive-edge 1355/tcp #Intuitive Edge +intuitive-edge 1355/udp #Intuitive Edge +cuillamartin 1356/tcp #CuillaMartin Company +cuillamartin 1356/udp #CuillaMartin Company +pegboard 1357/tcp #Electronic PegBoard +pegboard 1357/udp #Electronic PegBoard +connlcli 1358/tcp +connlcli 1358/udp +ftsrv 1359/tcp +ftsrv 1359/udp +mimer 1360/tcp +mimer 1360/udp +linx 1361/tcp +linx 1361/udp +timeflies 1362/tcp +timeflies 1362/udp +ndm-requester 1363/tcp #Network DataMover Requester +ndm-requester 1363/udp #Network DataMover Requester +ndm-server 1364/tcp #Network DataMover Server +ndm-server 1364/udp #Network DataMover Server +adapt-sna 1365/tcp #Network Software Associates +adapt-sna 1365/udp #Network Software Associates +netware-csp 1366/tcp #Novell NetWare Comm Service Platform +netware-csp 1366/udp #Novell NetWare Comm Service Platform +dcs 1367/tcp +dcs 1367/udp +screencast 1368/tcp +screencast 1368/udp +gv-us 1369/tcp #GlobalView to Unix Shell +gv-us 1369/udp #GlobalView to Unix Shell +us-gv 1370/tcp #Unix Shell to GlobalView +us-gv 1370/udp #Unix Shell to GlobalView +fc-cli 1371/tcp #Fujitsu Config Protocol +fc-cli 1371/udp #Fujitsu Config Protocol +fc-ser 1372/tcp #Fujitsu Config Protocol +fc-ser 1372/udp #Fujitsu Config Protocol +chromagrafx 1373/tcp +chromagrafx 1373/udp +molly 1374/tcp #EPI Software Systems +molly 1374/udp #EPI Software Systems +bytex 1375/tcp +bytex 1375/udp +ibm-pps 1376/tcp #IBM Person to Person Software +ibm-pps 1376/udp #IBM Person to Person Software +cichlid 1377/tcp #Cichlid License Manager +cichlid 1377/udp #Cichlid License Manager +elan 1378/tcp #Elan License Manager +elan 1378/udp #Elan License Manager +dbreporter 1379/tcp #Integrity Solutions +dbreporter 1379/udp #Integrity Solutions +telesis-licman 1380/tcp #Telesis Network License Manager +telesis-licman 1380/udp #Telesis Network License Manager +apple-licman 1381/tcp #Apple Network License Manager +apple-licman 1381/udp #Apple Network License Manager +#udt_os 1382/tcp +#udt_os 1382/udp +gwha 1383/tcp #GW Hannaway Network License Manager +gwha 1383/udp #GW Hannaway Network License Manager +os-licman 1384/tcp #Objective Solutions License Manager +os-licman 1384/udp #Objective Solutions License Manager +atex_elmd 1385/tcp #Atex Publishing License Manager +atex_elmd 1385/udp #Atex Publishing License Manager +checksum 1386/tcp #CheckSum License Manager +checksum 1386/udp #CheckSum License Manager +cadsi-lm 1387/tcp #Computer Aided Design Software Inc LM +cadsi-lm 1387/udp #Computer Aided Design Software Inc LM +objective-dbc 1388/tcp #Objective Solutions DataBase Cache +objective-dbc 1388/udp #Objective Solutions DataBase Cache +iclpv-dm 1389/tcp #Document Manager +iclpv-dm 1389/udp #Document Manager +iclpv-sc 1390/tcp #Storage Controller +iclpv-sc 1390/udp #Storage Controller +iclpv-sas 1391/tcp #Storage Access Server +iclpv-sas 1391/udp #Storage Access Server +iclpv-pm 1392/tcp #Print Manager +iclpv-pm 1392/udp #Print Manager +iclpv-nls 1393/tcp #Network Log Server +iclpv-nls 1393/udp #Network Log Server +iclpv-nlc 1394/tcp #Network Log Client +iclpv-nlc 1394/udp #Network Log Client +iclpv-wsm 1395/tcp #PC Workstation Manager software +iclpv-wsm 1395/udp #PC Workstation Manager software +dvl-activemail 1396/tcp #DVL Active Mail +dvl-activemail 1396/udp #DVL Active Mail +audio-activmail 1397/tcp #Audio Active Mail +audio-activmail 1397/udp #Audio Active Mail +video-activmail 1398/tcp #Video Active Mail +video-activmail 1398/udp #Video Active Mail +cadkey-licman 1399/tcp #Cadkey License Manager +cadkey-licman 1399/udp #Cadkey License Manager +cadkey-tablet 1400/tcp #Cadkey Tablet Daemon +cadkey-tablet 1400/udp #Cadkey Tablet Daemon +goldleaf-licman 1401/tcp #Goldleaf License Manager +goldleaf-licman 1401/udp #Goldleaf License Manager +prm-sm-np 1402/tcp #Prospero Resource Manager +prm-sm-np 1402/udp #Prospero Resource Manager +prm-nm-np 1403/tcp #Prospero Resource Manager +prm-nm-np 1403/udp #Prospero Resource Manager +igi-lm 1404/tcp #Infinite Graphics License Manager +igi-lm 1404/udp #Infinite Graphics License Manager +ibm-res 1405/tcp #IBM Remote Execution Starter +ibm-res 1405/udp #IBM Remote Execution Starter +netlabs-lm 1406/tcp #NetLabs License Manager +netlabs-lm 1406/udp #NetLabs License Manager +dbsa-lm 1407/tcp #DBSA License Manager +dbsa-lm 1407/udp #DBSA License Manager +sophia-lm 1408/tcp #Sophia License Manager +sophia-lm 1408/udp #Sophia License Manager +here-lm 1409/tcp #Here License Manager +here-lm 1409/udp #Here License Manager +hiq 1410/tcp #HiQ License Manager +hiq 1410/udp #HiQ License Manager +af 1411/tcp #AudioFile +af 1411/udp #AudioFile +innosys 1412/tcp +innosys 1412/udp +innosys-acl 1413/tcp +innosys-acl 1413/udp +ibm-mqseries 1414/tcp #IBM MQSeries +ibm-mqseries 1414/udp #IBM MQSeries +dbstar 1415/tcp +dbstar 1415/udp +novell-lu6.2 1416/tcp #Novell LU6.2 +novell-lu6.2 1416/udp #Novell LU6.2 +timbuktu-srv1 1417/tcp #Timbuktu Service 1 Port +timbuktu-srv1 1417/udp #Timbuktu Service 1 Port +timbuktu-srv2 1418/tcp #Timbuktu Service 2 Port +timbuktu-srv2 1418/udp #Timbuktu Service 2 Port +timbuktu-srv3 1419/tcp #Timbuktu Service 3 Port +timbuktu-srv3 1419/udp #Timbuktu Service 3 Port +timbuktu-srv4 1420/tcp #Timbuktu Service 4 Port +timbuktu-srv4 1420/udp #Timbuktu Service 4 Port +gandalf-lm 1421/tcp #Gandalf License Manager +gandalf-lm 1421/udp #Gandalf License Manager +autodesk-lm 1422/tcp #Autodesk License Manager +autodesk-lm 1422/udp #Autodesk License Manager +essbase 1423/tcp #Essbase Arbor Software +essbase 1423/udp #Essbase Arbor Software +hybrid 1424/tcp #Hybrid Encryption Protocol +hybrid 1424/udp #Hybrid Encryption Protocol +zion-lm 1425/tcp #Zion Software License Manager +zion-lm 1425/udp #Zion Software License Manager +sas-1 1426/tcp #Satellite-data Acquisition System 1 +sas-1 1426/udp #Satellite-data Acquisition System 1 +mloadd 1427/tcp #mloadd monitoring tool +mloadd 1427/udp #mloadd monitoring tool +informatik-lm 1428/tcp #Informatik License Manager +informatik-lm 1428/udp #Informatik License Manager +nms 1429/tcp #Hypercom NMS +nms 1429/udp #Hypercom NMS +tpdu 1430/tcp #Hypercom TPDU +tpdu 1430/udp #Hypercom TPDU +rgtp 1431/tcp #Reverse Gossip Transport +rgtp 1431/udp #Reverse Gossip Transport +blueberry-lm 1432/tcp #Blueberry Software License Manager +blueberry-lm 1432/udp #Blueberry Software License Manager +ms-sql-s 1433/tcp #Microsoft-SQL-Server +ms-sql-s 1433/udp #Microsoft-SQL-Server +ms-sql-m 1434/tcp #Microsoft-SQL-Monitor +ms-sql-m 1434/udp #Microsoft-SQL-Monitor +ibm-cics 1435/tcp +ibm-cics 1435/udp +sas-2 1436/tcp #Satellite-data Acquisition System 2 +sas-2 1436/udp #Satellite-data Acquisition System 2 +tabula 1437/tcp +tabula 1437/udp +eicon-server 1438/tcp #Eicon Security Agent/Server +eicon-server 1438/udp #Eicon Security Agent/Server +eicon-x25 1439/tcp #Eicon X25/SNA Gateway +eicon-x25 1439/udp #Eicon X25/SNA Gateway +eicon-slp 1440/tcp #Eicon Service Location Protocol +eicon-slp 1440/udp #Eicon Service Location Protocol +cadis-1 1441/tcp #Cadis License Management +cadis-1 1441/udp #Cadis License Management +cadis-2 1442/tcp #Cadis License Management +cadis-2 1442/udp #Cadis License Management +ies-lm 1443/tcp #Integrated Engineering Software +ies-lm 1443/udp #Integrated Engineering Software +marcam-lm 1444/tcp #Marcam License Management +marcam-lm 1444/udp #Marcam License Management +proxima-lm 1445/tcp #Proxima License Manager +proxima-lm 1445/udp #Proxima License Manager +ora-lm 1446/tcp #Optical Research Associates License Manager +ora-lm 1446/udp #Optical Research Associates License Manager +apri-lm 1447/tcp #Applied Parallel Research LM +apri-lm 1447/udp #Applied Parallel Research LM +oc-lm 1448/tcp #OpenConnect License Manager +oc-lm 1448/udp #OpenConnect License Manager +peport 1449/tcp +peport 1449/udp +dwf 1450/tcp #Tandem Distributed Workbench Facility +dwf 1450/udp #Tandem Distributed Workbench Facility +infoman 1451/tcp #IBM Information Management +infoman 1451/udp #IBM Information Management +gtegsc-lm 1452/tcp #GTE Government Systems License Man +gtegsc-lm 1452/udp #GTE Government Systems License Man +genie-lm 1453/tcp #Genie License Manager +genie-lm 1453/udp #Genie License Manager +interhdl_elmd 1454/tcp #interHDL License Manager +interhdl_elmd 1454/udp #interHDL License Manager +esl-lm 1455/tcp #ESL License Manager +esl-lm 1455/udp #ESL License Manager +dca 1456/tcp +dca 1456/udp +valisys-lm 1457/tcp #Valisys License Manager +valisys-lm 1457/udp #Valisys License Manager +nrcabq-lm 1458/tcp #Nichols Research Corp. +nrcabq-lm 1458/udp #Nichols Research Corp. +proshare1 1459/tcp #Proshare Notebook Application +proshare1 1459/udp #Proshare Notebook Application +proshare2 1460/tcp #Proshare Notebook Application +proshare2 1460/udp #Proshare Notebook Application +ibm_wrless_lan 1461/tcp #IBM Wireless LAN +ibm_wrless_lan 1461/udp #IBM Wireless LAN +world-lm 1462/tcp #World License Manager +world-lm 1462/udp #World License Manager +nucleus 1463/tcp +nucleus 1463/udp +msl_lmd 1464/tcp #MSL License Manager +msl_lmd 1464/udp #MSL License Manager +pipes 1465/tcp #Pipes Platform +pipes 1465/udp #Pipes Platform mfarlin@peerlogic.com +oceansoft-lm 1466/tcp #Ocean Software License Manager +oceansoft-lm 1466/udp #Ocean Software License Manager +csdmbase 1467/tcp +csdmbase 1467/udp +csdm 1468/tcp +csdm 1468/udp +aal-lm 1469/tcp #Active Analysis Limited License Manager +aal-lm 1469/udp #Active Analysis Limited License Manager +uaiact 1470/tcp #Universal Analytics +uaiact 1470/udp #Universal Analytics +csdmbase 1471/tcp +csdmbase 1471/udp +csdm 1472/tcp +csdm 1472/udp +openmath 1473/tcp +openmath 1473/udp +telefinder 1474/tcp +telefinder 1474/udp +taligent-lm 1475/tcp #Taligent License Manager +taligent-lm 1475/udp #Taligent License Manager +clvm-cfg 1476/tcp +clvm-cfg 1476/udp +ms-sna-server 1477/tcp +ms-sna-server 1477/udp +ms-sna-base 1478/tcp +ms-sna-base 1478/udp +dberegister 1479/tcp +dberegister 1479/udp +pacerforum 1480/tcp +pacerforum 1480/udp +airs 1481/tcp +airs 1481/udp +miteksys-lm 1482/tcp #Miteksys License Manager +miteksys-lm 1482/udp #Miteksys License Manager +afs 1483/tcp #AFS License Manager +afs 1483/udp #AFS License Manager +confluent 1484/tcp #Confluent License Manager +confluent 1484/udp #Confluent License Manager +lansource 1485/tcp +lansource 1485/udp +nms_topo_serv 1486/tcp +nms_topo_serv 1486/udp +localinfosrvr 1487/tcp +localinfosrvr 1487/udp +docstor 1488/tcp +docstor 1488/udp +dmdocbroker 1489/tcp +dmdocbroker 1489/udp +insitu-conf 1490/tcp +insitu-conf 1490/udp +anynetgateway 1491/tcp +anynetgateway 1491/udp +stone-design-1 1492/tcp +stone-design-1 1492/udp +netmap_lm 1493/tcp +netmap_lm 1493/udp +ica 1494/tcp +ica 1494/udp +cvc 1495/tcp +cvc 1495/udp +liberty-lm 1496/tcp +liberty-lm 1496/udp +rfx-lm 1497/tcp +rfx-lm 1497/udp +watcom-sql 1498/tcp +watcom-sql 1498/udp +fhc 1499/tcp #Federico Heinz Consultora +fhc 1499/udp #Federico Heinz Consultora +vlsi-lm 1500/tcp #VLSI License Manager +vlsi-lm 1500/udp #VLSI License Manager +sas-3 1501/tcp #Satellite-data Acquisition System 3 +sas-3 1501/udp #Satellite-data Acquisition System 3 +shivadiscovery 1502/tcp #Shiva +shivadiscovery 1502/udp #Shiva +imtc-mcs 1503/tcp #Databeam +imtc-mcs 1503/udp #Databeam +evb-elm 1504/tcp #EVB Software Engineering License Manager +evb-elm 1504/udp #EVB Software Engineering License Manager +funkproxy 1505/tcp #Funk Software, Inc. +funkproxy 1505/udp #Funk Software, Inc. +utcd 1506/tcp #Universal Time daemon (utcd) +utcd 1506/udp #Universal Time daemon (utcd) +symplex 1507/tcp +symplex 1507/udp +diagmond 1508/tcp +diagmond 1508/udp +robcad-lm 1509/tcp #Robcad, Ltd. License Manager +robcad-lm 1509/udp #Robcad, Ltd. License Manager +mvx-lm 1510/tcp #Midland Valley Exploration Ltd. Lic. Man. +mvx-lm 1510/udp #Midland Valley Exploration Ltd. Lic. Man. +3l-l1 1511/tcp +3l-l1 1511/udp +wins 1512/tcp #Microsoft's Windows Internet Name Service +wins 1512/udp #Microsoft's Windows Internet Name Service +fujitsu-dtc 1513/tcp #Fujitsu Systems Business of America, Inc +fujitsu-dtc 1513/udp #Fujitsu Systems Business of America, Inc +fujitsu-dtcns 1514/tcp #Fujitsu Systems Business of America, Inc +fujitsu-dtcns 1514/udp #Fujitsu Systems Business of America, Inc +ifor-protocol 1515/tcp +ifor-protocol 1515/udp +vpad 1516/tcp #Virtual Places Audio data +vpad 1516/udp #Virtual Places Audio data +vpac 1517/tcp #Virtual Places Audio control +vpac 1517/udp #Virtual Places Audio control +vpvd 1518/tcp #Virtual Places Video data +vpvd 1518/udp #Virtual Places Video data +vpvc 1519/tcp #Virtual Places Video control +vpvc 1519/udp #Virtual Places Video control +atm-zip-office 1520/tcp #atm zip office +atm-zip-office 1520/udp #atm zip office +ncube-lm 1521/tcp #nCube License Manager +ncube-lm 1521/udp #nCube License Manager +rna-lm 1522/tcp #Ricardo North America License Manager +rna-lm 1522/udp #Ricardo North America License Manager +cichild-lm 1523/tcp +cichild-lm 1523/udp +ingreslock 1524/tcp #ingres +ingreslock 1524/udp #ingres +prospero-np 1525/tcp #Prospero Directory Service non-priv +prospero-np 1525/udp #Prospero Directory Service non-priv +#PROBLEMS!======================================================== +orasrv 1525/tcp #oracle +orasrv 1525/udp #oracle +#PROBLEMS!======================================================== +pdap-np 1526/tcp #Prospero Data Access Prot non-priv +pdap-np 1526/udp #Prospero Data Access Prot non-priv +tlisrv 1527/tcp #oracle +tlisrv 1527/udp #oracle +mciautoreg 1528/tcp +mciautoreg 1528/udp +support 1529/tcp prmsd gnatsd # cygnus bug tracker +coauthor 1529/tcp #oracle +coauthor 1529/udp #oracle +rap-service 1530/tcp +rap-service 1530/udp +rap-listen 1531/tcp +rap-listen 1531/udp +miroconnect 1532/tcp +miroconnect 1532/udp +virtual-places 1533/tcp #Virtual Places Software +virtual-places 1533/udp #Virtual Places Software +micromuse-lm 1534/tcp +micromuse-lm 1534/udp +ampr-info 1535/tcp +ampr-info 1535/udp +ampr-inter 1536/tcp +ampr-inter 1536/udp +sdsc-lm 1537/tcp +sdsc-lm 1537/udp +3ds-lm 1538/tcp +3ds-lm 1538/udp +intellistor-lm 1539/tcp #Intellistor License Manager +intellistor-lm 1539/udp #Intellistor License Manager +rds 1540/tcp +rds 1540/udp +rds2 1541/tcp +rds2 1541/udp +gridgen-elmd 1542/tcp +gridgen-elmd 1542/udp +simba-cs 1543/tcp +simba-cs 1543/udp +aspeclmd 1544/tcp +aspeclmd 1544/udp +vistium-share 1545/tcp +vistium-share 1545/udp +abbaccuray 1546/tcp +abbaccuray 1546/udp +laplink 1547/tcp +laplink 1547/udp +axon-lm 1548/tcp #Axon License Manager +axon-lm 1548/udp #Axon License Manager +shivahose 1549/tcp #Shiva Hose +shivasound 1549/udp #Shiva Sound +3m-image-lm 1550/tcp #Image Storage license manager 3M Company +3m-image-lm 1550/udp #Image Storage license manager 3M Company +hecmtl-db 1551/tcp +hecmtl-db 1551/udp +pciarray 1552/tcp +pciarray 1552/udp +issd 1600/tcp +issd 1600/udp +# IMPORTANT NOTE: Ports 1645/1646 are the traditional radius ports used by +# many vendors without obtaining official IANA assignment. The official +# assignment is now ports 1812/1813 and users are encouraged to migrate +# when possible to these new ports. +#radius 1645/udp #RADIUS authentication protocol (old) +#radacct 1646/udp #RADIUS accounting protocol (old) +nkd 1650/tcp +nkd 1650/udp +shiva_confsrvr 1651/tcp +shiva_confsrvr 1651/udp +xnmp 1652/tcp +xnmp 1652/udp +netview-aix-1 1661/tcp +netview-aix-1 1661/udp +netview-aix-2 1662/tcp +netview-aix-2 1662/udp +netview-aix-3 1663/tcp +netview-aix-3 1663/udp +netview-aix-4 1664/tcp +netview-aix-4 1664/udp +netview-aix-5 1665/tcp +netview-aix-5 1665/udp +netview-aix-6 1666/tcp +netview-aix-6 1666/udp +netview-aix-7 1667/tcp +netview-aix-7 1667/udp +netview-aix-8 1668/tcp +netview-aix-8 1668/udp +netview-aix-9 1669/tcp +netview-aix-9 1669/udp +netview-aix-10 1670/tcp +netview-aix-10 1670/udp +netview-aix-11 1671/tcp +netview-aix-11 1671/udp +netview-aix-12 1672/tcp +netview-aix-12 1672/udp +l2f 1701/tcp #l2f +l2f 1701/udp #l2f +l2tp 1701/tcp #Layer 2 Tunnelling Protocol +l2tp 1701/udp #Layer 2 Tunnelling Protocol +pptp 1723/tcp #Point-to-point tunnelling protocol +# IMPORTANT NOTE: See comments for ports 1645/1646 when using older equipment +radius 1812/udp #RADIUS authentication protocol (IANA sanctioned) +radacct 1813/udp #RADIUS accounting protocol (IANA sanctioned) +licensedaemon 1986/tcp #cisco license management +licensedaemon 1986/udp #cisco license management +tr-rsrb-p1 1987/tcp #cisco RSRB Priority 1 port +tr-rsrb-p1 1987/udp #cisco RSRB Priority 1 port +tr-rsrb-p2 1988/tcp #cisco RSRB Priority 2 port +tr-rsrb-p2 1988/udp #cisco RSRB Priority 2 port +tr-rsrb-p3 1989/tcp #cisco RSRB Priority 3 port +tr-rsrb-p3 1989/udp #cisco RSRB Priority 3 port +#PROBLEMS!=================================================== +mshnet 1989/tcp #MHSnet system +mshnet 1989/udp #MHSnet system +#PROBLEMS!=================================================== +stun-p1 1990/tcp #cisco STUN Priority 1 port +stun-p1 1990/udp #cisco STUN Priority 1 port +stun-p2 1991/tcp #cisco STUN Priority 2 port +stun-p2 1991/udp #cisco STUN Priority 2 port +stun-p3 1992/tcp #cisco STUN Priority 3 port +stun-p3 1992/udp #cisco STUN Priority 3 port +#PROBLEMS!=================================================== +ipsendmsg 1992/tcp +ipsendmsg 1992/udp +#PROBLEMS!=================================================== +snmp-tcp-port 1993/tcp #cisco SNMP TCP port +snmp-tcp-port 1993/udp #cisco SNMP TCP port +stun-port 1994/tcp #cisco serial tunnel port +stun-port 1994/udp #cisco serial tunnel port +perf-port 1995/tcp #cisco perf port +perf-port 1995/udp #cisco perf port +tr-rsrb-port 1996/tcp #cisco Remote SRB port +tr-rsrb-port 1996/udp #cisco Remote SRB port +gdp-port 1997/tcp #cisco Gateway Discovery Protocol +gdp-port 1997/udp #cisco Gateway Discovery Protocol +x25-svc-port 1998/tcp #cisco X.25 service (XOT) +x25-svc-port 1998/udp #cisco X.25 service (XOT) +tcp-id-port 1999/tcp #cisco identification port +tcp-id-port 1999/udp #cisco identification port +callbook 2000/tcp +callbook 2000/udp +dc 2001/tcp +wizard 2001/udp #curry +globe 2002/tcp +globe 2002/udp +cfingerd 2003/tcp #GNU finger +mailbox 2004/tcp +emce 2004/udp #CCWS mm conf +berknet 2005/tcp +oracle 2005/udp +invokator 2006/tcp +raid-cc 2006/udp #raid +dectalk 2007/tcp +raid-am 2007/udp +conf 2008/tcp +terminaldb 2008/udp +news 2009/tcp +whosockami 2009/udp +search 2010/tcp +pipe_server 2010/udp +raid-cc 2011/tcp #raid +servserv 2011/udp +ttyinfo 2012/tcp +raid-ac 2012/udp +raid-am 2013/tcp +raid-cd 2013/udp +troff 2014/tcp +raid-sf 2014/udp +cypress 2015/tcp +raid-cs 2015/udp +bootserver 2016/tcp +bootserver 2016/udp +cypress-stat 2017/tcp +bootclient 2017/udp +terminaldb 2018/tcp +rellpack 2018/udp +whosockami 2019/tcp +about 2019/udp +xinupageserver 2020/tcp +xinupageserver 2020/udp +servexec 2021/tcp +xinuexpansion1 2021/udp +down 2022/tcp +xinuexpansion2 2022/udp +xinuexpansion3 2023/tcp +xinuexpansion3 2023/udp +xinuexpansion4 2024/tcp +xinuexpansion4 2024/udp +ellpack 2025/tcp +xribs 2025/udp +scrabble 2026/tcp +scrabble 2026/udp +shadowserver 2027/tcp +shadowserver 2027/udp +submitserver 2028/tcp +submitserver 2028/udp +device2 2030/tcp +device2 2030/udp +blackboard 2032/tcp +blackboard 2032/udp +glogger 2033/tcp +glogger 2033/udp +scoremgr 2034/tcp +scoremgr 2034/udp +imsldoc 2035/tcp +imsldoc 2035/udp +objectmanager 2038/tcp +objectmanager 2038/udp +lam 2040/tcp +lam 2040/udp +interbase 2041/tcp +interbase 2041/udp +isis 2042/tcp +isis 2042/udp +isis-bcast 2043/tcp +isis-bcast 2043/udp +rimsl 2044/tcp +rimsl 2044/udp +cdfunc 2045/tcp +cdfunc 2045/udp +sdfunc 2046/tcp +sdfunc 2046/udp +#dls 2047/tcp +#dls 2047/udp +dls-monitor 2048/tcp +dls-monitor 2048/udp +nfsd 2049/tcp nfs # NFS server daemon +nfsd 2049/udp nfs # NFS server daemon +#PROBLEMS!============================================================= +#shilp 2049/tcp +#shilp 2049/udp +#PROBLEMS!============================================================= +dlsrpn 2065/tcp #Data Link Switch Read Port Number +dlsrpn 2065/udp #Data Link Switch Read Port Number +dlswpn 2067/tcp #Data Link Switch Write Port Number +dlswpn 2067/udp #Data Link Switch Write Port Number +zephyr-clt 2103/udp #Zephyr serv-hm connection +zephyr-hm 2104/udp #Zephyr hostmanager +#PROBLEMS!============================================================= +#zephyr-hm-srv 2105/udp #Zephyr hm-serv connection +#PROBLEMS!============================================================= +eklogin 2105/tcp #Kerberos (v4) encrypted rlogin +eklogin 2105/udp #Kerberos (v4) encrypted rlogin +ekshell 2106/tcp #Kerberos (v4) encrypted rshell +ekshell 2106/udp #Kerberos (v4) encrypted rshell +rkinit 2108/tcp #Kerberos (v4) remote initialization +rkinit 2108/udp #Kerberos (v4) remote initialization +ats 2201/tcp #Advanced Training System Program +ats 2201/udp #Advanced Training System Program +hpssd 2207/tcp #HP Status and Services +hpssd 2207/udp #HP Status and Services +hpiod 2208/tcp #HP I/O Backend +hpiod 2208/udp #HP I/O Backend +ivs-video 2232/tcp #IVS Video default +ivs-video 2232/udp #IVS Video default +ivsd 2241/tcp #IVS Daemon +ivsd 2241/udp #IVS Daemon +pehelp 2307/tcp +pehelp 2307/udp +cvspserver 2401/tcp #CVS network server +cvspserver 2401/udp #CVS network server +venus 2430/tcp #venus +venus 2430/udp #venus +venus-se 2431/tcp #venus-se +venus-se 2431/udp #venus-se +codasrv 2432/tcp #codasrv +codasrv 2432/udp #codasrv +codasrv-se 2433/tcp #codasrv-se +codasrv-se 2433/udp #codasrv-se +rtsserv 2500/tcp #Resource Tracking system server +rtsserv 2500/udp #Resource Tracking system server +rtsclient 2501/tcp #Resource Tracking system client +rtsclient 2501/udp #Resource Tracking system client +hp-3000-telnet 2564/tcp #HP 3000 NS/VT block mode telnet +zebrasrv 2600/tcp #zebra service +zebra 2601/tcp #zebra vty +ripd 2602/tcp #RIPd vty +ripngd 2603/tcp #RIPngd vty +ospfd 2604/tcp #OSPFd vty +bgpd 2605/tcp #BGPd vty +ospf6d 2606/tcp #OSPF6d vty +dict 2628/tcp #RFC 2229 +dict 2628/udp #RFC 2229 +listen 2766/tcp #System V listener port +www-dev 2784/tcp #world wide web - development +www-dev 2784/udp #world wide web - development +eppc 3031/tcp #Remote AppleEvents/PPC Toolbox +eppc 3031/udp #Remote AppleEvents/PPC Toolbox +NSWS 3049/tcp +NSWS 3049/udp +gds_db 3050/tcp #InterBase Database Remote Protocol +gds_db 3050/udp #InterBase Database Remote Protocol +sj3 3086/tcp #SJ3 (kanji input) +vmodem 3141/tcp +vmodem 3141/udp +iscsi-target 3260/tcp # iSCSI port +iscsi-target 3260/udp # iSCSI port +ccmail 3264/tcp #cc:mail/lotus +ccmail 3264/udp #cc:mail/lotus +dec-notes 3333/tcp #DEC Notes +dec-notes 3333/udp #DEC Notes +rdp 3389/tcp #Microsoft Remote Desktop Protocol +bmap 3421/tcp #Bull Apprise portmapper +bmap 3421/udp #Bull Apprise portmapper +prsvp 3455/tcp #RSVP Port +prsvp 3455/udp rsvp-encap #RSVP Port +vat 3456/tcp #VAT default data +vat 3456/udp #VAT default data +vat-control 3457/tcp #VAT default control +vat-control 3457/udp #VAT default control +nut 3493/tcp #Network UPS Tools +nut 3493/udp #Network UPS Tools +tsp 3653/tcp #Tunnel Setup Protocol +tsp 3653/udp #Tunnel Setup Protocol +svn 3690/tcp #Subversion +svn 3690/udp #Subversion +udt_os 3900/tcp #Unidata UDT OS +udt_os 3900/udp #Unidata UDT OS +mapper-nodemgr 3984/tcp #MAPPER network node manager +mapper-nodemgr 3984/udp #MAPPER network node manager +mapper-mapethd 3985/tcp #MAPPER TCP/IP server +mapper-mapethd 3985/udp #MAPPER TCP/IP server +mapper-ws_ethd 3986/tcp #MAPPER workstation server +mapper-ws_ethd 3986/udp #MAPPER workstation server +netcheque 4008/tcp #NetCheque accounting +netcheque 4008/udp #NetCheque accounting +lockd 4045/udp # NFS lock daemon/manager +lockd 4045/tcp +nuts_dem 4132/tcp #NUTS Daemon +nuts_dem 4132/udp #NUTS Daemon +nuts_bootp 4133/tcp #NUTS Bootp Server +nuts_bootp 4133/udp #NUTS Bootp Server +sieve 4190/tcp #ManageSieve Protocol +sieve 4190/udp #ManageSieve Protocol +rwhois 4321/tcp #Remote Who Is +rwhois 4321/udp #Remote Who Is +unicall 4343/tcp +unicall 4343/udp +epmd 4369/tcp #Erlang Port Mapper Daemon +epmd 4369/udp #Erlang Port Mapper Daemon +krb524 4444/tcp +krb524 4444/udp +# PROBLEM krb524 assigned the port, +# PROBLEM nv used it without an assignment +nv-video 4444/tcp #NV Video default +nv-video 4444/udp #NV Video default +sae-urn 4500/tcp +sae-urn 4500/udp +fax 4557/tcp #FAX transmission service +hylafax 4559/tcp #HylaFAX client-server protocol +rfa 4672/tcp #remote file access server +rfa 4672/udp #remote file access server +commplex-main 5000/tcp +commplex-main 5000/udp +commplex-link 5001/tcp +commplex-link 5001/udp +rfe 5002/tcp #radio free ethernet +rfe 5002/udp #radio free ethernet +telelpathstart 5010/tcp +telelpathstart 5010/udp +telelpathattack 5011/tcp +telelpathattack 5011/udp +mmcc 5050/tcp #multimedia conference control tool +mmcc 5050/udp #multimedia conference control tool +sds 5059/tcp #SIP Directory Services +sds 5059/udp #SIP Directory Services +sip 5060/tcp #Session Initialization Protocol (VoIP) +sip 5060/udp #Session Initialization Protocol (VoIP) +sip-tls 5061/tcp #SIP over TLS +sip-tls 5061/udp #SIP over TLS +rmonitor_secure 5145/tcp +rmonitor_secure 5145/udp +aol 5190/tcp #America-Online +aol 5190/udp #America-Online +aol-1 5191/tcp #AmericaOnline1 +aol-1 5191/udp #AmericaOnline1 +aol-2 5192/tcp #AmericaOnline2 +aol-2 5192/udp #AmericaOnline2 +aol-3 5193/tcp #AmericaOnline3 +aol-3 5193/udp #AmericaOnline3 +xmpp-client 5222/tcp #XMPP Client Connection +xmpp-client 5222/udp #XMPP Client Connection +padl2sim 5236/tcp +padl2sim 5236/udp +xmpp-server 5269/tcp #XMPP Server Connection +xmpp-server 5269/udp #XMPP Server Connection +hacl-hb 5300/tcp # HA cluster heartbeat +hacl-hb 5300/udp # HA cluster heartbeat +hacl-gs 5301/tcp # HA cluster general services +hacl-gs 5301/udp # HA cluster general services +hacl-cfg 5302/tcp # HA cluster configuration +hacl-cfg 5302/udp # HA cluster configuration +hacl-probe 5303/tcp # HA cluster probing +hacl-probe 5303/udp # HA cluster probing +hacl-local 5304/tcp +hacl-local 5304/udp +hacl-test 5305/tcp +hacl-test 5305/udp +cfengine 5308/tcp +cfengine 5308/udp +mdns 5353/tcp #Multicast DNS +mdns 5353/udp #Multicast DNS +postgresql 5432/tcp #PostgreSQL Database +postgresql 5432/udp #PostgreSQL Database +rplay 5555/udp +canna 5680/tcp #Canna (Japanese Input) +proshareaudio 5713/tcp #proshare conf audio +proshareaudio 5713/udp #proshare conf audio +prosharevideo 5714/tcp #proshare conf video +prosharevideo 5714/udp #proshare conf video +prosharedata 5715/tcp #proshare conf data +prosharedata 5715/udp #proshare conf data +prosharerequest 5716/tcp #proshare conf request +prosharerequest 5716/udp #proshare conf request +prosharenotify 5717/tcp #proshare conf notify +prosharenotify 5717/udp #proshare conf notify +cvsup 5999/tcp #CVSup file transfer/John Polstra/FreeBSD +x11 6000/tcp #6000-6063 are assigned to X Window System +x11 6000/udp +x11-ssh 6010/tcp #Unofficial name, for convenience +x11-ssh 6010/udp +softcm 6110/tcp #HP SoftBench CM +softcm 6110/udp #HP SoftBench CM +spc 6111/tcp #HP SoftBench Sub-Process Control +spc 6111/udp #HP SoftBench Sub-Process Control +meta-corp 6141/tcp #Meta Corporation License Manager +meta-corp 6141/udp #Meta Corporation License Manager +aspentec-lm 6142/tcp #Aspen Technology License Manager +aspentec-lm 6142/udp #Aspen Technology License Manager +watershed-lm 6143/tcp #Watershed License Manager +watershed-lm 6143/udp #Watershed License Manager +statsci1-lm 6144/tcp #StatSci License Manager - 1 +statsci1-lm 6144/udp #StatSci License Manager - 1 +statsci2-lm 6145/tcp #StatSci License Manager - 2 +statsci2-lm 6145/udp #StatSci License Manager - 2 +lonewolf-lm 6146/tcp #Lone Wolf Systems License Manager +lonewolf-lm 6146/udp #Lone Wolf Systems License Manager +montage-lm 6147/tcp #Montage License Manager +montage-lm 6147/udp #Montage License Manager +ricardo-lm 6148/tcp #Ricardo North America License Manager +ricardo-lm 6148/udp #Ricardo North America License Manager +sge_qmaster 6444/tcp #Grid Engine Qmaster Service +sge_qmaster 6444/udp #Grid Engine Qmaster Service +sge_execd 6445/tcp #Grid Engine Execution Service +sge_execd 6445/udp #Grid Engine Execution Service +xdsxdm 6558/tcp +xdsxdm 6558/udp +ircd 6667/tcp #Internet Relay Chat (unoffical) +acmsoda 6969/tcp +acmsoda 6969/udp +afs3-fileserver 7000/tcp #file server itself +afs3-fileserver 7000/udp #file server itself +afs3-callback 7001/tcp #callbacks to cache managers +afs3-callback 7001/udp #callbacks to cache managers +afs3-prserver 7002/tcp #users & groups database +afs3-prserver 7002/udp #users & groups database +afs3-vlserver 7003/tcp #volume location database +afs3-vlserver 7003/udp #volume location database +afs3-kaserver 7004/tcp #AFS/Kerberos authentication service +afs3-kaserver 7004/udp #AFS/Kerberos authentication service +afs3-volser 7005/tcp #volume management server +afs3-volser 7005/udp #volume management server +afs3-errors 7006/tcp #error interpretation service +afs3-errors 7006/udp #error interpretation service +afs3-bos 7007/tcp #basic overseer process +afs3-bos 7007/udp #basic overseer process +afs3-update 7008/tcp #server-to-server updater +afs3-update 7008/udp #server-to-server updater +afs3-rmtsys 7009/tcp #remote cache manager service +afs3-rmtsys 7009/udp #remote cache manager service +afs3-resserver 7010/tcp #MR-AFS residence server +afs3-resserver 7010/udp #MR-AFS residence server +ups-onlinet 7010/tcp #onlinet uninterruptable power supplies +ups-onlinet 7010/udp #onlinet uninterruptable power supplies +afs3-remio 7011/tcp #MR-AFS remote IO server +afs3-remio 7011/udp #MR-AFS remote IO server +font-service 7100/tcp #X Font Service +font-service 7100/udp #X Font Service +fodms 7200/tcp #FODMS FLIP +fodms 7200/udp #FODMS FLIP +dlip 7201/tcp +dlip 7201/udp +ftp-proxy 8021/tcp # FTP proxy +natd 8668/divert # Network Address Translation +jetdirect 9100/tcp #HP JetDirect card +git 9418/tcp #git pack transfer service +git 9418/udp #git pack transfer service +man 9535/tcp +man 9535/udp +sd 9876/tcp #Session Director +sd 9876/udp #Session Director +amanda 10080/tcp #Dump server control +amanda 10080/udp #Dump server control +amandaidx 10082/tcp #Amanda indexing +amidxtape 10083/tcp #Amanda tape indexing +isode-dua 17007/tcp +isode-dua 17007/udp +biimenu 18000/tcp #Beckman Instruments, Inc. +biimenu 18000/udp #Beckman Instruments, Inc. +wnn4 22273/tcp wnn6 #Wnn4 (Japanese input) +wnn4_Cn 22289/tcp wnn6_Cn #Wnn4 (Chinese input) +wnn4_Kr 22305/tcp wnn6_Kr #Wnn4 (Korean input) +wnn4_Tw 22321/tcp wnn6_Tw #Wnn4 (Taiwanse input) +wnn6_DS 26208/tcp #Wnn6 (Dserver) +dbbrowse 47557/tcp #Databeam Corporation +dbbrowse 47557/udp #Databeam Corporation diff --git a/base/initfs/initfs/etc/shadow.new b/base/initfs/initfs/etc/shadow.new new file mode 100644 index 0000000..9929391 --- /dev/null +++ b/base/initfs/initfs/etc/shadow.new @@ -0,0 +1,13 @@ +root:XZKqCG3ai3paI:18421:0::::: +lp:!:18416:0:99999:7::: +messagebus:*:9797:0::::: +postfix:!:18421:0:99999:7::: +dovecot:!:18421:0:99999:7::: +dovenull:!:18421:0:99999:7::: +privoxy:!:18421:0:99999:7::: +tor:!:18421:0:99999:7::: +chrony:!:18421:0:99999:7::: +unbound:!:18421:0:99999:7::: +mysql:!:18421:0:9999:7::: +rpc:!:18421:0:9999:7::: +www-data:!:18421:0:9999:7::: diff --git a/base/initfs/initfs/etc/shells.new b/base/initfs/initfs/etc/shells.new new file mode 100644 index 0000000..f040ae3 --- /dev/null +++ b/base/initfs/initfs/etc/shells.new @@ -0,0 +1,3 @@ +/bin/sh +/bin/mksh +/bin/bash diff --git a/base/initfs/initfs/root/README b/base/initfs/initfs/root/README new file mode 100644 index 0000000..2ab68d9 --- /dev/null +++ b/base/initfs/initfs/root/README @@ -0,0 +1,21 @@ +**** CONSOLE KEYMAPPINGS **** + +You can change the keyboard mappings by running the "loadkmap" +applet provided by busybox. To view the available mappings, +run "loadkeys" program, or you can simply find the mappings by +doing ls /usr/share/kmap. + +loadkmap < /share/kmap/us.kmap + +^ Loads US keyboard mappings. + +And then add it to /etc/rc.d/rc.local or any other convenient place + +**** CONSOLE FONTS **** + +Console fonts can be loaded using the setfont applet provided by busybox. +However, busybox won't load psf.gz/pcf.gz files. It'll only load .psf files: + +setfont /share/kbd/consolefonts/ter-v*.psf + + diff --git a/base/intltool/intltool-regex-warning.patch b/base/intltool/intltool-regex-warning.patch new file mode 100644 index 0000000..606a0af --- /dev/null +++ b/base/intltool/intltool-regex-warning.patch @@ -0,0 +1,43 @@ +--- a/intltool-update.in 2015-03-09 01:39:54.000000000 +0000 ++++ b/intltool-update.in 2017-01-22 20:14:20.359080387 +0000 +@@ -1062,7 +1062,7 @@ + } + } + +- if ($str =~ /^(.*)\${?([A-Z_]+)}?(.*)$/) ++ if ($str =~ /^(.*)\$\{?([A-Z_]+)}?(.*)$/) + { + my $rest = $3; + my $untouched = $1; +@@ -1190,10 +1190,10 @@ + $name =~ s/\(+$//g; + $version =~ s/\(+$//g; + +- $varhash{"PACKAGE_NAME"} = $name if (not $name =~ /\${?AC_PACKAGE_NAME}?/); +- $varhash{"PACKAGE"} = $name if (not $name =~ /\${?PACKAGE}?/); +- $varhash{"PACKAGE_VERSION"} = $version if (not $name =~ /\${?AC_PACKAGE_VERSION}?/); +- $varhash{"VERSION"} = $version if (not $name =~ /\${?VERSION}?/); ++ $varhash{"PACKAGE_NAME"} = $name if (not $name =~ /\$\{?AC_PACKAGE_NAME}?/); ++ $varhash{"PACKAGE"} = $name if (not $name =~ /\$\{?PACKAGE}?/); ++ $varhash{"PACKAGE_VERSION"} = $version if (not $name =~ /\$\{?AC_PACKAGE_VERSION}?/); ++ $varhash{"VERSION"} = $version if (not $name =~ /\$\{?VERSION}?/); + } + + if ($conf_source =~ /^AC_INIT\(([^,\)]+),([^,\)]+)[,]?([^,\)]+)?/m) +@@ -1219,11 +1219,11 @@ + $version =~ s/\(+$//g; + $bugurl =~ s/\(+$//g if (defined $bugurl); + +- $varhash{"PACKAGE_NAME"} = $name if (not $name =~ /\${?AC_PACKAGE_NAME}?/); +- $varhash{"PACKAGE"} = $name if (not $name =~ /\${?PACKAGE}?/); +- $varhash{"PACKAGE_VERSION"} = $version if (not $name =~ /\${?AC_PACKAGE_VERSION}?/); +- $varhash{"VERSION"} = $version if (not $name =~ /\${?VERSION}?/); +- $varhash{"PACKAGE_BUGREPORT"} = $bugurl if (defined $bugurl and not $bugurl =~ /\${?\w+}?/); ++ $varhash{"PACKAGE_NAME"} = $name if (not $name =~ /\$\{?AC_PACKAGE_NAME}?/); ++ $varhash{"PACKAGE"} = $name if (not $name =~ /\$\{?PACKAGE}?/); ++ $varhash{"PACKAGE_VERSION"} = $version if (not $name =~ /\$\{?AC_PACKAGE_VERSION}?/); ++ $varhash{"VERSION"} = $version if (not $name =~ /\$\{?VERSION}?/); ++ $varhash{"PACKAGE_BUGREPORT"} = $bugurl if (defined $bugurl and not $bugurl =~ /\$\{?\w+}?/); + } + + # \s makes this not work, why? diff --git a/base/intltool/intltool.SMBuild b/base/intltool/intltool.SMBuild new file mode 100755 index 0000000..af6cf0b --- /dev/null +++ b/base/intltool/intltool.SMBuild @@ -0,0 +1,33 @@ +APP=intltool +VERSION=0.51.0 +BUILD=1sml +HOMEPAGE='https://launchpad.net/intltool' +DOWNLOAD='https://launchpad.net/intltool/trunk/0.51.0/+download/intltool-0.51.0.tar.gz' +DESC="Utilities for translation support" +REQUIRES="perl-modules" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/intltool-regex-warning.patch + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4c93cb26592ed0b1622d3b7800b5d6622ffa36f58ac73f2ef0bddfab522565fdfb8fa73d81914b9a202f1d62bc995a08960f8adb9f62c86918e75498e85fbfdf intltool-0.51.0.tar.gz +2ca20ba6ff0492cd7c816cca4c17bbf11281ae4c24bb4f70cfa92826ff2127036b8a07de5a61765becfd0ff506ca092e05ecd7a02b796ba92745459786e7ba03 intltool-regex-warning.patch +" \ No newline at end of file diff --git a/base/iptables/iptables-1.4.14-musl-fixes.patch b/base/iptables/iptables-1.4.14-musl-fixes.patch new file mode 100644 index 0000000..547d0df --- /dev/null +++ b/base/iptables/iptables-1.4.14-musl-fixes.patch @@ -0,0 +1,127 @@ +--- iptables-1.4.12.1.o/extensions/libip6t_ipv6header.c ++++ iptables-1.4.12.1/extensions/libip6t_ipv6header.c +@@ -10,6 +10,9 @@ + #include + #include + #include ++#ifndef IPPROTO_HOPOPTS ++# define IPPROTO_HOPOPTS 0 ++#endif + + enum { + O_HEADER = 0, +--- iptables-1.4.12.1.o/extensions/libxt_TCPOPTSTRIP.c ++++ iptables-1.4.12.1/extensions/libxt_TCPOPTSTRIP.c +@@ -12,6 +12,21 @@ + #ifndef TCPOPT_MD5SIG + # define TCPOPT_MD5SIG 19 + #endif ++#ifndef TCPOPT_MAXSEG ++# define TCPOPT_MAXSEG 2 ++#endif ++#ifndef TCPOPT_WINDOW ++# define TCPOPT_WINDOW 3 ++#endif ++#ifndef TCPOPT_SACK_PERMITTED ++# define TCPOPT_SACK_PERMITTED 4 ++#endif ++#ifndef TCPOPT_SACK ++# define TCPOPT_SACK 5 ++#endif ++#ifndef TCPOPT_TIMESTAMP ++# define TCPOPT_TIMESTAMP 8 ++#endif + + enum { + O_STRIP_OPTION = 0, +--- iptables-1.4.12.1.o/include/libiptc/ipt_kernel_headers.h ++++ iptables-1.4.12.1/include/libiptc/ipt_kernel_headers.h +@@ -5,7 +5,6 @@ + + #include + +-#if defined(__GLIBC__) && __GLIBC__ == 2 + #include + #include + #include +@@ -13,15 +12,4 @@ + #include + #include + #include +-#else /* libc5 */ +-#include +-#include +-#include +-#include +-#include +-#include +-#include +-#include +-#include +-#endif + #endif +--- iptables-1.4.12.1.o/include/linux/netfilter_ipv4/ip_tables.h ++++ iptables-1.4.12.1/include/linux/netfilter_ipv4/ip_tables.h +@@ -16,6 +16,7 @@ + #define _IPTABLES_H + + #include ++#include + + #include + +--- iptables-1.4.12.1.o/iptables/ip6tables-restore.c ++++ iptables-1.4.12.1/iptables/ip6tables-restore.c +@@ -9,7 +9,7 @@ + */ + + #include +-#include ++#include + #include + #include + #include +--- iptables-1.4.12.1.o/iptables/ip6tables-save.c ++++ iptables-1.4.12.1/iptables/ip6tables-save.c +@@ -6,7 +6,7 @@ + * This code is distributed under the terms of GNU GPL v2 + */ + #include +-#include ++#include + #include + #include + #include +--- iptables-1.4.12.1.o/iptables/iptables-restore.c ++++ iptables-1.4.12.1/iptables/iptables-restore.c +@@ -6,7 +6,7 @@ + */ + + #include +-#include ++#include + #include + #include + #include +--- iptables-1.4.12.1.o/iptables/iptables-save.c ++++ iptables-1.4.12.1/iptables/iptables-save.c +@@ -6,7 +6,7 @@ + * + */ + #include +-#include ++#include + #include + #include + #include +--- iptables-1.4.12.1.o/iptables/iptables-xml.c ++++ iptables-1.4.12.1/iptables/iptables-xml.c +@@ -7,7 +7,7 @@ + */ + + #include +-#include ++#include + #include + #include + #include diff --git a/base/iptables/iptables.SMBuild b/base/iptables/iptables.SMBuild new file mode 100755 index 0000000..e418786 --- /dev/null +++ b/base/iptables/iptables.SMBuild @@ -0,0 +1,34 @@ +APP=iptables +VERSION=1.4.20 +BUILD=1sml +HOMEPAGE='https://www.netfilter.org/projects/iptables/index.html' +DOWNLOAD='https://www.netfilter.org/projects/iptables/files/iptables-1.4.20.tar.bz2' +DESC="IP packet filter administration tool" +REQUIRES="libpcap libnfnetlink libnetfilter_conntrack" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/iptables-1.4.14-musl-fixes.patch + + ./configure \ + --prefix="" \ + --sbindir=/bin + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3f0b13052486f3b43a53989559417938a77ee4039c3ef606b286cba4708e118c9e4ebbd5e6304878e7d7ebb7adca8b660d6e40d2772567f1c78d19af459db270 iptables-1.4.20.tar.lz +bc1cb36957d5afb80b770fe15f951de3074e2b1b28015372fb6f121fd551dd0e86c76c1819022dc468d11750b3969db40ef2dc9651c654c9f99212c0f2746985 iptables-1.4.14-musl-fixes.patch +" diff --git a/base/iso-codes/iso-codes.SMBuild b/base/iso-codes/iso-codes.SMBuild new file mode 100755 index 0000000..0fe2120 --- /dev/null +++ b/base/iso-codes/iso-codes.SMBuild @@ -0,0 +1,38 @@ +APP=iso-codes +VERSION=4.4 +BUILD=1sml +HOMEPAGE='https://salsa.debian.org/iso-codes-team/iso-codes' +DOWNLOAD='http://anduin.linuxfromscratch.org/BLFS/iso-codes/iso-codes-4.4.tar.xz' +DESC="ISO standards collection like language, language script and curreny names" +REQUIRES="gettext" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # this software is so stupid, it doesn't make a basic msgfmt file check, + # which is part of gettext. + if [ ! -x /bin/msgfmt ]; then + exit 1 + fi + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --localstatedir=/var + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a2a07de5d8f4cd9851a86a3e28e8e0bb7c594246a706116b3dcc0f37423f4d880c76aa0a7b5b18aa3cc783c23689fc2f5c7faf83466d5cf2bf5a6b24f7626aef iso-codes-4.4.tar.lz +" diff --git a/base/itstool/itstool.SMBuild b/base/itstool/itstool.SMBuild new file mode 100755 index 0000000..b63ee47 --- /dev/null +++ b/base/itstool/itstool.SMBuild @@ -0,0 +1,31 @@ +APP=itstool +VERSION=2.0.6 +BUILD=1sml +HOMEPAGE='http://itstool.org/' +DOWNLOAD='http://files.itstool.org/itstool/itstool-2.0.6.tar.bz2' +DESC="Translate XML documents with PO files" +REQUIRES="python3 docbook" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING* NEWS $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +99f612db4bc009ac017abee6afff6121f73f759746cfbcab17a788348c294f7d6d94b0b8812fc34d716b6775fdd60039ab2a754bd1e285a9fcd73b4398157b63 itstool-2.0.6.tar.lz +" diff --git a/base/jam/jam.SMBuild b/base/jam/jam.SMBuild new file mode 100755 index 0000000..7d011b9 --- /dev/null +++ b/base/jam/jam.SMBuild @@ -0,0 +1,28 @@ +APP=jam +VERSION=2.5 +BUILD=1sml +HOMEPAGE='http://public.perforce.com/public/jam/src/Jam.html' +DOWNLOAD='' +DESC="Program construction tool like make" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + mkdir $APP-$VERSION + cd $APP-$VERSION + + unzip $SRCDIR/$APP-$VERSION.zip + fixbuilddirpermissions + + make V=s + ./jam0 -sBINDIR=$PKG/bin install + + cp Porting README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bbb3132c617a14dff9fcce70e6d88bed298a5c6bee580fa9d9a2d99b47507c252968e5fdf66138e6d69d1f60f724365fd80012164cffc1e3d0f2c1005bcec437 jam-2.5.zip +" diff --git a/base/jansson/jansson.SMBuild b/base/jansson/jansson.SMBuild new file mode 100755 index 0000000..0674422 --- /dev/null +++ b/base/jansson/jansson.SMBuild @@ -0,0 +1,32 @@ +APP=jansson +VERSION=2.13 +BUILD=1sml +HOMEPAGE='https://digip.org/jansson/' +DOWNLOAD='https://digip.org/jansson/releases/jansson-2.13.tar.bz2' +DESC="library for encoding, decoding and manipulating JSON data" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +64f6f81d8b3b1814845b9014f7da77bbf536abb7572dd939bfc870c9c5c93791e4f0c4e574f71ed1de19d74d1efe9498d045073905c119786554b7f2d7c1fde6 jansson-2.13.tar.lz +" diff --git a/base/jbig2dec/jbig2dec.SMBuild b/base/jbig2dec/jbig2dec.SMBuild new file mode 100755 index 0000000..4896d79 --- /dev/null +++ b/base/jbig2dec/jbig2dec.SMBuild @@ -0,0 +1,31 @@ +APP=jbig2dec +VERSION=0.18 +BUILD=1sml +HOMEPAGE='https://jbig2dec.com/' +DESC="a JBIG2 decoder" +REQUIRES="zlib libpng" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --enable-shared + + make + make install DESTDIR=$PKG + + cp COPYING LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +57779cc64dcdf25b2cb364f760d7e7c1eb8fa58450bc201faf4eeb03461fa7a13fb3181a7d6a1f42436d3c5e85046a5bd6eab4e6d33c420e1132a0b99e2655bf jbig2dec-0.18.tar.lz +" diff --git a/base/json-c/.deps/arraylist.Plo b/base/json-c/.deps/arraylist.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/arraylist.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/debug.Plo b/base/json-c/.deps/debug.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/debug.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/json_c_version.Plo b/base/json-c/.deps/json_c_version.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/json_c_version.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/json_object.Plo b/base/json-c/.deps/json_object.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/json_object.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/json_object_iterator.Plo b/base/json-c/.deps/json_object_iterator.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/json_object_iterator.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/json_tokener.Plo b/base/json-c/.deps/json_tokener.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/json_tokener.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/json_util.Plo b/base/json-c/.deps/json_util.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/json_util.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/linkhash.Plo b/base/json-c/.deps/linkhash.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/linkhash.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/printbuf.Plo b/base/json-c/.deps/printbuf.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/printbuf.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.deps/random_seed.Plo b/base/json-c/.deps/random_seed.Plo new file mode 100644 index 0000000..9ce06a8 --- /dev/null +++ b/base/json-c/.deps/random_seed.Plo @@ -0,0 +1 @@ +# dummy diff --git a/base/json-c/.travis.yml b/base/json-c/.travis.yml new file mode 100644 index 0000000..70e20eb --- /dev/null +++ b/base/json-c/.travis.yml @@ -0,0 +1,25 @@ +language: cpp + +compiler: + - gcc + - clang + +os: + - linux + - osx + +before_install: + - echo $LANG + - echo $LC_ALL + +install: + - sh autogen.sh + +before_script: + - ./configure + +script: + - make + +after_success: + - make check diff --git a/base/json-c/json-c.SMBuild b/base/json-c/json-c.SMBuild new file mode 100755 index 0000000..9790c34 --- /dev/null +++ b/base/json-c/json-c.SMBuild @@ -0,0 +1,33 @@ +APP=json-c +VERSION=0.13.1 +BUILD=1sml +HOMEPAGE='https://github.com/json-c/json-c' +DOWNLOAD='https://github.com/json-c/json-c/archive/refs/tags/json-c-0.13.1-20180305.tar.gz' +DESC="JSON library in C" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +db81b5a5a1e55135d3d3250a59846160a1c0482b5765dff8f2b7cc627103dab7e200eb7aa9033493a910a4dad19a4570098284584c645ede0009521178c111cd json-c-0.13.1.tar.lz +" diff --git a/base/json-glib/json-glib.SMBuild b/base/json-glib/json-glib.SMBuild new file mode 100755 index 0000000..b8b2150 --- /dev/null +++ b/base/json-glib/json-glib.SMBuild @@ -0,0 +1,30 @@ +APP=json-glib +VERSION=1.4.4 +BUILD=1sml +HOMEPAGE='https://wiki.gnome.org/Projects/JsonGlib' +DESC="library for serialization and deserialization of JSON data" +REQUIRES="gcc-libs libffi pcre glib util-linux" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir smbuild && cd smbuild + meson .. --prefix="/" \ + -Dnls=disabled + + ninja + DESTDIR="$PKG" ninja install + + cp ../COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +11b67d5628ee7fbfecdf86623bb3249f9118284c6c41e315bf2054f317966e0f90bd307b40ee92b7c4ad2b46ec3c07678e343650aff34db6ff40bfb398da2965 json-glib-1.4.4.tar.lz +" diff --git a/base/kbd/config.h b/base/kbd/config.h new file mode 100644 index 0000000..a4cbbd9 --- /dev/null +++ b/base/kbd/config.h @@ -0,0 +1,5 @@ +#include +#define DATADIR "." +#define PACKAGE_VERSION "" +#define PACKAGE_STRING "" +static const char *progname = "loadkeyz"; diff --git a/base/kbd/kbd.SMBuild b/base/kbd/kbd.SMBuild new file mode 100755 index 0000000..bacda9c --- /dev/null +++ b/base/kbd/kbd.SMBuild @@ -0,0 +1,50 @@ +APP=kbd +VERSION=2.0.4 +BUILD=1sml +HOMEPAGE='http://ftp.iij.ad.jp/pub/linux/kernel/linux/utils/kbd/' +DESC="utility to change console fonts and keyborad mappings" +REQUIRES="busybox" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + cp $SRCDIR/config.h src/ + cp $SRCDIR/config.h src/libkeymap/ + sed -i 's/progname/prgname/g' src/loadkeys.c + + gcc -Isrc -Isrc/libkeymap src/libkeymap/common.c \ + src/libkeymap/findfile.c src/libkeymap/array.c \ + src/libkeymap/parser.c src/libkeymap/analyze.c \ + src/libkeymap/func.c src/libkeymap/kmap.c \ + src/libkeymap/diacr.c src/libkeymap/ksyms.c \ + src/libkeymap/dump.c src/libkeymap/loadkeys.c \ + src/libkeymap/modifiers.c \ + src/kbd_error.c src/getfd.c \ + src/loadkeys.c -o loadkeys + + # generate busybox loadkmap compatible keymaps from the gnu ones + # taken from http://hg.slitaz.org/wok/file/3f989c266063/kbd-busybox/receipt + + mkdir -p "$PKG"/share/kmap + for i in $(cat $SRCDIR/keymaps) ; do + k=$(basename $i) + k=${k%.map} # strips off .map from $k + ./loadkeys -b -q data/keymaps/i386/$i > "$PKG"/share/kmap/$k.kmap || echo "Error loadkeys...$i" + done + + install -Dm 755 $SRCDIR/loadkeys $PKG/bin/loadkeys + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +5e264b3695b0af0bc85e0a4fa2c43e13648d8ea82102f3b051c28da2abfc52977577c470bce48f30cec9b0d215297e48c9b05e00561c990e3770fb68f6544e0f kbd-2.0.4.tar.xz +ef992b2e7b7ac30b19ed22a6e263d09a6711f7aba2e473a70586c7aa48df8eac9846cef1a490c49de330123e7070e77ffb8b469d4a78b930ca0f72b134b204d1 config.h +" diff --git a/base/kbd/keymaps b/base/kbd/keymaps new file mode 100644 index 0000000..22789cf --- /dev/null +++ b/base/kbd/keymaps @@ -0,0 +1,34 @@ +azerty/be-latin1.map +azerty/fr-latin1.map +colemak/en-latin9.map +dvorak/dvorak.map +dvorak/dvorak-r.map +dvorak/dvorak-l.map +qwerty/br-abnt2.map +qwerty/cf.map +qwerty/cz-lat2.map +qwerty/dk-latin1.map +qwerty/es.map +qwerty/fi.map +qwerty/it.map +qwerty/is-latin1.map +qwerty/jp106.map +qwerty/nl2.map +qwerty/no-latin1.map +qwerty/pl2.map +qwerty/pt-latin1.map +qwerty/ru1.map +qwerty/se-lat6.map +qwerty/tr_q-latin5.map +qwerty/trq.map +qwerty/uk.map +qwerty/us-acentos.map +qwerty/us.map +qwertz/croat.map +qwertz/de_CH-latin1.map +qwertz/de-latin1.map +qwertz/de-latin1-nodeadkeys.map +qwertz/fr_CH-latin1.map +qwertz/hu.map +qwertz/sg-latin1.map +qwertz/slovene.map diff --git a/base/kbd/loadkeys b/base/kbd/loadkeys new file mode 100644 index 0000000..a377885 --- /dev/null +++ b/base/kbd/loadkeys @@ -0,0 +1,5 @@ +#!/bin/sh +echo 'use loadkmap < /share/kmap/layout.kmap to change keyboard layout' +echo "available keyboard layouts are:" +find /share/kmap -name '*kmap' | sort +exit 1 diff --git a/base/kernel-headers/kernel-headers.SMBuild b/base/kernel-headers/kernel-headers.SMBuild new file mode 100755 index 0000000..288be14 --- /dev/null +++ b/base/kernel-headers/kernel-headers.SMBuild @@ -0,0 +1,28 @@ +APP=kernel-headers +VERSION=4.19.88 +BUILD=1sml +HOMEPAGE='http://ftp.barfooze.de/pub/sabotage/tarballs/' +DOWNLOAD='http://ftp.barfooze.de/pub/sabotage/tarballs/linux-headers-4.19.88.tar.xz' +DESC="Musl-compatible header files for the Linux kernel" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf linux-headers-$VERSION + + tar xf $SRCDIR/linux-headers-$VERSION.tar.?z* + cd linux-headers-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/ptrace.h.patch + + make ARCH="$ARCH" prefix="/" DESTDIR=$PKG install + cp -r generic/include $PKG/ + + mkfinalpkg +} + +SHA512SUMS=" +5a975ba49b577869f2338aa80f44efd4e94f76e5b4bda11a6a1761a6d646848fdeaad7c820339b2c1c20d55f9bbf0e686121d621ac1cfa1dfc6cd71a166ade3a linux-headers-4.19.88.tar.xz +185d627c8704cfdf423e7bcd16d54046d857457fd24ad087d6ad8cd768e5dcb9b8e19e688348afec233d54c5e85106e1d7246cd7cd0413865feb488d2ca64d7b ptrace.h.patch +" diff --git a/base/kernel-headers/ptrace.h.patch b/base/kernel-headers/ptrace.h.patch new file mode 100644 index 0000000..a634391 --- /dev/null +++ b/base/kernel-headers/ptrace.h.patch @@ -0,0 +1,11 @@ +Taken from void linux to fix breakage when compiling strace and gdb +--- a/aarch64/include/asm/ptrace.h 2020-08-03 22:40:11.132486764 +0530 ++++ b/aarch64/include/asm/ptrace.h 2020-08-03 22:40:20.844525756 +0530 +@@ -23,7 +23,6 @@ + #include + + #include +-#include + + + /* diff --git a/base/kernel-source/README b/base/kernel-source/README new file mode 100644 index 0000000..a93520b --- /dev/null +++ b/base/kernel-source/README @@ -0,0 +1,24 @@ +!!!! THIS SOURCE IS NOT FOR THE RASPBERRY PI KERNEL !!!! + +The kernel configuration file .config was taken from slackware-current +meant for use in 'huge' kernel 5.4.41 as slackware devs term it. + +I've disabled the ORC unwinder and am instead using frame pointer in the below +location using and the kernel builds fine. + +Kernel hacking -> Choose kernel unwinder + +The kernel build generates errors like these if ORC unwinder is chosen and +ultimately fails: + +... +arch/x86/kernel/e820.o: warning: objtool: elf_update: cannot write data to file +kernel/sched/rt.o: warning: objtool: elf_update: cannot write data to file +kernel/trace/trace_seq.o: warning: objtool: elf_update: cannot write data to file +kernel/kallsyms.o: warning: objtool: elf_update: cannot write data to file + +... +ar: warning: arch/x86/kernel/irq_64.o has a corrupt section with a size () larger than the file size +ar: warning: arch/x86/kernel/dumpstack_64.o has a corrupt section with a size () larger than the file size +ar: warning: arch/x86/kernel/time.o has a corrupt section with a size () larger than the file size +ar: built-in.o: invalid operation diff --git a/base/kernel-source/kernel-source.SMBuild b/base/kernel-source/kernel-source.SMBuild new file mode 100755 index 0000000..40075aa --- /dev/null +++ b/base/kernel-source/kernel-source.SMBuild @@ -0,0 +1,31 @@ +APP=kernel-source +VERSION=5.4.41 +BUILD=1sml +REQUIRES="musl" +HOMEPAGE='https://www.kernel.org' +DESC="source code for the Linux kernel" +AARCHVERSION=5.4.51 + +build() { + mkandenterbuilddir + rm -rf linux-$VERSION + + tar xf $SRCDIR/linux-$VERSION.tar.?z* + fixbuilddirpermissions + + if [ "$HOSTTYPE" = "x86_64" ] ; then + zcat $SRCDIR/kernelconfig-huge-$VERSION.gz > linux-$VERSION/.config + install -Dm 644 $SRCDIR/README $PKG/doc/$APP-$VERSION/README + elif [ "$HOSTTYPE" = "aarch64" ] ; then + zcat $SRCDIR/kernelconfig-$AARCHVERSION.gz > linux-$VERSION/.config + fi + + mkdir -p $PKG/share + cp -a linux-$VERSION $PKG/share/ + + mkfinalpkg +} + +SHA512SUMS=" +711db80661f2e94fd4819991bd69ff7c3124832ffd6c17025bb82daf2177b82d6700454f7cc58f76c9f839fddf1316f49406af3c2572723b3455b2aac689f7a4 linux-5.4.41.tar.xz +" diff --git a/base/keyutils/keyutils.SMBuild b/base/keyutils/keyutils.SMBuild new file mode 100755 index 0000000..29c8a23 --- /dev/null +++ b/base/keyutils/keyutils.SMBuild @@ -0,0 +1,43 @@ +APP=keyutils +VERSION=1.6.3 +BUILD=1sml +HOMEPAGE='http://people.redhat.com/~dhowells/keyutils/' +DESC="Kernel key management utilities" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make -j1 NO_ARLIB=1 \ + LIBDIR=/lib \ + USRLIBDIR=/lib \ + SBINDIR=/bin \ + MANDIR=/share/man \ + SHAREDIR=/share \ + INCLUDEDIR=/include \ + VERSION="$VERSION" \ + RELEASE="-r0" \ + CFLAGS="$CFLAGS" + + make -j1 NO_ARLIB=1 \ + LIBDIR=/lib \ + USRLIBDIR=/lib \ + SBINDIR=/bin \ + MANDIR=/share/man \ + SHAREDIR=/share \ + INCLUDEDIR=/include \ + install DESTDIR=$PKG + + cp LICENCE* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8923df8535000a47a8b85f3152bf0e3e4c0ad7f5a67804b22e15838c9ac52610d83113261e034f873b6d532cea8d710e8faace833fb9c5b5bb0a1b603126b4dc keyutils-1.6.3.tar.lz +" diff --git a/base/kmod/kmod.SMBuild b/base/kmod/kmod.SMBuild new file mode 100755 index 0000000..30de505 --- /dev/null +++ b/base/kmod/kmod.SMBuild @@ -0,0 +1,41 @@ +APP=kmod +VERSION=19 +BUILD=1sml +HOMEPAGE='ftp://ftp.kernel.org/pub/linux/utils/kernel/kmod/' +DOWNLOAD='https://mirrors.edge.kernel.org/pub/linux/utils/kernel/kmod/kmod-19.tar.xz' +DESC="kernel module tools and library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/strndupa.patch + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --libdir=/lib \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + cd $PKG/bin + for file in depmod insmod lsmod modinfo modprobe rmmod ; do + ln -sf kmod $file + done + + mkfinalpkg +} + +SHA512SUMS=" +07788ae81dccc4f1746200200594cff52a1d7d97c538a2d30371e893ea76d134d5b4d5dec8e0cc58f445ca1b2c4806fd4987630e77e6686d29f5492243563624 kmod-19.tar.lz +da573c1ac7979b7207cde6999b74e68c1e40fbed2400350ec83152acc547b9278c9b265b9c571b8e07700013c5131cf36ebfd9881acdab7259a1f1bb41cb9cf7 strndupa.patch +" diff --git a/base/kmod/strndupa.patch b/base/kmod/strndupa.patch new file mode 100644 index 0000000..fb5895f --- /dev/null +++ b/base/kmod/strndupa.patch @@ -0,0 +1,13 @@ +--- a/shared/util.c 2021-01-05 14:22:23.908595633 +0530 ++++ b/shared/util.c 2021-01-05 14:26:31.721134828 +0530 +@@ -404,7 +404,9 @@ + { + char *start, *end; + +- start = strndupa(path, len); ++ start = alloca(len+1); ++ strncpy(start, path, len); ++ start[len] = '\0'; + end = start + len; + + /* diff --git a/base/lame/lame.SMBuild b/base/lame/lame.SMBuild new file mode 100755 index 0000000..3cf3f42 --- /dev/null +++ b/base/lame/lame.SMBuild @@ -0,0 +1,34 @@ +APP=lame +VERSION=3.100 +BUILD=1sml +HOMEPAGE='https://lame.sourceforge.io/' +DOWNLOAD='https://sourceforge.net/projects/lame/files/lame/3.100/lame-3.100.tar.gz' +DESC="MP3 compression and creation library" +REQUIRES="netbsd-curses nasm" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + LIBS="-lcurses -lterminfo" \ + ./configure \ + --prefix="" \ + --enable-shared \ + --enable-nasm \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ebb3357d5366da40a4dc076ddc3ce9fa355be7f6ea7d505536d20a6049a4fc798c7952666fd2b79b2989486acd48c91e553eddb29fa21ab5542e16e1b01c2287 lame-3.100.tar.lz +" diff --git a/base/less/less-implicit.patch b/base/less/less-implicit.patch new file mode 100644 index 0000000..ab503e7 --- /dev/null +++ b/base/less/less-implicit.patch @@ -0,0 +1,20 @@ +--- less-444.org/configure ++++ less-444/configure +@@ -4221,7 +4221,7 @@ + LIBS="$LIBS $TERMLIBS" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ +- ++#include + int + main () + { +@@ -4252,7 +4252,7 @@ + LIBS="$LIBS $TERMLIBS" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ +- ++#include + int + main () + { diff --git a/base/less/less.SMBuild b/base/less/less.SMBuild new file mode 100755 index 0000000..817a0be --- /dev/null +++ b/base/less/less.SMBuild @@ -0,0 +1,36 @@ +APP=less +VERSION=471 +BUILD=1sml +HOMEPAGE='https://www.greenwoodsoftware.com/less/' +DOWNLOAD='https://www.greenwoodsoftware.com/less/less-471.tar.gz' +DESC="file pager similar to more" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/less.patch + patch -p1 < $SRCDIR/less-implicit.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make CFLAGS="-static" + make install DESTDIR=$PKG + + cp COPYING LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +16822a461cf8dd4f0ebecf48da555c0c583640e5e7c16dc1361c7397dc32ece37ea40a4e31dd7b9264054ec65fb7ea04f34b6fe5d4c3a14ad726bfdef1f8d582 less-471.tar.lz +b4b79a40d85a604a35071d17b00deb0cea787b267fc00a658b3558388f31feafd7c12191bb1e59f1e505be5380abe9fdeb9b3e8fc4317192ca2312164fbcb5cf less-implicit.patch +88c69cefe9af0c355cc8f06c83c4ef069b22ad7a11b38278c7a066f67d21081becb0df129536ddbadc3f4afe43aa9c230cf9ef528b69045b8abb5db9ab5dccd8 less.patch +" diff --git a/base/less/less.patch b/base/less/less.patch new file mode 100644 index 0000000..a3ecb96 --- /dev/null +++ b/base/less/less.patch @@ -0,0 +1,34 @@ +--- less-444/configure ++++ less-444.patched/configure +@@ -4072,6 +4072,7 @@ + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ + ++#include + int + main () + { +@@ -4101,6 +4102,7 @@ + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ + ++#include + int + main () + { +@@ -4130,6 +4132,7 @@ + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ + ++#include + int + main () + { +@@ -4159,6 +4162,7 @@ + cat confdefs.h - <<_ACEOF >conftest.$ac_ext + /* end confdefs.h. */ + ++#include + int + main () + { diff --git a/base/libaio/libaio.SMBuild b/base/libaio/libaio.SMBuild new file mode 100755 index 0000000..ca7f627 --- /dev/null +++ b/base/libaio/libaio.SMBuild @@ -0,0 +1,29 @@ +APP=libaio +VERSION=0.3.112 +BUILD=1sml +HOMEPAGE='https://pagure.io/libaio' +DOWNLOAD='https://releases.pagure.org/libaio/libaio-0.3.112.tar.gz' +DESC="Asynchronous I/O library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + make prefix="$PKG" libdir=$PKG/lib install + + rm -f $PKG/lib/libaio.a + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +024de41dabeeaa8e990710a188081ce0ea24e73140411fd6274be61bcaacab977c0a57a137ba46152468390a01c76df6d7576d6966d0c7626064b868f23d474c libaio-0.3.112.tar.lz +" diff --git a/base/libao/libao.SMBuild b/base/libao/libao.SMBuild new file mode 100755 index 0000000..ef8e29b --- /dev/null +++ b/base/libao/libao.SMBuild @@ -0,0 +1,34 @@ +APP=libao +VERSION=1.2.0 +BUILD=1sml +HOMEPAGE='https://xiph.org/ao/' +DOWNLOAD='https://downloads.xiph.org/releases/ao/libao-1.2.0.tar.gz' +DESC="Audio Output library" +REQUIRES="musl gcc-libs alsa-lib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-shared \ + --disable-static \ + --disable-pulse + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +107dde222e07f5f2aa7593e1dec2f72b01e71b9aed9f6759668a5a1ac6119de92e7317f32edbbc0f62fcb98f3fe35203217a0fb43e9fb2185a3a6319dec4b154 libao-1.2.0.tar.lz +" diff --git a/base/libarchive/libarchive.SMBuild b/base/libarchive/libarchive.SMBuild new file mode 100755 index 0000000..34de883 --- /dev/null +++ b/base/libarchive/libarchive.SMBuild @@ -0,0 +1,38 @@ +APP=libarchive +VERSION=3.4.2 +BUILD=1sml +HOMEPAGE='http://libarchive.org' +DOWNLOAD='https://www.libarchive.org/downloads/libarchive-3.4.2.tar.gz' +DESC="archive reading library" +REQUIRES="bzip2 expat zlib xz" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="$CFLAGS -D_BSD_SOURCE" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --with-pic \ + --without-openssl \ + --without-xml2 \ + --disable-acl \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +16a01dfac7f40ba47ad54a3c32b864d528be89fc34040f859ac4fe77a5050ace81e0795edeadd82ed2956abd4c9c8d3ede71ecfff19e69f6254fc48fb96b8cfb libarchive-3.4.2.tar.lz +" diff --git a/base/libasr/libasr.SMBuild b/base/libasr/libasr.SMBuild new file mode 100755 index 0000000..815e1c6 --- /dev/null +++ b/base/libasr/libasr.SMBuild @@ -0,0 +1,32 @@ +APP=libasr +VERSION=1.0.4 +BUILD=1sml +HOMEPAGE='https://github.com/OpenSMTPD/libasr' +DOWNLOAD='https://github.com/OpenSMTPD/libasr/archive/refs/tags/1.0.4.tar.gz' +DESC="ASyncronous Resolver library" +REQUIRES="musl openssl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +77e519a71762a9e02cff9fe29b9da68e5a3e84a45d930c1a45b24c0d2e4e827c078ce728d82c7124cee86c1af80f1a4b42c3da0f5e0f510aad4169f91bc6509b libasr-1.0.4.tar.lz +" diff --git a/base/libassuan/libassuan.SMBuild b/base/libassuan/libassuan.SMBuild new file mode 100755 index 0000000..fc05b3d --- /dev/null +++ b/base/libassuan/libassuan.SMBuild @@ -0,0 +1,32 @@ +APP=libassuan +VERSION=2.5.3 +BUILD=1sml +HOMEPAGE='https://gnupg.org/software/libassuan/index.html' +DOWNLOAD='https://gnupg.org/ftp/gcrypt/libassuan/libassuan-2.5.3.tar.bz2' +DESC="Interprocess Communication Library for GPG" +REQUIRES="libgpg-error" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +947c354e1b3a2014af28f0fb02ebadd5ec304f3764cdcc0d4b5904aee5628b3c34024ab2871daa765a936236df91232839dea911ac70a23533c25f1dd010abef libassuan-2.5.3.tar.lz +" diff --git a/base/libcap-ng/libcap-ng.SMBuild b/base/libcap-ng/libcap-ng.SMBuild new file mode 100755 index 0000000..895ca2e --- /dev/null +++ b/base/libcap-ng/libcap-ng.SMBuild @@ -0,0 +1,33 @@ +APP=libcap-ng +VERSION=0.7.10 +BUILD=1sml +HOMEPAGE='https://people.redhat.com/sgrubb/libcap-ng/' +DOWNLOAD='https://people.redhat.com/sgrubb/libcap-ng/libcap-ng-0.7.10.tar.gz' +DESC="capabilities library and utilities" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-static=no \ + --with-python=no \ + --with-python3=no + + make + make install DESTDIR=$PKG + + cp COPYING* LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +87ae6cc41ce67a0258b1ada7b4984e87039e2a6817b265cf6c9f07c0047e27ed555165bd4390f5e49e2a0c73f76772ab111d2cb071e07d85a049aeaf3a6af5c8 libcap-ng-0.7.10.tar.lz +" diff --git a/base/libcap/libcap.SMBuild b/base/libcap/libcap.SMBuild new file mode 100755 index 0000000..bcd3fef --- /dev/null +++ b/base/libcap/libcap.SMBuild @@ -0,0 +1,42 @@ +APP=libcap +VERSION=2.26 +BUILD=1sml +HOMEPAGE='https://www.kernel.org/pub/linux/libs/security/linux-privs/libcap2/' +DOWNLOAD="https://www.kernel.org/pub/linux/libs/security/linux-privs/libcap2/libcap-2.26.tar.xz" +DESC="library to get/set POSIX capabilities" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i 's,BUILD_GPERF := ,BUILD_GPERF := no #,' Make.Rules + + cp $SRCDIR/libcap2-cap_names.h libcap/cap_names.h + touch libcap/cap_names.list.h libcap/_makenames libcap/cap_names.h + + make prefix="" man_prefix=/share/man lib=lib CFLAGS="$CFLAGS" \ + BUILD_CC="$CC" + + make RAISE_SETFCAP=no FAKEROOT=$PKG prefix="" man_prefix=/share/man \ + SBINDIR=/bin lib=lib install + + LIBDIR=$PKG/lib + SBINDIR=$PKG/bin + + LD_LIBRARY_PATH=${LIBDIR} ${SBINDIR}/setcap cap_setfacap=i ${SBINDIR}/setcap || echo "oops" + + cp License $PKGDOCS/ + removestaticlibs + + mkfinalpkg +} + +SHA512SUMS=" +e40340d6a10bb9e935c9112e6ec3274d2b7ce79e3da23bf49fa575b381a21678597a2a1a2dee5732590700634fca5fa18c68ea98e8558dfdd12397247b72c395 libcap-2.26.tar.lz +75e8856399e8007424c1130eecebc4db05abda0ece9fa7533ad674e8f67e34122036238cc950f93b7711877a9b5abab0c46c71253e0a06d8cd7558e149e1baf9 libcap2-cap_names.h +" diff --git a/base/libcap/libcap2-cap_names.h b/base/libcap/libcap2-cap_names.h new file mode 100644 index 0000000..b97c336 --- /dev/null +++ b/base/libcap/libcap2-cap_names.h @@ -0,0 +1,51 @@ +/* + * DO NOT EDIT: this file is generated automatically from + * + * + */ +#define __CAP_BITS 38 + +#ifdef LIBCAP_PLEASE_INCLUDE_ARRAY + char const *_cap_names[__CAP_BITS] = { + /* 0 */ "cap_chown", + /* 1 */ "cap_dac_override", + /* 2 */ "cap_dac_read_search", + /* 3 */ "cap_fowner", + /* 4 */ "cap_fsetid", + /* 5 */ "cap_kill", + /* 6 */ "cap_setgid", + /* 7 */ "cap_setuid", + /* 8 */ "cap_setpcap", + /* 9 */ "cap_linux_immutable", + /* 10 */ "cap_net_bind_service", + /* 11 */ "cap_net_broadcast", + /* 12 */ "cap_net_admin", + /* 13 */ "cap_net_raw", + /* 14 */ "cap_ipc_lock", + /* 15 */ "cap_ipc_owner", + /* 16 */ "cap_sys_module", + /* 17 */ "cap_sys_rawio", + /* 18 */ "cap_sys_chroot", + /* 19 */ "cap_sys_ptrace", + /* 20 */ "cap_sys_pacct", + /* 21 */ "cap_sys_admin", + /* 22 */ "cap_sys_boot", + /* 23 */ "cap_sys_nice", + /* 24 */ "cap_sys_resource", + /* 25 */ "cap_sys_time", + /* 26 */ "cap_sys_tty_config", + /* 27 */ "cap_mknod", + /* 28 */ "cap_lease", + /* 29 */ "cap_audit_write", + /* 30 */ "cap_audit_control", + /* 31 */ "cap_setfcap", + /* 32 */ "cap_mac_override", + /* 33 */ "cap_mac_admin", + /* 34 */ "cap_syslog", + /* 35 */ "cap_wake_alarm", + /* 36 */ "cap_block_suspend", + /* 37 */ "cap_audit_read", + }; +#endif /* LIBCAP_PLEASE_INCLUDE_ARRAY */ + +/* END OF FILE */ diff --git a/base/libcddb/libcddb.SMBuild b/base/libcddb/libcddb.SMBuild new file mode 100755 index 0000000..b433ea7 --- /dev/null +++ b/base/libcddb/libcddb.SMBuild @@ -0,0 +1,33 @@ +APP=libcddb +VERSION=1.3.2 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/libcddb/' +DOWNLOAD="https://sourceforge.net/projects/libcddb/files/libcddb/1.3.2/libcddb-1.3.2.tar.bz2" +DESC="library to access CDDB data from different protocols such as CDDBP, HTTP, SMTP" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f1b512f953fa494cea09eddff451efd9291b49bd268df699d5dd609f113d153ddcf08fdd7d261287829b0dc2b527cb91838c7b603fd2f3a3a453d96850b289e7 libcddb-1.3.2.tar.lz +" diff --git a/base/libcdio-paranoia/libcdio-paranoia.SMBuild b/base/libcdio-paranoia/libcdio-paranoia.SMBuild new file mode 100755 index 0000000..58adfbc --- /dev/null +++ b/base/libcdio-paranoia/libcdio-paranoia.SMBuild @@ -0,0 +1,34 @@ +APP=libcdio-paranoia +VERSION=10.2 +LVERSION="+2.0.1" +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/libcdio/' +DESC="supporting library to libcdio for CD-ROM access" +REQUIRES="libcdio" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION$LVERSION + + tar xf $SRCDIR/$APP-$VERSION$LVERSION.tar.?z* + cd $APP-$VERSION$LVERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-cpp-progs \ + --disable-static \ + --disable-example-progs + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e2ab71d2112c481b3edd7adacc3e35c38b857b04bb0b36776f9c9b54d4aaccf9cacb07307ec3644c7ab70a88e3fc101a846b549b3d8a5ac52561348bfa6aded7 libcdio-paranoia-10.2+2.0.1.tar.lz +" diff --git a/base/libcdio/libcdio.SMBuild b/base/libcdio/libcdio.SMBuild new file mode 100755 index 0000000..6889954 --- /dev/null +++ b/base/libcdio/libcdio.SMBuild @@ -0,0 +1,34 @@ +APP=libcdio +VERSION=2.1.0 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/libcdio/' +DOWNLOAD='http://git.savannah.gnu.org/cgit/libcdio.git/snapshot/libcdio-release-2.1.0.tar.gz' +DESC="CD-ROM library to access data from various CD-ROM image formats" +REQUIRES="gcc-libs netbsd-curses libcddb" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-vcd-info \ + --disable-static \ + --enable-cpp-progs + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +eb939751e6f2066dd83ee353f247aeb73bb04328de1e322e73534b764f541213f8bb20c2d66da6d244ed4cd4240955881e4d86f19e8576cbe875f0a8d537a788 libcdio-2.1.0.tar.lz +" diff --git a/base/libcroco/libcroco.SMBuild b/base/libcroco/libcroco.SMBuild new file mode 100755 index 0000000..f424e89 --- /dev/null +++ b/base/libcroco/libcroco.SMBuild @@ -0,0 +1,31 @@ +APP=libcroco +VERSION=0.6.13 +BUILD=1sml +HOMEPAGE='https://gitlab.gnome.org/GNOME/libcroco' +DESC="CSS2 parsing and manipulation library" +REQUIRES="zlib pcre glib libxml2 xz" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a339be95dde686c8edfd474d9fb84865d31719e7d3a4e758177bba1c83eac5e3a53ee07f6e01c98084467e29e316bcc1749b6ee37dbe0739cf7972b72951a63e libcroco-0.6.13.tar.lz +" diff --git a/base/libcue/libcue.SMBuild b/base/libcue/libcue.SMBuild new file mode 100755 index 0000000..7a9b175 --- /dev/null +++ b/base/libcue/libcue.SMBuild @@ -0,0 +1,34 @@ +APP=libcue +VERSION=2.2.1 +BUILD=1sml +HOMEPAGE='https://github.com/lipnitsk/libcue/' +DOWNLOAD='https://github.com/lipnitsk/libcue/archive/refs/tags/v2.2.1.tar.gz' +DESC="library to parse and extract data from CUE sheets" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + + cmake .. \ + -DCMAKE_INSTALL_PREFIX="" \ + -DCMAKE_INSTALL_LIBDIR=lib \ + -DBUILD_SHARED_LIBS=ON + + make + make install DESTDIR=$PKG + + cp ../LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +36a86bbff7a944666949d1f468799c8607bfa2e4f5227684dfc8928072793089db30f99163a8596af01f1909baccdc1b1f134d9cb29cb6d39b3061bacfb82f8d libcue-2.2.1.tar.lz +" diff --git a/base/libdaemon/libdaemon-0001-testd-use-unistd-h-instead-of-sys-unistd-h.patch b/base/libdaemon/libdaemon-0001-testd-use-unistd-h-instead-of-sys-unistd-h.patch new file mode 100644 index 0000000..c2ebc78 --- /dev/null +++ b/base/libdaemon/libdaemon-0001-testd-use-unistd-h-instead-of-sys-unistd-h.patch @@ -0,0 +1,16 @@ +examples/testd.c: As the C POSIX library recommends include the +instead of . This removes an error when building libdaemon +against the musl C library. + +Signed-off-by: Jörg Krause +--- a/examples/testd.c 2014-08-30 00:27:08.359832977 +0200 ++++ b/examples/testd.c 2014-08-30 00:27:25.439832670 +0200 +@@ -23,7 +23,7 @@ + #include + #include + #include +-#include ++#include + #include + + #include diff --git a/base/libdaemon/libdaemon.SMBuild b/base/libdaemon/libdaemon.SMBuild new file mode 100755 index 0000000..1d775ac --- /dev/null +++ b/base/libdaemon/libdaemon.SMBuild @@ -0,0 +1,35 @@ +APP=libdaemon +VERSION=0.14 +BUILD=1sml +HOMEPAGE='http://0pointer.de/lennart/projects/libdaemon/' +DOWNLOAD='http://0pointer.de/lennart/projects/libdaemon/libdaemon-0.14.tar.gz' +DESC="Lightweight library for writing Unix daemons" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/libdaemon-0001-testd-use-unistd-h-instead-of-sys-unistd-h.patch + + ./configure \ + --prefix="" \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f2a756af88b9d4a83855e1eecf2127d180b7412a49039dbc76d430b2297a14fea3d012e799f36e12193953d05e6e8be2210353b0e7ad53c984bb668d65097ef3 libdaemon-0.14.tar.lz +8927b2a97bd862e101ff2a3663ef0b07633d03e9bce7148f1908899c4bae1d2b607699b7de3fdd28401635a59494708162a203307539a43ced537d149fe9caac libdaemon-0001-testd-use-unistd-h-instead-of-sys-unistd-h.patch +" \ No newline at end of file diff --git a/base/libelf-compat/libelf-compat.SMBuild b/base/libelf-compat/libelf-compat.SMBuild new file mode 100755 index 0000000..1f67271 --- /dev/null +++ b/base/libelf-compat/libelf-compat.SMBuild @@ -0,0 +1,29 @@ +APP=libelf-compat +VERSION=0.152c001 +BUILD=1sml +HOMEPAGE='https://sourceware.org/elfutils/' +DESC="library for manipulating ELF headers" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + echo "CFLAGS += -fPIC" > config.mak + sed -i 's@HEADERS = src/libelf.h@HEADERS = src/libelf.h src/gelf.h@' Makefile + + make + make prefix="" install DESTDIR="$PKG" + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8e87c4ae5e073dcf88e8b7fbdfc4512de67a49e3288c576b705ac7af3a2023ba994756180c4b817a45f5bffc8915b22f19908fdd48a1412aae62bf1888e74b66 libelf-compat-0.152c001.tar.lz +" diff --git a/base/libetpan/libetpan.SMBuild b/base/libetpan/libetpan.SMBuild new file mode 100755 index 0000000..ddb9acc --- /dev/null +++ b/base/libetpan/libetpan.SMBuild @@ -0,0 +1,32 @@ +APP=libetpan +VERSION=1.9.4 +BUILD=1sml +HOMEPAGE='https://www.etpan.org/' +DOWNLOAD='https://github.com/dinhvh/libetpan/archive/refs/tags/1.9.4.tar.gz' +DESC="middleware library providing various APIs to access mail" +REQUIRES="gcc-libs db expat curl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYRIGHT $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +aa3d91ac305f9a9a80946714008702f9f11507265275702040b6c034122b30cd9c639e378ae135e6617302f6810f617126a0b74f3594308b10beeb182549ebe8 libetpan-1.9.4.tar.lz +" diff --git a/base/libevent/libevent.SMBuild b/base/libevent/libevent.SMBuild new file mode 100755 index 0000000..ef08364 --- /dev/null +++ b/base/libevent/libevent.SMBuild @@ -0,0 +1,32 @@ +APP=libevent +VERSION=2.1.11 +BUILD=1sml +HOMEPAGE='http://libevent.org' +DOWNLOAD='https://github.com/libevent/libevent/releases/download/release-2.1.11-stable/libevent-2.1.11-stable.tar.gz' +DESC="event loop library" +REQUIRES="openssl" + +build() { + mkandenterbuilddir + rm -rf "$APP-$VERSION-stable" + + tar xf $SRCDIR/$APP-$VERSION-stable.tar.?z + cd "$APP-$VERSION-stable" + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +06e407677ba296ad98ad45f40a8f43504c8d2088696c86fe50d7769d32c0351cb2358b0cf9bbe78a5e84503d4d32e3d24948236c45e0cc3f6752123fbc96bc9b libevent-2.1.11-stable.tar.lz +" diff --git a/base/libexif/libexif.SMBuild b/base/libexif/libexif.SMBuild new file mode 100755 index 0000000..faf9ca4 --- /dev/null +++ b/base/libexif/libexif.SMBuild @@ -0,0 +1,31 @@ +APP=libexif +VERSION=0.6.22 +BUILD=1sml +HOMEPAGE='https://libexif.github.io/' +DOWNLOAD='https://github.com/libexif/libexif/releases/download/libexif-0_6_22-release/libexif-0.6.22.tar.xz' +DESC="Exchangeable Image File Format library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bb5ad5e68bc32142c61c46ddf72f8b3734b5ec2fcd9c5682eafe44ddf2a84f76c646b2d497ccfe590c61f13f315fc7c44623685c316d9ff77a289e877978318a libexif-0.6.22.tar.lz +" diff --git a/base/libffi/libffi.SMBuild b/base/libffi/libffi.SMBuild new file mode 100755 index 0000000..353aeb2 --- /dev/null +++ b/base/libffi/libffi.SMBuild @@ -0,0 +1,31 @@ +APP=libffi +VERSION=3.3 +BUILD=1sml +HOMEPAGE='http://sourceware.org/libffi/' +DOWNLOAD='ftp://sourceware.org/pub/libffi/libffi-3.3.tar.gz' +DESC="A Portable Foreign Function Interface Library" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICEN?E $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +6d344a19ab2f30070a52762069434d2da590e6c356647aa627f493291004e6690af70ef7408d8b46b5c767edae020c595b4e389da64192f29db31ab930424d1a libffi-3.3.tar.lz +" diff --git a/base/libgc/libgc-configure.patch b/base/libgc/libgc-configure.patch new file mode 100644 index 0000000..59c90f3 --- /dev/null +++ b/base/libgc/libgc-configure.patch @@ -0,0 +1,36 @@ +$NetBSD: patch-ab,v 1.23 2012/08/27 16:41:22 wiz Exp $ + +Unportable test(1) construct. +https://github.com/ivmai/bdwgc/commit/e091c078fad900f7b96881d5706a646d9c530cd8 + +--- configure.orig 2012-05-11 17:09:00.000000000 +0000 ++++ configure +@@ -5245,7 +5245,7 @@ $as_echo "#define DARWIN_DONT_PARSE_STAC + + fi + +-if test "$GCC" == yes; then ++if test "$GCC" = yes; then + # Disable aliasing optimization unless forced to. + { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether gcc supports -fno-strict-aliasing" >&5 + $as_echo_n "checking whether gcc supports -fno-strict-aliasing... " >&6; } +@@ -5453,8 +5453,8 @@ esac + $as_echo "$enable_shared" >&6; } + + # Compile with GC_DLL defined unless building static libraries. +-if test "${enable_shared}" == yes; then +- if test "${enable_static}" == no; then ++if test "${enable_shared}" = yes; then ++ if test "${enable_static}" = no; then + $as_echo "#define GC_DLL 1" >>confdefs.h + + # FIXME: Also pass -fvisibility=hidden option if GCC v4+ and not Win32. +@@ -16438,7 +16441,7 @@ $as_echo "#define SMALL_CONFIG 1" >>conf + + fi + +-if test "$enable_gc_debug" == "no"; then ++if test "$enable_gc_debug" = "no"; then + + $as_echo "#define NO_DEBUGGING 1" >>confdefs.h + diff --git a/base/libgc/libgc-os_dep.patch b/base/libgc/libgc-os_dep.patch new file mode 100644 index 0000000..d093f7d --- /dev/null +++ b/base/libgc/libgc-os_dep.patch @@ -0,0 +1,10 @@ +--- gc-7.2.org/os_dep.c 2013-01-03 17:13:21.878000003 +0000 ++++ gc-7.2/os_dep.c 2013-01-04 07:57:17.766000002 +0000 +@@ -26,6 +26,7 @@ + # define __KERNEL__ + # include + # undef __KERNEL__ ++# elif 1 + # else + /* Kernels prior to 2.1.1 defined struct sigcontext_struct instead of */ + /* struct sigcontext. libc6 (glibc2) uses "struct sigcontext" in */ diff --git a/base/libgc/libgc.SMBuild b/base/libgc/libgc.SMBuild new file mode 100755 index 0000000..337cc52 --- /dev/null +++ b/base/libgc/libgc.SMBuild @@ -0,0 +1,35 @@ +APP=libgc +VERSION=8.0.4 +BUILD=1sml +HOMEPAGE='https://www.hboehm.info/gc/' +DOWNLOAD='https://www.hboehm.info/gc/gc_source/gc-8.0.4.tar.gz' +DESC="Conservative garbage collector for C and C++" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf gc-$VERSION + + tar xf $SRCDIR/gc-$VERSION.tar.?z* + cd gc-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-cplusplus \ + --enable-threads=pthreads \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + mkfinalpkg +} + +SHA512SUMS=" +2a241a485ea689a1cae45aba29b21c8ac80956c8baec7b78a218d5ab59bdaa77f2c71f2f29d05e68e553d3160323da09e064d89045d56e03c0c7e9b5c12cd091 gc-8.0.4.tar.lz +49645d28a06323675890de938182733c08b7cfeb0188a05e363e5bbd8b831e23b86f906510b515a9324ff0973472ca720e895870e6ea2c1dcbb461d5515fc823 libgc-configure.patch +2c0b627582467cfd3f59aa06d995b399262a8c20304263b2e4953de26960675ed8508cd637e8a7c0ab71ba824ebc8f1434a2a9f5aea9faac9c47526598c713d7 libgc-os_dep.patch +" diff --git a/base/libgcrypt/libgcrypt.SMBuild b/base/libgcrypt/libgcrypt.SMBuild new file mode 100755 index 0000000..1d25f58 --- /dev/null +++ b/base/libgcrypt/libgcrypt.SMBuild @@ -0,0 +1,34 @@ +APP=libgcrypt +VERSION=1.8.5 +BUILD=1sml +HOMEPAGE='https://www.gnupg.org/software/libgcrypt/index.html' +DOWNLOAD='https://www.gnupg.org/ftp/gcrypt/libgcrypt/libgcrypt-1.8.5.tar.bz2' +DESC="General purpose crypto library based on GnuPG" +REQUIRES="libgpg-error" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-shared=yes \ + --enable-static=no \ + --program-prefix="" \ + --program-suffix="" + + make + make install DESTDIR=$PKG + + cp COPYING* LICENSES $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8ba8114093ac603857872428a4ba30dc08771614dfa123e01abc47f8fd51a7cf96343483c9a6fda3bd73e4f9e76cdf40b6e152ae803d03cbe15b5fb5ea4418f1 libgcrypt-1.8.5.tar.lz +" diff --git a/base/libgit2/libgit2.SMBuild b/base/libgit2/libgit2.SMBuild new file mode 100755 index 0000000..9ac336c --- /dev/null +++ b/base/libgit2/libgit2.SMBuild @@ -0,0 +1,35 @@ +APP=libgit2 +VERSION=1.0.1 +BUILD=1sml +HOMEPAGE='https://libgit2.github.com/' +DOWNLOAD='https://github.com/libgit2/libgit2/releases/download/v1.0.1/libgit2-1.0.1.tar.gz' +DESC="C library for custom Git applications" +REQUIRES="pcre libssh2" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DCMAKE_BUILD_TYPE=None \ + -DCMAKE_INSTALL_PREFIX="/" \ + -DCMAKE_INSTALL_LIBDIR=lib \ + -DTHREADSAFE=ON \ + -Wno-dev + + make + make install DESTDIR=$PKG + + cp ../{COPYING,README.md,SECURITY.md} $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2499ee5517da96afd56bcecddb412d4d50bbe325c642cffdf7796867a072a886c914d7afb139cc33313604a6a03c1a5a658d16a2848a95008981e0d2b6a65c11 libgit2-1.0.1.tar.lz +" diff --git a/base/libgpg-error/libgpg-error.SMBuild b/base/libgpg-error/libgpg-error.SMBuild new file mode 100755 index 0000000..7075121 --- /dev/null +++ b/base/libgpg-error/libgpg-error.SMBuild @@ -0,0 +1,31 @@ +APP=libgpg-error +VERSION=1.39 +BUILD=1sml +HOMEPAGE='https://www.gnupg.org/software/libgpg-error/index.html' +DOWNLOAD='https://www.gnupg.org/ftp/gcrypt/libgpg-error/libgpg-error-1.39.tar.bz2' +DESC="library that provides common error values and functions for all GnuPG components" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +9e67deaf4307fc1b8e9553be019e4c0dfc9554ba9e3151bb233fdb084f205fd1f934e12b6a4316e20aac21db919a4230fa11cd96ddad27a73073aca428d48404 libgpg-error-1.39.tar.lz +" diff --git a/base/libical/icu-68.patch b/base/libical/icu-68.patch new file mode 100644 index 0000000..1974db7 --- /dev/null +++ b/base/libical/icu-68.patch @@ -0,0 +1,44 @@ +From a90657f5bbc5e2eb45fa419e7f43889aeccd4c39 Mon Sep 17 00:00:00 2001 +From: Lars Wendler +Date: Fri, 30 Oct 2020 11:24:34 +0100 +Subject: [PATCH] Fix build with icu-68.1 + +icu-68.1 removed public macro definitions for TRUE and FALSE + +Signed-off-by: Lars Wendler +--- + src/libical/icalrecur.c | 5 +++-- + 1 file changed, 3 insertions(+), 2 deletions(-) + +diff --git a/src/libical/icalrecur.c b/src/libical/icalrecur.c +index 91522161..159163c5 100644 +--- a/src/libical/icalrecur.c ++++ b/src/libical/icalrecur.c +@@ -143,6 +143,7 @@ + #include + + #if defined(HAVE_LIBICU) ++#include + #include + #include + #else +@@ -1079,7 +1080,7 @@ icalarray *icalrecurrencetype_rscale_supported_calendars(void) + + calendars = icalarray_new(sizeof(const char **), 20); + +- en = ucal_getKeywordValuesForLocale("calendar", NULL, FALSE, &status); ++ en = ucal_getKeywordValuesForLocale("calendar", NULL, false, &status); + while ((cal = uenum_next(en, NULL, &status))) { + cal = icalmemory_tmp_copy(cal); + icalarray_append(calendars, &cal); +@@ -1472,7 +1473,7 @@ static int initialize_rscale(icalrecur_iterator *impl) + } + + /* Check if specified calendar is supported */ +- en = ucal_getKeywordValuesForLocale("calendar", NULL, FALSE, &status); ++ en = ucal_getKeywordValuesForLocale("calendar", NULL, false, &status); + while ((cal = uenum_next(en, NULL, &status))) { + if (!strcmp(cal, rule.rscale)) { + is_hebrew = !strcmp(rule.rscale, "hebrew"); +-- +2.29.2 diff --git a/base/libical/libical.SMBuild b/base/libical/libical.SMBuild new file mode 100755 index 0000000..393595f --- /dev/null +++ b/base/libical/libical.SMBuild @@ -0,0 +1,40 @@ +APP=libical +VERSION=3.0.8 +BUILD=2sml +HOMEPAGE='https://github.com/libical/libical' +DOWNLOAD='https://github.com/libical/libical/archive/refs/tags/v3.0.8.tar.gz' +DESC="iCAL calendaring and scheduling protocol implementation" +REQUIRES="gcc-libs icu" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Thanks gentoo linux + patch -p1 < $SRCDIR/icu-68.patch + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DCMAKE_INSTALL_PREFIX="" \ + -DLIB_SUFFIX=lib \ + -DINCLUDE_INSTALL_DIR=include \ + -DCMAKE_BUILD_TYPE=Release \ + -DENABLE_GTK_DOC=OFF \ + -DSHARED_ONLY=ON + + make + make install DESTDIR=$PKG + + cp ../{LICENSE,ReadMe.txt,ReleaseNotes.txt,THANKS,TODO} $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4c195f96d5c1d0dbd3c2c4c46dda2a4675c65e2cffa6b0ce7ee71d656a32dc75a6bb4d2b111395a1c01dfa7f1a0ccf579221fb63da72af7e4b9ac4b966debc29 libical-3.0.8.tar.lz +98b0b685676e7aa54e49050ec8adab4bb6cd3827fcd3977c156d841a527268cb47b3227852036f4bb195931ae8295fa6761bc96f4d4042f059193ab6f75aa27a icu-68.patch +" diff --git a/base/libid3tag/CVE-2008-2109.patch b/base/libid3tag/CVE-2008-2109.patch new file mode 100644 index 0000000..6226d14 --- /dev/null +++ b/base/libid3tag/CVE-2008-2109.patch @@ -0,0 +1,11 @@ +--- a/field.c.orig 2008-05-05 09:49:15.000000000 -0400 ++++ b/field.c 2008-05-05 09:49:25.000000000 -0400 +@@ -291,7 +291,7 @@ + + end = *ptr + length; + +- while (end - *ptr > 0) { ++ while (end - *ptr > 0 && **ptr != '\0') { + ucs4 = id3_parse_string(ptr, end - *ptr, *encoding, 0); + if (ucs4 == 0) + goto fail; diff --git a/base/libid3tag/libid3tag.SMBuild b/base/libid3tag/libid3tag.SMBuild new file mode 100755 index 0000000..4ab9c03 --- /dev/null +++ b/base/libid3tag/libid3tag.SMBuild @@ -0,0 +1,35 @@ +APP=libid3tag +VERSION=0.15.1b +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/mad/files/libid3tag/' +DESC="library for reading ID3 tags" +REQUIRES="zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/CVE-2008-2109.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPY* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ade7ce2a43c3646b4c9fdc642095174b9d4938b078b205cd40906d525acd17e87ad76064054a961f391edcba6495441450af2f68be69f116549ca666b069e6d3 libid3tag-0.15.1b.tar.gz +fc79d44ca9d1435ab5b11d4da6b46d3684827a1384a0156cd88242225f98f3a0668c0d6e6a88159f0c4985fcbdc636777c2f100d7f371eef258a6050d6fde567 CVE-2008-2109.patch +" diff --git a/base/libidn/libidn.SMBuild b/base/libidn/libidn.SMBuild new file mode 100755 index 0000000..2e11869 --- /dev/null +++ b/base/libidn/libidn.SMBuild @@ -0,0 +1,30 @@ +APP=libidn +VERSION=1.35 +BUILD=1sml +HOMEPAGE="https://www.gnu.org/software/libidn/" +DESC="GNU Internationalized Domain Name library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7c7af33279dc60af2c148da0c746a3af227de887e6e967afe49ba04f8d01c5ff6de792ca6dd0913525a5f4488557bba6eb12f4cf16369165b029d27942e01a31 libidn-1.35.tar.lz +" diff --git a/base/libidn2/libidn2.SMBuild b/base/libidn2/libidn2.SMBuild new file mode 100755 index 0000000..7d44394 --- /dev/null +++ b/base/libidn2/libidn2.SMBuild @@ -0,0 +1,30 @@ +APP=libidn2 +VERSION=2.3.0 +BUILD=1sml +HOMEPAGE='https://gitlab.com/libidn/libidn2' +DESC="GNU Internationalized Domain Name library" +REQUIRES="libunistring" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f525d6fa07e3b77ecb6e9ef70c3480b0ff4a7e2b06610c81cd1c02a3882efab29c8798f238b028445a33a70d0526246fa1161410920b2365e82a204381844446 libidn2-2.3.0.tar.lz +" diff --git a/base/libjpeg-turbo/libjpeg-turbo.SMBuild b/base/libjpeg-turbo/libjpeg-turbo.SMBuild new file mode 100755 index 0000000..85046e6 --- /dev/null +++ b/base/libjpeg-turbo/libjpeg-turbo.SMBuild @@ -0,0 +1,30 @@ +APP=libjpeg-turbo +VERSION=2.0.4 +BUILD=1sml +HOMEPAGE='https://github.com/libjpeg-turbo/libjpeg-turbo' +DESC="JPEG library on steroids" +REQUIRES="nasm" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DCMAKE_INSTALL_PREFIX="" \ + -DCMAKE_INSTALL_LIBDIR="/lib" \ + -DENABLE_STATIC=OFF + + make + make install DESTDIR=$PKG + + mkfinalpkg +} + +SHA512SUMS=" +f2d693ccb4e4c78bf989f069679b6dda5d4261f3375c955e183952d4a3d6e4b8d80e36ec366d730b3bb9372b4210f530f43c17a3034467c0cc2e8fde9799553a libjpeg-turbo-2.0.4.tar.lz +" diff --git a/base/libkate/libkate-0.4.1-no-libfl.patch b/base/libkate/libkate-0.4.1-no-libfl.patch new file mode 100644 index 0000000..a5183d2 --- /dev/null +++ b/base/libkate/libkate-0.4.1-no-libfl.patch @@ -0,0 +1,88 @@ +diff -u -r libkate-0.4.1-orig/Makefile.in libkate-0.4.1/Makefile.in +--- libkate-0.4.1-orig/Makefile.in 2011-08-21 23:46:58.000000000 +0100 ++++ libkate-0.4.1/Makefile.in 2015-05-28 23:52:21.389946971 +0100 +@@ -260,7 +260,6 @@ + LD = @LD@ + LDFLAGS = @LDFLAGS@ + LEX = @LEX@ +-LEXLIB = @LEXLIB@ + LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@ + LIBKATE_SHARED_VERSION = @LIBKATE_SHARED_VERSION@ + LIBOBJS = @LIBOBJS@ +diff -u -r libkate-0.4.1-orig/configure.ac libkate-0.4.1/configure.ac +--- libkate-0.4.1-orig/configure.ac 2011-08-21 23:44:32.000000000 +0100 ++++ libkate-0.4.1/configure.ac 2015-05-30 06:28:33.306682481 +0100 +@@ -7,7 +7,7 @@ + + AC_CANONICAL_TARGET + +-AM_INIT_AUTOMAKE([-Wall -Werror foreign subdir-objects]) ++AM_INIT_AUTOMAKE([-Wall foreign subdir-objects]) + AC_CONFIG_HEADERS([include/config.h]) + + ifdef([AM_SILENT_RULES],[AM_SILENT_RULES]) +diff -u -r libkate-0.4.1-orig/doc/Makefile.in libkate-0.4.1/doc/Makefile.in +--- libkate-0.4.1-orig/doc/Makefile.in 2011-08-21 23:47:10.000000000 +0100 ++++ libkate-0.4.1/doc/Makefile.in 2015-05-28 23:52:49.742054572 +0100 +@@ -125,7 +125,6 @@ + LD = @LD@ + LDFLAGS = @LDFLAGS@ + LEX = @LEX@ +-LEXLIB = @LEXLIB@ + LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@ + LIBKATE_SHARED_VERSION = @LIBKATE_SHARED_VERSION@ + LIBOBJS = @LIBOBJS@ +diff -u -r libkate-0.4.1-orig/tests/Makefile.in libkate-0.4.1/tests/Makefile.in +--- libkate-0.4.1-orig/tests/Makefile.in 2011-08-21 23:46:58.000000000 +0100 ++++ libkate-0.4.1/tests/Makefile.in 2015-05-28 23:52:36.542004463 +0100 +@@ -156,7 +156,6 @@ + LD = @LD@ + LDFLAGS = @LDFLAGS@ + LEX = @LEX@ +-LEXLIB = @LEXLIB@ + LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@ + LIBKATE_SHARED_VERSION = @LIBKATE_SHARED_VERSION@ + LIBOBJS = @LIBOBJS@ +diff -u -r libkate-0.4.1-orig/tools/KateDJ/Makefile.in libkate-0.4.1/tools/KateDJ/Makefile.in +--- libkate-0.4.1-orig/tools/KateDJ/Makefile.in 2011-08-21 23:46:58.000000000 +0100 ++++ libkate-0.4.1/tools/KateDJ/Makefile.in 2015-05-28 23:53:11.981139017 +0100 +@@ -99,7 +99,6 @@ + LD = @LD@ + LDFLAGS = @LDFLAGS@ + LEX = @LEX@ +-LEXLIB = @LEXLIB@ + LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@ + LIBKATE_SHARED_VERSION = @LIBKATE_SHARED_VERSION@ + LIBOBJS = @LIBOBJS@ +diff -u -r libkate-0.4.1-orig/tools/Makefile.am libkate-0.4.1/tools/Makefile.am +--- libkate-0.4.1-orig/tools/Makefile.am 2011-08-21 13:42:10.000000000 +0100 ++++ libkate-0.4.1/tools/Makefile.am 2015-05-28 23:54:03.293333914 +0100 +@@ -20,7 +20,7 @@ + endif + katedec_SOURCES=katedec.c kkate.c ksrt.c klrc.c kutil.c kfuzz.c kstream.c kread.c kstrings.c + katalyzer_SOURCES=katalyzer.c kutil.c kstream.c kread.c kstrings.c kstats.c +-kateenc_LDADD=../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ @PNG_LIBS@ @LEXLIB@ ++kateenc_LDADD=../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ @PNG_LIBS@ + katedec_LDADD=../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ + katalyzer_LDADD=../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ + kateenc_CFLAGS=@CWARNFLAGS_LIGHT@ @CFLAGS_FORTIFY_SOURCE@ @CFLAGS_DEBUG@ @OGG_CFLAGS@ @PNG_CFLAGS@ +diff -u -r libkate-0.4.1-orig/tools/Makefile.in libkate-0.4.1/tools/Makefile.in +--- libkate-0.4.1-orig/tools/Makefile.in 2011-08-21 23:46:58.000000000 +0100 ++++ libkate-0.4.1/tools/Makefile.in 2015-05-28 23:54:21.805404270 +0100 +@@ -223,7 +223,6 @@ + LD = @LD@ + LDFLAGS = @LDFLAGS@ + LEX = @LEX@ +-LEXLIB = @LEXLIB@ + LEX_OUTPUT_ROOT = @LEX_OUTPUT_ROOT@ + LIBKATE_SHARED_VERSION = @LIBKATE_SHARED_VERSION@ + LIBOBJS = @LIBOBJS@ +@@ -351,7 +350,7 @@ + @HAVE_OGG_TRUE@ $(am__append_1) + @HAVE_OGG_TRUE@katedec_SOURCES = katedec.c kkate.c ksrt.c klrc.c kutil.c kfuzz.c kstream.c kread.c kstrings.c + @HAVE_OGG_TRUE@katalyzer_SOURCES = katalyzer.c kutil.c kstream.c kread.c kstrings.c kstats.c +-@HAVE_OGG_TRUE@kateenc_LDADD = ../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ @PNG_LIBS@ @LEXLIB@ ++@HAVE_OGG_TRUE@kateenc_LDADD = ../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ @PNG_LIBS@ + @HAVE_OGG_TRUE@katedec_LDADD = ../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ + @HAVE_OGG_TRUE@katalyzer_LDADD = ../lib/liboggkate.la ../lib/libkate.la @OGG_LIBS@ + @HAVE_OGG_TRUE@kateenc_CFLAGS = @CWARNFLAGS_LIGHT@ @CFLAGS_FORTIFY_SOURCE@ @CFLAGS_DEBUG@ @OGG_CFLAGS@ @PNG_CFLAGS@ diff --git a/base/libkate/libkate.SMBuild b/base/libkate/libkate.SMBuild new file mode 100755 index 0000000..b8c31f7 --- /dev/null +++ b/base/libkate/libkate.SMBuild @@ -0,0 +1,37 @@ +APP=libkate +VERSION=0.4.1 +BUILD=1sml +HOMEPAGE='https://wiki.xiph.org/OggKate' +DESC="codec providing karaoke and text support in Ogg" +REQUIRES="libogg libpng python3" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/libkate-0.4.1-no-libfl.patch + + libtoolize --copy --force + aclocal + automake --add-missing --copy --force-missing + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f5db83caffa11ccc71626917e6199e5bb4da5d7531af33a899f2d6f452b6c104f8bf7fcc3c75d534fc1ebefff206a36b5099232aa991caefa99e883e8ad20562 libkate-0.4.1.tar.lz +f4cee4a8d309e424a51e03286a74ea6ecf403817343ea91a1c333f334e4ebf68630404b3a3393ca56b8582c8f1db4c1eea019a1141c3150fb75438e38258cdae libkate-0.4.1-no-libfl.patch +" diff --git a/base/libksba/libksba.SMBuild b/base/libksba/libksba.SMBuild new file mode 100755 index 0000000..87b5391 --- /dev/null +++ b/base/libksba/libksba.SMBuild @@ -0,0 +1,32 @@ +APP=libksba +VERSION=1.4.0 +BUILD=1sml +HOMEPAGE='https://gnupg.org/software/libksba/index.html' +DESC="X.509 & CMS library for S/MIME and TLS" +REQUIRES="libgpg-error" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-shared=yes \ + --enable-static=no + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bcd4e83b6a8e6ae2d15de8670d923d085556c6617d3904afe9477eca11484ab3db0b7cd64ca2c06d7b1af5bf9b95fca502bf0f6f4c15290dd1e90a4c0d8363e6 libksba-1.4.0.tar.lz +" diff --git a/base/libminizip/libminizip.SMBuild b/base/libminizip/libminizip.SMBuild new file mode 100755 index 0000000..b49dd45 --- /dev/null +++ b/base/libminizip/libminizip.SMBuild @@ -0,0 +1,38 @@ +APP=libminizip +VERSION=1.2.11 +BUILD=1sml +HOMEPAGE='https://www.zlib.net' +DESC="zip compression and decompression library" +REQUIRES="zlib" + +build() { + mkandenterbuilddir + rm -rf zlib-$VERSION + + tar xf $SRCDIR/zlib-$VERSION.tar.?z* + cd zlib-$VERSION + fixbuilddirpermissions + + cd contrib/minizip + libtoolize + aclocal + autoconf + automake --add-missing + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cd ../../ + cp README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c983b6d1e595d08b4cce8858a5df0ed01fc324807b1d191b06f0900224b51f247d482c2335828a6ec8e4e3778eb374dc3e31b8bfc23c69743926612d05cdd81e zlib-1.2.11.tar.lz +" diff --git a/base/libmms/libmms.SMBuild b/base/libmms/libmms.SMBuild new file mode 100755 index 0000000..8a8ed9f --- /dev/null +++ b/base/libmms/libmms.SMBuild @@ -0,0 +1,31 @@ +APP=libmms +VERSION=0.6.4 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/libmms/' +DESC="video library for parsing mms and mmsh video streams" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +1734761d3e7091856dc0b3ca140279b2090791732a7894f46bf6cb0d4c9c13ad8779285119136fbd9253ccfd980d65dd2969fabba377c3a5d03d28be3b158d74 libmms-0.6.4.tar.lz +" diff --git a/base/libmnl/libmnl.SMBuild b/base/libmnl/libmnl.SMBuild new file mode 100755 index 0000000..5e38ffc --- /dev/null +++ b/base/libmnl/libmnl.SMBuild @@ -0,0 +1,31 @@ +APP=libmnl +VERSION=1.0.4 +BUILD=1sml +HOMEPAGE='http://www.netfilter.org/projects/libmnl/' +DOWNLOAD='https://www.netfilter.org/pub/libmnl/libmnl-1.0.4.tar.bz2' +DESC="user-space library oriented to Netlink developers" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +30689d7f6c1e87d564e65c944b6d1fe36eba310f06b2fa39f37d1c0773ef0547c4100e6109cf03f9e844b0eda8832b17e12e137b6f603fa8fa1833705254f360 libmnl-1.0.4.tar.lz +" diff --git a/base/libmodplug/libmodplug.SMBuild b/base/libmodplug/libmodplug.SMBuild new file mode 100755 index 0000000..36ab81b --- /dev/null +++ b/base/libmodplug/libmodplug.SMBuild @@ -0,0 +1,31 @@ +APP=libmodplug +VERSION=0.8.9.0 +BUILD=1sml +HOMEPAGE='http://modplug-xmms.sourceforge.net/' +DESC="library for the modplug sound engine" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4b2eb34aeb7f2ae2f16b5fb6e302580205650d277e930b24ae30c8a5c0ff9def8a1a3c5730a4faa41971010630bd9c1f9425fe139b5afb5a9534c928935e26ab libmodplug-0.8.9.0.tar.lz +" diff --git a/base/libmrss/libmrss.SMBuild b/base/libmrss/libmrss.SMBuild new file mode 100755 index 0000000..4492c7a --- /dev/null +++ b/base/libmrss/libmrss.SMBuild @@ -0,0 +1,31 @@ +APP=libmrss +VERSION=0.19.2 +BUILD=1sml +HOMEPAGE='https://github.com/bakulf/libmrss' +DESC="C Library for parsing, writing and creating RSS files" +REQUIRES="libnxml" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4cea6c2251beaf0e372c3be7862c2470d2f4d18845d320ef63434e8ec4a9397750bc0aa04989c9a0bed6c0f33263f706860301f8df17903e4e3496c126620fea libmrss-0.19.2.tar.lz +" diff --git a/base/libmtp/libmtp.SMBuild b/base/libmtp/libmtp.SMBuild new file mode 100755 index 0000000..da7de88 --- /dev/null +++ b/base/libmtp/libmtp.SMBuild @@ -0,0 +1,32 @@ +APP=libmtp +VERSION=1.1.17 +BUILD=1sml +HOMEPAGE='https://github.com/libmtp/libmtp' +DESC="library for communicating with MTP devices" +REQUIRES="libgpg-error libgcrypt eudev libusb" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + --with-udev=/lib/udev + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d2f14b28713b43fb49f9b1e744a38ead2d98b31a060cefc3e49ab3b08521cbdd3edf5952e24b07f5b18c0cea50e2bb2f2cc17b531dda71c7e687d9f389de940e libmtp-1.1.17.tar.lz +" diff --git a/base/libmypaint/libmypaint.SMBuild b/base/libmypaint/libmypaint.SMBuild new file mode 100755 index 0000000..a6d0240 --- /dev/null +++ b/base/libmypaint/libmypaint.SMBuild @@ -0,0 +1,29 @@ +APP=libmypaint +VERSION=1.6.1 +BUILD=1sml +HOMEPAGE='https://github.com/mypaint/libmypaint' +DESC="library for making brushstrokes used by MyPaint and others" +REQUIRES="glib json-c json-glib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7d26880a3a4a140b3770ecf0b913bb6153fe20654ddee98b441479fed17990e1f4f617c55a76fe2a4bb94d2d194cda9d4e9b0e4b9a002f189249734bcde395c1 libmypaint-1.6.1.tar.lz +" diff --git a/base/libnetfilter_conntrack/libnetfilter_conntrack.SMBuild b/base/libnetfilter_conntrack/libnetfilter_conntrack.SMBuild new file mode 100755 index 0000000..059c20d --- /dev/null +++ b/base/libnetfilter_conntrack/libnetfilter_conntrack.SMBuild @@ -0,0 +1,31 @@ +APP=libnetfilter_conntrack +VERSION=1.0.7 +BUILD=1sml +HOMEPAGE='https://www.netfilter.org/projects/libnetfilter_conntrack/index.html' +DESC="library for in-kernel connection tracking used by iptables and others" +REQUIRES="libmnl libnfnetlink" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4697faa3ff0caae7ba13908d1805d6ce0c4e577a2c18407eca6b82550923fd8c675abac638489124ab72f2a1a27e7bbe0330ca603f7a889dc4a582f5e12dd784 libnetfilter_conntrack-1.0.7.tar.lz +" diff --git a/base/libnfnetlink/libnfnetlink.SMBuild b/base/libnfnetlink/libnfnetlink.SMBuild new file mode 100755 index 0000000..df2a6e3 --- /dev/null +++ b/base/libnfnetlink/libnfnetlink.SMBuild @@ -0,0 +1,33 @@ +APP=libnfnetlink +VERSION=1.0.1 +BUILD=1sml +HOMEPAGE='https://www.netfilter.org/projects/libnfnetlink/index.html' +DESC="library for netfilter kernel/userspace communications" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/musl-fix-includes.patch + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +04507f1340a93c408865d8c60826a3117fb57fa38459081d202d40b4b9f093b79365c05cc9c3b90dce20239d6ba819b110b42bf2a91b4da4bc65d701ed3812bd libnfnetlink-1.0.1.tar.lz +fc452e2924fa4de66e104229bc05a663c253148fb1c0bd62e5454a907877ffb084ba6a04e38bf4ef71a4e58041f4a242001a8029aefbe97ccc00e3bfcb7bba41 musl-fix-includes.patch +" diff --git a/base/libnfnetlink/musl-fix-includes.patch b/base/libnfnetlink/musl-fix-includes.patch new file mode 100644 index 0000000..04aef8a --- /dev/null +++ b/base/libnfnetlink/musl-fix-includes.patch @@ -0,0 +1,20 @@ +--- libnfnetlink-1.0.1.orig/include/libnfnetlink/linux_nfnetlink.h ++++ libnfnetlink-1.0.1/include/libnfnetlink/linux_nfnetlink.h +@@ -1,6 +1,6 @@ + #ifndef _NFNETLINK_H + #define _NFNETLINK_H +-#include ++#include + #include + + enum nfnetlink_groups { +--- libnfnetlink-1.0.1.orig/include/libnfnetlink/libnfnetlink.h ++++ libnfnetlink-1.0.1/include/libnfnetlink/libnfnetlink.h +@@ -15,6 +15,7 @@ + #define aligned_u64 unsigned long long __attribute__((aligned(8))) + #endif + ++#include + #include /* for sa_family_t */ + #include + #include diff --git a/base/libnfs/libnfs.SMBuild b/base/libnfs/libnfs.SMBuild new file mode 100755 index 0000000..55b1114 --- /dev/null +++ b/base/libnfs/libnfs.SMBuild @@ -0,0 +1,30 @@ +APP=libnfs +VERSION=4.0.0 +BUILD=1sml +HOMEPAGE='https://github.com/sahlberg/libnfs' +DESC="client library for accessing NFS shares" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING LICENCE* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3b93b2d9ab64f899cc25be795a077da12f36188f3170789c5903b5fd986b6641a1dc325ce3678047dbdaf6b7209b5711c7c746000b4a90274413163bf65ea147 libnfs-4.0.0.tar.lz +" diff --git a/base/libnl/libnl.SMBuild b/base/libnl/libnl.SMBuild new file mode 100755 index 0000000..6d83d9d --- /dev/null +++ b/base/libnl/libnl.SMBuild @@ -0,0 +1,30 @@ +APP=libnl +VERSION=3.5.0 +BUILD=1sml +HOMEPAGE='https://github.com/thom311/libnl' +DESC="Netlink Protocol Library Suite version 3" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ff9f91212e66103476ea01c5842da455aebd060502ae9ca1656fdaaa9ec30e1496e13c3203110371d71af4696d796e1770cb31599961f401aaff53a65c8a98cd libnl-3.5.0.tar.lz +" diff --git a/base/libnxml/libnxml.SMBuild b/base/libnxml/libnxml.SMBuild new file mode 100755 index 0000000..0eec8e6 --- /dev/null +++ b/base/libnxml/libnxml.SMBuild @@ -0,0 +1,31 @@ +APP=libnxml +VERSION=0.18.3 +BUILD=1sml +HOMEPAGE='https://github.com/bakulf/libnxml' +DESC="C library for parsing XML 1.0 and 1.1 files or streams" +REQUIRES="zlib curl nghttp2 libidn2 libssh2 openssl brotli libunistring" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +6e3ac6cfa9fadbf5d9ffd6c1ee671b4862fc4cd02211b025c9a52f10872490e2e365bd3524a830cb1a091340a9bb48b7468720018cb303b2d83a861326dd635a libnxml-0.18.3.tar.lz +" diff --git a/base/libogg/libogg.SMBuild b/base/libogg/libogg.SMBuild new file mode 100755 index 0000000..7cb9a20 --- /dev/null +++ b/base/libogg/libogg.SMBuild @@ -0,0 +1,31 @@ +APP=libogg +VERSION=1.3.4 +BUILD=1sml +HOMEPAGE='https://xiph.org/ogg/' +DESC="Library for manipulating ogg bitstreams" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +76fd0af0708dda9c84550945d314eb002f141d941dcf71a6942dd76d2f62a6eebfaa6469f1f5807bb69976181cd9a0f3076ddbd5c43e7f08217b1102d784aafc libogg-1.3.4.tar.lz +" diff --git a/base/libopenal/libopenal.SMBuild b/base/libopenal/libopenal.SMBuild new file mode 100755 index 0000000..bca69c9 --- /dev/null +++ b/base/libopenal/libopenal.SMBuild @@ -0,0 +1,32 @@ +APP=libopenal +VERSION=1.20.1 +BUILD=1sml +HOMEPAGE='https://openal-soft.org/' +DESC="Cross-platform 3D audio API" +REQUIRES="gcc-libs nettle libcap" + +build() { + mkandenterbuilddir + rm -rf openal-soft-$VERSION + + tar xf $SRCDIR/openal-soft-$VERSION.tar.?z* + cd openal-soft-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DCMAKE_INSTALL_PREFIX="" \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_LIBDIR=lib + + make + make install DESTDIR=$PKG + + cp ../COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4b89ca3c3e50648ea019932725b4d65a21e22b984c7cc6b19455b689e2a9b64e9e5827731918213ccfaaa8e4ae21d767ba53d6c8c19f9ec76efef0bf5d8a8555 openal-soft-1.20.1.tar.lz +" diff --git a/base/libpcap/libpcap.SMBuild b/base/libpcap/libpcap.SMBuild new file mode 100755 index 0000000..1f3e0d6 --- /dev/null +++ b/base/libpcap/libpcap.SMBuild @@ -0,0 +1,35 @@ +APP=libpcap +VERSION=1.9.0 +BUILD=1sml +HOMEPAGE='http://www.tcpdump.org' +DOWNLOAD='https://www.tcpdump.org/release/libpcap-1.9.0.tar.gz' +DESC="packet capture library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="$CFLAGS -D_BSD_SOURCE -DIPPROTO_HOPOPTS=0 -include limits.h" \ + ac_cv_type_u_int64_t=yes \ + ./configure \ + --prefix="" \ + --enable-shared \ + --disable-dbus \ + --disable-bluetooth + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b1449b248bc3f3daf17c1a8bfcb7870e7157d050db36bfce6f9adde6a9ba4893baff40d0f21d50012da02b11ec5a43d21a2b3715ab51dcbe03192541dc83be68 libpcap-1.9.0.tar.lz +" diff --git a/base/libpng/libpng.SMBuild b/base/libpng/libpng.SMBuild new file mode 100755 index 0000000..7da0b2d --- /dev/null +++ b/base/libpng/libpng.SMBuild @@ -0,0 +1,31 @@ +APP=libpng +VERSION=1.6.37 +BUILD=1sml +HOMEPAGE='http://www.libpng.org/pub/png/libpng.html' +DOWNLOAD='https://download.sourceforge.net/libpng/libpng-1.6.37.tar.xz' +DESC="Portable Network Graphics library" +REQUIRES="zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fb2f6d82ea4ae1206d6857fb471b71c56aa84a64a6943174b6da96cbe8fa38e2580401647981d9b1488a6fa8d43b661db11995fdacdab01f21911e40cb343ed0 libpng-1.6.37.tar.lz +" diff --git a/base/libpthread-stubs/libpthread-stubs.SMBuild b/base/libpthread-stubs/libpthread-stubs.SMBuild new file mode 100755 index 0000000..a9c84b2 --- /dev/null +++ b/base/libpthread-stubs/libpthread-stubs.SMBuild @@ -0,0 +1,30 @@ +APP=libpthread-stubs +VERSION=0.1 +BUILD=1sml +HOMEPAGE='https://gitlab.freedesktop.org/xorg/lib/pthread-stubs' +DESC="library providing weak aliases for pthread functions" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f46c856cc77c0fe5c3b785f52c7defc37cd5e8a731b0c81016334c80ff89d5a0724a2a3272050f5ff220d597f4a743de76e40b466c28634da3f5c8ee169f85e7 libpthread-stubs-0.1.tar.lz +" diff --git a/base/libsamplerate/libsamplerate.SMBuild b/base/libsamplerate/libsamplerate.SMBuild new file mode 100755 index 0000000..17453af --- /dev/null +++ b/base/libsamplerate/libsamplerate.SMBuild @@ -0,0 +1,33 @@ +APP=libsamplerate +VERSION=0.1.9 +BUILD=1sml +HOMEPAGE='https://github.com/libsndfile/libsamplerate' +DOWNLOAD='https://github.com/libsndfile/libsamplerate/archive/refs/tags/0.1.9.tar.gz' +DESC="library for performing sample rate conversion of audio data" +REQUIRES="alsa-lib libsndfile libogg libvorbis flac" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +74f1d8fc8ba378e75af33834aa174a4bb7a7b65e0adf76b148397a9f32b9b27d9127ceb77e78a8869071543bf03a5aa79a290eb1b9542c9fb1a34bfdd95b27e2 libsamplerate-0.1.9.tar.lz +" diff --git a/base/libseccomp/libseccomp.SMBuild b/base/libseccomp/libseccomp.SMBuild new file mode 100755 index 0000000..c479200 --- /dev/null +++ b/base/libseccomp/libseccomp.SMBuild @@ -0,0 +1,31 @@ +APP=libseccomp +VERSION=2.4.2 +BUILD=1sml +HOMEPAGE='https://github.com/seccomp/libseccomp' +DOWNLOAD='https://github.com/seccomp/libseccomp/releases/download/v2.4.2/libseccomp-2.4.2.tar.gz' +DESC="library providing easy and independent interface to kernel syscall filtering mechanism" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +6396fa4795193bc9138894f2969ec0a1659282380ab5a287ab30e0ed7004ec29671c66ca29f7eb2b09ef894287e450e3a76042980403af2e4eec3bd3b23866d2 libseccomp-2.4.2.tar.lz +" diff --git a/base/libsecret/libsecret.SMBuild b/base/libsecret/libsecret.SMBuild new file mode 100755 index 0000000..b778049 --- /dev/null +++ b/base/libsecret/libsecret.SMBuild @@ -0,0 +1,33 @@ +APP=libsecret +VERSION=0.20.3 +BUILD=1sml +HOMEPAGE='https://wiki.gnome.org/Projects/Libsecret' +DOWNLOAD='https://download.gnome.org/sources/libsecret/0.20/libsecret-0.20.3.tar.xz' +DESC="GObject based library to access the Secret Service API" +REQUIRES="libgcrypt glib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + --disable-introspection + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fbc344cc236a24f53e43d96e8d8b55ae45e7f9391c0443c6739098b356a5cf35701744760991811bfe043569087fe115ba1037f403b0c7ab711c5e1cbaafdc1f libsecret-0.20.3.tar.lz +" diff --git a/base/libshout/libshout.SMBuild b/base/libshout/libshout.SMBuild new file mode 100755 index 0000000..910ba29 --- /dev/null +++ b/base/libshout/libshout.SMBuild @@ -0,0 +1,32 @@ +APP=libshout +VERSION=2.3.1 +BUILD=1sml +HOMEPAGE='https://directory.fsf.org/wiki/Libshout' +DOWNLOAD='https://ftp.osuosl.org/pub/xiph/releases/libshout/libshout-2.3.1.tar.gz' +DESC="icecast server library" +REQUIRES="libtheora" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ee7f67f35df7cf4fe778d6e175c5fb59134814a822a68e9ef88a36193a98856d8d8da5bf7a8ee0b174c87630f5dbfe4a63719de7047e3e63bb79e8a14575937a libshout-2.3.1.tar.lz +" diff --git a/base/libsndfile/libsndfile.SMBuild b/base/libsndfile/libsndfile.SMBuild new file mode 100755 index 0000000..c093654 --- /dev/null +++ b/base/libsndfile/libsndfile.SMBuild @@ -0,0 +1,31 @@ +APP=libsndfile +VERSION=1.0.28 +BUILD=1sml +HOMEPAGE='http://www.mega-nerd.com/libsndfile/' +DOWNLOAD='http://www.mega-nerd.com/libsndfile/files/libsndfile-1.0.28.tar.gz' +DESC="C library for reading and writing wav files" +REQUIRES="alsa-lib libogg libvorbis" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4cc9f0e856763bec64104b9b1273943564bdf96443908817097a7de8032363ca91f9adba559ffb50f2570142bf0567cc8472bdf807c5966807734f3b91960855 libsndfile-1.0.28.tar.lz +" diff --git a/base/libsodium/libsodium.SMBuild b/base/libsodium/libsodium.SMBuild new file mode 100755 index 0000000..6786257 --- /dev/null +++ b/base/libsodium/libsodium.SMBuild @@ -0,0 +1,34 @@ +APP=libsodium +VERSION=1.0.18 +BUILD=1sml +HOMEPAGE='https://github.com/jedisct1/libsodium' +DOWNLOAD='https://github.com/jedisct1/libsodium/archive/refs/tags/1.0.18.tar.gz' +DESC="easy-to-use crypto library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ac_cv_tls=__thread \ + ax_cv_check_cflags___ftls_model_local_dynamic=no \ + ./configure \ + --prefix="" \ + --disable-ssp \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICEN?E $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +922647608e7be1acf4f7d901913e15e2acb595c9e53202b5a10b366e19ca4542e9583959096e6560273f01c7594936bd6a9f625d22d4e4582c5e16d6aac5fe96 libsodium-1.0.18.tar.lz +" diff --git a/base/libssh2/libssh2.SMBuild b/base/libssh2/libssh2.SMBuild new file mode 100755 index 0000000..dc3a85c --- /dev/null +++ b/base/libssh2/libssh2.SMBuild @@ -0,0 +1,31 @@ +APP=libssh2 +VERSION=1.9.0 +BUILD=1sml +HOMEPAGE='http://www.libssh2.org/' +DOWNLOAD='https://www.libssh2.org/download/libssh2-1.9.0.tar.gz' +DESC="SSH2 library" +REQUIRES="zlib openssl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-static=no + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +62a44fbaea33c8db8c7f59805fd4c593fcbbf27ad66764611ea40a09aeab8a0ec581d966e3bbd3ebcc37f707b69311770f6a5e45def64dec72d0b772be721445 libssh2-1.9.0.tar.lz +" diff --git a/base/libtasn1/libtasn1.SMBuild b/base/libtasn1/libtasn1.SMBuild new file mode 100755 index 0000000..77d9430 --- /dev/null +++ b/base/libtasn1/libtasn1.SMBuild @@ -0,0 +1,31 @@ +APP=libtasn1 +VERSION=4.13 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/libtasn1/' +DOWNLOAD='https://ftp.gnu.org/gnu/libtasn1/libtasn1-4.13.tar.gz' +DESC="Provides ASN.1 library used by GnuTLS and other crypto apps" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d063c1b8fc11f62d59ba162d6138148492cd9eb2a69487907d16f6bc0e2bf2645dc4313b1f85a27c8c1f8a69da7d332e4105fedb01bbb2103b93258c24bca95f libtasn1-4.13.tar.lz +" diff --git a/base/libtheora/libpng16.patch b/base/libtheora/libpng16.patch new file mode 100644 index 0000000..46d9333 --- /dev/null +++ b/base/libtheora/libpng16.patch @@ -0,0 +1,17 @@ +http://bugs.gentoo.org/465450 +http://trac.xiph.org/ticket/1947 + +--- a/examples/png2theora.c ++++ b/examples/png2theora.c +@@ -462,9 +462,9 @@ + png_set_strip_alpha(png_ptr); + + row_data = (png_bytep)png_malloc(png_ptr, +- 3*height*width*png_sizeof(*row_data)); ++ 3*height*width*sizeof(*row_data)); + row_pointers = (png_bytep *)png_malloc(png_ptr, +- height*png_sizeof(*row_pointers)); ++ height*sizeof(*row_pointers)); + for(y = 0; y < height; y++) { + row_pointers[y] = row_data + y*(3*width); + } diff --git a/base/libtheora/libtheora.SMBuild b/base/libtheora/libtheora.SMBuild new file mode 100755 index 0000000..655bbd6 --- /dev/null +++ b/base/libtheora/libtheora.SMBuild @@ -0,0 +1,36 @@ +APP=libtheora +VERSION=1.1.1 +BUILD=1sml +HOMEPAGE='https://www.theora.org/' +DOWNLOAD='http://downloads.xiph.org/releases/theora/libtheora-1.1.1.tar.bz2' +DESC="Theora video codec library" +REQUIRES="libogg libvorbis" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/libpng16.patch + + ./configure \ + --prefix="" \ + --disable-static \ + --disable-examples \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +715cc8265125168eb50e28a476a63ec3292486e7e6c61884caebefcf8d074efe9fbd1fa0ff4e1ce798f4f6a72051008e93f1e5c8109f24437a9a21a38f7103ba libtheora-1.1.1.tar.lz +5ed8c35eee6fb533fbbfc835fe62eddea18ddc956b453b1062a4d1534b6d69db2e70a03bdf3300a8b1a5832feef2c7536bfad4274e8e89769e07a8a3f635b1b5 libpng16.patch +" diff --git a/base/libtirpc/doinst.sh b/base/libtirpc/doinst.sh new file mode 100644 index 0000000..409cfbe --- /dev/null +++ b/base/libtirpc/doinst.sh @@ -0,0 +1,13 @@ +#!/bin/sh +config() { + NEW="$1" + OLD="`dirname $NEW`/`basename $NEW .new`" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/netconfig.new diff --git a/base/libtirpc/libtirpc.SMBuild b/base/libtirpc/libtirpc.SMBuild new file mode 100755 index 0000000..c5ca729 --- /dev/null +++ b/base/libtirpc/libtirpc.SMBuild @@ -0,0 +1,47 @@ +APP=libtirpc +VERSION=1.2.6 +BUILD=1sml +HOMEPAGE='http://sourceforge.net/projects/libtirpc/' +DOWNLOAD='https://downloads.sourceforge.net/libtirpc/libtirpc-1.2.6.tar.bz2' +DESC="Transport-Independent RPC library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/soname-suffix.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + --disable-gssapi + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + # Don't use .3t man page suffix: + if [ -d $PKG/share/man/man3 ]; then + ( cd $PKG/share/man/man3 + for file in *.3t ; do + mv $file $(basename $file .3t).3 + done + ) + fi + + mv $PKG/etc/netconfig $PKG/etc/netconfig.new + + mkfinalpkg +} + +SHA512SUMS=" +bcb6b5c062c1301aa1246ec93ae0a5c1d221b8421126d020863517cb814b43ed038fb6c0c2faf4e68ff133b69abefe4f4d42bfc870671da6c27ca941a30b155a libtirpc-1.2.6.tar.bz2 +ccb6352c3c3b896765581595b9a0e45a527c34cbc16495d3890f996a2bc077a02ceae0ddd63505b3420a8414b93a267c82a11bc75997de8f9ca0a22e4c4daa5c soname-suffix.patch +" diff --git a/base/libtirpc/soname-suffix.patch b/base/libtirpc/soname-suffix.patch new file mode 100644 index 0000000..4941bab --- /dev/null +++ b/base/libtirpc/soname-suffix.patch @@ -0,0 +1,103 @@ +Allow to append a suffix to the library name via configuration +variable SONAME_SUFFIX. + +--- a/configure.ac ++++ b/configure.ac +@@ -74,6 +74,8 @@ + [],[enable_symvers=yes]) + AM_CONDITIONAL(SYMVERS, test "x$enable_symvers" = xyes) + ++AC_ARG_VAR([SONAME_SUFFIX], [Suffix to be appended to the library name]) ++ + AC_CANONICAL_BUILD + # Check for which host we are on and setup a few things + # specifically based on the host +@@ -98,6 +100,7 @@ + AC_CHECK_FUNCS([getrpcbyname getrpcbynumber setrpcent endrpcent getrpcent]) + + AC_CONFIG_FILES([Makefile src/Makefile man/Makefile doc/Makefile]) +-AC_OUTPUT(libtirpc.pc) ++AC_CONFIG_FILES([libtirpc$SONAME_SUFFIX.pc:libtirpc.pc.in]) ++AC_OUTPUT + + +--- a/Makefile.am ++++ b/Makefile.am +@@ -46,7 +46,7 @@ + endif + + pkgconfigdir=$(libdir)/pkgconfig +-pkgconfig_DATA = libtirpc.pc ++pkgconfig_DATA = libtirpc@SONAME_SUFFIX@.pc + + CLEANFILES = cscope.* *~ + DISTCLEANFILES = Makefile.in libtirpc*.tar.gz +--- a/src/Makefile.am ++++ b/src/Makefile.am +@@ -10,12 +10,12 @@ + AM_CPPFLAGS = -I$(top_srcdir)/tirpc -include config.h -DPORTMAP -DINET6 \ + -D_GNU_SOURCE -Wall -pipe + +-lib_LTLIBRARIES = libtirpc.la ++lib_LTLIBRARIES = libtirpc@SONAME_SUFFIX@.la + +-libtirpc_la_LDFLAGS = @LDFLAG_NOUNDEFINED@ -no-undefined -lpthread +-libtirpc_la_LDFLAGS += -version-info @LT_VERSION_INFO@ ++libtirpc@SONAME_SUFFIX@_la_LDFLAGS = @LDFLAG_NOUNDEFINED@ -no-undefined -lpthread ++libtirpc@SONAME_SUFFIX@_la_LDFLAGS += -version-info @LT_VERSION_INFO@ + +-libtirpc_la_SOURCES = auth_none.c auth_unix.c authunix_prot.c \ ++libtirpc@SONAME_SUFFIX@_la_SOURCES = auth_none.c auth_unix.c authunix_prot.c \ + binddynport.c bindresvport.c \ + clnt_bcast.c clnt_dg.c clnt_generic.c clnt_perror.c clnt_raw.c clnt_simple.c \ + clnt_vc.c rpc_dtablesize.c getnetconfig.c getnetpath.c getrpcent.c \ +@@ -27,26 +27,26 @@ + auth_time.c debug.c + + if AUTHDES +-libtirpc_la_SOURCES += auth_des.c authdes_prot.c des_crypt.c des_impl.c des_soft.c svc_auth_des.c ++libtirpc@SONAME_SUFFIX@_la_SOURCES += auth_des.c authdes_prot.c des_crypt.c des_impl.c des_soft.c svc_auth_des.c + endif + + ## XDR +-libtirpc_la_SOURCES += xdr.c xdr_rec.c xdr_array.c xdr_float.c xdr_mem.c xdr_reference.c xdr_stdio.c xdr_sizeof.c ++libtirpc@SONAME_SUFFIX@_la_SOURCES += xdr.c xdr_rec.c xdr_array.c xdr_float.c xdr_mem.c xdr_reference.c xdr_stdio.c xdr_sizeof.c + + if SYMVERS +- libtirpc_la_LDFLAGS += -Wl,--version-script=$(srcdir)/libtirpc.map ++ libtirpc@SONAME_SUFFIX@_la_LDFLAGS += -Wl,--version-script=$(srcdir)/libtirpc.map + endif + + ## Secure-RPC + if GSS +- libtirpc_la_SOURCES += auth_gss.c authgss_prot.c svc_auth_gss.c \ ++ libtirpc@SONAME_SUFFIX@_la_SOURCES += auth_gss.c authgss_prot.c svc_auth_gss.c \ + rpc_gss_utils.c +- libtirpc_la_LIBADD = $(GSSAPI_LIBS) +- libtirpc_la_CFLAGS = -DHAVE_RPCSEC_GSS $(GSSAPI_CFLAGS) ++ libtirpc@SONAME_SUFFIX@_la_LIBADD = $(GSSAPI_LIBS) ++ libtirpc@SONAME_SUFFIX@_la_CFLAGS = -DHAVE_RPCSEC_GSS $(GSSAPI_CFLAGS) + endif + +-libtirpc_la_SOURCES += key_call.c key_prot_xdr.c getpublickey.c +-libtirpc_la_SOURCES += netname.c netnamer.c rpcdname.c rtime.c ++libtirpc@SONAME_SUFFIX@_la_SOURCES += key_call.c key_prot_xdr.c getpublickey.c ++libtirpc@SONAME_SUFFIX@_la_SOURCES += netname.c netnamer.c rpcdname.c rtime.c + + CLEANFILES = cscope.* *~ + DISTCLEANFILES = Makefile.in +--- a/libtirpc.pc.in ++++ b/libtirpc.pc.in +@@ -3,10 +3,10 @@ + libdir=@libdir@ + includedir=@includedir@ + +-Name: libtirpc ++Name: libtirpc@SONAME_SUFFIX@ + Description: Transport Independent RPC Library + Requires: + Version: @PACKAGE_VERSION@ +-Libs: -L@libdir@ -ltirpc ++Libs: -L@libdir@ -ltirpc@SONAME_SUFFIX@ + Libs.private: -lpthread + Cflags: -I@includedir@/tirpc diff --git a/base/libtool/libtool.SMBuild b/base/libtool/libtool.SMBuild new file mode 100755 index 0000000..f9c870e --- /dev/null +++ b/base/libtool/libtool.SMBuild @@ -0,0 +1,31 @@ +APP=libtool +VERSION=2.4.6 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/libtool' +DOWNLOAD='https://mirror.squ.edu.om/gnu/libtool/libtool-2.4.6.tar.xz' +DESC="Generic library support script" +REQUIRES="musl m4" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +703840ef4b5407ad0307a50dcba35703388d821a416ae5492e6f772494b073da3f4173902b2372dd4fae2591b7d5200ad49cd339acff1a6d7d72ac0b6751ebf5 libtool-2.4.6.tar.lz +" diff --git a/base/libtorrent/libtorrent.SMBuild b/base/libtorrent/libtorrent.SMBuild new file mode 100755 index 0000000..bc7746c --- /dev/null +++ b/base/libtorrent/libtorrent.SMBuild @@ -0,0 +1,36 @@ +APP=libtorrent +VERSION=0.13.8 +BUILD=1sml +HOMEPAGE='https://github.com/rakshasa/libtorrent' +DOWNLOAD='https://github.com/rakshasa/libtorrent/archive/refs/tags/v0.13.8.tar.gz' +DESC="C++ torrent library with focus on high performance and good code" +REQUIRES="gcc-libs zlib openssl" + + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-debug \ + --without-kqueue \ + --enable-aligned \ + --with-posix-fallocate \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e17d49d8858b53e692f7d8d2c312b517d375a3691873f3c542b5dddb16f364de7f765ee816576a23d6167a2e8a319e3a838305331dabec8f24ecd112a5f5359f libtorrent-0.13.8.tar.lz +" diff --git a/base/libunistring/libunistring.SMBuild b/base/libunistring/libunistring.SMBuild new file mode 100755 index 0000000..2f5626f --- /dev/null +++ b/base/libunistring/libunistring.SMBuild @@ -0,0 +1,33 @@ +APP=libunistring +VERSION=0.9.10 +BUILD=1sml +HOMEPAGE='http://www.gnu.org/s/libunistring' +DOWNLOAD='https://ftp.gnu.org/gnu/libunistring/libunistring-0.9.10.tar.gz' +DESC="GNU Unicode string manipulating library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static \ + --disable-rpath + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +296a0d2ff6d96eab8a4104af99aa8dfc3b22af68496161849e0ff6365346d21069ca589ecb10ad914b2969355bc049ac31f5fdb8e2146b172d5bc7cc2dd9c4a4 libunistring-0.9.10.tar.lz +" diff --git a/base/libusb/libusb.SMBuild b/base/libusb/libusb.SMBuild new file mode 100755 index 0000000..fac7dc3 --- /dev/null +++ b/base/libusb/libusb.SMBuild @@ -0,0 +1,31 @@ +APP=libusb +VERSION=1.0.23 +BUILD=1sml +HOMEPAGE='https://github.com/libusb/libusb' +DOWNLOAD='https://github.com/libusb/libusb/releases/download/v1.0.23/libusb-1.0.23.tar.bz2' +DESC="Library for userspace applications to access USB subsystem and devices" +REQUIRES="eudev" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +98aa486b7eaabd625eed51c4f4d03cc7215f5d3f353456fd6ebeba8e5dc1d0750a91626c76d6cb70c6c939daf168adbaaacba33b4da9863748620cafadd3540a libusb-1.0.23.tar.lz +" diff --git a/base/libuv/libuv.SMBuild b/base/libuv/libuv.SMBuild new file mode 100755 index 0000000..3c9a393 --- /dev/null +++ b/base/libuv/libuv.SMBuild @@ -0,0 +1,31 @@ +APP=libuv +VERSION=1.37.0 +BUILD=1sml +HOMEPAGE='https://github.com/libuv/libuv' +DOWNLOAD='https://github.com/libuv/libuv/archive/refs/tags/v1.37.0.tar.gz' +DESC="multi-platform library with a focus on asychronous I/O" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-v"$VERSION" + + tar xf $SRCDIR/$APP-v"$VERSION".tar.?z* + cd $APP-v"$VERSION" + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +55756c310172b499f38496451ee5dca9abd6caa71e2a2077491dfa8de9e74247e3ca9bb9b6034837d46db6614a9728234bc9f613de85ae199d21526aff0b73b4 libuv-v1.37.0.tar.lz +" diff --git a/base/libvncserver/libvncserver.SMBuild b/base/libvncserver/libvncserver.SMBuild new file mode 100755 index 0000000..f76e5a9 --- /dev/null +++ b/base/libvncserver/libvncserver.SMBuild @@ -0,0 +1,33 @@ +APP=libvncserver +VERSION=0.9.11 +BUILD=1sml +HOMEPAGE='https://libvnc.github.io/' +DOWNLOAD='https://github.com/LibVNC/libvncserver/archive/refs/tags/LibVNCServer-0.9.11.tar.gz' +DESC="VNC server library for easy implementation of the VNC server" +REQUIRES="zlib gmp libgcrypt libpng nettle gnutls libidn libtasn1 libjpeg-turbo" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --without-ssl \ + $HOSTDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +866e312874050629616919e2b8387368979c3773357ffa78f3b68574a7ee11a5b171f17503fc47a52ebc3de277bd443bbe714d476205229def61a46780bc6de3 libvncserver-0.9.11.tar.lz +" diff --git a/base/libvorbis/libvorbis.SMBuild b/base/libvorbis/libvorbis.SMBuild new file mode 100755 index 0000000..3a05943 --- /dev/null +++ b/base/libvorbis/libvorbis.SMBuild @@ -0,0 +1,31 @@ +APP=libvorbis +VERSION=1.3.6 +BUILD=1sml +HOMEPAGE='https://xiph.org/vorbis/' +DOWNLOAD='https://ftp.osuosl.org/pub/xiph/releases/vorbis/libvorbis-1.3.6.tar.xz' +DESC="Ogg Vorbis library" +REQUIRES="libogg" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +880b43e4d2ac7773cc3ac83cf5e36889fc674a7741f52d94561ab9b03c3c101e3bd9b3ab3903fba5804f8b7d499465cc3c434ec05d4f1993d10b1447bbba6465 libvorbis-1.3.6.tar.lz +" diff --git a/base/libvpx/libvpx.SMBuild b/base/libvpx/libvpx.SMBuild new file mode 100755 index 0000000..e51bc33 --- /dev/null +++ b/base/libvpx/libvpx.SMBuild @@ -0,0 +1,34 @@ +APP=libvpx +VERSION=1.8.2 +BUILD=1sml +HOMEPAGE='https://github.com/webmproject/libvpx' +DOWNLOAD='https://github.com/webmproject/libvpx/archive/refs/tags/v1.8.2.tar.gz' +DESC="provides the WebM VP8/VP9 codec libraries" +REQUIRES="gcc-libs nasm" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i 's/cp -p/cp/' build/make/Makefile + + ./configure \ + --prefix="///" \ + --enable-shared \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2f038cf1f3306ca70c6888d9bf9853dcb0f97bfca0fa28963596da4cf39939a4e2e67e0363c674326c17dbb562ce92a5ee39131881a39d88fd2588980d3f3d0f libvpx-1.8.2.tar.lz +" diff --git a/base/libxml2/libxml2-2.9.8-python3-unicode-errors.patch b/base/libxml2/libxml2-2.9.8-python3-unicode-errors.patch new file mode 100644 index 0000000..e87dcde --- /dev/null +++ b/base/libxml2/libxml2-2.9.8-python3-unicode-errors.patch @@ -0,0 +1,34 @@ +Index: libxml2-2.9.5/python/libxml.c +=================================================================== +--- libxml2-2.9.5.orig/python/libxml.c ++++ libxml2-2.9.5/python/libxml.c +@@ -1620,6 +1620,7 @@ libxml_xmlErrorFuncHandler(ATTRIBUTE_UNU + PyObject *message; + PyObject *result; + char str[1000]; ++ unsigned char *ptr = (unsigned char *)str; + + #ifdef DEBUG_ERROR + printf("libxml_xmlErrorFuncHandler(%p, %s, ...) called\n", ctx, msg); +@@ -1636,12 +1637,20 @@ libxml_xmlErrorFuncHandler(ATTRIBUTE_UNU + str[999] = 0; + va_end(ap); + ++#if PY_MAJOR_VERSION >= 3 ++ /* Ensure the error string doesn't start at UTF8 continuation. */ ++ while (*ptr && (*ptr & 0xc0) == 0x80) ++ ptr++; ++#endif ++ + list = PyTuple_New(2); + PyTuple_SetItem(list, 0, libxml_xmlPythonErrorFuncCtxt); + Py_XINCREF(libxml_xmlPythonErrorFuncCtxt); +- message = libxml_charPtrConstWrap(str); ++ message = libxml_charPtrConstWrap(ptr); + PyTuple_SetItem(list, 1, message); + result = PyEval_CallObject(libxml_xmlPythonErrorFuncHandler, list); ++ /* Forget any errors caused in the error handler. */ ++ PyErr_Clear(); + Py_XDECREF(list); + Py_XDECREF(result); + } diff --git a/base/libxml2/libxml2.SMBuild b/base/libxml2/libxml2.SMBuild new file mode 100755 index 0000000..2d06e50 --- /dev/null +++ b/base/libxml2/libxml2.SMBuild @@ -0,0 +1,41 @@ +APP=libxml2 +VERSION=2.9.12 +BUILD=2sml +HOMEPAGE='http://www.xmlsoft.org/' +DOWNLOAD='ftp://xmlsoft.org/libxml2/libxml2-2.9.10.tar.gz' +DESC="XML parser library" +REQUIRES="readline zlib xz python3" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/libxml2-2.9.8-python3-unicode-errors.patch + patch -p1 < $SRCDIR/revert-Make-xmlFreeNodeList-non-recursive.patch + + ./configure \ + --prefix="" \ + --enable-shared \ + --disable-static \ + --disable-silent-rules \ + --with-python=/bin/python3 + + sed -i 's@-L -L@@g' python/Makefile + + make + make install DESTDIR=$PKG + + cp Copyright $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +df1c6486e80f0fcf3c506f3599bcfb94b620c00d0b5d26831bc983daa78d58ec58b5057b1ec7c1a26c694f40199c6234ee2a6dcabf65abfa10c447cb5705abbd libxml2-2.9.12.tar.gz +a205c97fa1488fb8907cfa08b5f82e2055c80b86213dc3cc5c4b526fe6aa786bcc4e4eeb226c44635a1d021307b39e3940f706c42fb60e9e3e9b490a84164df7 libxml2-2.9.8-python3-unicode-errors.patch +347178e432379d543683cba21b902e7305202c03e8dbd724ae395963d677096a5cfc4e345e208d498163ca5174683c167610fc2b297090476038bc2bb7c84b4f revert-Make-xmlFreeNodeList-non-recursive.patch +" diff --git a/base/libxml2/revert-Make-xmlFreeNodeList-non-recursive.patch b/base/libxml2/revert-Make-xmlFreeNodeList-non-recursive.patch new file mode 100644 index 0000000..102abdb --- /dev/null +++ b/base/libxml2/revert-Make-xmlFreeNodeList-non-recursive.patch @@ -0,0 +1,64 @@ +This is a revert of +https://github.com/GNOME/libxml2/commit/0762c9b69ba01628f72eada1c64ff3d361fb5716 + +This fixes perl-xml-libxslt test suite +https://bugzilla.suse.com/show_bug.cgi?id=1157450 + +diff --git a/tree.c b/tree.c +index 08b1a50..f2b1457 100644 +--- a/tree.c ++++ b/tree.c +@@ -3664,9 +3664,7 @@ xmlNextElementSibling(xmlNodePtr node) { + void + xmlFreeNodeList(xmlNodePtr cur) { + xmlNodePtr next; +- xmlNodePtr parent; + xmlDictPtr dict = NULL; +- size_t depth = 0; + + if (cur == NULL) return; + if (cur->type == XML_NAMESPACE_DECL) { +@@ -3682,21 +3680,16 @@ xmlFreeNodeList(xmlNodePtr cur) { + return; + } + if (cur->doc != NULL) dict = cur->doc->dict; +- while (1) { +- while ((cur->children != NULL) && +- (cur->type != XML_DTD_NODE) && +- (cur->type != XML_ENTITY_REF_NODE)) { +- cur = cur->children; +- depth += 1; +- } +- ++ while (cur != NULL) { + next = cur->next; +- parent = cur->parent; + if (cur->type != XML_DTD_NODE) { + + if ((__xmlRegisterCallbacks) && (xmlDeregisterNodeDefaultValue)) + xmlDeregisterNodeDefaultValue(cur); + ++ if ((cur->children != NULL) && ++ (cur->type != XML_ENTITY_REF_NODE)) ++ xmlFreeNodeList(cur->children); + if (((cur->type == XML_ELEMENT_NODE) || + (cur->type == XML_XINCLUDE_START) || + (cur->type == XML_XINCLUDE_END)) && +@@ -3727,16 +3720,7 @@ xmlFreeNodeList(xmlNodePtr cur) { + DICT_FREE(cur->name) + xmlFree(cur); + } +- +- if (next != NULL) { +- cur = next; +- } else { +- if ((depth == 0) || (parent == NULL)) +- break; +- depth -= 1; +- cur = parent; +- cur->children = NULL; +- } ++ cur = next; + } + } + diff --git a/base/libxslt/0001-Make-generate-id-deterministic.patch b/base/libxslt/0001-Make-generate-id-deterministic.patch new file mode 100644 index 0000000..3928c7b --- /dev/null +++ b/base/libxslt/0001-Make-generate-id-deterministic.patch @@ -0,0 +1,184 @@ +From a94626df19f62bc7ee5aa8e65dd1995bed1a8092 Mon Sep 17 00:00:00 2001 +From: Daniel Veillard +Date: Sun, 29 Oct 2017 01:04:54 +0200 +Subject: [PATCH 1/2] Make generate-id deterministic + +Origin: upstream, https://bugzilla.gnome.org/attachment.cgi?id=306475 +Bug: https://bugzilla.gnome.org/show_bug.cgi?id=751621 +Bug-Debian: https://bugs.debian.org/823857 +--- + libxslt/functions.c | 91 ++++++++++++++++++++++++++++++++++++++++- + libxslt/functions.h | 7 ++++ + libxslt/transform.c | 8 ++++ + libxslt/xsltInternals.h | 2 + + 4 files changed, 107 insertions(+), 1 deletion(-) + +diff --git a/libxslt/functions.c b/libxslt/functions.c +index b350545a..858a483a 100644 +--- a/libxslt/functions.c ++++ b/libxslt/functions.c +@@ -671,6 +671,63 @@ xsltFormatNumberFunction(xmlXPathParserContextPtr ctxt, int nargs) + xmlXPathFreeObject(decimalObj); + } + ++/** ++ * xsltCleanupIds: ++ * @ctxt: the transformation context ++ * @root: the root of the resulting document ++ * ++ * This clean up ids which may have been saved in Element contents ++ * by xsltGenerateIdFunction() to provide stable IDs on elements. ++ * ++ * Returns the number of items cleaned or -1 in case of error ++ */ ++int ++xsltCleanupIds(xsltTransformContextPtr ctxt, xmlNodePtr root) { ++ xmlNodePtr cur; ++ int count = 0; ++ ++ if ((ctxt == NULL) || (root == NULL)) ++ return(-1); ++ if (root->type != XML_ELEMENT_NODE) ++ return(-1); ++ ++ cur = root; ++ while (cur != NULL) { ++ if (cur->type == XML_ELEMENT_NODE) { ++ if (cur->content != NULL) { ++ cur->content = NULL; ++ count++; ++ } ++ if (cur->children != NULL) { ++ cur = cur->children; ++ continue; ++ } ++ } ++ if (cur->next != NULL) { ++ cur = cur->next; ++ continue; ++ } ++ do { ++ cur = cur->parent; ++ if (cur == NULL) ++ break; ++ if (cur == (xmlNodePtr) root) { ++ cur = NULL; ++ break; ++ } ++ if (cur->next != NULL) { ++ cur = cur->next; ++ break; ++ } ++ } while (cur != NULL); ++ } ++ ++fprintf(stderr, "Attributed %d IDs for element, cleaned up %d\n", ++ ctxt->nextid, count); ++ ++ return(count); ++} ++ + /** + * xsltGenerateIdFunction: + * @ctxt: the XPath Parser context +@@ -722,7 +779,39 @@ xsltGenerateIdFunction(xmlXPathParserContextPtr ctxt, int nargs){ + if (obj) + xmlXPathFreeObject(obj); + +- val = (long)((char *)cur - (char *)&base_address); ++ /* ++ * Try to provide stable ID for generated document: ++ * - usually ID are computed to be placed on elements via attributes ++ * so using the element as the node for the ID ++ * - the cur->content should be a correct placeholder for this, we use ++ * it to hold element node numbers in xmlXPathOrderDocElems to ++ * speed up XPath too ++ * - xsltCleanupIds() clean them up before handing the XSLT output ++ * to the API client. ++ * - other nodes types use the node address method but that should ++ * not end up in resulting document ID ++ * - we can enable this by default without risk of performance issues ++ * only the one pass xsltCleanupIds() is added ++ */ ++ if (cur->type == XML_ELEMENT_NODE) { ++ if (cur->content == NULL) { ++ xsltTransformContextPtr tctxt; ++ ++ tctxt = xsltXPathGetTransformContext(ctxt); ++ if (tctxt == NULL) { ++ val = (long)((char *)cur - (char *)&base_address); ++ } else { ++ tctxt->nextid++; ++ val = tctxt->nextid; ++ cur->content = (void *) (val); ++ } ++ } else { ++ val = (long) cur->content; ++ } ++ } else { ++ val = (long)((char *)cur - (char *)&base_address); ++ } ++ + if (val >= 0) { + snprintf((char *)str, sizeof(str), "idp%ld", val); + } else { +diff --git a/libxslt/functions.h b/libxslt/functions.h +index 5455b7f4..31163613 100644 +--- a/libxslt/functions.h ++++ b/libxslt/functions.h +@@ -63,6 +63,13 @@ XSLTPUBFUN void XSLTCALL + xsltFunctionAvailableFunction (xmlXPathParserContextPtr ctxt, + int nargs); + ++/* ++ * Cleanup for ID generation ++ */ ++XSLTPUBFUN int XSLTCALL ++ xsltCleanupIds (xsltTransformContextPtr ctxt, ++ xmlNodePtr root); ++ + /* + * And the registration + */ +diff --git a/libxslt/transform.c b/libxslt/transform.c +index d1c47932..3d1ee059 100644 +--- a/libxslt/transform.c ++++ b/libxslt/transform.c +@@ -706,6 +706,7 @@ xsltNewTransformContext(xsltStylesheetPtr style, xmlDocPtr doc) { + cur->traceCode = (unsigned long*) &xsltDefaultTrace; + cur->xinclude = xsltGetXIncludeDefault(); + cur->keyInitLevel = 0; ++ cur->nextid = 0; + + return(cur); + +@@ -6140,6 +6141,13 @@ xsltApplyStylesheetInternal(xsltStylesheetPtr style, xmlDocPtr doc, + if (root != NULL) { + const xmlChar *doctype = NULL; + ++ /* ++ * cleanup ids which may have been saved in Elements content ptrs ++ */ ++ if (ctxt->nextid != 0) { ++ xsltCleanupIds(ctxt, root); ++ } ++ + if ((root->ns != NULL) && (root->ns->prefix != NULL)) + doctype = xmlDictQLookup(ctxt->dict, root->ns->prefix, root->name); + if (doctype == NULL) +diff --git a/libxslt/xsltInternals.h b/libxslt/xsltInternals.h +index 14a971aa..a7d71b57 100644 +--- a/libxslt/xsltInternals.h ++++ b/libxslt/xsltInternals.h +@@ -1782,6 +1782,8 @@ struct _xsltTransformContext { + int maxTemplateVars; + unsigned long opLimit; + unsigned long opCount; ++ ++ unsigned long nextid;/* for generating stable ids */ + }; + + /** +-- +2.27.0 + diff --git a/base/libxslt/0002-Fix-manpage.patch b/base/libxslt/0002-Fix-manpage.patch new file mode 100644 index 0000000..fe7bfea --- /dev/null +++ b/base/libxslt/0002-Fix-manpage.patch @@ -0,0 +1,45 @@ +From ea42953d3d75278f4f89009dfeed115200e4d102 Mon Sep 17 00:00:00 2001 +From: "Jan Alexander Steffens (heftig)" +Date: Wed, 10 Jun 2020 17:13:43 +0000 +Subject: [PATCH 2/2] Fix manpage + +Use the right stylesheet for DocBook 4. This fixes the bad whitespace +processing. + +Use the just-built xsltproc to generate the manpage. +--- + doc/Makefile.am | 4 ++-- + doc/xsltproc.xml | 2 +- + 2 files changed, 3 insertions(+), 3 deletions(-) + +diff --git a/doc/Makefile.am b/doc/Makefile.am +index 3d5364ca..6a7b9408 100644 +--- a/doc/Makefile.am ++++ b/doc/Makefile.am +@@ -239,9 +239,9 @@ libxslt-api.xml libxslt-refs.xml EXSLT/libexslt-api.xml \ + ($(XSLTPROC) -o ../libxslt/libxslt.syms $(srcdir)/syms.xsl $(srcdir)/symbols.xml) + + xsltproc.1: $(srcdir)/xsltproc.xml +- -@(if [ -x $(XSLTPROC) ] ; then \ ++ -@(if [ -x $(srcdir)/../xsltproc/xsltproc ] ; then \ + echo "Rebuilding the man pages from the xml" ; \ +- $(XSLTPROC) --nonet $(srcdir)/xsltproc.xml ; fi) ++ $(srcdir)/../xsltproc/xsltproc --nonet $(srcdir)/xsltproc.xml ; fi) + + # Note that in the following, xmllint output is piped to xsltproc + search.php: $(srcdir)/api.xsl $(srcdir)/site.xsl $(srcdir)/search.templ \ +diff --git a/doc/xsltproc.xml b/doc/xsltproc.xml +index 08fc3e97..6ca1b323 100644 +--- a/doc/xsltproc.xml ++++ b/doc/xsltproc.xml +@@ -1,6 +1,6 @@ + + ++ href="http://cdn.docbook.org/release/xsl-nons/current/manpages/docbook.xsl"?> + +Date: Tue, 12 Sep 2017 07:18:38 +0200 +Subject: [PATCH] Disable dynamic lib tests for musl's dlclose() is noop + +--- + unittests/Support/CMakeLists.txt | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/unittests/Support/CMakeLists.txt b/unittests/Support/CMakeLists.txt +index 641163e..4f508d9 100644 +--- a/unittests/Support/CMakeLists.txt ++++ b/unittests/Support/CMakeLists.txt +@@ -75,4 +75,4 @@ set_source_files_properties(AlignOfTest.cpp PROPERTIES COMPILE_FLAGS -w) + # ManagedStatic.cpp uses . + target_link_libraries(SupportTests LLVMTestingSupport ${LLVM_PTHREAD_LIB}) + +-add_subdirectory(DynamicLibrary) ++# add_subdirectory(DynamicLibrary) +-- +2.14.1 + diff --git a/base/llvm/fix-LLVMConfig-cmake-install-prefix.patch b/base/llvm/fix-LLVMConfig-cmake-install-prefix.patch new file mode 100644 index 0000000..b7e3dbe --- /dev/null +++ b/base/llvm/fix-LLVMConfig-cmake-install-prefix.patch @@ -0,0 +1,24 @@ +Fix LLVMConfig.cmake being generated to use correct LLVM_INSTALL_PREFIX +(e.g. /usr/lib/llvm5). + +This is needed e.g. for building lldb. + +--- a/cmake/modules/CMakeLists.txt ++++ b/cmake/modules/CMakeLists.txt +@@ -75,15 +75,7 @@ + + # Generate LLVMConfig.cmake for the install tree. + set(LLVM_CONFIG_CODE " +-# Compute the installation prefix from this LLVMConfig.cmake file location. +-get_filename_component(LLVM_INSTALL_PREFIX \"\${CMAKE_CURRENT_LIST_FILE}\" PATH)") +-# Construct the proper number of get_filename_component(... PATH) +-# calls to compute the installation prefix. +-string(REGEX REPLACE "/" ";" _count "${LLVM_INSTALL_PACKAGE_DIR}") +-foreach(p ${_count}) +- set(LLVM_CONFIG_CODE "${LLVM_CONFIG_CODE} +-get_filename_component(LLVM_INSTALL_PREFIX \"\${LLVM_INSTALL_PREFIX}\" PATH)") +-endforeach(p) ++set(LLVM_INSTALL_PREFIX \"${CMAKE_INSTALL_PREFIX}\")") + set(LLVM_CONFIG_INCLUDE_DIRS "\${LLVM_INSTALL_PREFIX}/include") + set(LLVM_CONFIG_LIBRARY_DIRS "\${LLVM_INSTALL_PREFIX}/lib\${LLVM_LIBDIR_SUFFIX}") + set(LLVM_CONFIG_CMAKE_DIR "\${LLVM_INSTALL_PREFIX}/${LLVM_INSTALL_PACKAGE_DIR}") diff --git a/base/llvm/fix-memory-mf_exec-on-aarch64.patch b/base/llvm/fix-memory-mf_exec-on-aarch64.patch new file mode 100644 index 0000000..a64a317 --- /dev/null +++ b/base/llvm/fix-memory-mf_exec-on-aarch64.patch @@ -0,0 +1,25 @@ +Fix failures in AllocationTests/MappedMemoryTest.* on aarch64: + + Failing Tests (8): + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.AllocAndRelease/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.DuplicateNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.EnabledWrite/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.MultipleAllocAndRelease/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.SuccessiveNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.UnalignedNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.ZeroNear/3 + LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.ZeroSizeNear/3 + +Upstream-Issue: https://bugs.llvm.org/show_bug.cgi?id=14278#c10 + +--- a/lib/Support/Unix/Memory.inc ++++ b/lib/Support/Unix/Memory.inc +@@ -59,7 +59,7 @@ + return PROT_READ | PROT_WRITE | PROT_EXEC; + case llvm::sys::Memory::MF_EXEC: + #if (defined(__FreeBSD__) || defined(__POWERPC__) || defined (__ppc__) || \ +- defined(_POWER) || defined(_ARCH_PPC)) ++ defined(_POWER) || defined(_ARCH_PPC) || (defined(__linux__) && defined(__aarch64__))) + // On PowerPC, having an executable page that has no read permission + // can have unintended consequences. The function InvalidateInstruction- + // Cache uses instructions dcbf and icbi, both of which are treated by diff --git a/base/llvm/llvm.SMBuild b/base/llvm/llvm.SMBuild new file mode 100755 index 0000000..8fbe4e6 --- /dev/null +++ b/base/llvm/llvm.SMBuild @@ -0,0 +1,70 @@ +APP=llvm +VERSION=10.0.1 +BUILD=2sml +HOMEPAGE='http://llvm.org/' +DESC="LLVM compiler toolkit" +REQUIRES="libffi libxml2 perl" + +build() { + mkandenterbuilddir + rm -rf $APP-"$VERSION".src + + tar xf $SRCDIR/$APP-"$VERSION".src.tar.?z* + cd $APP-"$VERSION".src + fixbuilddirpermissions + + patch -p1 < $SRCDIR/0001-Disable-dynamic-lib-tests-for-musl-s-dlclose-is-noop.patch + patch -p1 < $SRCDIR/fix-LLVMConfig-cmake-install-prefix.patch + patch -p1 < $SRCDIR/fix-memory-mf_exec-on-aarch64.patch + patch -p1 < $SRCDIR/python3-test.patch + + # We don't need our optimisations for small builds + unset CFLAGS CXXFLAGS + mkdir -p smbuild && cd smbuild + + # Set build targets + if [ "$ARCH" = "x86_64" ] ; then + BUILDTARGET='X86;AMDGPU;BPF' + elif [ "$ARCH" = "aarch64" ] ; then + BUILDTARGET="AArch64;ARM;BPF" + fi + + cmake .. -Wno-dev \ + -DCMAKE_BUILD_TYPE=MinSizeRel \ + -DCMAKE_INSTALL_PREFIX="/" \ + -DLLVM_BUILD_DOCS=OFF \ + -DLLVM_BUILD_EXAMPLES=OFF \ + -DLLVM_BUILD_EXTERNAL_COMPILER_RT=ON \ + -DLLVM_BUILD_LLVM_DYLIB=ON \ + -DLLVM_BUILD_TESTS=ON \ + -DLLVM_ENABLE_CXX1Y=ON \ + -DLLVM_ENABLE_FFI=ON \ + -DLLVM_ENABLE_LIBCXX=OFF \ + -DLLVM_ENABLE_PIC=ON \ + -DLLVM_ENABLE_RTTI=ON \ + -DLLVM_ENABLE_SPHINX=OFF \ + -DLLVM_ENABLE_TERMINFO=ON \ + -DLLVM_ENABLE_ZLIB=ON \ + -DLLVM_INCLUDE_EXAMPLES=OFF \ + -DLLVM_LINK_LLVM_DYLIB=ON \ + -DLLVM_APPEND_VC_REV=OFF \ + -DLLVM_INSTALL_UTILS=ON \ + -DLLVM_TARGETS_TO_BUILD="$BUILDTARGET" + + make llvm-tblgen + make + python3 ../utils/lit/setup.py build + make install DESTDIR=$PKG + + cp ../LICENSE.TXT $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +cf34d037c1684d09e7e38d5fc131714eac93c78353d6186b2f806a8fb22dcae0f4748ce22d6faf178c95cfcf20bdc3fa7c5238518a154b3112781f5ab70edaa4 llvm-10.0.1.src.tar.xz +695502bd3b5454c2f5630c59a8cf5f8aeb0deac16a76a8a4df34849e1e35c12ed4234572a320fe4c7e96f974f572f429eb816c5aa3dcfb17057f550eac596495 0001-Disable-dynamic-lib-tests-for-musl-s-dlclose-is-noop.patch +7d4825d16107e56a14b7b05be847f03d75e2e05952bea0742a1233b5b0441c9934d8058e612abb6471272884372d9bfd3348355fbd3c19cba82a554003cc3eec fix-LLVMConfig-cmake-install-prefix.patch +64b9ecb246cc94ce7f617b3699b3306de0872a1a9b0ade88563330aa6f9a60742bb1d73f95743d0f033ea8b1535e2e612250c8f50bddf4419741ca18f40eca1d fix-memory-mf_exec-on-aarch64.patch +53cc0d13dd871e9b775bb4e7567de4f9a97d91b8246cd7ce74607fd88d6e3e2ab9455f5b4195bc7f9dbdedbc77d659d43e98ec0b7cd78cd395aaea6919510287 python3-test.patch +" diff --git a/base/llvm/python3-test.patch b/base/llvm/python3-test.patch new file mode 100644 index 0000000..7463133 --- /dev/null +++ b/base/llvm/python3-test.patch @@ -0,0 +1,8 @@ +--- llvm-7.0.1.src/test/BugPoint/compile-custom.ll.py.old 2014-03-13 00:10:37.000000000 +0000 ++++ llvm-7.0.1.src/test/BugPoint/compile-custom.ll.py 2019-03-10 03:48:48.600000000 +0000 +@@ -1,4 +1,4 @@ +-#!/usr/bin/env python ++#!/usr/bin/env python3 + + import sys + diff --git a/base/lm-sensors/100-musl-compat.patch b/base/lm-sensors/100-musl-compat.patch new file mode 100644 index 0000000..1cd82ab --- /dev/null +++ b/base/lm-sensors/100-musl-compat.patch @@ -0,0 +1,44 @@ +--- a/prog/dump/isadump.c ++++ b/prog/dump/isadump.c +@@ -38,7 +38,7 @@ + + + /* To keep glibc2 happy */ +-#if defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ >= 0 ++#if !defined(__UCLIBC__) + #include + #else + #include +--- a/prog/dump/isaset.c ++++ b/prog/dump/isaset.c +@@ -34,7 +34,7 @@ + + + /* To keep glibc2 happy */ +-#if defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ >= 0 ++#if !defined(__UCLIBC__) + #include + #else + #include +--- a/prog/dump/superio.c ++++ b/prog/dump/superio.c +@@ -21,7 +21,7 @@ + + #include + +-#if defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ >= 0 ++#if !defined(__UCLIBC__) + #include + #else + #include +--- a/prog/dump/util.c ++++ b/prog/dump/util.c +@@ -12,7 +12,7 @@ + #include "util.h" + + /* To keep glibc2 happy */ +-#if defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ >= 0 ++#if !defined(__UCLIBC__) + #include + #else + #include diff --git a/base/lm-sensors/lm-sensors.SMBuild b/base/lm-sensors/lm-sensors.SMBuild new file mode 100755 index 0000000..da8925d --- /dev/null +++ b/base/lm-sensors/lm-sensors.SMBuild @@ -0,0 +1,32 @@ +APP=lm-sensors +VERSION=3.3.5 +BUILD=1sml +HOMEPAGE='https://github.com/lm-sensors/lm-sensors' +DESC="hardware sensors, voltages and fans monitoring package" +REQUIRES="perl" + +build() { + compileonlyfor x86_64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/100-musl-compat.patch + mkdir -p $PKG/bin $PKG/usr + + make PREFIX="" SBINDIR="$PKG/bin" + make install PREFIX="" DESTDIR="$PKG" SBINDIR="/bin" MANDIR="/share/man" + rmdir $PKG/usr + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +1df470aa0f389d08d5e8c437a2c9b3362381f2673ded46a5e5e861982c2dae7e0ca039d595793465ef98886e02143233808d1bfc7046f7f5e41274b90d524569 lm-sensors-3.3.5.tar.lz +d587a556f9abdd8570f9848b0bfd081ff2bddea1c31cd63b77a36d5d33cdd8c70b967df6a2d20f8c323573dc49c36d9c571af0eeaf007c3eee4cdfa78787c151 100-musl-compat.patch +" diff --git a/base/logrotate/doinst.sh b/base/logrotate/doinst.sh new file mode 100644 index 0000000..ea006ff --- /dev/null +++ b/base/logrotate/doinst.sh @@ -0,0 +1,13 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/logrotate.conf.new + diff --git a/base/logrotate/logrotate.SMBuild b/base/logrotate/logrotate.SMBuild new file mode 100755 index 0000000..8f5b6f0 --- /dev/null +++ b/base/logrotate/logrotate.SMBuild @@ -0,0 +1,34 @@ +APP=logrotate +VERSION=3.8.9 +BUILD=1sml +HOMEPAGE='https://github.com/logrotate/logrotate' +DOWNLOAD='https://github.com/logrotate/logrotate/archive/refs/tags/r3-8-9.tar.gz' +DESC="system log rotation tool, normally run as a daily cron job" +REQUIRES="popt" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make clean + make + + install -Dm 755 $APP $PKG/bin/$APP + install -Dm 644 $APP.8 $PKG/share/man/man8/$APP.8 + + mkdir -p $PKG/etc/logrotate.d $PKG/var/spool/cron/crontabs + cp $SRCDIR/logrotate.conf.new $PKG/etc/ + install -Dm 600 $SRCDIR/$APP.cron $PKG/var/spool/cron/crontabs/root + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +1bda961042f02a84b38fcd3aef4928daf04cc4cff15b649d0335a15f79e64d18d62fd5f8bb0186830008b9515904c6999b50d22a3646cc85ea45aa0cd4632f5e logrotate-3.8.9.tar.lz +" diff --git a/base/logrotate/logrotate.conf.new b/base/logrotate/logrotate.conf.new new file mode 100644 index 0000000..129d5cd --- /dev/null +++ b/base/logrotate/logrotate.conf.new @@ -0,0 +1,28 @@ +# /etc/logrotate.conf +# +# logrotate is designed to ease administration of systems that generate large +# numbers of log files. It allows automatic rotation, compression, removal, and +# mailing of log files. Each log file may be handled daily, weekly, monthly, or +# when it grows too large. +# +# logrotate is normally run daily from root's crontab. +# +# For more details, see "man logrotate". + +# rotate log files weekly: +weekly + +# keep 4 weeks worth of backlogs: +rotate 4 + +# create new (empty) log files after rotating old ones: +create + +# uncomment if you want to use the date as a suffix of the rotated file +#dateext + +# uncomment this if you want your log files compressed: +compress + +# some packages install log rotation information in this directory: +include /etc/logrotate.d diff --git a/base/logrotate/logrotate.cron b/base/logrotate/logrotate.cron new file mode 100644 index 0000000..bc04c21 --- /dev/null +++ b/base/logrotate/logrotate.cron @@ -0,0 +1 @@ +0 0 * * * /bin/logrotate /etc/logrotate.conf > /dev/null 2>&1 diff --git a/base/lsof/lsof.SMBuild b/base/lsof/lsof.SMBuild new file mode 100755 index 0000000..284b729 --- /dev/null +++ b/base/lsof/lsof.SMBuild @@ -0,0 +1,30 @@ +APP=lsof +VERSION=4.93.2 +BUILD=1sml +HOMEPAGE='https://github.com/lsof-org/lsof' +DOWNLOAD='https://github.com/lsof-org/lsof/archive/refs/tags/4.93.2.tar.gz' +DESC="list info about files open by processes" +REQUIRES="libtirpc" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./Configure -n linux + + make CC="$CC" LDFLAGS="-static" + cp 00README $PKGDOCS/LICENSE + + install -Dm 755 lsof $PKG/bin/lsof + install -Dm 644 Lsof.8 $PKG/share/man/man8/lsof.8 + + mkfinalpkg +} + +SHA512SUMS=" +69072f26ea4f2a7b0d56785ad364281cf71339f094d09c2b9b66469e60e8ee0ce3e08ea17a1d6b100308722877e568b41b9b05b7409f04a90e119f3334313fdf lsof-4.93.2.tar.lz +" diff --git a/base/lua/lua.SMBuild b/base/lua/lua.SMBuild new file mode 100755 index 0000000..da56131 --- /dev/null +++ b/base/lua/lua.SMBuild @@ -0,0 +1,47 @@ +APP=lua +VERSION=5.1.5 +BUILD=1sml +HOMEPAGE='https://www.lua.org/home.html' +DOWNLOAD='https://www.lua.org/ftp/lua-5.1.5.tar.gz' +DESC="a powerful, fast, light-weight, embeddable scripting language" +REQUIRES="readline" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i "s@#define LUA_ROOT\t"'"/usr/local/"@#define LUA_ROOT "/"@' src/luaconf.h + sed -i 's@INSTALL_TOP= /usr/local@INSTALL_TOP='"$dest"'@' Makefile + + make linux CFLAGS="$CFLAGS" + + make linux install \ + CFLAGS="$CFLAGS" \ + INSTALL_TOP="$PKG" \ + INSTALL_MAN="$PKG/share/man/man1" + + # Build the shared library + mkdir -p shared && cd shared + ar -x $PKG/lib/liblua.a + gcc -lreadline -lhistory -lncurses -lm -ldl -shared *.o -o liblua.so.$VERSION + cp -a liblua.so.$VERSION $PKG/lib/ + ( cd $PKG/lib + ln -s liblua.so.$VERSION liblua.so.5.1 + ln -s liblua.so.$VERSION liblua.so.5 + ln -s liblua.so.$VERSION liblua.so + ) + cd .. + + cp COPYRIGHT $PKGDOCS/ + install -Dm 644 etc/lua.pc $PKG/lib/pkgconfig/lua.pc + + mkfinalpkg +} + +SHA512SUMS=" +0142fefcbd13afcd9b201403592aa60620011cc8e8559d4d2db2f92739d18186860989f48caa45830ff4f99bfc7483287fd3ff3a16d4dec928e2767ce4d542a9 lua-5.1.5.tar.gz +" diff --git a/base/lua53/CVE-2019-6706-use-after-free-lua_upvaluejoin.patch b/base/lua53/CVE-2019-6706-use-after-free-lua_upvaluejoin.patch new file mode 100644 index 0000000..ea26696 --- /dev/null +++ b/base/lua53/CVE-2019-6706-use-after-free-lua_upvaluejoin.patch @@ -0,0 +1,24 @@ +http://lua.2524044.n2.nabble.com/CVE-2019-6706-use-after-free-in-lua-upvaluejoin-function-tc7685575.html + +--- a/src/lapi.c ++++ b/src/lapi.c +@@ -1285,14 +1285,14 @@ LUA_API void *lua_upvalueid (lua_State * + + LUA_API void lua_upvaluejoin (lua_State *L, int fidx1, int n1, + int fidx2, int n2) { +- LClosure *f1; +- UpVal **up1 = getupvalref(L, fidx1, n1, &f1); ++ UpVal **up1 = getupvalref(L, fidx1, n1, NULL); /* the last parameter not needed */ + UpVal **up2 = getupvalref(L, fidx2, n2, NULL); ++ if (*up1 == *up2) return; /* Already joined */ ++ (*up2)->refcount++; ++ if (upisopen(*up2)) (*up2)->u.open.touched = 1; ++ luaC_upvalbarrier(L, *up2); + luaC_upvdeccount(L, *up1); + *up1 = *up2; +- (*up1)->refcount++; +- if (upisopen(*up1)) (*up1)->u.open.touched = 1; +- luaC_upvalbarrier(L, *up1); + } + + diff --git a/base/lua53/lua.pc.in b/base/lua53/lua.pc.in new file mode 100644 index 0000000..96dc0f2 --- /dev/null +++ b/base/lua53/lua.pc.in @@ -0,0 +1,31 @@ +# lua.pc -- pkg-config data for Lua + +# vars from install Makefile + +# grep '^V=' ../Makefile +V= 5.1 +# grep '^R=' ../Makefile +R= 5.1.5 + +# grep '^INSTALL_.*=' ../Makefile | sed 's/INSTALL_TOP/prefix/' +prefix= /usr/local +INSTALL_BIN= ${prefix}/bin +INSTALL_INC= ${prefix}/include +INSTALL_LIB= ${prefix}/lib +INSTALL_MAN= ${prefix}/share/man/man1 +INSTALL_LMOD= ${prefix}/share/lua/${V} +INSTALL_CMOD= ${prefix}/lib/lua/${V} + +# canonical vars +exec_prefix=${prefix} +libdir=${exec_prefix}/lib +includedir=${prefix}/include + +Name: Lua +Description: An Extensible Extension Language +Version: ${R} +Requires: +Libs: -L${libdir} -llua${V} -lm +Cflags: -I${includedir} + +# (end of lua.pc) diff --git a/base/lua53/lua53.SMBuild b/base/lua53/lua53.SMBuild new file mode 100755 index 0000000..f06572e --- /dev/null +++ b/base/lua53/lua53.SMBuild @@ -0,0 +1,76 @@ +APP=lua53 +VERSION=5.3.5 +BUILD=1sml +HOMEPAGE='https://www.lua.org/home.html' +DOWNLOAD='https://www.lua.org/ftp/lua-5.3.5.tar.gz' +DESC="powerful, fast, light-weight, embeddable scripting language" +REQUIRES="readline" + +build() { + mkandenterbuilddir + rm -rf lua-$VERSION + + tar xf $SRCDIR/lua-$VERSION.tar.?z* + cd lua-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/CVE-2019-6706-use-after-free-lua_upvaluejoin.patch + + eval $(sed -ne '/^\(V\|R\)= /s, ,,p' Makefile) + + sed -i \ + -e '/^INSTALL_TOP= /s,\(/\).*,\$(DESTDIR)\1,' \ + -e '/^INSTALL_INC= /s,include,&/lua\$V,' \ + -e '/^TO_BIN= /s,luac\?,&\$V,g' \ + -e '/^TO_LIB= /s,liblua,&\$V,' \ + Makefile + + sed -i \ + -e '/^CFLAGS= /s,-O2,'"$CFLAGS"',' \ + -e '/-DLUA_USE_LINUX.*-Wl,-E -ldl -lreadline/s|-lreadline|& -lcurses|' \ + -e '/^LUA_A=/s,liblua,&'"$V"',' \ + -e '/^LUA_T=/s,lua,&'"$V"',' \ + -e '/^LUAC_T=/s,luac,&'"$V"',' \ + src/Makefile + + make linux + make install INSTALL_MAN="$PKG/share/man/man1" DESTDIR=$PKG + + # Now let's build the shared library + mkdir -p shared && cd shared + ar -x $PKG/lib/liblua$V.a + gcc -ldl -lreadline -lncurses -lterminfo -lm -shared *.o -o liblua$V.so.$R + cp -a liblua$V.so.$R $PKG/lib + ( cd $PKG/lib + ln -s liblua$V.so.$R liblua$V.so.$V + ln -s liblua$V.so.$R liblua$V.so.${V%??} + ln -s liblua$V.so.$R liblua$V.so + ) + cd - >/dev/null + + mkdir -p $PKG/lib/pkgconfig + cd $PKG/lib/pkgconfig + sed \ + -e '/^V= /s, .*, '"$V"',' \ + -e '/^R= /s, .*, '"$R"',' \ + -e '/^prefix= /s,\(/\).*,\1,' \ + -e '/^INSTALL_INC= /s,include,&/lua\${V},' \ + -e '/^includedir=/s,/include,&/lua\${V},' \ + $SRCDIR/lua.pc.in > lua$V.pc + ln -s lua$V.pc lua-$V.pc + mkfinalpkg + ln -s lua$V.pc lua${V%.?}${V#?.}.pc + cd - >/dev/null + + cd $PKG/share/man/man1 + mv lua.1 lua$V.1 + mv luac.1 luac$V.1 + cd - >/dev/null + + mkfinalpkg +} + +SHA512SUMS=" +4f9516acc4659dfd0a9e911bfa00c0788f0ad9348e5724fe8fb17aac59e9c0060a64378f82be86f8534e49c6c013e7488ad17321bafcc787831d3d67406bd0f4 lua-5.3.5.tar.gz +fde7f5f5a184cd393665c7c8c7ba3c728e1413df5f63dbe60855af13ddd313d9300720298534f4312638ddf59fa678a38f708bce622dd7a2298b4ed87c068ae7 CVE-2019-6706-use-after-free-lua_upvaluejoin.patch +" diff --git a/base/lua53/lua53.pc b/base/lua53/lua53.pc new file mode 120000 index 0000000..c9c0b94 --- /dev/null +++ b/base/lua53/lua53.pc @@ -0,0 +1 @@ +lua5.3.pc \ No newline at end of file diff --git a/base/lvm/create-dm-run-dir.diff b/base/lvm/create-dm-run-dir.diff new file mode 100644 index 0000000..a0e0a54 --- /dev/null +++ b/base/lvm/create-dm-run-dir.diff @@ -0,0 +1,13 @@ +diff -Nur LVM2.2.02.114.orig/daemons/dmeventd/dmeventd.c LVM2.2.02.114/daemons/dmeventd/dmeventd.c +--- LVM2.2.02.114.orig/daemons/dmeventd/dmeventd.c 2014-11-28 17:07:42.000000000 -0600 ++++ LVM2.2.02.114/daemons/dmeventd/dmeventd.c 2014-12-08 22:46:58.702066654 -0600 +@@ -2176,6 +2176,9 @@ + if (_restart) + restart(); + ++ /* Create rundir */ ++ mkdir(DEFAULT_DM_RUN_DIR, 0700); ++ + #ifdef __linux__ + _systemd_activation = _systemd_handover(&fifos); + #endif diff --git a/base/lvm/doinst.sh b/base/lvm/doinst.sh new file mode 100644 index 0000000..261294a --- /dev/null +++ b/base/lvm/doinst.sh @@ -0,0 +1,13 @@ +#!/bin/sh +config() { + NEW="$1" + OLD="`dirname $NEW`/`basename $NEW .new`" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/lvm/lvm.conf.new diff --git a/base/lvm/fix-stdio-usage.patch b/base/lvm/fix-stdio-usage.patch new file mode 100644 index 0000000..39ba2e1 --- /dev/null +++ b/base/lvm/fix-stdio-usage.patch @@ -0,0 +1,49 @@ +--- ./tools/lvmcmdline.c ++++ ./tools/lvmcmdline.c +@@ -1252,7 +1252,7 @@ + int err = is_valid_fd(STDERR_FILENO); + + if (!is_valid_fd(STDIN_FILENO) && +- !(stdin = fopen(_PATH_DEVNULL, "r"))) { ++ !freopen(_PATH_DEVNULL, "r", stdin)) { + if (err) + perror("stdin stream open"); + else +@@ -1262,7 +1262,7 @@ + } + + if (!is_valid_fd(STDOUT_FILENO) && +- !(stdout = fopen(_PATH_DEVNULL, "w"))) { ++ !freopen(_PATH_DEVNULL, "w", stdout)) { + if (err) + perror("stdout stream open"); + /* else no stdout */ +@@ -1270,7 +1270,7 @@ + } + + if (!is_valid_fd(STDERR_FILENO) && +- !(stderr = fopen(_PATH_DEVNULL, "w"))) { ++ !freopen(_PATH_DEVNULL, "w", stderr)) { + printf("stderr stream open: %s\n", + strerror(errno)); + return 0; +--- ./lib/commands/toolcontext.c.orig ++++ ./lib/commands/toolcontext.c +@@ -1860,7 +1860,7 @@ + /* FIXME Make this configurable? */ + reset_lvm_errno(1); + +-#ifndef VALGRIND_POOL ++#if !defined(VALGRIND_POOL) && defined(__GLIBC__) + /* Set in/out stream buffering before glibc */ + if (set_buffering) { + /* Allocate 2 buffers */ +@@ -2241,7 +2241,7 @@ + if (cmd->libmem) + dm_pool_destroy(cmd->libmem); + +-#ifndef VALGRIND_POOL ++#if !defined(VALGRIND_POOL) && defined(__GLIBC__) + if (cmd->linebuffer) { + /* Reset stream buffering to defaults */ + if (is_valid_fd(STDIN_FILENO) && diff --git a/base/lvm/lvm.SMBuild b/base/lvm/lvm.SMBuild new file mode 100755 index 0000000..d4a9757 --- /dev/null +++ b/base/lvm/lvm.SMBuild @@ -0,0 +1,53 @@ +APP=lvm +VERSION=2.2.02.168 +BUILD=1sml +HOMEPAGE='http://www.sourceware.org/lvm2/' +DOWNLOAD='ftp://sources.redhat.com/pub/lvm2/releases/LVM2.2.02.168.tgz' +DESC="Adds an additional layer between physical peripherals and low-level I/O to get logical view of disks" +REQUIRES="eudev util-linux" + +build() { + mkandenterbuilddir + rm -rf LVM-$VERSION + + tar xf $SRCDIR/LVM"$VERSION".tar.?z* + cd LVM"$VERSION" + fixbuilddirpermissions + + patch -p1 < $SRCDIR/fix-stdio-usage.patch + patch -p1 < $SRCDIR/mallinfo.patch + patch -p1 < $SRCDIR/lvm2-mlockall-config.patch + patch -p1 < $SRCDIR/lvm2-libdir-config.patch + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin \ + --disable-readline \ + --enable-dmeventd \ + --enable-cmdlib \ + --disable-nls \ + --enable-pkgconfig \ + --enable-applib \ + --with-thin=internal \ + --enable-udev_rules \ + $HOSTDIST + + make + make install DESTDIR=$PKG + + mv $PKG/etc/lvm/lvm.conf $PKG/etc/lvm/lvm.conf.new + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +1bd5b78f840dd53065be08a6638e05330d4de62ede415acb7a2bccc91659f154e830791b1b7b7ac2ba30588e2a295d03782b0444cb4a3cfd0ddc0a858bbef266 LVM2.2.02.168.tar.lz +6ea4efad03f8632f2883f33f9d9f8ca295f7d8d2aa1bfbfa7738e7d711727a511758848dde5776b222bd74e6fb60bed8b56a3cd2f74ca448b8d86f50470a42b9 fix-stdio-usage.patch +33004594a5cce7af1e493a2a66ce8ad2f864dde3b2ec0960d0fda9df9b7bcf65d9455f9eccf7860f48726c48f14111b843b0a0c9bd395ef2952b41aaab8092b2 lvm2-libdir-config.patch +d190c40a137b006d7b63298069c93ff08d2804b990e85d44739cd7c48beec9a569903b98f0d940895fc7365723ba886acd7ef0e08f1f65a1a391d1c448ce080e lvm2-mlockall-config.patch +9272ec8c5184ef5dc776ead8f74132e072b7563b5119a3a38b712f00d92a1e3878c9b3a54eb2b01dcba038110c686b39d4c17ecd0eb258537e9217d7ed03c408 mallinfo.patch +8f14c75dd07cfd01e4ec0ce29a77b891257ce39b0a536b493b08bc85522aa7796cb1eb9a84c9c3b6ffa437b91a0bd45be94ab27f3b2c22d37e992a0433d02593 create-dm-run-dir.diff +" diff --git a/base/lvm/lvm2-libdir-config.patch b/base/lvm/lvm2-libdir-config.patch new file mode 100644 index 0000000..6e3b958 --- /dev/null +++ b/base/lvm/lvm2-libdir-config.patch @@ -0,0 +1,10 @@ +--- ./conf/example.conf.in.orig ++++ ./conf/example.conf.in +@@ -694,6 +694,7 @@ + # Configuration option global/library_dir. + # Search this directory first for shared libraries. + # This configuration option does not have a default value defined. ++ library_dir="/lib/device-mapper" + + # Configuration option global/locking_library. + # The external locking library to use for locking_type 2. diff --git a/base/lvm/lvm2-mlockall-config.patch b/base/lvm/lvm2-mlockall-config.patch new file mode 100644 index 0000000..1daadef --- /dev/null +++ b/base/lvm/lvm2-mlockall-config.patch @@ -0,0 +1,24 @@ +--- ./conf/example.conf.in.orig ++++ ./conf/example.conf.in +@@ -1352,7 +1352,7 @@ + # Use the old behavior of mlockall to pin all memory. + # Prior to version 2.02.62, LVM used mlockall() to pin the whole + # process's memory while activating devices. +- use_mlockall = 0 ++ use_mlockall = 1 + + # Configuration option activation/monitoring. + # Monitor LVs that are activated. +diff --git a/lib/config/defaults.h b/lib/config/defaults.h +index 8ab1fde..57b2443 100644 +--- a/lib/config/defaults.h ++++ b/lib/config/defaults.h +@@ -53,7 +53,7 @@ + #define DEFAULT_WAIT_FOR_LOCKS 1 + #define DEFAULT_LVMLOCKD_LOCK_RETRIES 3 + #define DEFAULT_PRIORITISE_WRITE_LOCKS 1 +-#define DEFAULT_USE_MLOCKALL 0 ++#define DEFAULT_USE_MLOCKALL 1 + #define DEFAULT_METADATA_READ_ONLY 0 + #define DEFAULT_LVDISPLAY_SHOWS_FULL_DEVICE_PATH 0 + diff --git a/base/lvm/mallinfo.patch b/base/lvm/mallinfo.patch new file mode 100644 index 0000000..471a6b2 --- /dev/null +++ b/base/lvm/mallinfo.patch @@ -0,0 +1,11 @@ +--- ./lib/mm/memlock.c.orig 2015-03-09 11:18:41.560028850 -0100 ++++ ./lib/mm/memlock.c 2015-03-09 11:19:54.504373309 -0100 +@@ -137,7 +137,7 @@ + + static void _allocate_memory(void) + { +-#ifndef VALGRIND_POOL ++#if !defined(VALGRIND_POOL) && defined(__GLIBC__) + void *stack_mem; + struct rlimit limit; + int i, area = 0, missing = _size_malloc_tmp, max_areas = 32, hblks; diff --git a/base/lz4/lz4.SMBuild b/base/lz4/lz4.SMBuild new file mode 100755 index 0000000..ec4d3e9 --- /dev/null +++ b/base/lz4/lz4.SMBuild @@ -0,0 +1,31 @@ +APP=lz4 +VERSION=1.9.2 +BUILD=1sml +HOMEPAGE='https://github.com/lz4/lz4' +DOWNLOAD='https://github.com/lz4/lz4/archive/refs/tags/v1.9.2.tar.gz' +DESC="lossless compression algorithm" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make -j1 \ + CFLAGS="$CFLAGS" \ + PREFIX="" \ + MANDIR="/share/man" \ + BUILD_STATIC=no \ + DESTDIR=$PKG default install + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ae714c61ec8e33ed91359b63f2896cfa102d66b730dce112b74696ec5850e59d88bd5527173e01e354a70fbe8f036557a47c767ee0766bc5f9c257978116c3c1 lz4-1.9.2.tar.gz +" diff --git a/base/lzip/lzip.SMBuild b/base/lzip/lzip.SMBuild new file mode 100755 index 0000000..a85533b --- /dev/null +++ b/base/lzip/lzip.SMBuild @@ -0,0 +1,30 @@ +APP=lzip +VERSION=1.20 +BUILD=1sml +HOMEPAGE='https://www.nongnu.org/lzip/lzip.html' +DOWNLOAD='http://download.savannah.gnu.org/releases/lzip/lzip-1.20.tar.gz' +DESC="drop-in replacement for gzip and bzip with emphasis on data recovery" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make CXXFLAGS="$CXXFLAGS -static" + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0349b4c6c0b41e601b7ee381c3254d741397beb3ef9354c08162f346f131f4f48f6613ee0a610cdc6d827530df634f884ecfeee35215b10045a40fee76f8e938 lzip-1.20.tar.gz +" diff --git a/base/lzlib/lzlib.SMBuild b/base/lzlib/lzlib.SMBuild new file mode 100755 index 0000000..5f57b4e --- /dev/null +++ b/base/lzlib/lzlib.SMBuild @@ -0,0 +1,31 @@ +APP=lzlib +VERSION=1.11 +BUILD=1sml +HOMEPAGE='http://www.nongnu.org/lzip/lzlib.html' +DOWNLOAD='http://download.savannah.gnu.org/releases/lzip/lzlib/lzlib-1.11.tar.lz' +DESC="lzip compression and decompression library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2628bb5bfceb8124020cae57f4aecba2f83cbfb5be32acb4f66742e2460e7545be72696f81646fd3e0b7a509faa9d183b7237b7569c2f023ed0488b24a209ae7 lzlib-1.11.tar.lz +" diff --git a/base/lzo/lzo.SMBuild b/base/lzo/lzo.SMBuild new file mode 100755 index 0000000..7d31a69 --- /dev/null +++ b/base/lzo/lzo.SMBuild @@ -0,0 +1,32 @@ +APP=lzo +VERSION=2.10 +BUILD=1sml +HOMEPAGE='http://www.oberhumer.com/opensource/lzo/' +DOWNLOAD='http://www.oberhumer.com/opensource/lzo/download/lzo-2.10.tar.gz' +DESC="portable lossless data compression library written in ANSI C" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-shared=yes \ + --enable-static=no + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +306d6e076d8571b117f4d833aca303af0fafd5c8a798750bbec95eb6c10479ede2a013e6b7519835e2a036d273e00533dde0109052567e5fa809fbd58a2a3ec2 lzo-2.10.tar.lz +" diff --git a/base/m4/disable-mbrtowc-test.patch b/base/m4/disable-mbrtowc-test.patch new file mode 100644 index 0000000..cc2be24 --- /dev/null +++ b/base/m4/disable-mbrtowc-test.patch @@ -0,0 +1,10 @@ +--- m4-1.4.18/tests/test-mbrtowc5.sh.old 2016-12-31 13:54:43.000000000 +0000 ++++ m4-1.4.18/tests/test-mbrtowc5.sh 2017-07-30 17:29:50.879924130 +0000 +@@ -1,6 +1,2 @@ + #!/bin/sh +-# Test whether the POSIX locale has encoding errors. +-LC_ALL=C \ +-./test-mbrtowc${EXEEXT} 5 || exit +-LC_ALL=POSIX \ +-./test-mbrtowc${EXEEXT} 5 ++exit 77 diff --git a/base/m4/localename-test-fix.patch b/base/m4/localename-test-fix.patch new file mode 100644 index 0000000..04584ab --- /dev/null +++ b/base/m4/localename-test-fix.patch @@ -0,0 +1,34 @@ +--- m4-1.4.18/tests/localename.c.old 2016-12-31 13:54:43.000000000 +0000 ++++ m4-1.4.18/tests/localename.c 2017-07-30 16:40:47.098541270 +0000 +@@ -40,7 +40,7 @@ + # if defined __APPLE__ && defined __MACH__ + # include + # endif +-# if __GLIBC__ >= 2 && !defined __UCLIBC__ ++# if defined __linux__ + # include + # endif + # if !defined IN_LIBINTL +@@ -2692,16 +2692,19 @@ + locale_t thread_locale = uselocale (NULL); + if (thread_locale != LC_GLOBAL_LOCALE) + { +-# if __GLIBC__ >= 2 && !defined __UCLIBC__ ++# if defined(_NL_LOCALE_NAME) ++ const char *name = nl_langinfo(_NL_LOCALE_NAME(category)); ++# if __GLIBC__ >= 2 && !defined __UCLIBC__ + /* Work around an incorrect definition of the _NL_LOCALE_NAME macro in + glibc < 2.12. + See . */ +- const char *name = +- nl_langinfo (_NL_ITEM ((category), _NL_ITEM_INDEX (-1))); ++ if (name[0] == '\0') ++ name = nl_langinfo (_NL_ITEM ((category), _NL_ITEM_INDEX (-1))); + if (name[0] == '\0') + /* Fallback code for glibc < 2.4, which did not implement + nl_langinfo (_NL_LOCALE_NAME (category)). */ + name = thread_locale->__names[category]; ++# endif + return name; + # elif defined __FreeBSD__ || (defined __APPLE__ && defined __MACH__) + /* FreeBSD, Mac OS X */ diff --git a/base/m4/m4.SMBuild b/base/m4/m4.SMBuild new file mode 100755 index 0000000..e2b83b0 --- /dev/null +++ b/base/m4/m4.SMBuild @@ -0,0 +1,35 @@ +APP=m4 +VERSION=1.4.18 +BUILD=1sml +HOMEPAGE='http://gnu.org/software/m4' +DOWNLOAD='https://ftp.gnu.org/gnu/m4/m4-1.4.18.tar.xz' +DESC="implementation of the UNIX macro processor" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/disable-mbrtowc-test.patch + patch -p1 < $SRCDIR/localename-test-fix.patch + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +de0953d0373247b9f7edbe4cb68169f5405eb0eca4f78f54324e489f51eb50871ce9cc10fe91f23322c65929886ffc64b495deaaadc3494a5a677cee0d4b5290 m4-1.4.18.tar.lz +78bf099c96fcec8c9cebd4e34f0d7c942e99da2ec238baa9464f8443580edb0565e9026c433ee54fb564304ec8e7e90766e19474472e57b48e567fd7b356777e disable-mbrtowc-test.patch +fac0cb58e698996284a222c4da340f92689d6db98f1fbab6e61e1c5f2d90122660296f8e5c60c94169413e3e2ee632c6264f12b98e5d3a1e1aae145a2d4aac45 localename-test-fix.patch +" diff --git a/base/make/make.SMBuild b/base/make/make.SMBuild new file mode 100755 index 0000000..369cbab --- /dev/null +++ b/base/make/make.SMBuild @@ -0,0 +1,31 @@ +APP=make +VERSION=3.82 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/make/' +DOWNLOAD='https://ftp.gnu.org/gnu/make/make-3.82.tar.bz2' +DESC="GNU make utility to maintain groups of programs" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2894d997533a64d709958cae74f133a114e0db6e86dd1dc0d48e32b41f12edb66319a205c7ac536041006453fc0b168d247d329f057826a0d484275c3e949dbb make-3.82.tar.lz +" diff --git a/base/makeself/makeself.SMBuild b/base/makeself/makeself.SMBuild new file mode 100755 index 0000000..ce49a04 --- /dev/null +++ b/base/makeself/makeself.SMBuild @@ -0,0 +1,28 @@ +APP=makeself +VERSION=2.2.0 +BUILD=1sml +HOMEPAGE='https://github.com/megastep/makeself' +DOWNLOAD='https://github.com/megastep/makeself/archive/refs/tags/release-2.2.0.tar.gz' +DESC="shell script that generates a self-extractable compressed tar archive from a directory" +REQUIRES="bash" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p $PKG/bin + cp makeself-header.sh makeself.sh makeself.lsm $PKG/bin/ + install -Dm 644 makeself.1 $PKG/share/man/man1/makeself.1 + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +16ab58bd38d1eac8133f3028e420a11cf445836ef5981a5655bdef5a9108cf1b472aa8364e82ac92f38d2395522195006f9b8f6b78acae8895811c5ae99592a4 makeself-2.2.0.tar.lz +" diff --git a/base/mandoc/configure.local b/base/mandoc/configure.local new file mode 100644 index 0000000..f304143 --- /dev/null +++ b/base/mandoc/configure.local @@ -0,0 +1,9 @@ +PREFIX="" +MANDIR="${PREFIX}/share/man" +SBINDIR="${PREFIX}/bin" +MANPATH_DEFAULT="${PREFIX}/share:${PREFIX}/share/man" +MANPATH_BASE="${PREFIX}/share" +UTF8_LOCALE=en_US.UTF-8 +OSNAME="SMLinux" +INSTALL_PROGRAM="install -m 0755" +CC=gcc diff --git a/base/mandoc/fix-tbl-segfault.patch b/base/mandoc/fix-tbl-segfault.patch new file mode 100644 index 0000000..a990061 --- /dev/null +++ b/base/mandoc/fix-tbl-segfault.patch @@ -0,0 +1,20 @@ +--- a/tbl_term.c 2020-08-18 12:35:27.290953791 +0200 ++++ b/tbl_term.c 2020-08-18 12:35:23.450952148 +0200 +@@ -626,7 +626,7 @@ + + lw = cpp == NULL || cpn == NULL || + (cpn->pos != TBL_CELL_DOWN && +- (dpn == NULL || strcmp(dpn->string, "\\^") != 0)) ++ (dpn == NULL || dpn->pos == TBL_DATA_NONE || strcmp(dpn->string, "\\^") != 0)) + ? hw : 0; + tbl_direct_border(tp, BHORIZ * lw, + col->width + col->spacing / 2); +@@ -670,7 +670,7 @@ + + rw = cpp == NULL || cpn == NULL || + (cpn->pos != TBL_CELL_DOWN && +- (dpn == NULL || strcmp(dpn->string, "\\^") != 0)) ++ (dpn == NULL || dpn->pos == TBL_DATA_NONE || strcmp(dpn->string, "\\^") != 0)) + ? hw : 0; + + /* The line crossing at the end of this column. */ diff --git a/base/mandoc/main.c.patch b/base/mandoc/main.c.patch new file mode 100644 index 0000000..0b4b0c4 --- /dev/null +++ b/base/mandoc/main.c.patch @@ -0,0 +1,11 @@ +--- a/main.c ++++ b/main.c +@@ -1171,7 +1171,7 @@ + if (pager == NULL || *pager == '\0') + pager = getenv("PAGER"); + if (pager == NULL || *pager == '\0') +- pager = "more -s"; ++ pager = "less -s"; + cp = mandoc_strdup(pager); + + /* diff --git a/base/mandoc/mandoc.SMBuild b/base/mandoc/mandoc.SMBuild new file mode 100755 index 0000000..5a35131 --- /dev/null +++ b/base/mandoc/mandoc.SMBuild @@ -0,0 +1,50 @@ +APP=mandoc +VERSION=1.14.5 +BUILD=1sml +HOMEPAGE='https://mandoc.bsd.lv/' +DOWNLOAD='https://mandoc.bsd.lv/snapshots/mandoc-1.14.5.tar.gz' +DESC="UNIX manpage compiler suite" +REQUIRES="less zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/main.c.patch + patch -p1 < $SRCDIR/fix-tbl-segfault.patch + patch -p1 < $SRCDIR/shared-libmandoc.patch + patch -p1 < $SRCDIR/simplify-compat.patch + patch -p1 < $SRCDIR/outdated-warn-disable.patch + + cp $SRCDIR/configure.local configure.local + + ./configure + #make CFLAGS="-static" + make + make DESTDIR=$PKG PREFIX="" LIBDIR=/lib base-install lib-install + + cp LICENSE $PKGDOCS/ + + ( + cd $PKG/bin + for i in apropos makewhatis man whatis ; do + rm "$PKG"/bin/"$i" + ln -sf mandoc "$PKG"/bin/"$i" + done + ) + + mkfinalpkg +} + +SHA512SUMS=" +cba0c95ebb290cdc33767f8ffe338171c8494924a8bd919ca5626cc0bddbcece5bddf0399136652fbbedcfc96d8276cbf4597af56e37263a22eee756d2dca456 mandoc-1.14.5.tar.lz +0861027ece94c23395df3a235e8320a7353976df79d623a2fdbdd1673c5b745394726600a494d7403d52d18cefbdf9b3b9456b7f3813f8d9fe452a4c384f30e3 fix-tbl-segfault.patch +59eed3d6f6bba6a03cea86dac0cfae085b22aa42304be9671edd4f6e6751a939392977b64271bcfbd5e12052219df6b6be396f7ffdba3c450e16050213792654 main.c.patch +ced05e8b57fb9705c6d8d8570cd6b06ad187511a4c243ac2dbc34064aa164ca49e0c877160134161dcb98ebd5e61a5c23d5741f03ef95903ff56193dd07f36a1 outdated-warn-disable.patch +b1bd2c197584948cc8bab2310e759b8942b9f9479254ffb5a8223cfa6ba03c9e1a4d402c5440b8d9f962be9a020287d3dd8556592c17f2b46f15f405d9d373cb shared-libmandoc.patch +0979e8ee20d6163669f7ab3ace1f959ba9d831c208785c3522261c72ddc2f60ce8420ed36ea963c46a72b9ffdbcb9199da436b13e14c0ca4d938351d170adfa7 simplify-compat.patch +" diff --git a/base/mandoc/outdated-warn-disable.patch b/base/mandoc/outdated-warn-disable.patch new file mode 100644 index 0000000..f960de7 --- /dev/null +++ b/base/mandoc/outdated-warn-disable.patch @@ -0,0 +1,12 @@ +diff -Naur a/main.c b/main.c +--- a/main.c 2019-03-03 15:24:23.600767518 +0000 ++++ b/main.c 2019-03-03 15:27:37.609820365 +0000 +@@ -676,8 +676,6 @@ + return globres != -1; + + found: +- warnx("outdated mandoc.db lacks %s(%s) entry, run %s %s", +- name, sec, BINM_MAKEWHATIS, paths->paths[ipath]); + if (res == NULL) { + free(file); + return 1; diff --git a/base/mandoc/shared-libmandoc.patch b/base/mandoc/shared-libmandoc.patch new file mode 100644 index 0000000..0327138 --- /dev/null +++ b/base/mandoc/shared-libmandoc.patch @@ -0,0 +1,76 @@ +diff --git a/Makefile b/Makefile +index f4e2954..d153224 100644 +--- a/Makefile ++++ b/Makefile +@@ -367,9 +367,13 @@ WWW_INCS = eqn.h.html \ + tbl_int.h.html \ + tbl_parse.h.html + ++LIBMANDOC = libmandoc.so ++MANDOCLIB = -L. -lmandoc ++ + # === USER CONFIGURATION =============================================== + + include Makefile.local ++CFLAGS += -fPIC + + # === DEPENDENCY HANDLING ============================================== + +@@ -392,7 +396,7 @@ distclean: clean + rm -f Makefile.local config.h config.h.old config.log config.log.old + + clean: +- rm -f libmandoc.a $(LIBMANDOC_OBJS) $(COMPAT_OBJS) ++ rm -f $(LIBMANDOC) $(LIBMANDOC_OBJS) $(COMPAT_OBJS) + rm -f mandoc $(MAIN_OBJS) + rm -f man.cgi $(CGI_OBJS) + rm -f mandocd catman catman.o $(MANDOCD_OBJS) +@@ -431,11 +435,11 @@ base-install: mandoc demandoc soelim + $(INSTALL_MAN) makewhatis.8 \ + $(DESTDIR)$(MANDIR)/man8/$(BINM_MAKEWHATIS).8 + +-lib-install: libmandoc.a ++lib-install: $(LIBMANDOC) + mkdir -p $(DESTDIR)$(LIBDIR) + mkdir -p $(DESTDIR)$(INCLUDEDIR) + mkdir -p $(DESTDIR)$(MANDIR)/man3 +- $(INSTALL_LIB) libmandoc.a $(DESTDIR)$(LIBDIR) ++ $(INSTALL_LIB) $(LIBMANDOC) $(DESTDIR)$(LIBDIR) + $(INSTALL_LIB) eqn.h man.h mandoc.h mandoc_aux.h mandoc_parse.h \ + mdoc.h roff.h tbl.h $(DESTDIR)$(INCLUDEDIR) + $(INSTALL_MAN) mandoc.3 mandoc_escape.3 mandoc_malloc.3 \ +@@ -511,23 +515,23 @@ Makefile.local config.h: configure $(TESTSRCS) + @echo "$@ is out of date; please run ./configure" + @exit 1 + +-libmandoc.a: $(COMPAT_OBJS) $(LIBMANDOC_OBJS) +- ar rs $@ $(COMPAT_OBJS) $(LIBMANDOC_OBJS) ++libmandoc.so: $(COMPAT_OBJS) $(LIBMANDOC_OBJS) ++ $(CC) $(LDFLAGS) -shared -o $@ $(COMPAT_OBJS) $(LIBMANDOC_OBJS) $(LDADD) + +-mandoc: $(MAIN_OBJS) libmandoc.a +- $(CC) -o $@ $(LDFLAGS) $(MAIN_OBJS) libmandoc.a $(LDADD) ++mandoc: $(MAIN_OBJS) $(LIBMANDOC) ++ $(CC) -o $@ $(LDFLAGS) $(MAIN_OBJS) $(MANDOCLIB) $(LDADD) + + man.cgi: $(CGI_OBJS) libmandoc.a + $(CC) $(STATIC) -o $@ $(LDFLAGS) $(CGI_OBJS) libmandoc.a $(LDADD) + +-mandocd: $(MANDOCD_OBJS) libmandoc.a +- $(CC) -o $@ $(LDFLAGS) $(MANDOCD_OBJS) libmandoc.a $(LDADD) ++mandocd: $(MANDOCD_OBJS) $(LIBMANDOC) ++ $(CC) -o $@ $(LDFLAGS) $(MANDOCD_OBJS) $(LIBMANDOC) $(LDADD) + +-catman: catman.o libmandoc.a +- $(CC) -o $@ $(LDFLAGS) catman.o libmandoc.a $(LDADD) ++catman: catman.o $(LIBMANDOC) ++ $(CC) -o $@ $(LDFLAGS) catman.o $(LIBMANDOC) $(LDADD) + +-demandoc: $(DEMANDOC_OBJS) libmandoc.a +- $(CC) -o $@ $(LDFLAGS) $(DEMANDOC_OBJS) libmandoc.a $(LDADD) ++demandoc: $(DEMANDOC_OBJS) $(LIBMANDOC) ++ $(CC) -o $@ $(LDFLAGS) $(DEMANDOC_OBJS) $(LIBMANDOC) $(LDADD) + + soelim: $(SOELIM_OBJS) + $(CC) -o $@ $(LDFLAGS) $(SOELIM_OBJS) + diff --git a/base/mandoc/simplify-compat.patch b/base/mandoc/simplify-compat.patch new file mode 100644 index 0000000..d50be17 --- /dev/null +++ b/base/mandoc/simplify-compat.patch @@ -0,0 +1,275 @@ +Upstream: Unknown, taken from Fedora +Reason: Fixes compilation with gcc-10 + +diff -up mandoc-1.14.5/compat_err.c.orig mandoc-1.14.5/compat_err.c +--- mandoc-1.14.5/compat_err.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_err.c 2020-02-06 14:30:56.839081393 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_ERR +- +-int dummy; +- +-#else ++#if HAVE_ERR == 0 + + /* $Id: compat_err.c,v 1.4 2015/11/26 07:42:11 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/compat_fts.c.orig mandoc-1.14.5/compat_fts.c +--- mandoc-1.14.5/compat_fts.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_fts.c 2020-02-06 14:31:04.095057713 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_FTS +- +-int dummy; +- +-#else ++#if HAVE_FTS == 0 + + /* $Id: compat_fts.c,v 1.14 2017/02/18 12:24:24 schwarze Exp $ */ + /* $OpenBSD: fts.c,v 1.56 2016/09/21 04:38:56 guenther Exp $ */ +diff -up mandoc-1.14.5/compat_getline.c.orig mandoc-1.14.5/compat_getline.c +--- mandoc-1.14.5/compat_getline.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_getline.c 2020-02-06 14:31:14.287024456 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_GETLINE +- +-int dummy; +- +-#else ++#if HAVE_GETLINE == 0 + + /* $Id: compat_getline.c,v 1.1 2015/11/07 20:52:52 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/compat_getsubopt.c.orig mandoc-1.14.5/compat_getsubopt.c +--- mandoc-1.14.5/compat_getsubopt.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_getsubopt.c 2020-02-06 14:31:24.446991303 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_GETSUBOPT +- +-int dummy; +- +-#else ++#if HAVE_GETSUBOPT == 0 + + /* $Id: compat_getsubopt.c,v 1.5 2014/08/17 20:53:50 schwarze Exp $ */ + /* $OpenBSD: getsubopt.c,v 1.4 2005/08/08 08:05:36 espie Exp $ */ +diff -up mandoc-1.14.5/compat_isblank.c.orig mandoc-1.14.5/compat_isblank.c +--- mandoc-1.14.5/compat_isblank.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_isblank.c 2020-02-06 14:31:33.686961149 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_ISBLANK +- +-int dummy; +- +-#else ++#if HAVE_ISBLANK == 0 + + /* $Id: compat_isblank.c,v 1.2 2015/10/06 18:32:19 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/compat_mkdtemp.c.orig mandoc-1.14.5/compat_mkdtemp.c +--- mandoc-1.14.5/compat_mkdtemp.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_mkdtemp.c 2020-02-06 14:31:41.758934811 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_MKDTEMP +- +-int dummy; +- +-#else ++#if HAVE_MKDTEMP == 0 + + /* $Id: compat_mkdtemp.c,v 1.2 2015/10/06 18:32:19 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/compat_ohash.c.orig mandoc-1.14.5/compat_ohash.c +--- mandoc-1.14.5/compat_ohash.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_ohash.c 2020-02-06 14:31:49.943908103 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_OHASH +- +-int dummy; +- +-#else ++#if HAVE_OHASH == 0 + + /* $OpenBSD: ohash.c,v 1.1 2014/06/02 18:52:03 deraadt Exp $ */ + +diff -up mandoc-1.14.5/compat_progname.c.orig mandoc-1.14.5/compat_progname.c +--- mandoc-1.14.5/compat_progname.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_progname.c 2020-02-06 14:31:57.278884167 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_PROGNAME +- +-int dummy; +- +-#else ++#if HAVE_PROGNAME == 0 + + /* $Id: compat_progname.c,v 1.1 2015/11/06 16:30:33 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/compat_reallocarray.c.orig mandoc-1.14.5/compat_reallocarray.c +--- mandoc-1.14.5/compat_reallocarray.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_reallocarray.c 2020-02-06 14:32:05.686856733 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_REALLOCARRAY +- +-int dummy; +- +-#else ++#if HAVE_REALLOCARRAY == 0 + + /* $Id: compat_reallocarray.c,v 1.4 2014/12/11 09:05:01 schwarze Exp $ */ + /* $OpenBSD: reallocarray.c,v 1.2 2014/12/08 03:45:00 bcook Exp $ */ +diff -up mandoc-1.14.5/compat_recallocarray.c.orig mandoc-1.14.5/compat_recallocarray.c +--- mandoc-1.14.5/compat_recallocarray.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_recallocarray.c 2020-02-06 14:32:14.070829371 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_RECALLOCARRAY +- +-int dummy; +- +-#else ++#if HAVE_RECALLOCARRAY == 0 + + /* $Id: compat_recallocarray.c,v 1.1 2017/06/12 19:05:47 schwarze Exp $ */ + /* $OpenBSD: malloc.c,v 1.225 2017/05/13 07:11:29 otto Exp $ */ +diff -up mandoc-1.14.5/compat_strcasestr.c.orig mandoc-1.14.5/compat_strcasestr.c +--- mandoc-1.14.5/compat_strcasestr.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_strcasestr.c 2020-02-06 14:32:21.591804829 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRCASESTR +- +-int dummy; +- +-#else ++#if HAVE_STRCASESTR == 0 + + /* $Id: compat_strcasestr.c,v 1.4 2014/12/11 09:19:32 schwarze Exp $ */ + /* $NetBSD: strcasestr.c,v 1.3 2005/11/29 03:12:00 christos Exp $ */ +diff -up mandoc-1.14.5/compat_stringlist.c.orig mandoc-1.14.5/compat_stringlist.c +--- mandoc-1.14.5/compat_stringlist.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_stringlist.c 2020-02-06 14:29:49.568300904 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRINGLIST +- +-int dummy; +- +-#else ++#if HAVE_STRINGLIST == 0 + + /* $Id: compat_stringlist.c,v 1.6 2015/11/07 14:22:29 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/compat_stringlist.h.orig mandoc-1.14.5/compat_stringlist.h +diff -up mandoc-1.14.5/compat_strlcat.c.orig mandoc-1.14.5/compat_strlcat.c +--- mandoc-1.14.5/compat_strlcat.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_strlcat.c 2020-02-06 14:32:36.471756272 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRLCAT +- +-int dummy; +- +-#else ++#if HAVE_STRLCAT == 0 + + /* $OpenBSD: strlcat.c,v 1.13 2005/08/08 08:05:37 espie Exp $ */ + +diff -up mandoc-1.14.5/compat_strlcpy.c.orig mandoc-1.14.5/compat_strlcpy.c +--- mandoc-1.14.5/compat_strlcpy.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_strlcpy.c 2020-02-06 14:32:44.447730243 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRLCPY +- +-int dummy; +- +-#else ++#if HAVE_STRLCPY == 0 + + /* $OpenBSD: strlcpy.c,v 1.11 2006/05/05 15:27:38 millert Exp $ */ + +diff -up mandoc-1.14.5/compat_strndup.c.orig mandoc-1.14.5/compat_strndup.c +--- mandoc-1.14.5/compat_strndup.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_strndup.c 2020-02-06 14:32:52.264704732 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRNDUP +- +-int dummy; +- +-#else ++#if HAVE_STRNDUP == 0 + + /* $Id: compat_strndup.c,v 1.1 2018/02/27 11:16:23 schwarze Exp $ */ + /* OpenBSD: strndup.c,v 1.2 2015/08/31 02:53:57 guenther Exp */ +diff -up mandoc-1.14.5/compat_strsep.c.orig mandoc-1.14.5/compat_strsep.c +--- mandoc-1.14.5/compat_strsep.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_strsep.c 2020-02-06 14:33:01.807673592 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRSEP +- +-int dummy; +- +-#else ++#if HAVE_STRSEP == 0 + + /* $Id: compat_strsep.c,v 1.4 2014/12/11 09:05:01 schwarze Exp $ */ + /* $OpenBSD: strsep.c,v 1.7 2014/02/05 20:42:32 stsp Exp $ */ +diff -up mandoc-1.14.5/compat_strtonum.c.orig mandoc-1.14.5/compat_strtonum.c +--- mandoc-1.14.5/compat_strtonum.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_strtonum.c 2020-02-06 14:33:10.839644116 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_STRTONUM +- +-int dummy; +- +-#else ++#if HAVE_STRTONUM == 0 + + /* $Id: compat_strtonum.c,v 1.1 2015/02/16 14:56:22 schwarze Exp $ */ + /* $OpenBSD: strtonum.c,v 1.7 2013/04/17 18:40:58 tedu Exp $ */ +diff -up mandoc-1.14.5/compat_vasprintf.c.orig mandoc-1.14.5/compat_vasprintf.c +--- mandoc-1.14.5/compat_vasprintf.c.orig 2019-03-10 05:56:43.000000000 -0400 ++++ mandoc-1.14.5/compat_vasprintf.c 2020-02-06 14:33:18.119620363 -0500 +@@ -1,10 +1,6 @@ + #include "config.h" + +-#if HAVE_VASPRINTF +- +-int dummy; +- +-#else ++#if HAVE_VASPRINTF == 0 + + /* $Id: compat_vasprintf.c,v 1.3 2015/10/06 18:32:19 schwarze Exp $ */ + /* +diff -up mandoc-1.14.5/tbl_html.c.orig mandoc-1.14.5/tbl_html.c diff --git a/base/mdadm/doinst.sh b/base/mdadm/doinst.sh new file mode 100644 index 0000000..a6a71c7 --- /dev/null +++ b/base/mdadm/doinst.sh @@ -0,0 +1,12 @@ +config() { + NEW="$1" + OLD="`dirname $NEW`/`basename $NEW .new`" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/mdadm.conf.new diff --git a/base/mdadm/mdadm.SMBuild b/base/mdadm/mdadm.SMBuild new file mode 100755 index 0000000..0860e4d --- /dev/null +++ b/base/mdadm/mdadm.SMBuild @@ -0,0 +1,34 @@ +APP=mdadm +VERSION=4.0 +BUILD=1sml +HOMEPAGE='https://git.kernel.org/cgit/utils/mdadm' +DOWNLOAD='https://git.kernel.org/pub/scm/utils/mdadm/mdadm.git/snapshot/mdadm-4.0.tar.gz' +DESC="utility to create, manage and monitor software RAID devices" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make STRIP= \ + CHECK_RUN_DIR=0 \ + CC="$CC -include sys/sysmacros.h" \ + CWFLAGS="-Wall" \ + MANDIR="/share/man" \ + BINDIR="/bin" \ + RUNDIR="/var/run/mdadm" \ + UDEVDIR="/etc/udev" \ + DESTDIR="$PKG" all install + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ad35d0e80f5ff42f0cd853a742d78b1cc51edb2fea285881bcb3c81e5830e220984b7c1bb6c5a645c51ed5cfa72ad18e23603b8c9ca5cc959a01ae17a86e65d9 mdadm-4.0.tar.lz +" diff --git a/base/meson/meson.SMBuild b/base/meson/meson.SMBuild new file mode 100755 index 0000000..bd6ffed --- /dev/null +++ b/base/meson/meson.SMBuild @@ -0,0 +1,27 @@ +APP=meson +VERSION=0.56.0 +BUILD=1sml +HOMEPAGE='https://github.com/mesonbuild/meson' +DOWNLOAD='https://github.com/mesonbuild/meson/archive/refs/tags/0.56.0.tar.gz' +DESC="next generation build system based on python3 and ninja" +REQUIRES="python3 itstool ninja" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + python3 setup.py build + python3 setup.py install --prefix="" --root="$PKG" + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +81cbe26bd378db568f6c3e7ad09312c1a0fcb940f5b917bb4dcfbc289ecb5cd57d9b6e657e0c5825fd9608749168425932f34ca5f7af84ca288ca67f9812d29d meson-0.56.0.tar.lz +" diff --git a/base/miniupnpc/miniupnpc.SMBuild b/base/miniupnpc/miniupnpc.SMBuild new file mode 100755 index 0000000..df697fc --- /dev/null +++ b/base/miniupnpc/miniupnpc.SMBuild @@ -0,0 +1,30 @@ +APP=miniupnpc +VERSION=2.1 +BUILD=1sml +HOMEPAGE='http://miniupnp.free.fr/' +DOWNLOAD='http://miniupnp.free.fr/files/download.php?file=miniupnpc-2.1.tar.gz' +DESC="Client library to enable applications to access UPnP services on the network" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + make install DESTDIR=$PKG LIBDIR=lib + + python3 setup.py build + python3 setup.py install --root=$PKG + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +839a341e9fe0b2128383c6de4887dc551974aabefc0646a3bef811c6bc19efd0be59bae0a92c8deaef46c3658dfa0cd8376ac243dfbc7d22f96dc8dfb02e2db0 miniupnpc-2.1.tar.lz +" diff --git a/base/mksh/mksh.SMBuild b/base/mksh/mksh.SMBuild new file mode 100755 index 0000000..e5abe93 --- /dev/null +++ b/base/mksh/mksh.SMBuild @@ -0,0 +1,30 @@ +APP=mksh +VERSION=R56c +BUILD=1sml +HOMEPAGE='https://www.mirbsd.org/mksh.htm' +DOWNLOAD='http://www.mirbsd.org/MirOS/dist/mir/mksh/mksh-R56c.tgz' +DESC="MirBSD Korn Shell, successor to the pdksh" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tgz + cd "$APP" + fixbuilddirpermissions + + chmod +x Build.sh + CFLAGS="-static -O3 -fPIC" ./Build.sh + + install -Dm 644 mksh.1 $PKG/share/man/man1/mksh.1 + install -Dm 755 mksh $PKG/bin/mksh + + head -n 26 Build.sh > $PKGDOCS/LICENSE + + mkfinalpkg +} + +SHA512SUMS=" +7e4cd2d24c6bca2ebad7c6b02d158188e766bd4693d93f5bed198d69238aef078d42ce911431ad4e419e4af55083047d823bfad53973db5c6d8a685482770135 mksh-R56c.tgz +" diff --git a/base/mlocate/01-fortify-source-compat.patch b/base/mlocate/01-fortify-source-compat.patch new file mode 100644 index 0000000..deabf90 --- /dev/null +++ b/base/mlocate/01-fortify-source-compat.patch @@ -0,0 +1,21 @@ +--- a/configure 2012-09-22 06:13:53.000000000 +0400 ++++ b/configure 2017-02-24 00:28:09.645357065 +0300 +@@ -6666,7 +6666,6 @@ + gl_LIBOBJS="$gl_LIBOBJS canonicalize-lgpl.$ac_objext" + + +-$as_echo "#define realpath rpl_realpath" >>confdefs.h + + + +--- a/gnulib/m4/canonicalize-lgpl.m4 2010-03-26 22:38:17.000000000 +0300 ++++ b/gnulib/m4/canonicalize-lgpl.m4 2017-02-24 00:28:38.515419315 +0300 +@@ -12,8 +12,6 @@ + AC_CHECK_FUNCS_ONCE(canonicalize_file_name) + if test $ac_cv_func_canonicalize_file_name = no; then + AC_LIBOBJ(canonicalize-lgpl) +- AC_DEFINE([realpath], [rpl_realpath], +- [Define to a replacement function name for realpath().]) + gl_PREREQ_CANONICALIZE_LGPL + fi + ]) diff --git a/base/mlocate/mlocate.SMBuild b/base/mlocate/mlocate.SMBuild new file mode 100755 index 0000000..967e911 --- /dev/null +++ b/base/mlocate/mlocate.SMBuild @@ -0,0 +1,40 @@ +APP=mlocate +VERSION=0.26 +BUILD=1sml +HOMEPAGE='https://packages.debian.org/jessie/mlocate' +DOWNLOAD='http://deb.debian.org/debian/pool/main/m/mlocate/mlocate_0.26.orig.tar.gz' +DESC="file and directory finder that aims to optimize find times using databases" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/01-fortify-source-compat.patch + sed -i '/^groupname /s/mlocate/locate/' Makefile.in + + autoreconf -vif + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --localstatedir=/var + + make + make install DESTDIR=$PKG + + install -Dm 644 $SRCDIR/updatedb.conf.sample $PKG/etc/updatedb.conf + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +09d6fda20c4cd1293981ed2e3fce051aabd85076b386a92b7bfc6153e2405322fcdebd839bbb9258b91af11a7eff390f9e5faf9af51ecc592afff8be4cb86aa8 mlocate-0.26.tar.lz +ad4a70a3a827d09113b30788e7343f3cd47750cf0ce79f088fadab102fc78c04243482eddb9987cac8843c5065257dd6d9c17f423fe4c331fefe0148657f55fe 01-fortify-source-compat.patch +" diff --git a/base/mlocate/updatedb.conf.sample b/base/mlocate/updatedb.conf.sample new file mode 100644 index 0000000..ea33c32 --- /dev/null +++ b/base/mlocate/updatedb.conf.sample @@ -0,0 +1,4 @@ +PRUNE_BIND_MOUNTS = "yes" +PRUNEFS = "9p afs anon_inodefs auto autofs bdev binfmt_misc cgroup cifs coda configfs cpuset cramfs debugfs devpts devtmpfs ecryptfs exofs ftpfs fuse fuse.encfs fuse.sshfs fusectl gfs gfs2 hugetlbfs inotifyfs iso9660 jffs2 lustre mqueue ncpfs nfs nfs4 nfsd pipefs proc ramfs rootfs rpc_pipefs securityfs selinuxfs sfs shfs smbfs sockfs sshfs sysfs tmpfs ubifs udf usbfs vboxsf" +PRUNENAMES = ".git .hg .svn" +PRUNEPATHS = "/afs /media /mnt /net /sfs /tmp /udev /var/cache /var/lock /var/run /var/spool /var/tmp" diff --git a/base/mozilla-nss/MPL-1.1.txt b/base/mozilla-nss/MPL-1.1.txt new file mode 100644 index 0000000..7714141 --- /dev/null +++ b/base/mozilla-nss/MPL-1.1.txt @@ -0,0 +1,470 @@ + MOZILLA PUBLIC LICENSE + Version 1.1 + + --------------- + +1. Definitions. + + 1.0.1. "Commercial Use" means distribution or otherwise making the + Covered Code available to a third party. + + 1.1. "Contributor" means each entity that creates or contributes to + the creation of Modifications. + + 1.2. "Contributor Version" means the combination of the Original + Code, prior Modifications used by a Contributor, and the Modifications + made by that particular Contributor. + + 1.3. "Covered Code" means the Original Code or Modifications or the + combination of the Original Code and Modifications, in each case + including portions thereof. + + 1.4. "Electronic Distribution Mechanism" means a mechanism generally + accepted in the software development community for the electronic + transfer of data. + + 1.5. "Executable" means Covered Code in any form other than Source + Code. + + 1.6. "Initial Developer" means the individual or entity identified + as the Initial Developer in the Source Code notice required by Exhibit + A. + + 1.7. "Larger Work" means a work which combines Covered Code or + portions thereof with code not governed by the terms of this License. + + 1.8. "License" means this document. + + 1.8.1. "Licensable" means having the right to grant, to the maximum + extent possible, whether at the time of the initial grant or + subsequently acquired, any and all of the rights conveyed herein. + + 1.9. "Modifications" means any addition to or deletion from the + substance or structure of either the Original Code or any previous + Modifications. When Covered Code is released as a series of files, a + Modification is: + A. Any addition to or deletion from the contents of a file + containing Original Code or previous Modifications. + + B. Any new file that contains any part of the Original Code or + previous Modifications. + + 1.10. "Original Code" means Source Code of computer software code + which is described in the Source Code notice required by Exhibit A as + Original Code, and which, at the time of its release under this + License is not already Covered Code governed by this License. + + 1.10.1. "Patent Claims" means any patent claim(s), now owned or + hereafter acquired, including without limitation, method, process, + and apparatus claims, in any patent Licensable by grantor. + + 1.11. "Source Code" means the preferred form of the Covered Code for + making modifications to it, including all modules it contains, plus + any associated interface definition files, scripts used to control + compilation and installation of an Executable, or source code + differential comparisons against either the Original Code or another + well known, available Covered Code of the Contributor's choice. The + Source Code can be in a compressed or archival form, provided the + appropriate decompression or de-archiving software is widely available + for no charge. + + 1.12. "You" (or "Your") means an individual or a legal entity + exercising rights under, and complying with all of the terms of, this + License or a future version of this License issued under Section 6.1. + For legal entities, "You" includes any entity which controls, is + controlled by, or is under common control with You. For purposes of + this definition, "control" means (a) the power, direct or indirect, + to cause the direction or management of such entity, whether by + contract or otherwise, or (b) ownership of more than fifty percent + (50%) of the outstanding shares or beneficial ownership of such + entity. + +2. Source Code License. + + 2.1. The Initial Developer Grant. + The Initial Developer hereby grants You a world-wide, royalty-free, + non-exclusive license, subject to third party intellectual property + claims: + (a) under intellectual property rights (other than patent or + trademark) Licensable by Initial Developer to use, reproduce, + modify, display, perform, sublicense and distribute the Original + Code (or portions thereof) with or without Modifications, and/or + as part of a Larger Work; and + + (b) under Patents Claims infringed by the making, using or + selling of Original Code, to make, have made, use, practice, + sell, and offer for sale, and/or otherwise dispose of the + Original Code (or portions thereof). + + (c) the licenses granted in this Section 2.1(a) and (b) are + effective on the date Initial Developer first distributes + Original Code under the terms of this License. + + (d) Notwithstanding Section 2.1(b) above, no patent license is + granted: 1) for code that You delete from the Original Code; 2) + separate from the Original Code; or 3) for infringements caused + by: i) the modification of the Original Code or ii) the + combination of the Original Code with other software or devices. + + 2.2. Contributor Grant. + Subject to third party intellectual property claims, each Contributor + hereby grants You a world-wide, royalty-free, non-exclusive license + + (a) under intellectual property rights (other than patent or + trademark) Licensable by Contributor, to use, reproduce, modify, + display, perform, sublicense and distribute the Modifications + created by such Contributor (or portions thereof) either on an + unmodified basis, with other Modifications, as Covered Code + and/or as part of a Larger Work; and + + (b) under Patent Claims infringed by the making, using, or + selling of Modifications made by that Contributor either alone + and/or in combination with its Contributor Version (or portions + of such combination), to make, use, sell, offer for sale, have + made, and/or otherwise dispose of: 1) Modifications made by that + Contributor (or portions thereof); and 2) the combination of + Modifications made by that Contributor with its Contributor + Version (or portions of such combination). + + (c) the licenses granted in Sections 2.2(a) and 2.2(b) are + effective on the date Contributor first makes Commercial Use of + the Covered Code. + + (d) Notwithstanding Section 2.2(b) above, no patent license is + granted: 1) for any code that Contributor has deleted from the + Contributor Version; 2) separate from the Contributor Version; + 3) for infringements caused by: i) third party modifications of + Contributor Version or ii) the combination of Modifications made + by that Contributor with other software (except as part of the + Contributor Version) or other devices; or 4) under Patent Claims + infringed by Covered Code in the absence of Modifications made by + that Contributor. + +3. Distribution Obligations. + + 3.1. Application of License. + The Modifications which You create or to which You contribute are + governed by the terms of this License, including without limitation + Section 2.2. The Source Code version of Covered Code may be + distributed only under the terms of this License or a future version + of this License released under Section 6.1, and You must include a + copy of this License with every copy of the Source Code You + distribute. You may not offer or impose any terms on any Source Code + version that alters or restricts the applicable version of this + License or the recipients' rights hereunder. However, You may include + an additional document offering the additional rights described in + Section 3.5. + + 3.2. Availability of Source Code. + Any Modification which You create or to which You contribute must be + made available in Source Code form under the terms of this License + either on the same media as an Executable version or via an accepted + Electronic Distribution Mechanism to anyone to whom you made an + Executable version available; and if made available via Electronic + Distribution Mechanism, must remain available for at least twelve (12) + months after the date it initially became available, or at least six + (6) months after a subsequent version of that particular Modification + has been made available to such recipients. You are responsible for + ensuring that the Source Code version remains available even if the + Electronic Distribution Mechanism is maintained by a third party. + + 3.3. Description of Modifications. + You must cause all Covered Code to which You contribute to contain a + file documenting the changes You made to create that Covered Code and + the date of any change. You must include a prominent statement that + the Modification is derived, directly or indirectly, from Original + Code provided by the Initial Developer and including the name of the + Initial Developer in (a) the Source Code, and (b) in any notice in an + Executable version or related documentation in which You describe the + origin or ownership of the Covered Code. + + 3.4. Intellectual Property Matters + (a) Third Party Claims. + If Contributor has knowledge that a license under a third party's + intellectual property rights is required to exercise the rights + granted by such Contributor under Sections 2.1 or 2.2, + Contributor must include a text file with the Source Code + distribution titled "LEGAL" which describes the claim and the + party making the claim in sufficient detail that a recipient will + know whom to contact. If Contributor obtains such knowledge after + the Modification is made available as described in Section 3.2, + Contributor shall promptly modify the LEGAL file in all copies + Contributor makes available thereafter and shall take other steps + (such as notifying appropriate mailing lists or newsgroups) + reasonably calculated to inform those who received the Covered + Code that new knowledge has been obtained. + + (b) Contributor APIs. + If Contributor's Modifications include an application programming + interface and Contributor has knowledge of patent licenses which + are reasonably necessary to implement that API, Contributor must + also include this information in the LEGAL file. + + (c) Representations. + Contributor represents that, except as disclosed pursuant to + Section 3.4(a) above, Contributor believes that Contributor's + Modifications are Contributor's original creation(s) and/or + Contributor has sufficient rights to grant the rights conveyed by + this License. + + 3.5. Required Notices. + You must duplicate the notice in Exhibit A in each file of the Source + Code. If it is not possible to put such notice in a particular Source + Code file due to its structure, then You must include such notice in a + location (such as a relevant directory) where a user would be likely + to look for such a notice. If You created one or more Modification(s) + You may add your name as a Contributor to the notice described in + Exhibit A. You must also duplicate this License in any documentation + for the Source Code where You describe recipients' rights or ownership + rights relating to Covered Code. You may choose to offer, and to + charge a fee for, warranty, support, indemnity or liability + obligations to one or more recipients of Covered Code. However, You + may do so only on Your own behalf, and not on behalf of the Initial + Developer or any Contributor. You must make it absolutely clear than + any such warranty, support, indemnity or liability obligation is + offered by You alone, and You hereby agree to indemnify the Initial + Developer and every Contributor for any liability incurred by the + Initial Developer or such Contributor as a result of warranty, + support, indemnity or liability terms You offer. + + 3.6. Distribution of Executable Versions. + You may distribute Covered Code in Executable form only if the + requirements of Section 3.1-3.5 have been met for that Covered Code, + and if You include a notice stating that the Source Code version of + the Covered Code is available under the terms of this License, + including a description of how and where You have fulfilled the + obligations of Section 3.2. The notice must be conspicuously included + in any notice in an Executable version, related documentation or + collateral in which You describe recipients' rights relating to the + Covered Code. You may distribute the Executable version of Covered + Code or ownership rights under a license of Your choice, which may + contain terms different from this License, provided that You are in + compliance with the terms of this License and that the license for the + Executable version does not attempt to limit or alter the recipient's + rights in the Source Code version from the rights set forth in this + License. If You distribute the Executable version under a different + license You must make it absolutely clear that any terms which differ + from this License are offered by You alone, not by the Initial + Developer or any Contributor. You hereby agree to indemnify the + Initial Developer and every Contributor for any liability incurred by + the Initial Developer or such Contributor as a result of any such + terms You offer. + + 3.7. Larger Works. + You may create a Larger Work by combining Covered Code with other code + not governed by the terms of this License and distribute the Larger + Work as a single product. In such a case, You must make sure the + requirements of this License are fulfilled for the Covered Code. + +4. Inability to Comply Due to Statute or Regulation. + + If it is impossible for You to comply with any of the terms of this + License with respect to some or all of the Covered Code due to + statute, judicial order, or regulation then You must: (a) comply with + the terms of this License to the maximum extent possible; and (b) + describe the limitations and the code they affect. Such description + must be included in the LEGAL file described in Section 3.4 and must + be included with all distributions of the Source Code. Except to the + extent prohibited by statute or regulation, such description must be + sufficiently detailed for a recipient of ordinary skill to be able to + understand it. + +5. Application of this License. + + This License applies to code to which the Initial Developer has + attached the notice in Exhibit A and to related Covered Code. + +6. Versions of the License. + + 6.1. New Versions. + Netscape Communications Corporation ("Netscape") may publish revised + and/or new versions of the License from time to time. Each version + will be given a distinguishing version number. + + 6.2. Effect of New Versions. + Once Covered Code has been published under a particular version of the + License, You may always continue to use it under the terms of that + version. You may also choose to use such Covered Code under the terms + of any subsequent version of the License published by Netscape. No one + other than Netscape has the right to modify the terms applicable to + Covered Code created under this License. + + 6.3. Derivative Works. + If You create or use a modified version of this License (which you may + only do in order to apply it to code which is not already Covered Code + governed by this License), You must (a) rename Your license so that + the phrases "Mozilla", "MOZILLAPL", "MOZPL", "Netscape", + "MPL", "NPL" or any confusingly similar phrase do not appear in your + license (except to note that your license differs from this License) + and (b) otherwise make it clear that Your version of the license + contains terms which differ from the Mozilla Public License and + Netscape Public License. (Filling in the name of the Initial + Developer, Original Code or Contributor in the notice described in + Exhibit A shall not of themselves be deemed to be modifications of + this License.) + +7. DISCLAIMER OF WARRANTY. + + COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, + WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, + WITHOUT LIMITATION, WARRANTIES THAT THE COVERED CODE IS FREE OF + DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE OR NON-INFRINGING. + THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED CODE + IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, + YOU (NOT THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE + COST OF ANY NECESSARY SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER + OF WARRANTY CONSTITUTES AN ESSENTIAL PART OF THIS LICENSE. NO USE OF + ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER THIS DISCLAIMER. + +8. TERMINATION. + + 8.1. This License and the rights granted hereunder will terminate + automatically if You fail to comply with terms herein and fail to cure + such breach within 30 days of becoming aware of the breach. All + sublicenses to the Covered Code which are properly granted shall + survive any termination of this License. Provisions which, by their + nature, must remain in effect beyond the termination of this License + shall survive. + + 8.2. If You initiate litigation by asserting a patent infringement + claim (excluding declatory judgment actions) against Initial Developer + or a Contributor (the Initial Developer or Contributor against whom + You file such action is referred to as "Participant") alleging that: + + (a) such Participant's Contributor Version directly or indirectly + infringes any patent, then any and all rights granted by such + Participant to You under Sections 2.1 and/or 2.2 of this License + shall, upon 60 days notice from Participant terminate prospectively, + unless if within 60 days after receipt of notice You either: (i) + agree in writing to pay Participant a mutually agreeable reasonable + royalty for Your past and future use of Modifications made by such + Participant, or (ii) withdraw Your litigation claim with respect to + the Contributor Version against such Participant. If within 60 days + of notice, a reasonable royalty and payment arrangement are not + mutually agreed upon in writing by the parties or the litigation claim + is not withdrawn, the rights granted by Participant to You under + Sections 2.1 and/or 2.2 automatically terminate at the expiration of + the 60 day notice period specified above. + + (b) any software, hardware, or device, other than such Participant's + Contributor Version, directly or indirectly infringes any patent, then + any rights granted to You by such Participant under Sections 2.1(b) + and 2.2(b) are revoked effective as of the date You first made, used, + sold, distributed, or had made, Modifications made by that + Participant. + + 8.3. If You assert a patent infringement claim against Participant + alleging that such Participant's Contributor Version directly or + indirectly infringes any patent where such claim is resolved (such as + by license or settlement) prior to the initiation of patent + infringement litigation, then the reasonable value of the licenses + granted by such Participant under Sections 2.1 or 2.2 shall be taken + into account in determining the amount or value of any payment or + license. + + 8.4. In the event of termination under Sections 8.1 or 8.2 above, + all end user license agreements (excluding distributors and resellers) + which have been validly granted by You or any distributor hereunder + prior to termination shall survive termination. + +9. LIMITATION OF LIABILITY. + + UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, WHETHER TORT + (INCLUDING NEGLIGENCE), CONTRACT, OR OTHERWISE, SHALL YOU, THE INITIAL + DEVELOPER, ANY OTHER CONTRIBUTOR, OR ANY DISTRIBUTOR OF COVERED CODE, + OR ANY SUPPLIER OF ANY OF SUCH PARTIES, BE LIABLE TO ANY PERSON FOR + ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY + CHARACTER INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF GOODWILL, + WORK STOPPAGE, COMPUTER FAILURE OR MALFUNCTION, OR ANY AND ALL OTHER + COMMERCIAL DAMAGES OR LOSSES, EVEN IF SUCH PARTY SHALL HAVE BEEN + INFORMED OF THE POSSIBILITY OF SUCH DAMAGES. THIS LIMITATION OF + LIABILITY SHALL NOT APPLY TO LIABILITY FOR DEATH OR PERSONAL INJURY + RESULTING FROM SUCH PARTY'S NEGLIGENCE TO THE EXTENT APPLICABLE LAW + PROHIBITS SUCH LIMITATION. SOME JURISDICTIONS DO NOT ALLOW THE + EXCLUSION OR LIMITATION OF INCIDENTAL OR CONSEQUENTIAL DAMAGES, SO + THIS EXCLUSION AND LIMITATION MAY NOT APPLY TO YOU. + +10. U.S. GOVERNMENT END USERS. + + The Covered Code is a "commercial item," as that term is defined in + 48 C.F.R. 2.101 (Oct. 1995), consisting of "commercial computer + software" and "commercial computer software documentation," as such + terms are used in 48 C.F.R. 12.212 (Sept. 1995). Consistent with 48 + C.F.R. 12.212 and 48 C.F.R. 227.7202-1 through 227.7202-4 (June 1995), + all U.S. Government End Users acquire Covered Code with only those + rights set forth herein. + +11. MISCELLANEOUS. + + This License represents the complete agreement concerning subject + matter hereof. If any provision of this License is held to be + unenforceable, such provision shall be reformed only to the extent + necessary to make it enforceable. This License shall be governed by + California law provisions (except to the extent applicable law, if + any, provides otherwise), excluding its conflict-of-law provisions. + With respect to disputes in which at least one party is a citizen of, + or an entity chartered or registered to do business in the United + States of America, any litigation relating to this License shall be + subject to the jurisdiction of the Federal Courts of the Northern + District of California, with venue lying in Santa Clara County, + California, with the losing party responsible for costs, including + without limitation, court costs and reasonable attorneys' fees and + expenses. The application of the United Nations Convention on + Contracts for the International Sale of Goods is expressly excluded. + Any law or regulation which provides that the language of a contract + shall be construed against the drafter shall not apply to this + License. + +12. RESPONSIBILITY FOR CLAIMS. + + As between Initial Developer and the Contributors, each party is + responsible for claims and damages arising, directly or indirectly, + out of its utilization of rights under this License and You agree to + work with Initial Developer and Contributors to distribute such + responsibility on an equitable basis. Nothing herein is intended or + shall be deemed to constitute any admission of liability. + +13. MULTIPLE-LICENSED CODE. + + Initial Developer may designate portions of the Covered Code as + "Multiple-Licensed". "Multiple-Licensed" means that the Initial + Developer permits you to utilize portions of the Covered Code under + Your choice of the NPL or the alternative licenses, if any, specified + by the Initial Developer in the file described in Exhibit A. + +EXHIBIT A -Mozilla Public License. + + ``The contents of this file are subject to the Mozilla Public License + Version 1.1 (the "License"); you may not use this file except in + compliance with the License. You may obtain a copy of the License at + http://www.mozilla.org/MPL/ + + Software distributed under the License is distributed on an "AS IS" + basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the + License for the specific language governing rights and limitations + under the License. + + The Original Code is ______________________________________. + + The Initial Developer of the Original Code is ________________________. + Portions created by ______________________ are Copyright (C) ______ + _______________________. All Rights Reserved. + + Contributor(s): ______________________________________. + + Alternatively, the contents of this file may be used under the terms + of the _____ license (the "[___] License"), in which case the + provisions of [______] License are applicable instead of those + above. If you wish to allow use of your version of this file only + under the terms of the [____] License and not to allow others to use + your version of this file under the MPL, indicate your decision by + deleting the provisions above and replace them with the notice and + other provisions required by the [___] License. If you do not delete + the provisions above, a recipient may use your version of this file + under either the MPL or the [___] License." + + [NOTE: The text of this Exhibit A may differ slightly from the text of + the notices in the Source Code files of the Original Code. You should + use the text of this Exhibit A rather than the text found in the + Original Code Source Code for Your Modifications.] + diff --git a/base/mozilla-nss/faq.html b/base/mozilla-nss/faq.html new file mode 100644 index 0000000..176fe8f --- /dev/null +++ b/base/mozilla-nss/faq.html @@ -0,0 +1,364 @@ + + + + + + + + + + + + +NSS FAQ + + + +
+ + +
+
+ +
+
+ + + + +
+

NSS FAQ

+ + +Newsgroup: +mozilla.dev.tech.crypto + + +
+ +

+


+

+ +General Questions + +

+ +Developer Questions + + +Licensing Questions + +

+
General Questions

+

What is Network Security Services (NSS)?

+

NSS is set of libraries, APIs, utilities, and documentation designed +to support cross-platform development of security-enabled client and +server applications. It provides a complete open-source implementation +of the crypto libraries used by Netscape and other companies in the +Netscape 6 browser, server products from iPlanet E-Commerce Solutions, the +Gateway Connected Touch Pad with Instant AOL, and other products. + +

For an +overview of NSS, see Overview of NSS. For detailed information +on the open-source NSS project, see NSS Project Page. + +
+

What can I do with NSS? Is NSS appropriate for +my application?

+

If you want add support for SSL, S/MIME, or other Internet security standards +to your application, you can use Network Security Services (NSS) to do so. Because +NSS provides complete support for all versions of SSL and TLS, it is particularly well-suited +for applications that need to communicate with the many clients and servers +that already support the SSL protocol. +

The PKCS #11 interface included in NSS means that your application can +use hardware accelerators on the server and smart +cards for two-factor authentication. +
+ +

How does NSS compare to OpenSSL?

+ +OpenSSL is an open source project that implements server-side SSL, +TLS, and a general-purpose cryptography library. It does not support PKCS #11. It is based on +the SSLeay library developed by Eric A. Young and Tim J. Hudson. OpenSSL is widely used in +Apache servers and is licensed under an Apache-style licence. + +

NSS supports both server and client applications as well as PKCS #11 and S/MIME. To permit its use +in as many contexts as possible, +NSS is triple-licensed under the Mozilla Public License, the +GNU General Public License, +and the GNU Lesser General Public License. +You may choose to use the code either under the terms of the MPL or the GPL or the LGPL. + +

How does NSS compare to SSLRef?

+SSLRef was an early reference implementation of the SSL protocol. It contains +bugs that were never fixed, doesn't support TLS or or the +new 56-bit export cipher suites, and does not contain the fix to the +Bleichenbacher attack on PKCS#1. + +

Netscape no longer maintains SSLRef or makes it available. It was built as +an example of an SSL implementation, not for creating production applications. + +

NSS was designed from the ground up for use by commercial developers. +It provides a complete software development kit +that uses the same architecture used to support security features in many client +and server products from Netscape and other companies. + +

What platforms and development environments are supported?

+

iPlanet E-Commerce Solutions has certified NSS 3.1 on 18 platforms, including AIX 4.3, HP-UX 11.0, +Red Hat Linux 6.0, Solaris (2.6 or later), Windows NT (4.0 or later), and +Windows 2000. Other contributors are in the process of certifying additional platforms. +The NSS 3.1 API requires C or C++ development environments. + +

For the latest NSS release notes and detailed platform information, see +NSS 3.1 Release Notes. + +

What cryptography standards does NSS support?

+

NSS supports SSL v2 and v3, + TLS, + PKCS #5, + PKCS #7, + PKCS #11, + PKCS #12, + S/MIME, and + X.509 v3 certificates. +For complete details, +see +Encryption Technologies. + +

What is the relationship between NSS and PSM?

+ +Personal Security Manager (PSM) is built on top of NSS. It consists of libraries +and a daemon designed to support cross-platform development of security-enabled +client applications. The PSM binary provides a client module +that performs cryptographic operations on behalf of applications. +Netscape Personal Security Manager ships with Netscape 6 and the Gateway Connected Touch Pad with Instant AOL, +and is also available for use with Communicagotr 4.7x. + +

For more information about the PSM open-source project, see Personal Security Manager. + +

Where can I get the source code?

+ +For instructions on how to check out and build the NSS 3.1 source code, see +Build Instructions for NSS 3.1. The source code may also +be downloaded as a tar file from +ftp://ftp.mozilla.org/pub/mozilla.org/security/. + +

How much does it cost?

+ +NSS source code and binaries (when they become available) are completely free. No license fees, +no royalty fees, no subscription fees. + + +

+
Developer Questions

+ +

What hardware accelerators are supported?

+

NSS supports the PKCS #11 interface for hardware acceleration. Since leading accelerator vendors such as +Chrysalis-IT, nCipher, and Rainbow Technologies also support this interface, NSS-enabled applications +can support a wide variety of hardware accelerators. +

How do I integrate smart cards into my application using +NSS?

+

NSS supports the PKCS #11 interface for smart card integration. Applications that use the PKCS #11 +interface provided by NSS will therefore support smart cards from leading vendors such as +ActiveCard, Litronic, and SecureID Technologies that also support the PKCS #11 interface. + +

How is NSS compatible with other Netscape products?

+

NSS provides tight integration with other Netscape products in two ways. +First, by using NSS to implement SSL and TLS, you can support SSL communications +with all products from Netscape and all other vendors +that support SSL and TLS. Second, NSS makes it easy +to share certificates between Netscape client and server products +and your application. + +

Does NSS require Netscape Portable Runtime (NSPR)?

+

To provide cross-platform support, NSS utilizes Netscape Portable Runtime +(NSPR) libraries as a portability interface and implementation that +provides consistent cross-platform semantics for network I/O and threading +models. You can use NSPR throughout your application or +only in the portion that calls into NSS. Netscape strongly recommends that +multithreaded applications use the NSPR or native OS threading model. (In +recent NSPR releases, the NSPR threading model is compatible with the native +threading model if the OS has native threads.) Alternatively, you can adapt +the open-source NSPR implementation to be compatible with your existing +application's threading models. More information about NSPR may be found at +Netscape Portable Runtime. +
+ +

Can I use NSS even if my application protocol isn't +HTTP?

+

Yes, SSL independent of application protocols. It works with common +Internet standard application protocols (HTTP, POP3, FTP, SMTP, etc.) as +well as custom application protocols using TCP/IP. + +
+

How long does it take to integrate NSS into my application?

+

The integration effort depends on an number of factors, such as developer +skill set, application complexity, and the level of security required for +your application. NSS includes detailed documentation of the SSL API and +sample code that demonstrates basic SSL functionality (setting up an encrypted +session, server authentication, and client authentication) to help jump start the +integration process. However, there is little or no documentation currently +available for the rest of the NSS API. If your application requires sophisticated +certificate management, smart card support, or hardware acceleration, your +integration effort will be more extensive. + +

Where can I download the NSS tools?

+ +Currently, you must download the NSS source and build it to create binary files for the NSS tools. +For more information, see NSS Tools. + + +

How can I learn more about SSL?

+ +NSS provides extensive documentation related to SSL, including high-level introductions, +detailed API documentation, sample code for simple client and server +applications, the original SSL 3.0 specification, and +information on debugging SSL applications. For details, see the +SSL/TLS Project Page. For information about the NSS tools, including those used +for debugging SSL applications, see +NSS Security Tools. + +

+
Licensing Questions

+

How is NSS licensed?

+

NSS is triple-licensed under the Mozilla Public License, the +GNU General Public License, +and the GNU Lesser General Public License. +For more details, see the Mozilla Crypto FAQ. + +

Is NSS available outside the United States?

+

Yes; see +Build Instructions for NSS 3.1. and +ftp://ftp.mozilla.org/pub/mozilla.org/security/. +However, NSS source code is subject to the U.S. Export +Administration Regulations and other U.S. law, and may not be exported or +re-exported to certain +countries (currently Cuba, Iran, Libya, North Korea, Sudan and Syria) or +to persons or entities prohibited from receiving U.S. exports (including +those (a) on the Bureau of Industry and Security Denied Parties List or +Entity List, (b) on the Office of Foreign Assets Control list of Specially +Designated Nationals and Blocked Persons, and (c) involved with missile +technology or nuclear, chemical or biological weapons). + +

For more information about U.S. export controls on encryption software, +see the Mozilla Crypto FAQ. + + + + + +


+
+
+ +
+ + diff --git a/base/mozilla-nss/gpl-2.0.txt b/base/mozilla-nss/gpl-2.0.txt new file mode 100644 index 0000000..d511905 --- /dev/null +++ b/base/mozilla-nss/gpl-2.0.txt @@ -0,0 +1,339 @@ + GNU GENERAL PUBLIC LICENSE + Version 2, June 1991 + + Copyright (C) 1989, 1991 Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +License is intended to guarantee your freedom to share and change free +software--to make sure the software is free for all its users. This +General Public License applies to most of the Free Software +Foundation's software and to any other program whose authors commit to +using it. (Some other Free Software Foundation software is covered by +the GNU Lesser General Public License instead.) You can apply it to +your programs, too. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +this service if you wish), that you receive source code or can get it +if you want it, that you can change the software or use pieces of it +in new free programs; and that you know you can do these things. + + To protect your rights, we need to make restrictions that forbid +anyone to deny you these rights or to ask you to surrender the rights. +These restrictions translate to certain responsibilities for you if you +distribute copies of the software, or if you modify it. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must give the recipients all the rights that +you have. You must make sure that they, too, receive or can get the +source code. And you must show them these terms so they know their +rights. + + We protect your rights with two steps: (1) copyright the software, and +(2) offer you this license which gives you legal permission to copy, +distribute and/or modify the software. + + Also, for each author's protection and ours, we want to make certain +that everyone understands that there is no warranty for this free +software. If the software is modified by someone else and passed on, we +want its recipients to know that what they have is not the original, so +that any problems introduced by others will not reflect on the original +authors' reputations. + + Finally, any free program is threatened constantly by software +patents. We wish to avoid the danger that redistributors of a free +program will individually obtain patent licenses, in effect making the +program proprietary. To prevent this, we have made it clear that any +patent must be licensed for everyone's free use or not licensed at all. + + The precise terms and conditions for copying, distribution and +modification follow. + + GNU GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License applies to any program or other work which contains +a notice placed by the copyright holder saying it may be distributed +under the terms of this General Public License. The "Program", below, +refers to any such program or work, and a "work based on the Program" +means either the Program or any derivative work under copyright law: +that is to say, a work containing the Program or a portion of it, +either verbatim or with modifications and/or translated into another +language. (Hereinafter, translation is included without limitation in +the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running the Program is not restricted, and the output from the Program +is covered only if its contents constitute a work based on the +Program (independent of having been made by running the Program). +Whether that is true depends on what the Program does. + + 1. You may copy and distribute verbatim copies of the Program's +source code as you receive it, in any medium, provided that you +conspicuously and appropriately publish on each copy an appropriate +copyright notice and disclaimer of warranty; keep intact all the +notices that refer to this License and to the absence of any warranty; +and give any other recipients of the Program a copy of this License +along with the Program. + +You may charge a fee for the physical act of transferring a copy, and +you may at your option offer warranty protection in exchange for a fee. + + 2. You may modify your copy or copies of the Program or any portion +of it, thus forming a work based on the Program, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices + stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in + whole or in part contains or is derived from the Program or any + part thereof, to be licensed as a whole at no charge to all third + parties under the terms of this License. + + c) If the modified program normally reads commands interactively + when run, you must cause it, when started running for such + interactive use in the most ordinary way, to print or display an + announcement including an appropriate copyright notice and a + notice that there is no warranty (or else, saying that you provide + a warranty) and that users may redistribute the program under + these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but + does not normally print such an announcement, your work based on + the Program is not required to print an announcement.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Program, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Program, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program +with the Program (or with a work based on the Program) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may copy and distribute the Program (or a work based on it, +under Section 2) in object code or executable form under the terms of +Sections 1 and 2 above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable + source code, which must be distributed under the terms of Sections + 1 and 2 above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three + years, to give any third party, for a charge no more than your + cost of physically performing source distribution, a complete + machine-readable copy of the corresponding source code, to be + distributed under the terms of Sections 1 and 2 above on a medium + customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer + to distribute corresponding source code. (This alternative is + allowed only for noncommercial distribution and only if you + received the program in object code or executable form with such + an offer, in accord with Subsection b above.) + +The source code for a work means the preferred form of the work for +making modifications to it. For an executable work, complete source +code means all the source code for all modules it contains, plus any +associated interface definition files, plus the scripts used to +control compilation and installation of the executable. However, as a +special exception, the source code distributed need not include +anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the +operating system on which the executable runs, unless that component +itself accompanies the executable. + +If distribution of executable or object code is made by offering +access to copy from a designated place, then offering equivalent +access to copy the source code from the same place counts as +distribution of the source code, even though third parties are not +compelled to copy the source along with the object code. + + 4. You may not copy, modify, sublicense, or distribute the Program +except as expressly provided under this License. Any attempt +otherwise to copy, modify, sublicense or distribute the Program is +void, and will automatically terminate your rights under this License. +However, parties who have received copies, or rights, from you under +this License will not have their licenses terminated so long as such +parties remain in full compliance. + + 5. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Program or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Program (or any work based on the +Program), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Program or works based on it. + + 6. Each time you redistribute the Program (or any work based on the +Program), the recipient automatically receives a license from the +original licensor to copy, distribute or modify the Program subject to +these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties to +this License. + + 7. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Program at all. For example, if a patent +license would not permit royalty-free redistribution of the Program by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Program. + +If any portion of this section is held invalid or unenforceable under +any particular circumstance, the balance of the section is intended to +apply and the section as a whole is intended to apply in other +circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system, which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 8. If the distribution and/or use of the Program is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Program under this License +may add an explicit geographical distribution limitation excluding +those countries, so that distribution is permitted only in or among +countries not thus excluded. In such case, this License incorporates +the limitation as if written in the body of this License. + + 9. The Free Software Foundation may publish revised and/or new versions +of the General Public License from time to time. Such new versions will +be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + +Each version is given a distinguishing version number. If the Program +specifies a version number of this License which applies to it and "any +later version", you have the option of following the terms and conditions +either of that version or of any later version published by the Free +Software Foundation. If the Program does not specify a version number of +this License, you may choose any version ever published by the Free Software +Foundation. + + 10. If you wish to incorporate parts of the Program into other free +programs whose distribution conditions are different, write to the author +to ask for permission. For software which is copyrighted by the Free +Software Foundation, write to the Free Software Foundation; we sometimes +make exceptions for this. Our decision will be guided by the two goals +of preserving the free status of all derivatives of our free software and +of promoting the sharing and reuse of software generally. + + NO WARRANTY + + 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY +FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN +OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES +PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED +OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF +MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS +TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE +PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, +REPAIR OR CORRECTION. + + 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR +REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING +OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED +TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY +YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER +PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE +POSSIBILITY OF SUCH DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License along + with this program; if not, write to the Free Software Foundation, Inc., + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. + +Also add information on how to contact you by electronic and paper mail. + +If the program is interactive, make it output a short notice like this +when it starts in an interactive mode: + + Gnomovision version 69, Copyright (C) year name of author + Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, the commands you use may +be called something other than `show w' and `show c'; they could even be +mouse-clicks or menu items--whatever suits your program. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the program, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the program + `Gnomovision' (which makes passes at compilers) written by James Hacker. + + , 1 April 1989 + Ty Coon, President of Vice + +This General Public License does not permit incorporating your program into +proprietary programs. If your program is a subroutine library, you may +consider it more useful to permit linking proprietary applications with the +library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. diff --git a/base/mozilla-nss/lgpl-2.1.txt b/base/mozilla-nss/lgpl-2.1.txt new file mode 100644 index 0000000..602bfc9 --- /dev/null +++ b/base/mozilla-nss/lgpl-2.1.txt @@ -0,0 +1,504 @@ + GNU LESSER GENERAL PUBLIC LICENSE + Version 2.1, February 1999 + + Copyright (C) 1991, 1999 Free Software Foundation, Inc. + 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + +[This is the first released version of the Lesser GPL. It also counts + as the successor of the GNU Library Public License, version 2, hence + the version number 2.1.] + + Preamble + + The licenses for most software are designed to take away your +freedom to share and change it. By contrast, the GNU General Public +Licenses are intended to guarantee your freedom to share and change +free software--to make sure the software is free for all its users. + + This license, the Lesser General Public License, applies to some +specially designated software packages--typically libraries--of the +Free Software Foundation and other authors who decide to use it. You +can use it too, but we suggest you first think carefully about whether +this license or the ordinary General Public License is the better +strategy to use in any particular case, based on the explanations below. + + When we speak of free software, we are referring to freedom of use, +not price. Our General Public Licenses are designed to make sure that +you have the freedom to distribute copies of free software (and charge +for this service if you wish); that you receive source code or can get +it if you want it; that you can change the software and use pieces of +it in new free programs; and that you are informed that you can do +these things. + + To protect your rights, we need to make restrictions that forbid +distributors to deny you these rights or to ask you to surrender these +rights. These restrictions translate to certain responsibilities for +you if you distribute copies of the library or if you modify it. + + For example, if you distribute copies of the library, whether gratis +or for a fee, you must give the recipients all the rights that we gave +you. You must make sure that they, too, receive or can get the source +code. If you link other code with the library, you must provide +complete object files to the recipients, so that they can relink them +with the library after making changes to the library and recompiling +it. And you must show them these terms so they know their rights. + + We protect your rights with a two-step method: (1) we copyright the +library, and (2) we offer you this license, which gives you legal +permission to copy, distribute and/or modify the library. + + To protect each distributor, we want to make it very clear that +there is no warranty for the free library. Also, if the library is +modified by someone else and passed on, the recipients should know +that what they have is not the original version, so that the original +author's reputation will not be affected by problems that might be +introduced by others. + + Finally, software patents pose a constant threat to the existence of +any free program. We wish to make sure that a company cannot +effectively restrict the users of a free program by obtaining a +restrictive license from a patent holder. Therefore, we insist that +any patent license obtained for a version of the library must be +consistent with the full freedom of use specified in this license. + + Most GNU software, including some libraries, is covered by the +ordinary GNU General Public License. This license, the GNU Lesser +General Public License, applies to certain designated libraries, and +is quite different from the ordinary General Public License. We use +this license for certain libraries in order to permit linking those +libraries into non-free programs. + + When a program is linked with a library, whether statically or using +a shared library, the combination of the two is legally speaking a +combined work, a derivative of the original library. The ordinary +General Public License therefore permits such linking only if the +entire combination fits its criteria of freedom. The Lesser General +Public License permits more lax criteria for linking other code with +the library. + + We call this license the "Lesser" General Public License because it +does Less to protect the user's freedom than the ordinary General +Public License. It also provides other free software developers Less +of an advantage over competing non-free programs. These disadvantages +are the reason we use the ordinary General Public License for many +libraries. However, the Lesser license provides advantages in certain +special circumstances. + + For example, on rare occasions, there may be a special need to +encourage the widest possible use of a certain library, so that it becomes +a de-facto standard. To achieve this, non-free programs must be +allowed to use the library. A more frequent case is that a free +library does the same job as widely used non-free libraries. In this +case, there is little to gain by limiting the free library to free +software only, so we use the Lesser General Public License. + + In other cases, permission to use a particular library in non-free +programs enables a greater number of people to use a large body of +free software. For example, permission to use the GNU C Library in +non-free programs enables many more people to use the whole GNU +operating system, as well as its variant, the GNU/Linux operating +system. + + Although the Lesser General Public License is Less protective of the +users' freedom, it does ensure that the user of a program that is +linked with the Library has the freedom and the wherewithal to run +that program using a modified version of the Library. + + The precise terms and conditions for copying, distribution and +modification follow. Pay close attention to the difference between a +"work based on the library" and a "work that uses the library". The +former contains code derived from the library, whereas the latter must +be combined with the library in order to run. + + GNU LESSER GENERAL PUBLIC LICENSE + TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + + 0. This License Agreement applies to any software library or other +program which contains a notice placed by the copyright holder or +other authorized party saying it may be distributed under the terms of +this Lesser General Public License (also called "this License"). +Each licensee is addressed as "you". + + A "library" means a collection of software functions and/or data +prepared so as to be conveniently linked with application programs +(which use some of those functions and data) to form executables. + + The "Library", below, refers to any such software library or work +which has been distributed under these terms. A "work based on the +Library" means either the Library or any derivative work under +copyright law: that is to say, a work containing the Library or a +portion of it, either verbatim or with modifications and/or translated +straightforwardly into another language. (Hereinafter, translation is +included without limitation in the term "modification".) + + "Source code" for a work means the preferred form of the work for +making modifications to it. For a library, complete source code means +all the source code for all modules it contains, plus any associated +interface definition files, plus the scripts used to control compilation +and installation of the library. + + Activities other than copying, distribution and modification are not +covered by this License; they are outside its scope. The act of +running a program using the Library is not restricted, and output from +such a program is covered only if its contents constitute a work based +on the Library (independent of the use of the Library in a tool for +writing it). Whether that is true depends on what the Library does +and what the program that uses the Library does. + + 1. You may copy and distribute verbatim copies of the Library's +complete source code as you receive it, in any medium, provided that +you conspicuously and appropriately publish on each copy an +appropriate copyright notice and disclaimer of warranty; keep intact +all the notices that refer to this License and to the absence of any +warranty; and distribute a copy of this License along with the +Library. + + You may charge a fee for the physical act of transferring a copy, +and you may at your option offer warranty protection in exchange for a +fee. + + 2. You may modify your copy or copies of the Library or any portion +of it, thus forming a work based on the Library, and copy and +distribute such modifications or work under the terms of Section 1 +above, provided that you also meet all of these conditions: + + a) The modified work must itself be a software library. + + b) You must cause the files modified to carry prominent notices + stating that you changed the files and the date of any change. + + c) You must cause the whole of the work to be licensed at no + charge to all third parties under the terms of this License. + + d) If a facility in the modified Library refers to a function or a + table of data to be supplied by an application program that uses + the facility, other than as an argument passed when the facility + is invoked, then you must make a good faith effort to ensure that, + in the event an application does not supply such function or + table, the facility still operates, and performs whatever part of + its purpose remains meaningful. + + (For example, a function in a library to compute square roots has + a purpose that is entirely well-defined independent of the + application. Therefore, Subsection 2d requires that any + application-supplied function or table used by this function must + be optional: if the application does not supply it, the square + root function must still compute square roots.) + +These requirements apply to the modified work as a whole. If +identifiable sections of that work are not derived from the Library, +and can be reasonably considered independent and separate works in +themselves, then this License, and its terms, do not apply to those +sections when you distribute them as separate works. But when you +distribute the same sections as part of a whole which is a work based +on the Library, the distribution of the whole must be on the terms of +this License, whose permissions for other licensees extend to the +entire whole, and thus to each and every part regardless of who wrote +it. + +Thus, it is not the intent of this section to claim rights or contest +your rights to work written entirely by you; rather, the intent is to +exercise the right to control the distribution of derivative or +collective works based on the Library. + +In addition, mere aggregation of another work not based on the Library +with the Library (or with a work based on the Library) on a volume of +a storage or distribution medium does not bring the other work under +the scope of this License. + + 3. You may opt to apply the terms of the ordinary GNU General Public +License instead of this License to a given copy of the Library. To do +this, you must alter all the notices that refer to this License, so +that they refer to the ordinary GNU General Public License, version 2, +instead of to this License. (If a newer version than version 2 of the +ordinary GNU General Public License has appeared, then you can specify +that version instead if you wish.) Do not make any other change in +these notices. + + Once this change is made in a given copy, it is irreversible for +that copy, so the ordinary GNU General Public License applies to all +subsequent copies and derivative works made from that copy. + + This option is useful when you wish to copy part of the code of +the Library into a program that is not a library. + + 4. You may copy and distribute the Library (or a portion or +derivative of it, under Section 2) in object code or executable form +under the terms of Sections 1 and 2 above provided that you accompany +it with the complete corresponding machine-readable source code, which +must be distributed under the terms of Sections 1 and 2 above on a +medium customarily used for software interchange. + + If distribution of object code is made by offering access to copy +from a designated place, then offering equivalent access to copy the +source code from the same place satisfies the requirement to +distribute the source code, even though third parties are not +compelled to copy the source along with the object code. + + 5. A program that contains no derivative of any portion of the +Library, but is designed to work with the Library by being compiled or +linked with it, is called a "work that uses the Library". Such a +work, in isolation, is not a derivative work of the Library, and +therefore falls outside the scope of this License. + + However, linking a "work that uses the Library" with the Library +creates an executable that is a derivative of the Library (because it +contains portions of the Library), rather than a "work that uses the +library". The executable is therefore covered by this License. +Section 6 states terms for distribution of such executables. + + When a "work that uses the Library" uses material from a header file +that is part of the Library, the object code for the work may be a +derivative work of the Library even though the source code is not. +Whether this is true is especially significant if the work can be +linked without the Library, or if the work is itself a library. The +threshold for this to be true is not precisely defined by law. + + If such an object file uses only numerical parameters, data +structure layouts and accessors, and small macros and small inline +functions (ten lines or less in length), then the use of the object +file is unrestricted, regardless of whether it is legally a derivative +work. (Executables containing this object code plus portions of the +Library will still fall under Section 6.) + + Otherwise, if the work is a derivative of the Library, you may +distribute the object code for the work under the terms of Section 6. +Any executables containing that work also fall under Section 6, +whether or not they are linked directly with the Library itself. + + 6. As an exception to the Sections above, you may also combine or +link a "work that uses the Library" with the Library to produce a +work containing portions of the Library, and distribute that work +under terms of your choice, provided that the terms permit +modification of the work for the customer's own use and reverse +engineering for debugging such modifications. + + You must give prominent notice with each copy of the work that the +Library is used in it and that the Library and its use are covered by +this License. You must supply a copy of this License. If the work +during execution displays copyright notices, you must include the +copyright notice for the Library among them, as well as a reference +directing the user to the copy of this License. Also, you must do one +of these things: + + a) Accompany the work with the complete corresponding + machine-readable source code for the Library including whatever + changes were used in the work (which must be distributed under + Sections 1 and 2 above); and, if the work is an executable linked + with the Library, with the complete machine-readable "work that + uses the Library", as object code and/or source code, so that the + user can modify the Library and then relink to produce a modified + executable containing the modified Library. (It is understood + that the user who changes the contents of definitions files in the + Library will not necessarily be able to recompile the application + to use the modified definitions.) + + b) Use a suitable shared library mechanism for linking with the + Library. A suitable mechanism is one that (1) uses at run time a + copy of the library already present on the user's computer system, + rather than copying library functions into the executable, and (2) + will operate properly with a modified version of the library, if + the user installs one, as long as the modified version is + interface-compatible with the version that the work was made with. + + c) Accompany the work with a written offer, valid for at + least three years, to give the same user the materials + specified in Subsection 6a, above, for a charge no more + than the cost of performing this distribution. + + d) If distribution of the work is made by offering access to copy + from a designated place, offer equivalent access to copy the above + specified materials from the same place. + + e) Verify that the user has already received a copy of these + materials or that you have already sent this user a copy. + + For an executable, the required form of the "work that uses the +Library" must include any data and utility programs needed for +reproducing the executable from it. However, as a special exception, +the materials to be distributed need not include anything that is +normally distributed (in either source or binary form) with the major +components (compiler, kernel, and so on) of the operating system on +which the executable runs, unless that component itself accompanies +the executable. + + It may happen that this requirement contradicts the license +restrictions of other proprietary libraries that do not normally +accompany the operating system. Such a contradiction means you cannot +use both them and the Library together in an executable that you +distribute. + + 7. You may place library facilities that are a work based on the +Library side-by-side in a single library together with other library +facilities not covered by this License, and distribute such a combined +library, provided that the separate distribution of the work based on +the Library and of the other library facilities is otherwise +permitted, and provided that you do these two things: + + a) Accompany the combined library with a copy of the same work + based on the Library, uncombined with any other library + facilities. This must be distributed under the terms of the + Sections above. + + b) Give prominent notice with the combined library of the fact + that part of it is a work based on the Library, and explaining + where to find the accompanying uncombined form of the same work. + + 8. You may not copy, modify, sublicense, link with, or distribute +the Library except as expressly provided under this License. Any +attempt otherwise to copy, modify, sublicense, link with, or +distribute the Library is void, and will automatically terminate your +rights under this License. However, parties who have received copies, +or rights, from you under this License will not have their licenses +terminated so long as such parties remain in full compliance. + + 9. You are not required to accept this License, since you have not +signed it. However, nothing else grants you permission to modify or +distribute the Library or its derivative works. These actions are +prohibited by law if you do not accept this License. Therefore, by +modifying or distributing the Library (or any work based on the +Library), you indicate your acceptance of this License to do so, and +all its terms and conditions for copying, distributing or modifying +the Library or works based on it. + + 10. Each time you redistribute the Library (or any work based on the +Library), the recipient automatically receives a license from the +original licensor to copy, distribute, link with or modify the Library +subject to these terms and conditions. You may not impose any further +restrictions on the recipients' exercise of the rights granted herein. +You are not responsible for enforcing compliance by third parties with +this License. + + 11. If, as a consequence of a court judgment or allegation of patent +infringement or for any other reason (not limited to patent issues), +conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot +distribute so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you +may not distribute the Library at all. For example, if a patent +license would not permit royalty-free redistribution of the Library by +all those who receive copies directly or indirectly through you, then +the only way you could satisfy both it and this License would be to +refrain entirely from distribution of the Library. + +If any portion of this section is held invalid or unenforceable under any +particular circumstance, the balance of the section is intended to apply, +and the section as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any +patents or other property right claims or to contest validity of any +such claims; this section has the sole purpose of protecting the +integrity of the free software distribution system which is +implemented by public license practices. Many people have made +generous contributions to the wide range of software distributed +through that system in reliance on consistent application of that +system; it is up to the author/donor to decide if he or she is willing +to distribute software through any other system and a licensee cannot +impose that choice. + +This section is intended to make thoroughly clear what is believed to +be a consequence of the rest of this License. + + 12. If the distribution and/or use of the Library is restricted in +certain countries either by patents or by copyrighted interfaces, the +original copyright holder who places the Library under this License may add +an explicit geographical distribution limitation excluding those countries, +so that distribution is permitted only in or among countries not thus +excluded. In such case, this License incorporates the limitation as if +written in the body of this License. + + 13. The Free Software Foundation may publish revised and/or new +versions of the Lesser General Public License from time to time. +Such new versions will be similar in spirit to the present version, +but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Library +specifies a version number of this License which applies to it and +"any later version", you have the option of following the terms and +conditions either of that version or of any later version published by +the Free Software Foundation. If the Library does not specify a +license version number, you may choose any version ever published by +the Free Software Foundation. + + 14. If you wish to incorporate parts of the Library into other free +programs whose distribution conditions are incompatible with these, +write to the author to ask for permission. For software which is +copyrighted by the Free Software Foundation, write to the Free +Software Foundation; we sometimes make exceptions for this. Our +decision will be guided by the two goals of preserving the free status +of all derivatives of our free software and of promoting the sharing +and reuse of software generally. + + NO WARRANTY + + 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO +WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. +EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR +OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY +KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE +IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE +LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME +THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN +WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY +AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU +FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR +CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE +LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING +RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A +FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF +SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH +DAMAGES. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Libraries + + If you develop a new library, and you want it to be of the greatest +possible use to the public, we recommend making it free software that +everyone can redistribute and change. You can do so by permitting +redistribution under these terms (or, alternatively, under the terms of the +ordinary General Public License). + + To apply these terms, attach the following notices to the library. It is +safest to attach them to the start of each source file to most effectively +convey the exclusion of warranty; and each file should have at least the +"copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + This library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + +Also add information on how to contact you by electronic and paper mail. + +You should also get your employer (if you work as a programmer) or your +school, if any, to sign a "copyright disclaimer" for the library, if +necessary. Here is a sample; alter the names: + + Yoyodyne, Inc., hereby disclaims all copyright interest in the + library `Frob' (a library for tweaking knobs) written by James Random Hacker. + + , 1 April 1990 + Ty Coon, President of Vice + +That's all there is to it! + + diff --git a/base/mozilla-nss/mozilla-nss.SMBuild b/base/mozilla-nss/mozilla-nss.SMBuild new file mode 100755 index 0000000..055b096 --- /dev/null +++ b/base/mozilla-nss/mozilla-nss.SMBuild @@ -0,0 +1,111 @@ +APP=mozilla-nss +VERSION=3.73.1 +NSPRVERSION=4.32 +BUILD=1sml +HOMEPAGE='https://mozilla.org' +DESC="set of cryptographic libraries from Mozilla for use in security-focused applications" +REQUIRES="gyp" + +NJOBS="(echo $MAKEFLAGS | sed 's/-j//')" + +build() { + mkandenterbuilddir + rm -rf nss-$VERSION + rm -rf nspr-* + + tar xf $SRCDIR/nss-$VERSION.tar.?z* + cd nss-$VERSION + tar xf $SRCDIR/nspr-$NSPRVERSION.tar.?z* + mv nspr*/nspr . + fixbuilddirpermissions + + # NSS doesn't like our ARM64-specific optimization C/CXXFLAGS + if [ "$ARCH" == "aarch64" ] ; then + unset CFLAGS CXXFLAGS + fi + + # Disable Werror + export NSS_ENABLE_WERROR=0 + + # Disable deprecated ciphers + export NSS_DISABLE_DEPRECATED_SEED=1 + export NSS_DISABLE_DEPRECATED_RC2=1 + + cd nss + ./build.sh -v -j 8 --opt --system-sqlite --enable-libpkix --disable-tests + cd - + + # Install all the needed stuff to the package directory + mkdir -p $PKG/{bin,lib,include/{nss,nspr}} + cd dist/Release + cp -pL bin/{certutil,cmsutil,crlutil,modutil,pk12util,shlibsign,signtool,signver,ssltap} $PKG/bin/ + cp -pL lib/*.{so,a} $PKG/lib/ + chmod 755 $PKG/lib/*.so* + cp -rL include/* $PKG/include/ + cp -rpL ../public/nss/*.h $PKG/include/nss/ + + cd - + + cd nss/cmd/smimetools + install -m 755 smime $PKG/bin/smime + sed -i -e 's#/usr/local/bin#/bin#g' $PKG/bin/smime + cd - + + # Install nspr-config + cat nspr/Release/config/nspr-config | sed -e "s,^prefix=.*$,prefix=,g" > $PKG/bin/nspr-config + chmod 755 $PKG/bin/nspr-config + + # Install nss-config + sed -e "s,@prefix@,,g" \ + -e "s,@MOD_MAJOR_VERSION@,$(printf $VERSION | cut -d. -f1),g" \ + -e "s,@MOD_MAJOR_VERSION@,$(printf $VERSION | cut -d. -f2),g" \ + -e "s,@MOD_MAJOR_VERSION@,$(printf $VERSION | cut -d. -f3),g" \ + $SRCDIR/nss-config.in > $PKG/bin/nss-config + chmod 755 $PKG/bin/nss-config + + # Provide pkg-config files + mkdir -p $PKG/lib/pkgconfig + cat < $PKG/lib/pkgconfig/mozilla-nss.pc +prefix= +exec_prefix=\${prefix} +libdir=/lib +includedir=\${prefix}/include/nss + +Name: NSS +Description: Network Security Services +Version: $VERSION +Requires: nspr >= $NSPRVERSION sqlite3 +Libs: -L\${libdir} -lnss3 -lsmime3 -lssl3 -lsoftokn3 -lnssutil3 +Cflags: -I\${includedir} +EOT + + cat < $PKG/lib/pkgconfig/mozilla-nspr.pc +prefix= +exec_prefix=\${prefix} +libdir=/lib +includedir=\${prefix}/include/nspr + +Name: NSPR +Description: The Netscape Portable Runtime +Version: $NSPRVERSION +Libs: -L\${libdir} -lplds4 -lplc4 -lnspr4 +Cflags: -I\${includedir} +EOT + + # Create pkgconfig symlinks + ( + cd $PKG/lib/pkgconfig + ln -s mozilla-nspr.pc nspr.pc + ln -s mozilla-nss.pc nss.pc + ) + + cp -a $SRCDIR/{MPL-1.1.txt,gpl-2.0.txt,lgpl-2.1.txt} $PKGDOCS/ + removestaticlibs + + mkfinalpkg +} + +SHA512SUMS=" +f9d9f04f2ae95d569d100561db57b00c2ecc305ddff89698cb6c82352e5a279354546d4df12598bdac1b619bedfdb3b491120a364b959a591a2fbd3f7e40a705 nspr-4.32.tar.lz +3987f82d8d75eb18721ba94cd86261fbf3f61d2d21687fc975d9753b5b722e597ce6f7a5aabd34128b087ddee6aa3691a647f916c2227fd3d783683f4971a814 nss-3.73.1.tar.lz +" diff --git a/base/mozilla-nss/nss-config.in b/base/mozilla-nss/nss-config.in new file mode 100644 index 0000000..f8f893e --- /dev/null +++ b/base/mozilla-nss/nss-config.in @@ -0,0 +1,145 @@ +#!/bin/sh + +prefix=@prefix@ + +major_version=@MOD_MAJOR_VERSION@ +minor_version=@MOD_MINOR_VERSION@ +patch_version=@MOD_PATCH_VERSION@ + +usage() +{ + cat <&2 +fi + +lib_ssl=yes +lib_smime=yes +lib_nss=yes +lib_nssutil=yes + +while test $# -gt 0; do + case "$1" in + -*=*) optarg=`echo "$1" | sed 's/[-_a-zA-Z0-9]*=//'` ;; + *) optarg= ;; + esac + + case $1 in + --prefix=*) + prefix=$optarg + ;; + --prefix) + echo_prefix=yes + ;; + --exec-prefix=*) + exec_prefix=$optarg + ;; + --exec-prefix) + echo_exec_prefix=yes + ;; + --includedir=*) + includedir=$optarg + ;; + --includedir) + echo_includedir=yes + ;; + --libdir=*) + libdir=$optarg + ;; + --libdir) + echo_libdir=yes + ;; + --version) + echo ${major_version}.${minor_version}.${patch_version} + ;; + --cflags) + echo_cflags=yes + ;; + --libs) + echo_libs=yes + ;; + ssl) + lib_ssl=yes + ;; + smime) + lib_smime=yes + ;; + nss) + lib_nss=yes + ;; + nssutil) + lib_nssutil=yes + ;; + *) + usage 1 1>&2 + ;; + esac + shift +done + +# Set variables that may be dependent upon other variables +if test -z "$exec_prefix"; then + exec_prefix=`pkg-config --variable=exec_prefix nss` +fi +if test -z "$includedir"; then + includedir=`pkg-config --variable=includedir nss` +fi +if test -z "$libdir"; then + libdir=`pkg-config --variable=libdir nss` +fi + +if test "$echo_prefix" = "yes"; then + echo $prefix +fi + +if test "$echo_exec_prefix" = "yes"; then + echo $exec_prefix +fi + +if test "$echo_includedir" = "yes"; then + echo $includedir +fi + +if test "$echo_libdir" = "yes"; then + echo $libdir +fi + +if test "$echo_cflags" = "yes"; then + echo -I$includedir +fi + +if test "$echo_libs" = "yes"; then + libdirs="-Wl,-rpath-link,$libdir -L$libdir" + if test -n "$lib_ssl"; then + libdirs="$libdirs -lssl${major_version}" + fi + if test -n "$lib_smime"; then + libdirs="$libdirs -lsmime${major_version}" + fi + if test -n "$lib_nss"; then + libdirs="$libdirs -lnss${major_version}" + fi + if test -n "$lib_nssutil"; then + libdirs="$libdirs -lnssutil${major_version}" + fi + echo $libdirs +fi + diff --git a/base/mpfr/mpfr.SMBuild b/base/mpfr/mpfr.SMBuild new file mode 100755 index 0000000..19de676 --- /dev/null +++ b/base/mpfr/mpfr.SMBuild @@ -0,0 +1,33 @@ +APP=mpfr +VERSION=3.1.6 +BUILD=1sml +HOMEPAGE='https://www.mpfr.org/' +DOWNLOAD='https://ftp.gnu.org/gnu/mpfr/mpfr-3.1.6.tar.xz' +DESC="Multiple-Precision Floating-Point Reliable Library" +REQUIRES="gmp" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="-I/include" \ + LDFLAGS="-L/lib" \ + ./configure \ + --prefix="" \ + --enable-static + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +746ee74d5026f267f74ab352d850ed30ff627d530aa840c71b24793e44875f8503946bd7399905dea2b2dd5744326254d7889337fe94cfe58d03c4066e9d8054 mpfr-3.1.6.tar.xz +" diff --git a/base/mpg123/mpg123.SMBuild b/base/mpg123/mpg123.SMBuild new file mode 100755 index 0000000..bce36a4 --- /dev/null +++ b/base/mpg123/mpg123.SMBuild @@ -0,0 +1,31 @@ +APP=mpg123 +VERSION=1.26.1 +BUILD=1sml +HOMEPAGE='https://www.mpg123.de/' +DOWNLOAD='https://downloads.sourceforge.net/mpg123/mpg123-1.26.1.tar.bz2' +DESC="MPEG audio player for UNIX" +REQUIRES="gcc-libs alsa-lib portaudio" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ddea0573ea6a8f47003af48eabb8e57d9e56ea0a6a1d73046b6484a7a4b12f84572c066c9dcd41a1dfaa4f9d92bfb7bd809c07b00425be9a1dd6cd5efccc6827 mpg123-1.26.1.tar.lz +" diff --git a/base/mtools/mtools.SMBuild b/base/mtools/mtools.SMBuild new file mode 100755 index 0000000..06453a9 --- /dev/null +++ b/base/mtools/mtools.SMBuild @@ -0,0 +1,30 @@ +APP=mtools +VERSION=4.0.24 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/mtools/' +DOWNLOAD='ftp://ftp.gnu.org/gnu/mtools/mtools-4.0.24.tar.lz' +DESC="collection of utilities to access MS-DOS disks without mounting them" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION +# fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --without-x + + make PREFIX="/" DESTDIR=$PKG -j1 all install + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +1d9ece8222f3f0845091dd3647fe8d7c95049bbdca60f7f80a16b20c3c73b6bb86f8ba0d09965949cdbd4b7735651ac2f3ca6ef135d89db590d74149a4636ddc mtools-4.0.24.tar.lz +" diff --git a/base/musl/asm.hwcap.h b/base/musl/asm.hwcap.h new file mode 100644 index 0000000..e9b7a70 --- /dev/null +++ b/base/musl/asm.hwcap.h @@ -0,0 +1,69 @@ +/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ +/* + * Copyright (C) 2012 ARM Ltd. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +#ifndef __ASM_HWCAP_H +#define __ASM_HWCAP_H + +/* + * HWCAP flags - for AT_HWCAP + */ +#define HWCAP_FP (1 << 0) +#define HWCAP_ASIMD (1 << 1) +#define HWCAP_EVTSTRM (1 << 2) +#define HWCAP_AES (1 << 3) +#define HWCAP_PMULL (1 << 4) +#define HWCAP_SHA1 (1 << 5) +#define HWCAP_SHA2 (1 << 6) +#define HWCAP_CRC32 (1 << 7) +#define HWCAP_ATOMICS (1 << 8) +#define HWCAP_FPHP (1 << 9) +#define HWCAP_ASIMDHP (1 << 10) +#define HWCAP_CPUID (1 << 11) +#define HWCAP_ASIMDRDM (1 << 12) +#define HWCAP_JSCVT (1 << 13) +#define HWCAP_FCMA (1 << 14) +#define HWCAP_LRCPC (1 << 15) +#define HWCAP_DCPOP (1 << 16) +#define HWCAP_SHA3 (1 << 17) +#define HWCAP_SM3 (1 << 18) +#define HWCAP_SM4 (1 << 19) +#define HWCAP_ASIMDDP (1 << 20) +#define HWCAP_SHA512 (1 << 21) +#define HWCAP_SVE (1 << 22) +#define HWCAP_ASIMDFHM (1 << 23) +#define HWCAP_DIT (1 << 24) +#define HWCAP_USCAT (1 << 25) +#define HWCAP_ILRCPC (1 << 26) +#define HWCAP_FLAGM (1 << 27) +#define HWCAP_SSBS (1 << 28) +#define HWCAP_SB (1 << 29) +#define HWCAP_PACA (1 << 30) +#define HWCAP_PACG (1UL << 31) + +/* + * HWCAP2 flags - for AT_HWCAP2 + */ +#define HWCAP2_DCPODP (1 << 0) +#define HWCAP2_SVE2 (1 << 1) +#define HWCAP2_SVEAES (1 << 2) +#define HWCAP2_SVEPMULL (1 << 3) +#define HWCAP2_SVEBITPERM (1 << 4) +#define HWCAP2_SVESHA3 (1 << 5) +#define HWCAP2_SVESM4 (1 << 6) +#define HWCAP2_FLAGM2 (1 << 7) +#define HWCAP2_FRINT (1 << 8) + +#endif /* __ASM_HWCAP_H */ diff --git a/base/musl/cdefs.h b/base/musl/cdefs.h new file mode 100644 index 0000000..209a623 --- /dev/null +++ b/base/musl/cdefs.h @@ -0,0 +1,26 @@ +#warning usage of non-standard #include is deprecated + +#undef __P +#undef __PMT + +#define __P(args) args +#define __PMT(args) args + +#define __CONCAT(x,y) x ## y +#define __STRING(x) #x + +#ifdef __cplusplus +# define __BEGIN_DECLS extern "C" { +# define __END_DECLS } +#else +# define __BEGIN_DECLS +# define __END_DECLS +#endif + +#if defined(__GNUC__) && !defined(__cplusplus) +# define __THROW __attribute__ ((__nothrow__)) +# define __NTH(fct) __attribute__ ((__nothrow__)) fct +#else +# define __THROW +# define __NTH(fct) fct +#endif diff --git a/base/musl/getconf.c b/base/musl/getconf.c new file mode 100644 index 0000000..c423524 --- /dev/null +++ b/base/musl/getconf.c @@ -0,0 +1,338 @@ +/*- + * Copyright (c) 1996, 1998 The NetBSD Foundation, Inc. + * All rights reserved. + * + * This code is derived from software contributed to The NetBSD Foundation + * by J.T. Conklin. + * + * Mostly rewritten to be used in Alpine Linux (with musl c-library) + * by Timo Teräs. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS + * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS + * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +struct conf_variable { + const char *name; + enum { SYSCONF, CONFSTR, PATHCONF, CONSTANT, UCONSTANT, NUM_TYPES } type; + long value; +}; + +static const struct conf_variable conf_table[] = { +{ "PATH", CONFSTR, _CS_PATH }, + +/* Utility Limit Minimum Values */ +{ "POSIX2_BC_BASE_MAX", CONSTANT, _POSIX2_BC_BASE_MAX }, +{ "POSIX2_BC_DIM_MAX", CONSTANT, _POSIX2_BC_DIM_MAX }, +{ "POSIX2_BC_SCALE_MAX", CONSTANT, _POSIX2_BC_SCALE_MAX }, +{ "POSIX2_BC_STRING_MAX", CONSTANT, _POSIX2_BC_STRING_MAX }, +{ "POSIX2_COLL_WEIGHTS_MAX", CONSTANT, _POSIX2_COLL_WEIGHTS_MAX }, +{ "POSIX2_EXPR_NEST_MAX", CONSTANT, _POSIX2_EXPR_NEST_MAX }, +{ "POSIX2_LINE_MAX", CONSTANT, _POSIX2_LINE_MAX }, +{ "POSIX2_RE_DUP_MAX", CONSTANT, _POSIX2_RE_DUP_MAX }, +{ "POSIX2_VERSION", CONSTANT, _POSIX2_VERSION }, + +/* POSIX.1 Minimum Values */ +{ "_POSIX_AIO_LISTIO_MAX", CONSTANT, _POSIX_AIO_LISTIO_MAX }, +{ "_POSIX_AIO_MAX", CONSTANT, _POSIX_AIO_MAX }, +{ "_POSIX_ARG_MAX", CONSTANT, _POSIX_ARG_MAX }, +{ "_POSIX_CHILD_MAX", CONSTANT, _POSIX_CHILD_MAX }, +{ "_POSIX_LINK_MAX", CONSTANT, _POSIX_LINK_MAX }, +{ "_POSIX_MAX_CANON", CONSTANT, _POSIX_MAX_CANON }, +{ "_POSIX_MAX_INPUT", CONSTANT, _POSIX_MAX_INPUT }, +{ "_POSIX_MQ_OPEN_MAX", CONSTANT, _POSIX_MQ_OPEN_MAX }, +{ "_POSIX_MQ_PRIO_MAX", CONSTANT, _POSIX_MQ_PRIO_MAX }, +{ "_POSIX_NAME_MAX", CONSTANT, _POSIX_NAME_MAX }, +{ "_POSIX_NGROUPS_MAX", CONSTANT, _POSIX_NGROUPS_MAX }, +{ "_POSIX_OPEN_MAX", CONSTANT, _POSIX_OPEN_MAX }, +{ "_POSIX_PATH_MAX", CONSTANT, _POSIX_PATH_MAX }, +{ "_POSIX_PIPE_BUF", CONSTANT, _POSIX_PIPE_BUF }, +{ "_POSIX_SSIZE_MAX", CONSTANT, _POSIX_SSIZE_MAX }, +{ "_POSIX_STREAM_MAX", CONSTANT, _POSIX_STREAM_MAX }, +{ "_POSIX_TZNAME_MAX", CONSTANT, _POSIX_TZNAME_MAX }, + +/* Symbolic Utility Limits */ +{ "BC_BASE_MAX", SYSCONF, _SC_BC_BASE_MAX }, +{ "BC_DIM_MAX", SYSCONF, _SC_BC_DIM_MAX }, +{ "BC_SCALE_MAX", SYSCONF, _SC_BC_SCALE_MAX }, +{ "BC_STRING_MAX", SYSCONF, _SC_BC_STRING_MAX }, +{ "COLL_WEIGHTS_MAX", SYSCONF, _SC_COLL_WEIGHTS_MAX }, +{ "EXPR_NEST_MAX", SYSCONF, _SC_EXPR_NEST_MAX }, +{ "LINE_MAX", SYSCONF, _SC_LINE_MAX }, +{ "RE_DUP_MAX", SYSCONF, _SC_RE_DUP_MAX }, + +/* Optional Facility Configuration Values */ +{ "_POSIX2_C_BIND", SYSCONF, _SC_2_C_BIND }, +{ "POSIX2_C_DEV", SYSCONF, _SC_2_C_DEV }, +{ "POSIX2_CHAR_TERM", SYSCONF, _SC_2_CHAR_TERM }, +{ "POSIX2_FORT_DEV", SYSCONF, _SC_2_FORT_DEV }, +{ "POSIX2_FORT_RUN", SYSCONF, _SC_2_FORT_RUN }, +{ "POSIX2_LOCALEDEF", SYSCONF, _SC_2_LOCALEDEF }, +{ "POSIX2_SW_DEV", SYSCONF, _SC_2_SW_DEV }, +{ "POSIX2_UPE", SYSCONF, _SC_2_UPE }, + +/* POSIX.1 Configurable System Variables */ +{ "AIO_LISTIO_MAX", SYSCONF, _SC_AIO_LISTIO_MAX }, +{ "AIO_MAX", SYSCONF, _SC_AIO_MAX }, +{ "ARG_MAX", SYSCONF, _SC_ARG_MAX }, +{ "CHILD_MAX", SYSCONF, _SC_CHILD_MAX }, +{ "CLK_TCK", SYSCONF, _SC_CLK_TCK }, +{ "MQ_OPEN_MAX", SYSCONF, _SC_MQ_OPEN_MAX }, +{ "MQ_PRIO_MAX", SYSCONF, _SC_MQ_PRIO_MAX }, +{ "NGROUPS_MAX", SYSCONF, _SC_NGROUPS_MAX }, +{ "OPEN_MAX", SYSCONF, _SC_OPEN_MAX }, +{ "STREAM_MAX", SYSCONF, _SC_STREAM_MAX }, +{ "TZNAME_MAX", SYSCONF, _SC_TZNAME_MAX }, +{ "_POSIX_JOB_CONTROL", SYSCONF, _SC_JOB_CONTROL }, +{ "_POSIX_SAVED_IDS", SYSCONF, _SC_SAVED_IDS }, +{ "_POSIX_VERSION", SYSCONF, _SC_VERSION }, + +{ "LINK_MAX", PATHCONF, _PC_LINK_MAX }, +{ "MAX_CANON", PATHCONF, _PC_MAX_CANON }, +{ "MAX_INPUT", PATHCONF, _PC_MAX_INPUT }, +{ "NAME_MAX", PATHCONF, _PC_NAME_MAX }, +{ "PATH_MAX", PATHCONF, _PC_PATH_MAX }, +{ "PIPE_BUF", PATHCONF, _PC_PIPE_BUF }, +{ "_POSIX_CHOWN_RESTRICTED", PATHCONF, _PC_CHOWN_RESTRICTED }, +{ "_POSIX_NO_TRUNC", PATHCONF, _PC_NO_TRUNC }, +{ "_POSIX_VDISABLE", PATHCONF, _PC_VDISABLE }, + +/* POSIX.1b Configurable System Variables */ +{ "PAGESIZE", SYSCONF, _SC_PAGESIZE }, +{ "_POSIX_ASYNCHRONOUS_IO", SYSCONF, _SC_ASYNCHRONOUS_IO }, +{ "_POSIX_FSYNC", SYSCONF, _SC_FSYNC }, +{ "_POSIX_MAPPED_FILES", SYSCONF, _SC_MAPPED_FILES }, +{ "_POSIX_MEMLOCK", SYSCONF, _SC_MEMLOCK }, +{ "_POSIX_MEMLOCK_RANGE", SYSCONF, _SC_MEMLOCK_RANGE }, +{ "_POSIX_MEMORY_PROTECTION", SYSCONF, _SC_MEMORY_PROTECTION }, +{ "_POSIX_MESSAGE_PASSING", SYSCONF, _SC_MESSAGE_PASSING }, +{ "_POSIX_MONOTONIC_CLOCK", SYSCONF, _SC_MONOTONIC_CLOCK }, +{ "_POSIX_PRIORITY_SCHEDULING", SYSCONF, _SC_PRIORITY_SCHEDULING }, +{ "_POSIX_SEMAPHORES", SYSCONF, _SC_SEMAPHORES }, +{ "_POSIX_SHARED_MEMORY_OBJECTS", SYSCONF, _SC_SHARED_MEMORY_OBJECTS }, +{ "_POSIX_SYNCHRONIZED_IO", SYSCONF, _SC_SYNCHRONIZED_IO }, +{ "_POSIX_TIMERS", SYSCONF, _SC_TIMERS }, + +{ "_POSIX_SYNC_IO", PATHCONF, _PC_SYNC_IO }, + +/* POSIX.1c Configurable System Variables */ +{ "LOGIN_NAME_MAX", SYSCONF, _SC_LOGIN_NAME_MAX }, +{ "_POSIX_THREADS", SYSCONF, _SC_THREADS }, + +/* POSIX.1j Configurable System Variables */ +{ "_POSIX_BARRIERS", SYSCONF, _SC_BARRIERS }, +{ "_POSIX_READER_WRITER_LOCKS", SYSCONF, _SC_READER_WRITER_LOCKS }, +{ "_POSIX_SPIN_LOCKS", SYSCONF, _SC_SPIN_LOCKS }, + +/* XPG4.2 Configurable System Variables */ +{ "IOV_MAX", SYSCONF, _SC_IOV_MAX }, +{ "PAGE_SIZE", SYSCONF, _SC_PAGE_SIZE }, +{ "_XOPEN_SHM", SYSCONF, _SC_XOPEN_SHM }, + +/* X/Open CAE Spec. Issue 5 Version 2 Configurable System Variables */ +{ "FILESIZEBITS", PATHCONF, _PC_FILESIZEBITS }, + +/* POSIX.1-2001 XSI Option Group Configurable System Variables */ +{ "ATEXIT_MAX", SYSCONF, _SC_ATEXIT_MAX }, + +/* POSIX.1-2001 TSF Configurable System Variables */ +{ "GETGR_R_SIZE_MAX", SYSCONF, _SC_GETGR_R_SIZE_MAX }, +{ "GETPW_R_SIZE_MAX", SYSCONF, _SC_GETPW_R_SIZE_MAX }, + +/* Commonly provided extensions */ +{ "_PHYS_PAGES", SYSCONF, _SC_PHYS_PAGES }, +{ "_AVPHYS_PAGES", SYSCONF, _SC_AVPHYS_PAGES }, +{ "_NPROCESSORS_CONF", SYSCONF, _SC_NPROCESSORS_CONF }, +{ "_NPROCESSORS_ONLN", SYSCONF, _SC_NPROCESSORS_ONLN }, + +/* Data type related extensions */ +{ "CHAR_BIT", CONSTANT, CHAR_BIT }, +{ "CHAR_MAX", CONSTANT, CHAR_MAX }, +{ "CHAR_MIN", CONSTANT, CHAR_MIN }, +{ "INT_MAX", CONSTANT, INT_MAX }, +{ "INT_MIN", CONSTANT, INT_MIN }, +{ "LONG_BIT", CONSTANT, LONG_BIT }, +{ "LONG_MAX", CONSTANT, LONG_MAX }, +{ "LONG_MIN", CONSTANT, LONG_MIN }, +{ "SCHAR_MAX", CONSTANT, SCHAR_MAX }, +{ "SCHAR_MIN", CONSTANT, SCHAR_MIN }, +{ "SHRT_MAX", CONSTANT, SHRT_MAX }, +{ "SHRT_MIN", CONSTANT, SHRT_MIN }, +{ "SSIZE_MAX", CONSTANT, SSIZE_MAX }, +{ "UCHAR_MAX", UCONSTANT, (long) UCHAR_MAX }, +{ "UINT_MAX", UCONSTANT, (long) UINT_MAX }, +{ "ULONG_MAX", UCONSTANT, (long) ULONG_MAX }, +{ "USHRT_MAX", UCONSTANT, (long) USHRT_MAX }, +{ "WORD_BIT", CONSTANT, WORD_BIT }, + +{ NULL, CONSTANT, 0L } +}; + +static int all = 0; + +static void usage(const char *p) +{ + (void)fprintf(stderr, "Usage: %s system_var\n\t%s -a\n" + "\t%s path_var pathname\n\t%s -a pathname\n", p, p, p, p); + exit(EXIT_FAILURE); +} + +static void print_long(const char *name, long val) +{ + if (all) printf("%s = %ld\n", name, val); + else printf("%ld\n", val); +} + +static void print_ulong(const char *name, unsigned long val) +{ + if (all) printf("%s = %lu\n", name, val); + else printf("%lu\n", val); +} + +static void print_string(const char *name, const char *val) +{ + if (all) printf("%s = %s\n", name, val); + else printf("%s\n", val); +} + +static int print_constant(const struct conf_variable *cp, const char *pathname) +{ + print_long(cp->name, cp->value); + return 0; +} + +static int print_uconstant(const struct conf_variable *cp, const char *pathname) +{ + print_ulong(cp->name, (unsigned long) cp->value); + return 0; +} + +static int print_sysconf(const struct conf_variable *cp, const char *pathname) +{ + long val; + + errno = 0; + if ((val = sysconf((int)cp->value)) == -1) { + if (errno != 0) err(EXIT_FAILURE, "sysconf(%ld)", cp->value); + return -1; + } + print_long(cp->name, val); + return 0; +} + +static int print_confstr(const struct conf_variable *cp, const char *pathname) +{ + size_t len; + char *val; + + errno = 0; + if ((len = confstr((int)cp->value, NULL, 0)) == 0) goto error; + if ((val = malloc(len)) == NULL) err(EXIT_FAILURE, "Can't allocate %zu bytes", len); + errno = 0; + if (confstr((int)cp->value, val, len) == 0) goto error; + print_string(cp->name, val); + free(val); + return 0; +error: + if (errno != EINVAL) err(EXIT_FAILURE, "confstr(%ld)", cp->value); + return -1; +} + +static int print_pathconf(const struct conf_variable *cp, const char *pathname) +{ + long val; + + errno = 0; + if ((val = pathconf(pathname, (int)cp->value)) == -1) { + if (all && errno == EINVAL) return 0; + if (errno != 0) err(EXIT_FAILURE, "pathconf(%s, %ld)", pathname, cp->value); + return -1; + } + print_long(cp->name, val); + return 0; +} + +typedef int (*handler_t)(const struct conf_variable *cp, const char *pathname); +static const handler_t type_handlers[NUM_TYPES] = { + [SYSCONF] = print_sysconf, + [CONFSTR] = print_confstr, + [PATHCONF] = print_pathconf, + [CONSTANT] = print_constant, + [UCONSTANT] = print_uconstant, +}; + +int main(int argc, char **argv) +{ + const char *progname = argv[0]; + const struct conf_variable *cp; + const char *varname, *pathname; + int ch, found = 0; + + (void)setlocale(LC_ALL, ""); + while ((ch = getopt(argc, argv, "a")) != -1) { + switch (ch) { + case 'a': + all = 1; + break; + case '?': + default: + usage(progname); + } + } + argc -= optind; + argv += optind; + + if (!all) { + if (argc == 0) + usage(progname); + varname = argv[0]; + argc--; + argv++; + } else + varname = NULL; + + if (argc > 1) + usage(progname); + pathname = argv[0]; /* may be NULL */ + + for (cp = conf_table; cp->name != NULL; cp++) { + if (!all && strcmp(varname, cp->name) != 0) continue; + if ((cp->type == PATHCONF) == (pathname != NULL)) { + if (type_handlers[cp->type](cp, pathname) < 0) + print_string(cp->name, "undefined"); + found = 1; + } else if (!all) + errx(EXIT_FAILURE, "%s: invalid variable type", cp->name); + } + if (!all && !found) errx(EXIT_FAILURE, "%s: unknown variable", varname); + (void)fflush(stdout); + return ferror(stdout) ? EXIT_FAILURE : EXIT_SUCCESS; +} diff --git a/base/musl/getent.c b/base/musl/getent.c new file mode 100644 index 0000000..b10d75a --- /dev/null +++ b/base/musl/getent.c @@ -0,0 +1,511 @@ +/*- + * Copyright (c) 2004-2006 The NetBSD Foundation, Inc. + * All rights reserved. + * + * This code is derived from software contributed to The NetBSD Foundation + * by Luke Mewburn. + * Timo Teräs cleaned up the code for use in Alpine Linux with musl libc. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS + * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS + * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include + +#include +#include +#include +#include + +enum { + RV_OK = 0, + RV_USAGE = 1, + RV_NOTFOUND = 2, + RV_NOENUM = 3 +}; + +static int usage(const char *); + +static int parsenum(const char *word, unsigned long *result) +{ + unsigned long num; + char *ep; + + if (!isdigit((unsigned char)word[0])) + return 0; + errno = 0; + num = strtoul(word, &ep, 10); + if (num == ULONG_MAX && errno == ERANGE) + return 0; + if (*ep != '\0') + return 0; + *result = num; + return 1; +} + +/* + * printfmtstrings -- + * vprintf(format, ...), + * then the aliases (beginning with prefix, separated by sep), + * then a newline + */ +__attribute__ ((format (printf, 4, 5))) +static void printfmtstrings(char *strings[], const char *prefix, const char *sep, + const char *fmt, ...) +{ + va_list ap; + const char *curpref; + size_t i; + + va_start(ap, fmt); + (void)vprintf(fmt, ap); + va_end(ap); + + curpref = prefix; + for (i = 0; strings[i] != NULL; i++) { + (void)printf("%s%s", curpref, strings[i]); + curpref = sep; + } + (void)printf("\n"); +} + +static int ethers(int argc, char *argv[]) +{ + char hostname[MAXHOSTNAMELEN + 1], *hp; + struct ether_addr ea, *eap; + int i, rv; + + if (argc == 2) { + warnx("Enumeration not supported on ethers"); + return RV_NOENUM; + } + + rv = RV_OK; + for (i = 2; i < argc; i++) { + if ((eap = ether_aton(argv[i])) == NULL) { + eap = &ea; + hp = argv[i]; + if (ether_hostton(hp, eap) != 0) { + rv = RV_NOTFOUND; + break; + } + } else { + hp = hostname; + if (ether_ntohost(hp, eap) != 0) { + rv = RV_NOTFOUND; + break; + } + } + (void)printf("%-17s %s\n", ether_ntoa(eap), hp); + } + return rv; +} + +static void groupprint(const struct group *gr) +{ + printfmtstrings(gr->gr_mem, ":", ",", "%s:%s:%u", + gr->gr_name, gr->gr_passwd, gr->gr_gid); +} + +static int group(int argc, char *argv[]) +{ + struct group *gr; + unsigned long id; + int i, rv; + + rv = RV_OK; + if (argc == 2) { + while ((gr = getgrent()) != NULL) + groupprint(gr); + } else { + for (i = 2; i < argc; i++) { + if (parsenum(argv[i], &id)) + gr = getgrgid((gid_t)id); + else + gr = getgrnam(argv[i]); + if (gr == NULL) { + rv = RV_NOTFOUND; + break; + } + groupprint(gr); + } + } + endgrent(); + return rv; +} + +static void hostsprint(const struct hostent *he) +{ + char buf[INET6_ADDRSTRLEN]; + + if (inet_ntop(he->h_addrtype, he->h_addr, buf, sizeof(buf)) == NULL) + (void)strlcpy(buf, "# unknown", sizeof(buf)); + printfmtstrings(he->h_aliases, " ", " ", "%-16s %s", buf, he->h_name); +} + +static int hosts(int argc, char *argv[]) +{ + struct hostent *he; + char addr[IN6ADDRSZ]; + int i, rv; + + sethostent(1); + rv = RV_OK; + if (argc == 2) { + while ((he = gethostent()) != NULL) + hostsprint(he); + } else { + for (i = 2; i < argc; i++) { + if (inet_pton(AF_INET6, argv[i], (void *)addr) > 0) + he = gethostbyaddr(addr, IN6ADDRSZ, AF_INET6); + else if (inet_pton(AF_INET, argv[i], (void *)addr) > 0) + he = gethostbyaddr(addr, INADDRSZ, AF_INET); + else if ((he = gethostbyname2(argv[i], AF_INET6)) == NULL) + he = gethostbyname2(argv[i], AF_INET); + if (he == NULL) { + rv = RV_NOTFOUND; + break; + } + hostsprint(he); + } + } + endhostent(); + return rv; +} + +static int ahosts_ex(int family, int flags, int argc, char *argv[]) +{ + static const char *socktypes[] = { + [SOCK_STREAM] = "STREAM", + [SOCK_DGRAM] = "DGRAM", + [SOCK_RAW] = "RAW", + [SOCK_RDM] = "RDM", + [SOCK_SEQPACKET] = "SEQPACKET", + [SOCK_DCCP] = "DCCP", + [SOCK_PACKET] = "PACKET", + }; + const char *sockstr; + char sockbuf[16], buf[INET6_ADDRSTRLEN]; + struct addrinfo *res, *r, hint; + void *addr; + int i; + + if (argc == 2) + return hosts(argc, argv); + + hint = (struct addrinfo) { + .ai_family = family, + .ai_flags = AI_ADDRCONFIG | AI_CANONNAME | flags, + }; + + for (i = 2; i < argc; i++) { + if (getaddrinfo(argv[i], 0, &hint, &res) != 0) + return RV_NOTFOUND; + + for (r = res; r; r = r->ai_next) { + sockstr = NULL; + if (r->ai_socktype >= 0 && r->ai_socktype < sizeof(socktypes)/sizeof(socktypes[0])) + sockstr = socktypes[r->ai_socktype]; + if (!sockstr) { + sprintf(buf, "%d", r->ai_socktype); + sockstr = sockbuf; + } + switch (r->ai_family) { + case AF_INET: + addr = &((struct sockaddr_in*) r->ai_addr)->sin_addr; + break; + case AF_INET6: + addr = &((struct sockaddr_in6*) r->ai_addr)->sin6_addr; + break; + default: + continue; + } + if (inet_ntop(r->ai_family, addr, buf, sizeof(buf)) == NULL) + (void)strlcpy(buf, "# unknown", sizeof(buf)); + printf("%-15s %-6s %s\n", buf, sockstr, r->ai_canonname ?: ""); + } + } + + return RV_OK; +} + +static int ahosts(int argc, char *argv[]) +{ + return ahosts_ex(AF_UNSPEC, 0, argc, argv); +} + +static int ahostsv4(int argc, char *argv[]) +{ + return ahosts_ex(AF_INET, 0, argc, argv); +} + +static int ahostsv6(int argc, char *argv[]) +{ + return ahosts_ex(AF_INET6, AI_V4MAPPED, argc, argv); +} + +static void networksprint(const struct netent *ne) +{ + char buf[INET6_ADDRSTRLEN]; + struct in_addr ianet; + + ianet = inet_makeaddr(ne->n_net, 0); + if (inet_ntop(ne->n_addrtype, &ianet, buf, sizeof(buf)) == NULL) + (void)strlcpy(buf, "# unknown", sizeof(buf)); + printfmtstrings(ne->n_aliases, " ", " ", "%-16s %s", ne->n_name, buf); +} + +static int networks(int argc, char *argv[]) +{ + struct netent *ne; + in_addr_t net; + int i, rv; + + setnetent(1); + rv = RV_OK; + if (argc == 2) { + while ((ne = getnetent()) != NULL) + networksprint(ne); + } else { + for (i = 2; i < argc; i++) { + net = inet_network(argv[i]); + if (net != INADDR_NONE) + ne = getnetbyaddr(net, AF_INET); + else + ne = getnetbyname(argv[i]); + if (ne != NULL) { + rv = RV_NOTFOUND; + break; + } + networksprint(ne); + } + } + endnetent(); + return rv; +} + +static void passwdprint(struct passwd *pw) +{ + (void)printf("%s:%s:%u:%u:%s:%s:%s\n", + pw->pw_name, pw->pw_passwd, pw->pw_uid, + pw->pw_gid, pw->pw_gecos, pw->pw_dir, pw->pw_shell); +} + +static int passwd(int argc, char *argv[]) +{ + struct passwd *pw; + unsigned long id; + int i, rv; + + rv = RV_OK; + if (argc == 2) { + while ((pw = getpwent()) != NULL) + passwdprint(pw); + } else { + for (i = 2; i < argc; i++) { + if (parsenum(argv[i], &id)) + pw = getpwuid((uid_t)id); + else + pw = getpwnam(argv[i]); + if (pw == NULL) { + rv = RV_NOTFOUND; + break; + } + passwdprint(pw); + } + } + endpwent(); + return rv; +} + +static void protocolsprint(struct protoent *pe) +{ + printfmtstrings(pe->p_aliases, " ", " ", + "%-16s %5d", pe->p_name, pe->p_proto); +} + +static int protocols(int argc, char *argv[]) +{ + struct protoent *pe; + unsigned long id; + int i, rv; + + setprotoent(1); + rv = RV_OK; + if (argc == 2) { + while ((pe = getprotoent()) != NULL) + protocolsprint(pe); + } else { + for (i = 2; i < argc; i++) { + if (parsenum(argv[i], &id)) + pe = getprotobynumber((int)id); + else + pe = getprotobyname(argv[i]); + if (pe == NULL) { + rv = RV_NOTFOUND; + break; + } + protocolsprint(pe); + } + } + endprotoent(); + return rv; +} + +static void servicesprint(struct servent *se) +{ + printfmtstrings(se->s_aliases, " ", " ", + "%-16s %5d/%s", + se->s_name, ntohs(se->s_port), se->s_proto); + +} + +static int services(int argc, char *argv[]) +{ + struct servent *se; + unsigned long id; + char *proto; + int i, rv; + + setservent(1); + rv = RV_OK; + if (argc == 2) { + while ((se = getservent()) != NULL) + servicesprint(se); + } else { + for (i = 2; i < argc; i++) { + proto = strchr(argv[i], '/'); + if (proto != NULL) + *proto++ = '\0'; + if (parsenum(argv[i], &id)) + se = getservbyport(htons(id), proto); + else + se = getservbyname(argv[i], proto); + if (se == NULL) { + rv = RV_NOTFOUND; + break; + } + servicesprint(se); + } + } + endservent(); + return rv; +} + +static int shells(int argc, char *argv[]) +{ + const char *sh; + int i, rv; + + setusershell(); + rv = RV_OK; + if (argc == 2) { + while ((sh = getusershell()) != NULL) + (void)printf("%s\n", sh); + } else { + for (i = 2; i < argc; i++) { + setusershell(); + while ((sh = getusershell()) != NULL) { + if (strcmp(sh, argv[i]) == 0) { + (void)printf("%s\n", sh); + break; + } + } + if (sh == NULL) { + rv = RV_NOTFOUND; + break; + } + } + } + endusershell(); + return rv; +} + +static struct getentdb { + const char *name; + int (*callback)(int, char *[]); +} databases[] = { + { "ethers", ethers, }, + { "group", group, }, + { "hosts", hosts, }, + { "ahosts", ahosts, }, + { "ahostsv4", ahostsv4, }, + { "ahostsv6", ahostsv6, }, + { "networks", networks, }, + { "passwd", passwd, }, + { "protocols", protocols, }, + { "services", services, }, + { "shells", shells, }, + + { NULL, NULL, }, +}; + +static int usage(const char *arg0) +{ + struct getentdb *curdb; + size_t i; + + (void)fprintf(stderr, "Usage: %s database [key ...]\n", arg0); + (void)fprintf(stderr, "\tdatabase may be one of:"); + for (i = 0, curdb = databases; curdb->name != NULL; curdb++, i++) { + if (i % 7 == 0) + (void)fputs("\n\t\t", stderr); + (void)fprintf(stderr, "%s%s", i % 7 == 0 ? "" : " ", + curdb->name); + } + (void)fprintf(stderr, "\n"); + exit(RV_USAGE); + /* NOTREACHED */ +} + +int +main(int argc, char *argv[]) +{ + struct getentdb *curdb; + + if (argc < 2) + usage(argv[0]); + for (curdb = databases; curdb->name != NULL; curdb++) + if (strcmp(curdb->name, argv[1]) == 0) + return (*curdb->callback)(argc, argv); + + warn("Unknown database `%s'", argv[1]); + usage(argv[0]); + /* NOTREACHED */ +} diff --git a/base/musl/iconv.c b/base/musl/iconv.c new file mode 100644 index 0000000..f5d5ce2 --- /dev/null +++ b/base/musl/iconv.c @@ -0,0 +1,110 @@ +/* + * iconv.c + * Implementation of SUSv4 XCU iconv utility + * Copyright © 2011 Rich Felker + * Licensed under the terms of the GNU General Public License, v2 or later + */ + +#include +#include +#include +#include +#include +#include +#include +#include + +int main(int argc, char **argv) +{ + const char *from=0, *to=0; + int b; + iconv_t cd; + char buf[BUFSIZ]; + char outbuf[BUFSIZ*4]; + char *in, *out; + size_t inb; + size_t l; + size_t unitsize=0; + int err=0; + FILE *f; + + while ((b = getopt(argc, argv, "f:t:csl")) != EOF) switch(b) { + case 'l': + puts("UTF-8, UTF-16BE, UTF-16LE, UTF-32BE, UTF32-LE, UCS-2BE, UCS-2LE, WCHAR_T,\n" + "US_ASCII, ISO8859-1, ISO8859-2, ISO8859-3, ISO8859-4, ISO8859-5,\n" + "ISO8859-6, ISO8859-7, ..."); + exit(0); + case 'c': case 's': break; + case 'f': from=optarg; break; + case 't': to=optarg; break; + default: exit(1); + } + + if (!from || !to) { + setlocale(LC_CTYPE, ""); + if (!to) to = nl_langinfo(CODESET); + if (!from) from = nl_langinfo(CODESET); + } + cd = iconv_open(to, from); + if (cd == (iconv_t)-1) { + if (iconv_open(to, "WCHAR_T") == (iconv_t)-1) + fprintf(stderr, "iconv: destination charset %s: ", to); + else + fprintf(stderr, "iconv: source charset %s: ", from); + perror(""); + exit(1); + } + if (optind == argc) argv[argc++] = "-"; + + for (; optind < argc; optind++) { + if (argv[optind][0]=='-' && !argv[optind][1]) { + f = stdin; + argv[optind] = "(stdin)"; + } else if (!(f = fopen(argv[optind], "rb"))) { + fprintf(stderr, "iconv: %s: ", argv[optind]); + perror(""); + err = 1; + continue; + } + inb = 0; + for (;;) { + in = buf; + out = outbuf; + l = fread(buf+inb, 1, sizeof(buf)-inb, f); + inb += l; + if (!inb) break; + if (iconv(cd, &in, &inb, &out, (size_t [1]){sizeof outbuf})==-1 + && errno == EILSEQ) { + if (!unitsize) { + wchar_t wc='0'; + char dummy[4], *dummyp=dummy; + iconv_t cd2 = iconv_open(from, "WCHAR_T"); + if (cd == (iconv_t)-1) { + unitsize = 1; + } else { + iconv(cd2, + (char *[1]){(char *)&wc}, + (size_t[1]){1}, + &dummyp, (size_t[1]){4}); + unitsize = dummyp-dummy; + if (!unitsize) unitsize=1; + } + } + inb-=unitsize; + in+=unitsize; + } + if (inb && !l && errno==EINVAL) break; + if (out>outbuf && !fwrite(outbuf, out-outbuf, 1, stdout)) { + perror("iconv: write error"); + exit(1); + } + if (inb) memmove(buf, in, inb); + } + if (ferror(f)) { + fprintf(stderr, "iconv: %s: ", argv[optind]); + perror(""); + err = 1; + } + } + return err; +} diff --git a/base/musl/musl-wcsnrtombs.c b/base/musl/musl-wcsnrtombs.c new file mode 100644 index 0000000..95e25e7 --- /dev/null +++ b/base/musl/musl-wcsnrtombs.c @@ -0,0 +1,35 @@ +#include +#include +#include + +size_t wcsnrtombs(char *restrict dst, const wchar_t **restrict wcs, size_t wn, size_t n, mbstate_t *restrict st) +{ + const wchar_t *ws = *wcs; + size_t cnt = 0; + if (!dst) n=0; + while (ws && wn) { + char tmp[MB_LEN_MAX]; + size_t l = wcrtomb(nn) break; + memcpy(dst, tmp, l); + } + dst += l; + n -= l; + } + if (!*ws) { + ws = 0; + break; + } + ws++; + wn--; + cnt += l; + } + if (dst) *wcs = ws; + return cnt; +} diff --git a/base/musl/musl.SMBuild b/base/musl/musl.SMBuild new file mode 100755 index 0000000..bcab735 --- /dev/null +++ b/base/musl/musl.SMBuild @@ -0,0 +1,67 @@ +APP=musl +VERSION=1.1.24 +BUILD=1sml +HOMEPAGE='http://www.musl-libc.org/' +DOWNLOAD='https://musl.libc.org/releases/musl-1.1.24.tar.gz' +DESC="Simple, fast and POSIX-compliant C library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Thanks sabotage + cp $SRCDIR/musl-wcsnrtombs.c src/multibyte/wcsnrtombs.c + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + # Some additional stuff from alpine + mkdir -p addons && cd addons + cp $SRCDIR/{getconf.c,getent.c,iconv.c} . + + gcc -o getconf getconf.c ; install -Dm 755 getconf $PKG/bin/getconf + gcc -o getent getent.c ; install -Dm 755 getent $PKG/bin/getent + gcc -o iconv iconv.c ; install -Dm 755 iconv $PKG/bin/iconv + cd .. + + ( cd $PKG/lib + # Remove the symlink, it'll break upgrades and make the system useless + rm ld-musl-$ARCH.so.1 + # Copy the libc.so as the $ARCH-specific file + cp libc.so ld-musl-$ARCH.so.1 + ) + + cp COPYRIGHT $PKGDOCS/ + + cp $SRCDIR/{cdefs.h,queue.h,stab.h,tree.h} $PKG/include/sys/ + + [ "$ARCH" = "aarch64" ] && install -Dm 644 $SRCDIR/asm.hwcap.h $PKG/include/asm/hwcap.h + + #( + #mkdir -p $PKG/bin + #cd $PKG/lib ; ln -sf libc.so ld-musl-$ARCH.so.1 + #) + + mkfinalpkg +} + +SHA512SUMS=" +5a8c719897b4d24ba7c0d7d584fdc57f46bb65bb9c7ca4b1d03d54cf8b5fd15697ccc5536d3e4e2a907624cfb0926877b8e7fa2b2ef961c3ea4458b7b3ca930c musl-1.1.24.tar.lz +0d80f37b34a35e3d14b012257c50862dfeb9d2c81139ea2dfa101d981d093b009b9fa450ba27a708ac59377a48626971dfc58e20a3799084a65777a0c32cbc7d getconf.c +378d70e65bcc65bb4e1415354cecfa54b0c1146dfb24474b69e418cdbf7ad730472cd09f6f103e1c99ba6c324c9560bccdf287f5889bbc3ef0bdf0e08da47413 getent.c +9d42d66fb1facce2b85dad919be5be819ee290bd26ca2db00982b2f8e055a0196290a008711cbe2b18ec9eee8d2270e3b3a4692c5a1b807013baa5c2b70a2bbf iconv.c +fb9ee91cf8fd6330727b67fee8f4f7c4e603839c5cbd8fa9e838bf2f5f68558119d0535de54643d56ddbc2ac5dcd38878818e91da7c6dd15c10422c84270d2ef musl-wcsnrtombs.c +3af049adb95230efab7e71964e9cb4a5a4d6b4a10adec43e1540fc2a10dbc77ed96511bc862c2f13deb6d599298d3ec2610ad0107898f6105ba4705f973737db asm.hwcap.h +8c3fddd73b696a38e633953715c79c47703739be27ee085fc6c960a57b6746ca05bf6406f7e6126cc1a13204254fd5830afb566624e1f298f4d6b58216013c28 cdefs.h +19cec4d39310285eb49ad1beae86884080e0152f9477757513050211b31f95ee7283a64ae95939683df09231cfb021ace816b26981ad05f4fff0a39519f935fe queue.h +cd57bec6b2462b08b54dcfc6ba37e1d5289fcdd9463f22ea091679aa8006e24d89c9d57637c0e7a5bfbf02d06e93aa4cb3c0d066400aa1b698a8ae66a9cb7b8e stab.h +07cb70f2f0ddb31e23dd913c6f561fc9885667c5803fdf3a559676c99d08834b4104589bacb5d17b4a0b379c68c81a1cf3173832b3da33a7b936fa7b93706844 tree.h +" diff --git a/base/musl/queue.h b/base/musl/queue.h new file mode 100644 index 0000000..99d01a5 --- /dev/null +++ b/base/musl/queue.h @@ -0,0 +1,846 @@ +/* $NetBSD: queue.h,v 1.68 2014/11/19 08:10:01 uebayasi Exp $ */ + +/* + * Copyright (c) 1991, 1993 + * The Regents of the University of California. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * @(#)queue.h 8.5 (Berkeley) 8/20/94 + */ + +#ifndef _SYS_QUEUE_H_ +#define _SYS_QUEUE_H_ + +/* + * This file defines five types of data structures: singly-linked lists, + * lists, simple queues, tail queues, and circular queues. + * + * A singly-linked list is headed by a single forward pointer. The + * elements are singly linked for minimum space and pointer manipulation + * overhead at the expense of O(n) removal for arbitrary elements. New + * elements can be added to the list after an existing element or at the + * head of the list. Elements being removed from the head of the list + * should use the explicit macro for this purpose for optimum + * efficiency. A singly-linked list may only be traversed in the forward + * direction. Singly-linked lists are ideal for applications with large + * datasets and few or no removals or for implementing a LIFO queue. + * + * A list is headed by a single forward pointer (or an array of forward + * pointers for a hash table header). The elements are doubly linked + * so that an arbitrary element can be removed without a need to + * traverse the list. New elements can be added to the list before + * or after an existing element or at the head of the list. A list + * may only be traversed in the forward direction. + * + * A simple queue is headed by a pair of pointers, one the head of the + * list and the other to the tail of the list. The elements are singly + * linked to save space, so elements can only be removed from the + * head of the list. New elements can be added to the list after + * an existing element, at the head of the list, or at the end of the + * list. A simple queue may only be traversed in the forward direction. + * + * A tail queue is headed by a pair of pointers, one to the head of the + * list and the other to the tail of the list. The elements are doubly + * linked so that an arbitrary element can be removed without a need to + * traverse the list. New elements can be added to the list before or + * after an existing element, at the head of the list, or at the end of + * the list. A tail queue may be traversed in either direction. + * + * A circle queue is headed by a pair of pointers, one to the head of the + * list and the other to the tail of the list. The elements are doubly + * linked so that an arbitrary element can be removed without a need to + * traverse the list. New elements can be added to the list before or after + * an existing element, at the head of the list, or at the end of the list. + * A circle queue may be traversed in either direction, but has a more + * complex end of list detection. + * + * For details on the use of these macros, see the queue(3) manual page. + */ + +/* + * Include the definition of NULL only on NetBSD because sys/null.h + * is not available elsewhere. This conditional makes the header + * portable and it can simply be dropped verbatim into any system. + * The caveat is that on other systems some other header + * must provide NULL before the macros can be used. + */ +#ifdef __NetBSD__ +#include +#endif + +#if defined(QUEUEDEBUG) +# if defined(_KERNEL) +# define QUEUEDEBUG_ABORT(...) panic(__VA_ARGS__) +# else +# include +# define QUEUEDEBUG_ABORT(...) err(1, __VA_ARGS__) +# endif +#endif + +/* + * Singly-linked List definitions. + */ +#define SLIST_HEAD(name, type) \ +struct name { \ + struct type *slh_first; /* first element */ \ +} + +#define SLIST_HEAD_INITIALIZER(head) \ + { NULL } + +#define SLIST_ENTRY(type) \ +struct { \ + struct type *sle_next; /* next element */ \ +} + +/* + * Singly-linked List access methods. + */ +#define SLIST_FIRST(head) ((head)->slh_first) +#define SLIST_END(head) NULL +#define SLIST_EMPTY(head) ((head)->slh_first == NULL) +#define SLIST_NEXT(elm, field) ((elm)->field.sle_next) + +#define SLIST_FOREACH(var, head, field) \ + for((var) = (head)->slh_first; \ + (var) != SLIST_END(head); \ + (var) = (var)->field.sle_next) + +#define SLIST_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = SLIST_FIRST((head)); \ + (var) != SLIST_END(head) && \ + ((tvar) = SLIST_NEXT((var), field), 1); \ + (var) = (tvar)) + +/* + * Singly-linked List functions. + */ +#define SLIST_INIT(head) do { \ + (head)->slh_first = SLIST_END(head); \ +} while (/*CONSTCOND*/0) + +#define SLIST_INSERT_AFTER(slistelm, elm, field) do { \ + (elm)->field.sle_next = (slistelm)->field.sle_next; \ + (slistelm)->field.sle_next = (elm); \ +} while (/*CONSTCOND*/0) + +#define SLIST_INSERT_HEAD(head, elm, field) do { \ + (elm)->field.sle_next = (head)->slh_first; \ + (head)->slh_first = (elm); \ +} while (/*CONSTCOND*/0) + +#define SLIST_REMOVE_AFTER(slistelm, field) do { \ + (slistelm)->field.sle_next = \ + SLIST_NEXT(SLIST_NEXT((slistelm), field), field); \ +} while (/*CONSTCOND*/0) + +#define SLIST_REMOVE_HEAD(head, field) do { \ + (head)->slh_first = (head)->slh_first->field.sle_next; \ +} while (/*CONSTCOND*/0) + +#define SLIST_REMOVE(head, elm, type, field) do { \ + if ((head)->slh_first == (elm)) { \ + SLIST_REMOVE_HEAD((head), field); \ + } \ + else { \ + struct type *curelm = (head)->slh_first; \ + while(curelm->field.sle_next != (elm)) \ + curelm = curelm->field.sle_next; \ + curelm->field.sle_next = \ + curelm->field.sle_next->field.sle_next; \ + } \ +} while (/*CONSTCOND*/0) + + +/* + * List definitions. + */ +#define LIST_HEAD(name, type) \ +struct name { \ + struct type *lh_first; /* first element */ \ +} + +#define LIST_HEAD_INITIALIZER(head) \ + { NULL } + +#define LIST_ENTRY(type) \ +struct { \ + struct type *le_next; /* next element */ \ + struct type **le_prev; /* address of previous next element */ \ +} + +/* + * List access methods. + */ +#define LIST_FIRST(head) ((head)->lh_first) +#define LIST_END(head) NULL +#define LIST_EMPTY(head) ((head)->lh_first == LIST_END(head)) +#define LIST_NEXT(elm, field) ((elm)->field.le_next) + +#define LIST_FOREACH(var, head, field) \ + for ((var) = ((head)->lh_first); \ + (var) != LIST_END(head); \ + (var) = ((var)->field.le_next)) + +#define LIST_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = LIST_FIRST((head)); \ + (var) != LIST_END(head) && \ + ((tvar) = LIST_NEXT((var), field), 1); \ + (var) = (tvar)) + +#define LIST_MOVE(head1, head2) do { \ + LIST_INIT((head2)); \ + if (!LIST_EMPTY((head1))) { \ + (head2)->lh_first = (head1)->lh_first; \ + LIST_INIT((head1)); \ + } \ +} while (/*CONSTCOND*/0) + +/* + * List functions. + */ +#if defined(QUEUEDEBUG) +#define QUEUEDEBUG_LIST_INSERT_HEAD(head, elm, field) \ + if ((head)->lh_first && \ + (head)->lh_first->field.le_prev != &(head)->lh_first) \ + QUEUEDEBUG_ABORT("LIST_INSERT_HEAD %p %s:%d", (head), \ + __FILE__, __LINE__); +#define QUEUEDEBUG_LIST_OP(elm, field) \ + if ((elm)->field.le_next && \ + (elm)->field.le_next->field.le_prev != \ + &(elm)->field.le_next) \ + QUEUEDEBUG_ABORT("LIST_* forw %p %s:%d", (elm), \ + __FILE__, __LINE__); \ + if (*(elm)->field.le_prev != (elm)) \ + QUEUEDEBUG_ABORT("LIST_* back %p %s:%d", (elm), \ + __FILE__, __LINE__); +#define QUEUEDEBUG_LIST_POSTREMOVE(elm, field) \ + (elm)->field.le_next = (void *)1L; \ + (elm)->field.le_prev = (void *)1L; +#else +#define QUEUEDEBUG_LIST_INSERT_HEAD(head, elm, field) +#define QUEUEDEBUG_LIST_OP(elm, field) +#define QUEUEDEBUG_LIST_POSTREMOVE(elm, field) +#endif + +#define LIST_INIT(head) do { \ + (head)->lh_first = LIST_END(head); \ +} while (/*CONSTCOND*/0) + +#define LIST_INSERT_AFTER(listelm, elm, field) do { \ + QUEUEDEBUG_LIST_OP((listelm), field) \ + if (((elm)->field.le_next = (listelm)->field.le_next) != \ + LIST_END(head)) \ + (listelm)->field.le_next->field.le_prev = \ + &(elm)->field.le_next; \ + (listelm)->field.le_next = (elm); \ + (elm)->field.le_prev = &(listelm)->field.le_next; \ +} while (/*CONSTCOND*/0) + +#define LIST_INSERT_BEFORE(listelm, elm, field) do { \ + QUEUEDEBUG_LIST_OP((listelm), field) \ + (elm)->field.le_prev = (listelm)->field.le_prev; \ + (elm)->field.le_next = (listelm); \ + *(listelm)->field.le_prev = (elm); \ + (listelm)->field.le_prev = &(elm)->field.le_next; \ +} while (/*CONSTCOND*/0) + +#define LIST_INSERT_HEAD(head, elm, field) do { \ + QUEUEDEBUG_LIST_INSERT_HEAD((head), (elm), field) \ + if (((elm)->field.le_next = (head)->lh_first) != LIST_END(head))\ + (head)->lh_first->field.le_prev = &(elm)->field.le_next;\ + (head)->lh_first = (elm); \ + (elm)->field.le_prev = &(head)->lh_first; \ +} while (/*CONSTCOND*/0) + +#define LIST_REMOVE(elm, field) do { \ + QUEUEDEBUG_LIST_OP((elm), field) \ + if ((elm)->field.le_next != NULL) \ + (elm)->field.le_next->field.le_prev = \ + (elm)->field.le_prev; \ + *(elm)->field.le_prev = (elm)->field.le_next; \ + QUEUEDEBUG_LIST_POSTREMOVE((elm), field) \ +} while (/*CONSTCOND*/0) + +#define LIST_REPLACE(elm, elm2, field) do { \ + if (((elm2)->field.le_next = (elm)->field.le_next) != NULL) \ + (elm2)->field.le_next->field.le_prev = \ + &(elm2)->field.le_next; \ + (elm2)->field.le_prev = (elm)->field.le_prev; \ + *(elm2)->field.le_prev = (elm2); \ + QUEUEDEBUG_LIST_POSTREMOVE((elm), field) \ +} while (/*CONSTCOND*/0) + +/* + * Simple queue definitions. + */ +#define SIMPLEQ_HEAD(name, type) \ +struct name { \ + struct type *sqh_first; /* first element */ \ + struct type **sqh_last; /* addr of last next element */ \ +} + +#define SIMPLEQ_HEAD_INITIALIZER(head) \ + { NULL, &(head).sqh_first } + +#define SIMPLEQ_ENTRY(type) \ +struct { \ + struct type *sqe_next; /* next element */ \ +} + +/* + * Simple queue access methods. + */ +#define SIMPLEQ_FIRST(head) ((head)->sqh_first) +#define SIMPLEQ_END(head) NULL +#define SIMPLEQ_EMPTY(head) ((head)->sqh_first == SIMPLEQ_END(head)) +#define SIMPLEQ_NEXT(elm, field) ((elm)->field.sqe_next) + +#define SIMPLEQ_FOREACH(var, head, field) \ + for ((var) = ((head)->sqh_first); \ + (var) != SIMPLEQ_END(head); \ + (var) = ((var)->field.sqe_next)) + +#define SIMPLEQ_FOREACH_SAFE(var, head, field, next) \ + for ((var) = ((head)->sqh_first); \ + (var) != SIMPLEQ_END(head) && \ + ((next = ((var)->field.sqe_next)), 1); \ + (var) = (next)) + +/* + * Simple queue functions. + */ +#define SIMPLEQ_INIT(head) do { \ + (head)->sqh_first = NULL; \ + (head)->sqh_last = &(head)->sqh_first; \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_INSERT_HEAD(head, elm, field) do { \ + if (((elm)->field.sqe_next = (head)->sqh_first) == NULL) \ + (head)->sqh_last = &(elm)->field.sqe_next; \ + (head)->sqh_first = (elm); \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_INSERT_TAIL(head, elm, field) do { \ + (elm)->field.sqe_next = NULL; \ + *(head)->sqh_last = (elm); \ + (head)->sqh_last = &(elm)->field.sqe_next; \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_INSERT_AFTER(head, listelm, elm, field) do { \ + if (((elm)->field.sqe_next = (listelm)->field.sqe_next) == NULL)\ + (head)->sqh_last = &(elm)->field.sqe_next; \ + (listelm)->field.sqe_next = (elm); \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_REMOVE_HEAD(head, field) do { \ + if (((head)->sqh_first = (head)->sqh_first->field.sqe_next) == NULL) \ + (head)->sqh_last = &(head)->sqh_first; \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_REMOVE_AFTER(head, elm, field) do { \ + if (((elm)->field.sqe_next = (elm)->field.sqe_next->field.sqe_next) \ + == NULL) \ + (head)->sqh_last = &(elm)->field.sqe_next; \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_REMOVE(head, elm, type, field) do { \ + if ((head)->sqh_first == (elm)) { \ + SIMPLEQ_REMOVE_HEAD((head), field); \ + } else { \ + struct type *curelm = (head)->sqh_first; \ + while (curelm->field.sqe_next != (elm)) \ + curelm = curelm->field.sqe_next; \ + if ((curelm->field.sqe_next = \ + curelm->field.sqe_next->field.sqe_next) == NULL) \ + (head)->sqh_last = &(curelm)->field.sqe_next; \ + } \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_CONCAT(head1, head2) do { \ + if (!SIMPLEQ_EMPTY((head2))) { \ + *(head1)->sqh_last = (head2)->sqh_first; \ + (head1)->sqh_last = (head2)->sqh_last; \ + SIMPLEQ_INIT((head2)); \ + } \ +} while (/*CONSTCOND*/0) + +#define SIMPLEQ_LAST(head, type, field) \ + (SIMPLEQ_EMPTY((head)) ? \ + NULL : \ + ((struct type *)(void *) \ + ((char *)((head)->sqh_last) - offsetof(struct type, field)))) + +/* + * Tail queue definitions. + */ +#define _TAILQ_HEAD(name, type, qual) \ +struct name { \ + qual type *tqh_first; /* first element */ \ + qual type *qual *tqh_last; /* addr of last next element */ \ +} +#define TAILQ_HEAD(name, type) _TAILQ_HEAD(name, struct type,) + +#define TAILQ_HEAD_INITIALIZER(head) \ + { TAILQ_END(head), &(head).tqh_first } + +#define _TAILQ_ENTRY(type, qual) \ +struct { \ + qual type *tqe_next; /* next element */ \ + qual type *qual *tqe_prev; /* address of previous next element */\ +} +#define TAILQ_ENTRY(type) _TAILQ_ENTRY(struct type,) + +/* + * Tail queue access methods. + */ +#define TAILQ_FIRST(head) ((head)->tqh_first) +#define TAILQ_END(head) (NULL) +#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next) +#define TAILQ_LAST(head, headname) \ + (*(((struct headname *)((head)->tqh_last))->tqh_last)) +#define TAILQ_PREV(elm, headname, field) \ + (*(((struct headname *)((elm)->field.tqe_prev))->tqh_last)) +#define TAILQ_EMPTY(head) (TAILQ_FIRST(head) == TAILQ_END(head)) + + +#define TAILQ_FOREACH(var, head, field) \ + for ((var) = ((head)->tqh_first); \ + (var) != TAILQ_END(head); \ + (var) = ((var)->field.tqe_next)) + +#define TAILQ_FOREACH_SAFE(var, head, field, next) \ + for ((var) = ((head)->tqh_first); \ + (var) != TAILQ_END(head) && \ + ((next) = TAILQ_NEXT(var, field), 1); (var) = (next)) + +#define TAILQ_FOREACH_REVERSE(var, head, headname, field) \ + for ((var) = (*(((struct headname *)((head)->tqh_last))->tqh_last));\ + (var) != TAILQ_END(head); \ + (var) = (*(((struct headname *)((var)->field.tqe_prev))->tqh_last))) + +#define TAILQ_FOREACH_REVERSE_SAFE(var, head, headname, field, prev) \ + for ((var) = TAILQ_LAST((head), headname); \ + (var) != TAILQ_END(head) && \ + ((prev) = TAILQ_PREV((var), headname, field), 1); (var) = (prev)) + +/* + * Tail queue functions. + */ +#if defined(QUEUEDEBUG) +#define QUEUEDEBUG_TAILQ_INSERT_HEAD(head, elm, field) \ + if ((head)->tqh_first && \ + (head)->tqh_first->field.tqe_prev != &(head)->tqh_first) \ + QUEUEDEBUG_ABORT("TAILQ_INSERT_HEAD %p %s:%d", (head), \ + __FILE__, __LINE__); +#define QUEUEDEBUG_TAILQ_INSERT_TAIL(head, elm, field) \ + if (*(head)->tqh_last != NULL) \ + QUEUEDEBUG_ABORT("TAILQ_INSERT_TAIL %p %s:%d", (head), \ + __FILE__, __LINE__); +#define QUEUEDEBUG_TAILQ_OP(elm, field) \ + if ((elm)->field.tqe_next && \ + (elm)->field.tqe_next->field.tqe_prev != \ + &(elm)->field.tqe_next) \ + QUEUEDEBUG_ABORT("TAILQ_* forw %p %s:%d", (elm), \ + __FILE__, __LINE__); \ + if (*(elm)->field.tqe_prev != (elm)) \ + QUEUEDEBUG_ABORT("TAILQ_* back %p %s:%d", (elm), \ + __FILE__, __LINE__); +#define QUEUEDEBUG_TAILQ_PREREMOVE(head, elm, field) \ + if ((elm)->field.tqe_next == NULL && \ + (head)->tqh_last != &(elm)->field.tqe_next) \ + QUEUEDEBUG_ABORT("TAILQ_PREREMOVE head %p elm %p %s:%d",\ + (head), (elm), __FILE__, __LINE__); +#define QUEUEDEBUG_TAILQ_POSTREMOVE(elm, field) \ + (elm)->field.tqe_next = (void *)1L; \ + (elm)->field.tqe_prev = (void *)1L; +#else +#define QUEUEDEBUG_TAILQ_INSERT_HEAD(head, elm, field) +#define QUEUEDEBUG_TAILQ_INSERT_TAIL(head, elm, field) +#define QUEUEDEBUG_TAILQ_OP(elm, field) +#define QUEUEDEBUG_TAILQ_PREREMOVE(head, elm, field) +#define QUEUEDEBUG_TAILQ_POSTREMOVE(elm, field) +#endif + +#define TAILQ_INIT(head) do { \ + (head)->tqh_first = TAILQ_END(head); \ + (head)->tqh_last = &(head)->tqh_first; \ +} while (/*CONSTCOND*/0) + +#define TAILQ_INSERT_HEAD(head, elm, field) do { \ + QUEUEDEBUG_TAILQ_INSERT_HEAD((head), (elm), field) \ + if (((elm)->field.tqe_next = (head)->tqh_first) != TAILQ_END(head))\ + (head)->tqh_first->field.tqe_prev = \ + &(elm)->field.tqe_next; \ + else \ + (head)->tqh_last = &(elm)->field.tqe_next; \ + (head)->tqh_first = (elm); \ + (elm)->field.tqe_prev = &(head)->tqh_first; \ +} while (/*CONSTCOND*/0) + +#define TAILQ_INSERT_TAIL(head, elm, field) do { \ + QUEUEDEBUG_TAILQ_INSERT_TAIL((head), (elm), field) \ + (elm)->field.tqe_next = TAILQ_END(head); \ + (elm)->field.tqe_prev = (head)->tqh_last; \ + *(head)->tqh_last = (elm); \ + (head)->tqh_last = &(elm)->field.tqe_next; \ +} while (/*CONSTCOND*/0) + +#define TAILQ_INSERT_AFTER(head, listelm, elm, field) do { \ + QUEUEDEBUG_TAILQ_OP((listelm), field) \ + if (((elm)->field.tqe_next = (listelm)->field.tqe_next) != \ + TAILQ_END(head)) \ + (elm)->field.tqe_next->field.tqe_prev = \ + &(elm)->field.tqe_next; \ + else \ + (head)->tqh_last = &(elm)->field.tqe_next; \ + (listelm)->field.tqe_next = (elm); \ + (elm)->field.tqe_prev = &(listelm)->field.tqe_next; \ +} while (/*CONSTCOND*/0) + +#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \ + QUEUEDEBUG_TAILQ_OP((listelm), field) \ + (elm)->field.tqe_prev = (listelm)->field.tqe_prev; \ + (elm)->field.tqe_next = (listelm); \ + *(listelm)->field.tqe_prev = (elm); \ + (listelm)->field.tqe_prev = &(elm)->field.tqe_next; \ +} while (/*CONSTCOND*/0) + +#define TAILQ_REMOVE(head, elm, field) do { \ + QUEUEDEBUG_TAILQ_PREREMOVE((head), (elm), field) \ + QUEUEDEBUG_TAILQ_OP((elm), field) \ + if (((elm)->field.tqe_next) != TAILQ_END(head)) \ + (elm)->field.tqe_next->field.tqe_prev = \ + (elm)->field.tqe_prev; \ + else \ + (head)->tqh_last = (elm)->field.tqe_prev; \ + *(elm)->field.tqe_prev = (elm)->field.tqe_next; \ + QUEUEDEBUG_TAILQ_POSTREMOVE((elm), field); \ +} while (/*CONSTCOND*/0) + +#define TAILQ_REPLACE(head, elm, elm2, field) do { \ + if (((elm2)->field.tqe_next = (elm)->field.tqe_next) != \ + TAILQ_END(head)) \ + (elm2)->field.tqe_next->field.tqe_prev = \ + &(elm2)->field.tqe_next; \ + else \ + (head)->tqh_last = &(elm2)->field.tqe_next; \ + (elm2)->field.tqe_prev = (elm)->field.tqe_prev; \ + *(elm2)->field.tqe_prev = (elm2); \ + QUEUEDEBUG_TAILQ_POSTREMOVE((elm), field); \ +} while (/*CONSTCOND*/0) + +#define TAILQ_CONCAT(head1, head2, field) do { \ + if (!TAILQ_EMPTY(head2)) { \ + *(head1)->tqh_last = (head2)->tqh_first; \ + (head2)->tqh_first->field.tqe_prev = (head1)->tqh_last; \ + (head1)->tqh_last = (head2)->tqh_last; \ + TAILQ_INIT((head2)); \ + } \ +} while (/*CONSTCOND*/0) + +/* + * Singly-linked Tail queue declarations. + */ +#define STAILQ_HEAD(name, type) \ +struct name { \ + struct type *stqh_first; /* first element */ \ + struct type **stqh_last; /* addr of last next element */ \ +} + +#define STAILQ_HEAD_INITIALIZER(head) \ + { NULL, &(head).stqh_first } + +#define STAILQ_ENTRY(type) \ +struct { \ + struct type *stqe_next; /* next element */ \ +} + +/* + * Singly-linked Tail queue access methods. + */ +#define STAILQ_FIRST(head) ((head)->stqh_first) +#define STAILQ_END(head) NULL +#define STAILQ_NEXT(elm, field) ((elm)->field.stqe_next) +#define STAILQ_EMPTY(head) (STAILQ_FIRST(head) == STAILQ_END(head)) + +/* + * Singly-linked Tail queue functions. + */ +#define STAILQ_INIT(head) do { \ + (head)->stqh_first = NULL; \ + (head)->stqh_last = &(head)->stqh_first; \ +} while (/*CONSTCOND*/0) + +#define STAILQ_INSERT_HEAD(head, elm, field) do { \ + if (((elm)->field.stqe_next = (head)->stqh_first) == NULL) \ + (head)->stqh_last = &(elm)->field.stqe_next; \ + (head)->stqh_first = (elm); \ +} while (/*CONSTCOND*/0) + +#define STAILQ_INSERT_TAIL(head, elm, field) do { \ + (elm)->field.stqe_next = NULL; \ + *(head)->stqh_last = (elm); \ + (head)->stqh_last = &(elm)->field.stqe_next; \ +} while (/*CONSTCOND*/0) + +#define STAILQ_INSERT_AFTER(head, listelm, elm, field) do { \ + if (((elm)->field.stqe_next = (listelm)->field.stqe_next) == NULL)\ + (head)->stqh_last = &(elm)->field.stqe_next; \ + (listelm)->field.stqe_next = (elm); \ +} while (/*CONSTCOND*/0) + +#define STAILQ_REMOVE_HEAD(head, field) do { \ + if (((head)->stqh_first = (head)->stqh_first->field.stqe_next) == NULL) \ + (head)->stqh_last = &(head)->stqh_first; \ +} while (/*CONSTCOND*/0) + +#define STAILQ_REMOVE(head, elm, type, field) do { \ + if ((head)->stqh_first == (elm)) { \ + STAILQ_REMOVE_HEAD((head), field); \ + } else { \ + struct type *curelm = (head)->stqh_first; \ + while (curelm->field.stqe_next != (elm)) \ + curelm = curelm->field.stqe_next; \ + if ((curelm->field.stqe_next = \ + curelm->field.stqe_next->field.stqe_next) == NULL) \ + (head)->stqh_last = &(curelm)->field.stqe_next; \ + } \ +} while (/*CONSTCOND*/0) + +#define STAILQ_FOREACH(var, head, field) \ + for ((var) = ((head)->stqh_first); \ + (var); \ + (var) = ((var)->field.stqe_next)) + +#define STAILQ_FOREACH_SAFE(var, head, field, tvar) \ + for ((var) = STAILQ_FIRST((head)); \ + (var) && ((tvar) = STAILQ_NEXT((var), field), 1); \ + (var) = (tvar)) + +#define STAILQ_CONCAT(head1, head2) do { \ + if (!STAILQ_EMPTY((head2))) { \ + *(head1)->stqh_last = (head2)->stqh_first; \ + (head1)->stqh_last = (head2)->stqh_last; \ + STAILQ_INIT((head2)); \ + } \ +} while (/*CONSTCOND*/0) + +#define STAILQ_LAST(head, type, field) \ + (STAILQ_EMPTY((head)) ? \ + NULL : \ + ((struct type *)(void *) \ + ((char *)((head)->stqh_last) - offsetof(struct type, field)))) + + +#ifndef _KERNEL +/* + * Circular queue definitions. Do not use. We still keep the macros + * for compatibility but because of pointer aliasing issues their use + * is discouraged! + */ + +/* + * __launder_type(): We use this ugly hack to work around the the compiler + * noticing that two types may not alias each other and elide tests in code. + * We hit this in the CIRCLEQ macros when comparing 'struct name *' and + * 'struct type *' (see CIRCLEQ_HEAD()). Modern compilers (such as GCC + * 4.8) declare these comparisons as always false, causing the code to + * not run as designed. + * + * This hack is only to be used for comparisons and thus can be fully const. + * Do not use for assignment. + * + * If we ever choose to change the ABI of the CIRCLEQ macros, we could fix + * this by changing the head/tail sentinal values, but see the note above + * this one. + */ +static __inline const void * __launder_type(const void *); +static __inline const void * +__launder_type(const void *__x) +{ + __asm __volatile("" : "+r" (__x)); + return __x; +} + +#if defined(QUEUEDEBUG) +#define QUEUEDEBUG_CIRCLEQ_HEAD(head, field) \ + if ((head)->cqh_first != CIRCLEQ_ENDC(head) && \ + (head)->cqh_first->field.cqe_prev != CIRCLEQ_ENDC(head)) \ + QUEUEDEBUG_ABORT("CIRCLEQ head forw %p %s:%d", (head), \ + __FILE__, __LINE__); \ + if ((head)->cqh_last != CIRCLEQ_ENDC(head) && \ + (head)->cqh_last->field.cqe_next != CIRCLEQ_ENDC(head)) \ + QUEUEDEBUG_ABORT("CIRCLEQ head back %p %s:%d", (head), \ + __FILE__, __LINE__); +#define QUEUEDEBUG_CIRCLEQ_ELM(head, elm, field) \ + if ((elm)->field.cqe_next == CIRCLEQ_ENDC(head)) { \ + if ((head)->cqh_last != (elm)) \ + QUEUEDEBUG_ABORT("CIRCLEQ elm last %p %s:%d", \ + (elm), __FILE__, __LINE__); \ + } else { \ + if ((elm)->field.cqe_next->field.cqe_prev != (elm)) \ + QUEUEDEBUG_ABORT("CIRCLEQ elm forw %p %s:%d", \ + (elm), __FILE__, __LINE__); \ + } \ + if ((elm)->field.cqe_prev == CIRCLEQ_ENDC(head)) { \ + if ((head)->cqh_first != (elm)) \ + QUEUEDEBUG_ABORT("CIRCLEQ elm first %p %s:%d", \ + (elm), __FILE__, __LINE__); \ + } else { \ + if ((elm)->field.cqe_prev->field.cqe_next != (elm)) \ + QUEUEDEBUG_ABORT("CIRCLEQ elm prev %p %s:%d", \ + (elm), __FILE__, __LINE__); \ + } +#define QUEUEDEBUG_CIRCLEQ_POSTREMOVE(elm, field) \ + (elm)->field.cqe_next = (void *)1L; \ + (elm)->field.cqe_prev = (void *)1L; +#else +#define QUEUEDEBUG_CIRCLEQ_HEAD(head, field) +#define QUEUEDEBUG_CIRCLEQ_ELM(head, elm, field) +#define QUEUEDEBUG_CIRCLEQ_POSTREMOVE(elm, field) +#endif + +#define CIRCLEQ_HEAD(name, type) \ +struct name { \ + struct type *cqh_first; /* first element */ \ + struct type *cqh_last; /* last element */ \ +} + +#define CIRCLEQ_HEAD_INITIALIZER(head) \ + { CIRCLEQ_END(&head), CIRCLEQ_END(&head) } + +#define CIRCLEQ_ENTRY(type) \ +struct { \ + struct type *cqe_next; /* next element */ \ + struct type *cqe_prev; /* previous element */ \ +} + +/* + * Circular queue functions. + */ +#define CIRCLEQ_INIT(head) do { \ + (head)->cqh_first = CIRCLEQ_END(head); \ + (head)->cqh_last = CIRCLEQ_END(head); \ +} while (/*CONSTCOND*/0) + +#define CIRCLEQ_INSERT_AFTER(head, listelm, elm, field) do { \ + QUEUEDEBUG_CIRCLEQ_HEAD((head), field) \ + QUEUEDEBUG_CIRCLEQ_ELM((head), (listelm), field) \ + (elm)->field.cqe_next = (listelm)->field.cqe_next; \ + (elm)->field.cqe_prev = (listelm); \ + if ((listelm)->field.cqe_next == CIRCLEQ_ENDC(head)) \ + (head)->cqh_last = (elm); \ + else \ + (listelm)->field.cqe_next->field.cqe_prev = (elm); \ + (listelm)->field.cqe_next = (elm); \ +} while (/*CONSTCOND*/0) + +#define CIRCLEQ_INSERT_BEFORE(head, listelm, elm, field) do { \ + QUEUEDEBUG_CIRCLEQ_HEAD((head), field) \ + QUEUEDEBUG_CIRCLEQ_ELM((head), (listelm), field) \ + (elm)->field.cqe_next = (listelm); \ + (elm)->field.cqe_prev = (listelm)->field.cqe_prev; \ + if ((listelm)->field.cqe_prev == CIRCLEQ_ENDC(head)) \ + (head)->cqh_first = (elm); \ + else \ + (listelm)->field.cqe_prev->field.cqe_next = (elm); \ + (listelm)->field.cqe_prev = (elm); \ +} while (/*CONSTCOND*/0) + +#define CIRCLEQ_INSERT_HEAD(head, elm, field) do { \ + QUEUEDEBUG_CIRCLEQ_HEAD((head), field) \ + (elm)->field.cqe_next = (head)->cqh_first; \ + (elm)->field.cqe_prev = CIRCLEQ_END(head); \ + if ((head)->cqh_last == CIRCLEQ_ENDC(head)) \ + (head)->cqh_last = (elm); \ + else \ + (head)->cqh_first->field.cqe_prev = (elm); \ + (head)->cqh_first = (elm); \ +} while (/*CONSTCOND*/0) + +#define CIRCLEQ_INSERT_TAIL(head, elm, field) do { \ + QUEUEDEBUG_CIRCLEQ_HEAD((head), field) \ + (elm)->field.cqe_next = CIRCLEQ_END(head); \ + (elm)->field.cqe_prev = (head)->cqh_last; \ + if ((head)->cqh_first == CIRCLEQ_ENDC(head)) \ + (head)->cqh_first = (elm); \ + else \ + (head)->cqh_last->field.cqe_next = (elm); \ + (head)->cqh_last = (elm); \ +} while (/*CONSTCOND*/0) + +#define CIRCLEQ_REMOVE(head, elm, field) do { \ + QUEUEDEBUG_CIRCLEQ_HEAD((head), field) \ + QUEUEDEBUG_CIRCLEQ_ELM((head), (elm), field) \ + if ((elm)->field.cqe_next == CIRCLEQ_ENDC(head)) \ + (head)->cqh_last = (elm)->field.cqe_prev; \ + else \ + (elm)->field.cqe_next->field.cqe_prev = \ + (elm)->field.cqe_prev; \ + if ((elm)->field.cqe_prev == CIRCLEQ_ENDC(head)) \ + (head)->cqh_first = (elm)->field.cqe_next; \ + else \ + (elm)->field.cqe_prev->field.cqe_next = \ + (elm)->field.cqe_next; \ + QUEUEDEBUG_CIRCLEQ_POSTREMOVE((elm), field) \ +} while (/*CONSTCOND*/0) + +#define CIRCLEQ_FOREACH(var, head, field) \ + for ((var) = ((head)->cqh_first); \ + (var) != CIRCLEQ_ENDC(head); \ + (var) = ((var)->field.cqe_next)) + +#define CIRCLEQ_FOREACH_REVERSE(var, head, field) \ + for ((var) = ((head)->cqh_last); \ + (var) != CIRCLEQ_ENDC(head); \ + (var) = ((var)->field.cqe_prev)) + +/* + * Circular queue access methods. + */ +#define CIRCLEQ_FIRST(head) ((head)->cqh_first) +#define CIRCLEQ_LAST(head) ((head)->cqh_last) +/* For comparisons */ +#define CIRCLEQ_ENDC(head) (__launder_type(head)) +/* For assignments */ +#define CIRCLEQ_END(head) ((void *)(head)) +#define CIRCLEQ_NEXT(elm, field) ((elm)->field.cqe_next) +#define CIRCLEQ_PREV(elm, field) ((elm)->field.cqe_prev) +#define CIRCLEQ_EMPTY(head) \ + (CIRCLEQ_FIRST(head) == CIRCLEQ_ENDC(head)) + +#define CIRCLEQ_LOOP_NEXT(head, elm, field) \ + (((elm)->field.cqe_next == CIRCLEQ_ENDC(head)) \ + ? ((head)->cqh_first) \ + : (elm->field.cqe_next)) +#define CIRCLEQ_LOOP_PREV(head, elm, field) \ + (((elm)->field.cqe_prev == CIRCLEQ_ENDC(head)) \ + ? ((head)->cqh_last) \ + : (elm->field.cqe_prev)) +#endif /* !_KERNEL */ + +#endif /* !_SYS_QUEUE_H_ */ diff --git a/base/musl/stab.h b/base/musl/stab.h new file mode 100644 index 0000000..8b85e75 --- /dev/null +++ b/base/musl/stab.h @@ -0,0 +1,37 @@ +#ifndef _STAB_H_ +#define _STAB_H_ + +/* + * The following are symbols used by various debuggers and by the Pascal + * compiler. Each of them must have one (or more) of the bits defined by + * the N_STAB mask set. + */ + +#define N_GSYM 0x20 /* global symbol */ +#define N_FNAME 0x22 /* F77 function name */ +#define N_FUN 0x24 /* procedure name */ +#define N_STSYM 0x26 /* data segment variable */ +#define N_LCSYM 0x28 /* bss segment variable */ +#define N_MAIN 0x2a /* main function name */ +#define N_PC 0x30 /* global Pascal symbol */ +#define N_RSYM 0x40 /* register variable */ +#define N_SLINE 0x44 /* text segment line number */ +#define N_DSLINE 0x46 /* data segment line number */ +#define N_BSLINE 0x48 /* bss segment line number */ +#define N_SSYM 0x60 /* structure/union element */ +#define N_SO 0x64 /* main source file name */ +#define N_LSYM 0x80 /* stack variable */ +#define N_BINCL 0x82 /* include file beginning */ +#define N_SOL 0x84 /* included source file name */ +#define N_PSYM 0xa0 /* parameter variable */ +#define N_EINCL 0xa2 /* include file end */ +#define N_ENTRY 0xa4 /* alternate entry point */ +#define N_LBRAC 0xc0 /* left bracket */ +#define N_EXCL 0xc2 /* deleted include file */ +#define N_RBRAC 0xe0 /* right bracket */ +#define N_BCOMM 0xe2 /* begin common */ +#define N_ECOMM 0xe4 /* end common */ +#define N_ECOML 0xe8 /* end common (local name) */ +#define N_LENG 0xfe /* length of preceding entry */ + +#endif /* !_STAB_H_ */ diff --git a/base/musl/tree.h b/base/musl/tree.h new file mode 100644 index 0000000..eaea56a --- /dev/null +++ b/base/musl/tree.h @@ -0,0 +1,761 @@ +/* $NetBSD: tree.h,v 1.20 2013/09/14 13:20:45 joerg Exp $ */ +/* $OpenBSD: tree.h,v 1.13 2011/07/09 00:19:45 pirofti Exp $ */ +/* + * Copyright 2002 Niels Provos + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef _SYS_TREE_H_ +#define _SYS_TREE_H_ + +/* + * This file defines data structures for different types of trees: + * splay trees and red-black trees. + * + * A splay tree is a self-organizing data structure. Every operation + * on the tree causes a splay to happen. The splay moves the requested + * node to the root of the tree and partly rebalances it. + * + * This has the benefit that request locality causes faster lookups as + * the requested nodes move to the top of the tree. On the other hand, + * every lookup causes memory writes. + * + * The Balance Theorem bounds the total access time for m operations + * and n inserts on an initially empty tree as O((m + n)lg n). The + * amortized cost for a sequence of m accesses to a splay tree is O(lg n); + * + * A red-black tree is a binary search tree with the node color as an + * extra attribute. It fulfills a set of conditions: + * - every search path from the root to a leaf consists of the + * same number of black nodes, + * - each red node (except for the root) has a black parent, + * - each leaf node is black. + * + * Every operation on a red-black tree is bounded as O(lg n). + * The maximum height of a red-black tree is 2lg (n+1). + */ + +#define SPLAY_HEAD(name, type) \ +struct name { \ + struct type *sph_root; /* root of the tree */ \ +} + +#define SPLAY_INITIALIZER(root) \ + { NULL } + +#define SPLAY_INIT(root) do { \ + (root)->sph_root = NULL; \ +} while (/*CONSTCOND*/ 0) + +#define SPLAY_ENTRY(type) \ +struct { \ + struct type *spe_left; /* left element */ \ + struct type *spe_right; /* right element */ \ +} + +#define SPLAY_LEFT(elm, field) (elm)->field.spe_left +#define SPLAY_RIGHT(elm, field) (elm)->field.spe_right +#define SPLAY_ROOT(head) (head)->sph_root +#define SPLAY_EMPTY(head) (SPLAY_ROOT(head) == NULL) + +/* SPLAY_ROTATE_{LEFT,RIGHT} expect that tmp hold SPLAY_{RIGHT,LEFT} */ +#define SPLAY_ROTATE_RIGHT(head, tmp, field) do { \ + SPLAY_LEFT((head)->sph_root, field) = SPLAY_RIGHT(tmp, field); \ + SPLAY_RIGHT(tmp, field) = (head)->sph_root; \ + (head)->sph_root = tmp; \ +} while (/*CONSTCOND*/ 0) + +#define SPLAY_ROTATE_LEFT(head, tmp, field) do { \ + SPLAY_RIGHT((head)->sph_root, field) = SPLAY_LEFT(tmp, field); \ + SPLAY_LEFT(tmp, field) = (head)->sph_root; \ + (head)->sph_root = tmp; \ +} while (/*CONSTCOND*/ 0) + +#define SPLAY_LINKLEFT(head, tmp, field) do { \ + SPLAY_LEFT(tmp, field) = (head)->sph_root; \ + tmp = (head)->sph_root; \ + (head)->sph_root = SPLAY_LEFT((head)->sph_root, field); \ +} while (/*CONSTCOND*/ 0) + +#define SPLAY_LINKRIGHT(head, tmp, field) do { \ + SPLAY_RIGHT(tmp, field) = (head)->sph_root; \ + tmp = (head)->sph_root; \ + (head)->sph_root = SPLAY_RIGHT((head)->sph_root, field); \ +} while (/*CONSTCOND*/ 0) + +#define SPLAY_ASSEMBLE(head, node, left, right, field) do { \ + SPLAY_RIGHT(left, field) = SPLAY_LEFT((head)->sph_root, field); \ + SPLAY_LEFT(right, field) = SPLAY_RIGHT((head)->sph_root, field);\ + SPLAY_LEFT((head)->sph_root, field) = SPLAY_RIGHT(node, field); \ + SPLAY_RIGHT((head)->sph_root, field) = SPLAY_LEFT(node, field); \ +} while (/*CONSTCOND*/ 0) + +/* Generates prototypes and inline functions */ + +#define SPLAY_PROTOTYPE(name, type, field, cmp) \ +void name##_SPLAY(struct name *, struct type *); \ +void name##_SPLAY_MINMAX(struct name *, int); \ +struct type *name##_SPLAY_INSERT(struct name *, struct type *); \ +struct type *name##_SPLAY_REMOVE(struct name *, struct type *); \ + \ +/* Finds the node with the same key as elm */ \ +static __inline struct type * \ +name##_SPLAY_FIND(struct name *head, struct type *elm) \ +{ \ + if (SPLAY_EMPTY(head)) \ + return(NULL); \ + name##_SPLAY(head, elm); \ + if ((cmp)(elm, (head)->sph_root) == 0) \ + return (head->sph_root); \ + return (NULL); \ +} \ + \ +static __inline __unused struct type * \ +name##_SPLAY_NEXT(struct name *head, struct type *elm) \ +{ \ + name##_SPLAY(head, elm); \ + if (SPLAY_RIGHT(elm, field) != NULL) { \ + elm = SPLAY_RIGHT(elm, field); \ + while (SPLAY_LEFT(elm, field) != NULL) { \ + elm = SPLAY_LEFT(elm, field); \ + } \ + } else \ + elm = NULL; \ + return (elm); \ +} \ + \ +static __unused __inline struct type * \ +name##_SPLAY_MIN_MAX(struct name *head, int val) \ +{ \ + name##_SPLAY_MINMAX(head, val); \ + return (SPLAY_ROOT(head)); \ +} + +/* Main splay operation. + * Moves node close to the key of elm to top + */ +#define SPLAY_GENERATE(name, type, field, cmp) \ +struct type * \ +name##_SPLAY_INSERT(struct name *head, struct type *elm) \ +{ \ + if (SPLAY_EMPTY(head)) { \ + SPLAY_LEFT(elm, field) = SPLAY_RIGHT(elm, field) = NULL; \ + } else { \ + int __comp; \ + name##_SPLAY(head, elm); \ + __comp = (cmp)(elm, (head)->sph_root); \ + if(__comp < 0) { \ + SPLAY_LEFT(elm, field) = SPLAY_LEFT((head)->sph_root, field);\ + SPLAY_RIGHT(elm, field) = (head)->sph_root; \ + SPLAY_LEFT((head)->sph_root, field) = NULL; \ + } else if (__comp > 0) { \ + SPLAY_RIGHT(elm, field) = SPLAY_RIGHT((head)->sph_root, field);\ + SPLAY_LEFT(elm, field) = (head)->sph_root; \ + SPLAY_RIGHT((head)->sph_root, field) = NULL; \ + } else \ + return ((head)->sph_root); \ + } \ + (head)->sph_root = (elm); \ + return (NULL); \ +} \ + \ +struct type * \ +name##_SPLAY_REMOVE(struct name *head, struct type *elm) \ +{ \ + struct type *__tmp; \ + if (SPLAY_EMPTY(head)) \ + return (NULL); \ + name##_SPLAY(head, elm); \ + if ((cmp)(elm, (head)->sph_root) == 0) { \ + if (SPLAY_LEFT((head)->sph_root, field) == NULL) { \ + (head)->sph_root = SPLAY_RIGHT((head)->sph_root, field);\ + } else { \ + __tmp = SPLAY_RIGHT((head)->sph_root, field); \ + (head)->sph_root = SPLAY_LEFT((head)->sph_root, field);\ + name##_SPLAY(head, elm); \ + SPLAY_RIGHT((head)->sph_root, field) = __tmp; \ + } \ + return (elm); \ + } \ + return (NULL); \ +} \ + \ +void \ +name##_SPLAY(struct name *head, struct type *elm) \ +{ \ + struct type __node, *__left, *__right, *__tmp; \ + int __comp; \ +\ + SPLAY_LEFT(&__node, field) = SPLAY_RIGHT(&__node, field) = NULL;\ + __left = __right = &__node; \ +\ + while ((__comp = (cmp)(elm, (head)->sph_root)) != 0) { \ + if (__comp < 0) { \ + __tmp = SPLAY_LEFT((head)->sph_root, field); \ + if (__tmp == NULL) \ + break; \ + if ((cmp)(elm, __tmp) < 0){ \ + SPLAY_ROTATE_RIGHT(head, __tmp, field); \ + if (SPLAY_LEFT((head)->sph_root, field) == NULL)\ + break; \ + } \ + SPLAY_LINKLEFT(head, __right, field); \ + } else if (__comp > 0) { \ + __tmp = SPLAY_RIGHT((head)->sph_root, field); \ + if (__tmp == NULL) \ + break; \ + if ((cmp)(elm, __tmp) > 0){ \ + SPLAY_ROTATE_LEFT(head, __tmp, field); \ + if (SPLAY_RIGHT((head)->sph_root, field) == NULL)\ + break; \ + } \ + SPLAY_LINKRIGHT(head, __left, field); \ + } \ + } \ + SPLAY_ASSEMBLE(head, &__node, __left, __right, field); \ +} \ + \ +/* Splay with either the minimum or the maximum element \ + * Used to find minimum or maximum element in tree. \ + */ \ +void name##_SPLAY_MINMAX(struct name *head, int __comp) \ +{ \ + struct type __node, *__left, *__right, *__tmp; \ +\ + SPLAY_LEFT(&__node, field) = SPLAY_RIGHT(&__node, field) = NULL;\ + __left = __right = &__node; \ +\ + while (1) { \ + if (__comp < 0) { \ + __tmp = SPLAY_LEFT((head)->sph_root, field); \ + if (__tmp == NULL) \ + break; \ + if (__comp < 0){ \ + SPLAY_ROTATE_RIGHT(head, __tmp, field); \ + if (SPLAY_LEFT((head)->sph_root, field) == NULL)\ + break; \ + } \ + SPLAY_LINKLEFT(head, __right, field); \ + } else if (__comp > 0) { \ + __tmp = SPLAY_RIGHT((head)->sph_root, field); \ + if (__tmp == NULL) \ + break; \ + if (__comp > 0) { \ + SPLAY_ROTATE_LEFT(head, __tmp, field); \ + if (SPLAY_RIGHT((head)->sph_root, field) == NULL)\ + break; \ + } \ + SPLAY_LINKRIGHT(head, __left, field); \ + } \ + } \ + SPLAY_ASSEMBLE(head, &__node, __left, __right, field); \ +} + +#define SPLAY_NEGINF -1 +#define SPLAY_INF 1 + +#define SPLAY_INSERT(name, x, y) name##_SPLAY_INSERT(x, y) +#define SPLAY_REMOVE(name, x, y) name##_SPLAY_REMOVE(x, y) +#define SPLAY_FIND(name, x, y) name##_SPLAY_FIND(x, y) +#define SPLAY_NEXT(name, x, y) name##_SPLAY_NEXT(x, y) +#define SPLAY_MIN(name, x) (SPLAY_EMPTY(x) ? NULL \ + : name##_SPLAY_MIN_MAX(x, SPLAY_NEGINF)) +#define SPLAY_MAX(name, x) (SPLAY_EMPTY(x) ? NULL \ + : name##_SPLAY_MIN_MAX(x, SPLAY_INF)) + +#define SPLAY_FOREACH(x, name, head) \ + for ((x) = SPLAY_MIN(name, head); \ + (x) != NULL; \ + (x) = SPLAY_NEXT(name, head, x)) + +/* Macros that define a red-black tree */ +#define RB_HEAD(name, type) \ +struct name { \ + struct type *rbh_root; /* root of the tree */ \ +} + +#define RB_INITIALIZER(root) \ + { NULL } + +#define RB_INIT(root) do { \ + (root)->rbh_root = NULL; \ +} while (/*CONSTCOND*/ 0) + +#define RB_BLACK 0 +#define RB_RED 1 +#define RB_ENTRY(type) \ +struct { \ + struct type *rbe_left; /* left element */ \ + struct type *rbe_right; /* right element */ \ + struct type *rbe_parent; /* parent element */ \ + int rbe_color; /* node color */ \ +} + +#define RB_LEFT(elm, field) (elm)->field.rbe_left +#define RB_RIGHT(elm, field) (elm)->field.rbe_right +#define RB_PARENT(elm, field) (elm)->field.rbe_parent +#define RB_COLOR(elm, field) (elm)->field.rbe_color +#define RB_ROOT(head) (head)->rbh_root +#define RB_EMPTY(head) (RB_ROOT(head) == NULL) + +#define RB_SET(elm, parent, field) do { \ + RB_PARENT(elm, field) = parent; \ + RB_LEFT(elm, field) = RB_RIGHT(elm, field) = NULL; \ + RB_COLOR(elm, field) = RB_RED; \ +} while (/*CONSTCOND*/ 0) + +#define RB_SET_BLACKRED(black, red, field) do { \ + RB_COLOR(black, field) = RB_BLACK; \ + RB_COLOR(red, field) = RB_RED; \ +} while (/*CONSTCOND*/ 0) + +#ifndef RB_AUGMENT +#define RB_AUGMENT(x) do {} while (/*CONSTCOND*/ 0) +#endif + +#define RB_ROTATE_LEFT(head, elm, tmp, field) do { \ + (tmp) = RB_RIGHT(elm, field); \ + if ((RB_RIGHT(elm, field) = RB_LEFT(tmp, field)) != NULL) { \ + RB_PARENT(RB_LEFT(tmp, field), field) = (elm); \ + } \ + RB_AUGMENT(elm); \ + if ((RB_PARENT(tmp, field) = RB_PARENT(elm, field)) != NULL) { \ + if ((elm) == RB_LEFT(RB_PARENT(elm, field), field)) \ + RB_LEFT(RB_PARENT(elm, field), field) = (tmp); \ + else \ + RB_RIGHT(RB_PARENT(elm, field), field) = (tmp); \ + } else \ + (head)->rbh_root = (tmp); \ + RB_LEFT(tmp, field) = (elm); \ + RB_PARENT(elm, field) = (tmp); \ + RB_AUGMENT(tmp); \ + if ((RB_PARENT(tmp, field))) \ + RB_AUGMENT(RB_PARENT(tmp, field)); \ +} while (/*CONSTCOND*/ 0) + +#define RB_ROTATE_RIGHT(head, elm, tmp, field) do { \ + (tmp) = RB_LEFT(elm, field); \ + if ((RB_LEFT(elm, field) = RB_RIGHT(tmp, field)) != NULL) { \ + RB_PARENT(RB_RIGHT(tmp, field), field) = (elm); \ + } \ + RB_AUGMENT(elm); \ + if ((RB_PARENT(tmp, field) = RB_PARENT(elm, field)) != NULL) { \ + if ((elm) == RB_LEFT(RB_PARENT(elm, field), field)) \ + RB_LEFT(RB_PARENT(elm, field), field) = (tmp); \ + else \ + RB_RIGHT(RB_PARENT(elm, field), field) = (tmp); \ + } else \ + (head)->rbh_root = (tmp); \ + RB_RIGHT(tmp, field) = (elm); \ + RB_PARENT(elm, field) = (tmp); \ + RB_AUGMENT(tmp); \ + if ((RB_PARENT(tmp, field))) \ + RB_AUGMENT(RB_PARENT(tmp, field)); \ +} while (/*CONSTCOND*/ 0) + +/* Generates prototypes and inline functions */ +#define RB_PROTOTYPE(name, type, field, cmp) \ + RB_PROTOTYPE_INTERNAL(name, type, field, cmp,) +#define RB_PROTOTYPE_STATIC(name, type, field, cmp) \ + RB_PROTOTYPE_INTERNAL(name, type, field, cmp, __unused static) +#define RB_PROTOTYPE_INTERNAL(name, type, field, cmp, attr) \ +attr void name##_RB_INSERT_COLOR(struct name *, struct type *); \ +attr void name##_RB_REMOVE_COLOR(struct name *, struct type *, struct type *);\ +attr struct type *name##_RB_REMOVE(struct name *, struct type *); \ +attr struct type *name##_RB_INSERT(struct name *, struct type *); \ +attr struct type *name##_RB_FIND(struct name *, struct type *); \ +attr struct type *name##_RB_NFIND(struct name *, struct type *); \ +attr struct type *name##_RB_NEXT(struct type *); \ +attr struct type *name##_RB_PREV(struct type *); \ +attr struct type *name##_RB_MINMAX(struct name *, int); \ + \ + +/* Main rb operation. + * Moves node close to the key of elm to top + */ +#define RB_GENERATE(name, type, field, cmp) \ + RB_GENERATE_INTERNAL(name, type, field, cmp,) +#define RB_GENERATE_STATIC(name, type, field, cmp) \ + RB_GENERATE_INTERNAL(name, type, field, cmp, __unused static) +#define RB_GENERATE_INTERNAL(name, type, field, cmp, attr) \ +attr void \ +name##_RB_INSERT_COLOR(struct name *head, struct type *elm) \ +{ \ + struct type *parent, *gparent, *tmp; \ + while ((parent = RB_PARENT(elm, field)) != NULL && \ + RB_COLOR(parent, field) == RB_RED) { \ + gparent = RB_PARENT(parent, field); \ + if (parent == RB_LEFT(gparent, field)) { \ + tmp = RB_RIGHT(gparent, field); \ + if (tmp && RB_COLOR(tmp, field) == RB_RED) { \ + RB_COLOR(tmp, field) = RB_BLACK; \ + RB_SET_BLACKRED(parent, gparent, field);\ + elm = gparent; \ + continue; \ + } \ + if (RB_RIGHT(parent, field) == elm) { \ + RB_ROTATE_LEFT(head, parent, tmp, field);\ + tmp = parent; \ + parent = elm; \ + elm = tmp; \ + } \ + RB_SET_BLACKRED(parent, gparent, field); \ + RB_ROTATE_RIGHT(head, gparent, tmp, field); \ + } else { \ + tmp = RB_LEFT(gparent, field); \ + if (tmp && RB_COLOR(tmp, field) == RB_RED) { \ + RB_COLOR(tmp, field) = RB_BLACK; \ + RB_SET_BLACKRED(parent, gparent, field);\ + elm = gparent; \ + continue; \ + } \ + if (RB_LEFT(parent, field) == elm) { \ + RB_ROTATE_RIGHT(head, parent, tmp, field);\ + tmp = parent; \ + parent = elm; \ + elm = tmp; \ + } \ + RB_SET_BLACKRED(parent, gparent, field); \ + RB_ROTATE_LEFT(head, gparent, tmp, field); \ + } \ + } \ + RB_COLOR(head->rbh_root, field) = RB_BLACK; \ +} \ + \ +attr void \ +name##_RB_REMOVE_COLOR(struct name *head, struct type *parent, struct type *elm) \ +{ \ + struct type *tmp; \ + while ((elm == NULL || RB_COLOR(elm, field) == RB_BLACK) && \ + elm != RB_ROOT(head)) { \ + if (RB_LEFT(parent, field) == elm) { \ + tmp = RB_RIGHT(parent, field); \ + if (RB_COLOR(tmp, field) == RB_RED) { \ + RB_SET_BLACKRED(tmp, parent, field); \ + RB_ROTATE_LEFT(head, parent, tmp, field);\ + tmp = RB_RIGHT(parent, field); \ + } \ + if ((RB_LEFT(tmp, field) == NULL || \ + RB_COLOR(RB_LEFT(tmp, field), field) == RB_BLACK) &&\ + (RB_RIGHT(tmp, field) == NULL || \ + RB_COLOR(RB_RIGHT(tmp, field), field) == RB_BLACK)) {\ + RB_COLOR(tmp, field) = RB_RED; \ + elm = parent; \ + parent = RB_PARENT(elm, field); \ + } else { \ + if (RB_RIGHT(tmp, field) == NULL || \ + RB_COLOR(RB_RIGHT(tmp, field), field) == RB_BLACK) {\ + struct type *oleft; \ + if ((oleft = RB_LEFT(tmp, field)) \ + != NULL) \ + RB_COLOR(oleft, field) = RB_BLACK;\ + RB_COLOR(tmp, field) = RB_RED; \ + RB_ROTATE_RIGHT(head, tmp, oleft, field);\ + tmp = RB_RIGHT(parent, field); \ + } \ + RB_COLOR(tmp, field) = RB_COLOR(parent, field);\ + RB_COLOR(parent, field) = RB_BLACK; \ + if (RB_RIGHT(tmp, field)) \ + RB_COLOR(RB_RIGHT(tmp, field), field) = RB_BLACK;\ + RB_ROTATE_LEFT(head, parent, tmp, field);\ + elm = RB_ROOT(head); \ + break; \ + } \ + } else { \ + tmp = RB_LEFT(parent, field); \ + if (RB_COLOR(tmp, field) == RB_RED) { \ + RB_SET_BLACKRED(tmp, parent, field); \ + RB_ROTATE_RIGHT(head, parent, tmp, field);\ + tmp = RB_LEFT(parent, field); \ + } \ + if ((RB_LEFT(tmp, field) == NULL || \ + RB_COLOR(RB_LEFT(tmp, field), field) == RB_BLACK) &&\ + (RB_RIGHT(tmp, field) == NULL || \ + RB_COLOR(RB_RIGHT(tmp, field), field) == RB_BLACK)) {\ + RB_COLOR(tmp, field) = RB_RED; \ + elm = parent; \ + parent = RB_PARENT(elm, field); \ + } else { \ + if (RB_LEFT(tmp, field) == NULL || \ + RB_COLOR(RB_LEFT(tmp, field), field) == RB_BLACK) {\ + struct type *oright; \ + if ((oright = RB_RIGHT(tmp, field)) \ + != NULL) \ + RB_COLOR(oright, field) = RB_BLACK;\ + RB_COLOR(tmp, field) = RB_RED; \ + RB_ROTATE_LEFT(head, tmp, oright, field);\ + tmp = RB_LEFT(parent, field); \ + } \ + RB_COLOR(tmp, field) = RB_COLOR(parent, field);\ + RB_COLOR(parent, field) = RB_BLACK; \ + if (RB_LEFT(tmp, field)) \ + RB_COLOR(RB_LEFT(tmp, field), field) = RB_BLACK;\ + RB_ROTATE_RIGHT(head, parent, tmp, field);\ + elm = RB_ROOT(head); \ + break; \ + } \ + } \ + } \ + if (elm) \ + RB_COLOR(elm, field) = RB_BLACK; \ +} \ + \ +attr struct type * \ +name##_RB_REMOVE(struct name *head, struct type *elm) \ +{ \ + struct type *child, *parent, *old = elm; \ + int color; \ + if (RB_LEFT(elm, field) == NULL) \ + child = RB_RIGHT(elm, field); \ + else if (RB_RIGHT(elm, field) == NULL) \ + child = RB_LEFT(elm, field); \ + else { \ + struct type *left; \ + elm = RB_RIGHT(elm, field); \ + while ((left = RB_LEFT(elm, field)) != NULL) \ + elm = left; \ + child = RB_RIGHT(elm, field); \ + parent = RB_PARENT(elm, field); \ + color = RB_COLOR(elm, field); \ + if (child) \ + RB_PARENT(child, field) = parent; \ + if (parent) { \ + if (RB_LEFT(parent, field) == elm) \ + RB_LEFT(parent, field) = child; \ + else \ + RB_RIGHT(parent, field) = child; \ + RB_AUGMENT(parent); \ + } else \ + RB_ROOT(head) = child; \ + if (RB_PARENT(elm, field) == old) \ + parent = elm; \ + (elm)->field = (old)->field; \ + if (RB_PARENT(old, field)) { \ + if (RB_LEFT(RB_PARENT(old, field), field) == old)\ + RB_LEFT(RB_PARENT(old, field), field) = elm;\ + else \ + RB_RIGHT(RB_PARENT(old, field), field) = elm;\ + RB_AUGMENT(RB_PARENT(old, field)); \ + } else \ + RB_ROOT(head) = elm; \ + RB_PARENT(RB_LEFT(old, field), field) = elm; \ + if (RB_RIGHT(old, field)) \ + RB_PARENT(RB_RIGHT(old, field), field) = elm; \ + if (parent) { \ + left = parent; \ + do { \ + RB_AUGMENT(left); \ + } while ((left = RB_PARENT(left, field)) != NULL); \ + } \ + goto color; \ + } \ + parent = RB_PARENT(elm, field); \ + color = RB_COLOR(elm, field); \ + if (child) \ + RB_PARENT(child, field) = parent; \ + if (parent) { \ + if (RB_LEFT(parent, field) == elm) \ + RB_LEFT(parent, field) = child; \ + else \ + RB_RIGHT(parent, field) = child; \ + RB_AUGMENT(parent); \ + } else \ + RB_ROOT(head) = child; \ +color: \ + if (color == RB_BLACK) \ + name##_RB_REMOVE_COLOR(head, parent, child); \ + return (old); \ +} \ + \ +/* Inserts a node into the RB tree */ \ +attr struct type * \ +name##_RB_INSERT(struct name *head, struct type *elm) \ +{ \ + struct type *tmp; \ + struct type *parent = NULL; \ + int comp = 0; \ + tmp = RB_ROOT(head); \ + while (tmp) { \ + parent = tmp; \ + comp = (cmp)(elm, parent); \ + if (comp < 0) \ + tmp = RB_LEFT(tmp, field); \ + else if (comp > 0) \ + tmp = RB_RIGHT(tmp, field); \ + else \ + return (tmp); \ + } \ + RB_SET(elm, parent, field); \ + if (parent != NULL) { \ + if (comp < 0) \ + RB_LEFT(parent, field) = elm; \ + else \ + RB_RIGHT(parent, field) = elm; \ + RB_AUGMENT(parent); \ + } else \ + RB_ROOT(head) = elm; \ + name##_RB_INSERT_COLOR(head, elm); \ + return (NULL); \ +} \ + \ +/* Finds the node with the same key as elm */ \ +attr struct type * \ +name##_RB_FIND(struct name *head, struct type *elm) \ +{ \ + struct type *tmp = RB_ROOT(head); \ + int comp; \ + while (tmp) { \ + comp = cmp(elm, tmp); \ + if (comp < 0) \ + tmp = RB_LEFT(tmp, field); \ + else if (comp > 0) \ + tmp = RB_RIGHT(tmp, field); \ + else \ + return (tmp); \ + } \ + return (NULL); \ +} \ + \ +/* Finds the first node greater than or equal to the search key */ \ +attr struct type * \ +name##_RB_NFIND(struct name *head, struct type *elm) \ +{ \ + struct type *tmp = RB_ROOT(head); \ + struct type *res = NULL; \ + int comp; \ + while (tmp) { \ + comp = cmp(elm, tmp); \ + if (comp < 0) { \ + res = tmp; \ + tmp = RB_LEFT(tmp, field); \ + } \ + else if (comp > 0) \ + tmp = RB_RIGHT(tmp, field); \ + else \ + return (tmp); \ + } \ + return (res); \ +} \ + \ +/* ARGSUSED */ \ +attr struct type * \ +name##_RB_NEXT(struct type *elm) \ +{ \ + if (RB_RIGHT(elm, field)) { \ + elm = RB_RIGHT(elm, field); \ + while (RB_LEFT(elm, field)) \ + elm = RB_LEFT(elm, field); \ + } else { \ + if (RB_PARENT(elm, field) && \ + (elm == RB_LEFT(RB_PARENT(elm, field), field))) \ + elm = RB_PARENT(elm, field); \ + else { \ + while (RB_PARENT(elm, field) && \ + (elm == RB_RIGHT(RB_PARENT(elm, field), field)))\ + elm = RB_PARENT(elm, field); \ + elm = RB_PARENT(elm, field); \ + } \ + } \ + return (elm); \ +} \ + \ +/* ARGSUSED */ \ +attr struct type * \ +name##_RB_PREV(struct type *elm) \ +{ \ + if (RB_LEFT(elm, field)) { \ + elm = RB_LEFT(elm, field); \ + while (RB_RIGHT(elm, field)) \ + elm = RB_RIGHT(elm, field); \ + } else { \ + if (RB_PARENT(elm, field) && \ + (elm == RB_RIGHT(RB_PARENT(elm, field), field))) \ + elm = RB_PARENT(elm, field); \ + else { \ + while (RB_PARENT(elm, field) && \ + (elm == RB_LEFT(RB_PARENT(elm, field), field)))\ + elm = RB_PARENT(elm, field); \ + elm = RB_PARENT(elm, field); \ + } \ + } \ + return (elm); \ +} \ + \ +attr struct type * \ +name##_RB_MINMAX(struct name *head, int val) \ +{ \ + struct type *tmp = RB_ROOT(head); \ + struct type *parent = NULL; \ + while (tmp) { \ + parent = tmp; \ + if (val < 0) \ + tmp = RB_LEFT(tmp, field); \ + else \ + tmp = RB_RIGHT(tmp, field); \ + } \ + return (parent); \ +} + +#define RB_NEGINF -1 +#define RB_INF 1 + +#define RB_INSERT(name, x, y) name##_RB_INSERT(x, y) +#define RB_REMOVE(name, x, y) name##_RB_REMOVE(x, y) +#define RB_FIND(name, x, y) name##_RB_FIND(x, y) +#define RB_NFIND(name, x, y) name##_RB_NFIND(x, y) +#define RB_NEXT(name, x, y) name##_RB_NEXT(y) +#define RB_PREV(name, x, y) name##_RB_PREV(y) +#define RB_MIN(name, x) name##_RB_MINMAX(x, RB_NEGINF) +#define RB_MAX(name, x) name##_RB_MINMAX(x, RB_INF) + +#define RB_FOREACH(x, name, head) \ + for ((x) = RB_MIN(name, head); \ + (x) != NULL; \ + (x) = name##_RB_NEXT(x)) + +#define RB_FOREACH_FROM(x, name, y) \ + for ((x) = (y); \ + ((x) != NULL) && ((y) = name##_RB_NEXT(x), (x) != NULL); \ + (x) = (y)) + +#define RB_FOREACH_SAFE(x, name, head, y) \ + for ((x) = RB_MIN(name, head); \ + ((x) != NULL) && ((y) = name##_RB_NEXT(x), (x) != NULL); \ + (x) = (y)) + +#define RB_FOREACH_REVERSE(x, name, head) \ + for ((x) = RB_MAX(name, head); \ + (x) != NULL; \ + (x) = name##_RB_PREV(x)) + +#define RB_FOREACH_REVERSE_FROM(x, name, y) \ + for ((x) = (y); \ + ((x) != NULL) && ((y) = name##_RB_PREV(x), (x) != NULL); \ + (x) = (y)) + +#define RB_FOREACH_REVERSE_SAFE(x, name, head, y) \ + for ((x) = RB_MAX(name, head); \ + ((x) != NULL) && ((y) = name##_RB_PREV(x), (x) != NULL); \ + (x) = (y)) + +#endif /* _SYS_TREE_H_ */ diff --git a/base/mypaint-brushes/mypaint-brushes.SMBuild b/base/mypaint-brushes/mypaint-brushes.SMBuild new file mode 100755 index 0000000..2ab6454 --- /dev/null +++ b/base/mypaint-brushes/mypaint-brushes.SMBuild @@ -0,0 +1,30 @@ +APP=mypaint-brushes +VERSION=1.3.0 +BUILD=1sml +HOMEPAGE='https://github.com/Jehan/mypaint-brushes' +DOWNLOAD='https://github.com/Jehan/mypaint-brushes/archive/v1.3.0/mypaint-brushes-v1.3.0.tar.gz' +DESC="Brushes used by MyPaint and other software using libmypaint" +REQUIRES="libmypaint" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING Licenses* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bc96342055349b475d5ef6d00ac36f1bc688acf850a31fa3b71f4ff86892a97271334fa76a5d37aa28a67de34d652e4c176b600c83c45124e2dfb7a0035e0a19 mypaint-brushes-1.3.0.tar.lz +" diff --git a/base/nano/nano.SMBuild b/base/nano/nano.SMBuild new file mode 100755 index 0000000..4746499 --- /dev/null +++ b/base/nano/nano.SMBuild @@ -0,0 +1,32 @@ +APP=nano +VERSION=3.2 +BUILD=1sml +HOMEPAGE='http://www.nano-editor.org' +DOWNLOAD='https://www.nano-editor.org/dist/v3/nano-3.2.tar.xz' +DESC="Nano's ANOther editor, an enhanced free Pico clone" +REQUIRES="file netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8fce9cf85a4663a4a8961887b8c6f37ca8b3caf0ab1fc69ff1e7f8ce7452807e9f1b2851fffec9e281e46631d1ac127392d774e01bd310b42db97a4f7824e55e nano-3.2.tar.lz +" diff --git a/base/nasm/nasm.SMBuild b/base/nasm/nasm.SMBuild new file mode 100755 index 0000000..2dcbe59 --- /dev/null +++ b/base/nasm/nasm.SMBuild @@ -0,0 +1,37 @@ +APP=nasm +VERSION=2.14.02 +BUILD=1sml +HOMEPAGE='https://www.nasm.us/' +DOWNLOAD='https://www.nasm.us/pub/nasm/releasebuilds/2.14.02/nasm-2.14.02.tar.xz' +DESC="Netwide assembler providing instruction mnemonics and syntax" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + if [ "ARCH" == "aarch64" ]; then + HOSTDIST="--host=arm-musl-linux" + fi + + CFLAGS="-D_GNU_SOURCE" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + $HOSTDIST + + make + make install DESTDIR=$PKG + + cp AUTHORS LICENSE README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +760e44e99737cf5609c13b365a0d9edcb31bd767e6906f53e9134c507edd4b722ef11f230450b0065820b5a9d5fa3e36dc13407dc2747b6e5afaa48a28b0ea41 nasm-2.14.02.tar.lz +" diff --git a/base/ncdu/ncdu.SMBuild b/base/ncdu/ncdu.SMBuild new file mode 100755 index 0000000..414d573 --- /dev/null +++ b/base/ncdu/ncdu.SMBuild @@ -0,0 +1,32 @@ +APP=ncdu +VERSION=1.15 +BUILD=1sml +HOMEPAGE='https://dev.yorhel.nl/ncdu' +DOWNLOAD='https://dev.yorhel.nl/download/ncdu-1.15.tar.gz' +DESC="disk usage viewer using netbsd-curses library" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +cc41d59cdb8166e9d8e1fe658b1a044aa99ec055ff518ccb71a7c50c2034c9fcdae550a1c9196841239f7d7e70278eaf3b4a1a28cb4d342f9564c95bf14bdd3d ncdu-1.15.tar.lz +" diff --git a/base/neon/neon.SMBuild b/base/neon/neon.SMBuild new file mode 100755 index 0000000..d71ab81 --- /dev/null +++ b/base/neon/neon.SMBuild @@ -0,0 +1,34 @@ +APP=neon +VERSION=0.31.1 +BUILD=1sml +HOMEPAGE='https://notroj.github.io/neon/' +DOWNLOAD='https://notroj.github.io/neon/neon-0.31.1.tar.gz' +DESC="HTTP and WebDav client library with a C interface" +REQUIRES="expat zlib openssl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-static=no \ + --enable-shared=yes \ + --with-ssl=openssl + + make + make install DESTDIR=$PKG + + cp README.md $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +87c702a84a63a2c35f1b9ea38ba6f5453d4fbd51c17b17a8dca4bbbac2834c92e5e3b4f187d725e42bcdf6390b7c31cd7297b57b53fb1426ddd86190656b1496 neon-0.31.1.tar.lz +" diff --git a/base/netbsd-curses/netbsd-curses.SMBuild b/base/netbsd-curses/netbsd-curses.SMBuild new file mode 100755 index 0000000..8157935 --- /dev/null +++ b/base/netbsd-curses/netbsd-curses.SMBuild @@ -0,0 +1,36 @@ +APP=netbsd-curses +VERSION=0.3.1 +BUILD=1sml +HOMEPAGE='http://ftp.barfooze.de/pub/sabotage/tarballs/' +DOWNLOAD='' +DESC="drop-in replacement for the bloated ncurses library with wide character support" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + cat << EOF > config.mak +CC=gcc +HOSTCC=gcc +AR=ar +RANLIB=ranlib +PREFIX="" +DESTDIR=$PKG +EOF + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +60b6e5644e1d9b0b872f83411e731fae626e09749f783eb60633cb6712275db6087dd25b0375b667adb53031a67804da6f9dcd83ba7e165adc6ab39dd2b2f023 netbsd-curses-0.3.1.tar.lz +" diff --git a/base/nettle/nettle.SMBuild b/base/nettle/nettle.SMBuild new file mode 100755 index 0000000..49db647 --- /dev/null +++ b/base/nettle/nettle.SMBuild @@ -0,0 +1,33 @@ +APP=nettle +VERSION=3.7.2 +BUILD=1sml +HOMEPAGE='http://www.lysator.liu.se/~nisse/nettle/' +DOWNLOAD="https://ftp.gnu.org/gnu/nettle/nettle-3.4.tar.gz" +DESC="small cryptographic library designed to fit easily in any programming language" +REQUIRES="gmp" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + sed -i 's@#.*$@@g' "$PKG"/lib/pkgconfig/hogweed.pc + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +692f052eb492bcf07690157d1496ea9b87b9e42f01d68b30f5be60f51596db37ce4adc0ea9e636889aba0e84b0357b02d888a77228a80f2d81a6f99c1021236f nettle-3.7.2.tar.lz +" diff --git a/base/nghttp2/nghttp2.SMBuild b/base/nghttp2/nghttp2.SMBuild new file mode 100755 index 0000000..c89b0e9 --- /dev/null +++ b/base/nghttp2/nghttp2.SMBuild @@ -0,0 +1,36 @@ +APP=nghttp2 +VERSION=1.41.0 +BUILD=1sml +HOMEPAGE='https://nghttp2.org/' +DOWNLOAD='https://github.com/nghttp2/nghttp2/releases/download/v1.41.0/nghttp2-1.41.0.tar.xz' +DESC="framing layer of HTTP/2 web protocol implemented as a form of a reusable C library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-examples \ + --disable-python-bindings \ + --enable-lib-only \ + --disable-static + + make + cd lib + make install DESTDIR=$PKG + + cd .. + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +000c8033b882e0e071fdfdadbd808fba8556e83efafe397e5f28dcd3fe2c32fa33eceab502a907d7023084f06ae141dfd85ecee9fdc55037fb1b242df94e976a nghttp2-1.41.0.tar.lz +" diff --git a/base/ninja/ninja.SMBuild b/base/ninja/ninja.SMBuild new file mode 100755 index 0000000..8343bda --- /dev/null +++ b/base/ninja/ninja.SMBuild @@ -0,0 +1,32 @@ +APP=ninja +VERSION=1.9.0 +BUILD=1sml +HOMEPAGE='https://github.com/ninja-build/ninja' +DOWNLOAD='https://github.com/ninja-build/ninja/archive/refs/tags/v1.9.0.tar.gz' +DESC="small build system with a focus on speed" +REQUIRES="gcc-libs python3" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/posix-fix.patch + + python ./configure.py --bootstrap + + install -Dm 755 ninja $PKG/bin/ninja + install -Dm 644 misc/bash-completion $PKG/share/bash-completion/completions/ninja + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0c8e877efc4cf7fd474f90fc31454f8bb1dcf483b0f1a6132678eeaa413a9e1c5c53b37705aada999efacc83a31afb75df0b509d87a41c4fe736c2ac6ed87251 ninja-1.9.0.tar.lz +78b29a57ec3c4feedf2bcfe9370b30cecd5302f29e8e14c6a3bc01becb555be6330aafba12f9225625af0644ea1f534feba8396d32bb944253a9daa5dd0e98d8 posix-fix.patch +" diff --git a/base/ninja/posix-fix.patch b/base/ninja/posix-fix.patch new file mode 100644 index 0000000..f6aeb42 --- /dev/null +++ b/base/ninja/posix-fix.patch @@ -0,0 +1,39 @@ +From 567815df38a2ff54ad7478a90bd75c91e434236a Mon Sep 17 00:00:00 2001 +From: makepost +Date: Mon, 24 Dec 2018 03:13:16 +0200 +Subject: [PATCH] Use st_mtim if st_mtime is macro, fix #1510 + +In POSIX.1-2008, sys_stat has a st_mtim member and a st_mtime backward +compatibility macro. Should help avoid hardcoding platform detection. +--- + src/disk_interface.cc | 14 ++++---------- + 1 file changed, 4 insertions(+), 10 deletions(-) + +diff --git a/src/disk_interface.cc b/src/disk_interface.cc +index d4c2fb087..dc297c449 100644 +--- a/src/disk_interface.cc ++++ b/src/disk_interface.cc +@@ -202,19 +202,13 @@ TimeStamp RealDiskInterface::Stat(const string& path, string* err) const { + // that it doesn't exist. + if (st.st_mtime == 0) + return 1; +-#if defined(__APPLE__) && !defined(_POSIX_C_SOURCE) ++#if defined(_AIX) ++ return (int64_t)st.st_mtime * 1000000000LL + st.st_mtime_n; ++#elif defined(__APPLE__) + return ((int64_t)st.st_mtimespec.tv_sec * 1000000000LL + + st.st_mtimespec.tv_nsec); +-#elif (_POSIX_C_SOURCE >= 200809L || _XOPEN_SOURCE >= 700 || defined(_BSD_SOURCE) || defined(_SVID_SOURCE) || \ +- defined(__BIONIC__) || (defined (__SVR4) && defined (__sun)) || defined(__FreeBSD__)) +- // For glibc, see "Timestamp files" in the Notes of http://www.kernel.org/doc/man-pages/online/pages/man2/stat.2.html +- // newlib, uClibc and musl follow the kernel (or Cygwin) headers and define the right macro values above. +- // For bsd, see https://github.com/freebsd/freebsd/blob/master/sys/sys/stat.h and similar +- // For bionic, C and POSIX API is always enabled. +- // For solaris, see https://docs.oracle.com/cd/E88353_01/html/E37841/stat-2.html. ++#elif defined(st_mtime) // A macro, so we're likely on modern POSIX. + return (int64_t)st.st_mtim.tv_sec * 1000000000LL + st.st_mtim.tv_nsec; +-#elif defined(_AIX) +- return (int64_t)st.st_mtime * 1000000000LL + st.st_mtime_n; + #else + return (int64_t)st.st_mtime * 1000000000LL + st.st_mtimensec; + #endif diff --git a/base/nodejs/nodejs.SMBuild b/base/nodejs/nodejs.SMBuild new file mode 100755 index 0000000..5a74906 --- /dev/null +++ b/base/nodejs/nodejs.SMBuild @@ -0,0 +1,30 @@ +APP=nodejs +VERSION=16.4.2 +BUILD=1sml +HOMEPAGE='https://nodejs.org/en/' +DESC="Asynchronous Chrome-based, event-driven Javascript engine designed to build scalable network applications" +REQUIRES="openssl" + +build() { + mkandenterbuilddir + rm -rf node-$VERSION + + tar xf $SRCDIR/nodejs-$VERSION.tar.?z* + cd node-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="/" \ + --shared-zlib + + make + make install DESTDIR=$PKG + + install -Dm 644 LICENSE $PKGDOCS/LICENSE + + mkfinalpkg +} + +SHA512SUMS=" +f20e92d1f163defa9fb4b7d5e3f4a73e1e993e9602d30b43564501a9fc96fadc8647775c42af3eb57e06600d7e5081af0fb525b76786724c71796befc64feb4a nodejs-16.4.2.tar.gz +" diff --git a/base/npth/npth.SMBuild b/base/npth/npth.SMBuild new file mode 100755 index 0000000..c3b8870 --- /dev/null +++ b/base/npth/npth.SMBuild @@ -0,0 +1,30 @@ +APP=npth +VERSION=1.6 +BUILD=1sml +HOMEPAGE='https://gnupg.org/software/npth/index.html' +DOWNLOAD='https://gnupg.org/ftp/gcrypt/npth/npth-1.6.tar.bz2' +DESC="library that provides non-premptive priority-based scheduling for multiple threads in event-driven applications" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2ed1012e14a9d10665420b9a23628be7e206fd9348111ec751349b93557ee69f1176bcf7e6b195b35b1c44a5e0e81ee33b713f03d79a33d1ecd9037035afeda2 npth-1.6.tar.bz2 +" diff --git a/base/ntfs-3g/ntfs-3g.SMBuild b/base/ntfs-3g/ntfs-3g.SMBuild new file mode 100755 index 0000000..ee9cd63 --- /dev/null +++ b/base/ntfs-3g/ntfs-3g.SMBuild @@ -0,0 +1,35 @@ +APP=ntfs-3g +VERSION=2017.3.23 +BUILD=1sml +HOMEPAGE='http://www.tuxera.com/community/open-source-ntfs-3g/' +DOWNLOAD='https://tuxera.com/opensource/ntfs-3g_ntfsprogs-2017.3.23.tgz' +DESC="NTFS read-write filesystem driver" +REQUIRES="netbsd-curses util-linux fuse" +SM_NOAUTOCONFSITE=1 + +build() { + mkandenterbuilddir + rm -rf $APP"_ntfsprogs"-$VERSION + + tar xf $SRCDIR/$APP"_ntfsprogs"-$VERSION.tgz + cd $APP"_ntfsprogs"-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir="/bin" \ + --sbindir="/bin" \ + --disable-static \ + --with-fuse=internal + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3a607f0d7be35204c992d8931de0404fbc52032c13b4240d2c5e6f285c318a28eb2a385d7cf5ac4cd445876aee5baa5753bb636ada0d870d84a9d3fdbce794ef ntfs-3g_ntfsprogs-2017.3.23.tgz +" diff --git a/base/oniguruma/oniguruma.SMBuild b/base/oniguruma/oniguruma.SMBuild new file mode 100755 index 0000000..4c75d5e --- /dev/null +++ b/base/oniguruma/oniguruma.SMBuild @@ -0,0 +1,32 @@ +APP=oniguruma +VERSION=6.9.5 +BUILD=1sml +HOMEPAGE='https://github.com/kkos/oniguruma' +DOWNLOAD='https://github.com/kkos/oniguruma/archive/refs/tags/v6.9.5.tar.gz' +DESC="Regular expressions library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --enable-posix-api \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d901fdbb1ecf4af2a659d246678242e415298b04d85d1e662f592b4ee85b3157edeb33cd2f20db6841afba37b7503f9b943431ab915df51a17ca726ee4e07601 oniguruma-6.9.5.tar.lz +" diff --git a/base/openssl/openssl.SMBuild b/base/openssl/openssl.SMBuild new file mode 100755 index 0000000..f925af7 --- /dev/null +++ b/base/openssl/openssl.SMBuild @@ -0,0 +1,41 @@ +APP=openssl +VERSION=1.1.1k +BUILD=1sml +HOMEPAGE='https://www.openssl.org/' +DOWNLOAD='https://www.openssl.org/source/openssl-1.1.1k.tar.gz' +DESC="commercial-grade, robust, fully featured crypto library from OpenSSL Project that implements TLS and SSLv3" +REQUIRES="perl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + if [ "$ARCH" = "aarch64" ]; then + cpuflag="linux-aarch64" + elif [ "$ARCH" = "x86_64" ]; then + cpuflag="linux-x86_64" + fi + + ./Configure "$cpuflag" \ + --prefix="/" \ + --openssldir=/etc/ssl \ + shared enable-md2 no-weak-ssl-ciphers + + make + make install DESTDIR=$PKG + + rm -rf $PKG/share/doc + + cp LICENSE $PKGDOCS/ + + + mkfinalpkg +} + +SHA512SUMS=" +73cd042d4056585e5a9dd7ab68e7c7310a3a4c783eafa07ab0b560e7462b924e4376436a6d38a155c687f6942a881cfc0c1b9394afcde1d8c46bf396e7d51121 openssl-1.1.1k.tar.gz +" diff --git a/base/opus/opus.SMBuild b/base/opus/opus.SMBuild new file mode 100755 index 0000000..3900ed4 --- /dev/null +++ b/base/opus/opus.SMBuild @@ -0,0 +1,32 @@ +APP=opus +VERSION=1.3.1 +BUILD=1sml +HOMEPAGE='https://opus-codec.org/' +DOWNLOAD='https://archive.mozilla.org/pub/opus/opus-1.3.1.tar.gz' +DESC="Open, royalty-free audio codec standardised by IETF" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --disable-doc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +5cce20210130b6ade405f4d6489b383c151f130af79ba0fffa8e0d71df1ad158373f734f0746bcbe94a23e5e873d71bf5b03019183c2c9cbb218bfb0c81d7b3f opus-1.3.1.tar.lz +" diff --git a/base/opusfile/opusfile.SMBuild b/base/opusfile/opusfile.SMBuild new file mode 100755 index 0000000..a67760a --- /dev/null +++ b/base/opusfile/opusfile.SMBuild @@ -0,0 +1,31 @@ +APP=opusfile +VERSION=0.11 +BUILD=1sml +HOMEPAGE='https://opus-codec.org/' +DOWNLOAD='https://downloads.xiph.org/releases/opus/opusfile-0.12.tar.gz' +DESC="dependency for the opus audio library" +REQUIRES="openssl libogg opus" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +94ebf4d4c19cb3602093d1c37ae2dffd60fb4a29c2b2a21d9bb964567fa71b7f31d027cb705a09875f134dd67b8356b9217ee06ecaf851bd313197be20013922 opusfile-0.11.tar.lz +" diff --git a/base/p11-kit/p11-kit.SMBuild b/base/p11-kit/p11-kit.SMBuild new file mode 100755 index 0000000..b8f13b9 --- /dev/null +++ b/base/p11-kit/p11-kit.SMBuild @@ -0,0 +1,33 @@ +APP=p11-kit +VERSION=0.23.20 +BUILD=1sml +HOMEPAGE='https://github.com/p11-glue/p11-kit' +DOWNLOAD='https://github.com/p11-glue/p11-kit/archive/refs/tags/0.23.20.tar.gz' +DESC="tools to load and enumerate PKCS#11 modules" +REQUIRES="gcc-libs libffi libtasn1" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="-D_GNU_SOURCE" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c15954e339c1193cad3f27acb496edfcc397dc671d7213daf9402bc8b5471271520931f54aacd2f4516f6777c1bef055ee721e3c4287c39d67826083b8e5f8aa p11-kit-0.23.20.tar.lz +" diff --git a/base/p7zip/p7zip.SMBuild b/base/p7zip/p7zip.SMBuild new file mode 100755 index 0000000..d81437a --- /dev/null +++ b/base/p7zip/p7zip.SMBuild @@ -0,0 +1,32 @@ +APP=p7zip +VERSION=16.02 +BUILD=1sml +HOMEPAGE='https://sourceforge.net/projects/p7zip/' +DOWNLOAD='' +DESC="file archiver and a port of the 7z windows archive utility" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i 's/-pipe -s//' makefile.machine + sed -i -e 's/strip /#strip /' \ + -e 's/chmod 555/chmod 755/' \ + -e 's/chmod 444/chmod 644/' install.sh && make all3 || true + + make install DEST_HOME="" DEST_DIR="$PKG" \ + DEST_MAN="/share/man" || true + + cp DOC/License.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +72beac97a0d298d5416a25db6863d7f5033408e979555d1dae61a847e0d9062a4b5eca7e31f47bfeb26eda95b567fea081a13e1a20098a6e57a6de0ab39715ee p7zip-16.02.tar.lz +" diff --git a/base/parted/parted-3.2-xfs.patch b/base/parted/parted-3.2-xfs.patch new file mode 100644 index 0000000..3bd13fb --- /dev/null +++ b/base/parted/parted-3.2-xfs.patch @@ -0,0 +1,13 @@ +diff -r -c parted-3.2/libparted/fs/xfs/platform_defs.h parted-3.2-fixed/libparted/fs/xfs/platform_defs.h +*** parted-3.2/libparted/fs/xfs/platform_defs.h Sun Jun 15 18:17:43 2014 +--- parted-3.2-fixed/libparted/fs/xfs/platform_defs.h Sat Oct 11 15:33:49 2014 +*************** +*** 44,49 **** +--- 44,50 ---- + #include + #include + #include ++ #include + + #if (__GLIBC__ <= 2) && (__GLIBC_MINOR__ <= 1) + # define constpp const char * const * diff --git a/base/parted/parted.SMBuild b/base/parted/parted.SMBuild new file mode 100755 index 0000000..25da57e --- /dev/null +++ b/base/parted/parted.SMBuild @@ -0,0 +1,40 @@ +APP=parted +VERSION=3.2 +BUILD=1sml +SM_NOAUTOCONFSITE=1 +HOMEPAGE='https://www.gnu.org/software/parted/' +DOWNLOAD='https://ftp.gnu.org/gnu/parted/parted-3.2.tar.xz' +DESC="GNU disk partitioning tool" +REQUIRES="eudev util-linux lvm" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/parted-3.2-xfs.patch + + CFLAGS="-D_GNU_SOURCE -Dloff_t=off_t $CFLAGS -include sys/sysmacros.h" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin \ + --enable-threads=posix \ + --disable-nls \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b7e882e2641d301b9e85b392dd65d145f53f9ddc7722d5712d34897592e1e9add088902a00121a8c8c9706750304690d1f096e36ffa6ca8fba68ff04e8e5e2fb parted-3.2.tar.lz +2aaf39c84dd630df1fb281cf3d13dc9b14a7d720c4e3a2c6c1052cc84a1bd4fbbd38d9ec521afb3c6dc514b63c19483b5ff3bef4bf3e778fcbdb843c7c5a6906 parted-3.2-xfs.patch +" diff --git a/base/patch/patch.SMBuild b/base/patch/patch.SMBuild new file mode 100755 index 0000000..c712bee --- /dev/null +++ b/base/patch/patch.SMBuild @@ -0,0 +1,32 @@ +APP=patch +VERSION=2.7.5 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/patch/' +DOWNLOAD='https://ftp.gnu.org/gnu/patch/patch-2.7.5.tar.xz' +DESC="Utility to apply a diff or patches file to an original file or files" +REQUIRES="attr" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + LDFLAGS="-static" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8fb24cf406a8a97343c2ea438544db865c48356b31965479a95014bafcee38e57c2c5112336562dd220fc753b3d98e2052c4bbb3b08af5b12764f65acc3ffd00 patch-2.7.5.tar.lz +" diff --git a/base/pciutils/pciutils-pread.patch b/base/pciutils/pciutils-pread.patch new file mode 100644 index 0000000..307c95f --- /dev/null +++ b/base/pciutils/pciutils-pread.patch @@ -0,0 +1,12 @@ +--- pciutils-3.2.1/lib/pread.h 2006-05-05 12:18:24.000000000 +0000 ++++ pciutils-3.2.1/lib/pread.h 2014-01-01 16:09:44.653087473 +0000 +@@ -12,7 +12,7 @@ + * don't define it. + */ + +-#if defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ > 0 ++#if defined(HAVE_PREAD) || (defined(__GLIBC__) && __GLIBC__ == 2 && __GLIBC_MINOR__ > 0) + /* glibc 2.1 or newer -> pread/pwrite supported automatically */ + + #elif defined(i386) && defined(__GLIBC__) + diff --git a/base/pciutils/pciutils.SMBuild b/base/pciutils/pciutils.SMBuild new file mode 100755 index 0000000..724ba6a --- /dev/null +++ b/base/pciutils/pciutils.SMBuild @@ -0,0 +1,47 @@ +APP=pciutils +VERSION=3.5.6 +BUILD=1sml +HOMEPAGE='https://mj.ucw.cz/sw/pciutils/' +DOWNLOAD='https://mj.ucw.cz/download/linux/pci/pciutils-3.5.6.tar.gz' +DESC="PCI bus library and tools" +REQUIRES="musl" + +build() { + compileonlyfor x86_64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/pciutils-pread.patch + + make CFLAGS="$CFLAGS -D_GNU_SOURCE -DHAVE_PREAD -fPIC" \ + LDFLAGS="-llzma" \ + PREFIX="/" \ + SHARED=yes \ + SBINDIR="/bin" \ + DESTDIR="$PKG" \ + STRIP="" all install + + make CFLAGS="-D_GNU_SOURCE -DHAVE_PREAD -fPIC" \ + LDFLAGS="-llzma" \ + PREFIX="/" \ + SHARED=yes \ + SBINDIR="/bin" \ + DESTDIR="$PKG" \ + STRIP="" install-lib + + sed -i '/^Libs:/d' $PKG/lib/pkgconfig/libpci.pc + sed -i 's/^Libs.private:/Libs: -lpci /' $PKG/lib/pkgconfig/libpci.pc + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f8afe23b804e32fbc0c66f68e7525a16a23cbad3579aa0d7670eceeed1809ae3aed6f6efeadc68e9430e7f291150401596de24961a4767a5b071b37331b28ed8 pciutils-3.5.6.tar.lz +5e9c64a65f350c569fd6ab0d1d49adcd70519dc2c7c88ccdec33f22fd59f71e16c10103424897182db0e16fa6ebf2e21786cb49dede06cf71d49f5498c72e55a pciutils-pread.patch +" diff --git a/base/pcre/pcre.SMBuild b/base/pcre/pcre.SMBuild new file mode 100755 index 0000000..ff329ac --- /dev/null +++ b/base/pcre/pcre.SMBuild @@ -0,0 +1,37 @@ +APP=pcre +VERSION=8.44 +BUILD=1sml +HOMEPAGE='https://www.pcre.org/' +DOWNLOAD='https://ftp.pcre.org/pub/pcre/pcre-8.44.tar.gz' +DESC="Perl-compatible regular expression library" +REQUIRES="zlib bzip2" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --enable-pcre16 \ + --enable-pcre32 \ + --enable-pcregrep-libbz2 \ + --enable-pcretest-libreadline \ + --enable-unicode-properties \ + --enable-pcregrep-libz + + make + make install DESTDIR=$PKG + + cp LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f26d850aab5228799e58ac8c2306fb313889332c39e29b118ef1de57677c5c90f970d68d3f475cabc64f8b982a77f04eca990ff1057f3ccf5e19bd137997c4ac pcre-8.44.tar.bz2 +" diff --git a/base/pcre2/pcre2.SMBuild b/base/pcre2/pcre2.SMBuild new file mode 100755 index 0000000..82b591e --- /dev/null +++ b/base/pcre2/pcre2.SMBuild @@ -0,0 +1,39 @@ +APP=pcre2 +VERSION=10.33 +BUILD=1sml +HOMEPAGE='https://www.pcre.org/' +DOWNLOAD='https://ftp.pcre.org/pub/pcre/pcre2-10.33.tar.gz' +DESC="Perl-compatible regular expression library v2" +REQUIRES="gcc-libs zlib bzip2 readline" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-pcre2-16 \ + --enable-pcre2-32 \ + --enable-jit \ + --enable-pcre2grep-libz \ + --enable-pcre2grep-libbz2 \ + --enable-pcre2test-libreadline \ + --with-match-limit-recursion=8192 \ + --disable-static + + make + make install DESTDIR=$PKG + + cp LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b94e6df0a779c58fce66854b5d64eed1232cc0027362e369a2465b893d9f59c9f01126db6336a5a77714148bf70d4b11c28fd866ee26d061f3f36426495e43bf pcre2-10.33.tar.lz +" diff --git a/base/perl-modules/perl-modules.SMBuild b/base/perl-modules/perl-modules.SMBuild new file mode 100755 index 0000000..004937c --- /dev/null +++ b/base/perl-modules/perl-modules.SMBuild @@ -0,0 +1,82 @@ +APP=perl-modules +VERSION=5.24.3 +BUILD=2sml +HOMEPAGE='https://www.perl.org/' +DESC="Collection of support addons for default perl installation" +REQUIRES="perl" + +# modules and their versions +URIVER=1.71 +GETTEXTVER=1.07 +DBIVER=1.636 +HTMLPARSERVER=3.72 +XMLPARSERVER=2.44 +XMLSIMPLEVER=2.22 +PARSEYAPP=1.21 + +build() { + mkandenterbuilddir + rm -rf DBI* HTML-Parser* Locale* URI* XML* + + prepperlpackage() { + fixbuilddirpermissions + perl Makefile.PL INSTALLDIRS=vendor + make + make install DESTDIR=$PKG + cd .. + } + + # URI module + tar xf $SRCDIR/URI-"$URIVER".tar.?z* + cd URI-"$URIVER" + cp LICENSE $PKGDOCS/LICENSE.URI + head -n 1000 Changes > $PKGDOCS/CHANGES.URI + prepperlpackage + + # gettext module + tar xf $SRCDIR/gettext-"$GETTEXTVER".tar.?z* + cd Locale-gettext-"$GETTEXTVER" + prepperlpackage + + # DBI module + tar xf $SRCDIR/DBI-"$DBIVER".tar.?z* + cd DBI-"$DBIVER" + cp LICENSE $PKGDOCS/LICENSE.DBI + prepperlpackage + + # HTML-Parser module + tar xf $SRCDIR/HTML-Parser-"$HTMLPARSERVER".tar.?z* + cd HTML-Parser-"$HTMLPARSERVER" + cp README $PKGDOCS/README.HTML-PARSER + prepperlpackage + + # XML-Parser module + tar xf $SRCDIR/XML-Parser-"$XMLPARSERVER".tar.?z* + cd XML-Parser-"$XMLPARSERVER" + cp README $PKGDOCS/README.XML-PARSER + prepperlpackage + + # Parse-Yapp module + tar xf $SRCDIR/Parse-Yapp-"$PARSEYAPP".tar.?z* + cd Parse-Yapp-"$PARSEYAPP" + cp README $PKGDOCS/README.PARSE-YAPP + prepperlpackage + + # finally, XML-Simple module + tar xf $SRCDIR/XML-Simple-"$XMLSIMPLEVER".tar.?z* + cd XML-Simple-"$XMLSIMPLEVER" + cp LICENSE $PKGDOCS/LICENSE.XML-SIMPLE + prepperlpackage + + mkfinalpkg +} + +SHA512SUMS=" +8d541ada1fabb7e82dd4f47c43edf79cc70c783ef3582a9911b13239734876aee9f27095f2526e6923d07b7ac86df48ee081af1ca6000df0559a13c75b6f6ed3 DBI-1.636.tar.gz +9fded69219791af085018ffbe6737e74e370c543af52aa221aec174daf52d1b8d3cdd07f025176c0212ae572a924555262f2eefc73781f82cdb7d9cff58ae716 HTML-Parser-3.72.tar.gz +dbf6182d4813ff7e355ea1713c748bfdf8290040a93f123acec645c7a1733fe457ab6e0ab51c4ec83cf82bc43d7fb35cbf89875df7b5c2ffc9635e85458cfeee Parse-Yapp-1.21.tar.gz +db412b75054a4d315eb861060fa4641832c2428b9dfe56bbe35f530c9ba572d4de2061d9782454750293dd5a64f3375830988d8512f410e84a9d599c80458405 URI-1.71.tar.gz +4790d20d89478880b18255679727e5b2fb2860bb4de67d5032c805fd44c9f90697a240a612aba51255325192253aa578b346d658b29f631a4e92ad96e7d65b61 XML-Parser-2.44.tar.gz +b5e5d36726b8a0efcf7200522d802a7f733c883526db2dba64ce23bf7e044d20d9186fac3bb2f2940807a30f746301f690129c4c542341c8a57a735471b5f4d7 XML-Simple-2.22.tar.gz +d3716a597d586ee2ff29472ca7b13aaf67770299de31e5f12abafebc879bbe4a1e1dbc0025cf4f3dc29992955f26cffc3be387d974c3911af095d5b49e67a1c6 gettext-1.07.tar.gz +" diff --git a/base/perl/perl.SMBuild b/base/perl/perl.SMBuild new file mode 100755 index 0000000..e3d1df0 --- /dev/null +++ b/base/perl/perl.SMBuild @@ -0,0 +1,57 @@ +APP=perl +VERSION=5.24.3 +BUILD=1sml +HOMEPAGE='https://www.perl.org/' +DOWNLOAD='https://www.cpan.org/src/5.0/perl-5.24.3.tar.xz' +REQUIRES="db" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed '1i#define PERL_BUILD_DATE "01.01.18 00:00:00"' -i perl.c + + sed -e 's;myuname=`$u;myuname="linux host" #`$u;' \ + -e 's;cf_time=`;cf_time="01.01.18 00:00:00" #`;' \ + -e 's;cf_by=`;cf_by=user #`;' \ + -e "s;^myhostname='';myhostname=host;" \ + -e "s;^phostname='';phostname=host;" \ + -i Configure + + sed -i 's,-fstack-protector,-fnostack-protector,g' ./Configure + + ./Configure -des \ + -Accflags='$CFLAGS -D_BSD_SOURCE' \ + -Dprefix="/" \ + -Dvendorprefix="/" \ + -Dsitelib="/lib/perl5/site_perl" \ + -Dsitearch="/lib/perl5/site_perl" \ + -Darchlib="/lib/perl5/core_perl" \ + -Dprivlib="/lib/perl5/core_perl" \ + -Dvendorlib="/lib/perl5/vendor_perl" \ + -Dvendorarch="/lib/perl5/vendor_perl" \ + -Dscriptdir='/bin' \ + -Dbin='/bin' \ + -Duseshrplib \ + -Dusethreads \ + -Ubincompat5005 \ + -Uversiononly \ + -Dcc="$CC" + + make + make install DESTDIR=$PKG + + rm -f $PKG/*.0 + + cp Artistic $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +330bbcd4bc8fc25dd84f9170f8b56450fa3ab4cdd6f39ab85fbfc4b9b8b47c130f312839189f45e6e2d7ca557524a3ee2cbd06f4aeb3ac96b4dd4f70b466cec6 perl-5.24.3.tar.lz +" diff --git a/base/physfs/physfs.SMBuild b/base/physfs/physfs.SMBuild new file mode 100755 index 0000000..200aaa1 --- /dev/null +++ b/base/physfs/physfs.SMBuild @@ -0,0 +1,35 @@ +APP=physfs +VERSION=3.0.2 +BUILD=1sml +HOMEPAGE='http://icculus.org/physfs/' +DOWNLOAD='https://icculus.org/physfs/downloads/physfs-3.0.2.tar.bz2' +DESC="library to provide abstract access to various archives" +REQUIRES="zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DPHYSFS_BUILD_SHARED=ON \ + -DPHYSFS_BUILD_STATIC=OFF \ + -DPHYSFS_BUILD_TEST=OFF \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX="" + + make + make install DESTDIR=$PKG + + cp ../LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2d407f3145dde9b8be86a88e1a22286c8663cc929a22155b9e4d4db9127addb4d0b963878e4d695861bf04cef872ef1decbbfb619c3546c486da3af2e908e0ff physfs-3.0.2.tar.lz +" diff --git a/base/pigz/pigz.SMBuild b/base/pigz/pigz.SMBuild new file mode 100755 index 0000000..786ba87 --- /dev/null +++ b/base/pigz/pigz.SMBuild @@ -0,0 +1,30 @@ +APP=pigz +VERSION=2.4 +BUILD=1sml +HOMEPAGE='https://www.zlib.net/pigz/' +DESC="multi-threaded gzip alternative to minimise compression time" +REQUIRES="zlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + mkdir -p $PKG/bin $PKG/share/man/man1 + cp pigz unpigz $PKG/bin/ + cp pigz.1 $PKG/share/man/man1/ + + cp README $PKGDOCS/ + cp zopfli/COPYING $PKGDOCS/COPYING.zopfli + cp zopfli/README $PKGDOCS/README.zopfli + + mkfinalpkg +} + +SHA512SUMS=" +c9e3b42ba332959ee212085d1544923e4e46a0ea7cc0064e115f2a78ce8f4555d209926ba64404ca1255ab7b1be073a5446d53b54574ecb85a57b58ff994979b pigz-2.4.tar.lz +" diff --git a/base/pinfo/pinfo.SMBuild b/base/pinfo/pinfo.SMBuild new file mode 100755 index 0000000..23b34af --- /dev/null +++ b/base/pinfo/pinfo.SMBuild @@ -0,0 +1,33 @@ +APP=pinfo +VERSION=0.6.8 +BUILD=1sml +HOMEPAGE='http://pinfo.sourceforge.net/' +DOWNLOAD='http://pinfo.sourceforge.net/pinfo-0.6.8.tar.gz' +DESC="ncurses-based lynx-styled info and document viewer" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --mandir=/share/man \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4a0c41e8724a24323e2b069dabdfc757f4f041f67b2a15c41d75e26dbfe150dfac622bc0b764b542122d0c5979fdc452abf2056e89414f1d074900aeb41a1f82 pinfo-0.6.8.tar.lz +" diff --git a/base/pkgconf/pkgconf.SMBuild b/base/pkgconf/pkgconf.SMBuild new file mode 100755 index 0000000..e3e0ab3 --- /dev/null +++ b/base/pkgconf/pkgconf.SMBuild @@ -0,0 +1,33 @@ +APP=pkgconf +VERSION=1.7.3 +BUILD=1sml +HOMEPAGE='https://git.sr.ht/~kaniini/pkgconf' +DOWNLOAD='https://distfiles.dereferenced.org/pkgconf/pkgconf-1.7.3.tar.xz' +DESC="drop-in replacement for the bloated pkg-config utility" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --with-pkg-config-dir=/usr/lib/pkgconfig:/usr/share/pkgconfig:/lib/pkgconfig + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + ( cd $PKG/bin ; ln -sf pkgconf pkg-config ) + + mkfinalpkg +} + +SHA512SUMS=" +37b6c4f9f3b93970e35b6970fde22fbbde65e7fa32a5634b3fdfc25cc1f33843582722ad13d9a8e96fd6768406fcbe86bf5feb76996ddd0bb66d6ff91e65f0b6 pkgconf-1.7.3.tar.xz +" diff --git a/base/plzip/plzip.SMBuild b/base/plzip/plzip.SMBuild new file mode 100755 index 0000000..2d5bcb5 --- /dev/null +++ b/base/plzip/plzip.SMBuild @@ -0,0 +1,30 @@ +APP=plzip +VERSION=1.8 +BUILD=1sml +HOMEPAGE='http://www.nongnu.org/lzip/plzip.html' +DOWNLOAD='http://download.savannah.gnu.org/releases/lzip/plzip/plzip-1.8.tar.lz' +DESC="parallel lzip compressor" +REQUIRES="gcc-libs lzlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bbc4c2c94b49c9efed0c93b3c766fedd82195014b7d7aa813420bec6a52d064de8f0ef4ba912ab5fc9d4fddc204001ba8eddd9c5191b50e7f50b6600af47ea75 plzip-1.8.tar.lz +" diff --git a/base/pm-utils/pm-utils.SMBuild b/base/pm-utils/pm-utils.SMBuild new file mode 100755 index 0000000..d52a384 --- /dev/null +++ b/base/pm-utils/pm-utils.SMBuild @@ -0,0 +1,32 @@ +APP=pm-utils +VERSION=1.4.1 +BUILD=1sml +HOMEPAGE='http://pm-utils.freedesktop.org/' +DOWNLOAD='https://pm-utils.freedesktop.org/releases/pm-utils-1.4.1.tar.gz' +DESC="Power management utilities" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ab69a4caca21e1fa0f571874d583eb18f7d83116bcd033b5b5c8f74b8948bccde0e169710ce6af345ac466ec6f1907ac64a5d223544cb70a71decb010c708531 pm-utils-1.4.1.tar.lz +" diff --git a/base/popt/popt.SMBuild b/base/popt/popt.SMBuild new file mode 100755 index 0000000..f4e5a5e --- /dev/null +++ b/base/popt/popt.SMBuild @@ -0,0 +1,32 @@ +APP=popt +VERSION=1.16 +BUILD=1sml +HOMEPAGE='https://github.com/rpm-software-management/popt' +DOWNLOAD='http://rpm5.org/files/popt/popt-1.16.tar.gz' +DESC="command line parsing library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b9b5ec15e2040a0d5c1d5c5dc69be245be55a9884bfd656fc097e9a30772cefdcd3d7c5fe2bf01010de8907c0b6ce235c65591dafc0bbf41d3da4bccd183c40c popt-1.16.tar.lz +" diff --git a/base/portaudio/portaudio.SMBuild b/base/portaudio/portaudio.SMBuild new file mode 100755 index 0000000..95767be --- /dev/null +++ b/base/portaudio/portaudio.SMBuild @@ -0,0 +1,32 @@ +APP=portaudio +VERSION=19.6.0 +BUILD=1sml +HOMEPAGE='https://github.com/portaudio/portaudio/' +DESC="cross-platform audio I/O library" +REQUIRES="gcc-libs alsa-lib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-cxx \ + --disable-static + + make -j1 + make install DESTDIR=$PKG + + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8fafbd9ba84e60408d8861c55438641ef85e7cafd92010e79e5cdfdaa43bedcc10cebd8214872193ca942914b13d8d556abfc2e88ddcd898a1f744896d64fc1a portaudio-19.6.0.tar.lz +" diff --git a/base/procps-ng/procps-ng-netbsd-curses.patch b/base/procps-ng/procps-ng-netbsd-curses.patch new file mode 100644 index 0000000..30d73bd --- /dev/null +++ b/base/procps-ng/procps-ng-netbsd-curses.patch @@ -0,0 +1,31 @@ +--- procps-ng-3.3.12.org/top/top.c ++++ procps-ng-3.3.12/top/top.c +@@ -61,6 +61,7 @@ + #include "top.h" + #include "top_nls.h" + ++#define TPARM2(a, b) tparm(a, b, 0, 0, 0, 0, 0, 0, 0, 0) + + /*###### Miscellaneous global stuff ####################################*/ + +@@ -703,15 +704,15 @@ + the job's done until he/she/it has a change-of-heart */ + STRLCPY(q->cap_bold, CHKw(q, View_NOBOLD) ? Cap_norm : tIF(enter_bold_mode)) + if (CHKw(q, Show_COLORS) && max_colors > 0) { +- STRLCPY(q->capclr_sum, tparm(set_a_foreground, q->rc.summclr)) ++ STRLCPY(q->capclr_sum, TPARM2(set_a_foreground, q->rc.summclr)) + snprintf(q->capclr_msg, sizeof(q->capclr_msg), "%s%s" +- , tparm(set_a_foreground, q->rc.msgsclr), Cap_reverse); ++ , TPARM2(set_a_foreground, q->rc.msgsclr), Cap_reverse); + snprintf(q->capclr_pmt, sizeof(q->capclr_pmt), "%s%s" +- , tparm(set_a_foreground, q->rc.msgsclr), q->cap_bold); ++ , TPARM2(set_a_foreground, q->rc.msgsclr), q->cap_bold); + snprintf(q->capclr_hdr, sizeof(q->capclr_hdr), "%s%s" +- , tparm(set_a_foreground, q->rc.headclr), Cap_reverse); ++ , TPARM2(set_a_foreground, q->rc.headclr), Cap_reverse); + snprintf(q->capclr_rownorm, sizeof(q->capclr_rownorm), "%s%s" +- , Caps_off, tparm(set_a_foreground, q->rc.taskclr)); ++ , Caps_off, TPARM2(set_a_foreground, q->rc.taskclr)); + } else { + q->capclr_sum[0] = '\0'; + #ifdef USE_X_COLHDR diff --git a/base/procps-ng/procps-ng.SMBuild b/base/procps-ng/procps-ng.SMBuild new file mode 100755 index 0000000..f70ba88 --- /dev/null +++ b/base/procps-ng/procps-ng.SMBuild @@ -0,0 +1,52 @@ +APP=procps-ng +VERSION=3.3.12 +BUILD=1sml +PSMISCVERSION=23.3 +HOMEPAGE='http://sourceforge.net/projects/procps-ng/' +DESC="utilities for displaying process information" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/procps-ng-netbsd-curses.patch + + STRIP=false \ + CPPFLAGS="$CFLAGS -DGLOB_TILDE=0 -DAF_INET6=10 -DAF_INET=2" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --bindir=/bin \ + --sbindir=/bin \ + --disable-nls + + make V=1 LDFLAGS="-all-static" + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + tar xf $SRCDIR/psmisc-$PSMISCVERSION.tar.?z* + cd psmisc-$PSMISCVERSION + + LDFLAGS="-static" \ + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/COPYING.psmisc + + mkfinalpkg +} + +SHA512SUMS=" +2fcdd0773d980f54b18146086beb24a4b3e44e495a5d3fdaf0b5239b6b555cc330d326eab048cc8439162490d03d426c6dfdf27539d3aebd76a2c7e150db8a7f procps-ng-3.3.12.tar.lz +791ffef78d87b092d653da98710b338017466a9e1e1935968b9f0194ccef8da941317aa0c39d821d46b20d95d6539ccf78e5ebb71ad1032ae62337a397180d58 psmisc-23.3.tar.xz +f33f577194c5699d0f4d57f4f8dfbdb8ef1373368d3ac6d5d3207e59ff044273bcef9421f1f67bf2f372fdd96fdf1c80d228a0b41d001c08f5544237897c4d26 procps-ng-netbsd-curses.patch +" diff --git a/base/pv/pv.SMBuild b/base/pv/pv.SMBuild new file mode 100755 index 0000000..ccb0f61 --- /dev/null +++ b/base/pv/pv.SMBuild @@ -0,0 +1,31 @@ +APP=pv +VERSION=1.6.6 +BUILD=1sml +HOMEPAGE='http://www.ivarch.com/programs/pv.shtml' +DOWNLOAD='http://www.ivarch.com/programs/sources/pv-1.6.6.tar.bz2' +DESC="pipe Viewer for monitoring progress of data through pipeline" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp doc/COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3642ae4c2e743bc3d037e86afadf4ebecf60afa3662f071ec123e3278402be7a40c34783f86b7bbf3f59f5ab10269ebd32c498ae12698d56556d7aa2f41387be pv-1.6.6.tar.gz +" diff --git a/base/pwgen/pwgen.SMBuild b/base/pwgen/pwgen.SMBuild new file mode 100755 index 0000000..274f825 --- /dev/null +++ b/base/pwgen/pwgen.SMBuild @@ -0,0 +1,30 @@ +APP=pwgen +VERSION=2.07 +BUILD=1sml +HOMEPAGE="https://sourceforge.net/projects/pwgen" +DESC="A small tool to generate semi-random passwords" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp debian/copyright $PKGDOCS/LICENSE + + mkfinalpkg +} + +SHA512SUMS=" +c70080820e1502f2f25e6f8c4b6b7df4bd8f5aa0a502f215e56b3142fe5e2a6150275d42a0f526638b7cb7b8b7512aae8ab39d4ecd893995de72be20a29ee1e9 pwgen-2.07.tar.lz +" diff --git a/base/python-cheetah/python-cheetah.SMBuild b/base/python-cheetah/python-cheetah.SMBuild new file mode 100755 index 0000000..4c4300c --- /dev/null +++ b/base/python-cheetah/python-cheetah.SMBuild @@ -0,0 +1,24 @@ +APP=python-cheetah +VERSION=3.2.6 +BUILD=1sml +HOMEPAGE='https://pypi.org/project/Cheetah/' +DESC="Python-Powered Template Engine" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf Cheetah3-$VERSION.post2 + + tar xf $SRCDIR/Cheetah3-$VERSION.post2.tar.?z* + cd Cheetah3-$VERSION.post2 + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +94b45c4e48e507b9eca254d097fff7175b2d75597cfda05a7a8f373917d333a5bc2e48ff7eebe5f8f711b0ed2531adbe2bfee3c271c093026c3ece2627734e1b Cheetah3-3.2.6.post2.tar.gz +" diff --git a/base/python-click/python-click.SMBuild b/base/python-click/python-click.SMBuild new file mode 100755 index 0000000..1f84c3b --- /dev/null +++ b/base/python-click/python-click.SMBuild @@ -0,0 +1,24 @@ +APP=python-click +VERSION=7.1.2 +BUILD=1sml +HOMEPAGE='https://palletsprojects.com/p/click/' +DESC="python cli interface toolkit" +REQUIRES="python-jinja2" + +build() { + mkandenterbuilddir + rm -rf click-$VERSION + + tar xf $SRCDIR/click-$VERSION.tar.?z* + cd click-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.rst $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b9fba8a30f57e380a2005b45c4f37074a27637ace9e16fb0fb0cce88aac72cfa806eea2829dac665fe2b558b8753a40b811dbfcca94dfccf999ad494865d7888 click-7.1.2.tar.gz +" diff --git a/base/python-future/python-future.SMBuild b/base/python-future/python-future.SMBuild new file mode 100755 index 0000000..8018ea0 --- /dev/null +++ b/base/python-future/python-future.SMBuild @@ -0,0 +1,24 @@ +APP=python-future +VERSION=0.18.2 +BUILD=1sml +HOMEPAGE='https://python-future.org' +DESC="Easy, clean, reliable Python 2/3 compatibility toolkit" +REQUIRES="python3 python-setuptools" + +build() { + mkandenterbuilddir + rm -rf future-$VERSION + + tar xf $SRCDIR/future-$VERSION.tar.?z* + cd future-$VERSION + fixbuilddirpermissions + + python setup.py install --prefix="" --root="$PKG" + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0fe2460226e1eef1fac0e49e2044150bfc96f6573f34c3e0f5cd78849dc83f86ca9a9b980141f95f25cbe325a58e8fcad86587b188e7ec298643733706dc0a2d future-0.18.2.tar.lz +" diff --git a/base/python-importlib-metadata/python-importlib-metadata.SMBuild b/base/python-importlib-metadata/python-importlib-metadata.SMBuild new file mode 100755 index 0000000..559b88b --- /dev/null +++ b/base/python-importlib-metadata/python-importlib-metadata.SMBuild @@ -0,0 +1,24 @@ +APP=python-importlib-metadata +VERSION=4.0.1 +BUILD=1sml +HOMEPAGE='https://github.com/python/importlib_metadata' +DESC="python library to import metadata from a python package" +REQUIRES="python-wheel" + +build() { + mkandenterbuilddir + rm -rf importlib_metadata-$VERSION + + tar xf $SRCDIR/importlib_metadata-$VERSION.tar.?z* + cd importlib_metadata-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +972e2f4bcd6433f603f0c6e23f4dbf4269993a47a5a8f66740e0143df63568ea8ca4ed6aa84587dcf967c6c4ba93e5d5ead9ac9444db9bc6424bd8c238f8335e importlib_metadata-4.0.1.tar.gz +" diff --git a/base/python-jinja2/python-jinja2.SMBuild b/base/python-jinja2/python-jinja2.SMBuild new file mode 100755 index 0000000..668552f --- /dev/null +++ b/base/python-jinja2/python-jinja2.SMBuild @@ -0,0 +1,24 @@ +APP=python-jinja2 +VERSION=2.11.3 +BUILD=1sml +HOMEPAGE='https://palletsprojects.com/p/jinja/' +DESC="fast, expressive, extensible python template engine" +REQUIRES="python-livereload" + +build() { + mkandenterbuilddir + rm -rf Jinja2-$VERSION + + tar xf $SRCDIR/Jinja2-$VERSION.tar.?z* + cd Jinja2-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.rst $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fce4f835795fe9afb622f8106f60344032a811f3f693806f31ba482f9b7c1400f93dfa1701b4db0b472cbed4b0793cb329778c8091811ef0e3b577150d28e004 Jinja2-2.11.3.tar.gz +" diff --git a/base/python-joblib/python-joblib.SMBuild b/base/python-joblib/python-joblib.SMBuild new file mode 100755 index 0000000..4ff2373 --- /dev/null +++ b/base/python-joblib/python-joblib.SMBuild @@ -0,0 +1,24 @@ +APP=python-joblib +VERSION=1.0.1 +BUILD=1sml +HOMEPAGE='https://joblib.readthedocs.io' +DESC="set of python tools to provide lightweight pipelining" +REQUIRES="python-regex" + +build() { + mkandenterbuilddir + rm -rf joblib-$VERSION + + tar xf $SRCDIR/joblib-$VERSION.tar.?z* + cd joblib-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e985982d9f4fb1abf5f9a55008e4666a06fe7d39324877a89823e9acd7edd447dc342c264a21d4546eb29f285b1b735f25b3064e5c0361be4dbf723860e4fdbe joblib-1.0.1.tar.gz +" diff --git a/base/python-livereload/python-livereload.SMBuild b/base/python-livereload/python-livereload.SMBuild new file mode 100755 index 0000000..bbc7fd6 --- /dev/null +++ b/base/python-livereload/python-livereload.SMBuild @@ -0,0 +1,24 @@ +APP=python-livereload +VERSION=2.6.3 +BUILD=1sml +HOMEPAGE="https://github.com/lepture/python-livereload" +REQUIRES="python-lunr" +DESC="python tool to trigger script reloads when web documents are changed" + +build() { + mkandenterbuilddir + rm -rf livereload-$VERSION + + tar xf $SRCDIR/livereload-$VERSION.tar.?z* + cd livereload-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +8a989d8bbfa9f33b986ff9d080f41472667602172f12d2fc6acbc76d84353aea24c71602cecab0719e84442180285cd9ab3af9b5b733706c55e182fd0b10aa7e livereload-2.6.3.tar.gz +" diff --git a/base/python-lunr/python-lunr.SMBuild b/base/python-lunr/python-lunr.SMBuild new file mode 100755 index 0000000..e945db3 --- /dev/null +++ b/base/python-lunr/python-lunr.SMBuild @@ -0,0 +1,24 @@ +APP=python-lunr +VERSION=0.5.8 +BUILD=1sml +HOMEPAGE='https://github.com/yeraydiazdiaz/lunr.py' +DESC="Python fork of lunr.js" +REQUIRES="python-tornado" + +build() { + mkandenterbuilddir + rm -rf lunr-$VERSION + + tar xf $SRCDIR/lunr-$VERSION.tar.?z* + cd lunr-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ebdbf322ce6dde022e5d9a9aaee010b7eb727eb340c155a69072cd573c05d7e5b9f4aeef9cf34a3b86f7716f767053c05061ac79a1c9ebf24322fe94102f4c6b lunr-0.5.8.tar.gz +" diff --git a/base/python-lxml/python-lxml.SMBuild b/base/python-lxml/python-lxml.SMBuild new file mode 100755 index 0000000..d4fb07e --- /dev/null +++ b/base/python-lxml/python-lxml.SMBuild @@ -0,0 +1,25 @@ +APP=python-lxml +VERSION=4.5.1 +BUILD=1sml +HOMEPAGE='https://lxml.de/' +DESC="python library for processing HTML and XML documents" +REQUIRES="python3 python-setuptools" + +build() { + mkandenterbuilddir + rm -rf lxml-$VERSION + + tar xf $SRCDIR/lxml-$VERSION.tar.?z* + cd lxml-$VERSION + + python setup.py build + python setup.py install --prefix="" --root=$PKG + cp LICENSES.txt $PKGDOCS/ + head -n 1000 CHANGES.txt > $PKGDOCS/CHANGELOG + + mkfinalpkg +} + +SHA512SUMS=" +dd6216c5741a48cd4113b69fe9ac3ac976eba210cc1ef65358e0f0977573e3057bb4ab9345a63edfd98fc8b1e2fc2b3a6141bafdcee66720a40c1160c837bf9c lxml-4.5.1.tar.lz +" diff --git a/base/python-m2crypto/python-m2crypto.SMBuild b/base/python-m2crypto/python-m2crypto.SMBuild new file mode 100755 index 0000000..a461284 --- /dev/null +++ b/base/python-m2crypto/python-m2crypto.SMBuild @@ -0,0 +1,24 @@ +APP=python-m2crypto +VERSION=0.36.0 +BUILD=1sml +HOMEPAGE='https://gitlab.com/m2crypto/m2crypto' +DESC="cryptography toolkit for Python" +REQUIRES="python3 swig" + +build() { + mkandenterbuilddir + rm -rf M2Crypto-$VERSION + + tar xf $SRCDIR/M2Crypto-$VERSION.tar.?z* + cd M2Crypto-$VERSION + fixbuilddirpermissions + + python setup.py install --prefix="" --root=$PKG + cp CHANGES LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +5a27b6f75257b907f63600f6cda094f52909a5b0d4dcfa2f2d7e423f89b156cfe1f71718f02b01e167d87c68740c49aeda75c29c30e9b8f9729536e8f824593a M2Crypto-0.36.0.tar.lz +" diff --git a/base/python-mako/python-mako.SMBuild b/base/python-mako/python-mako.SMBuild new file mode 100755 index 0000000..1057d72 --- /dev/null +++ b/base/python-mako/python-mako.SMBuild @@ -0,0 +1,24 @@ +APP=python-mako +VERSION=1.1.3 +BUILD=1sml +HOMEPAGE='http://www.makotemplates.org/' +DESC="template library for compiling high performance python modules" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf Mako-$VERSION + + tar xf $SRCDIR/Mako-$VERSION.tar.?z* + cd Mako-$VERSION + fixbuilddirpermissions + + python setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ce868ba748a67c1abcbc21a783f666c53e58fd379b532cbc94327580b1db205068477e0e5b047c333885d965bb1944d72b39b6b466a55ebc41cef469fb8fd150 Mako-1.1.3.tar.lz +" diff --git a/base/python-markdown/python-markdown.SMBuild b/base/python-markdown/python-markdown.SMBuild new file mode 100755 index 0000000..d62693e --- /dev/null +++ b/base/python-markdown/python-markdown.SMBuild @@ -0,0 +1,24 @@ +APP=python-markdown +VERSION=3.3.4 +BUILD=1sml +HOMEPAGE='https://github.com/Python-Markdown/markdown' +DESC="Python Markdown Library" +REQUIRES="python3 python-setuptools" + +build() { + mkandenterbuilddir + rm -rf Markdown-$VERSION + + tar xf $SRCDIR/Markdown-$VERSION.tar.?z* + cd Markdown-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.md $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +37422619dd8f542bfcf7975c92e76a39e4eeeb42386727d52037869cee1617f8efcb74a382a9c7cb903907ebf3643a27ba0de583bc0dbd327a36e72bbf8520af Markdown-3.3.4.tar.gz +" diff --git a/base/python-markupsafe/python-markupsafe.SMBuild b/base/python-markupsafe/python-markupsafe.SMBuild new file mode 100755 index 0000000..d14be62 --- /dev/null +++ b/base/python-markupsafe/python-markupsafe.SMBuild @@ -0,0 +1,25 @@ +APP=python-markupsafe +VERSION=1.1.1 +BUILD=1sml +HOMEPAGE='https://pypi.python.org/pypi/python-markupsafe' +DESC="python library that implements unicode subclass for supporting HTML strings" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf MarkupSafe-$VERSION + + tar xf $SRCDIR/MarkupSafe-$VERSION.tar.?z* + cd MarkupSafe-$VERSION + fixbuilddirpermissions + + python setup.py build + python setup.py install --prefix="" --root=$PKG + cp CHANGES.rst LICENSE.rst $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +851703e4eb9496db23a3fcac614b367b36a3bd62ee75c0d5de20777dfbb7addebf3da192042e6a31ac44f2e32f56c53d409d04e46beb01b7259f1b4b2ef8230a MarkupSafe-1.1.1.tar.lz +" diff --git a/base/python-mkdocs/python-mkdocs.SMBuild b/base/python-mkdocs/python-mkdocs.SMBuild new file mode 100755 index 0000000..e9cf18f --- /dev/null +++ b/base/python-mkdocs/python-mkdocs.SMBuild @@ -0,0 +1,24 @@ +APP=python-mkdocs +VERSION=1.1.2 +BUILD=1sml +HOMEPAGE='https://github.com/mkdocs/mkdocs' +DESC="Python markdown documentation generation toolkit" +REQUIRES="python-six python-future python-markupsafe python-nltk" + +build() { + mkandenterbuilddir + rm -rf mkdocs-$VERSION + + tar xf $SRCDIR/mkdocs-$VERSION.tar.?z* + cd mkdocs-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bf0e5ba8a15524ebe433fce9f2d16404922850ca562339d60e7860e243f9523321cbab5dca1f276a71d3158c7b1bfadfa25b134da50ef1cedc0b1a9658b6f10c mkdocs-1.1.2.tar.gz +" diff --git a/base/python-nltk/python-nltk.SMBuild b/base/python-nltk/python-nltk.SMBuild new file mode 100755 index 0000000..ef802ba --- /dev/null +++ b/base/python-nltk/python-nltk.SMBuild @@ -0,0 +1,24 @@ +APP=python-nltk +VERSION=3.6.2 +BUILD=1sml +HOMEPAGE='https://www.nltk.org' +DESC="python natural language development toolkit" +REQUIRES="python-joblib" + +build() { + mkandenterbuilddir + rm -rf nltk-$VERSION + + tar xf $SRCDIR/nltk-$VERSION.tar.?z* + cd nltk-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3fd2cba52377613f35f6574f859482de987f969cfc8d4243a859be365ab1bd8300f9013dcedc6caeff7aa7fc035b331a47b557027209ca9a85b0cc7fbde44d6d nltk-3.6.2.tar.gz +" diff --git a/base/python-pip/python-pip.SMBuild b/base/python-pip/python-pip.SMBuild new file mode 100755 index 0000000..534163a --- /dev/null +++ b/base/python-pip/python-pip.SMBuild @@ -0,0 +1,26 @@ +APP=python-pip +VERSION=20.1.1 +BUILD=1sml +HOMEPAGE='https://pypi.org/project/pip/' +DESC="package installer for python" +REQUIRES="python3 python-setuptools" + +build() { + mkandenterbuilddir + rm -rf pip-$VERSION + + tar xf $SRCDIR/pip-$VERSION.tar.?z* + cd pip-$VERSION + fixbuilddirpermissions + + python setup.py build + python setup.py install --prefix="" --root=$PKG + + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +383bab9880fbaaa46681257c389bf04238c8b9418d83f110be7b23331846cf3d353287793c3bfb920ba6b05fe23d1779b43a84c0d74cafb4c3561f55736423d8 pip-20.1.1.tar.lz +" diff --git a/base/python-pyyaml/python-pyyaml.SMBuild b/base/python-pyyaml/python-pyyaml.SMBuild new file mode 100755 index 0000000..befb676 --- /dev/null +++ b/base/python-pyyaml/python-pyyaml.SMBuild @@ -0,0 +1,24 @@ +APP=python-pyyaml +VERSION=5.4.1 +BUILD=1sml +HOMEPAGE='https://pyyaml.org' +DESC="Next-generation YAML parser and emitter for python" +REQUIRES="python-markdown" + +build() { + mkandenterbuilddir + rm -rf PyYAML-$VERSION + + tar xf $SRCDIR/PyYAML-$VERSION.tar.?z* + cd PyYAML-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +359c45d843fd839797572efeab121f17b1947647960dfb062f3618f25f71e1a6bc4bab14a1720b6b67f256089d5d48c452ec5419e3130222765c7ca41db11dad PyYAML-5.4.1.tar.gz +" diff --git a/base/python-regex/python-regex.SMBuild b/base/python-regex/python-regex.SMBuild new file mode 100755 index 0000000..df6bb27 --- /dev/null +++ b/base/python-regex/python-regex.SMBuild @@ -0,0 +1,24 @@ +APP=python-regex +VERSION=2021.4.4 +BUILD=1sml +HOMEPAGE='https://bitbucket.org/mrabarnett/mrab-regex' +DESC="Alternative to standard regex module supplied by python with additional features" +REQUIRES="python-tqdm" + +build() { + mkandenterbuilddir + rm -rf regex-$VERSION + + tar xf $SRCDIR/regex-$VERSION.tar.?z* + cd regex-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2eff9867639f16ad7894997f399262d653a9ef0bb4e8d40bd977e5c55625cf57b4bb593f84504009a0b3cd50b3876d1938c71fd733c0ad1a076de32b6b4b33b9 regex-2021.4.4.tar.gz +" diff --git a/base/python-setuptools/python-setuptools.SMBuild b/base/python-setuptools/python-setuptools.SMBuild new file mode 100755 index 0000000..ff96f5e --- /dev/null +++ b/base/python-setuptools/python-setuptools.SMBuild @@ -0,0 +1,26 @@ +APP=python-setuptools +VERSION=46.4.0 +BUILD=1sml +HOMEPAGE='https://github.com/pypa/setuptools' +DESC="python module installation helper" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf setuptools-$VERSION + + tar xf $SRCDIR/setuptools-$VERSION.tar.?z* + cd setuptools-$VERSION + fixbuilddirpermissions + + python bootstrap.py + python setup.py install --prefix="" --root=$PKG --optimize=1 + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fe22f2fd29791fbdb065c5ef4eca478f623f029dc6ef572e206b47419df311e42d2968e2f3752f1299a35bd71b59bcf69c0f6fb67b477ba810fd0c141ea1183b setuptools-46.4.0.tar.lz +" diff --git a/base/python-six/python-six.SMBuild b/base/python-six/python-six.SMBuild new file mode 100755 index 0000000..b540ebc --- /dev/null +++ b/base/python-six/python-six.SMBuild @@ -0,0 +1,24 @@ +APP=python-six +VERSION=1.14.0 +BUILD=1sml +HOMEPAGE='https://pypi.python.org/pypi/python-six/' +DESC="Python 2 and 3 compatibility library" +REQUIRES="python3 python-setuptools" + +build() { + mkandenterbuilddir + rm -rf six-$VERSION + + tar xf $SRCDIR/six-$VERSION.tar.?z* + cd six-$VERSION + fixbuilddirpermissions + + python setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +22076cc724c39af8d9e04241ddf3e0651b47685016485d5e6e948218b934310a6b9b0f8fd6b200dac11c606e1bba52c28878fdcae5461ac1901e3a30d74149c5 six-1.14.0.tar.lz +" diff --git a/base/python-tornado/python-tornado.SMBuild b/base/python-tornado/python-tornado.SMBuild new file mode 100755 index 0000000..b1aa445 --- /dev/null +++ b/base/python-tornado/python-tornado.SMBuild @@ -0,0 +1,24 @@ +APP=python-tornado +VERSION=6.1.0 +BUILD=1sml +HOMEPAGE='http://www.tornadoweb.org' +DESC="Python Web Framework and ASYNC Net Library" +REQUIRES="python-pyyaml" + +build() { + mkandenterbuilddir + rm -rf tornado-$VERSION + + tar xf $SRCDIR/tornado-$VERSION.tar.?z* + cd tornado-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bd161a1c30f40f983d608297bca113735cb4baad255de71302a5b4d35be8c02afbc9820728efa912e62e1cbbfad8f92360261a69e0c8759f9e6cb477fbca31c7 tornado-6.1.0.tar.gz +" diff --git a/base/python-tqdm/python-tqdm.SMBuild b/base/python-tqdm/python-tqdm.SMBuild new file mode 100755 index 0000000..883b09a --- /dev/null +++ b/base/python-tqdm/python-tqdm.SMBuild @@ -0,0 +1,24 @@ +APP=python-tqdm +VERSION=4.60.0 +BUILD=1sml +HOMEPAGE='https://github.com/tqdm/tqdm' +DESC="Generate progress meter between loops in python programs" +REQUIRES="python-zipp" + +build() { + mkandenterbuilddir + rm -rf tqdm-$VERSION + + tar xf $SRCDIR/tqdm-$VERSION.tar.?z* + cd tqdm-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e76dda97323353725c8e30b254bacfa328b4708d37ba2d21dadd30fd26e76605d8f077f02f2047030c6ab9761710a0e86640153fee0e3a3f972db12266fcfde2 tqdm-4.60.0.tar.gz +" diff --git a/base/python-typing-extensions/python-typing-extensions.SMBuild b/base/python-typing-extensions/python-typing-extensions.SMBuild new file mode 100755 index 0000000..b996bc2 --- /dev/null +++ b/base/python-typing-extensions/python-typing-extensions.SMBuild @@ -0,0 +1,24 @@ +APP=python-typing-extensions +VERSION=3.7.4.3 +BUILD=1sml +HOMEPAGE='https://pypi.org/project/typing-extensions/' +DESC="python module providing backports and experimental cases from original typing module" +REQUIRES="python-importlib-metadata" + +build() { + mkandenterbuilddir + rm -rf typing_extensions--$VERSION + + tar xf $SRCDIR/typing_extensions-$VERSION.tar.?z* + cd typing_extensions-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fa1f96b73b13308ddb2676684862916aac8741be4523387c6a0f682a52d307190aac3e4149317842e686d14483d8a37a9e1de2514a2d1ca86f9ae9c8b0e18eb1 typing_extensions-3.7.4.3.tar.gz +" diff --git a/base/python-typing/python-typing.SMBuild b/base/python-typing/python-typing.SMBuild new file mode 100755 index 0000000..74891af --- /dev/null +++ b/base/python-typing/python-typing.SMBuild @@ -0,0 +1,24 @@ +APP=python-typing +VERSION=3.7.4.3 +BUILD=1sml +HOMEPAGE='https://pypi.org/project/typing/' +DESC="python typing module" +REQUIRES="python3 python-setuptools" + +build() { + mkandenterbuilddir + rm -rf typing-$VERSION + + tar xf $SRCDIR/typing-$VERSION.tar.?z* + cd typing-$VERSION + fixbuilddirpermissions + + python setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ef58b8b56654956b7d6754dfbee4c929b03ee0ed7c06e89aa9e341a80126f287c25d57ed0f981f889977ba05202905b0a6550f68f8050e908f6e2bd7ec40daf9 typing-3.7.4.3.tar.lz +" diff --git a/base/python-wheel/python-wheel.SMBuild b/base/python-wheel/python-wheel.SMBuild new file mode 100755 index 0000000..2505bf6 --- /dev/null +++ b/base/python-wheel/python-wheel.SMBuild @@ -0,0 +1,24 @@ +APP=python-wheel +VERSION=0.36.2 +BUILD=1sml +HOMEPAGE='https://pypi.org/project/wheel/' +DESC="Python implementation of the python wheel packaging standard" +REQUIRES="python-click" + +build() { + mkandenterbuilddir + rm -rf wheel-$VERSION + + tar xf $SRCDIR/wheel-$VERSION.tar.?z* + cd wheel-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +73f5c6e77b8c396163b02e12ce7291e32960d771c732d8e97476971201b29e654d53551b2ce17db1fbde5697ced1908607995cac38fe2b61c63aec6abd4b6aaf wheel-0.36.2.tar.gz +" diff --git a/base/python-zipp/python-zipp.SMBuild b/base/python-zipp/python-zipp.SMBuild new file mode 100755 index 0000000..1d11b3e --- /dev/null +++ b/base/python-zipp/python-zipp.SMBuild @@ -0,0 +1,24 @@ +APP=python-zipp +VERSION=3.4.1 +BUILD=1sml +HOMEPAGE='https://pypi.org/project/zipp/' +DESC="pathlib-compatible Zipfile object wrapper for python" +REQUIRES="python-typing-extensions" + +build() { + mkandenterbuilddir + rm -rf zipp-$VERSION + + tar xf $SRCDIR/zipp-$VERSION.tar.?z* + cd zipp-$VERSION + fixbuilddirpermissions + + python3 setup.py install --prefix="" --root=$PKG + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +2ba50109efd0ceea9eb1d57e2d839f522b5a78a8dae344d6da54b79305dd46bff23f1116f562127290152c0b100369439c17fe9dc3fb14d0b42beaa48348ebe6 zipp-3.4.1.tar.gz +" diff --git a/base/python3/fix-xattrs-glibc.patch b/base/python3/fix-xattrs-glibc.patch new file mode 100644 index 0000000..57a8fb7 --- /dev/null +++ b/base/python3/fix-xattrs-glibc.patch @@ -0,0 +1,15 @@ +diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c +index 8f8ba25..72b92da 100644 +--- a/Modules/posixmodule.c ++++ b/Modules/posixmodule.c +@@ -103,8 +103,9 @@ corresponding Unix manual entries for more information on calls."); + #undef HAVE_SCHED_SETAFFINITY + #endif + +-#if defined(HAVE_SYS_XATTR_H) && defined(__GLIBC__) && !defined(__FreeBSD_kernel__) && !defined(__GNU__) ++#if defined(HAVE_SYS_XATTR_H) && defined(__linux__) && !defined(__FreeBSD_kernel__) && !defined(__GNU__) + #define USE_XATTRS ++#include + #endif + + #ifdef USE_XATTRS diff --git a/base/python3/musl-find_library.patch b/base/python3/musl-find_library.patch new file mode 100644 index 0000000..7899abb --- /dev/null +++ b/base/python3/musl-find_library.patch @@ -0,0 +1,45 @@ +diff -ru Python-2.7.12.orig/Lib/ctypes/util.py Python-2.7.12/Lib/ctypes/util.py +--- Python-2.7.12.orig/Lib/ctypes/util.py 2016-06-26 00:49:30.000000000 +0300 ++++ Python-2.7.12/Lib/ctypes/util.py 2016-11-03 16:05:46.954665040 +0200 +@@ -204,6 +204,41 @@ + def find_library(name, is64 = False): + return _get_soname(_findLib_crle(name, is64) or _findLib_gcc(name)) + ++ elif True: ++ ++ # Patched for Alpine Linux / musl - search manually system paths ++ def _is_elf(filepath): ++ try: ++ with open(filepath, 'rb') as fh: ++ return fh.read(4) == b'\x7fELF' ++ except: ++ return False ++ ++ def find_library(name): ++ from glob import glob ++ # absolute name? ++ if os.path.isabs(name): ++ return name ++ # special case for libm, libcrypt and libpthread and musl ++ if name in ['m', 'crypt', 'pthread']: ++ name = 'c' ++ elif name in ['libm.so', 'libcrypt.so', 'libpthread.so']: ++ name = 'libc.so' ++ # search in standard locations (musl order) ++ paths = ['/lib', '/usr/local/lib', '/usr/lib'] ++ if 'LD_LIBRARY_PATH' in os.environ: ++ paths = os.environ['LD_LIBRARY_PATH'].split(':') + paths ++ for d in paths: ++ f = os.path.join(d, name) ++ if _is_elf(f): ++ return os.path.basename(f) ++ ++ prefix = os.path.join(d, 'lib'+name) ++ for suffix in ['.so', '.so.*']: ++ for f in glob('{0}{1}'.format(prefix, suffix)): ++ if _is_elf(f): ++ return os.path.basename(f) ++ + else: + + def _findSoname_ldconfig(name): diff --git a/base/python3/python3-includedirs.patch b/base/python3/python3-includedirs.patch new file mode 100644 index 0000000..c97681c --- /dev/null +++ b/base/python3/python3-includedirs.patch @@ -0,0 +1,17 @@ +--- Python-3.7.3.orig/setup.py ++++ Python-3.7.3/setup.py +@@ -536,8 +536,12 @@ + add_dir_to_list(self.compiler.library_dirs, + d) + elif is_gcc and in_incdirs and '/gcc/' not in line: +- add_dir_to_list(self.compiler.include_dirs, +- line.strip()) ++ incdir = line.strip() ++ add_dir_to_list(self.compiler.include_dirs, incdir) ++ libdir = incdir.replace("/include", "/lib") ++ if libdir != incdir: ++ add_dir_to_list(self.compiler.library_dirs, ++ libdir) + finally: + os.unlink(tmpfile) + diff --git a/base/python3/python3-pathsearch.patch b/base/python3/python3-pathsearch.patch new file mode 100644 index 0000000..26f2125 --- /dev/null +++ b/base/python3/python3-pathsearch.patch @@ -0,0 +1,129 @@ +--- Python-3.7.3.orig/Modules/getpath.c ++++ Python-3.7.3/Modules/getpath.c +@@ -121,6 +121,7 @@ + wchar_t *pythonpath; /* PYTHONPATH define */ + wchar_t *prefix; /* PREFIX define */ + wchar_t *exec_prefix; /* EXEC_PREFIX define */ ++ wchar_t *smlinux_staging_dir; /* SMLINUX_STAGING_DIR define */ + + wchar_t *lib_python; /* "lib/pythonX.Y" */ + wchar_t argv0_path[MAXPATHLEN+1]; +@@ -155,9 +156,16 @@ + reduce(wchar_t *dir) + { + size_t i = wcslen(dir); ++ if (i == 1 && dir[0] == SEP) { ++ /* L"/" becomes L"" */ ++ dir[0] = L'\0'; ++ return; ++ } + while (i > 0 && dir[i] != SEP) + --i; +- dir[i] = '\0'; ++ if (i == 0 && dir[0] == SEP) ++ i = 1; /* L"/blah" becomes L"/" */ ++ dir[i] = L'\0'; + } + + +@@ -374,6 +382,15 @@ + } + } + ++ /* If argv[0] appears to be in smlinux's staging directory, ++ * then skip to the following PREFIX check, ++ * otherwise proceed as normal to preserve virtual environments. ++ */ ++ if (!wcsncmp(calculate->smlinux_staging_dir, calculate->argv0_path, ++ wcslen(calculate->smlinux_staging_dir)) || ++ !wcsncmp(calculate->argv0_path, L"/bin/../", 8)) ++ goto skip_argv0_path; ++ + /* Search from argv0_path, until root is found */ + copy_absolute(prefix, calculate->argv0_path, MAXPATHLEN+1); + do { +@@ -386,9 +403,15 @@ + prefix[n] = L'\0'; + reduce(prefix); + } while (prefix[0]); ++ skip_argv0_path: + + /* Look at configure's PREFIX */ +- wcsncpy(prefix, calculate->prefix, MAXPATHLEN); ++ if (wcslen(calculate->prefix)) ++ wcsncpy(prefix, calculate->prefix, MAXPATHLEN); ++ else { ++ prefix[0] = '/'; ++ prefix[1] = 0; ++ } + prefix[MAXPATHLEN] = L'\0'; + joinpath(prefix, calculate->lib_python); + joinpath(prefix, LANDMARK); +@@ -495,6 +518,15 @@ + } + } + ++ /* If argv[0] appears to be in smlinux's staging directory, ++ * then skip to the following EXEC_PREFIX check, ++ * otherwise proceed as normal to preserve virtual environments. ++ */ ++ if (!wcsncmp(calculate->smlinux_staging_dir, calculate->argv0_path, ++ wcslen(calculate->smlinux_staging_dir)) || ++ !wcsncmp(calculate->argv0_path, L"/bin/../", 8)) ++ goto skip_argv0_path; ++ + /* Search from argv0_path, until root is found */ + copy_absolute(exec_prefix, calculate->argv0_path, MAXPATHLEN+1); + do { +@@ -507,9 +539,16 @@ + exec_prefix[n] = L'\0'; + reduce(exec_prefix); + } while (exec_prefix[0]); ++ skip_argv0_path: + + /* Look at configure's EXEC_PREFIX */ +- wcsncpy(exec_prefix, calculate->exec_prefix, MAXPATHLEN); ++ if (strlen(EXEC_PREFIX)) { ++ wcsncpy(exec_prefix, calculate->exec_prefix, MAXPATHLEN); ++ } ++ else { ++ exec_prefix[0] = L'/'; ++ exec_prefix[1] = L'\0'; ++ } + exec_prefix[MAXPATHLEN] = L'\0'; + joinpath(exec_prefix, calculate->lib_python); + joinpath(exec_prefix, L"lib-dynload"); +@@ -829,7 +868,9 @@ + } + + bufsz += wcslen(calculate->zip_path) + 1; +- bufsz += wcslen(exec_prefix) + 1; ++ if (wcslen(exec_prefix)) { ++ bufsz += wcslen(exec_prefix) + 1; ++ } + + /* Allocate the buffer */ + wchar_t *buf = PyMem_RawMalloc(bufsz * sizeof(wchar_t)); +@@ -880,7 +921,10 @@ + wcscat(buf, delimiter); + + /* Finally, on goes the directory for dynamic-load modules */ +- wcscat(buf, exec_prefix); ++ if (wcslen(exec_prefix)) { ++ wcscat(buf, delimiter); ++ wcscat(buf, exec_prefix); ++ } + + config->module_search_path = buf; + return _Py_INIT_OK(); +@@ -908,6 +952,10 @@ + if (!calculate->prefix) { + return DECODE_LOCALE_ERR("PREFIX define", len); + } ++ calculate->smlinux_staging_dir = Py_DecodeLocale(SMLINUX_STAGING_DIR, &len); ++ if (!calculate->smlinux_staging_dir) { ++ return DECODE_LOCALE_ERR("SMLINUX_STAGING_DIR define", len); ++ } + calculate->exec_prefix = Py_DecodeLocale(EXEC_PREFIX, &len); + if (!calculate->prefix) { + return DECODE_LOCALE_ERR("EXEC_PREFIX define", len); diff --git a/base/python3/python3-sysconfig-prefix.patch b/base/python3/python3-sysconfig-prefix.patch new file mode 100644 index 0000000..03945f2 --- /dev/null +++ b/base/python3/python3-sysconfig-prefix.patch @@ -0,0 +1,58 @@ +this patch fixes 3 things: +1) native: if prefix is empty, use "/" to construct the pathname, otherwise + we will end up with something like `-I include/python2.7` +2) cross-compile: if we're cross-compiling, we're reusing the + PKG_CONFIG_SYSROOT_DIR environment variable to prefix the include/lib path. + this though helps only when the system doing the crosscompile uses the so- + patched python. we therefore assume a sabotage host system is used. +3) previously, the right logic for selecting LD_SHARED was only used on Mac. + it should be done on any POSIX system (CC overrides). + +--- Python-3.7.3.orig/Lib/distutils/sysconfig.py ++++ Python-3.7.3/Lib/distutils/sysconfig.py +@@ -92,7 +92,7 @@ + If 'prefix' is supplied, use it instead of sys.base_prefix or + sys.base_exec_prefix -- i.e., ignore 'plat_specific'. + """ +- if prefix is None: ++ if prefix is None or prefix == '': + prefix = plat_specific and BASE_EXEC_PREFIX or BASE_PREFIX + if os.name == "posix": + if python_build: +@@ -107,7 +107,8 @@ + incdir = os.path.join(get_config_var('srcdir'), 'Include') + return os.path.normpath(incdir) + python_dir = 'python' + get_python_version() + build_flags +- return os.path.join(prefix, "include", python_dir) ++ sysroot = os.environ.get('PKG_CONFIG_SYSROOT_DIR', '') ++ return os.path.join(sysroot + prefix, "include", python_dir) + elif os.name == "nt": + if python_build: + # Include both the include and PC dir to ensure we can find +@@ -135,14 +136,15 @@ + If 'prefix' is supplied, use it instead of sys.base_prefix or + sys.base_exec_prefix -- i.e., ignore 'plat_specific'. + """ +- if prefix is None: ++ if prefix is None or prefix == '': + if standard_lib: + prefix = plat_specific and BASE_EXEC_PREFIX or BASE_PREFIX + else: + prefix = plat_specific and EXEC_PREFIX or PREFIX + + if os.name == "posix": +- libpython = os.path.join(prefix, ++ sysroot = os.environ.get('PKG_CONFIG_SYSROOT_DIR', '') ++ libpython = os.path.join(sysroot + prefix, + "lib", "python" + get_python_version()) + if standard_lib: + return libpython +@@ -189,7 +191,7 @@ + + if 'CC' in os.environ: + newcc = os.environ['CC'] +- if (sys.platform == 'darwin' ++ if ((sys.platform == 'darwin' or os.name == 'posix') + and 'LDSHARED' not in os.environ + and ldshared.startswith(cc)): + # On OS X, if CC is overridden, use that as the default diff --git a/base/python3/python3.SMBuild b/base/python3/python3.SMBuild new file mode 100755 index 0000000..96fee19 --- /dev/null +++ b/base/python3/python3.SMBuild @@ -0,0 +1,68 @@ +APP=python3 +VERSION=3.7.10 +BUILD=1sml +HOMEPAGE='https://www.python.org/' +DOWNLOAD='https://www.python.org/ftp/python/3.7.10/Python-3.7.10.tar.xz' +DESC="object-oriented interpreted programming language" +REQUIRES="libffi expat file openssl sqlite" +SM_NOAUTOCONFSITE=1 + +build() { + mkandenterbuilddir + rm -rf "Python-$VERSION" + + tar xf $SRCDIR/Python-$VERSION.tar.?z* + cd "Python-$VERSION" + fixbuilddirpermissions + + patch -p1 < $SRCDIR/fix-xattrs-glibc.patch + patch -p1 < $SRCDIR/musl-find_library.patch + patch -p1 < $SRCDIR/python3-includedirs.patch + patch -p1 < $SRCDIR/python3-pathsearch.patch + patch -p1 < $SRCDIR/python3-sysconfig-prefix.patch + + sed -i -e "s|^#.* /usr/local/bin/python|#!/bin/python3|" Lib/cgi.py + find . -name '*.py' -exec \ + sed -i "s|#[ ]*![ ]*/usr/bin/env python$|#!/usr/bin/env python3|" {} + + + ac_cv_lib_readline_rl_callback_handler_install=no \ + ac_cv_lib_readline_rl_pre_input_hook=no \ + ac_cv_lib_readline_rl_completion_display_matches_hook=no \ + ac_cv_have_long_long_format=yes \ + ac_cv_func_timegm=yes \ + ac_cv_file__dev_ptc=no \ + ac_cv_file__dev_ptmx=yes \ + CFLAGS="$CFLAGS -D_BSD_SOURCE -DSMLINUX_STAGING_DIR='\"$PKG/\"'" \ + LDFLAGS="-lncursesw -lterminfo" \ + ./configure \ + --prefix= \ + --with-system-expat \ + --with-system-ffi \ + --without-cxx-main \ + --without-ensurepip + + make $MAKEFLAGS + make install DESTDIR=$PKG + + cp LICENSE $PKGDOCS/ + + for test in sqlite3/test email/test ctypes/test test\ + unittest/test tkinter/test \ + bsddb/test json/tests lib2to3/tests\ + distutils/tests tests ; do + rm -rf "$PKG"/lib/python3.7/"$test" + done + + ( cd $PKG/bin ; ln -s python3 python ) + + mkfinalpkg +} + +SHA512SUMS=" +5cb61739acbd29f526d25073443398b2ca0eef30d01d134e8236c8bbc7ab0586c44ec00689f5a75e6aedc0170acf4551721ada5e967e4b99a146cfcaad949128 Python-3.7.10.tar.xz +37b6ee5d0d5de43799316aa111423ba5a666c17dc7f81b04c330f59c1d1565540eac4c585abe2199bbed52ebe7426001edb1c53bd0a17486a2a8e052d0f494ad fix-xattrs-glibc.patch +ab8eaa2858d5109049b1f9f553198d40e0ef8d78211ad6455f7b491af525bffb16738fed60fc84e960c4889568d25753b9e4a1494834fea48291b33f07000ec2 musl-find_library.patch +3542288821723c00651248935537ee2141e9510473c00b096713581bcc75d2e57ad73d69f4e0eaad9e9d231832f1764eb8f3cd52fac80a388e2b9caae25bfe92 python3-includedirs.patch +a72ac0cb27787f5dd52ef3cdec10f12be08009b0fbd6c21cfc3cec98083a8556513bf2548220376384268449f022f24fa488ff57e4d1f9ca4622ae94aca79281 python3-pathsearch.patch +f87338142ef6ce222c165c1aca618c71e6d2d4467007ff20a26cef95580f7bd01c7bac2d45741450b9e93191e67d798cf7ba71fb24c265f1f24e6d92f2f34dce python3-sysconfig-prefix.patch +" diff --git a/base/qpdf/qpdf.SMBuild b/base/qpdf/qpdf.SMBuild new file mode 100755 index 0000000..0baccb5 --- /dev/null +++ b/base/qpdf/qpdf.SMBuild @@ -0,0 +1,32 @@ +APP=qpdf +VERSION=6.0.0 +BUILD=1sml +HOMEPAGE='http://qpdf.sourceforge.net/' +DOWNLOAD='https://sourceforge.net/projects/qpdf/files/qpdf/6.0.0/qpdf-6.0.0.tar.gz' +DESC="Command-line tools and library for transforming PDF files" +REQUIRES="gcc-libs pcre" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp Artistic* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a6025fca43885bd04e43c8222a0bb858ef7cfc4c09abdda324975dcf8bdc99e225997c3e12f3ecac15f6aca314e4d836db00f2fe1bce600c36a9a53bf934a208 qpdf-6.0.0.tar.lz +" diff --git a/base/readline/readline.SMBuild b/base/readline/readline.SMBuild new file mode 100755 index 0000000..336f41c --- /dev/null +++ b/base/readline/readline.SMBuild @@ -0,0 +1,45 @@ +APP=readline +VERSION=6.3 +BUILD=1sml +HOMEPAGE='https://tiswww.case.edu/php/chet/readline/rltop.html' +DOWNLOAD='ftp://ftp.cwru.edu/pub/bash/readline-6.3.tar.gz' +DESC="line input library with editing features" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + for file in $SRCDIR/readline*-???.patch ; do + cat $file | patch -p0 --verbose + done + + ./configure \ + --prefix="" \ + --with-curses \ + --enable-multibyte \ + --disable-static + + make shared + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +39d003396e2dc5127f1d970dd0b50fa95388f2e31f9c08a513138637156b673d1e82b53fddce9ad9ee23cfe206ea8ea4b6adc900a0eb3af4a2f761e74e3856de readline-6.3.tar.lz +e70f89ca52a4eae7e1cddd70de6a7162252231ee029c89bb3fcb0f6c8c8b46c666be910c8b2eee72e96983ec2f1a23663694dc222f67228d82e8e4684f1504a2 readline63-001.patch +4e23bd67433577e6e361d10a6c32768ea9e13b10e77493e565b870f56069b673fbcb0b860225f79fa9931845fc91d35c9a82c1385c23f8b757ebfd59f27851f4 readline63-002.patch +6bfb84a5b980091b995e2b96bdf5680f97fe670e6cac1b8606d2d75a1ef922ff5bd4e73f029f7af98a115006b7ab7828146f2cd6986287543d8a29987c91dc12 readline63-003.patch +6b683e9fe28831885135391b5a23bc580cacf0ffe720951a80f545574eda4eb064fe189801d44329b2eb2d3577db5a90f9e5ad9ed131e7e8a8ae349511632721 readline63-004.patch +b0332d7f999376788155341319d138a899a2278c338a6faaac89ecf3ed1e2248a07413dd810a76996bf25f211de787182b55f34ab3d7d31eb7519d7a48ebed32 readline63-005.patch +e9fbfa38d7b03ab2aff2e9e48918b85b4b67a729862ee47d1cc8e0aeb90c3224394a79f68829951e1377cae65742aa5385eae865f75e9c0b2e2abde42889431c readline63-006.patch +abee331894846b360203a521d9a66fa02c03214120d5cafbd1cb4d680bd7bbef14321ae845dd67f7b5e8c87322801fd96fc9a5fd0ae026b41d98dc24a8949854 readline63-007.patch +8e30bbca3aa5cea8c2ee511abe0ec8f131608d74fe5ab24d68bcf452267f0f97446ed6e7cd482360876ce6c027280e4f4450cae05eb18f56046240f4c224841c readline63-008.patch +" diff --git a/base/readline/readline63-001.patch b/base/readline/readline63-001.patch new file mode 100644 index 0000000..bae6a2f --- /dev/null +++ b/base/readline/readline63-001.patch @@ -0,0 +1,43 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-001 + +Bug-Reported-by: Daan van Rossum +Bug-Reference-ID: <20140307072523.GA14250@flash.uchicago.edu> +Bug-Reference-URL: + +Bug-Description: + +The `.' command in vi mode cannot undo multi-key commands beginning with +`c', `d', and `y' (command plus motion specifier). + +Patch (apply with `patch -p0'): + +*** ../readline-6.3/readline.c 2013-10-28 14:58:06.000000000 -0400 +--- readline.c 2014-03-07 15:20:33.000000000 -0500 +*************** +*** 965,969 **** + if (rl_editing_mode == vi_mode && _rl_keymap == vi_movement_keymap && + key != ANYOTHERKEY && +! rl_key_sequence_length == 1 && /* XXX */ + _rl_vi_textmod_command (key)) + _rl_vi_set_last (key, rl_numeric_arg, rl_arg_sign); +--- 965,969 ---- + if (rl_editing_mode == vi_mode && _rl_keymap == vi_movement_keymap && + key != ANYOTHERKEY && +! _rl_dispatching_keymap == vi_movement_keymap && + _rl_vi_textmod_command (key)) + _rl_vi_set_last (key, rl_numeric_arg, rl_arg_sign); +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 5 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 1 diff --git a/base/readline/readline63-002.patch b/base/readline/readline63-002.patch new file mode 100644 index 0000000..0e79f13 --- /dev/null +++ b/base/readline/readline63-002.patch @@ -0,0 +1,44 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-002 + +Bug-Reported-by: Anatol Pomozov +Bug-Reference-ID: +Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-readline/2014-03/msg00010.html + +Bug-Description: + +When in callback mode, some readline commands can cause readline to seg +fault by passing invalid contexts to callback functions. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3/readline.c 2013-10-28 14:58:06.000000000 -0400 +--- readline.c 2014-03-10 14:15:02.000000000 -0400 +*************** +*** 745,749 **** + + RL_CHECK_SIGNALS (); +! if (r == 0) /* success! */ + { + _rl_keyseq_chain_dispose (); +--- 745,750 ---- + + RL_CHECK_SIGNALS (); +! /* We only treat values < 0 specially to simulate recursion. */ +! if (r >= 0 || (r == -1 && (cxt->flags & KSEQ_SUBSEQ) == 0)) /* success! or failure! */ + { + _rl_keyseq_chain_dispose (); +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 1 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 2 diff --git a/base/readline/readline63-003.patch b/base/readline/readline63-003.patch new file mode 100644 index 0000000..d2cad94 --- /dev/null +++ b/base/readline/readline63-003.patch @@ -0,0 +1,47 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-003 + +Bug-Reported-by: +Bug-Reference-ID: +Bug-Reference-URL: + +Bug-Description: + +There are debugging functions in the readline release that are theoretically +exploitable as security problems. They are not public functions, but have +global linkage. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3/util.c 2013-09-02 13:36:12.000000000 -0400 +--- util.c 2014-03-20 10:25:53.000000000 -0400 +*************** +*** 477,480 **** +--- 479,483 ---- + } + ++ #if defined (DEBUG) + #if defined (USE_VARARGS) + static FILE *_rl_tracefp; +*************** +*** 539,542 **** +--- 542,546 ---- + } + #endif ++ #endif /* DEBUG */ + + +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 2 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 3 diff --git a/base/readline/readline63-004.patch b/base/readline/readline63-004.patch new file mode 100644 index 0000000..3cd89e3 --- /dev/null +++ b/base/readline/readline63-004.patch @@ -0,0 +1,45 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-004 + +Bug-Reported-by: Egmont Koblinger +Bug-Reference-ID: +Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-bash/2014-03/msg00153.html + +Bug-Description: + +The signal handling changes to bash and readline (to avoid running any code +in a signal handler context) cause the cursor to be placed on the wrong +line of a multi-line command after a ^C interrupts editing. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3-patched/display.c 2013-12-27 13:10:56.000000000 -0500 +--- display.c 2014-03-27 11:52:45.000000000 -0400 +*************** +*** 2678,2682 **** + if (_rl_echoing_p) + { +! _rl_move_vert (_rl_vis_botlin); + _rl_vis_botlin = 0; + fflush (rl_outstream); +--- 2678,2683 ---- + if (_rl_echoing_p) + { +! if (_rl_vis_botlin > 0) /* minor optimization plus bug fix */ +! _rl_move_vert (_rl_vis_botlin); + _rl_vis_botlin = 0; + fflush (rl_outstream); +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 3 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 4 diff --git a/base/readline/readline63-005.patch b/base/readline/readline63-005.patch new file mode 100644 index 0000000..8a63738 --- /dev/null +++ b/base/readline/readline63-005.patch @@ -0,0 +1,58 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-005 + +Bug-Reported-by: Juergen Daubert +Bug-Reference-ID: <20140303180430.GA7346@jue.netz> +Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-readline/2014-03/msg00002.html + +Bug-Description: + +There are still applications using the deprecated Function/VFunction/etc. +typedefs in rltypedefs.h. This patch restores the typedefs, but attempts +to mark them as deprecated using gcc/clang attributes. Thanks to Max Horn +for the suggestion. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3-patched/rltypedefs.h 2011-03-26 14:53:31.000000000 -0400 +--- rltypedefs.h 2014-04-10 11:30:45.000000000 -0400 +*************** +*** 27,30 **** +--- 27,49 ---- + #endif + ++ /* Old-style, attempt to mark as deprecated in some way people will notice. */ ++ ++ #if !defined (_FUNCTION_DEF) ++ # define _FUNCTION_DEF ++ ++ #if defined(__GNUC__) || defined(__clang__) ++ typedef int Function () __attribute__ ((deprecated)); ++ typedef void VFunction () __attribute__ ((deprecated)); ++ typedef char *CPFunction () __attribute__ ((deprecated)); ++ typedef char **CPPFunction () __attribute__ ((deprecated)); ++ #else ++ typedef int Function (); ++ typedef void VFunction (); ++ typedef char *CPFunction (); ++ typedef char **CPPFunction (); ++ #endif ++ ++ #endif /* _FUNCTION_DEF */ ++ + /* New style. */ + +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 4 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 5 diff --git a/base/readline/readline63-006.patch b/base/readline/readline63-006.patch new file mode 100644 index 0000000..a3f0930 --- /dev/null +++ b/base/readline/readline63-006.patch @@ -0,0 +1,63 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-006 + +Bug-Reported-by: +Bug-Reference-ID: +Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-bash/2014-04/msg00069.html + +Bug-Description: + +Using reverse-i-search when horizontal scrolling is enabled does not redisplay +the entire line containing the successful search results. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3-patched/display.c 2014-04-08 18:19:36.000000000 -0400 +--- display.c 2014-04-20 18:32:52.000000000 -0400 +*************** +*** 1638,1642 **** + the spot of first difference is before the end of the invisible chars, + lendiff needs to be adjusted. */ +! if (current_line == 0 && !_rl_horizontal_scroll_mode && + current_invis_chars != visible_wrap_offset) + { +--- 1638,1642 ---- + the spot of first difference is before the end of the invisible chars, + lendiff needs to be adjusted. */ +! if (current_line == 0 && /* !_rl_horizontal_scroll_mode && */ + current_invis_chars != visible_wrap_offset) + { +*************** +*** 1826,1831 **** + _rl_last_c_pos += bytes_to_insert; + + if (_rl_horizontal_scroll_mode && ((oe-old) > (ne-new))) +! goto clear_rest_of_line; + } + } +--- 1826,1836 ---- + _rl_last_c_pos += bytes_to_insert; + ++ /* XXX - we only want to do this if we are at the end of the line ++ so we move there with _rl_move_cursor_relative */ + if (_rl_horizontal_scroll_mode && ((oe-old) > (ne-new))) +! { +! _rl_move_cursor_relative (ne-new, new); +! goto clear_rest_of_line; +! } + } + } +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 5 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 6 diff --git a/base/readline/readline63-007.patch b/base/readline/readline63-007.patch new file mode 100644 index 0000000..1b65792 --- /dev/null +++ b/base/readline/readline63-007.patch @@ -0,0 +1,47 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-007 + +Bug-Reported-by: John Lenton +Bug-Reference-ID: +Bug-Reference-URL: https://bugs.launchpad.net/ubuntu/+source/bash/+bug/1317476 + +Bug-Description: + +Readline should allow SIGALRM and SIGVTALRM (if available) to `interrupt' +rl_getc and cause the handler to run when not in a signal handling context. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3-patched/input.c 2014-01-10 15:07:08.000000000 -0500 +--- input.c 2014-05-30 16:20:56.000000000 -0400 +*************** +*** 535,540 **** +--- 538,551 ---- + else if (_rl_caught_signal == SIGHUP || _rl_caught_signal == SIGTERM) + return (RL_ISSTATE (RL_STATE_READCMD) ? READERR : EOF); ++ /* keyboard-generated signals of interest */ + else if (_rl_caught_signal == SIGINT || _rl_caught_signal == SIGQUIT) + RL_CHECK_SIGNALS (); ++ /* non-keyboard-generated signals of interest */ ++ else if (_rl_caught_signal == SIGALRM ++ #if defined (SIGVTALRM) ++ || _rl_caught_signal == SIGVTALRM ++ #endif ++ ) ++ RL_CHECK_SIGNALS (); + + if (rl_signal_event_hook) +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 6 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 7 diff --git a/base/readline/readline63-008.patch b/base/readline/readline63-008.patch new file mode 100644 index 0000000..691016f --- /dev/null +++ b/base/readline/readline63-008.patch @@ -0,0 +1,47 @@ + READLINE PATCH REPORT + ===================== + +Readline-Release: 6.3 +Patch-ID: readline63-008 + +Bug-Reported-by: Jared Yanovich +Bug-Reference-ID: <20140625225019.GJ17044@nightderanger.psc.edu> +Bug-Reference-URL: http://lists.gnu.org/archive/html/bug-bash/2014-06/msg00070.html + +Bug-Description: + +When the readline `revert-all-at-newline' option is set, pressing newline +when the current line is one retrieved from history results in a double free +and a segmentation fault. + +Patch (apply with `patch -p0'): + +*** ../readline-6.3-patched/misc.c 2012-09-01 18:03:11.000000000 -0400 +--- misc.c 2014-06-30 13:41:19.000000000 -0400 +*************** +*** 462,465 **** +--- 462,466 ---- + /* Set up rl_line_buffer and other variables from history entry */ + rl_replace_from_history (entry, 0); /* entry->line is now current */ ++ entry->data = 0; /* entry->data is now current undo list */ + /* Undo all changes to this history entry */ + while (rl_undo_list) +*************** +*** 469,473 **** + FREE (entry->line); + entry->line = savestring (rl_line_buffer); +- entry->data = 0; + } + entry = previous_history (); +--- 470,473 ---- +*** ../readline-6.3/patchlevel 2013-11-15 08:11:11.000000000 -0500 +--- patchlevel 2014-03-21 08:28:40.000000000 -0400 +*************** +*** 1,3 **** + # Do not edit -- exists only for use by patch + +! 7 +--- 1,3 ---- + # Do not edit -- exists only for use by patch + +! 8 diff --git a/base/rpi-userland/10-vchiq.rules b/base/rpi-userland/10-vchiq.rules new file mode 100644 index 0000000..c891542 --- /dev/null +++ b/base/rpi-userland/10-vchiq.rules @@ -0,0 +1 @@ +SUBSYSTEMS=="vchiq",GROUP="video",MODE="0660" diff --git a/base/rpi-userland/rpi-userland.SMBuild b/base/rpi-userland/rpi-userland.SMBuild new file mode 100755 index 0000000..2b7f11c --- /dev/null +++ b/base/rpi-userland/rpi-userland.SMBuild @@ -0,0 +1,46 @@ +APP=rpi-userland +VERSION=20200603 +BUILD=1sml +HOMEPAGE='https://github.com/raspberrypi/userland' +DESC="common raspberry-pi userland utilities" +REQUIRES="musl" + +build() { + compileonlyfor aarch64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # this package does not like execinfo header, and will fail to link against the execinfo + # library, so we temporarily rename the header + [ -e /include/execinfo.h ] && mv /include/execinfo.h /include/execinfo.h.bak + + sed -i -e 's/sudo //' buildme + ./buildme --aarch64 "$PKG" + + # The build script does not exit with a status 0, so we do a couple of file checks ourselves + if ! [ -e $PKG/opt/vc/bin/dtmerge ] ; then + echo "Oops, compilation failed!" + exit 1 + elif ! [ -e $PKG/opt/vc/bin/tvservice ]; then + echo "Oops, compilation failed!" + exit 1 + fi + + install -Dm 644 $SRCDIR/10-vchiq.rules $PKG/lib/udev/rules.d/10-vchiq.rules + install -Dm 755 $SRCDIR/rpi-userland.sh $PKG/etc/profile.d/rpi-userland.sh + + # restore the execinfo header to its original name + [ -e /include/execinfo.h.bak ] && mv /include/execinfo.h.bak /include/execinfo.h + + cp LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +dbfe0e6bc50eeb745e66bbfdb5bc6f4774ed51d99f334a3604f73df997bf1a4be4ee8f3e703022f128640a28fac8b2cf7366ad563e07d2afdef67ea4de747f2c rpi-userland-20200603.tar.lz +" diff --git a/base/rpi-userland/rpi-userland.sh b/base/rpi-userland/rpi-userland.sh new file mode 100644 index 0000000..c9f2ecd --- /dev/null +++ b/base/rpi-userland/rpi-userland.sh @@ -0,0 +1,2 @@ +[ -d /opt/vc/bin ] && PATH=$PATH:/opt/vc/bin +export PATH diff --git a/base/ruby/ruby-rubygems-avoid-platform-specific-gems.patch b/base/ruby/ruby-rubygems-avoid-platform-specific-gems.patch new file mode 100644 index 0000000..74a5365 --- /dev/null +++ b/base/ruby/ruby-rubygems-avoid-platform-specific-gems.patch @@ -0,0 +1,31 @@ +From: Jakub Jirutka +Date: Fri, 19 May 2017 19:56:00 +0200 +Subject: [PATCH] Rubygems: don't install platform-specific gems + +Gems with native extensions typically contain just source code that is +built during installation on user's system. However, Rubygems allows to +publish even platform-specific gems with prebuilt binaries for specific +platform. The problem is that Rubygems uses only short platform +identification like x86_64-linux; it does not identify used libc. +And sadly platform-specific gems for linux are built against glibc, so +they may not work on musl libc. + +This patch is a workaround for the aforesaid problem. It removes local +platform from Rubygems' supported platforms to force it always pick +a platform-agnostic (source) gem. Users can override it using +`--platform` option. + +--- a/lib/rubygems.rb ++++ b/lib/rubygems.rb +@@ -743,7 +743,10 @@ + def self.platforms + @platforms ||= [] + if @platforms.empty? +- @platforms = [Gem::Platform::RUBY, Gem::Platform.local] ++ # XXX: Patched to avoid installing platform-specific gems with binaries ++ # linked against glibc. ++ @platforms = [Gem::Platform::RUBY] ++ #@platforms = [Gem::Platform::RUBY, Gem::Platform.local] + end + @platforms + end diff --git a/base/ruby/ruby-test_insns-lower-recursion-depth.patch b/base/ruby/ruby-test_insns-lower-recursion-depth.patch new file mode 100644 index 0000000..48e88df --- /dev/null +++ b/base/ruby/ruby-test_insns-lower-recursion-depth.patch @@ -0,0 +1,47 @@ +The patched test is a recursion function. We have lower stack size, +so we hit SystemStackError sooner than on other platforms. + + #361 test_insns.rb:389:in `block in ': + # recursive once + def once n + return %r/#{ + if n == 0 + true + else + once(n-1) # here + end + }/ox + end + x = once(128); x = once(7); x = once(16); + x =~ "true" && $~ + #=> "" (expected "true") once + Stderr output is not empty + bootstraptest.tmp.rb:3:in `once': stack level too deep (SystemStackError) + from bootstraptest.tmp.rb:7:in `block in once' + from bootstraptest.tmp.rb:3:in `once' + from bootstraptest.tmp.rb:7:in `block in once' + from bootstraptest.tmp.rb:3:in `once' + from bootstraptest.tmp.rb:7:in `block in once' + from bootstraptest.tmp.rb:3:in `once' + from bootstraptest.tmp.rb:7:in `block in once' + from bootstraptest.tmp.rb:3:in `once' + ... 125 levels... + from bootstraptest.tmp.rb:3:in `once' + from bootstraptest.tmp.rb:7:in `block in once' + from bootstraptest.tmp.rb:3:in `once' + from bootstraptest.tmp.rb:11:in `
' + Test_insns.rb FAIL 1/187 + FAIL 1/1197 tests failed + Make: *** [uncommon.mk:666: yes-btest-ruby] Error 1 + +--- a/bootstraptest/test_insns.rb ++++ b/bootstraptest/test_insns.rb +@@ -248,7 +248,7 @@ + end + }/ox + end +- x = once(128); x = once(7); x = once(16); ++ x = once(32); x = once(7); x = once(16); + x =~ "true" && $~ + }, + [ 'once', <<~'},', ], # { diff --git a/base/ruby/ruby.SMBuild b/base/ruby/ruby.SMBuild new file mode 100755 index 0000000..e6f405d --- /dev/null +++ b/base/ruby/ruby.SMBuild @@ -0,0 +1,53 @@ +APP=ruby +VERSION=2.5.0 +BUILD=1sml +HOMEPAGE='http://www.ruby-lang.org/' +DOWNLOAD='https://cache.ruby-lang.org/pub/ruby/2.5/ruby-2.5.0.tar.gz' +DESC="Interpreted object-oriented scripting language" +REQUIRES="gmp" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Thanks sabotage + patch -p1 < $SRCDIR/ruby-test_insns-lower-recursion-depth.patch + patch -p1 < $SRCDIR/ruby-rubygems-avoid-platform-specific-gems.patch + + unset CFLAGS CXXFLAGS CPPFLAGS + + # Put ruby on a diet + export CPPFLAGS="-D_GNU_SOURCE -fno-omit-frame-pointer -fno-strict-aliasing" + export CFLAGS="-Os -fno-omit-frame-pointer -fno-strict-aliasing" + + export ac_cv_func_isnan=yes + export ac_cv_func_isinf=yes + + stack_protector=no \ + rb_cv_binary_elf=yes \ + ./configure \ + --prefix="" \ + --enable-shared \ + --enable-pthread \ + --without-jemalloc \ + --disable-rpath \ + --with-mantype=man \ + --disable-install-doc + + make + make install DESTDIR=$PKG + + cp BSDL COPYING GPL LEGAL $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fc27f44b2a495db0ade5812f649182b9f7570873d27b9ccfd6e6fc9564b4e32086cc4b09879e6ceda7f604347c7da7c5a337d258a82b13427da1e2894a9fa6db ruby-2.5.0.tar.lz +cfdc5ea3b2e2ea69c51f38e8e2180cb1dc27008ca55cc6301f142ebafdbab31c3379b3b6bba9ff543153876dd98ed2ad194df3255b7ea77a62e931c935f80538 ruby-rubygems-avoid-platform-specific-gems.patch +814fe6359505b70d8ff680adf22f20a74b4dbd3fecc9a63a6c2456ee9824257815929917b6df5394ed069a6869511b8c6dce5b95b4acbbb7867c1f3a975a0150 ruby-test_insns-lower-recursion-depth.patch +" diff --git a/base/rust/0001-Fix-LLVM-build.patch b/base/rust/0001-Fix-LLVM-build.patch new file mode 100644 index 0000000..0da829a --- /dev/null +++ b/base/rust/0001-Fix-LLVM-build.patch @@ -0,0 +1,26 @@ +From 4443eca0d6b3ba599832b2f73a5350fdd0c90d10 Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Fri, 8 Sep 2017 00:04:29 -0500 +Subject: [PATCH 01/15] Fix LLVM build + +--- + src/bootstrap/lib.rs | 3 ++- + 1 file changed, 2 insertions(+), 1 deletion(-) + +diff --git a/src/bootstrap/lib.rs b/src/bootstrap/lib.rs +index a476d25f..c7e63990 100644 +--- a/src/bootstrap/lib.rs ++++ b/src/bootstrap/lib.rs +@@ -768,7 +768,8 @@ impl Build { + .args() + .iter() + .map(|s| s.to_string_lossy().into_owned()) +- .filter(|s| !s.starts_with("-O") && !s.starts_with("/O")) ++ .filter(|s| !s.starts_with("-O") && !s.starts_with("/O") ++ && !s.starts_with("-static")) + .collect::>(); + + // If we're compiling on macOS then we add a few unconditional flags +-- +2.26.2 + diff --git a/base/rust/00016-do-not-copy-libunwind.patch b/base/rust/00016-do-not-copy-libunwind.patch new file mode 100644 index 0000000..73c496a --- /dev/null +++ b/base/rust/00016-do-not-copy-libunwind.patch @@ -0,0 +1,26 @@ +From 227096bde5283269aa1d1002860b6ec54d2cf284 Mon Sep 17 00:00:00 2001 +From: Johannes Brechtmann +Date: Sun, 22 Nov 2020 16:00:50 +0100 +Subject: [PATCH] Revert "Include libunwind in the rust-src component." + +This reverts commit 9f27f3796d3487411ab035803a0757d69040649c. +--- + src/bootstrap/dist.rs | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/src/bootstrap/dist.rs b/src/bootstrap/dist.rs +index b2a590307a2..020cd665a0e 100644 +--- a/src/bootstrap/dist.rs ++++ b/src/bootstrap/dist.rs +@@ -1016,7 +1016,7 @@ impl Step for Src { + copy_src_dirs( + builder, + &builder.src, +- &["library", "src/llvm-project/libunwind"], ++ &["library"], + &[ + // not needed and contains symlinks which rustup currently + // chokes on when unpacking. +-- +2.29.2 + diff --git a/base/rust/0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch b/base/rust/0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch new file mode 100644 index 0000000..f72bd0e --- /dev/null +++ b/base/rust/0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch @@ -0,0 +1,45 @@ +From a78859bb6690e0ad285d1892d7a40796a40ac287 Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Sat, 2 Dec 2017 17:25:44 -0600 +Subject: [PATCH 02/15] Allow rustdoc to work when cross-compiling on musl + +musl can't handle foreign-architecture libraries in LD_LIBRARY_PATH. +--- + src/bootstrap/bin/rustdoc.rs | 7 ++----- + 1 file changed, 2 insertions(+), 5 deletions(-) + +diff --git a/src/bootstrap/bin/rustdoc.rs b/src/bootstrap/bin/rustdoc.rs +index cba17c8e6..45cbdd81b 100644 +--- a/src/bootstrap/bin/rustdoc.rs ++++ b/src/bootstrap/bin/rustdoc.rs +@@ -20,9 +20,6 @@ fn main() { + Err(_) => 0, + }; + +- let mut dylib_path = bootstrap::util::dylib_path(); +- dylib_path.insert(0, PathBuf::from(libdir.clone())); +- + let mut cmd = Command::new(rustdoc); + cmd.args(&args) + .arg("--sysroot") +@@ -35,7 +32,7 @@ fn main() { + .arg("dox") + .arg("--sysroot") + .arg(&sysroot) +- .env(bootstrap::util::dylib_path_var(), env::join_paths(&dylib_path).unwrap()); ++ .env(bootstrap::util::dylib_path_var(), PathBuf::from(libdir.clone())); + + // Force all crates compiled by this compiler to (a) be unstable and (b) + // allow the `rustc_private` feature to link to other unstable crates +@@ -83,7 +80,7 @@ fn main() { + eprintln!( + "rustdoc command: {:?}={:?} {:?}", + bootstrap::util::dylib_path_var(), +- env::join_paths(&dylib_path).unwrap(), ++ PathBuf::from(libdir.clone()), + cmd, + ); + eprintln!("sysroot: {:?}", sysroot); +-- +2.26.2 + diff --git a/base/rust/0003-Require-static-native-libraries-when-linking-static-.patch b/base/rust/0003-Require-static-native-libraries-when-linking-static-.patch new file mode 100644 index 0000000..0fd1ca7 --- /dev/null +++ b/base/rust/0003-Require-static-native-libraries-when-linking-static-.patch @@ -0,0 +1,52 @@ +From baa7ce46f19e3584d70e47c8df28c084e76446da Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Sun, 3 May 2020 17:48:47 +0200 +Subject: [PATCH 03/15] Require static native libraries when linking static + executables + +On ELF targets like Linux, gcc/ld will create a dynamically-linked +executable without warning, even when passed `-static`, when asked to +link to a `.so`. Avoid this confusing and unintended behavior by always +using the static version of libraries when trying to link static +executables. + +Fixes #54243 +--- + src/librustc_codegen_ssa/back/link.rs | 18 ++++++++++++++---- + 1 file changed, 14 insertions(+), 4 deletions(-) + +diff --git a/compiler/rustc_codegen_ssa/src/back/link.rs b/compiler/rustc_codegen_ssa/src/back/link.rs +index 8bc4e6442..52ff7a52e 100644 +--- a/compiler/rustc_codegen_ssa/src/back/link.rs ++++ b/compiler/rustc_codegen_ssa/src/back/link.rs +@@ -2081,8 +2081,7 @@ fn add_upstream_rust_crates<'a, B: ArchiveBuilder<'a>>( + } + } + +-/// Link in all of our upstream crates' native dependencies. Remember that all of these upstream +-/// native dependencies are all non-static dependencies. We've got two cases then: ++/// Link in all of our upstream crates' native dependencies. We have two cases: + /// + /// 1. The upstream crate is an rlib. In this case we *must* link in the native dependency because + /// the rlib is just an archive. +@@ -2015,7 +2013,19 @@ + continue; + } + match lib.kind { +- NativeLibKind::Dylib | NativeLibKind::Unspecified => cmd.link_dylib(name), ++ NativeLibKind::Dylib | NativeLibKind::Unspecified => { ++ // On some targets, like Linux, linking a static executable inhibits using ++ // dylibs at all. Force native libraries to be static, even if for example ++ // an upstream rlib was originally linked against a native shared library. ++ if crate_type == config::CrateType::Executable ++ && sess.crt_static(Some(crate_type)) ++ && !sess.target.options.crt_static_allows_dylibs ++ { ++ cmd.link_staticlib(name) ++ } else { ++ cmd.link_dylib(name) ++ } ++ }, + NativeLibKind::Framework => cmd.link_framework(name), + NativeLibKind::StaticNoBundle => { + // Link "static-nobundle" native libs only if the crate they originate from diff --git a/base/rust/0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch b/base/rust/0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch new file mode 100644 index 0000000..85a8806 --- /dev/null +++ b/base/rust/0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch @@ -0,0 +1,344 @@ +diff --git a/compiler/rustc_target/src/spec/crt_objects.rs b/compiler/rustc_target/src/spec/crt_objects.rs +index 2fc9ab29f..276736159 100644 +--- a/compiler/rustc_target/src/spec/crt_objects.rs ++++ b/compiler/rustc_target/src/spec/crt_objects.rs +@@ -62,28 +62,6 @@ pub(super) fn all(obj: &str) -> CrtObjects { + ]) + } + +-pub(super) fn pre_musl_fallback() -> CrtObjects { +- new(&[ +- (LinkOutputKind::DynamicNoPicExe, &["crt1.o", "crti.o", "crtbegin.o"]), +- (LinkOutputKind::DynamicPicExe, &["Scrt1.o", "crti.o", "crtbeginS.o"]), +- (LinkOutputKind::StaticNoPicExe, &["crt1.o", "crti.o", "crtbegin.o"]), +- (LinkOutputKind::StaticPicExe, &["rcrt1.o", "crti.o", "crtbeginS.o"]), +- (LinkOutputKind::DynamicDylib, &["crti.o", "crtbeginS.o"]), +- (LinkOutputKind::StaticDylib, &["crti.o", "crtbeginS.o"]), +- ]) +-} +- +-pub(super) fn post_musl_fallback() -> CrtObjects { +- new(&[ +- (LinkOutputKind::DynamicNoPicExe, &["crtend.o", "crtn.o"]), +- (LinkOutputKind::DynamicPicExe, &["crtendS.o", "crtn.o"]), +- (LinkOutputKind::StaticNoPicExe, &["crtend.o", "crtn.o"]), +- (LinkOutputKind::StaticPicExe, &["crtendS.o", "crtn.o"]), +- (LinkOutputKind::DynamicDylib, &["crtendS.o", "crtn.o"]), +- (LinkOutputKind::StaticDylib, &["crtendS.o", "crtn.o"]), +- ]) +-} +- + pub(super) fn pre_mingw_fallback() -> CrtObjects { + new(&[ + (LinkOutputKind::DynamicNoPicExe, &["crt2.o", "rsbegin.o"]), +diff --git a/compiler/rustc_target/src/spec/linux_musl_base.rs b/compiler/rustc_target/src/spec/linux_musl_base.rs +index 5038a967d..b3c0e5bc4 100644 +--- a/compiler/rustc_target/src/spec/linux_musl_base.rs ++++ b/compiler/rustc_target/src/spec/linux_musl_base.rs +@@ -1,16 +1,9 @@ +-use crate::spec::crt_objects::{self, CrtObjectsFallback}; + use crate::spec::TargetOptions; + + pub fn opts() -> TargetOptions { + let mut base = super::linux_base::opts(); + + base.env = "musl".to_string(); +- base.pre_link_objects_fallback = crt_objects::pre_musl_fallback(); +- base.post_link_objects_fallback = crt_objects::post_musl_fallback(); +- base.crt_objects_fallback = Some(CrtObjectsFallback::Musl); +- +- // These targets statically link libc by default +- base.crt_static_default = true; + + base + } +diff --git a/config.toml.example b/config.toml.example +index 6e5584797..5be9882a8 100644 +--- a/config.toml.example ++++ b/config.toml.example +@@ -638,15 +638,6 @@ changelog-seen = 2 + # only use static libraries. If unset, the target's default linkage is used. + #crt-static = (bool) + +-# The root location of the musl installation directory. The library directory +-# will also need to contain libunwind.a for an unwinding implementation. Note +-# that this option only makes sense for musl targets that produce statically +-# linked binaries. +-#musl-root = build.musl-root (path) +- +-# The full path to the musl libdir. +-#musl-libdir = musl-root/lib +- + # The root location of the `wasm32-wasi` sysroot. Only used for the + # `wasm32-wasi` target. If you are building wasm32-wasi target, make sure to + # create a `[target.wasm32-wasi]` section and move this field there. +diff --git a/src/bootstrap/cc_detect.rs b/src/bootstrap/cc_detect.rs +index e750c2963..f6ba3032b 100644 +--- a/src/bootstrap/cc_detect.rs ++++ b/src/bootstrap/cc_detect.rs +@@ -98,7 +98,7 @@ pub fn find(build: &mut Build) { + if let Some(cc) = config.and_then(|c| c.cc.as_ref()) { + cfg.compiler(cc); + } else { +- set_compiler(&mut cfg, Language::C, target, config, build); ++ set_compiler(&mut cfg, Language::C, target, config); + } + + let compiler = cfg.get_compiler(); +@@ -126,7 +126,7 @@ pub fn find(build: &mut Build) { + cfg.compiler(cxx); + true + } else if build.hosts.contains(&target) || build.build == target { +- set_compiler(&mut cfg, Language::CPlusPlus, target, config, build); ++ set_compiler(&mut cfg, Language::CPlusPlus, target, config); + true + } else { + // Use an auto-detected compiler (or one configured via `CXX_target_triple` env vars). +@@ -157,7 +157,6 @@ fn set_compiler( + compiler: Language, + target: TargetSelection, + config: Option<&Target>, +- build: &Build, + ) { + match &*target.triple { + // When compiling for android we may have the NDK configured in the +@@ -200,26 +199,6 @@ fn set_compiler( + } + } + +- "mips-unknown-linux-musl" => { +- if cfg.get_compiler().path().to_str() == Some("gcc") { +- cfg.compiler("mips-linux-musl-gcc"); +- } +- } +- "mipsel-unknown-linux-musl" => { +- if cfg.get_compiler().path().to_str() == Some("gcc") { +- cfg.compiler("mipsel-linux-musl-gcc"); +- } +- } +- +- t if t.contains("musl") => { +- if let Some(root) = build.musl_root(target) { +- let guess = root.join("bin/musl-gcc"); +- if guess.exists() { +- cfg.compiler(guess); +- } +- } +- } +- + _ => {} + } + } +diff --git a/src/bootstrap/compile.rs b/src/bootstrap/compile.rs +index ee3527b6b..0a8b78327 100644 +--- a/src/bootstrap/compile.rs ++++ b/src/bootstrap/compile.rs +@@ -179,34 +179,7 @@ fn copy_self_contained_objects( + let mut target_deps = vec![]; + + // Copies the CRT objects. +- // +- // rustc historically provides a more self-contained installation for musl targets +- // not requiring the presence of a native musl toolchain. For example, it can fall back +- // to using gcc from a glibc-targeting toolchain for linking. +- // To do that we have to distribute musl startup objects as a part of Rust toolchain +- // and link with them manually in the self-contained mode. +- if target.contains("musl") { +- let srcdir = builder.musl_libdir(target).unwrap_or_else(|| { +- panic!("Target {:?} does not have a \"musl-libdir\" key", target.triple) +- }); +- for &obj in &["crt1.o", "Scrt1.o", "rcrt1.o", "crti.o", "crtn.o"] { +- copy_and_stamp( +- builder, +- &libdir_self_contained, +- &srcdir, +- obj, +- &mut target_deps, +- DependencyType::TargetSelfContained, +- ); +- } +- let crt_path = builder.ensure(native::CrtBeginEnd { target }); +- for &obj in &["crtbegin.o", "crtbeginS.o", "crtend.o", "crtendS.o"] { +- let src = crt_path.join(obj); +- let target = libdir_self_contained.join(obj); +- builder.copy(&src, &target); +- target_deps.push((target, DependencyType::TargetSelfContained)); +- } +- } else if target.ends_with("-wasi") { ++ if target.ends_with("-wasi") { + let srcdir = builder + .wasi_root(target) + .unwrap_or_else(|| { +@@ -288,15 +261,6 @@ pub fn std_cargo(builder: &Builder<'_>, target: TargetSelection, stage: u32, car + .arg("--manifest-path") + .arg(builder.src.join("library/test/Cargo.toml")); + +- // Help the libc crate compile by assisting it in finding various +- // sysroot native libraries. +- if target.contains("musl") { +- if let Some(p) = builder.musl_libdir(target) { +- let root = format!("native={}", p.to_str().unwrap()); +- cargo.rustflag("-L").rustflag(&root); +- } +- } +- + if target.ends_with("-wasi") { + if let Some(p) = builder.wasi_root(target) { + let root = format!("native={}/lib/wasm32-wasi", p.to_str().unwrap()); +diff --git a/src/bootstrap/config.rs b/src/bootstrap/config.rs +index 483816b98..7517d757c 100644 +--- a/src/bootstrap/config.rs ++++ b/src/bootstrap/config.rs +@@ -165,7 +165,6 @@ pub struct Config { + pub missing_tools: bool, + + // Fallback musl-root for all targets +- pub musl_root: Option, + pub prefix: Option, + pub sysconfdir: Option, + pub datadir: Option, +@@ -291,8 +290,6 @@ pub struct Target { + pub sanitizers: Option, + pub profiler: Option, + pub crt_static: Option, +- pub musl_root: Option, +- pub musl_libdir: Option, + pub wasi_root: Option, + pub qemu_rootfs: Option, + pub no_std: bool, +@@ -481,7 +478,6 @@ struct Rust { + default_linker: Option, + channel: Option, + description: Option, +- musl_root: Option, + rpath: Option, + verbose_tests: Option, + optimize_tests: Option, +@@ -524,8 +520,6 @@ struct TomlTarget { + sanitizers: Option, + profiler: Option, + crt_static: Option, +- musl_root: Option, +- musl_libdir: Option, + wasi_root: Option, + qemu_rootfs: Option, + no_std: Option, +@@ -846,7 +840,6 @@ impl Config { + set(&mut config.llvm_tools_enabled, rust.llvm_tools); + config.rustc_parallel = rust.parallel_compiler.unwrap_or(false); + config.rustc_default_linker = rust.default_linker; +- config.musl_root = rust.musl_root.map(PathBuf::from); + config.save_toolstates = rust.save_toolstates.map(PathBuf::from); + set(&mut config.deny_warnings, flags.deny_warnings.or(rust.deny_warnings)); + set(&mut config.backtrace_on_ice, rust.backtrace_on_ice); +@@ -892,8 +885,6 @@ impl Config { + target.ranlib = cfg.ranlib.map(PathBuf::from); + target.linker = cfg.linker.map(PathBuf::from); + target.crt_static = cfg.crt_static; +- target.musl_root = cfg.musl_root.map(PathBuf::from); +- target.musl_libdir = cfg.musl_libdir.map(PathBuf::from); + target.wasi_root = cfg.wasi_root.map(PathBuf::from); + target.qemu_rootfs = cfg.qemu_rootfs.map(PathBuf::from); + target.sanitizers = cfg.sanitizers; +diff --git a/src/bootstrap/configure.py b/src/bootstrap/configure.py +index 999882a1c..7ccc2b73c 100755 +--- a/src/bootstrap/configure.py ++++ b/src/bootstrap/configure.py +@@ -109,34 +109,6 @@ v("aarch64-linux-android-ndk", "target.aarch64-linux-android.android-ndk", + "aarch64-linux-android NDK standalone path") + v("x86_64-linux-android-ndk", "target.x86_64-linux-android.android-ndk", + "x86_64-linux-android NDK standalone path") +-v("musl-root", "target.x86_64-unknown-linux-musl.musl-root", +- "MUSL root installation directory (deprecated)") +-v("musl-root-x86_64", "target.x86_64-unknown-linux-musl.musl-root", +- "x86_64-unknown-linux-musl install directory") +-v("musl-root-i586", "target.i586-unknown-linux-musl.musl-root", +- "i586-unknown-linux-musl install directory") +-v("musl-root-i686", "target.i686-unknown-linux-musl.musl-root", +- "i686-unknown-linux-musl install directory") +-v("musl-root-arm", "target.arm-unknown-linux-musleabi.musl-root", +- "arm-unknown-linux-musleabi install directory") +-v("musl-root-armhf", "target.arm-unknown-linux-musleabihf.musl-root", +- "arm-unknown-linux-musleabihf install directory") +-v("musl-root-armv5te", "target.armv5te-unknown-linux-musleabi.musl-root", +- "armv5te-unknown-linux-musleabi install directory") +-v("musl-root-armv7", "target.armv7-unknown-linux-musleabi.musl-root", +- "armv7-unknown-linux-musleabi install directory") +-v("musl-root-armv7hf", "target.armv7-unknown-linux-musleabihf.musl-root", +- "armv7-unknown-linux-musleabihf install directory") +-v("musl-root-aarch64", "target.aarch64-unknown-linux-musl.musl-root", +- "aarch64-unknown-linux-musl install directory") +-v("musl-root-mips", "target.mips-unknown-linux-musl.musl-root", +- "mips-unknown-linux-musl install directory") +-v("musl-root-mipsel", "target.mipsel-unknown-linux-musl.musl-root", +- "mipsel-unknown-linux-musl install directory") +-v("musl-root-mips64", "target.mips64-unknown-linux-muslabi64.musl-root", +- "mips64-unknown-linux-muslabi64 install directory") +-v("musl-root-mips64el", "target.mips64el-unknown-linux-muslabi64.musl-root", +- "mips64el-unknown-linux-muslabi64 install directory") + v("qemu-armhf-rootfs", "target.arm-unknown-linux-gnueabihf.qemu-rootfs", + "rootfs in qemu testing, you probably don't want to use this") + v("qemu-aarch64-rootfs", "target.aarch64-unknown-linux-gnu.qemu-rootfs", +diff --git a/src/bootstrap/lib.rs b/src/bootstrap/lib.rs +index 24da44b93..c08bc6d94 100644 +--- a/src/bootstrap/lib.rs ++++ b/src/bootstrap/lib.rs +@@ -927,25 +927,6 @@ impl Build { + } + } + +- /// Returns the "musl root" for this `target`, if defined +- fn musl_root(&self, target: TargetSelection) -> Option<&Path> { +- self.config +- .target_config +- .get(&target) +- .and_then(|t| t.musl_root.as_ref()) +- .or_else(|| self.config.musl_root.as_ref()) +- .map(|p| &**p) +- } +- +- /// Returns the "musl libdir" for this `target`. +- fn musl_libdir(&self, target: TargetSelection) -> Option { +- let t = self.config.target_config.get(&target)?; +- if let libdir @ Some(_) = &t.musl_libdir { +- return libdir.clone(); +- } +- self.musl_root(target).map(|root| root.join("lib")) +- } +- + /// Returns the sysroot for the wasi target, if defined + fn wasi_root(&self, target: TargetSelection) -> Option<&Path> { + self.config.target_config.get(&target).and_then(|t| t.wasi_root.as_ref()).map(|p| &**p) +diff --git a/src/bootstrap/sanity.rs b/src/bootstrap/sanity.rs +index ed0cbdf97..44937aed9 100644 +--- a/src/bootstrap/sanity.rs ++++ b/src/bootstrap/sanity.rs +@@ -182,28 +182,6 @@ pub fn check(build: &mut Build) { + } + } + +- // Make sure musl-root is valid +- if target.contains("musl") { +- // If this is a native target (host is also musl) and no musl-root is given, +- // fall back to the system toolchain in /usr before giving up +- if build.musl_root(*target).is_none() && build.config.build == *target { +- let target = build.config.target_config.entry(*target).or_default(); +- target.musl_root = Some("/usr".into()); +- } +- match build.musl_libdir(*target) { +- Some(libdir) => { +- if fs::metadata(libdir.join("libc.a")).is_err() { +- panic!("couldn't find libc.a in musl libdir: {}", libdir.display()); +- } +- } +- None => panic!( +- "when targeting MUSL either the rust.musl-root \ +- option or the target.$TARGET.musl-root option must \ +- be specified in config.toml" +- ), +- } +- } +- + if target.contains("msvc") { + // There are three builds of cmake on windows: MSVC, MinGW, and + // Cygwin. The Cygwin build does not have generators for Visual diff --git a/base/rust/0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch b/base/rust/0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch new file mode 100644 index 0000000..58ffd07 --- /dev/null +++ b/base/rust/0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch @@ -0,0 +1,63 @@ +Additions for build.rs by q66, necessary for our musl setup. + +From 1eb558f246269606c6d8d73824ef6b44fa10764e Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Sat, 9 Sep 2017 00:14:16 -0500 +Subject: [PATCH 06/16] Prefer libgcc_eh over libunwind for musl + +--- + src/libunwind/lib.rs | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/src/libunwind/lib.rs b/src/libunwind/lib.rs +index 9182e349b19..0377fbb58fc 100644 +--- a/library/unwind/src/lib.rs ++++ b/library/unwind/src/lib.rs +@@ -23,6 +23,6 @@ cfg_if::cfg_if! { + } + + #[cfg(target_env = "musl")] +-#[link(name = "unwind", kind = "static", cfg(target_feature = "crt-static"))] ++#[link(name = "gcc_eh", cfg(target_feature = "crt-static"))] + #[link(name = "gcc_s", cfg(not(target_feature = "crt-static")))] + extern {} +diff --git a/src/libunwind/build.rs b/src/libunwind/build.rs +index f24d957..28828e5 100644 +--- a/library/unwind/build.rs ++++ b/library/unwind/build.rs +@@ -5,17 +5,12 @@ + let target = env::var("TARGET").expect("TARGET was not set"); + + if cfg!(feature = "llvm-libunwind") +- && ((target.contains("linux") && !target.contains("musl")) || target.contains("fuchsia")) ++ && (target.contains("linux") || target.contains("fuchsia")) + { + // Build the unwinding from libunwind C/C++ source code. + llvm_libunwind::compile(); + } else if target.contains("x86_64-fortanix-unknown-sgx") { + llvm_libunwind::compile(); +- } else if target.contains("linux") { +- // linking for Linux is handled in lib.rs +- if target.contains("musl") { +- llvm_libunwind::compile(); +- } + } else if target.contains("freebsd") { + println!("cargo:rustc-link-lib=gcc_s"); + } else if target.contains("rumprun") { +@@ -143,15 +138,6 @@ + cfg.file(root.join("src").join(src)); + } + +- if target_env == "musl" { +- // use the same C compiler command to compile C++ code so we do not need to setup the +- // C++ compiler env variables on the builders +- cfg.cpp(false); +- // linking for musl is handled in lib.rs +- cfg.cargo_metadata(false); +- println!("cargo:rustc-link-search=native={}", env::var("OUT_DIR").unwrap()); +- } +- + cfg.compile("unwind"); + } + } + diff --git a/base/rust/0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch b/base/rust/0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch new file mode 100644 index 0000000..c80fe15 --- /dev/null +++ b/base/rust/0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch @@ -0,0 +1,30 @@ +From e44838dabefa1a62578895b4465717f7be8a7a86 Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Sat, 6 Oct 2018 04:01:48 +0000 +Subject: [PATCH 06/15] test/use-extern-for-plugins: Don't assume multilib + +--- + src/test/run-make-fulldeps/use-extern-for-plugins/Makefile | 7 +------ + 1 file changed, 1 insertion(+), 6 deletions(-) + +diff --git a/src/test/run-make-fulldeps/use-extern-for-plugins/Makefile b/src/test/run-make-fulldeps/use-extern-for-plugins/Makefile +index 838b1a27..94fa9f6d 100644 +--- a/src/test/run-make-fulldeps/use-extern-for-plugins/Makefile ++++ b/src/test/run-make-fulldeps/use-extern-for-plugins/Makefile +@@ -4,12 +4,7 @@ + # ignore-openbsd + # ignore-sunos + +-HOST := $(shell $(RUSTC) -vV | grep 'host:' | sed 's/host: //') +-ifeq ($(findstring i686,$(HOST)),i686) +-TARGET := $(subst i686,x86_64,$(HOST)) +-else +-TARGET := $(subst x86_64,i686,$(HOST)) +-endif ++TARGET := $(shell $(RUSTC) -vV | grep 'host:' | sed 's/host: //') + + all: + $(RUSTC) foo.rs -C extra-filename=-host +-- +2.26.2 + diff --git a/base/rust/0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch b/base/rust/0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch new file mode 100644 index 0000000..612f527 --- /dev/null +++ b/base/rust/0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch @@ -0,0 +1,24 @@ +From cde014a1108b7d1cea85100cad48b12297267405 Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Mon, 17 Sep 2018 01:32:20 +0000 +Subject: [PATCH 07/15] test/sysroot-crates-are-unstable: Fix test when rpath + is disabled + +Without this environment var, the test can't run rustc to find +the sysroot path. +--- + .../run-make-fulldeps/sysroot-crates-are-unstable/Makefile | 4 +++- + 1 file changed, 3 insertions(+), 1 deletion(-) + +diff --git a/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile b/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile +index a35174b3..9e770706 100644 +--- a/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile ++++ b/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile +@@ -1,2 +1,4 @@ ++-include ../tools.mk ++ + all: +- '$(PYTHON)' test.py ++ env '$(HOST_RPATH_ENV)' '$(PYTHON)' test.py +-- +2.26.2 diff --git a/base/rust/0008-Ignore-broken-and-non-applicable-tests.patch b/base/rust/0008-Ignore-broken-and-non-applicable-tests.patch new file mode 100644 index 0000000..aa6e829 --- /dev/null +++ b/base/rust/0008-Ignore-broken-and-non-applicable-tests.patch @@ -0,0 +1,77 @@ +From c63745a2777648d530898bae5af9d25266472b05 Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Sat, 21 Dec 2019 17:00:40 +0100 +Subject: [PATCH 08/15] Ignore broken and non-applicable tests + +c-link-to-rust-va-list-fn: unstable feature, broken on aarch64, #56475 +env-funky-keys: can't handle LD_PRELOAD (e.g. sandbox) +long-linker-command-lines: takes >10 minutes to run (but still passes) +simd-intrinsic-generic-bitmask.rs: broken on BE, #59356 +simd-intrinsic-generic-select.rs: broken on BE, #59356 +sparc-struct-abi: no sparc target +sysroot-crates-are-unstable: can't run rustc without RPATH +--- + src/test/codegen/sparc-struct-abi.rs | 1 + + src/test/run-make-fulldeps/c-link-to-rust-va-list-fn/Makefile | 2 ++ + src/test/run-make-fulldeps/long-linker-command-lines/Makefile | 2 ++ + src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile | 2 ++ + src/test/ui/env-funky-keys.rs | 1 + + src/test/ui/simd/simd-intrinsic-generic-bitmask.rs | 2 ++ + 6 files changed, 10 insertions(+) + +diff --git a/src/test/codegen/sparc-struct-abi.rs b/src/test/codegen/sparc-struct-abi.rs +index 78e5b14a..6f93e932 100644 +--- a/src/test/codegen/sparc-struct-abi.rs ++++ b/src/test/codegen/sparc-struct-abi.rs +@@ -4,6 +4,7 @@ + + // only-sparc64 + // compile-flags: -O --target=sparc64-unknown-linux-gnu --crate-type=rlib ++// ignore-test + #![feature(no_core, lang_items)] + #![no_core] + +diff --git a/src/test/run-make-fulldeps/c-link-to-rust-va-list-fn/Makefile b/src/test/run-make-fulldeps/c-link-to-rust-va-list-fn/Makefile +index f124ca2a..363b18f0 100644 +--- a/src/test/run-make-fulldeps/c-link-to-rust-va-list-fn/Makefile ++++ b/src/test/run-make-fulldeps/c-link-to-rust-va-list-fn/Makefile +@@ -1,3 +1,5 @@ ++# ignore-aarch64 ++ + -include ../tools.mk + + all: +diff --git a/src/test/run-make-fulldeps/long-linker-command-lines/Makefile b/src/test/run-make-fulldeps/long-linker-command-lines/Makefile +index 5876fbc9..5f167ece 100644 +--- a/src/test/run-make-fulldeps/long-linker-command-lines/Makefile ++++ b/src/test/run-make-fulldeps/long-linker-command-lines/Makefile +@@ -1,3 +1,5 @@ ++# ignore-test ++ + -include ../tools.mk + + all: +diff --git a/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile b/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile +index 9e770706..6d92ec5c 100644 +--- a/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile ++++ b/src/test/run-make-fulldeps/sysroot-crates-are-unstable/Makefile +@@ -1,3 +1,5 @@ ++# ignore-test ++ + -include ../tools.mk + + all: +diff --git a/src/test/ui/env-funky-keys.rs b/src/test/ui/env-funky-keys.rs +index c5c824ac..f3fe047a 100644 +--- a/src/test/ui/env-funky-keys.rs ++++ b/src/test/ui/env-funky-keys.rs +@@ -1,6 +1,7 @@ + // run-pass + // Ignore this test on Android, because it segfaults there. + ++// ignore-test + // ignore-android + // ignore-windows + // ignore-cloudabi no execve +2.26.2 + diff --git a/base/rust/0009-Link-stage2-tools-dynamically-to-libstd.patch b/base/rust/0009-Link-stage2-tools-dynamically-to-libstd.patch new file mode 100644 index 0000000..40f896b --- /dev/null +++ b/base/rust/0009-Link-stage2-tools-dynamically-to-libstd.patch @@ -0,0 +1,31 @@ +From f5dad49f112151bb0ee74570e971bd475cbec128 Mon Sep 17 00:00:00 2001 +From: q66 +Date: Sun, 3 May 2020 18:00:09 +0200 +Subject: [PATCH 09/15] Link stage2 tools dynamically to libstd + +Replaces an older patch by Samuel Holland. The RUSTC_NO_PREFER_DYNAMIC +env var was removed and replaced with the following logic in builder.rs. + +The idea for this patch is to link stage2 tools dynamically as these will +be distributed (if built). Intermediate tools from previous stages will +be statically linked for convenience. +--- + src/bootstrap/builder.rs | 2 ++ + 1 file changed, 2 insertions(+) + +diff --git a/src/bootstrap/builder.rs b/src/bootstrap/builder.rs +index eb0199fd..0ec7cbd8 100644 +--- a/src/bootstrap/builder.rs ++++ b/src/bootstrap/builder.rs +@@ -1236,6 +1236,8 @@ impl<'a> Builder<'a> { + // linking all deps statically into the dylib. + if let Mode::Std | Mode::Rustc | Mode::Codegen = mode { + rustflags.arg("-Cprefer-dynamic"); ++ } else if stage >= 2 { ++ rustflags.arg("-Cprefer-dynamic"); + } + + // When building incrementally we default to a lower ThinLTO import limit +-- +2.26.2 + diff --git a/base/rust/0010-Move-debugger-scripts-to-usr-share-rust.patch b/base/rust/0010-Move-debugger-scripts-to-usr-share-rust.patch new file mode 100644 index 0000000..c9f5132 --- /dev/null +++ b/base/rust/0010-Move-debugger-scripts-to-usr-share-rust.patch @@ -0,0 +1,37 @@ +From 9b0c14783127e195d7bd54ca2c0c498a46714964 Mon Sep 17 00:00:00 2001 +From: Samuel Holland +Date: Mon, 17 Sep 2018 02:09:10 +0000 +Subject: [PATCH 10/15] Move debugger scripts to /usr/share/rust + +--- + src/bootstrap/dist.rs | 2 +- + src/etc/rust-gdb | 2 +- + src/etc/rust-lldb | 2 +- + 3 files changed, 3 insertions(+), 3 deletions(-) + +diff --git a/src/bootstrap/dist.rs b/src/bootstrap/dist.rs +index 8215211e..05a173b4 100644 +--- a/src/bootstrap/dist.rs ++++ b/src/bootstrap/dist.rs +@@ -603,7 +603,7 @@ impl Step for DebuggerScripts { + fn run(self, builder: &Builder<'_>) { + let host = self.host; + let sysroot = self.sysroot; +- let dst = sysroot.join("lib/rustlib/etc"); ++ let dst = sysroot.join("share/rust"); + t!(fs::create_dir_all(&dst)); + let cp_debugger_script = |file: &str| { + builder.install(&builder.src.join("src/etc/").join(file), &dst, 0o644); +diff --git a/src/etc/rust-gdb b/src/etc/rust-gdb +index 23ba93da..dc51b16c 100755 +--- a/src/etc/rust-gdb ++++ b/src/etc/rust-gdb +@@ -12,7 +12,7 @@ + + # Find out where the pretty printer Python module is + RUSTC_SYSROOT="$("$RUSTC" --print=sysroot)" +-GDB_PYTHON_MODULE_DIRECTORY="$RUSTC_SYSROOT/lib/rustlib/etc" ++GDB_PYTHON_MODULE_DIRECTORY="$RUSTC_SYSROOT/share/rust" + + # Run GDB with the additional arguments that load the pretty printers + # Set the environment variable `RUST_GDB` to overwrite the call to a diff --git a/base/rust/0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch b/base/rust/0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch new file mode 100644 index 0000000..3378ee3 --- /dev/null +++ b/base/rust/0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch @@ -0,0 +1,49 @@ +From e363a0e0ff7ffc8bd83f72ec1a20d289996b6370 Mon Sep 17 00:00:00 2001 +From: q66 +Date: Sun, 3 May 2020 18:02:03 +0200 +Subject: [PATCH 12/15] Fix dynamic linkage of musl libc for the libc crate + +--- + vendor/libc/src/lib.rs | 1 + + vendor/libc/src/unix/mod.rs | 6 +++--- + 2 files changed, 4 insertions(+), 3 deletions(-) + +diff --git a/vendor/libc/src/lib.rs b/vendor/libc/src/lib.rs +index 6bb71c552..22060a8d7 100644 +--- a/vendor/libc/src/lib.rs ++++ b/vendor/libc/src/lib.rs +@@ -24,10 +24,7 @@ + #![deny(missing_copy_implementations, safe_packed_borrows)] + #![cfg_attr(not(feature = "rustc-dep-of-std"), no_std)] + #![cfg_attr(feature = "rustc-dep-of-std", no_core)] +-#![cfg_attr( +- any(feature = "rustc-dep-of-std", target_os = "redox"), +- feature(static_nobundle) +-)] ++#![cfg_attr(feature = "rustc-dep-of-std", feature(static_nobundle))] + #![cfg_attr(libc_const_extern_fn, feature(const_extern_fn))] + + #[macro_use] +diff --git a/vendor/libc/src/unix/mod.rs b/vendor/libc/src/unix/mod.rs +index 238da24b..ffb05ee7 100644 +--- a/vendor/libc/src/unix/mod.rs ++++ b/vendor/libc/src/unix/mod.rs +@@ -299,11 +299,11 @@ cfg_if! { + // cargo build, don't pull in anything extra as the libstd dep + // already pulls in all libs. + } else if #[cfg(target_env = "musl")] { ++ #[link(name = "c")] ++ extern {} + #[cfg_attr(feature = "rustc-dep-of-std", +- link(name = "c", kind = "static", ++ link(name = "gcc", kind = "static-nobundle", + cfg(target_feature = "crt-static")))] +- #[cfg_attr(feature = "rustc-dep-of-std", +- link(name = "c", cfg(not(target_feature = "crt-static"))))] + extern {} + } else if #[cfg(target_os = "emscripten")] { + #[link(name = "c")] +index 0b1496af..7f7e85a7 100644 +-- +2.26.2 + diff --git a/base/rust/0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch b/base/rust/0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch new file mode 100644 index 0000000..692eb71 --- /dev/null +++ b/base/rust/0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch @@ -0,0 +1,31 @@ +From 07efbc3bdd67de4e13b0f3f4df853a9de0800ec3 Mon Sep 17 00:00:00 2001 +From: q66 +Date: Sun, 3 May 2020 18:05:22 +0200 +Subject: [PATCH 14/15] Void: fix linkage against host/target LLVM in cross + setups + +--- + src/librustc_llvm/build.rs | 6 ++++-- + 1 file changed, 4 insertions(+), 2 deletions(-) + +diff --git a/compiler/rustc_llvm/build.rs b/compiler/rustc_llvm/build.rs +index 621363bed..01322e1d2 100644 +--- a/compiler/rustc_llvm/build.rs ++++ b/compiler/rustc_llvm/build.rs +@@ -242,9 +242,11 @@ fn main() { + for lib in output(&mut cmd).split_whitespace() { + if is_crossed { + if let Some(stripped) = lib.strip_prefix("-LIBPATH:") { +- println!("cargo:rustc-link-search=native={}", stripped.replace(&host, &target)); ++ println!("cargo:rustc-link-search=native={}{}", ++ env::var("XBPS_CROSS_BASE").unwrap(), stripped); + } else if let Some(stripped) = lib.strip_prefix("-L") { +- println!("cargo:rustc-link-search=native={}", stripped.replace(&host, &target)); ++ println!("cargo:rustc-link-search=native={}{}", ++ env::var("XBPS_CROSS_BASE").unwrap(), stripped); + } + } else if let Some(stripped) = lib.strip_prefix("-LIBPATH:") { + println!("cargo:rustc-link-search=native={}", stripped); +-- +2.26.2 + diff --git a/base/rust/config.toml b/base/rust/config.toml new file mode 100644 index 0000000..8678838 --- /dev/null +++ b/base/rust/config.toml @@ -0,0 +1,43 @@ +[llvm] +ccache = "/bin/ccache" +link-shared = true + +[build] +build = "ARCH-unknown-linux-musl" +host = ["ARCH-unknown-linux-musl"] +target = ["ARCH-unknown-linux-musl"] +tools = ["analysis", "cargo", "src"] +submodules = false +extended = true +vendor = true +rustc = "/bin/rustc" +cargo = "/bin/cargo" +locked-deps = true +docs = false + +[install] +prefix = "/" +libdir = "lib" +mandir = "share" + +[rust] +codegen-units = 0 +channel = "stable" +rpath = false +codegen-tests = false +ignore-git = true +debug-assertions = false +backtrace = true +incremental = false +parallel-compiler = false +dist-src = false +jemalloc = false +llvm-libunwind = "no" + +[target.ARCH-unknown-linux-musl] +llvm-config = "/bin/llvm-config" +crt-static = false +cc = "gcc" +cxx = "c++" +ar = "ar" +linker = "gcc" diff --git a/base/rust/disable_miri.patch b/base/rust/disable_miri.patch new file mode 100644 index 0000000..73eec74 --- /dev/null +++ b/base/rust/disable_miri.patch @@ -0,0 +1,164 @@ +From 601d24810e89efd42f7cd69d4a7ccecd4e35364d Mon Sep 17 00:00:00 2001 +From: Eric Huss +Date: Tue, 22 Jun 2021 22:10:25 -0700 +Subject: [PATCH 1/2] Don't dist miri on stable or beta. + +--- + src/bootstrap/dist.rs | 3 +++ + 1 file changed, 3 insertions(+) + +diff --git a/src/bootstrap/dist.rs b/src/bootstrap/dist.rs +index 71ed0af4a7c04..e0c33f7357741 100644 +--- a/src/bootstrap/dist.rs ++++ b/src/bootstrap/dist.rs +@@ -1171,6 +1171,9 @@ impl Step for Miri { + } + + fn run(self, builder: &Builder<'_>) -> Option { ++ if !builder.build.unstable_features() { ++ return None; ++ } + let compiler = self.compiler; + let target = self.target; + assert!(builder.config.extended); + +From 6aa79a34d87252deaae11e75663e5740a22f14ea Mon Sep 17 00:00:00 2001 +From: Eric Huss +Date: Wed, 23 Jun 2021 07:03:42 -0700 +Subject: [PATCH 2/2] Comment and include rust-analyzer. + +--- + src/bootstrap/dist.rs | 9 +++++++++ + 1 file changed, 9 insertions(+) + +diff --git a/src/bootstrap/dist.rs b/src/bootstrap/dist.rs +index e0c33f7357741..19895baf08f16 100644 +--- a/src/bootstrap/dist.rs ++++ b/src/bootstrap/dist.rs +@@ -1072,6 +1072,12 @@ impl Step for RustAnalyzer { + } + + fn run(self, builder: &Builder<'_>) -> Option { ++ // This prevents rust-analyzer from being built for "dist" or "install" ++ // on the stable/beta channels. It is a nightly-only tool and should ++ // not be included. ++ if !builder.build.unstable_features() { ++ return None; ++ } + let compiler = self.compiler; + let target = self.target; + assert!(builder.config.extended); +@@ -1171,6 +1177,9 @@ impl Step for Miri { + } + + fn run(self, builder: &Builder<'_>) -> Option { ++ // This prevents miri from being built for "dist" or "install" ++ // on the stable/beta channels. It is a nightly-only tool and should ++ // not be included. + if !builder.build.unstable_features() { + return None; + } +From f698cacc33f0c9148bb3bb7501087b0d37e837ec Mon Sep 17 00:00:00 2001 +From: Eric Huss +Date: Fri, 9 Jul 2021 10:01:23 -0700 +Subject: [PATCH 1/3] Fix rust-analyzer install when not available. + +--- + src/bootstrap/install.rs | 13 +++++++++---- + 1 file changed, 9 insertions(+), 4 deletions(-) + +diff --git a/src/bootstrap/install.rs b/src/bootstrap/install.rs +index 13ee909afd5e4..6f3054538a898 100644 +--- a/src/bootstrap/install.rs ++++ b/src/bootstrap/install.rs +@@ -165,10 +165,15 @@ install!((self, builder, _config), + } + }; + RustAnalyzer, "rust-analyzer", Self::should_build(_config), only_hosts: true, { +- let tarball = builder +- .ensure(dist::RustAnalyzer { compiler: self.compiler, target: self.target }) +- .expect("missing rust-analyzer"); +- install_sh(builder, "rust-analyzer", self.compiler.stage, Some(self.target), &tarball); ++ if let Some(tarball) = ++ builder.ensure(dist::RustAnalyzer { compiler: self.compiler, target: self.target }) ++ { ++ install_sh(builder, "rust-analyzer", self.compiler.stage, Some(self.target), &tarball); ++ } else { ++ builder.info( ++ &format!("skipping Install rust-analyzer stage{} ({})", self.compiler.stage, self.target), ++ ); ++ } + }; + Clippy, "clippy", Self::should_build(_config), only_hosts: true, { + let tarball = builder.ensure(dist::Clippy { compiler: self.compiler, target: self.target }); + +From 60ff731110815349dbc052c36e9cc50b9f12f32a Mon Sep 17 00:00:00 2001 +From: Eric Huss +Date: Sun, 11 Jul 2021 09:01:31 -0700 +Subject: [PATCH 2/3] Add comments why install steps should never fail. + +--- + src/bootstrap/install.rs | 6 ++++++ + 1 file changed, 6 insertions(+) + +diff --git a/src/bootstrap/install.rs b/src/bootstrap/install.rs +index 6f3054538a898..2ac9d3dda206f 100644 +--- a/src/bootstrap/install.rs ++++ b/src/bootstrap/install.rs +@@ -139,11 +139,15 @@ macro_rules! install { + + install!((self, builder, _config), + Docs, "src/doc", _config.docs, only_hosts: false, { ++ // `expect` should be safe, only None when config.docs is false, ++ // which is guarded in `should_run` + let tarball = builder.ensure(dist::Docs { host: self.target }).expect("missing docs"); + install_sh(builder, "docs", self.compiler.stage, Some(self.target), &tarball); + }; + Std, "library/std", true, only_hosts: false, { + for target in &builder.targets { ++ // `expect` should be safe, only None when host != build, but this ++ // only runs when host == build + let tarball = builder.ensure(dist::Std { + compiler: self.compiler, + target: *target +@@ -217,6 +221,8 @@ install!((self, builder, _config), + } + }; + Analysis, "analysis", Self::should_build(_config), only_hosts: false, { ++ // `expect` should be safe, only None with host != build, but this ++ // only uses the `build` compiler + let tarball = builder.ensure(dist::Analysis { + // Find the actual compiler (handling the full bootstrap option) which + // produced the save-analysis data because that data isn't copied + +From 166c147c2727cd6d6ad4d39c40c51273b8a63c96 Mon Sep 17 00:00:00 2001 +From: Eric Huss +Date: Mon, 12 Jul 2021 13:29:47 -0700 +Subject: [PATCH 3/3] Provide a better error when `x.py install src/doc` + doesn't work. + +--- + src/bootstrap/install.rs | 10 ++++++---- + 1 file changed, 6 insertions(+), 4 deletions(-) + +diff --git a/src/bootstrap/install.rs b/src/bootstrap/install.rs +index 2ac9d3dda206f..8a1b6df0dafe3 100644 +--- a/src/bootstrap/install.rs ++++ b/src/bootstrap/install.rs +@@ -139,10 +139,12 @@ macro_rules! install { + + install!((self, builder, _config), + Docs, "src/doc", _config.docs, only_hosts: false, { +- // `expect` should be safe, only None when config.docs is false, +- // which is guarded in `should_run` +- let tarball = builder.ensure(dist::Docs { host: self.target }).expect("missing docs"); +- install_sh(builder, "docs", self.compiler.stage, Some(self.target), &tarball); ++ if let Some(tarball) = builder.ensure(dist::Docs { host: self.target }) { ++ install_sh(builder, "docs", self.compiler.stage, Some(self.target), &tarball); ++ } else { ++ panic!("docs are not available to install, \ ++ check that `build.docs` is true in `config.toml`"); ++ } + }; + Std, "library/std", true, only_hosts: false, { + for target in &builder.targets { diff --git a/base/rust/rust.SMBuild b/base/rust/rust.SMBuild new file mode 100755 index 0000000..eb70670 --- /dev/null +++ b/base/rust/rust.SMBuild @@ -0,0 +1,100 @@ +APP=rust +VERSION=1.53.0 +BUILD=1sml +HOMEPAGE='https://rust-lang.org' +DOWNLOAD='https://static.rust-lang.org/dist/rustc-1.53.0-src.tar.xz' +DESC="a safe, concurrent, practical language" +REQUIRES="gcc-libs bash llvm clang gdb" + +build() { + mkandenterbuilddir + rm -rf rustc-$VERSION-src + + tar xf $SRCDIR/rustc-$VERSION-src.tar.?z* + cd rustc-$VERSION-src + fixbuilddirpermissions + + # Create a temporary directory that will house a prebuilt architecture-specific rust toolchain provided by rust developers for bootstrapping + mkdir temp-toolchain + cd temp-toolchain + + # Extract the toolchain into it + tar xf $SRCDIR/$APP-$VERSION-$ARCH-unknown-linux-musl.tar.gz + cd $APP-$VERSION-$ARCH-unknown-linux-musl + + # Now install the toolchain + ./install.sh --prefix="/" || true + + # Go back to the temporary build directory + cd ../../ + + patch -p1 < $SRCDIR/0001-Fix-LLVM-build.patch + patch -p1 < $SRCDIR/00016-do-not-copy-libunwind.patch + patch -p1 < $SRCDIR/0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch + patch -p1 < $SRCDIR/0003-Require-static-native-libraries-when-linking-static-.patch + patch -p1 < $SRCDIR/0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch + patch -p1 < $SRCDIR/0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch + patch -p1 < $SRCDIR/0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch + patch -p1 < $SRCDIR/0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch + patch -p1 < $SRCDIR/0008-Ignore-broken-and-non-applicable-tests.patch + patch -p1 < $SRCDIR/0009-Link-stage2-tools-dynamically-to-libstd.patch + patch -p1 < $SRCDIR/0010-Move-debugger-scripts-to-usr-share-rust.patch + patch -p1 < $SRCDIR/0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch + patch -p1 < $SRCDIR/0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch + patch -p1 < $SRCDIR/disable_miri.patch + + clear_vendor_checksums() { + sed -i 's/\("files":{\)[^}]*/\1/' vendor/$1/.cargo-checksum.json + } + + export RUST_BACKTRACE=1 + export PKG_CONFIG_ALLOW_CROSS=1 + sed -i /LD_LIBRARY_PATH/d src/bootstrap/bootstrap.py + clear_vendor_checksums libc + + # We use our system's LLVM. Discard rust's own bundled LLVM directory + rm -Rf src/llvm-project/ + + cp $SRCDIR/config.toml . + + if [ "$ARCH" = "aarch64" ] ; then + sed -i 's@ARCH@aarch64@g' config.toml + elif [ "$ARCH" = "x86_64" ] ; then + sed -i 's@ARCH@x86_64@g' config.toml + fi + + # Go easy on the pi + unset MAKEFLAGS + python3 ./x.py dist -v -j2 + DESTDIR="$PKG" python3 ./x.py install + + cp LICENSE* COPYRIGHT $PKGDOCS/ + + find $PKG/lib -name "*.so" -exec chmod 755 "{}" \+ + + # Remove the temporary toolchain + cd temp-toolchain/$APP-$VERSION-$ARCH-unknown-linux-musl + ./install.sh --uninstall --prefix="/" + + mkfinalpkg +} + +SHA512SUMS=" +ddd5fbd62242e7541245c0abd0ba76ac0197e8182ea425610da3e8be8700d6639763c4dadc699bfa29e1441e659de82fdfbe6e235efce29b9e28d0c8e9ad44f3 rust-1.53.0-aarch64-unknown-linux-musl.tar.gz +97d1c3c43f02a378ae2fba0148b6ec37c4c69756bb518c3e1624fa6c5dee9383925312d69ff4bde45a2c3a04a3ef6bb10ed0d2939a932b12cfbb507550cc3c4f rust-1.53.0-x86_64-unknown-linux-musl.tar.gz +e279491a6252b2a62a70c0352e4dd9603ffbb629231315572ef2eac4581ebad394076ff05da47ff71f488f1b84a783ac95b41665b3c85b524ecc8a4eccd7c4b0 rustc-1.53.0-src.tar.xz +3a2961af1f90f19f06cd079c051566952f7e347bd29dcb5f2b6ffe85d59e00f9de1eda4a5ddad7a5abd0ef85d5f8e7c5b2a143923cb286bff9369291e562856e 0001-Fix-LLVM-build.patch +165316d689dc664101a720af4baf5772159dc87459f3937488ceb1cfd4063b76bcb190046fe3927489b399f9815d24007845f4270d58fb06e4500d05cc39fa50 00016-do-not-copy-libunwind.patch +966a3f898d516b9e327a6caa2dcecb189f1af2ad2b606a4254452b7525b992d160fbb5acc5e6747dd8f572d6f055dded4d07b0e5680184af3f58c86ef434e6c7 0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch +4fc9d7ced03f0effb3bcce385fa1663d37ae9f271b79c8270fa442a6e9a2de3694246f3a95eaa0fb5177558c0f312e8df38ce514b69c889642b6895197e0b15f 0003-Require-static-native-libraries-when-linking-static-.patch +a9fd9de296f3c4a54534901d3b9912b1cafd0787ad2358e872a030393c7f9f6e57adf39f6a16699621389056edd8118dbb4e8071bce97906b1311b39ccec4098 0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch +fa67468667903290b8e6d16d6777f80aac49d987e8e60c43f8302da77fa1e0e35c4d363d216867c79989c8c35d552c0d5dd6bce69734ed0ce75b4b67ca924953 0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch +5798114c8eb1b914b7affe9925c477f5dcd135925ed925580b69811ca3249c40ca73731425b5e15322879817ad5cb17e19dc78748e993a6c56fa5570a44ce228 0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch +7a559ce8f92f015cc5173fdf378e7e3b52052b7a0ea2604e851121bcdab098220c6cdba59980a087560865b339e761afa0570fefb63b0def5e45f512bb0d1a9e 0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch +1bd86522b04d95baa42aff5656cc12642f4772de021aa6b13fc809cca998ec2ac78b075f66c57c0a565804a14ad6f99f34fd9b3470198970c57b13b61e6bbcad 0008-Ignore-broken-and-non-applicable-tests.patch +ab7cea491237894bfa77e2a74ca27a3ff20c38c6428e853fa384e5ba511afe496f7ec3210048f26b393224c47414440c5e7beea0e480a471128b301515750196 0009-Link-stage2-tools-dynamically-to-libstd.patch +5ed3c48782f52e30180b0a012686a5dbea18bf69e053eefd4211fb077b2e5696b1e7031f6b37659cbdf78e9fa902abe36aeb384a3ff88f8ab2ba5ada7b32a3f9 0010-Move-debugger-scripts-to-usr-share-rust.patch +63701e7d8c5606abe94cba6d157a60682b67f6eb585f16dd543061229e5cfff777a675d984541398a4c0bf4d8f7a873428b9849ebcaa9acdc685c269b40c6a57 0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch +9d772f7d109becbae2fa007e350a4357b70afc13a6a2d9b64885cb0970742785cd4e770b28cdaa6a4314a7db0d44a91f0a95334c46b51591c89ad17cdc3e020b 0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch +70b12454888b80487b5819e03800c86ad978099f0b607e60b8e129f2388780068b11e79a0382a58af7a03f7c2e8bf28e1682edc1d55118ad4be8e72ddf011a59 disable_miri.patch +" diff --git a/base/rust/rust.SMBuild.incomplete b/base/rust/rust.SMBuild.incomplete new file mode 100755 index 0000000..aff0982 --- /dev/null +++ b/base/rust/rust.SMBuild.incomplete @@ -0,0 +1,100 @@ +APP=rust +VERSION=1.53.0 +BUILD=1sml +HOMEPAGE='https://rust-lang.org' +DOWNLOAD='https://static.rust-lang.org/dist/rustc-1.53.0-src.tar.xz' +DESC="a safe, concurrent, practical language" +REQUIRES="gcc-libs bash llvm clang gdb" + +build() { + mkandenterbuilddir + #rm -rf rustc-$VERSION-src + + #tar xf $SRCDIR/rustc-$VERSION-src.tar.?z* + cd rustc-$VERSION-src + #fixbuilddirpermissions + + # Create a temporary directory that will house a prebuilt architecture-specific rust toolchain provided by rust developers for bootstrapping + #mkdir temp-toolchain + #cd temp-toolchain + + # Extract the toolchain into it + #tar xf $SRCDIR/$APP-$VERSION-$ARCH-unknown-linux-musl.tar.gz + #cd $APP-$VERSION-$ARCH-unknown-linux-musl + + # Now install the toolchain + #./install.sh --prefix="/" || true + + # Go back to the temporary build directory + #cd ../../ + + #patch -p1 < $SRCDIR/0001-Fix-LLVM-build.patch + #patch -p1 < $SRCDIR/00016-do-not-copy-libunwind.patch + #patch -p1 < $SRCDIR/0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch + #patch -p1 < $SRCDIR/0003-Require-static-native-libraries-when-linking-static-.patch + #patch -p1 < $SRCDIR/0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch + #patch -p1 < $SRCDIR/0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch + #patch -p1 < $SRCDIR/0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch + #patch -p1 < $SRCDIR/0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch + #patch -p1 < $SRCDIR/0008-Ignore-broken-and-non-applicable-tests.patch + #patch -p1 < $SRCDIR/0009-Link-stage2-tools-dynamically-to-libstd.patch + #patch -p1 < $SRCDIR/0010-Move-debugger-scripts-to-usr-share-rust.patch + #patch -p1 < $SRCDIR/0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch + #patch -p1 < $SRCDIR/0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch + #patch -p1 < $SRCDIR/disable_miri.patch + + clear_vendor_checksums() { + sed -i 's/\("files":{\)[^}]*/\1/' vendor/$1/.cargo-checksum.json + } + + export RUST_BACKTRACE=1 + export PKG_CONFIG_ALLOW_CROSS=1 + #sed -i /LD_LIBRARY_PATH/d src/bootstrap/bootstrap.py + #clear_vendor_checksums libc + + # We use our system's LLVM. Discard rust's own bundled LLVM directory + #rm -Rf src/llvm-project/ + + #cp $SRCDIR/config.toml . + + #if [ "$ARCH" = "aarch64" ] ; then + # sed -i 's@ARCH@aarch64@g' config.toml + #elif [ "$ARCH" = "x86_64" ] ; then + # sed -i 's@ARCH@x86_64@g' config.toml + #fi + + # Go easy on the pi + unset MAKEFLAGS + python3 ./x.py dist -v -j2 + DESTDIR="$PKG" python3 ./x.py install + + cp LICENSE* COPYRIGHT $PKGDOCS/ + + find $PKG/lib -name "*.so" -exec chmod 755 "{}" \+ + + # Remove the temporary toolchain + cd temp-toolchain/$APP-$VERSION-$ARCH-unknown-linux-musl + ./install.sh --uninstall --prefix="/" + + mkfinalpkg +} + +SHA512SUMS=" +ddd5fbd62242e7541245c0abd0ba76ac0197e8182ea425610da3e8be8700d6639763c4dadc699bfa29e1441e659de82fdfbe6e235efce29b9e28d0c8e9ad44f3 rust-1.53.0-aarch64-unknown-linux-musl.tar.gz +97d1c3c43f02a378ae2fba0148b6ec37c4c69756bb518c3e1624fa6c5dee9383925312d69ff4bde45a2c3a04a3ef6bb10ed0d2939a932b12cfbb507550cc3c4f rust-1.53.0-x86_64-unknown-linux-musl.tar.gz +e279491a6252b2a62a70c0352e4dd9603ffbb629231315572ef2eac4581ebad394076ff05da47ff71f488f1b84a783ac95b41665b3c85b524ecc8a4eccd7c4b0 rustc-1.53.0-src.tar.xz +3a2961af1f90f19f06cd079c051566952f7e347bd29dcb5f2b6ffe85d59e00f9de1eda4a5ddad7a5abd0ef85d5f8e7c5b2a143923cb286bff9369291e562856e 0001-Fix-LLVM-build.patch +165316d689dc664101a720af4baf5772159dc87459f3937488ceb1cfd4063b76bcb190046fe3927489b399f9815d24007845f4270d58fb06e4500d05cc39fa50 00016-do-not-copy-libunwind.patch +966a3f898d516b9e327a6caa2dcecb189f1af2ad2b606a4254452b7525b992d160fbb5acc5e6747dd8f572d6f055dded4d07b0e5680184af3f58c86ef434e6c7 0002-Allow-rustdoc-to-work-when-cross-compiling-on-musl.patch +4fc9d7ced03f0effb3bcce385fa1663d37ae9f271b79c8270fa442a6e9a2de3694246f3a95eaa0fb5177558c0f312e8df38ce514b69c889642b6895197e0b15f 0003-Require-static-native-libraries-when-linking-static-.patch +a9fd9de296f3c4a54534901d3b9912b1cafd0787ad2358e872a030393c7f9f6e57adf39f6a16699621389056edd8118dbb4e8071bce97906b1311b39ccec4098 0004-Remove-nostdlib-and-musl_root-from-musl-targets.patch +fa67468667903290b8e6d16d6777f80aac49d987e8e60c43f8302da77fa1e0e35c4d363d216867c79989c8c35d552c0d5dd6bce69734ed0ce75b4b67ca924953 0005-Prefer-libgcc_eh-over-libunwind-on-musl.patch +5798114c8eb1b914b7affe9925c477f5dcd135925ed925580b69811ca3249c40ca73731425b5e15322879817ad5cb17e19dc78748e993a6c56fa5570a44ce228 0006-test-use-extern-for-plugins-Don-t-assume-multilib.patch +7a559ce8f92f015cc5173fdf378e7e3b52052b7a0ea2604e851121bcdab098220c6cdba59980a087560865b339e761afa0570fefb63b0def5e45f512bb0d1a9e 0007-test-sysroot-crates-are-unstable-Fix-test-when-rpath.patch +1bd86522b04d95baa42aff5656cc12642f4772de021aa6b13fc809cca998ec2ac78b075f66c57c0a565804a14ad6f99f34fd9b3470198970c57b13b61e6bbcad 0008-Ignore-broken-and-non-applicable-tests.patch +ab7cea491237894bfa77e2a74ca27a3ff20c38c6428e853fa384e5ba511afe496f7ec3210048f26b393224c47414440c5e7beea0e480a471128b301515750196 0009-Link-stage2-tools-dynamically-to-libstd.patch +5ed3c48782f52e30180b0a012686a5dbea18bf69e053eefd4211fb077b2e5696b1e7031f6b37659cbdf78e9fa902abe36aeb384a3ff88f8ab2ba5ada7b32a3f9 0010-Move-debugger-scripts-to-usr-share-rust.patch +63701e7d8c5606abe94cba6d157a60682b67f6eb585f16dd543061229e5cfff777a675d984541398a4c0bf4d8f7a873428b9849ebcaa9acdc685c269b40c6a57 0012-Fix-dynamic-linkage-of-musl-libc-for-the-libc-crate.patch +9d772f7d109becbae2fa007e350a4357b70afc13a6a2d9b64885cb0970742785cd4e770b28cdaa6a4314a7db0d44a91f0a95334c46b51591c89ad17cdc3e020b 0014-Void-fix-linkage-against-host-target-LLVM-in-cross-s.patch +70b12454888b80487b5819e03800c86ad978099f0b607e60b8e129f2388780068b11e79a0382a58af7a03f7c2e8bf28e1682edc1d55118ad4be8e72ddf011a59 disable_miri.patch +" diff --git a/base/sbc/sbc.SMBuild b/base/sbc/sbc.SMBuild new file mode 100755 index 0000000..3ba3c85 --- /dev/null +++ b/base/sbc/sbc.SMBuild @@ -0,0 +1,32 @@ +APP=sbc +VERSION=1.4 +BUILD=1sml +HOMEPAGE='https://www.kernel.org/pub/linux/bluetooth' +DOWNLOAD='https://www.kernel.org/pub/linux/bluetooth/sbc-1.4.tar.xz' +DESC="Bluetooth audio library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --disable-tester + + make + make install DESTDIR=$PKG + + cp COPYING* ChangeLog $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +eb31d73cccfff76a74befc44f7c5ea7a40b4dc22787f4d1ce10a787ee480ebafda4235c8abb5ccefda6804e47d0cc414a6ccd4f3acf6abb00109d3db7cfaa9a5 sbc-1.4.tar.lz +" diff --git a/base/sccache/sccache.SMBuild b/base/sccache/sccache.SMBuild new file mode 100755 index 0000000..37bf7c3 --- /dev/null +++ b/base/sccache/sccache.SMBuild @@ -0,0 +1,29 @@ +APP=sccache +VERSION=0.2.15 +BUILD=1sml +HOMEPAGE='https://github.com/mozilla/sccache' +DESC="compile caching tool like ccache which can also cache rust objects" +REQUIRES="rust" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + cargo build \ + --release \ + --manifest-path Cargo.toml \ + --features native-zlib + + install -Dm 755 target/release/$APP "$PKG/bin/$APP" + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +82f09b15bcac300c22b4bab8b6d665ef5824af82d3e0fa198395fb7825c31da1eeb7ada1f39b0438efaf5760652f8977e50d1ca8f18770fe714c46f39840e67c sccache-0.2.15.tar.gz +" diff --git a/base/scons/scons.SMBuild b/base/scons/scons.SMBuild new file mode 100755 index 0000000..cc22974 --- /dev/null +++ b/base/scons/scons.SMBuild @@ -0,0 +1,31 @@ +APP=scons +VERSION=3.1.2 +BUILD=1sml +HOMEPAGE='http://www.scons.org/' +DOWNLOAD='https://sourceforge.net/projects/scons/files/scons/2.4.1/scons-2.4.1.tar.gz' +DESC="A software construction tool based on python" +REQUIRES="python3" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + python3 setup.py build + python3 setup.py install --prefix="" --root=$PKG + + mkdir -p $PKG/share/man + mv $PKG/man/man1 $PKG/share/man/ + rm -rf $PKG/man + + cp LICENSE.txt $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +bfc0d58d33408a03eb37c1eff166af8139078026e6b43d6274afceac889d0a6743e359e89ad9a30be5ca43aeed26fba92fa4732854750b7d53091ef3e99b3d33 scons-3.1.2.tar.gz +" diff --git a/base/sed/sed.SMBuild b/base/sed/sed.SMBuild new file mode 100755 index 0000000..bbc7715 --- /dev/null +++ b/base/sed/sed.SMBuild @@ -0,0 +1,31 @@ +APP=sed +VERSION=4.2.2 +BUILD=1sml +HOMEPAGE='https://www.gnu.org/software/sed/' +DOWNLOAD='https://ftp.gnu.org/gnu/sed/sed-4.2.2.tar.bz2' +DESC="GNU stream editor" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + LDFLAGS="-static" \ + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp ABOUT-NLS AUTHORS BUGS COPYING* NEWS THANKS $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +ac24e705bbe630c012c3fa6b57869a6cb288dcc545f320da657b01417ad82226e21ce7b15ad919fc11c4b0fb13f124f2f6a7eb8a4cef045bda85e1fd141d4413 sed-4.2.2.tar.lz +" diff --git a/base/signify/sha2.h.patch b/base/signify/sha2.h.patch new file mode 100644 index 0000000..c5c2b2b --- /dev/null +++ b/base/signify/sha2.h.patch @@ -0,0 +1,11 @@ +--- a/sha2.h 2019-11-19 18:14:53.014674974 +0530 ++++ b/sha2.h 2019-11-19 18:15:07.824476042 +0530 +@@ -36,7 +36,7 @@ + + #ifndef _SHA2_H + #define _SHA2_H +- ++#include + + /*** SHA-256/384/512 Various Length Definitions ***********************/ + #define SHA224_BLOCK_LENGTH 64 diff --git a/base/signify/signify.SMBuild b/base/signify/signify.SMBuild new file mode 100755 index 0000000..5a5ca8f --- /dev/null +++ b/base/signify/signify.SMBuild @@ -0,0 +1,45 @@ +APP=signify +VERSION=30 +BUILD=1sml +LIBBSDVERSION=0.10.0 +HOMEPAGE='https://github.com/aperezdc/signify' +DOWNLOAD='https://github.com/aperezdc/signify/releases/download/v30/signify-30.tar.xz' +DESC="Tools to cryptographically sign and verify files from OpenBSD folks" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # We don't need a system-wide libbsd install because it would then get sucked + # in by xorg and qt5-based applications. We'll keep it contained to the + # signify source directory by modifying the pkgconfig path and CFLAGS and LDFLAGS. + + mkdir libbsd && cd libbsd + tar xf "$SRCDIR"/libbsd-$LIBBSDVERSION.tar.?z + cd libbsd-$LIBBSDVERSION + ./configure --prefix="$PWD"/../ + make && make install + cd .. + + LIBBSDPATH="$PWD" + cd .. + + PKG_CONFIG_PATH="$PKG_CONFIG_PATH:$LIBBSDPATH/lib/pkgconfig" + patch -p1 < $SRCDIR/sha2.h.patch + make CC="$CC -static" \ + CFLAGS="-I$LIBBSDPATH/include" LDFLAGS="-L$LIBBSDPATH/lib" + make install PREFIX="" DESTDIR=$PKG + + mkfinalpkg +} + +SHA512SUMS=" +b75529785b16c93d31401187f8a58258fbebe565dac071c8311775c913af989f62cd29d5ce2651af3ea6221cffd31cf04826577d3e546ab9ca14340f297777b9 libbsd-0.10.0.tar.xz +4a1ebcdbf7aa74865b97cadbf5380460702306b6d0a77306e6c943bb0c3419ca929ecd3455522da4448d780a56c8eddeb26fb4d7fb006fc3bf23f69693c39e87 signify-30.tar.gz +15d8eaa27c6e46862d8957341501c9f0dab254ed9652aca130c47b7478c025796d90b7ded10a74b69020c8da550b167a65b471b1c01d207abe0d281a785e6ffe sha2.h.patch +" diff --git a/base/slapt-get/example.slapt-getrc b/base/slapt-get/example.slapt-getrc new file mode 100644 index 0000000..a1b47ee --- /dev/null +++ b/base/slapt-get/example.slapt-getrc @@ -0,0 +1,18 @@ +# working directory, local storage/cache +WORKINGDIR=/var/cache/slapt-get + +# exclude package names and expressions +EXCLUDE=^kernel-.*,.*-[0-9]+dl$ +# Architecture specific excludes might include: x86_64, i[3456]86, arm, aarch64 +# To exclude pre and beta packages, add this as an exclude: +# [0-9\_\.\-]{1}pre[0-9\-\.\-]{1} + +# Packages on a CD/DVD. +# SOURCE=file:///mnt/cdrom/:OFFICIAL + +# Home made packages. +# SOURCE=file:///var/www/packages/:CUSTOM + +# SMLinux Official Mirror that has PACKAGES.TXT +# SOURCE=https://slackware.uk/smlinux/smlinux/packages/aarch64/:OFFICIAL +# SOURCE=https://slackware.uk/smlinux/smlinux/packages/x86_64/:OFFICIAL diff --git a/base/slapt-get/slapt-get.SMBuild b/base/slapt-get/slapt-get.SMBuild new file mode 100755 index 0000000..b0b72d0 --- /dev/null +++ b/base/slapt-get/slapt-get.SMBuild @@ -0,0 +1,33 @@ +APP=slapt-get +VERSION=0.11.1 +BUILD=1sml +HOMEPAGE='https://github.com/jaos/slapt-get' +DESC="an apt-like front-end to Slackware's pkgtools" +REQUIRES="curl libassuan" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + install -Dm 644 src/slapt.h $PKG/include/slapt.h + install -Dm 755 src/libslapt.so.0.11.1 $PKG/lib/libslapt.so.0.11.1 + (cd $PKG/lib ; ln -s libslapt.so.0.11.1 libslapt.so) + install -Dm 755 slapt-get $PKG/bin/slapt-get + install -Dm 644 doc/libslapt.3 $PKG/share/man/man3/libslapt.3 + install -Dm 644 doc/slapt-get.8 $PKG/share/man/man8/slapt-get.8 + install -Dm 644 $SRCDIR/example.slapt-getrc $PKG/etc/slapt-get/slapt-getrc + mkdir -p $PKG/var/cache/slapt-get + + cp TODO COPYING README FAQ $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +3a9bf702fabfe9a8a9e50ad24d8ebae8dddb73cfe1dd7823effcc3e391cb783456510b109ce870e141e45b0e7f640a6d56de2cf6cf791901d97e85361edb3aac slapt-get-0.11.1.tar.gz +" diff --git a/base/smartmontools/rc.smartd b/base/smartmontools/rc.smartd new file mode 100644 index 0000000..67d327f --- /dev/null +++ b/base/smartmontools/rc.smartd @@ -0,0 +1,88 @@ +#! /bin/sh + +# smartmontools init file for smartd +# Copyright (C) 2002-8 Bruce Allen +# $Id: smartd.initd.in 4120 2015-08-27 16:12:21Z samm2 $ + +# description: Self Monitoring and Reporting Technology (SMART) Daemon +# processname: smartd +# Description: Start S.M.A.R.T. disk and tape monitor. + +# This program is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by the Free +# Software Foundation; either version 2, or (at your option) any later +# version. +# You should have received a copy of the GNU General Public License (for +# example COPYING); if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +# This code was originally developed as a Senior Thesis by Michael Cornwell +# at the Concurrent Systems Laboratory (now part of the Storage Systems +# Research Center), Jack Baskin School of Engineering, University of +# California, Santa Cruz. http://ssrc.soe.ucsc.edu/. + +# Modified for use in SMLinux + +# Uncomment the line below to pass options to smartd on startup. +# Note that distribution specific configuration files like +# /etc/{default,sysconfig}/smartmontools might override these +#smartd_opts="--interval=1800" + +SMARTD_BIN=/bin/smartd + +[ -r /etc/sysconfig/smartmontools ] && . /etc/sysconfig/smartmontools + +RETVAL=0 +case "$1" in +start) + echo -n "Starting smartd: " + $SMARTD_BIN $smartd_opts + RETVAL=$? + echo + ;; +stop) + echo -n "Shutting down smartd: " + killall $SMARTD_BIN + RETVAL=$? + echo + ;; +restart) + $0 stop + sleep 1 + $0 start + RETVAL=$? + ;; +try-restart) + if pidof $SMARTD_BIN >/dev/null; then + $0 restart + RETVAL=$? + fi + ;; +force-reload) + $0 reload || $0 restart + RETVAL=$? + ;; +reload) + echo -n "Reloading smartd configuration: " + killall -s HUP $SMARTD_BIN + RETVAL=$? + echo + ;; +report) + echo -n "Checking SMART devices now: " + killall -s USR1 $SMARTD_BIN + RETVAL=$? + echo + ;; +status) + if pidof $SMARTD_BIN >/dev/null; then + echo "$SMARTD_BIN is running." + else + echo "$SMARTD_BIN is not running." + RETVAL=1 + fi + ;; +*) + echo "Usage: $0 {start|stop|restart|try-restart|force-reload|reload|report|status}" + RETVAL=1 + esac + exit $RETVAL diff --git a/base/smartmontools/smartmontools.SMBuild b/base/smartmontools/smartmontools.SMBuild new file mode 100755 index 0000000..5543b99 --- /dev/null +++ b/base/smartmontools/smartmontools.SMBuild @@ -0,0 +1,35 @@ +APP=smartmontools +VERSION=6.5 +BUILD=1sml +HOMEPAGE="http://smartmontools.sourceforge.net" +DOWNLOAD="https://sourceforge.net/projects/smartmontools/files/smartmontools/6.5/smartmontools-6.5.tar.gz" +DESC="monitoring utilities for hard drives using SMART protocol" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin + + make + make install DESTDIR=$PKG + + cp COPYING README $PKGDOCS/ + head -n 1000 ChangeLog > $PKGDOCS/CHANGELOG + + install -Dm 755 $SRCDIR/rc.smartd $PKG/etc/rc.d/rc.smartd + + mkfinalpkg +} + +SHA512SUMS=" +3ae0cf5eb6afb0a7630496575709fb8ad41b7692f1b2a544ba4a539b6d01e01a1a62b1b73132e4b3d2981f1b8b717c9cbd5037a86a1aae1031640d5cf096417c smartmontools-6.5.tar.lz +" diff --git a/base/soxr/soxr.SMBuild b/base/soxr/soxr.SMBuild new file mode 100755 index 0000000..9a87e8a --- /dev/null +++ b/base/soxr/soxr.SMBuild @@ -0,0 +1,38 @@ +APP=soxr +VERSION=0.1.3 +BUILD=1sml +HOMEPAGE="https://github.com/chirlu/soxr" +DOWNLOAD="https://github.com/chirlu/soxr/archive/refs/tags/0.1.3.tar.gz" +DESC="audio library that outputs fast and high quality results for resampling ratio" +REQUIRES="gcc-libs" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION-Source + + tar xf $SRCDIR/$APP-$VERSION-Source.tar.?z* + cd $APP-$VERSION-Source + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DCMAKE_BUILD_TYPE=Release \ + -DCMAKE_INSTALL_PREFIX="" \ + -DBUILD_EXAMPLES='OFF' \ + -DBUILD_SHARED_LIBS='ON' \ + -DWITH_AVFFT='ON' \ + -DWITH_LSR_BINDINGS='ON' \ + -DWITH_OPENMP='ON' \ + -DWITH_PFFFT='ON' + + make + make install DESTDIR=$PKG + + cp ../COPYING* ../LICENCE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +afd8e9f2a9be8ead553640c713bfa6daaf88ee3c393d1cf30a4c20ed09b92e5c80869abd152370075d30c7f38c5cdeab322c758c43f1f19ffdd78a58e3e0fa6a soxr-0.1.3-Source.tar.lz +" diff --git a/base/speexdsp/speexdsp.SMBuild b/base/speexdsp/speexdsp.SMBuild new file mode 100755 index 0000000..74ecea5 --- /dev/null +++ b/base/speexdsp/speexdsp.SMBuild @@ -0,0 +1,31 @@ +APP=speexdsp +VERSION=1.2.0 +BUILD=1sml +HOMEPAGE="http://www.speex.org/" +DESC="patent-free open-source DSP library" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING ChangeLog $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c2270fd9d2c7567f55c5bfa1ac6ea6d45a454f0bc7aaa79989b7bec2960a67eea475bdc03d7d37a54459506c73fbf1471abfe702862135e0ce056185e7e3a4d9 speexdsp-1.2.0.tar.lz +" diff --git a/base/sqlite/sqlite.SMBuild b/base/sqlite/sqlite.SMBuild new file mode 100755 index 0000000..1b15707 --- /dev/null +++ b/base/sqlite/sqlite.SMBuild @@ -0,0 +1,32 @@ +APP=sqlite +VERSION=3320100 +BUILD=1sml +HOMEPAGE="https://www.sqlite.org/" +DOWNLOAD="https://www.sqlite.org/2020/sqlite-autoconf-3320100.tar.gz" +DESC="simple, self contained database engine" +REQUIRES="readline zlib" + +build() { + mkandenterbuilddir + rm -rf "$APP-autoconf-$VERSION" + + tar xf $SRCDIR/$APP-autoconf-$VERSION.tar.?z* + cd "$APP-autoconf-$VERSION" + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-tcl \ + --disable-static + + make -j1 + make install DESTDIR=$PKG + + cp tea/license.terms $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +12b463c0749403b22c160ebbea2e41434968167b9e0f95d1772b2043d791130c7a73726f8be68f8a1760e0c94b8f5b0ca6666b9de90e9ad7ae4446c33c7c4776 sqlite-autoconf-3320100.tar.lz +" diff --git a/base/ssb.base.SMBuild b/base/ssb.base.SMBuild new file mode 100755 index 0000000..d282621 --- /dev/null +++ b/base/ssb.base.SMBuild @@ -0,0 +1,267 @@ +#!/bin/bash +# Version: 1.7 GSB Section SMBuild - Do not remove this line! +# Copyright (c) 2007, 2008: +# Darren 'Tadgy' Austin , Coventry, UK. +# Licenced under the terms of the GNU General Public Licence version 3. +# +# Modified and trimmed extensively for use with SMLinux + +# Prevent users from directly executing this section autobuild file. The whole build +# process has to be initiated from the main autobuild file. +if [ -z "$SM_AUTOBUILD" ] ; then + echo "Please invoke the main ssb.SMBuild file rather than this section build file because" + echo "it has the required functions that are exported to this section build file during" + echo "the build process" + exit 1 +fi + +. ${BUILDVARS:-/etc/buildvars.conf} + +if [ -n "$SM_AUTOBUILDTEMP" ] ; then + SM_AUTOBUILDTEMP="$(echo $SM_AUTOBUILDTEMP)" + export SM_AUTOBUILDTEMP +fi + +SM_COLOURS=0 +export SM_COLOURS + +# Make sure we are in the right directory (you can never trust users..) +cd $( cd ${BASH_SOURCE%/*} ; pwd ) + +# Section name. +# This should not need to be changed unless the auto detection fails. +SECTION="$( basename $( pwd ) )" +export SECTION + +if [ ! -f .buildlist."$SECTION" ]; then + echo "" + echo "**********************************************************************" + echo "The buildlist either doesn't exist, or is of a different architecture." + echo "** .buildlist.$SECTION is needed **" + echo "Exiting!" + echo "**********************************************************************" + exit 1 +fi + +# Packages to build. +# The package list is read in from .buildlist in the current directory, with +# any comments and blank lines removed. +PACKAGES="$( egrep -v "^#|^$" .buildlist."$SECTION" | cut -d'#' -f1 )" + +function list_packages() { + local PACKAGE + echo "The following packages are built in this section, listed in processing order:" + + ( for PACKAGE in $PACKAGES + do + echo -n "$PACKAGE, " + done ) | sed -e 's/, $//' | fmt -w 74 | sed -e 's/^/ /g' +} + +function find_package_files() { + # $1 = Directory to look for files in [required] + # $2 = Package name or regex to match. An empty string matches all. + # $3 = Package version or regex to match. An empty string matches all. + # $4 = Package architecture or regex to match. An empty string matches all. + # $5 = Package build tag or regex to match. An empty string matches all. + # $6 = File extension or regex to match. An empty string means no extension. + # Note: Remember to escape any regex characters used in fixed strings. + + [ -z "$1" ] || [ ! -d "$1" ] && return 1 + find $1 -maxdepth 1 -mindepth 1 2>/dev/null | \ + egrep "^.*/(${2:-.*})(-${3:-[^-]*})(-${4:-[^-]*})(-${5:-[^-.]*})($6)$" 2>/dev/null + return $? +} + +# Environment. +PACKAGESDIR=${PACKAGESDIR:-/$ARCH} +export PACKAGESDIR + +# Option defaults. +NOPATCHESDIR=0 +NOINSTALL=0 + +# This check compares a list of source directories with the list of the +# packages in the build list and warns of any missing package names +# in either of the two. + +DIRTEMPFILE=$(mktemp $SM_PARENTTMP/DIRECTORYNAMES."$SECTION".XXXXXX) +DIRFILETEMPPATH="$DIRTEMPFILE" +DIRLIST=$(find . -type d -maxdepth 1 -mindepth 1 | sed 's@./@@' | sort > $DIRFILETEMPPATH) + +PACKTEMPFILE=$(mktemp $SM_PARENTTMP/BUILDFILENAMES."$SECTION".XXXXXX) +PACKFILETEMPPATH="$PACKTEMPFILE" +sort .buildlist.$SECTION > $PACKFILETEMPPATH + +DIRECTORYCOUNT="$( wc -l < $DIRTEMPFILE )" +BUILDLISTCOUNT="$( wc -l < $PACKTEMPFILE )" + +# Get number of total packages +TOTALPKGNUMBER="$(wc -l < .buildlist.$SECTION)" +export TOTALPKGNUMBER + +if diff -u "$DIRFILETEMPPATH" "$PACKFILETEMPPATH" > /dev/null 2>&1 ; then + DIFFSTATUS="0" +else + DIFFSTATUS="1" +fi + +if [ "$DIFFSTATUS" != "0" ]; then + echo "*********************************************************************" + echo "** Warning: In section '"$SECTION"', the number of packages in the" + echo "** hidden file '.buildlist."$SECTION"' is different to the number of" + echo "** package directories. Some packages may not have been added to" + echo "** this file/section directory. They are listed below:" + echo "" + + diff -u "$DIRFILETEMPPATH" "$PACKFILETEMPPATH" || true + echo "" + diff -u "$PACKFILETEMPPATH" "$DIRFILETEMPPATH" || true + + echo "" + echo "** Building anyways :-) " + echo "*********************************************************************" + sleep 2 + +fi +rm -f $PACKFILETEMPPATH $DIRFILETEMPPATH + +# Parse command line arguments. +while [ $# -gt 0 ]; do + if [ "$1" = "-help" ] || [ "$1" = "--help" ]; then + usage + exit 0 + elif [ "$1" = "-list" ] || [ "$1" = "--list" ]; then + list_packages + exit 0 + shift + else + echo "${0##*/}: Unknown option: $1" + echo "Try: $0 --help" + exit 1 + fi +done + +# Temporary space, package and log file storage. +mkdir -p $PKGDEST $LOGSDIR/$SECTION + + echo "*********************************************************************" + echo "** Building section '$SECTION'..." + echo "*********************************************************************" + +# Process packages. +( for PACKAGE in $PACKAGES + do + # Build defaults. + SKIP_BUILD=0 + SUBDIR=$PACKAGESDIR/$SECTION + + echo "*********************************************************************" + echo "*** Processing package '$PACKAGE'..." + echo "*********************************************************************" + + # Sanity checks. + [ ! -e "$PACKAGE/$PACKAGE.SMBuild" ] && { + echo "*********************************************************************" + echo "*** Error: '$PACKAGE.SMBuild' not found." + echo "*********************************************************************" + exit 1 + } + [ ! -x "$PACKAGE/$PACKAGE.SMBuild" ] && { + echo "*********************************************************************" + echo "*** Error: '$PACKAGE.SMBuild' is not executable." + echo "*********************************************************************" + exit 1 + } + + # Get package version and build numbers from the package SMBuild. + declare PACKAGE_$( egrep -m 1 "^VERSION=.*" $PACKAGE/$PACKAGE.SMBuild ) + declare PACKAGE_$( egrep -m 1 "^BUILD=.*" $PACKAGE/$PACKAGE.SMBuild ) + + # Check that we got a version and build. + [ -z "$PACKAGE_VERSION" ] || [ -z "$PACKAGE_BUILD" ] && { + echo "*********************************************************************" + echo "*** Error: failed to get VERSION or BUILD from '$PACKAGE.SMBuild'" + echo "*********************************************************************" + exit 1 + } + + # Check if the package should be rebuilt, and where it should be put. + # The assumption is to always rebuild and put packages in the main + # directory, unless modified by the checks below. + if find_package_files "$PKGDEST/$SUBDIR" "${PACKAGE//+/\+}" \ + "" "" "" "\.$PKGEXT" >/dev/null + then + if find_package_files "$PKGDEST/$SUBDIR" "${PACKAGE//+/\+}" \ + "${PACKAGE_VERSION//-/_}" "" "$PACKAGE_BUILD" "\.$PKGEXT" >/dev/null + then + # Package with same version/build was found in the main directory. + SKIP_BUILD=1 + fi + fi + + # Build package if required. + if [ "$SKIP_BUILD" = "0" ]; then + echo "*********************************************************************" + echo "*** Building package '$PACKAGE'..." + echo "*********************************************************************" + # Get the current package number from the build list + CURRENTPKGNUMBER="$(grep -wn "$PACKAGE" .buildlist.$SECTION | cut -d: -f 1)" + export CURRENTPKGNUMBER + mkdir -p $PKGDEST/$SUBDIR + ( cd $PACKAGE && export PKGDEST=$PKGDEST/$SUBDIR && + bldpkg 2>&1 ) | \ + tee $LOGSDIR/$SECTION/$PACKAGE-$SECTION-$HOSTTYPE.log.txt + # Unset $CURRENTPKGNUMBER. We don't want issues when a new one comes in + ERR=${PIPESTATUS[0]} + if [ "$ERR" != "0" ] ; then + unset CURRENTPKGNUMBER + echo "*** Error: '$PACKAGE' build failed." + exit $ERR + else + unset CURRENTPKGNUMBER + VERSION="$(cat $SM_PARENTTMP/$PACKAGE.VERSION)" + BUILD="$(cat $SM_PARENTTMP/$PACKAGE.BUILD)" + mv $LOGSDIR/$SECTION/$PACKAGE-$SECTION-$HOSTTYPE.log.txt \ + $LOGSDIR/$SECTION/$PACKAGE-$VERSION-$BUILD-$SECTION-$HOSTTYPE.log.txt + rm -f $SM_PARENTTMP/$PACKAGE.{APP,VERSION,BUILD} + fi + else + echo "*********************************************************************" + echo "*** Skipping build of '$PACKAGE' - package up to date." + echo "*********************************************************************" + + fi + + if [ "$NOINSTALL" = "0" ]; then + echo + echo "*********************************************************************" + echo "*** Installing '$PACKAGE'..." + echo "*********************************************************************" + upgradepkg --install-new $( find_package_files "$PKGDEST/$SUBDIR" \ + "${PACKAGE//+/\+}" "${PACKAGE_VERSION//-/_}" "" "$PACKAGE_BUILD" "\.$PKGEXT" ) || { + echo + echo "*********************************************************************" + echo "*** Error: failed to install '$PACKAGE'." + echo "*********************************************************************" + exit 1 + } + else + echo + echo "*********************************************************************" + echo "*** Warning: not installing '$PACKAGE'." + echo "*********************************************************************" + fi + done + + echo "*********************************************************************" + echo "** Finished building section '$SECTION'." + echo "** SMLinux packages are in '$PKGDEST/$ARCH/$SECTION'." + echo "** Section build logs are in '$LOGSDIR/$SECTION'." + echo "*********************************************************************" + echo "** Section build time was $( runtime $SECONDS )" + echo "*********************************************************************" +) 2>&1 | tee $LOGSDIR/$SECTION-$ARCH.log.txt + +# Return the exit status from the sub-shell, not the tee command. +exit ${PIPESTATUS[0]} diff --git a/base/strace/strace.SMBuild b/base/strace/strace.SMBuild new file mode 100755 index 0000000..6af17fc --- /dev/null +++ b/base/strace/strace.SMBuild @@ -0,0 +1,34 @@ +APP=strace +VERSION=5.7 +BUILD=1sml +HOMEPAGE="https://strace.io/" +DOWNLOAD="https://strace.io/files/5.7/strace-5.7.tar.xz" +DESC="linux system call tracing utility" +REQUIRES="perl" +SM_NOAUTOCONFSITE=1 + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="$CFLAGS -Dsigcontext_struct=sigcontext" \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --enable-mpers=no + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7e6a8f50792cdaa11aedcc8972a3f0143900fc0de0c8852e6796a884aada43fe11480b31cad9a27caee354d697746ff1f1b8e511855f01e0164ed745a044d0d7 strace-5.7.tar.lz +" diff --git a/base/sudo/020-no-owner-change.patch b/base/sudo/020-no-owner-change.patch new file mode 100644 index 0000000..ec14548 --- /dev/null +++ b/base/sudo/020-no-owner-change.patch @@ -0,0 +1,11 @@ +--- a/Makefile.in ++++ b/Makefile.in +@@ -64,7 +64,7 @@ SHELL = @SHELL@ + SED = @SED@ + + INSTALL = $(SHELL) $(top_srcdir)/install-sh -c +-INSTALL_OWNER = -o $(install_uid) -g $(install_gid) ++INSTALL_OWNER = + + ECHO_N = @ECHO_N@ + ECHO_C = @ECHO_C@ diff --git a/base/sudo/sudo.SMBuild b/base/sudo/sudo.SMBuild new file mode 100755 index 0000000..dc11c83 --- /dev/null +++ b/base/sudo/sudo.SMBuild @@ -0,0 +1,40 @@ +APP=sudo +VERSION=1.9.0 +BUILD=1sml +HOMEPAGE="https://www.sudo.ws/" +DOWNLOAD="https://www.sudo.ws/dist/sudo-1.9.0.tar.gz" +DESC="give limited root privileges to certain users" +REQUIRES="zlib" +SM_NOAUTOCONFSITE=1 + + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin \ + --libexecdir=/lib \ + --with-env-editor \ + --disable-pam-session \ + --without-pam \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp doc/LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +9142a86662151b9b598dfe7379990226f8b735343ac93341f6c152eb210dbc82d744041b86f231618cb2166924d4aace76391a186ad632041093b3809651e4dc sudo-1.9.0.tar.lz +5b8a3b5762b622019f6d8fe54a0e9cc1371055ea9f19e1a07ec783f569fbbbdb13bd2348ef501ce34a361511ca5917ae51c21293d3aafbf0b6f39d126bb9daa0 020-no-owner-change.patch +" diff --git a/base/swig/swig.SMBuild b/base/swig/swig.SMBuild new file mode 100755 index 0000000..3c1ca46 --- /dev/null +++ b/base/swig/swig.SMBuild @@ -0,0 +1,31 @@ +APP=swig +VERSION=4.0.2 +BUILD=1sml +HOMEPAGE="http://www.swig.org/" +DOWNLOAD="http://prdownloads.sourceforge.net/swig/swig-4.0.2.tar.gz" +DESC="Simplified Wrapper and Interface Generator" +REQUIRES="gcc-libs pcre" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYRIGHT LICENSE* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +afd6792d6b10b7bae6559b9070563aad957b5780017d7bfae49b5b0dd2c6f9981995bdc409dcd8ae6d245615a0af9abc286feba47af36c6d77bbc586bcc93c3a swig-4.0.2.tar.lz +" diff --git a/base/sysfsutils/sysfsutils.SMBuild b/base/sysfsutils/sysfsutils.SMBuild new file mode 100755 index 0000000..eef49eb --- /dev/null +++ b/base/sysfsutils/sysfsutils.SMBuild @@ -0,0 +1,33 @@ +APP=sysfsutils +VERSION=2.1.0 +BUILD=1sml +HOMEPAGE="http://linux-diag.sourceforge.net/Sysfsutils.html" +DOWNLOAD="https://sourceforge.net/projects/linux-diag/files/sysfsutils/2.1.0/sysfsutils-2.1.0.tar.gz" +DESC="Utilities for the sysfs filesystem" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --mandir=/share/man \ + --disable-static \ + $BUILDDIST + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +0e9566d46ce04bfc854030107e70cfd99e1b596c0a35b20b134b4df318e0df5b5ac89635dace4e90a59158d2383d12aa298adac119d074febfc35d99eecd17f5 sysfsutils-2.1.0.tar.bz2 +" diff --git a/base/sysklogd/doinst.sh b/base/sysklogd/doinst.sh new file mode 100644 index 0000000..79c37a1 --- /dev/null +++ b/base/sysklogd/doinst.sh @@ -0,0 +1,29 @@ +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} +config etc/logrotate.d/syslog.new +config etc/syslog.conf.new +config var/log/cron.new +config var/log/debug.new +config var/log/maillog.new +config var/log/messages.new +config var/log/secure.new +config var/log/spooler.new +config var/log/syslog.new + +# Remove any leftover empty files: +rm -f var/log/cron.new +rm -f var/log/debug.new +rm -f var/log/maillog.new +rm -f var/log/messages.new +rm -f var/log/secure.new +rm -f var/log/spooler.new +rm -f var/log/syslog.new diff --git a/base/sysklogd/fix-includes.patch b/base/sysklogd/fix-includes.patch new file mode 100644 index 0000000..d15baf5 --- /dev/null +++ b/base/sysklogd/fix-includes.patch @@ -0,0 +1,122 @@ +--- sysklogd-1.5.orig/klogd.c ++++ sysklogd-1.5/klogd.c +@@ -260,11 +260,8 @@ + #include + #include + #include +-#include ++#include + #include +-#if !defined(__GLIBC__) +-#include +-#endif /* __GLIBC__ */ + #include + #include + #include +@@ -279,13 +276,8 @@ + + #define __LIBRARY__ + #include +-#if !defined(__GLIBC__) +-# define __NR_ksyslog __NR_syslog +-_syscall3(int,ksyslog,int, type, char *, buf, int, len); +-#else + #include + #define ksyslog klogctl +-#endif + + #define LOG_BUFFER_SIZE 4096 + #define LOG_LINE_LENGTH 1000 +--- sysklogd-1.5.orig/ksym_mod.c ++++ sysklogd-1.5/ksym_mod.c +@@ -113,12 +113,9 @@ + #include + #include + #include +-#include ++#include + #include + #include "module.h" +-#if !defined(__GLIBC__) +-#include +-#endif /* __GLIBC__ */ + #include + #include + #include +--- sysklogd-1.5.orig/pidfile.c ++++ sysklogd-1.5/pidfile.c +@@ -25,6 +25,7 @@ + */ + + #include ++#include + #include + #include + #include +--- sysklogd-1.5.orig/syslog.c ++++ sysklogd-1.5/syslog.c +@@ -55,7 +55,6 @@ + #include + #include + #include +-#include + #include + #if 0 + #include "syslog.h" +@@ -64,6 +63,8 @@ + + #include + #include ++#include ++#include + #include + #include + #include +--- sysklogd-1.5.orig/syslogd.c ++++ sysklogd-1.5/syslogd.c +@@ -519,9 +519,9 @@ + #include + + #define SYSLOG_NAMES ++#include + #include + #include +-#include + #include + #include + #include +@@ -823,9 +823,7 @@ + void init(); + void cfline(char *line, register struct filed *f); + int decode(char *name, struct code *codetab); +-#if defined(__GLIBC__) + #define dprintf mydprintf +-#endif /* __GLIBC__ */ + static void dprintf(char *, ...); + static void allocate_log(void); + void sighup_handler(); +@@ -860,15 +858,9 @@ + register char *p; + #ifndef TESTING + ssize_t msglen; +-#endif +-#if !defined(__GLIBC__) +- int len, num_fds; +-#else /* __GLIBC__ */ +-#ifndef TESTING + socklen_t len; + #endif + int num_fds; +-#endif /* __GLIBC__ */ + /* + * It took me quite some time to figure out how this is + * supposed to work so I guess I should better write it down. +@@ -2126,7 +2118,7 @@ + (void) signal(SIGCHLD, reapchild); /* reset signal handler -ASP */ + wait ((int *)0); + #else +- union wait status; ++ int status; + + while (wait3(&status, WNOHANG, (struct rusage *) NULL) > 0) + ; diff --git a/base/sysklogd/klogd.finish b/base/sysklogd/klogd.finish new file mode 100644 index 0000000..53cdb8e --- /dev/null +++ b/base/sysklogd/klogd.finish @@ -0,0 +1,2 @@ +#!/bin/sh +exec killall klogd 2> /dev/null diff --git a/base/sysklogd/klogd.run b/base/sysklogd/klogd.run new file mode 100644 index 0000000..ebe25b8 --- /dev/null +++ b/base/sysklogd/klogd.run @@ -0,0 +1,5 @@ +#!/bin/sh +# start klogd +# -c 3 = display level 'error' or higher messages on console +# -x = turn off broken EIP translation +exec klogd -n -c 3 -x 2>&1 diff --git a/base/sysklogd/rc.syslog.new b/base/sysklogd/rc.syslog.new new file mode 100644 index 0000000..e2855d3 --- /dev/null +++ b/base/sysklogd/rc.syslog.new @@ -0,0 +1,50 @@ +#!/bin/sh +# Start/stop/restart the system logging daemons. +# +# Written for Slackware Linux by Patrick J. Volkerding . +# Modified for use in SMLinux + +syslogd_start() { + if [ -x /bin/syslogd -a -x /bin/klogd ]; then + echo -n "Starting sysklogd daemons: " + echo -n "/bin/syslogd " + /bin/syslogd + # prevent syslogd/klogd race condition on SMP kernels + if ps acx | grep -q udevd ; then + while [ ! -e /dev/log ] ; do + sleep 0 + done + else + sleep 1 + fi + echo "/bin/klogd -c 3 -x" + # '-c 3' = display level 'error' or higher messages on console + # '-x' = turn off broken EIP translation + /bin/klogd -c 3 -x + fi +} + +syslogd_stop() { + killall syslogd 2> /dev/null + killall klogd 2> /dev/null +} + +syslogd_restart() { + syslogd_stop + sleep 1 + syslogd_start +} + +case "$1" in +'start') + syslogd_start + ;; +'stop') + syslogd_stop + ;; +'restart') + syslogd_restart + ;; +*) + echo "usage $0 start|stop|restart" +esac diff --git a/base/sysklogd/sysklogd.SMBuild b/base/sysklogd/sysklogd.SMBuild new file mode 100755 index 0000000..50e2237 --- /dev/null +++ b/base/sysklogd/sysklogd.SMBuild @@ -0,0 +1,56 @@ +APP=sysklogd +VERSION=1.5 +BUILD=1sml +HOMEPAGE="https://github.com/troglobit/sysklogd" +DESC="Linux system logging utilities" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Use memmove() instead of strcpy() in syslogd.c + patch -p1 --verbose < $SRCDIR/use_memmove_not_strcpy.diff + patch -p1 < $SRCDIR/fix-includes.patch + sleep 1 + + make all syslog_tst CC="$CC -static" + + # install binaries + install -Dm 755 klogd $PKG/bin/klogd + install -Dm 755 syslog_tst $PKG/bin/syslog_tst + install -Dm 755 syslogd $PKG/bin/syslogd + + # install man pages + install -Dm 644 syslog.conf.5 $PKG/share/man/man5/syslog.conf.5 + install -Dm 644 klogd.8 $PKG/share/man/man8/klogd.8 + install -Dm 644 sysklogd.8 $PKG/share/man/man8/sysklogd.8 + + # install conf files + install -Dm 644 $SRCDIR/syslog.conf.new $PKG/etc/syslog.conf.new + install -Dm 644 $SRCDIR/syslog.logrotate $PKG/etc/logrotate.d/syslog.new + + cp ANNOUNCE CHANGES COPYING MANIFEST NEWS README* $PKGDOCS/ + + mkdir -p $PKG/var/log + for i in cron debug maillog messages secure spooler syslog ; do + touch $PKG/var/log/$i.new + chmod 640 $PKG/var/log/$i.new + done + + preprunitservice syslogd finish + preprunitservice klogd finish + chmod 755 $PKG/etc/service/{klogd,syslogd/finish} + + mkfinalpkg +} + +SHA512SUMS=" +c4d3057b1e6ed67379bffe2a801d17e036ee6907e5166b80ece5b99f25526e9de1e9f9f22b2105f3130a9fcb928f1527f7d3d3cb714a03f0c6bc1aa150689840 sysklogd-1.5.tar.lz +0208662a0158ecb6b0a387bd1bf467c866105dac02767209aeaaaeb02762d6c2b814a2707315f8f6cd40f46c4b7744b74653e30973c31354998c27cd7c966dbd fix-includes.patch +90b990cdc52f908889f51a1f24cee1cc29c72369c2900d4dd6397440ee73e52fcc52dd5b8f59bb9d227d2238f8330ff0fb98ff1814062ecf1e0f4743f429bea6 use_memmove_not_strcpy.diff +" diff --git a/base/sysklogd/syslog.conf.new b/base/sysklogd/syslog.conf.new new file mode 100644 index 0000000..15bc5ee --- /dev/null +++ b/base/sysklogd/syslog.conf.new @@ -0,0 +1,46 @@ +# /etc/syslog.conf +# For info about the format of this file, see "man syslog.conf" +# and /usr/doc/sysklogd/README.linux. Note the '-' prefixing some +# of these entries; this omits syncing the file after every logging. +# In the event of a crash, some log information might be lost, so +# if this is a concern to you then you might want to remove the '-'. +# Be advised this will cause a performation loss if you're using +# programs that do heavy logging. + +# Uncomment this to see kernel messages on the console. +#kern.* /dev/console + +# Log anything 'info' or higher, but lower than 'warn'. +# Exclude authpriv, cron, mail, and news. These are logged elsewhere. +*.info;*.!warn;\ + authpriv.none;cron.none;mail.none;news.none -/var/log/messages + +# Log anything 'warn' or higher. +# Exclude authpriv, cron, mail, and news. These are logged elsewhere. +*.warn;\ + authpriv.none;cron.none;mail.none;news.none -/var/log/syslog + +# Debugging information is logged here. +*.=debug -/var/log/debug + +# Private authentication message logging: +authpriv.* -/var/log/secure + +# Cron related logs: +cron.* -/var/log/cron + +# Mail related logs: +mail.* -/var/log/maillog + +# Emergency level messages go to all users: +*.emerg * + +# This log is for news and uucp errors: +uucp,news.crit -/var/log/spooler + +# Uncomment these if you'd like INN to keep logs on everything. +# You won't need this if you don't run INN (the InterNetNews daemon). +#news.=crit -/var/log/news/news.crit +#news.=err -/var/log/news/news.err +#news.notice -/var/log/news/news.notice + diff --git a/base/sysklogd/syslog.logrotate b/base/sysklogd/syslog.logrotate new file mode 100644 index 0000000..151d1c0 --- /dev/null +++ b/base/sysklogd/syslog.logrotate @@ -0,0 +1,8 @@ +/var/log/cron /var/log/maillog /var/log/messages /var/log/secure /var/log/syslog { + nomail + sharedscripts + postrotate + sv restart klogd + sv restart syslogd + endscript +} diff --git a/base/sysklogd/syslogd.finish b/base/sysklogd/syslogd.finish new file mode 100644 index 0000000..80fc981 --- /dev/null +++ b/base/sysklogd/syslogd.finish @@ -0,0 +1,2 @@ +#!/bin/sh +exec killall syslogd 2> /dev/null diff --git a/base/sysklogd/syslogd.run b/base/sysklogd/syslogd.run new file mode 100644 index 0000000..4dcd9a4 --- /dev/null +++ b/base/sysklogd/syslogd.run @@ -0,0 +1,3 @@ +#!/bin/sh +# start syslogd first with -n (to prevent backgrounding) +exec syslogd -n 2>&1 diff --git a/base/sysklogd/use_memmove_not_strcpy.diff b/base/sysklogd/use_memmove_not_strcpy.diff new file mode 100644 index 0000000..8fb7c50 --- /dev/null +++ b/base/sysklogd/use_memmove_not_strcpy.diff @@ -0,0 +1,15 @@ +Adapted from this upstream git commit: 2a80f8117f40dc6a3fce30c6d0f15f3c5af55ccf +http://git.infodrom.org/?p=infodrom/sysklogd;a=commit;h=2a80f8117f40dc6a3fce30c6d0f15f3c5af55ccf + +diff -Nur sysklogd-1.5.orig//syslogd.c sysklogd-1.5/syslogd.c +--- sysklogd-1.5.orig//syslogd.c 2007-07-04 14:04:01.000000000 -0500 ++++ sysklogd-1.5/syslogd.c 2010-10-14 13:12:15.808000011 -0500 +@@ -2392,7 +2392,7 @@ + if (*p == '\0' || *p == '#') + continue; + #if CONT_LINE +- strcpy(cline, p); ++ memmove(cline, p, strlen(p)+1); + #endif + for (p = strchr(cline, '\0'); isspace(*--p);); + #if CONT_LINE diff --git a/base/syslinux/extlinux.conf.smlinux b/base/syslinux/extlinux.conf.smlinux new file mode 100644 index 0000000..2825dd0 --- /dev/null +++ b/base/syslinux/extlinux.conf.smlinux @@ -0,0 +1,16 @@ +UI menu.c32 + +PROMPT 1 +MENU TITLE SMLinux Boot Menu + +TIMEOUT 30 + +LABEL SMLinux LTS 5.X + LINUX vmlinuz-5.4.41 + INITRD initrd.img-5.4.41 + APPEND root="UUID=<>" ro quiet consoleblank=0 + +LABEL SMLinux LTS 5.X rescue + LINUX vmlinuz-5.4.41 + INITRD initrd.img-5.4.41 + APPEND root=/dev/sda2 ro quiet consoleblank=0 nomodeset rescue diff --git a/base/syslinux/syslinux.SMBuild b/base/syslinux/syslinux.SMBuild new file mode 100755 index 0000000..46f1b02 --- /dev/null +++ b/base/syslinux/syslinux.SMBuild @@ -0,0 +1,84 @@ +APP=syslinux +VERSION=6.03 +BUILD=1sml +HOMEPAGE="https://wiki.syslinux.org/wiki/index.php?title=The_Syslinux_Project" +DESC="boot loader for the linux operating system which boots off of MS-DOS Windows FAT filesystem" +REQUIRES="musl" + +build() { + compileonlyfor x86_64 + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/syslinux6-ext4_fix_64bit_feature.patch + + # We don't use sbin + sed -i 's,/sbin,/bin,' syslinux.spec mk/syslinux.mk + + # Exclude windows stuff and mtools and others + sed 's|INSTALLSUBDIRS = com32 utils dosutil|INSTALLSUBDIRS = com32 utils|g' -i Makefile + sed '/DIAGDIR/d' -i Makefile + + # Windows stuff not needed. + sed 's|diag libinstaller dos win32 win64 dosutil txt|libinstaller txt|g' -i Makefile + sed 's|win32/syslinux.exe win64/syslinux64.exe||g' -i Makefile + sed 's|dosutil/\*.com dosutil/\*.sys||g' -i Makefile + sed 's|dos/syslinux.com||g' -i Makefile + sed 's|gpxe/gpxelinuxk*\.0||g' -i Makefile + + # We dont want the perl-based utils + # They also pull in the isohybrid mbrs + sed "s|utils/[a-z]*||g" -i Makefile + + # rarely used COM32 Modules + sed "s,com32/modules/\*.c32,," -i Makefile + sed "s,com32/hdt/\*.c32,," -i Makefile + sed "s,com32/rosh/\*.c32,," -i Makefile + sed "s,com32/gfxboot/\*.c32,," -i Makefile + sed "s,com32/sysdump/\*.c32,," -i Makefile + sed "s,com32/lua/src/\*.c32,," -i Makefile + sed "s,com32/gpllib/\*.c32,," -i Makefile + sed "s,com32/cmenu/libmenu/\*.c32,," -i Makefile + + # Exclude perl utils from being installed + sed '/DIRS/ s/utils//' -i Makefile + + sed -i 's,#include ,#include "include/getkey.h",' com32/libutil/keyname.c + sed -i 's,#include ,#include "include/libutil.h",' com32/libutil/keyname.c + sed -i 's,#include "sha1.h",#include "include/sha1.h",' com32/libutil/sha1hash.c + sed -i 's,#include ,#include "include/base64.h",' com32/libutil/unbase64.c + sed -i 's,#include ,#include "include/md5.h",' com32/libutil/md5.c + sed -i 's,#include ,#include "include/md5.h",' com32/libutil/crypt-md5.c + sed -i 's,#include ,#include "include/minmax.h",' com32/libutil/sha256crypt.c + sed -i 's,#include "xcrypt.h",#include "include/xcrypt.h",' com32/libutil/sha256crypt.c + sed -i 's,#include ,#include "include/minmax.h",' com32/libutil/sha512crypt.c + sed -i 's,#include "xcrypt.h",#include "include/xcrypt.h",' com32/libutil/sha512crypt.c + sed -i 's,#include ,#include "include/base64.h",' com32/libutil/base64.c + sed -i '/herror.*/d' utils/gethostip.c + sed -ri 's,__uint([0-9]+)_t,uint\1_t,g' efi/wrapper.c + sed -ri 's,__uint([0-9]+)_t,uint\1_t,g' efi/wrapper.h + + PREFIXED_PATHS="BINDIR='/bin' LIBDIR='/lib' DATADIR='/share' MANDIR='/share/man' INCDIR='/include'" + + make CC="gcc -I/include -include sys/sysmacros.h" $PREFIXED_PATHS AUXDIR="/lib/syslinux/bios" INSTALLROOT="$PKG" -j1 bios installer + make $PREFIXED_PATHS AUXDIR="/lib/syslinux/bios" INSTALLROOT="$PKG" -j1 bios install + + make CC="gcc -I/include -include sys/sysmacros.h" $PREFIXED_PATHS AUXDIR="/lib/syslinux/bios" INSTALLROOT="$PKG" efi64 installer + make CC="gcc -I/include -include sys/sysmacros.h" $PREFIXED_PATHS AUXDIR="/lib/syslinux/bios" INSTALLROOT="$PKG" -j1 efi64 install + + # copy the smlinux bootloader configuration + install -Dm 0644 $SRCDIR/extlinux.conf.smlinux $PKG/boot/extlinux.conf.sample + + cp COPYING $PKGDOCS/LICENSE + + mkfinalpkg +} + +SHA512SUMS=" +5740536857c7789304ff00fc568fdce18ed3b2e09cf3623f08df7f46144ccc87248b618934d9fa092b99ceab054698b3e0250fd70a664b631da28bf3612b8160 syslinux-6.03.tar.lz +1ecba0810415963707099143de74ea5c9e41e38b200da2de57ceee29914b1eaeebc58b1cf14738f0b7bd4d37695a8490adb8a9f1b4f35ff4ad1f34c816db54da syslinux6-ext4_fix_64bit_feature.patch +" diff --git a/base/syslinux/syslinux6-ext4_fix_64bit_feature.patch b/base/syslinux/syslinux6-ext4_fix_64bit_feature.patch new file mode 100644 index 0000000..3a51a6f --- /dev/null +++ b/base/syslinux/syslinux6-ext4_fix_64bit_feature.patch @@ -0,0 +1,101 @@ +From af7e95c32cea40c1e443ae301e64b27f068b4915 Mon Sep 17 00:00:00 2001 +From: Paulo Alcantara +Date: Wed, 11 Oct 2017 07:00:31 -0400 +Subject: ext4: Fix 64bit feature + +As per ext4 specification: + +> In ext2, ext3, and ext4 (when the 64bit feature is not enabled), the +> block group descriptor was only 32 bytes long and therefore ends at +> bg_checksum. On an ext4 filesystem with the 64bit feature enabled, the +> block group descriptor expands to at least the 64 bytes described below; +> the size is stored in the superblock. + +Since block group descriptor has been expanded to 64 bytes long (when 64 +bit feature is enabled), we cannot index ext2_group_desc and return it +*directly* -- as we did it in ext2_get_group_desc -- it's still 32 bytes +long. + +Instead, use s_desc_size field from superblock to correctly index and +return block group descriptors. + +Cc: H. Peter Anvin +Cc: Gene Cumm +Signed-off-by: Paulo Alcantara +--- + core/fs/ext2/ext2.c | 23 ++++++++++++++--------- + core/fs/ext2/ext2_fs.h | 1 + + 2 files changed, 15 insertions(+), 9 deletions(-) + +diff --git a/core/fs/ext2/ext2.c b/core/fs/ext2/ext2.c +index 76bd1d5a..4bc0a535 100644 +--- a/core/fs/ext2/ext2.c ++++ b/core/fs/ext2/ext2.c +@@ -25,22 +25,17 @@ static enum dirent_type ext2_cvt_type(unsigned int d_file_type) + return inode_type[d_file_type]; + } + +-/* +- * get the group's descriptor of group_num +- */ +-static const struct ext2_group_desc * +-ext2_get_group_desc(struct fs_info *fs, uint32_t group_num) ++static const void *__ext2_get_group_desc(struct fs_info *fs, uint32_t group_num) + { + struct ext2_sb_info *sbi = EXT2_SB(fs); + uint32_t desc_block, desc_index; +- const struct ext2_group_desc *desc_data_block; ++ uint8_t *p; + + if (group_num >= sbi->s_groups_count) { + printf ("ext2_get_group_desc" + "block_group >= groups_count - " + "block_group = %d, groups_count = %d", + group_num, sbi->s_groups_count); +- + return NULL; + } + +@@ -49,8 +44,17 @@ ext2_get_group_desc(struct fs_info *fs, uint32_t group_num) + + desc_block += sbi->s_first_data_block + 1; + +- desc_data_block = get_cache(fs->fs_dev, desc_block); +- return &desc_data_block[desc_index]; ++ p = get_cache(fs->fs_dev, desc_block); ++ return p + sbi->s_desc_size * desc_index; ++} ++ ++/* ++ * get the group's descriptor of group_num ++ */ ++static inline const struct ext2_group_desc * ++ext2_get_group_desc(struct fs_info *fs, uint32_t group_num) ++{ ++ return __ext2_get_group_desc(fs, group_num); + } + + /* +@@ -306,6 +310,7 @@ static int ext2_fs_init(struct fs_info *fs) + if (sb.s_desc_size < sizeof(struct ext2_group_desc)) + sb.s_desc_size = sizeof(struct ext2_group_desc); + sbi->s_desc_per_block = BLOCK_SIZE(fs) / sb.s_desc_size; ++ sbi->s_desc_size = sb.s_desc_size; + sbi->s_groups_count = (sb.s_blocks_count - sb.s_first_data_block + + EXT2_BLOCKS_PER_GROUP(fs) - 1) + / EXT2_BLOCKS_PER_GROUP(fs); +diff --git a/core/fs/ext2/ext2_fs.h b/core/fs/ext2/ext2_fs.h +index 803a9954..d8d07ebd 100644 +--- a/core/fs/ext2/ext2_fs.h ++++ b/core/fs/ext2/ext2_fs.h +@@ -278,6 +278,7 @@ struct ext2_sb_info { + uint32_t s_first_data_block; /* First Data Block */ + int s_inode_size; + uint8_t s_uuid[16]; /* 128-bit uuid for volume */ ++ int s_desc_size; /* size of group descriptor */ + }; + + static inline struct ext2_sb_info *EXT2_SB(struct fs_info *fs) +-- +cgit v1.2.1 + diff --git a/base/sysstat/doinst.sh b/base/sysstat/doinst.sh new file mode 100644 index 0000000..b0f71a9 --- /dev/null +++ b/base/sysstat/doinst.sh @@ -0,0 +1,34 @@ + +# Since /etc/sysstat/sysstat used to be the init script and now it is +# a config file, if we find an init script here, we have to move it +# out of the way: +if grep -wq "sadc was successfully launched" etc/sysstat/sysstat 1> /dev/null 2> /dev/null ; then + mv etc/sysstat/sysstat etc/sysstat/sysstat.obsolete.use.etc.rc.d.rc.sysstat +fi + +config() { + NEW="$1" + OLD="$(dirname $NEW)/$(basename $NEW .new)" + # If there's no config file by that name, mv it over: + if [ ! -r $OLD ]; then + mv $NEW $OLD + elif [ "$(cat $OLD | md5sum)" = "$(cat $NEW | md5sum)" ]; then # toss the redundant copy + rm $NEW + fi + # Otherwise, we leave the .new copy for the admin to consider... +} + +config etc/sysstat/sysstat.new + +# Keep same perms on rc.sysstat.new: +if [ -e etc/rc.d/rc.sysstat ]; then + cp -a etc/rc.d/rc.sysstat etc/rc.d/rc.sysstat.new.incoming + cat etc/rc.d/rc.sysstat.new > etc/rc.d/rc.sysstat.new.incoming + mv etc/rc.d/rc.sysstat.new.incoming etc/rc.d/rc.sysstat.new +fi + +# There's no reason for a user to edit rc.sysstat, so overwrite it: +if [ -r etc/rc.d/rc.sysstat.new ]; then + mv etc/rc.d/rc.sysstat.new etc/rc.d/rc.sysstat +fi + diff --git a/base/sysstat/sysstat.SMBuild b/base/sysstat/sysstat.SMBuild new file mode 100755 index 0000000..b708bf2 --- /dev/null +++ b/base/sysstat/sysstat.SMBuild @@ -0,0 +1,33 @@ +APP=sysstat +VERSION=12.2.2 +BUILD=1sml +HOMEPAGE='http://sebastien.godard.pagesperso-orange.fr/' +DOWNLOAD="https://github.com/sysstat/sysstat/archive/refs/tags/v12.2.2.tar.gz" +DESC="System performance monitoring tools" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + rm -rf tests/root* + fixbuilddirpermissions + + ./configure \ + --prefix="/" \ + --sysconfdir=/etc \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +4faaf3f062aac1b46db3bce697f7b2e1d41ca525c01c8af763d5f4b6b81b34db4e1ac56d1ae2cec32628a37c4a3a4fe92570e5870b8600ea1683b0abf923eb38 sysstat-12.2.2.tar.xz +" diff --git a/base/tar/tar-1.13.bzip2.diff b/base/tar/tar-1.13.bzip2.diff new file mode 100644 index 0000000..85c0336 --- /dev/null +++ b/base/tar/tar-1.13.bzip2.diff @@ -0,0 +1,48 @@ +--- ./src/tar.c.orig Wed Jul 7 00:49:50 1999 ++++ ./src/tar.c Fri Jul 30 23:00:13 1999 +@@ -16,6 +16,8 @@ + with this program; if not, write to the Free Software Foundation, Inc., + 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + ++/* Patched to integrate bzip2 as compression filter (option -j) */ ++ + #include "system.h" + + #include +@@ -164,6 +166,8 @@ + {"block-number", no_argument, NULL, 'R'}, + {"block-size", required_argument, NULL, OBSOLETE_BLOCKING_FACTOR}, + {"blocking-factor", required_argument, NULL, 'b'}, ++ {"bzip2", required_argument, NULL, 'j'}, ++ {"bunzip2", required_argument, NULL, 'j'}, + {"catenate", no_argument, NULL, 'A'}, + {"checkpoint", no_argument, &checkpoint_option, 1}, + {"compare", no_argument, NULL, 'd'}, +@@ -340,6 +344,7 @@ + PATTERN at list/extract time, a globbing PATTERN\n\ + -o, --old-archive, --portability write a V7 format archive\n\ + --posix write a POSIX conformant archive\n\ ++ -j, --bzip2, --bunzip2 filter the archive through bzip2\n\ + -z, --gzip, --ungzip filter the archive through gzip\n\ + -Z, --compress, --uncompress filter the archive through compress\n\ + --use-compress-program=PROG filter through PROG (must accept -d)\n"), +@@ -416,7 +421,7 @@ + Y per-block gzip compression */ + + #define OPTION_STRING \ +- "-01234567ABC:F:GK:L:MN:OPRST:UV:WX:Zb:cdf:g:hiklmoprstuvwxz" ++ "-01234567ABC:F:GK:L:MN:OPRST:UV:WX:Zb:cdf:g:hijklmoprstuvwxz" + + static void + set_subcommand_option (enum subcommand subcommand) +@@ -787,6 +792,10 @@ + if (add_exclude_file (excluded, optarg, '\n') != 0) + FATAL_ERROR ((0, errno, "%s", optarg)); + break; ++ ++ case 'j': ++ set_use_compress_program_option ("bzip2"); ++ break; + + case 'z': + set_use_compress_program_option ("gzip"); diff --git a/base/tar/tar.SMBuild b/base/tar/tar.SMBuild new file mode 100755 index 0000000..bfb2dcc --- /dev/null +++ b/base/tar/tar.SMBuild @@ -0,0 +1,60 @@ +APP=tar +VERSION=1.29 +BUILD=1sml +HOMEPAGE='' +DOWNLOAD='' +HOMEPAGE="https://www.gnu.org/software/tar/" +DOWNLOAD="https://ftp.gnu.org/gnu/tar/tar-1.29.tar.xz" +DESC="GNU archiving utility" +REQUIRES="bzip2 gzip xz attr acl" + +build() { + mkandenterbuilddir + + rm -rf tar-1.13 + tar xf $SRCDIR/tar-1.13.tar.?z + + cd tar-1.13 + patch -p1 < $SRCDIR/tar-1.13.bzip2.diff + cp -p --verbose /usr/share/libtool/build-aux/config.{guess,sub} . + fixbuilddirpermissions + + CFLAGS="-static" \ + ./configure \ + --prefix="" \ + --libexecdir=/lib \ + --disable-nls + + make CFLAGS="-static" V=s + install -Dm 755 src/tar $PKG/bin/tar-1.13 + # that's it as far as 1.13 is concerned. + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # The "A lone zero block at %s" messages also cause problems: + patch -p1 < $SRCDIR/tar.nolonezero.diff + + FORCE_UNSAFE_CONFIGURE=1 \ + CFLAGS="-static" \ + ./configure \ + --prefix="" \ + --sbindir=/bin \ + --libexecdir=/lib \ + --enable-backup-scripts + + make CFLAGS="-static" + make install DESTDIR=$PKG + + cp ABOUT-NLS AUTHORS COPYING README THANKS TODO $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7c0f2dfb7708bd5fe7cc5b841f68cc4cc077b14200df337f1847ecc41dcafae3b8f3dd210b78bf0ebc3d3408444283f71705ba34b1c9153d93dc631e80da6f07 tar-1.13.tar.lz +f14a0f20dc514dda887299b9ecad3fd8482f39e6abb9238a5dff819a5600a7e424df642e38a6d17b57e34c5655eb0d50137a6b0857c429e353fc72cbb3546beb tar-1.29.tar.lz +5e12ae7f99a3bc73cd9a57d5451b534cc02da98aee46a7d6073eac492070f94e55b266e2cadcfcff4f5e2048ead683dd796b92f689d8f8ee56bc5f34ff186cde tar-1.13.bzip2.diff +90b764cd2128d6c316a0cd9e24ae734ee94b1e2794e6cf724e60592d23ca6dac2d9a44552054610747cadd733263ee56971062f4201227bfda93966f287984bd tar.nolonezero.diff +" diff --git a/base/tar/tar.nolonezero.diff b/base/tar/tar.nolonezero.diff new file mode 100644 index 0000000..c47e067 --- /dev/null +++ b/base/tar/tar.nolonezero.diff @@ -0,0 +1,26 @@ +diff -Nur tar-1.27.1.orig/src/list.c tar-1.27.1/src/list.c +--- tar-1.27.1.orig/src/list.c 2013-03-14 15:18:10.000000000 -0500 ++++ tar-1.27.1/src/list.c 2014-07-26 20:42:16.613004098 -0500 +@@ -211,6 +211,14 @@ + + if (!ignore_zeros_option) + { ++ ++ /* ++ * According to POSIX tar specs, this is wrong, but on the web ++ * there are some tar specs that can trigger this, and some tar ++ * implementations create tars according to that spec. For now, ++ * let's not be pedantic about issuing the warning. ++ */ ++#if 0 + char buf[UINTMAX_STRSIZE_BOUND]; + + status = read_header (¤t_header, ¤t_stat_info, +@@ -220,6 +228,7 @@ + WARNOPT (WARN_ALONE_ZERO_BLOCK, + (0, 0, _("A lone zero block at %s"), + STRINGIFY_BIGINT (current_block_ordinal (), buf))); ++#endif + break; + } + status = prev_status; diff --git a/base/tarlz/tarlz.SMBuild b/base/tarlz/tarlz.SMBuild new file mode 100755 index 0000000..a60ad3a --- /dev/null +++ b/base/tarlz/tarlz.SMBuild @@ -0,0 +1,31 @@ +APP=tarlz +VERSION=0.16 +BUILD=1sml +HOMEPAGE="https://www.nongnu.org/lzip/tarlz.html" +DOWNLOAD="http://download.savannah.gnu.org/releases/lzip/tarlz/tarlz-0.16.tar.lz" +DESC="multi-threaded compression utility of tar and lzip" +REQUIRES="gcc-libs lzlib" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +619cb5807e58cbb267e0bd4780e578a069de2bd721c4ff84416b0d551d79c4172d453ee7e0c610b3c5da5a9f5068f5d134638c39ab67c05a5e853257abb2ff00 tarlz-0.16.tar.lz +" diff --git a/base/texinfo/texinfo.SMBuild b/base/texinfo/texinfo.SMBuild new file mode 100755 index 0000000..344c076 --- /dev/null +++ b/base/texinfo/texinfo.SMBuild @@ -0,0 +1,31 @@ +APP=texinfo +VERSION=6.7 +BUILD=1sml +HOMEPAGE="https://www.gnu.org/software/texinfo/" +DOWNLOAD="https://ftp.gnu.org/gnu/texinfo/texinfo-6.7.tar.xz" +DESC="GNU software documentation system" +REQUIRES="netbsd-curses perl gzip" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-nls + + make + make install DESTDIR=$PKG + + cp AUTHORS COPYING NEWS README* TODO $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +c1cba6894164fb9e09f000d5af287b7d324d15a0034d4145959b76fcd1e4ca671c201aa0725e8f99c51ac468e59467ebf950e2bc11ed4a07f15f6c838defd855 texinfo-6.7.tar.lz +" diff --git a/base/time/time.SMBuild b/base/time/time.SMBuild new file mode 100755 index 0000000..2b27d1b --- /dev/null +++ b/base/time/time.SMBuild @@ -0,0 +1,31 @@ +APP=time +VERSION=1.9 +BUILD=1sml +HOMEPAGE="https://www.gnui.org/software/time/" +DOWNLOAD="https://ftp.gnu.org/gnu/time/time-1.9.tar.gz" +DESC="command for measuring program resource use" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +43f584decc52d2768e99634741504c7836d1f8345155b41bde4940486809711ffc014d12cd7029fd5f5fd16a26b7b6791ee72f628716b3b16218fde7a4cf3036 time-1.9.tar.lz +" diff --git a/base/tofrodos/tofrodos.SMBuild b/base/tofrodos/tofrodos.SMBuild new file mode 100755 index 0000000..8b747ca --- /dev/null +++ b/base/tofrodos/tofrodos.SMBuild @@ -0,0 +1,29 @@ +APP=tofrodos +VERSION=1.7.13 +BUILD=1sml +HOMEPAGE="https://www.thefreecountry.com/tofrodos/index.shtml" +DOWNLOAD="https://tofrodos.sourceforge.io/download/tofrodos-1.7.13.tar.gz" +DESC="text file conversion utility to process UTF-8 and ASCII files between MSDOS and Unix formats" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP + fixbuilddirpermissions + + cd src + make + install -Dm 755 fromdos $PKG/bin/fromdos + ( cd $PKG/bin ; ln -s fromdos todos ) + + cp ../COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +084a26d44c7ec17929c8cda7655df59f91a6d8f08bba51af9ca0434eedca2f900fb0d38721c9e452c6c2728ad00709531b68b2d40089796622c5163d7663aa19 tofrodos-1.7.13.tar.lz +" diff --git a/base/toluapp/toluapp.SMBuild b/base/toluapp/toluapp.SMBuild new file mode 100755 index 0000000..3ecc726 --- /dev/null +++ b/base/toluapp/toluapp.SMBuild @@ -0,0 +1,33 @@ +APP=toluapp +VERSION=1.0.93 +BUILD=1sml +HOMEPAGE='https://github.com/LuaDist/toluapp' +DOWNLOAD="https://github.com/LuaDist/toluapp/archive/refs/tags/1.0.93.tar.gz" +DESC="tool to integrate C/C++ code with Lua" +REQUIRES="lua" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + mkdir -p smbuild && cd smbuild + cmake .. \ + -DCMAKE_INSTALL_PREFIX="" \ + -DCMAKE_BUILD_TYPE=Release + + make + make install DESTDIR=$PKG + + cd .. + cp README* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +68f169244f1b37fdeb1a72b0f8fc61a30329c0a828f46af718021c8cfa120fe15379b4b2bc10f0995de90e34735564afd6d302fa1865be60272e52e276e1114f toluapp-1.0.93.tar.gz +" diff --git a/base/tree/tree.SMBuild b/base/tree/tree.SMBuild new file mode 100755 index 0000000..78bc2a7 --- /dev/null +++ b/base/tree/tree.SMBuild @@ -0,0 +1,28 @@ +APP=tree +VERSION=1.6.0 +BUILD=1sml +HOMEPAGE="http://mama.indstate.edu/users/ice/tree/" +DOWNLOAD="http://mama.indstate.edu/users/ice/tree/src/tree-1.6.0.tgz" +DESC="program to display a directory tree" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make + install -Dm 755 tree $PKG/bin/tree + install -Dm 644 doc/tree.1 $PKG/share/man/man1/tree.1 + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +43ec8adf83dd5d42c3216c15b643fa3cb1905313817b4a7bc0b15682f1124f3707ef5e004fb1e344307c8a58e17785f9b0e2066f7cc880701f849bc885ab40f1 tree-1.6.0.tar.lz +" diff --git a/base/twolame/twolame.SMBuild b/base/twolame/twolame.SMBuild new file mode 100755 index 0000000..e51ca09 --- /dev/null +++ b/base/twolame/twolame.SMBuild @@ -0,0 +1,31 @@ +APP=twolame +VERSION=0.4.0 +BUILD=1sml +HOMEPAGE="https://www.twolame.org/" +DOWNLOAD="https://downloads.sourceforge.net/twolame/twolame-0.4.0.tar.gz" +DESC="Optimised MP2 audio encoder" +REQUIRES="libsndfile flac" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +cf9d23c15a16216ad1c3d11ff6f811eb28d2e07e940f0e9308f8f9917dd7af5c96f9ba4420f25c50beaa95f5cb9c6c1a094fb4d7ada6063114204716327938ef twolame-0.4.0.tar.lz +" diff --git a/base/tzdb/tzdb.SMBuild b/base/tzdb/tzdb.SMBuild new file mode 100755 index 0000000..042ecc9 --- /dev/null +++ b/base/tzdb/tzdb.SMBuild @@ -0,0 +1,31 @@ +APP=tzdb +VERSION=2019c +BUILD=1sml +HOMEPAGE="https://www.iana.org/time-zones" +DOWNLOAD="https://data.iana.org/time-zones/releases/tzdb-2019c.tar.lz" +DESC="Time zone database from IANA" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + make install CC="$CC" \ + DESTDIR=$PKG \ + USRDIR="/" \ + BINDIR="/bin" \ + ZICDIR="/bin" \ + MANDIR="/share/man" + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +cc76c25a55868d61e8500293d1ee3cadb0055987fc81ad0ed08add548e1c6a19cd2a10f4c4313827e4ab46bd2fbf16607519b4db92930ebaaa87062fa4c8b55d tzdb-2019c.tar.lz +" diff --git a/base/unzip/unzip.SMBuild b/base/unzip/unzip.SMBuild new file mode 100755 index 0000000..99a6b0d --- /dev/null +++ b/base/unzip/unzip.SMBuild @@ -0,0 +1,37 @@ +APP=unzip +VERSION=60 +BUILD=1sml +HOMEPAGE="http://infozip.sourceforge.net/UnZip.html" +DESC="decompression and extraction utility for archives compressed in .zip format" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf "$APP$VERSION" + + tar xf $SRCDIR/$APP$VERSION.tar.?z + cd "$APP$VERSION" + fixbuilddirpermissions + + make -f unix/Makefile flags \ + CFLAGS_BZ="$CFLAGS" \ + CC="$CC" STRIP=true LF2= + + sed -i 's@-DNO_LCHMOD@@' flags + sed -i 's@-O3@''@' flags + + make -f unix/Makefile generic + + make prefix="$PKG" -f unix/Makefile install + mkdir -p $PKG/share/man + mv $PKG/man/man* $PKG/share/man/ + rmdir $PKG/man + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7fa0c4db56062b6615969263f23ac18b1eada893e03e76752862e450dc5bfbcf8d99fa7f9cc31ffe8b8bdb014bb5b7033759eb719fca62d52ce98e9dcb9327a0 unzip60.tar.lz +" diff --git a/base/usbutils/usbutils.SMBuild b/base/usbutils/usbutils.SMBuild new file mode 100755 index 0000000..103578b --- /dev/null +++ b/base/usbutils/usbutils.SMBuild @@ -0,0 +1,33 @@ +APP=usbutils +VERSION=012 +BUILD=1sml +HOMEPAGE="https://github.com/gregkh/usbutils" +DOWNLOAD="https://github.com/gregkh/usbutils/archive/refs/tags/v012.tar.gz" +DESC="USB utilities for displaying detailed info about USB buses and devices in the system" +REQUIRES="python3 libusb" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --sbindir=/bin \ + --datadir=/share/hwdata + + make + make install DESTDIR=$PKG + + cp LICENSES/* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a995d0a70814b1e87fbeee4261b9a8541eeaa3bb3de75810399f7daa63ef94dc75e8c9af2fbb551dbcdf641497778a88e1b0f54fbc6a9f925cc8c95f9eabcab7 usbutils-012.tar.lz +" diff --git a/base/util-linux/cal.patch b/base/util-linux/cal.patch new file mode 100644 index 0000000..c79791e --- /dev/null +++ b/base/util-linux/cal.patch @@ -0,0 +1,39 @@ +From b2fd60c1a471074814ad0a2761530383bc42e414 Mon Sep 17 00:00:00 2001 +From: rofl0r +Date: Mon, 19 Oct 2020 16:14:49 +0000 +Subject: [PATCH] cal: fix invalid use of putp() + +according to documentation, putp() is supposed to be only used with: +> ... a terminfo string variable or the return value from tparm, tgetstr, or +> tgoto. + +for arbitrary strings, standard libc output routines need to be used. + +this caused strings like "11 12 13"... to be truncated to "12 13" in the output +when built with netbsd-curses. +--- + misc-utils/cal.c | 7 +------ + 1 file changed, 1 insertion(+), 6 deletions(-) + +diff --git a/misc-utils/cal.c b/misc-utils/cal.c +index 0834be2bd..02ef690b7 100644 +--- a/misc-utils/cal.c ++++ b/misc-utils/cal.c +@@ -110,12 +110,7 @@ static int setup_terminal(char *term + + static void my_putstring(const char *s) + { +-#if defined(HAVE_LIBNCURSES) || defined(HAVE_LIBNCURSESW) +- if (has_term) +- putp(s); +- else +-#endif +- fputs(s, stdout); ++ fputs(s, stdout); + } + + static const char *my_tgetstr(char *ss +-- +2.25.0 + + diff --git a/base/util-linux/util-linux.SMBuild b/base/util-linux/util-linux.SMBuild new file mode 100755 index 0000000..66131a8 --- /dev/null +++ b/base/util-linux/util-linux.SMBuild @@ -0,0 +1,63 @@ +APP=util-linux +VERSION=2.33 +BUILD=2sml +HOMEPAGE="https://github.com/karelzak/util-linux" +DOWNLOAD="https://mirrors.edge.kernel.org/pub/linux/utils/util-linux/v2.33/util-linux-2.33.tar.xz" +DESC="a huge collection of essential utilities" +REQUIRES="readline zlib xz kmod eudev" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # Thank you sabotage linux + patch -p1 < $SRCDIR/cal.patch + + CFLAGS="$CFLAGS -include sys/sysmacros.h" \ + LDFLAGS="-lcurses -lterminfo" \ + ./configure \ + --prefix="" --sbindir=/bin --libdir=/lib \ + --includedir=/include \ + --disable-silent-rules \ + --disable-nls --disable-fsck\ + --enable-libmount-support-mtab \ + --disable-fdformat --disable-hwclock --disable-switch-root \ + --disable-kill --disable-login --disable-sulogin --disable-su\ + --disable-more --disable-pg --disable-agetty \ + --without-systemd --disable-wdctl --enable-libuuid \ + --enable-libblkid --enable-libmount --disable-uuidd \ + --enable-static-programs="mount,umount" \ + --without-python + + sed -i 's,/sbin,/bin,' config.status + ./config.status + + make + make install DESTDIR=$PKG + + # libuuid.la is required by gegl + cp .libs/libuuid.la $PKG/lib/ + + # Replace dynamically-linked mount with statically-linked mount + ( + cd $PKG/bin + mv mount.static mount + mv umount.static umount + ) + + cp COPYING $PKGDOCS/ + + # rev is provided by busybox which is statically-linked + rm $PKG/bin/rev + + mkfinalpkg +} + +SHA512SUMS=" +41c95705c06e8794140091c41e62a3eb7c6a62c86bb2415dad53a19ed26f9ff849fb400cb87d5650ff6ff7b89d170d3139b04931f8c4b5c7257b724b61fa7da4 util-linux-2.33.tar.lz +ab3ab93642f6feaaba4d1125d5f213d7aa322cfa3396553b418a738a7f9bcdffd20d6c5ba272a6e72a52ec10349d21400791a47a9c5c1c879c311435b8db79fa cal.patch +" diff --git a/base/vim/vim.SMBuild b/base/vim/vim.SMBuild new file mode 100755 index 0000000..cb68139 --- /dev/null +++ b/base/vim/vim.SMBuild @@ -0,0 +1,47 @@ +APP=vim +VERSION=8.1 +BUILD=1sml +HOMEPAGE="https://www.vim.org/" +DOWNLOAD="ftp://ftp.vim.org/pub/vim/unix/vim-8.1.tar.bz2" +DESC="Vi IMproved UNIX text editor" +REQUIRES="netbsd-curses" + +build() { + mkandenterbuilddir + rm -rf "$APP""81" + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd "$APP""81" + fixbuilddirpermissions + + CPPFLAGS="$CFLAGS -include stdlib.h -DHAVE_SETENV -DHAVE_PUTENV" \ + LIBS="-lcurses -lterminfo" \ + LDFLAGS="-static" \ + vim_cv_toupper_broken=no \ + vim_cv_terminfo=yes \ + vim_cv_tty_group=world \ + vim_cv_getcwd_broken=no \ + vim_cv_stat_ignores_slash=no \ + vim_cv_memmove_handles_overlap=yes \ + ./configure \ + --prefix="" \ + --sysconfdir=/etc \ + --disable-nls --disable-netbeans --disable-gui \ + --with-x=no --enable-multibyte --with-features=normal \ + --with-compiledby="" \ + --enable-terminal + + make + make -j1 STRIP=true VIMRCLOC="$PKG"/etc install DESTDIR="$PKG" + + cp *.md $PKGDOCS/ + + cd $PKG/bin + ln -s vim vi + + mkfinalpkg +} + +SHA512SUMS=" +0cd68de074962116b222dcbe918f36647fc0edc4c6e1520ec07ad837c868f502bd3f3d5c875570076d52fc335196014a42d9d7d860396c1f4aaeaf1ae1024267 vim-8.1.tar.lz +" diff --git a/base/wavpack/wavpack.SMBuild b/base/wavpack/wavpack.SMBuild new file mode 100755 index 0000000..cd1499c --- /dev/null +++ b/base/wavpack/wavpack.SMBuild @@ -0,0 +1,31 @@ +APP=wavpack +VERSION=5.3.0 +BUILD=1sml +HOMEPAGE="https://www.wavpack.com" +DOWNLOAD="https://www.wavpack.com/wavpack-5.3.0.tar.xz" +DESC="hybrid lossless wavefile compressor" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +e4c831371984a32f79d522e067210295aed6ff94ebef89f2ec0fab32e225cb807bd11c980ae9177717d6a446c4795aaac8a7f69e1af14e317222d5601c13c0fd wavpack-5.3.0.tar.lz +" diff --git a/base/wayland-protocols/wayland-protocols.SMBuild b/base/wayland-protocols/wayland-protocols.SMBuild new file mode 100755 index 0000000..8dec3a2 --- /dev/null +++ b/base/wayland-protocols/wayland-protocols.SMBuild @@ -0,0 +1,30 @@ +APP=wayland-protocols +VERSION=1.18 +BUILD=1sml +HOMEPAGE="https://wayland.freedesktop.org/" +DOWNLOAD="https://wayland.freedesktop.org/releases/wayland-protocols-1.18.tar.xz" +DESC="specifications of extended wayland protocols" +REQUIRES="wayland" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +fbf5b0888a2c40cca2b49d29154ff032a23073668b1ace2f5683d960f2491b375279de02474433c3da2f6b35d2f9ac125afdb84edd8bdb8ede1584fcfb20f691 wayland-protocols-1.18.tar.lz +" diff --git a/base/wayland/wayland.SMBuild b/base/wayland/wayland.SMBuild new file mode 100755 index 0000000..9c54c72 --- /dev/null +++ b/base/wayland/wayland.SMBuild @@ -0,0 +1,32 @@ +APP=wayland +VERSION=1.18.0 +BUILD=1sml +HOMEPAGE="https://wayland.freedesktop.org/" +DOWNLOAD="https://wayland.freedesktop.org/releases/wayland-1.18.0.tar.xz" +DESC="replacement for the Xorg server protocol" +REQUIRES="expat libxml2 libffi" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --disable-static \ + --disable-documentation + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +6bec8c334e2f2aae976afa24501b2449206834795e60b780629ec2f1736ecf18c358306f4d325d006e2d6d937f50dce5798d233d5c8a1949f66a543b34e7eec2 wayland-1.18.0.tar.lz +" diff --git a/base/which/which.SMBuild b/base/which/which.SMBuild new file mode 100755 index 0000000..eceac38 --- /dev/null +++ b/base/which/which.SMBuild @@ -0,0 +1,31 @@ +APP=which +VERSION=2.21 +BUILD=1sml +HOMEPAGE="https://savannah.gnu.org/projects/which/" +DOWNLOAD="http://ftp.gnu.org/gnu/which/which-2.21.tar.gz" +DESC="shows the full path to shell commands" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + CFLAGS="-O2 -static" \ + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +467993862114fda14ee25b3a504cd843a9c3f70ded2345d47f2274fe85124215e2d17a463fd520cacf14b7478a7fd12700cbff999d2c7ba11e1e4afc3fb5a8d7 which-2.21.tar.lz +" diff --git a/base/wireless-regdb/wireless-regdb.SMBuild b/base/wireless-regdb/wireless-regdb.SMBuild new file mode 100755 index 0000000..020b781 --- /dev/null +++ b/base/wireless-regdb/wireless-regdb.SMBuild @@ -0,0 +1,29 @@ +APP=wireless-regdb +VERSION=2019.06.03 +BUILD=1sml +HOMEPAGE="https://wireless.wiki.kernel.org/en/developers/regulatory/wireless-regdb" +DOWNLOAD="http://ftp.iij.ad.jp/pub/linux/kernel/software/network/wireless-regdb/wireless-regdb-2019.06.03.tar.xz" +DESC="regulatory database package for use by CRDA" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + install -Dm 644 regulatory.bin $PKG/lib/crda/regulatory.bin + install -Dm 644 regulatory.db $PKG/lib/firmware/regulatory.db + install -Dm 644 regulatory.db.p7s $PKG/lib/firmware/regulatory.db.p7s + install -Dm 644 regulatory.bin.5 $PKG/share/man/man5/regulatory.bin.5 + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +73209ca28c59d6760349ffb713f550300e80db1592bae52b6d252ac9401fa2bb2ace7e6c30cf55df7541da9cef4c8587f3790f7aa34529552468e4b63a3d8fdb wireless-regdb-2019.06.03.tar.xz +" diff --git a/base/wiringpi/wiringpi.SMBuild b/base/wiringpi/wiringpi.SMBuild new file mode 100755 index 0000000..a0d4067 --- /dev/null +++ b/base/wiringpi/wiringpi.SMBuild @@ -0,0 +1,51 @@ +APP=wiringpi +VERSION=2.60 +BUILD=1sml +HOMEPAGE="http://wiringpi.com" +DESC="utility for communicating with GPIO pins on the raspberry pi" +REQUIRES="musl" + +build() { + compileonlyfor aarch64 + mkandenterbuilddir + rm -rf $APP-4B + + tar xf $SRCDIR/$APP-4B.tar.?z* + cd $APP-4B + fixbuilddirpermissions + + make -C wiringPi \ + CFLAGS="$CFLAGS -fpic -I." LDFLAGS="$LDFLAGS" \ + WIRINGPI_SONAME_SUFFIX=".$VERSION" + ln -sf libwiringPi.so.$VERSION wiringPi/libwiringPi.so + + make -C devLib \ + CFLAGS="$CFLAGS -fpic -I../wiringPi" LDFLAGS="$LDFLAGS" \ + WIRINGPI_SONAME_SUFFIX=".$VERSION" + ln -sf libwiringPiDev.so.$VERSION devLib/libwiringPiDev.so + + make -C gpio \ + CFLAGS="$CFLAGS -I../wiringPi -I../devLib" \ + LDFLAGS="$LDFLAGS -L../wiringPi -L../devLib" + + # Final packaging. + mkdir $PKG/include + cp wiringPi/*.h devLib/*.h $PKG/include + + install -Dm 755 gpio/gpio $PKG/bin/gpio + install -Dm 755 wiringPi/libwiringPi.so."$VERSION" \ + $PKG/lib/libwiringPi.so."$VERSION" + install -Dm 755 devLib/libwiringPiDev.so."$VERSION" \ + $PKG/lib/libwiringPiDev.so."$VERSION" + + ( cd $PKG/lib ; ln -s libwiringPi.so."$VERSION" libwiringPi.so ) + ( cd $PKG/lib ; ln -s libwiringPiDev.so."$VERSION" libwiringPiDev.so ) + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +a8ee6dc60a32c71f8b9db6ad294ae9affa7f5c99cd546919b8b2b1992f37891a2fb59482cec6ec5afd80b5873c018012245729111bdd43e2c26d61765d570c5c wiringpi-4B.tar.xz +" diff --git a/base/woff2/woff2.SMBuild b/base/woff2/woff2.SMBuild new file mode 100755 index 0000000..81d0100 --- /dev/null +++ b/base/woff2/woff2.SMBuild @@ -0,0 +1,32 @@ +APP=woff2 +VERSION=1.0.2 +BUILD=1sml +HOMEPAGE="https://github.com/google/iwoff2/" +DOWNLOAD="https://github.com/google/woff2/archive/v1.0.2/woff2-1.0.2.tar.gz" +DESC="font compression and decompression library in C++" +REQUIRES="gcc-libs brotli" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + sed -i "s/NOT BUILD_SHARED_LIBS/TRUE/" CMakeLists.txt + mkdir -p smbuild && cd smbuild + cmake .. -GNinja \ + -DCMAKE_INSTALL_PREFIX="" \ + -DCMAKE_INSTALL_LIBDIR=lib + + DESTDIR="$PKG" ninja install + + cp ../LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +7315c05853540c34be1d2223a7999df63518ebe8341ced45ce37d72f2277435653e9c8251c991fd330ab94a16fd77aaa71db281536f175e8ac34cde2668f3471 woff2-1.0.2.tar.lz +" diff --git a/base/x264/x264.SMBuild b/base/x264/x264.SMBuild new file mode 100755 index 0000000..ef17d9e --- /dev/null +++ b/base/x264/x264.SMBuild @@ -0,0 +1,35 @@ +APP=x264 +VERSION=0.155 +BUILD=1sml +VERSIONLONG=snapshot-20180831-2245-stable +HOMEPAGE='http://www.videolan.org/developers/x264.html' +DESC="free h264/avc encoder" +REQUIRES="nasm" + +build() { + mkandenterbuilddir + rm -rf "$APP-$VERSIONLONG" + + tar xf $SRCDIR/$APP-$VERSIONLONG.tar.?z* + cd "$APP-$VERSIONLONG" + fixbuilddirpermissions + + # Let x264 use its own optimized -O3 -ffast-math compiler flags. + unset CFLAGS CXXFLAGS + + ./configure \ + --prefix="" \ + --enable-shared + + make + make install DESTDIR=$PKG + + cp AUTHORS COPYING doc/* $PKGDOCS/ + removestaticlibs + + mkfinalpkg +} + +SHA512SUMS=" +e2472af814c2bf57c0ce293e0b74ca27cd567874ba953dcf995470ba2357b4c1b27a2c51b0033c01afff9d9897ed78f53ca4be30e24036106ec2df5671234223 x264-snapshot-20180831-2245-stable.tar.lz +" diff --git a/base/xmlto/xmlto.SMBuild b/base/xmlto/xmlto.SMBuild new file mode 100755 index 0000000..7b43387 --- /dev/null +++ b/base/xmlto/xmlto.SMBuild @@ -0,0 +1,31 @@ +APP=xmlto +VERSION=0.0.28 +BUILD=1sml +HOMEPAGE="https://pagure.io/xmlto" +DOWNLOAD="https://releases.pagure.org/xmlto/xmlto-0.0.28.tar.bz2" +DESC="XML conversion tool" +REQUIRES="libxslt" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --sysconfdir=/etc + + make + make install DESTDIR=$PKG + + cp COPYING $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +428af553df979773a83136b31766a1a66bcf8524797b5e0a5973d2a28b5296b215765167e7aaa3ecfbed031ed17c72bedcd660c4f854e7673921d50bc1da4584 xmlto-0.0.28.tar.lz +" diff --git a/base/xz/xz.SMBuild b/base/xz/xz.SMBuild new file mode 100755 index 0000000..1aae6e2 --- /dev/null +++ b/base/xz/xz.SMBuild @@ -0,0 +1,34 @@ +APP=xz +VERSION=5.2.5 +BUILD=1sml +HOMEPAGE="https://tukaani.org/xz/" +DOWNLOAD="https://tukaani.org/xz/xz-5.2.5.tar.xz" +DESC="compression utility based on the LZMA algorithm" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" \ + --bindir=/bin \ + --disable-nls \ + --enable-static \ + --with-pic + + make + make install DESTDIR=$PKG + + cp COPYING* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +59266068a51cb616eb31b67cd8f07ffeb2288d1391c61665ae2ec6814465afac80fec69248f6a2f2db45b44475af001296a99af6a32287226a9c41419173ccbb xz-5.2.5.tar.xz +" diff --git a/base/yasm/yasm.SMBuild b/base/yasm/yasm.SMBuild new file mode 100755 index 0000000..962f124 --- /dev/null +++ b/base/yasm/yasm.SMBuild @@ -0,0 +1,32 @@ +APP=yasm +VERSION=1.3.0 +BUILD=1sml +HOMEPAGE="http://www.tortall.net/projects/yasm/" +DOWNLOAD="http://www.tortall.net/projects/yasm/releases/yasm-1.3.0.tar.gz" +DESC="complete rewrite of the NASM assembler" +REQUIRES="musl" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + rm -rv $PKG/lib + + cp GNU* $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +b4a4dc7207dc60387fda5b35c712179d039e492c8970e2aab2d699645169bda60d0f3da4c27cf54baaad7349cf5caf0ad58e3c82f4e74abea00fea5fd8ac1759 yasm-1.3.0.tar.lz +" diff --git a/base/zip/zip.SMBuild b/base/zip/zip.SMBuild new file mode 100755 index 0000000..a944b8e --- /dev/null +++ b/base/zip/zip.SMBuild @@ -0,0 +1,32 @@ +APP=zip +VERSION=30 +BUILD=1sml +HOMEPAGE="http://www.info-zip.org/Zip.html" +DOWNLOAD="https://downloads.sourceforge.net/infozip/zip30.tar.gz" +DESC="compression and file packaging utility" +REQUIRES="bzip2" + +build() { + mkandenterbuilddir + rm -rf "$APP$VERSION" + + tar xf $SRCDIR/$APP$VERSION.tar.?z + cd "$APP$VERSION" + fixbuilddirpermissions + + make -f unix/Makefile generic_gcc \ + CFLAGS="$CFLAGS" + + make prefix="$PKG" -f unix/Makefile install + mkdir -p $PKG/share/man + mv $PKG/man/man* $PKG/share/man/ + rmdir $PKG/man + + cp LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +d2a0bcb3421dfcb205ec656be6d31a61ac59a4d093ee6e2edac5242a4557369cf140fd0040e89281cd90e4d00f04b42cb3a23fb9fd45df4a1efde6040c4035fe zip30.tar.lz +" diff --git a/base/zlib/zlib.SMBuild b/base/zlib/zlib.SMBuild new file mode 100755 index 0000000..a5d68af --- /dev/null +++ b/base/zlib/zlib.SMBuild @@ -0,0 +1,30 @@ +APP=zlib +VERSION=1.2.11 +BUILD=1sml +HOMEPAGE="https://www.zlib.net" +DOWNLOAD="https://www.zlib.net/zlib-1.2.11.tar.xz" +REQUIRES="musl" +DESC="General purpose thread safe data compression library" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + ./configure \ + --prefix="" + + make + make install DESTDIR=$PKG + + cp README $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +93968f26901a68c605d850d67cdee4ffada08b8e7b9fbe8ee062da6d9bc036c8c2d21194b437b00956d9473dff17ff0a8fafb5b19fcdbc460d372c37de9dc45b zlib-1.2.11.tar.lz +" diff --git a/base/zsh/zsh.SMBuild b/base/zsh/zsh.SMBuild new file mode 100755 index 0000000..d367fce --- /dev/null +++ b/base/zsh/zsh.SMBuild @@ -0,0 +1,34 @@ +APP=zsh +VERSION=5.6.2 +BUILD=1sml +HOMEPAGE="http://www.zsh.org" +DOWNLOAD='' +REQUIRES="netbsd-curses gdbm" +DESC="Zsh is a UNIX command interpreter shell that resembles the Korn shell" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + # relieve dependency on autoconf + sed -i '/autoheader/d' Makefile.in + + ./configure \ + --prefix="" \ + --enable-libc-musl + + make + make install DESTDIR=$PKG + + cp LICEN?E $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +29f403fea7947c258a63d3fd33ffa94afa8ca12032cc0d55305e08a5bbc49b53baa9efa9cac0c44eef8e9198239bafc707afcf7ca71c9b9b9941895e436193f7 zsh-5.6.2.tar.lz +" diff --git a/base/zstd/zstd.SMBuild b/base/zstd/zstd.SMBuild new file mode 100755 index 0000000..8f380a8 --- /dev/null +++ b/base/zstd/zstd.SMBuild @@ -0,0 +1,44 @@ +APP=zstd +VERSION=1.4.4 +BUILD=1sml +HOMEPAGE="http://zstd.net" +DOWNLOAD="" +DESC="Zstd is a real-time compression algorithm providing high compression ratios" +REQUIRES="gcc-libs zlib xz lz4" + +build() { + mkandenterbuilddir + rm -rf $APP-$VERSION + + tar xf $SRCDIR/$APP-$VERSION.tar.?z* + cd $APP-$VERSION + fixbuilddirpermissions + + patch -p1 < $SRCDIR/zstd.dont.link.pzstd.to.static.libzstd.a.diff + + make + make -C contrib/pzstd + + make \ + prefix="" \ + libdir="/lib" \ + mandir="/share/man" \ + DESTDIR=$PKG install + + install -Dm 755 contrib/pzstd/pzstd $PKG/bin/pzstd + + # Remove any static libs + rm $PKG/lib/*.a + + # zstdmt and zstd are the same, so symlink them + ( cd $PKG/bin ; ln -sf zstd zstdmt ) + + cp -a COPYING* LICENSE $PKGDOCS/ + + mkfinalpkg +} + +SHA512SUMS=" +f12b6f38bd322a0538179ef90e4c83d2cba29e1fef391a8e8e964785e5761e7ba685f62e9a5a1d6b66171fd64e4fd6374e607569531e2f4c05c470cff2294454 zstd-1.4.4.tar.gz +356a47ea676262c70d0a22c20aedc98a4d1070972ec8910b2bb063c35e32b9beadb09ecab51beab36df24fd678e8948ace3efe485af5208d635dcc7c02d22948 zstd.dont.link.pzstd.to.static.libzstd.a.diff +" diff --git a/base/zstd/zstd.dont.link.pzstd.to.static.libzstd.a.diff b/base/zstd/zstd.dont.link.pzstd.to.static.libzstd.a.diff new file mode 100644 index 0000000..6ecc373 --- /dev/null +++ b/base/zstd/zstd.dont.link.pzstd.to.static.libzstd.a.diff @@ -0,0 +1,13 @@ +--- ./contrib/pzstd/Makefile.orig 2018-12-29 22:36:55.196425576 -0600 ++++ ./contrib/pzstd/Makefile 2018-12-29 22:37:54.123426836 -0600 +@@ -171,8 +171,8 @@ + $(TESTPROG) ./test/RoundTripTest$(EXT) $(TESTFLAGS) + + # Build the main binary +-pzstd$(EXT): main.o $(PROGDIR)/util.o Options.o Pzstd.o SkippableFrame.o $(ZSTDDIR)/libzstd.a +- $(LD_COMMAND) ++pzstd$(EXT): main.o $(PROGDIR)/util.o Options.o Pzstd.o SkippableFrame.o ++ $(LD_COMMAND) -L ../../lib -lzstd + + # Target that depends on all the tests + .PHONY: tests diff --git a/bldpkg b/bldpkg new file mode 100755 index 0000000..e50332c --- /dev/null +++ b/bldpkg @@ -0,0 +1,309 @@ +#!/bin/bash +# Part of the SMLinux distribution +# pktsurf.in + +# Exit on any error +set -e + +# Store the source directory the build file was initiated from inside $SRCDIR +SRCDIR="$PWD" + +# get relative directory name from SRCDIR +SRCDIRRPATH="$(basename $SRCDIR)" + +# verify checksums +verify() { + if [ -z "$SHA512SUMS" ] ; then + echo "sha512 checksums don't exist in $SRCDIRRPATH.SMBuild !" + echo "Please run bldpkg genchecksum" + exit 1 + fi + + eval sums=\"\$SHA512SUMS\" + + echo "Verifying Checksums..." + IFS=$'\n' + for src in $sums; do + echo "$src" | sha512sum -c + done + unset IFS + echo "Looks good..." +} + +# Generate sha512sums in the build file +genchecksum() { + echo "Discarding old SHA512SUMS from $SRCDIRRPATH.SMBuild" + sed -E -i \ + -e '/^SHA512SUMS=".*"$/d' \ + -e '/^SHA512SUMS="/,/"$/d' \ + -e "/^SHA512SUMS='.*'\$/d" \ + -e "/^SHA512sums='/,/'\$/d" \ + "$SRCDIRRPATH".SMBuild + + echo "Adding new SHA512SUMS in $SRCDIRRPATH.SMBuild..." + printf 'SHA512SUMS="\n' >> "$SRCDIRRPATH".SMBuild + + # File types + FILES=( *.tar.* *.zip *.t?z *.patch *.diff *.c *.h ) + + # Checksum digest to be used along with arguments + CHECKSUMBINARY="sha512sum" + + for FILE in ${FILES[@]} ; do + if [ -f "$FILE" ] ; then + $CHECKSUMBINARY $FILE >> "$SRCDIRRPATH".SMBuild + fi + done + printf '"' >> "$SRCDIRRPATH".SMBuild + echo "You may now run bldpkg again without any arguments" + exit 0 +} + + +if [ -n "$1" ] && [ "$1" = "genchecksum" ] ; then + genchecksum +elif [ -n "$1" ] ; then + if [ -f "$1" ]; then + source "$1" + else + echo "File not found!" + exit 1 + fi +elif [ -z $1 ] && [ -f "$SRCDIRRPATH".SMBuild ]; then + source "$SRCDIRRPATH".SMBuild +else + echo "Please provide a build file as an argument" + exit 1 +fi + +#type -t prepbdir + +# Then source the conf file holding all values +. ${BUILDVARS:-/etc/bldpkg.conf} +# This file is executed by bldpkg.conf and assists in preparing a complete build environment. + +# Execute everything inside this condition so that stuff isn't executed and put into the build environment +# unnecessarily when the section build file runs. This happens mostly during autobuilds. +# Get APP and VERSION from the build file +if [ -n "$APP" ] && [ -n "$VERSION" ]; then + + # Display the package and its version we are building + echo "[INFO] Building package $APP version $VERSION ..." + sleep 0.5 + + # Create the $SM_PARENTTEMP directory. This directory is used for everything related to the build process outside + #the source directory $SRCDIR + mkdir -p $SM_PARENTTMP + + # If $SM_HTMLOUTPUT is set to 1, echo $APP, $VERSION and $BUILD as file names inside the parent build directory. + # This will output into an HTML file so that the basic status of the build process (whether started, stopped, + # interrupted or failed) can be viewed in the web browser. + if [ -n "$SM_HTMLOUTPUT" ] && [ "$SM_HTMLOUTPUT" = "1" ] ; then + echo $APP > $SM_PARENTTMP/$APP.APP + echo $VERSION > $SM_PARENTTMP/$APP.VERSION + echo $BUILD > $SM_PARENTTMP/$APP.BUILD + fi + + # Store the source directory the build file was initiated from inside $SRCDIR + #SRCDIR="$PWD" + + # Function to match specifically match arrays inside a value. This function will be used later on to perform package + # and directory matches using certain conditions. Note: "${ARRAY[@]}" =~ "${VARIABLE}" isn't fool-proof. + inarray() { + local n=$1 h + shift + for h ; + do + [[ $n = "$h" ]] && return + done + return 1 + } + + for f in /etc/bldpkg.d/* ; do + source $f + done + + # Time when the build commenced. Note: elapsed time is logged by the runtime function way below. This output goes + # into package build summary. + SM_COMMENCEDATE="$(date '+%a, %d %b %Y, %T')" + + if [ -n "$SM_HTMLOUTPUT" ] && [ "$SM_HTMLOUTPUT" = "1" ] ; then + if [ -n "$SM_AUTOBUILD" ] ; then + cat << EOF >> $SM_PARENTTMP/BUILDMONITOR +$SM_COMMENCEDATE | Building package # $CURRENTPKGNUMBER / $TOTALPKGNUMBER: $APP $VERSION +EOF + else + cat << EOF >> $SM_PARENTTMP/BUILDMONITOR +$SM_COMMENCEDATE | Building package $APP $VERSION +EOF + fi + + touch $SM_PARENTTMP/BUILDING + fi + + # Validate compressor and set extension + validatecompressors + + # Validate tmpfs + validatetmpfs + + # Validate system swap if SM_SWAPCHECK is defined and set to 1 + validateswap + + # Set the temporary directory for building the package. Also define package staging directory. This is where package + # files that get "installed" go into, for example 'make install DESTDIR=$PKG' or 'DESTDIR="$PKG" ninja install'. + + # If SM_USETMPFS is set to 1, SM_TMPFSDIR is defined and SM_TMPFSCHECKFAILED variable is unset, determine if the + # $APP is in the exception list and whether to build inside or outside the TMPFS directory. + if [ "$SM_USETMPFS" = "1" ] && [ -n "$SM_TMPFSDIR" ] && \ + [ -z "$SM_TMPFSCHECKFAILED" ] ; then + + # If $APP is in the TMPFS exception list inside /etc/bldpkg.conf, compile it *OUTSIDE* the TMPFS directory, i.e + # the non-TMPFS directory, else compile it *INSIDE* the TMPFS directory. This if/else is solely for deciding + # whether $APP is in the exception list or not. + if inarray "${APP}" "${SM_TMPFSEXCEPTIONLIST[@]}" ; then + + # We DO NOT compile inside tmpfsdir + SM_TMPFSENABLEDFORTHISPACKAGE=0 + + # In the absence of tmpfs, we use the normal directory + SM_TMP="$SM_NONTMPFSDIR/$APP.src" + PKG=${PKG:-$SM_NONTMPFSDIR/package-$APP} + else + # We compile inside tmpfsdir. Set the TMPFSENABLEDFORTHISPACKAGE variable here to inform build summary function at the bottom + SM_TMPFSENABLEDFORTHISPACKAGE=1 + + # Disable ccache + SM_CCACHE=0 + + # Override SM_PRESERVEBUILDDIR and SM_PRESERVEPACKAGEDIR to remove both build and package directories + SM_PRESERVEBUILDDIR=0 + SM_PRESERVEPACKAGEDIR=0 + + # Get the directory from the SM_TMPFSDIR variable for extracting the source + SM_TMP="$SM_TMPFSDIR/$APP.src" + PKG=${PKG:-$SM_TMPFSDIR/package-$APP} + fi + else + # If SM_USETMPFS is disabled, we compile in the non-TMPFS directory + SM_TMP="$SM_NONTMPFSDIR/$APP.src" + PKG=${PKG:-$SM_NONTMPFSDIR/package-$APP} + fi + + + # Validate and export $SM_CPUTHREADS as MAKEFLAGS variable + if [ -n "$SM_CPUTHREADS" ]; then + # export the user-defined number + MAKEFLAGS="$SM_CPUTHREADS" + export MAKEFLAGS + else + # Or fetch the number from nproc + MAKEFLAGS="$(nproc --all)" + export MAKEFLAGS + fi + + # Invoke validatecompilers function + validatecompilers + + # Apply CPU-specific compiler variables defined inside bldpkg.conf + # https://github.com/sakaki-/gentoo-on-rpi-64bit/blob/master/reference/compile_run_benchmarks.sh + # https://www.raspberrypi.org/forums/viewtopic.php?t=11629 + # noarch is set inside initfs, pkgtools, GTK themes and some other stuff. + + # If $ARCH has not been exported by autobuild or not set in the individual build files that have ARCH=noarch, we set our own + # $HOSTTYPE is only set in the bash shell. + [ -z "$ARCH" ] && ARCH="$HOSTTYPE" + + if [ "$ARCH" = "noarch" ]; then + CFLAGS="" + export CFLAGS + + elif [ "$ARCH" = "aarch64" ]; then + HOSTDIST="$SM_AARCH64HOSTDIST" + BUILDDIST="$SM_AARCH64BUILDDIST" + if [ -n "$SM_DEBUG" ]; then + CFLAGS="$(echo $SM_GCCDEBUG $SM_AARCH64CFLAGS)" + else + CFLAGS="$SM_AARCH64CFLAGS" + fi + CXXFLAGS="$CFLAGS" + export HOSTDIST BUILDDIST CFLAGS CXXFLAGS + + elif [ "$ARCH" = "x86_64" ]; then + BUILDDIST="$SM_X8664BUILDDIST" + if [ -n "$SM_DEBUG" ]; then + CFLAGS="$(echo $SM_GCCDEBUG $SM_X8664CFLAGS)" + else + CFLAGS="$SM_X8664CFLAGS" + fi + CXXFLAGS="$CFLAGS" + export BUILDDIST CFLAGS CXXFLAGS + + else + echo "[ERROR] Sorry! '$ARCH' CPU architecture not supported by SMLinux! Aborting!" + exit 1 + fi + + # Function to do a preliminary package dependency check + checkdependencies + + # If $SM_NOAUTOCONFSITE is unset in an individual package build file, export CONFIG_SITE variable into the build + # environment for a package's configure script to pickup. Most autoconf-compatible configure scripts will + # automatically pick up this variable from the environment and speed up the initial configure process. + if [ -z "$SM_NOAUTOCONFSITE" ] ; then + if [ -n "$SM_CONFIGSITE" ]; then + CONFIG_SITE="$SM_CONFIGSITE" + if [ -e "$CONFIG_SITE" ]; then + export CONFIG_SITE + fi + fi + fi + + # Check if SM_VERIFYCHECKSUMS is set and enabled to 1 and determine whether to continue building or abort if checksums fail + if [ -n "$SM_VERIFYCHECKSUMS" ] && [ "$SM_VERIFYCHECKSUMS" = "1" ] ; then + echo "[INFO] Verifying source checksums..." + if [ -f "$SRCDIR/$APP.CHKSUM512" ] && \ + [ -f "$SRCDIR/$APP.CHKSUM512.sig" ] ; then + # Verify the checksum file using our tool mkchecksums + if [ -x /bin/mkchecksums ] ; then + /bin/mkchecksums -vv + else + echo "/bin/mkchecksums script not found! Aborting!" + exit 1 + fi + else + echo "[ERROR] Checksum files not found! Exiting!" + exit 1 + fi + fi + + # Condition to reuse the AUTOBUILDTEMP file if set from autobuild or make a new temporary file + if [ -n "$SM_AUTOBUILDTEMP" ]; then + SM_TEMPFILE="$SM_AUTOBUILDTEMP" + else + SM_TEMPFILE="$(mktemp $SM_PARENTTMP/SMBUILD.XXXXXX)" + fi + + # https://unix.stackexchange.com/questions/462392/bash-the-function-is-executed-twice + # https://stackoverflow.com/questions/9256644/identifying-received-signal-name-in-bash/9256709 + # We use two traps to identify the signals, EXIT and INT. EXIT will invoke 'prepbuildsummary' function on any exit + # status >= 0. The script fail status is determined by the above SM_PKGSTATUS or any premature compile failure. + # The 'interrruptsummary' function is invoked when the user sends CTRL-C aka SIGINT. The SIGINT trap does not work + # for auto builds, it has been added in the section build file too. + + trap "prepbuildsummary" EXIT + trap "interruptsummary" INT + +fi + +#if [ -z $1 ] ; then +# echo "Please provide a build file or an argument." +# exit 1 +#else +# source $1 +#fi + +verify +#build 2>&1 | tee -a "$APP".SMBuild.log.txt +build + diff --git a/bldpkg.conf b/bldpkg.conf new file mode 100644 index 0000000..b5b4227 --- /dev/null +++ b/bldpkg.conf @@ -0,0 +1,192 @@ +# /etc/bldpkg.conf +# Part of the SMLinux distribution + +# This file allows you to define paths and variable values and prepares a +# complete build environment for creating SMLinux-compatible packages + +# Please refer to sample.SMBuild.explained in the buildsamples directory +# for complete explanation. + +# Set the package extension. Makepkg will use this to figure out the +# compression utility. Pick one out of tbz/tgz/txz/tlz. +PKGEXT="tlz" + +# Set compressor options. These will be exported in the mkfinalpkg function +# for makepkg to pickup. +SM_GZIPOPTS="-9c" +SM_BZIPOPTS="-9c" +SM_LZIPOPTS="-0c" +SM_XZOPTS="-9c" + +# Set this variable if you wish to be prompted for installing (or upgrading) +# the package after it has been built successfully. 0 to disable, 1 to +# enable. Ignored for SSB autobuilds. +SM_INSTALLPROMPT=0 + +# Set this variable if you wish to be prompted for extracting contents of +# the newly-built package installer file into a new subdirectory called +# "test" within the current source directory the build was invoked from. 0 +# to disable, 1 to enable. Ignored for SSB autobuilds. +SM_EXTRACTPROMPT=0 + +# Whether to use distcc for distributed compilations. 0 to disable, 1 to +# enable. +SM_GLOBALDISTCC=1 + +# Whether to use ccache for faster consecutive rebuilds. Set 0 to disable, +# 1 to enable. +SM_GLOBALCCACHE=1 + +# Whether to use sccache for faster consecutive builds. Set 0 to disable, +# 1 to enable. +SM_GLOBALSCCACHE=0 + +# Typical $PATH layout when using ccache + distcc + gcc, assuming gcc is in +# /bin, should be: +# /opt/ccache/bin:/opt/distcc/bin:/bin: +# ccache first, then distcc and then local gcc. Kindly ensure your $PATH is +# set in a similar manner. +# +# HINT: +# To create distcc/ccache symlinks, run this for distcc as an example: +# $ mkdir -p /opt/distcc/bin +# $ for f in cc c++ gcc g++ ; do ln -s /bin/distcc /opt/distcc/bin/$f ; done +# Replace distcc with ccache for creating distcc symlinks + +# Distcc binary location +SM_DISTCCBINPATH="/bin/distcc" +# Distcc symlink paths created for cc/gcc/c++/g++ +SM_DISTCCSYMPATH="/opt/distcc/bin" + +# Ccache binary location +SM_CCACHEBINPATH="/bin/ccache" +# Ccache symlink paths created for cc/gcc/c++/g++ +SM_CCACHESYMPATH="/opt/ccache/bin" + +# Sccache binary location +SM_SCCACHEBINPATH="/bin/sccache" +# Scache hardlink paths created for cc/gcc/c++/g++ +SM_SCCACHEPATH="/opt/sccache/bin" + +# Define the distcc timeout period in seconds. This prevents distcc from +# falling back to local compiler if a distributed job takes a long time to +# complete. We set it to 30 minutes instead of 5 minutes which is default. +DISTCC_IO_TIMEOUT="1800" + +# Define network hosts who will take part in the compile. Please refer to +# distcc manual for complete info. Must be defined in /etc/hosts unless they +# are an IP. Tip: Distcc by default will use only 2 cores on the local +# machine. +DISTCC_HOSTS="--randomize localhost/3 mx/3,lzo" + +# Add sum total of the above CPU cores/threads or add your own count +# prepended with "-j". +SM_CPUTHREADS="-j6" + +# Declare a parent temporary directory +SM_PARENTTMP="/tmp" + +# Whether to use tmpfs for the package build. The package source will be +# extracted and compiled inside the tmpfs directory and ccache will be +# disabled to prevent writes to the disk. 1 to enable, 0 to disable. +SM_USETMPFS=0 + +# Set the tmpfs directory if the above variable is enabled +SM_TMPFSDIR="$SM_PARENTTMP/tmpfsdir" + +# Define the nontmpfs base directory +SM_NONTMPFSDIR="$SM_PARENTTMP/sml" + +# Directory where the final package installer, example: +# openssh-8.1-x86_64-1sml.tlz should be placed in. Again, should be outside +# tmpfs dir. Also declared and defined in autobuild section file, so values +# may differ. This is for manual builds. +PKGDEST=${PKGDEST:-$SM_PARENTTMP/sml/packages/} + +# Whether you want to preserve the build directory which contains the +# extracted source, for example /tmp/sml/openssh.src/openssh-8.1. +# SM_USETMPFS, if set to 1, will auto-reset this variable to 0 and the build +# directory will be deleted. Set 1 to preserve it, 0 to rm -rf it +# automatically at the end of each build +SM_PRESERVEBUILDDIR=1 + +# Whether you want to preserve the package directory. for example +# /tmp/sml/package-openssh SM_USETMPFS, if set to 1, will auto-reset this +# variable to 0 and the package directory will be deleted. Set 1 to preserve +# it, 0 to rm -rf it automatically at the end of each build +SM_PRESERVEPACKAGEDIR=1 + +# Whether to show build summary. Set to 1 to enable, 0 to disable. +SM_SHOWSUMMARY=1 + +# Whether to show colours in the build summary. Set 1 to enable, 0 to +# disable. Also, only show colours if the build is invoked manually and not +# through the SSB autobuild system where logging is automatic or when +# logging is invoked using log ./. +[ -z "$SM_COLOURS" ] && SM_COLOURS=1 + +# Define whether to check for swap. 1 to enable, 0 to disable. +SM_SWAPCHECK=1 + +# If above variable is set to 1, define minimum swap size required for huge +# compiles in KiB +SM_SWAPSIZE=2048000 + +# Define your compilers here. They must be in $PATH *AFTER* ccache and +# distcc directories +CC="gcc" +CXX="g++" +export CC CXX + +# Set CPU-specific compiler variables. Only aarch64 and x86_64 supported. +# https://github.com/sakaki-/gentoo-on-rpi-64bit/blob/master/reference/compile_run_benchmarks.sh +# https://www.raspberrypi.org/forums/viewtopic.php?t=11629 +# Set debug flag +SM_GCCDEBUG="-g3" +# For aarch64 +# aarch64-musl-linux is not recognised by most configure scripts and I haven't +# seen any compile except for gmp going wrong with arm-musl-linux +SM_AARCH64HOSTDIST="--host=arm-musl-linux" +SM_AARCH64BUILDDIST="--build=arm-musl-linux" +SM_AARCH64CFLAGS="-O2 -fPIC -pipe -march=armv8-a+crc -mtune=cortex-a53" +# For x86_64 +SM_X8664BUILDDIST="--build=x86_64-musl-linux" +SM_X8664CFLAGS="-O2 -fPIC -pipe" + +# Set path to configure cache file that contains predefined answers to several +# tests autoconf scripts run. Credits: Sabotage Linux. +SM_CONFIGSITE="/etc/config.cache" + +# Whether to verify tarball checksums contained in checksums.$APP files inside +# source directories. Path to smlinux public key file and signify binaries +# handled by the mkchecksums script. +SM_VERIFYCHECKSUMS=0 + +# This array lists the packages whose sources will not be extracted and +# compiled inside tmpfs, if tmpfs is <= 2GB. If your tmpfs is >= 2GB, empty +# out this entire list. +SM_TMPFSEXCEPTIONLIST=( firefox palemoon qemu dovecot gdb gimp gnumeric \ +gtk+2 gtk+3 guile llvm mariadb mesa mesa-demos mupdf perl postfix python2 \ +python3 rtorrent spice python-lxml qtbase kernel libreoffice mono \ +qtwebengine kernel-source rust ) + +# This array lists the packages which require additional swap for +# compilation to prevent the system from becoming completely unresponsive +# for want of more memory. +SM_PACKAGESREQUIRINGSWAP=( firefox palemoon qemu gdb gimp gnumeric gtk+2 \ +gtk+3 guile llvm mariadb mesa mupdf libtorrent rtorrent qtbase \ +qtwebengine ) + +# This array is to protect important system directories from being rm -rf'd +# accidentally. Sometimes you never know what value the variable being +# expanded as an argument for rm -rf holds, so prevention is better. +# Populate this list appropriately and use it inside an if/else whenever +# rm -rf is about to be called. +SM_PROTECTEDDIRECTORIES=( "/bin" "/boot" "/dev" "/etc" "/home" "/include" \ +"/lib" "/lib64" "/libexec" "/local" "/man" "/media" "/mnt" "/opt" "/proc" \ +"/root" "/run" "/sbin" "/share" "/srv" "/sys" "/tmp" "/usr" "/var" ) + +# Whether to output application build status in HTML format. Set 1 to enable, +# 0 to disable. +SM_HTMLOUTPUT=1 + diff --git a/bldpkg.d/checkdependencies b/bldpkg.d/checkdependencies new file mode 100755 index 0000000..ecd0aca --- /dev/null +++ b/bldpkg.d/checkdependencies @@ -0,0 +1,20 @@ +# Function to do a preliminary package dependency check +checkdependencies() { + echo "Parsing $APP 's dependency list..." + + for PACKAGEDEP in $REQUIRES; do + DEPCOUNT="$(find /doc -name $PACKAGEDEP.SMBuild | wc -l)" + # If count is 1, we are ok + if [ "$DEPCOUNT" == "1" ] ; then + echo "Found dependency $PACKAGEDEP" + # If count is 0, we exit, because we are in trouble + elif [ "$DEPCOUNT" == "0" ] ; then + echo "Did not find dependency $PACKAGEDEP ! Aborting!" + exit 1 + # If count is greater than or equal to 2, we are in slightly less trouble + elif [ "$DEPCOUNT" -ge "2" ] ; then + echo "Warning! Found multiple versions of $PACKAGEDEP !" + sleep 0.5 + fi + done +} diff --git a/bldpkg.d/compileonlyfor b/bldpkg.d/compileonlyfor new file mode 100755 index 0000000..c8dcc22 --- /dev/null +++ b/bldpkg.d/compileonlyfor @@ -0,0 +1,14 @@ +# Function to prevent a package from compiling on an unsupported architecture +compileonlyfor() { + # usage: compileonlyfor + # will cause compilation to exit with 0 if uname -m does not match + archname="$(uname -m)" + archargument=$1 + if [ "$archname" != "$archargument" ]; then + echo "" + echo "[INFO] '"$APP"' not supported on '"$archname"' and hence not" + echo "[INFO] not being built. Exiting." + exit 0 + fi +} + diff --git a/bldpkg.d/fixbuilddirpermissions b/bldpkg.d/fixbuilddirpermissions new file mode 100755 index 0000000..6588d56 --- /dev/null +++ b/bldpkg.d/fixbuilddirpermissions @@ -0,0 +1,10 @@ +# Function to fix permissions inside the build directory +# To be invoked inside a package build file. +fixbuilddirpermissions() { + echo -n "[INFO] Fixing permissions in the newly-created build directory..." + chown -R root.root . + find -L . -perm /111 -a \! -perm 755 -a -exec chmod 755 {} \+ -o \ + \! -perm /111 -a \! -perm 644 -a -exec chmod 644 {} \+ || true + echo " done." +} + diff --git a/bldpkg.d/interruptsummary b/bldpkg.d/interruptsummary new file mode 100755 index 0000000..b5f670f --- /dev/null +++ b/bldpkg.d/interruptsummary @@ -0,0 +1,17 @@ +# This function will set the interrupt variable so prepbuildsummary can output the right build status on receiving +# ctrl-c from the user during a manual build. +interruptsummary() { + echo "Caught Keyboard Interrupt..." + SM_WASINTERRUPTED="1" + # If SM_INSTALLPROMPT and SM_EXTRACTPROMPT are set and the prompt is invoked after a successful build, hitting + # ctrl-C will only set the above SM_WASINTERRUPTED variable repeatedly and won't return user to the shell because + # of the interrupt (SIGINT) trap set way below. Putting exit 0 is a decent way to get out of that prompt + + # Clean up stale files like $APP.APP, $APP.BUILD and $APP.VERSION + if [ -z "$SM_AUTOBUILD" ] ; then + rm -f $SM_PARENTTMP/$APP.APP,BUILD,VERSION} + fi + + exit 0 +} + diff --git a/bldpkg.d/mkandenterbuilddir b/bldpkg.d/mkandenterbuilddir new file mode 100755 index 0000000..5137cef --- /dev/null +++ b/bldpkg.d/mkandenterbuilddir @@ -0,0 +1,25 @@ +# Function to remove old package directories and make new ones. +# To be invoked inside a package build file. +mkandenterbuilddir() { + # $TMP, $PKG and $PKGDEST are set in bldpkg.conf. + PKGDOCS="$PKG/doc/$APP-$VERSION" + # Remove any old $PKG staging directory left by any previous build. + # We are about to rm -rf something, so trying a bit hard not to delete + # the wrong directory + if ! inarray "${PKG}" "${SM_PROTECTEDDIRECTORIES[@]}" ; then + rm -rf "$PKG" + else + systemdirectorydeletionmessage + echo "'"$PKG"' IS LISTED AS A PROTECTED DIRECTORY BUT +ACCIDENTALLY LISTED AS A VALUE FOR "'$PKG'" VARIABLE!! ABORTING!!" + exit 1 + fi + + # Now create all essential build-related directories + mkdir -p "$SM_TMP" "$PKG" "$PKGDOCS" "$PKGDEST" + + echo "[INFO] Leaving source directory $SRCDIR" + echo "[INFO] Entering build directory $SM_TMP" + cd "$SM_TMP" +} + diff --git a/bldpkg.d/mkfinalpkg b/bldpkg.d/mkfinalpkg new file mode 100755 index 0000000..516218c --- /dev/null +++ b/bldpkg.d/mkfinalpkg @@ -0,0 +1,142 @@ +# Function to perform post-compile tasks: +# To be invoked inside a package build file. +mkfinalpkg() { + # Now we attempt to split the total time we'll get when making the summary into two times: compile time and + # packaging time. Here we store the value of $SECONDS variable the moment makefinalpkg is invoked. We use this + # value as the compile time, because this is the next function that's called by the build script the moment a + # successful compile make install DESTDIR=$PKG or something similar. + + # SM_COMPILETIMEA will store the exact seconds + SM_COMPILETIMEA="$SECONDS" + + # SM_COMPILETIMEB will run the runtime function against SM_COMPILETIMEA and store the resulting output + SM_COMPILETIMEB="$( runtime $SM_COMPILETIMEA )" + + echo "[INFO] Leaving build directory $SM_TMP" + echo "[INFO] Entering staging directory $PKG" + cd $PKG + echo "[INFO] Just a min..." + echo "[INFO] Copying post-install files..." + mkdir -p "$PKG/install" + + for f in doinst.sh ; do + [ -e "$SRCDIR/$f" ] && cp "$SRCDIR/$f" "$PKG/install/" + done + + # Compress and link manpages + if [ -d "$PKG/share/man" ]; then + echo "[INFO] Compressing and linking man pages..." + ( cd "$PKG/share/man" + for manpagedir in $(find . -type d -name "man*") ; do + ( cd "$manpagedir" + for eachpage in $( find . -type l -maxdepth 1) ; do + ln -s "$( readlink "$eachpage" ).gz" "$eachpage".gz + rm "$eachpage" + done + gzip -9 ./*.? >/dev/null 2>&1 || true + ) + done + ) + fi + + SM_TOTALFILECOUNT="$(find $PKG -type f | wc -l)" + SM_TOTALDIRCOUNT="$(find $PKG -type d | wc -l)" + SM_TOTALSYMCOUNT="$(find $PKG -type l | wc -l)" + SM_PACKUSIZE1="$(du -s $PKG | awk '{print $1}')" + + # Remove .la files similar to what slackware devs are doing in slackware-current, but in a more efficient manner :) + echo "[INFO] Discarding any libtool archive (.la) files..." + find "$PKG" ! -type d -name "*.la" -exec rm -v {} \; + + # Provide a copy of the package build file so that users know the build options that went into compiling the package + install -Dm 644 "$SRCDIR/$APP.SMBuild" "$PKGDOCS/$APP.SMBuild" + + # Now strip the binaries and shared libraries + if [ -z "$SM_DEBUG" ] && [ "$SM_DEBUG" != "1" ]; then + find "$PKG" -print0 | xargs -0 file -m /etc/file/magic/elf | \ + grep -E "executable|shared object|statically linked" | grep "ELF" | \ + cut -d: -f1 | xargs strip --strip-unneeded 2>/dev/null || true + fi + + # And static libraries separately unconditionally + find "$PKG" -print0 | xargs -0 file -m /etc/file/magic/archive | \ + grep -E "current ar archive" | awk '{print $1}' | cut -d: -f1 | \ + xargs strip --strip-unneeded 2>/dev/null || true + + # Here we ascertain the packaging time taken to actually prepare the final package. For this, we must reset the + # SECONDS variable to ensure accuracy + SECONDS=0 + + # Finally create the package + /bin/makepkg -l y -c n "$PKGDEST/$APP-$VERSION-$ARCH-$BUILD.$PKGEXT" + SM_PKGSTATUS=$? + + # Store package location inside this variable: + SM_PACKLOCATION="$PKGDEST/$APP-$VERSION-$ARCH-$BUILD.$PKGEXT" + + echo "[INFO] Leaving staging directory $PKG" + + # cd back to $SRCDIR when SM_PRESERVEPACKAGEDIR is set to 0 to prevent this error: shell-init: error retrieving + # current directory: getcwd: cannot access parent directories: No such file or directory + echo "[INFO] Re-entering source directory $SRCDIR" + cd "$SRCDIR" + + # Discard $APP.APP, $APP.BUILD and $APP.VERSION files if SM_AUTOBUILDTEMP is not set. If SM_AUTOBUILDTEMP is set, + # there's no need to discard these files because it's auto-discarded by the section build file itself. + if [ -n "$SM_HTMLOUTPUT" ] && [ "$SM_HTMLOUTPUT" = "1" ] ; then + if [ -z "$SM_AUTOBUILDTEMP" ] ; then + rm -f $SM_PARENTTMP/$APP.{APP,BUILD,VERSION} + fi + fi + + # With SECONDS reset, the shell will add in a fresh value, which we can now use to ascertain the packaging time, + # by again passing that value as an argument to the runtime function + SM_PACKAGETIMEA="$SECONDS" + SM_PACKAGETIMEB="$( runtime $SM_PACKAGETIMEA )" + + # Determine size of SRCDIR aka source directory + SM_SRCDIRSIZE="$(du -s $SRCDIR | awk '{print $1}')" + # Determine size of SM_TMP aka build directory size + SM_BUILDDIRSIZE="$(du -s $SM_TMP | awk '{print $1}')" + + # Calculate SSD write savings if TMPFS has been used + if [ "$SM_USETMPFS" = "1" ] && \ + [ "$SM_TMPFSENABLEDFORTHISPACKAGE" = "1" ] ; then + + # Determine size of staging directory + SM_PKGDIRSIZE="$(du -s $PKG | awk '{print $1}')" + + # Sum total of the above two variables is the amount of writes we saved + SM_TMPFSSAVINGSSUM0="$(( $SM_BUILDDIRSIZE + $SM_PKGDIRSIZE ))" + + # We'll get sum in kB. Convert that to MB. + SM_TMPFSSAVINGSSUM1="$(echo "scale=2 ; "$SM_TMPFSSAVINGSSUM0" / 1024" | bc)" + + # Store the result for build summary to pickup. + SM_TMPFSSAVINGSSIZE="$(echo and $SM_TMPFSSAVINGSSUM1"MB" writes to SSD saved)" + fi + + # Delete the build directory if SM_PRESERVEBUILDDIR is set to 0 + if [ "$SM_PRESERVEBUILDDIR" = "0" ] ; then + if ! inarray "${SM_TMP}" "${SM_PROTECTEDDIRECTORIES[@]}" ; then + rm -rf "$SM_TMP" + else + systemdirectorydeletionmessage + echo "'"$SM_TMP"' IS LISTED AS A PROTECTED DIRECTORY BUT \ +ACCIDENTALLY LISTED AS A VALUE FOR "'$SM_TMP'" VARIABLE!! EXITING!!" + exit 1 + fi + fi + + # Delete the package build directory if SM_PRESERVEPACKAGEDIR is set to 0 + if [ "$SM_PRESERVEPACKAGEDIR" = "0" ] ; then + if [[ ! "${SM_PROTECTEDDIRECTORIES[@]}" =~ "${PKG}" ]] ; then + rm -rf "$PKG" + else + systemdirectorydeletionmessage + echo "'"$PKG"' IS LISTED AS A PROTECTED DIRECTORY BUT ACCIDENTALLY\ + LISTED AS A VALUE FOR "'$PKG'" VARIABLE!! EXITING!!" + exit 1 + fi + fi +} diff --git a/bldpkg.d/prepbuildsummary b/bldpkg.d/prepbuildsummary new file mode 100755 index 0000000..b95f802 --- /dev/null +++ b/bldpkg.d/prepbuildsummary @@ -0,0 +1,300 @@ +prepbuildsummary() { + # Start of the SM_SHOWSUMMARY if/else check + if [ -n "$SM_SHOWSUMMARY" ] && [ "$SM_SHOWSUMMARY" = "1" ]; then + # Get the build completion time and store it in a variable + SM_FINISHDATE="$(date '+%a, %d %b %Y, %T')" + + # Stick to 8/16 colours, those are supported on most terminals + if [ "$SM_COLOURS" = "1" ]; then + SM_COLOURSCHECK="$(tput colors 2>/dev/null)" + if [ "$?" = "0" ] && [ "$SM_COLOURSCHECK" -gt "2" ] ; then + # Red when the build fails + SM_COLOURR="\e[41m" + # Yellow when the build is interrupted + SM_COLOURY="\e[93m" + # Green when the build succeeds + SM_COLOURG="\e[92m" + # Cyan for the short questions + SM_COLOURC="\e[96m" + # APPNAME/VERSION Colours + SM_COLOURV="\e[92m" + # Restore to default + SM_COLOURD="\e[0m" + fi + fi + + # Determine the build type + if [ -n "$SM_AUTOBUILD" ]; then + # We are using Tadgy's autobuild system + SM_BUILDSYS="SSB Autobuild" + else + # We compiled the package manually + SM_BUILDSYS="Manual" + fi + + + # Determine if distcc was used. If SM_GLOBALDISTCC is enabled and set to 1 and SM_DISTCC is not declared in the + # package build file, then set SM_DSTATS in the build summary + if [ -n "$SM_GLOBALDISTCC" ] && [ "$SM_GLOBALDISTCC" = "1" ] && \ + [ -z "$SM_DISTCC" ]; then + SM_DSTATS="Yes" + # Else if SM_GLOBALDISTCC is enabled and set to 1 and SM_DISTCC is set to 0 in the package build file, then set + # SM_DSTATS in the build summary + elif [ -n "$SM_GLOBALDISTCC" ] && [ "$SM_GLOBALDISTCC" = "1" ] && \ + [ "$SM_DISTCC" = "0" ]; then + SM_DSTATS="Nope, disabled but global variable set" + # Else If SM_GLOBALDISTCC is unset, set SM_DSTATS in the build summary + elif [ -z "$SM_GLOBALDISTCC" ] || [ "$SM_GLOBALDISTCC" = "0" ]; then + SM_DSTATS="No, disabled globally" + fi + + + # Determine if ccache was used. Ccache caches compiler objects to disk, which speeds up subsequent compiles. + # However, if we are compiling inside tmpfs, we are not using ccache at all. So we set SM_CSTATS accordingly + # in the build summary + if [ -n "$SM_GLOBALCCACHE" ] && [ "$SM_GLOBALCCACHE" = "1" ] && \ + [ -n "$SM_USETMPFS" ] && [ "$SM_USETMPFS" = "1" ] && \ + [ -n "$SM_TMPFSENABLEDFORTHISPACKAGE" ] && \ + [ "$SM_TMPFSENABLEDFORTHISPACKAGE" = "1" ] ; then + SM_CSTATS="Enabled globally but disabled due to tmpfs" + + elif [ -n "$SM_GLOBALCCACHE" ] && [ "$SM_GLOBALCCACHE" = "1" ] && \ + [ -n "$SM_USETMPFS" ] && [ "$SM_USETMPFS" = "0" ] ; then + SM_CSTATS="Yes" + + elif [ -n "$SM_GLOBALCCACHE" ] && [ "$SM_GLOBALCCACHE" = "1" ] && \ + [ -z "$SM_USETMPFS" ] ; then + SM_CSTATS="Yes" + + elif [ -z "$SM_GLOBALCCACHE" ] || [ "$SM_GLOBALCCACHE" = "0" ] ; then + SM_CSTATS="No, disabled globally" + fi + + + # Determine the build type + if [ "$SM_DEBUG" = "1" ] ; then + SM_BLDTYPE="*DEBUG* build" + else + SM_BLDTYPE="General build, no debug symbols" + fi + + + # Determine whether tmpfs was used + if [ "$SM_USETMPFS" = "1" ] && \ + [ "$SM_TMPFSENABLEDFORTHISPACKAGE" = "1" ] ; then + SM_TMPFSSTATE="Yes" + + elif [ "$SM_USETMPFS" = "1" ] && \ + [ "$SM_TMPFSENABLEDFORTHISPACKAGE" = "0" ]; then + SM_TMPFSSTATE="*Not for this package* but enabled globally" + + elif [ "$SM_USETMPFS" = "1" ] && \ + [ "$SM_TMPFSCHECKFAILED" = "1" ]; then + SM_TMPFSSTATE="*NOPE, TMPFS DIRECTORY CHECK FAILED* but enabled globally" + + else + SM_TMPFSSTATE="No, disabled globally" + fi + + + if [ -n "$SM_CPUTHREADS" ]; then + SM_MAKEFLAGS="$MAKEFLAGS, manually set" + else + SM_MAKEFLAGS="$MAKEFLAGS, auto-detected" + fi + + # If SM_COMPILETIMEA is set, then do a sum total of SM_COMPILETIMEA and SM_PACKAGETIMEA variables to get the + # total time in seconds and use that as an argument for the runtime function. If SM_COMPILETIMEA is not set, + # invoke the runtime function alone on new reset $SECONDS + if [ -n "$SM_COMPILETIMEA" ]; then + SM_FINALCOMPILETIME="$(( $SM_COMPILETIMEA + $SM_PACKAGETIMEA ))" + SM_TOTALTIME="$( runtime $SM_FINALCOMPILETIME )" + else + SM_TOTALTIME="$( runtime $SECONDS )" + fi + + # Determine if the build was successful or not + if [ "$SM_PKGSTATUS" = "0" ] ; then + SM_BLDSTATUS="$(echo -e "$SM_COLOURG"'Successful! :-D' \ +"$SM_COLOURD")" + + if [ -n "$SM_HTMLOUTPUT" ] && [ "$SM_HTMLOUTPUT" = "1" ] ; then + cat << EOF >> $SM_PARENTTMP/BUILDMONITOR.html +$APP $VERSION$SM_COMMENCEDATE$SM_FINISHDATE$SM_TOTALTIMESUCCEEDED +EOF + + rm -f $SM_PARENTTMP/BUILDING + fi + + # Determine the compressed size + SM_PACKSIZE="$(du -bk "$SM_PACKLOCATION" | awk '{print $1}')" + + # Determine the uncompressed size + SM_PACKUSIZE="$(echo $SM_PACKUSIZE1)" + + elif [ "$SM_WASINTERRUPTED" = "1" ]; then + SM_BLDSTATUS="$(echo -e "$SM_COLOURY"\ +'** INTERRUPTED ** :-/'"$SM_COLOURD")" + + if [ -n "$SM_HTMLOUTPUT" ] && [ "$SM_HTMLOUTPUT" = "1" ] ; then + cat << EOF >> $SM_PARENTTMP/BUILDMONITOR.html +$APP $VERSION$SM_COMMENCEDATE$SM_FINISHDATE$SM_TOTALTIMEINTERRUPTED +EOF + + rm -f $SM_PARENTTMP/BUILDING + fi + + else + SM_BLDSTATUS="$(echo -e "$SM_COLOURR"'!! FAILED !! :-('\ +"$SM_COLOURD")" + + if [ -n "$SM_HTMLOUTPUT" ] && [ "$SM_HTMLOUTPUT" = "1" ] ; then + cat << EOF >> $SM_PARENTTMP/BUILDMONITOR.html +$APP $VERSION$SM_COMMENCEDATE$SM_FINISHDATE$SM_TOTALTIME>FAILED +EOF + + rm -f $SM_PARENTTMP/BUILDING + fi + + + fi + + + # Finally prepare the summary + echo "" >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC"---------------------------------------------\ +----------------------------------" \ + >> "$SM_TEMPFILE" + + echo -e " BUILD SUMMARY FOR PACKAGE "$SM_COLOURD"'"$SM_COLOURV"\ +"$APP""$SM_COLOURD"'"$SM_COLOURC" VERSION "$SM_COLOURD"'"$SM_COLOURV"\ +"$VERSION"'" "$SM_COLOURC"TAG"$SM_COLOURV" "'$BUILD'"$SM_COLOURD"" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC"---------------------------------------------\ +----------------------------------"$SM_COLOURD"" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" Build Status:"$SM_COLOURD" \ +$SM_BLDSTATUS" \ + >> "$SM_TEMPFILE" + + + # Output the section name if SM_AUTOBUILDTEMP is set. This means we are running an autobuild. + if [ -n "$SM_AUTOBUILDTEMP" ]; then + echo -e ""$SM_COLOURC" Build Section:"$SM_COLOURD" $SECTION" \ + >> "$SM_TEMPFILE" + fi + + + # If we have $SM_COMPILETIMEB set, then assume the compile went well and output compile and packaging times + # into SM_TEMPFILE. + if [ -n "$SM_TOTALTIME" ] && [ -z "$SM_PACKAGETIMEB" ]; then + echo -e ""$SM_COLOURC" Total Time: "$SM_COLOURD" $SM_TOTALTIME" \ + >> "$SM_TEMPFILE" + elif [ -n "$SM_TOTALTIME" ] && [ -n "$SM_PACKAGETIMEB" ]; then + echo -e ""$SM_COLOURC" Total Time: "$SM_COLOURD" $SM_TOTALTIME \ +( $SM_COMPILETIMEB Compile ) + ( $SM_PACKAGETIMEB Packaging )" \ + >> "$SM_TEMPFILE" + fi + + + echo -e ""$SM_COLOURC" Started:"$SM_COLOURD" $SM_COMMENCEDATE" \ + >> "$SM_TEMPFILE" + echo -e ""$SM_COLOURC" Stopped:"$SM_COLOURD" $SM_FINISHDATE" \ + >> "$SM_TEMPFILE" + + # If the package was built successfully, output the installer sizes + if [ "$SM_PKGSTATUS" = "0" ]; then + #SM_COMPRESSEDSIZE="$(echo $(($SM_PACKSIZE * 100 / $SM_PACKUSIZE)))" + # Space saving = 1 - Compressed Size / Uncompressed size. + # Also, bc code taken from: + # https://stackoverflow.com/questions/56945130/bash-echo-percentage-with-no-decimal-point-with-result-returned-from-bc-comman + SM_COMPRESSEDSIZE="$(echo $(echo "scale=2 ; 1 - "$SM_PACKSIZE" / \ + "$SM_PACKUSIZE"" | bc ) | sed 's@.@@')" + + echo -e ""$SM_COLOURC" Source Size: "$SM_COLOURD" Compressed: \ +$SM_SRCDIRSIZE"K", Uncompressed: $SM_BUILDDIRSIZE"K"" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" Package Size: "$SM_COLOURD" Uncompressed: \ +$SM_PACKUSIZE"K", Compressed: $SM_PACKSIZE"K" ("$SM_COMPRESSEDSIZE'%'")" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" Package Has: "$SM_COLOURD" \ +$SM_TOTALFILECOUNT files and $SM_TOTALSYMCOUNT symlinks in $SM_TOTALDIRCOUNT \ +directories" \ + >> "$SM_TEMPFILE" + + fi + + + # If ccache was used, output the current cache used size and max allocated size + if [ "$SM_GLOBALCCACHE" = "1" ] && [ "$SM_CCACHE" != "0" ] && \ + [ "$SM_CSTATS" = "Yes" ]; then + SM_CCACHEUSEDSIZE="$(ccache -s | grep "cache size" | head -n 1 | \ + awk '{ $1=$2="" ; print $0}')" + SM_CCACHETOTALSIZE="$(ccache -s | grep "max cache size" | \ + awk '{ $1=$2=$3="" ; print $0}')" + + echo -e ""$SM_COLOURC" Ccache Used?"$SM_COLOURD" "$SM_CSTATS",\ +"$SM_CCACHEUSEDSIZE" /"$SM_CCACHETOTALSIZE" Allocated" \ + >> "$SM_TEMPFILE" + + else + echo -e ""$SM_COLOURC" Ccache Used?"$SM_COLOURD" "$SM_CSTATS"" \ + >> "$SM_TEMPFILE" + + fi + + echo -e ""$SM_COLOURC" Distcc Used?"$SM_COLOURD" $SM_DSTATS" \ + >> "$SM_TEMPFILE" + + + # If distcc was used, cut out --randomize and output rest of the DISTCC_HOSTS variable + if [ "$SM_GLOBALDISTCC" = "1" ] && [ "$SM_DISTCC" != "0" ]; then + echo -e ""$SM_COLOURC" Distcc Args: "$SM_COLOURD" $(echo \ +"$DISTCC_HOSTS" | sed 's@--randomize@@')" \ + >> "$SM_TEMPFILE" + fi + + + echo -e ""$SM_COLOURC" TMPFS Used? "$SM_COLOURD" "$SM_TMPFSSTATE" $SM_TMPFSSAVINGSSIZE" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" CPU Threads: "$SM_COLOURD" $(echo $SM_MAKEFLAGS | \ + sed 's@-j@@')" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" CFLAGS Used: "$SM_COLOURD" $CFLAGS" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" Compressor: "$SM_COLOURD" $COMPRESSOR \ +($COMPRESSOPTS)" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC" Build Type:" $SM_COLOURD" $SM_BUILDSYS \ +& $SM_BLDTYPE" \ + >> "$SM_TEMPFILE" + + echo -e ""$SM_COLOURC"---------------------------------------------------\ +----------------------------"$SM_COLOURD"" \ + >> "$SM_TEMPFILE" + + + # Output the build summary to the user on every build + cat $SM_TEMPFILE + + # Once the output is shown, discard all temporary files + rm -f $SM_TEMPFILE + if [ -z "$SM_AUTOBUILD" ] ; then + rm -f $SM_PARENTTMP/$APP.{APP,BUILD,VERSION} + fi + fi + # Completion of the SM_SHOWSUMMARY if/else check + + # Invoke the promptuser variable + promptuser +} + diff --git a/bldpkg.d/preprunitservice b/bldpkg.d/preprunitservice new file mode 100755 index 0000000..133b9cb --- /dev/null +++ b/bldpkg.d/preprunitservice @@ -0,0 +1,44 @@ +# Function to prepare runit service directories for a particular daemon +# To be invoked inside a package build file. +preprunitservice() { + + # usage: $ preprunitservice + # Will create the chrony service directories with a down and a finish file to prevent auto-execution at next boot + # and to provide a clean exit respectively. Use the first argument to define the service name + rsname=$1 + # Use the second argument to add the down file + down=$2 + # Use the third argument to add the finish file + finish=$3 + + # Enter the staging directory + cd "$PKG" + + # Create the service directories + mkdir -p "etc/service/$1" var/service + + # Copy the service run file from the source directory into etc/service/$1 + if [ -f "$SRCDIR/$1.run" ] ; then + cp "$SRCDIR/$1.run" "etc/service/$1/run" + else + echo "$1.run does not exist! Exiting" + exit 1 + fi + + # If the second argument is "down", or if the second argument is "finish", create that file inside etc/service/$1/ + if [ "$2" = "down" ]; then + touch "etc/service/$1/down" + elif [ "$2" = "finish" ]; then + cp "$SRCDIR/$1.$2" "etc/service/$1/finish" + fi + + # If the third argument is "finish", copy that file from the source directory into etc/service/$1/ + [ -n "$3" ] && cp "$SRCDIR/$1.$3" "etc/service/$1/finish" + + # Create the symlinks between etc/service and var/service + ln -s "../../etc/service/$1" "var/service/$1" + + # Finally set the executable permissions on the run file + chmod 0755 "$PKG/etc/service/$1/run" +} + diff --git a/bldpkg.d/promptuser b/bldpkg.d/promptuser new file mode 100755 index 0000000..0634f5e --- /dev/null +++ b/bldpkg.d/promptuser @@ -0,0 +1,56 @@ +promptuser() { + # Prompt the user at the end of a build whether to extract contents of a newly-built installer into a subdirectory + # called "test" inside the package source directory the build was manually initiated from. Has no effect on + # autobuilds since they are simply installed right away. + if [ "$SM_EXTRACTPROMPT" = "1" ] && [ -z "$SM_AUTOBUILD" ] && \ + [ -n "$SM_PACKLOCATION" ] ; then + while true ; do + echo + echo "[NOTIFY] '"$APP"' has been built and SM_EXTRACTPROMPT is enabled in" + echo "[NOTIFY] bldpkg.conf file. Would you like to extract and examine contents" + echo "[NOTIFY] of its package installer in a 'test' directory within the" + echo "[NOTIFY] current source directory" + echo "[NOTIFY] ($SRCDIR) ?" + + read -r -p "[NOTIFY] Old test directory, if it exists already, will \ +be overwritten. (y/N) " yn + + case $yn in + [Yy]* ) echo "[INFO] Wise choice :-) "; + mkdir -p "$SRCDIR"/test + tar xvf "$SM_PACKLOCATION" -C "$SRCDIR"/test + echo "" + echo "[INFO] '"$APP"' package installer file successfully\ + extracted" + break;; + *) echo "[INFO] Nope? Alright." ; break ;; + esac + done + fi + + + # Prompt the user at the end of a successful build whether to install the newly created package. Has no effect on + # autobuilds because packages there are installed automatically. + if [ "$SM_INSTALLPROMPT" = "1" ] && [ -z "$SM_AUTOBUILD" ] && \ + [ -n "$SM_PACKLOCATION" ] ; then + while true ; do + echo + + echo "[NOTIFY] '"$APP"' successfully built and SM_INSTALLPROMPT is \ +enabled in the bldpkg.conf file." + + read -r -p "[NOTIFY] Would you like to install/upgrade it? (y/N) " yn + case $yn in + [Yy]* ) echo "[INFO] Wise choice :-) " + upgradepkg --install-new "$SM_PACKLOCATION" + break;; + *) echo "[INFO] Nope? Alright." ; exit 0 ;; + esac + done + fi + + + if [ -n "$SM_PKGSTATUS" ] && [ "$SM_PKGSTATUS" = "0" ]; then + exit 0 + fi +} diff --git a/bldpkg.d/removestaticlibs b/bldpkg.d/removestaticlibs new file mode 100755 index 0000000..873b9dd --- /dev/null +++ b/bldpkg.d/removestaticlibs @@ -0,0 +1,7 @@ +# Function to remove static libraries for use inside build scripts +# To be invoked inside a package build file. +removestaticlibs() { + echo "[INFO] Discarding static libraries..." + find "$PKG" -name "*.a" -exec rm -fv {} \; +} + diff --git a/bldpkg.d/runtime b/bldpkg.d/runtime new file mode 100755 index 0000000..9919cdf --- /dev/null +++ b/bldpkg.d/runtime @@ -0,0 +1,18 @@ +# Function to calculate elapsed build time. runtime takes the $SECONDS variable as an argument. $SECONDS is an +# environment variable set by bash to show the number of whole seconds the shell has been running. +runtime() { + [ -z "$1" ] && return 1 + + local D=$(( $1 / 86400 )) + local H=$(( ($1 - ($D * 86400)) / 3600 )) + local M=$(( ($1 - ($D * 86400) - ($H * 3600)) / 60 )) + local S=$(( $1 - ($D * 86400) - ($H * 3600) - ($M * 60) )) + + if [ "$D" -gt "0" ]; then + echo -n "${D}d, ${H}h ${M}m ${S}s" + else + echo -n "${H}h, ${M}m ${S}s" + fi + return 0 +} + diff --git a/bldpkg.d/systemdirectorydeletionmessage b/bldpkg.d/systemdirectorydeletionmessage new file mode 100755 index 0000000..67be9fa --- /dev/null +++ b/bldpkg.d/systemdirectorydeletionmessage @@ -0,0 +1,5 @@ +systemdirectorydeletionmessage() { + echo "############ ATTENTION ############" + echo "I JUST STOPPED AN IMPORTANT SYSTEM DIRECTORY FROM BEING DELETED!!" +} + diff --git a/bldpkg.d/validatecompilers b/bldpkg.d/validatecompilers new file mode 100755 index 0000000..bef5244 --- /dev/null +++ b/bldpkg.d/validatecompilers @@ -0,0 +1,232 @@ +# Validate compilers +validatecompilers() { +# Validate everything related to distcc if SM_GLOBALDISTCC is set + if [ -n "$SM_GLOBALDISTCC" ] && [ "$SM_GLOBALDISTCC" = "1" ] ; then + # Check if distcc exists and is an executable + if [ ! -x "$SM_DISTCCBINPATH" ]; then + echo "[ERROR] Oops! Distcc binary was not found but building with it" + echo "[ERROR] was requested! Either ensure distcc is in your "'$PATH'" or" + echo "[ERROR] disable this option in bldpkg file. bldpkg file" + echo "[ERROR] is located in $BUILDVARS ! Aborting!" + exit 1 + fi + + # Check if the symlinks are right + if [ ! "$(echo "$PATH" | grep "$SM_DISTCCSYMPATH")" ] ; then + echo "[ERROR] $SM_DISTCCSYMPATH not found in "'$PATH'"! Fix it please." + exit 1 + elif [ ! -d "$SM_DISTCCSYMPATH" ] ; then + echo "[ERROR] $SM_DISTCCSYMPATH directory containing symlinks to distcc" + echo "[ERROR] does not exist! Kindly create it and create symlinks" + echo "[ERROR] based on instructions in bldpkg.conf! Aborting!" + exit 1 + fi + + # Trace symlinks to the binary + for f in gcc g++ cc c++ ; do + if [ -e "$SM_DISTCCSYMPATH/$f" ] && [ -L "$SM_DISTCCSYMPATH/$f" ]; then + # We use "realpath" to follow the $SM_DISTCCSYMPATH/$f symlink and act on the exit code. + if [ "$(realpath -e "$SM_DISTCCSYMPATH/$f")" != "$SM_DISTCCBINPATH" ] ; then + echo "[ERROR] $SM_DISTCCSYMPATH/$f does not point to $SM_DISTCCBINPATH. " + echo "[ERROR] Kindly fix this! Aborting!" + exit 1 + fi + else + echo "[ERROR] $f either does not exist or is not a symlink inside" + echo "[ERROR] $SM_DISTCCSYMPATH. Kindly fix this! Aborting!" + exit 1 + fi + + #echo -n "Validating distcc $f compiler... " + + # This is a really small C program taken from autoconf tests + #cat << EOF > $SM_PARENTTMP/distcccheck-"$f".c +#int +#main() +#{ +# ; +# return 0; +#} +#EOF + + #"$SM_DISTCCSYMPATH/$f" -o $SM_PARENTTMP/distcccheck-"$f" $SM_PARENTTMP/distcccheck-"$f".c + #CHECKSTATUS="$?" + + # Discard the files once the validation passes/fails + #if [ "$CHECKSTATUS" == "0" ] ; then + # echo "[OK]" + # rm $SM_PARENTTMP/distcccheck-"$f"{,.c} + #else + # echo "Something's up with distcc $f" + # rm $SM_PARENTTMP/distcccheck-"$f"{,.c} + # exit 1 + #fi + + done + + # If SM_DISTCC=0 is set in the package build file to disable distcc, remove the value of $SM_DISTCCSYMPATH from + # $PATH otherwise export DISTCC_HOSTS and DISTCC_IO_TIMEOUT variables. + if [ "$SM_DISTCC" = "0" ] ; then + PATH="$(echo "$PATH" | sed "s@:$SM_DISTCCSYMPATH@@g")" + export PATH + else + export DISTCC_HOSTS DISTCC_IO_TIMEOUT + fi + else + # Remove $SM_DISTCCSYMPATH + PATH="$(echo "$PATH" | sed "s@:$SM_DISTCCSYMPATH@@g")" + export PATH + fi + + # Validate everything related to ccache if SM_GLOBALCCACHE is set + if [ -n "$SM_GLOBALCCACHE" ] && [ "$SM_GLOBALCCACHE" = "1" ]; then + if [ ! -x "$SM_CCACHEBINPATH" ] ; then + echo "[ERROR] Oops! ccache binary was not found but building with it" + echo "[ERROR] was requested! Either ensure ccache is in your "'$PATH'" or" + echo "[ERROR] disable this option in bldpkg.conf. bldpkg.conf" + echo "[ERROR] file is located in $BUILDVARS . Aborting!" + exit 1 + fi + + if [ ! "$(echo $PATH | grep "$SM_CCACHESYMPATH")" ] ; then + echo "[ERROR] $SM_CCACHESYMPATH not found in "'$PATH!'" Fix it please." + exit 1 + elif [ ! -d "$SM_CCACHESYMPATH" ] ; then + echo "[ERROR] $SM_CCACHESYMPATH directory containing symlinks to ccache" + echo "[ERROR] does not exist! Kindly create it and create symlinks" + echo "[ERROR] based on instructions in bldpkg.conf. Aborting!" + exit 1 + fi + + for f in gcc g++ cc c++ ; do + if [ -e "$SM_CCACHESYMPATH/$f" ] && [ -L "$SM_CCACHESYMPATH/$f" ]; then + # We use "realpath" to follow the $SM_CCACHESYMPATH/$f symlink and + # # act on the exit code. + if [ "$(realpath -e "$SM_CCACHESYMPATH/$f")" != "$SM_CCACHEBINPATH" ] ; then + echo "[ERROR] $SM_CCACHESYMPATH/$f does not point to $SM_CCACHEBINPATH. " + echo "[ERROR] Kindly fix this! Aborting!" + exit 1 + fi + else + echo "[ERROR] $f either does not exist or is not a symlink inside $SM_CCACHESYMPATH" + echo "[ERROR] Kindly fix this! Aborting!" + exit 1 + fi + + #echo -n "Validating ccache $f compiler... " + + # This is a really small C program taken from autoconf tests + #cat << EOF > $SM_PARENTTMP/ccachecheck-"$f".c +#int +#main() +#{ +# ; +# return 0; +#} +#EOF + + #"$SM_CCACHESYMPATH/$f" -o $SM_PARENTTMP/ccachecheck-"$f" $SM_PARENTTMP/ccachecheck-"$f".c + #CHECKSTATUS="$?" + + # Discard the files once the validation passes/fails + #if [ "$CHECKSTATUS" == "0" ] ; then + # echo "[OK]" + # rm $SM_PARENTTMP/ccachecheck-"$f"{,.c} + #else + # echo "Something's up with ccache $f" + # rm $SM_PARENTTMP/ccachecheck-"$f"{,.c} + # exit 1 + #fi + + done + + # If SM_CCACHE=0 is set in the package build file to disable ccache, remove the value of SM_CCACHESYMPATH + # from $PATH and export it again + if [ "$SM_CCACHE" = "0" ]; then + PATH="$(echo "$PATH" | sed "s@$SM_CCACHESYMPATH:@@g")" + export PATH + fi + else + # Remove $SM_CCACHESYMPATH + PATH="$(echo "$PATH" | sed "s@$SM_CCACHESYMPATH:@@g")" + export PATH + fi + + # Validate everything related to sccache if SM_GLOBALCCACHE is set + if [ -n "$SM_GLOBALSCCACHE" ] && [ "$SM_GLOBALSCCACHE" = "1" ]; then + if [ ! -x "$SM_SCCACHEBINPATH" ] ; then + echo "[ERROR] Oops! sccache binary was not found but building with it" + echo "[ERROR] was requested! Either ensure sccache is in your "'$PATH'" or" + echo "[ERROR] disable this option in bldpkg.conf. bldpkg.conf" + echo "[ERROR] file is located in $BUILDVARS . Aborting!" + exit 1 + fi + + if [ ! "$(echo $PATH | grep "$SM_SCCACHEPATH")" ] ; then + echo "[ERROR] $SM_SCCACHEPATH not found in "'$PATH!'" Fix it please." + exit 1 + elif [ ! -d "$SM_SCCACHEPATH" ] ; then + echo "[ERROR] $SM_SCCACHEPATH directory containing symlinks to ccache" + echo "[ERROR] does not exist! Kindly create it and create symlinks" + echo "[ERROR] based on instructions in bldpkg.conf. Aborting!" + exit 1 + fi + + for f in gcc g++ cc c++ ; do + # A hard link is basically a copy of a file with the same inode number stored in a different location. + # We are trying a bit hard to ascertain whether a binary is a hard link or not. + # First get the inode number of the binary in the original location + SM_SCCACHE_BINARY_INODE_NUM="$(stat --printf '%i\n' $SM_SCCACHEBINPATH)" + # Then get the inode number of the file inside the hard link path + SM_SCCACHE_HARDLINK_FILE_INODE_NUM="$(stat --printf '%i\n' $SM_SCCACHEPATH/$f)" + + if [ ! -e "$SM_SCCACHEPATH/$f" ] ; then + echo "[ERROR] $f either does not exist inside $SM_SCCACHEPATH" + echo "[ERROR] Kindly fix this! Aborting!" + exit 1 + # If the hard link's inode number does not match the original binary's inode number, throw an error and exit + elif [ "$SM_SCCACHE_HARDLINK_FILE_INODE_NUM" != "$SM_SCCACHE_BINARY_INODE_NUM" ] ; then + echo "[ERROR] File '"$f"' inside $SM_SCCACHEPATH is not a hard link!" + echo "[ERROR] Kindly fix this! Aborting!" + exit 1 + fi + + #echo -n "Validating sccache $f compiler... " + + # This is a really small C program taken from autoconf tests + #cat << EOF > $SM_PARENTTMP/sccachecheck-"$f".c +#int +#main() +#{ +# ; +# return 0; +#} +#EOF + + #"$SM_SCCACHEPATH/$f" -o $SM_PARENTTMP/sccachecheck-"$f" $SM_PARENTTMP/sccachecheck-"$f".c + #CHECKSTATUS="$?" + + # Discard the files once the validation passes/fails + #if [ "$CHECKSTATUS" == "0" ] ; then + # echo "[OK]" + # rm $SM_PARENTTMP/sccachecheck-"$f"{,.c} + #else + # echo "Something's up with sccache $f" + # rm $SM_PARENTTMP/sccachecheck-"$f"{,.c} + # exit 1 + #fi + + done + + # If SM_SCCACHE=0 is set in the package build file to disable sccache, remove the value of SM_SCCACHEPATH + # from $PATH and export it again + if [ "$SM_SCCACHE" = "0" ]; then + PATH="$(echo "$PATH" | sed "s@$SM_SCCACHEPATH:@@g")" + export PATH + fi + else + # Remove $SM_SCCACHEPATH + PATH="$(echo "$PATH" | sed "s@$SM_SCCACHEPATH:@@g")" + export PATH + fi +} diff --git a/bldpkg.d/validatecompressors b/bldpkg.d/validatecompressors new file mode 100755 index 0000000..8ca892e --- /dev/null +++ b/bldpkg.d/validatecompressors @@ -0,0 +1,35 @@ +validatecompressors() { +# Validate package extension set in bldpkg.conf + SM_VALIDPKGEXTENSIONS=( "tgz" "tbz" "tlz" "txz" ) + if ! inarray "${PKGEXT}" "${SM_VALIDPKGEXTENSIONS[@]}" ; then + echo "[ERROR] $PKGEXT is not a valid package extension for an SMLinux" + echo "[ERROR] installer file! Aborting!" + exit 1 + fi + + # Figure out the compression tool to be used based on the $PKGEXT variable set in bldpkg.conf. At the same time, + # export the compressor options set for makepkg to import from the build environment. + case "$PKGEXT" in + tgz) COMPRESSOR=gzip + COMPRESSOPTS="$SM_GZIPOPTS" + export COMPRESSOPTS ;; + tbz) COMPRESSOR=bzip2 + COMPRESSOPTS="$SM_BZIPOPTS" + export COMPRESSOPTS ;; + tlz) COMPRESSOR=lzip + COMPRESSOPTS="$SM_LZIPOPTS" + export COMPRESSOPTS ;; + txz) COMPRESSOR=xz + COMPRESSOPTS="$SM_XZOPTS" + export COMPRESSOPTS ;; + esac + + echo -n "Validating $COMPRESSOR...." + # Borrowed from slackware's installpkg utility + if ! $COMPRESSOR --help 1> /dev/null 2> /dev/null ; then + echo "[FAILED]" + exit 1 + else + echo "[OK]" + fi +} diff --git a/bldpkg.d/validateswap b/bldpkg.d/validateswap new file mode 100755 index 0000000..7744ebd --- /dev/null +++ b/bldpkg.d/validateswap @@ -0,0 +1,20 @@ +validateswap() { +# Validate system swap if SM_SWAPCHECK is defined and set to 1 + if [ -n "$SM_SWAPCHECK" ] && [ "$SM_SWAPCHECK" = "1" ]; then + if inarray "${APP}" "${SM_PACKAGESREQUIRINGSWAP[@]}" ; then + + # Here we determine available system swap size needed to compile exceptional packages that pull in a lot of RAM. + # Those packages are listed under the SM_PACKAGESREQUIRINGSWAP array in /etc/bldpkg.conf. Check whether swap + #is available on the system and if it is, determine its size. If its size is >= SM_SWAPSIZE, we are all good. + #If it's less than SM_SWAPSIZE, we exit with a status 1. + + SM_SWAPCHECK="$(grep "SwapFree" /proc/meminfo | awk '{print $2}')" + if [ "$SM_SWAPCHECK" -lt "$SM_SWAPSIZE" ]; then + echo "[ERROR] Insufficient swap to build '"$APP"' which is listed" + echo "[ERROR] in $SM_PACKAGESREQUIRINGSWAP. Kindly add/increase" + echo "[ERROR] swap size on this system and try again. Aborting!" + exit 1 + fi + fi + fi +} diff --git a/bldpkg.d/validatetmpfs b/bldpkg.d/validatetmpfs new file mode 100755 index 0000000..adaa308 --- /dev/null +++ b/bldpkg.d/validatetmpfs @@ -0,0 +1,11 @@ +validatetmpfs() { +# Validate the TMPFS directory. If SM_USETMPFS is set to 1 and SM_TMPFSDIR variable is set, then check for + # genuineness of the TMPFS directory. If it fails, declare a variable for the build summary. + if [ "$SM_USETMPFS" = "1" ] && [ -n "$SM_TMPFSDIR" ]; then + if [ ! -d "$SM_TMPFSDIR" ] || [ ! -w "$SM_TMPFSDIR" ] \ + || [ "$(findmnt -no TARGET $SM_TMPFSDIR)" != "$SM_TMPFSDIR" ] \ + || [ "$(findmnt -no FSTYPE $SM_TMPFSDIR)" != "tmpfs" ]; then + SM_TMPFSCHECKFAILED=1 + fi + fi +}