Index: Makefile
===================================================================
--- Makefile (nonexistent)
+++ Makefile (revision 5)
@@ -0,0 +1,436 @@
+
+COMPONENT_TARGETS = $(HARDWARE_INTEL_PC32)
+COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
+COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
+COMPONENT_TARGETS += $(HARDWARE_CB1X)
+COMPONENT_TARGETS += $(HARDWARE_CB2X)
+COMPONENT_TARGETS += $(HARDWARE_CB3X)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
+COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
+COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
+COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
+COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
+COMPONENT_TARGETS += $(HARDWARE_POIN2)
+COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
+COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
+COMPONENT_TARGETS += $(HARDWARE_M201)
+COMPONENT_TARGETS += $(HARDWARE_MXV)
+COMPONENT_TARGETS += $(HARDWARE_P201)
+COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
+COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
+COMPONENT_TARGETS += $(HARDWARE_P212)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
+COMPONENT_TARGETS += $(HARDWARE_Q201)
+COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
+COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
+COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
+COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
+COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
+COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
+COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
+COMPONENT_TARGETS += $(HARDWARE_CI20)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
+COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
+COMPONENT_TARGETS += $(HARDWARE_S824L)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN)
+COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
+COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
+COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
+COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)
+
+
+NEED_ABS_PATH = true
+COMPONENT_IS_3PP = true
+
+
+include ../../../build-system/constants.mk
+
+
+SOURCE_REQUIRES = sources/packages/n/cyrus-imapd
+
+REQUIRES = app/util-linux/2.38.1
+REQUIRES += app/mariadb/10.6.5
+REQUIRES += app/postgresql/14.1
+REQUIRES += app/sqlite/3.39.4.0
+REQUIRES += dev/perl/5.36.0
+REQUIRES += libs/jansson/2.13.1
+REQUIRES += libs/libxml2/2.9.9
+REQUIRES += libs/icu4c/68.2
+REQUIRES += libs/zstd/1.5.2
+REQUIRES += libs/zlib/1.2.13
+REQUIRES += libs/pcre/8.44
+REQUIRES += net/tcp_wrappers/7.6
+REQUIRES += net/cyrus-sasl/2.1.27
+REQUIRES += net/openssl/1.1.1r
+REQUIRES += net/krb5/1.19.1
+REQUIRES += net/libtirpc/1.3.1
+REQUIRES += net/libnsl/1.3.0
+REQUIRES += secure/libcap/2.48
+
+# ======= __END_OF_REQUIRES__ =======
+
+
+version = 3.4.4
+tar_xz_archive = $(SRC_PACKAGE_PATH)/packages/n/cyrus-imapd/cyrus-imapd-$(version).tar.xz
+SRC_ARCHIVE = $(tar_xz_archive)
+SRC_DIR = $(TARGET_BUILD_DIR)/cyrus-imapd-$(version)
+src_dir_name = cyrus-imapd-$(version)
+src_done = $(TARGET_BUILD_DIR)/.source_done
+
+PATCHES = PATCHES
+
+build_target = $(TARGET_BUILD_DIR)/.build_done
+install_target = $(TARGET_BUILD_DIR)/.install_done
+
+
+####### Targets
+
+PKG_GROUP = net
+
+#
+# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
+#
+IMAPD_PKG_NAME = cyrus-imapd
+IMAPD_PKG_VERSION = 3.4.4
+IMAPD_PKG_ARCH = $(PKGARCH)
+IMAPD_PKG_DISTRO_NAME = $(DISTRO_NAME)
+IMAPD_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
+IMAPD_PKG_GROUP = $(PKG_GROUP)
+### |---handy-ruler-------------------------------|
+IMAPD_PKG_SHORT_DESCRIPTION = Cyrus IMAP server
+IMAPD_PKG_URL = $(BUG_URL)
+IMAPD_PKG_LICENSE = Carnegie
+IMAPD_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(IMAPD_PKG_NAME)-pkg-description
+IMAPD_PKG_DESCRIPTION_FILE_IN = $(IMAPD_PKG_NAME)-pkg-description.in
+IMAPD_PKG_INSTALL_SCRIPT = $(TARGET_BUILD_DIR)/$(IMAPD_PKG_NAME)-pkg-install.sh
+IMAPD_PKG_INSTALL_SCRIPT_IN = $(IMAPD_PKG_NAME)-pkg-install.sh.in
+
+IMAPD_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(IMAPD_PKG_NAME)-package
+
+pkg_basename = $(IMAPD_PKG_NAME)-$(IMAPD_PKG_VERSION)-$(IMAPD_PKG_ARCH)-$(IMAPD_PKG_DISTRO_NAME)-$(IMAPD_PKG_DISTRO_VERSION)
+
+pkg_archive = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
+pkg_certificate = $(call cert-name,$(pkg_archive))
+pkg_signature = $(call sign-name,$(pkg_archive))
+pkg_description = $(call desc-name,$(pkg_archive))
+products = $(call pkg-files,$(pkg_archive))
+
+BUILD_TARGETS = $(build_target)
+BUILD_TARGETS += $(install_target)
+
+PRODUCT_TARGETS = $(products)
+
+ROOTFS_TARGETS = $(pkg_archive)
+
+
+include ../../../build-system/core.mk
+
+
+env_sysroot = DESTDIR=$(IMAPD_PKG)
+
+
+#
+# Common Perl5 Environment:
+# ========================
+#
+perl_args = INSTALLDIRS=vendor
+
+perl_args += PERL_LIB='$(TARGET_DEST_DIR)/usr/share/perl5'
+perl_args += PERL_ARCHLIB='$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/perl5'
+perl_args += PERL_INC='$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/perl5/CORE'
+perl_args += PERL_INCDEP='$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/perl5/CORE'
+
+perl_args += SITELIBEXP='/usr/share/perl5/site_perl'
+perl_args += SITEARCHEXP='/usr/lib$(LIBSUFFIX)/perl5/site_perl'
+perl_args += VENDORLIBEXP='/usr/share/perl5/vendor_perl'
+perl_args += VENDORARCHEXP='/usr/lib$(LIBSUFFIX)/perl5/vendor_perl'
+
+perl_args += PERLPREFIX='/usr'
+perl_args += INSTALLPRIVLIB='/usr/share/perl5'
+perl_args += INSTALLARCHLIB='/usr/lib$(LIBSUFFIX)/perl5'
+
+perl_args += SITEPREFIX='/usr'
+perl_args += INSTALLSITELIB='/usr/share/perl5/site_perl'
+perl_args += INSTALLSITEARCH='/usr/lib$(LIBSUFFIX)/perl5/site_perl'
+
+perl_args += VENDORPREFIX='/usr'
+perl_args += INSTALLVENDORLIB='/usr/share/perl5/vendor_perl'
+perl_args += INSTALLVENDORARCH='/usr/lib$(LIBSUFFIX)/perl5/vendor_perl'
+
+perl_args += INSTALLBIN='/usr/bin'
+perl_args += INSTALLSITEBIN='/usr/bin'
+perl_args += INSTALLVENDORBIN='/usr/bin'
+
+perl_args += INSTALLSCRIPT='/usr/bin'
+perl_args += INSTALLSITESCRIPT='/usr/bin'
+perl_args += INSTALLVENDORSCRIPT='/usr/bin'
+
+perl_args += INSTALLMAN1DIR='/usr/share/man/man1'
+perl_args += INSTALLSITEMAN1DIR='/usr/share/man/man1'
+perl_args += INSTALLVENDORMAN1DIR='/usr/share/man/man1'
+
+perl_args += INSTALLMAN3DIR='/usr/share/man/man3'
+perl_args += INSTALLSITEMAN3DIR='/usr/share/man/man3'
+perl_args += INSTALLVENDORMAN3DIR='/usr/share/man/man3'
+
+#
+# HW Specific Perl5 Environment:
+# =============================
+#
+perl_args += PREFIX='/usr'
+perl_args += AR='$(AR)'
+perl_args += RANLIB='$(RANLIB)'
+perl_args += CC='$(CC) --sysroot=$(TARGET_DEST_DIR)'
+perl_args += LD='$(CC) --sysroot=$(TARGET_DEST_DIR)'
+perl_args += LDFLAGS='$(LDFLAGS) -L$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/perl5/CORE'
+perl_args += CCFLAGS='$(ARCH_OPTIMIZATION) $(ARCH_FLAGS) $(ARCH_DEFS) -I$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/perl5/CORE'
+perl_args += LDDLFLAGS='-L$(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/perl5/CORE -shared'
+perl_args += CCCDLFLAGS='-fPIC'
+perl_args += CCDLFLAGS='-Wl,-E -Wl,-rpath,/usr/lib$(LIBSUFFIX)/perl5/CORE'
+perl_args += FULL_AR='$(AR)'
+perl_args += OSNAME='linux'
+perl_args += LIBC=
+perl_args += OSVERS=
+
+perl_local_pod = usr/lib$(LIBSUFFIX)/perl5/perllocal.pod
+
+extra_configure_switches = --libdir=/usr/lib$(LIBSUFFIX)
+extra_configure_switches += --docdir=/usr/share/doc/$(src_dir_name)
+extra_configure_switches += --mandir=/usr/share/man
+
+extra_configure_switches += --disable-dependency-tracking
+
+extra_configure_switches += --sysconfdir=/etc
+extra_configure_switches += --localstatedir=/var
+
+extra_configure_switches += --with-sasl=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-libwrap=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-openssl=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --enable-gssapi=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-krb=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-krb5-config=$(TARGET_DEST_DIR)/usr/bin/krb5-config
+extra_configure_switches += --with-ldap=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-zlib=$(TARGET_DEST_DIR)/usr
+
+extra_configure_switches += --without-krbdes
+extra_configure_switches += --with-libcap
+
+extra_configure_switches += --with-perl=$(PERL)
+
+extra_configure_switches += --with-cyrus-user=cyrus
+extra_configure_switches += --with-pidfile=/var/run/cyrus-master.pid
+
+extra_configure_switches += --enable-autocreate
+extra_configure_switches += --enable-idled
+
+#
+# Available Data base backends: pgsql, musql, sqlite
+#
+DATA_BASES = pgsql mysql sqlite
+
+ifeq ($(filter pgsql, $(DATA_BASES)),pgsql)
+extra_configure_switches += --with-pgsql=$(TARGET_DEST_DIR)/usr
+extra_configure_switches += --with-pgsql-incdir=$(TARGET_DEST_DIR)/usr/include/pgsql
+extra_configure_switches += --with-pgsql-libdir=$(TARGET_DEST_DIR)/usr/lib
+endif
+ifeq ($(filter mysql, $(DATA_BASES)),mysql)
+extra_configure_switches += --with-mysql=yes
+extra_configure_switches += mysql_config=$(TARGET_DEST_DIR)/usr/bin/$(TARGET)-mysql_config
+endif
+ifeq ($(filter sqlite, $(DATA_BASES)),sqlite)
+extra_configure_switches += --with-sqlite=$(TARGET_DEST_DIR)/usr
+endif
+
+ifeq ($(__ENABLE_STATIC__),yes)
+extra_configure_switches += --enable-static=yes
+else
+extra_configure_switches += --enable-static=no
+endif
+extra_configure_switches += --enable-shared=yes
+
+
+extra_env_vars = ZSTD_CFLAGS=$(TARGET_DEST_DIR)/usr/include
+extra_env_vars += ZSTD_LIBS=-lzstd
+
+extra_env_vars += XML2_CFLAGS=$(TARGET_DEST_DIR)/usr/include
+extra_env_vars += XML2_LIBS=-lxml2
+
+extra_env_vars += YFLAGS='-v --warnings=no-yacc --warnings=no-deprecated'
+
+
+TARGET_BIN_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX)
+TARGET_LIB_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX):/usr/lib/../lib$(LIBSUFFIX)
+
+
+####### Dependencies
+
+$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
+ $(UNPACK_SRC_ARCHIVE)
+ $(APPLY_PATCHES)
+ @( cd $(SRC_DIR) ; autoreconf -fiv --warnings=none )
+ @( cd $(SRC_DIR) ; \
+ sed -i "s|@PERL_MAKER_ARGS@|$(perl_args)|g" configure ; \
+ )
+ @touch $@
+
+$(build_target): $(src_done)
+ @cd $(SRC_DIR) && \
+ $(BUILD_ENVIRONMENT) PYTHON=$(PYTHON3) $(extra_env_vars) ../$(src_dir_name)/configure \
+ --prefix=/usr \
+ --build=$(BUILD) \
+ --host=$(TARGET) \
+ $(extra_configure_switches)
+ @cd $(SRC_DIR) && $(BUILD_ENVIRONMENT) $(MAKE)
+ @touch $@
+
+$(install_target): $(build_target)
+ @mkdir -p $(IMAPD_PKG)
+ @cd $(SRC_DIR) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
+ @find $(IMAPD_PKG) -name '.packlist' -delete
+ @rm -f $(IMAPD_PKG)/$(perl_local_pod)
+ @find $(IMAPD_PKG)/usr/lib/perl5 -name '*.so' -exec chmod 0755 {} \;
+ @mkdir -p $(IMAPD_PKG)/etc/rc.d
+ # ======= Install Config Files =======
+ @cat $(SRC_DIR)/doc/examples/cyrus_conf/normal.conf > $(IMAPD_PKG)/etc/cyrus.conf.new
+ @cat $(SRC_DIR)/doc/examples/imapd_conf/normal.conf > $(IMAPD_PKG)/etc/imapd.conf.new
+ @install -m 0644 -D $(CURDIR)/rc.d/rc.cyrus-imapd $(IMAPD_PKG)/etc/rc.d/rc.cyrus-imapd.new
+ # ======= Create Directories =======
+ @mkdir -p $(IMAPD_PKG)/var/{lib,run,spool}/cyrus
+ @mkdir -p $(IMAPD_PKG)/var/run/cyrus/socket
+ @mkdir -p $(IMAPD_PKG)/var/spool/sieve
+ @mkdir -p $(IMAPD_PKG)/var/lib/imap
+ # ======= Compress man pages =======
+ @if [ -d $(IMAPD_PKG)/usr/share/man ]; then \
+ ( cd $(IMAPD_PKG)/usr/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 ; \
+ find . -type f -name "*.?" -exec gzip -9 {} \; ; \
+ ) \
+ done \
+ ) \
+ fi
+ # ======= Install Documentation =======
+ @mkdir -p $(IMAPD_PKG)/usr/doc/$(src_dir_name)
+ @cp -a $(SRC_DIR)/COPYING \
+ $(IMAPD_PKG)/usr/doc/$(src_dir_name)
+ @mkdir -p $(IMAPD_PKG)/usr/share/doc/$(src_dir_name)
+ @( cd $(SRC_DIR) ; \
+ cp -a COPYING README* doc/* tools \
+ $(IMAPD_PKG)/usr/share/doc/$(src_dir_name) ; \
+ )
+ @( cd $(IMAPD_PKG)/usr/share/doc/$(src_dir_name)/html ; \
+ rm -f .buildinfo objects.inv ; \
+ )
+ @( cd $(SRC_DIR) ; \
+ if [ -r ChangeLog ]; then \
+ DOCSDIR=`echo $(IMAPD_PKG)/usr/share/doc/$(src_dir_name)` ; \
+ cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
+ touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
+ fi \
+ )
+ # ======= Remove toolchain path from target libtool *.la files =======
+ @( cd $(IMAPD_PKG)/usr/lib$(LIBSUFFIX) ; \
+ sed -i "s,$(TARGET_DEST_DIR),,g" libcyrus.la libcyrus_imap.la \
+ libcyrus_min.la libcyrus_sieve.la ; \
+ sed -i "s,lib$(BUILD_MULTILIB_SUFFIX),lib$(LIBSUFFIX),g" libcyrus.la libcyrus_imap.la \
+ libcyrus_min.la libcyrus_sieve.la ; \
+ )
+ # ======= Remove toolchain path from target pkgconfig *.pc files =======
+ @( cd $(IMAPD_PKG)/usr/lib$(LIBSUFFIX)/pkgconfig ; \
+ sed -i "s,$(TARGET_DEST_DIR),,g" libcyrus.pc libcyrus_imap.pc \
+ libcyrus_min.pc libcyrus_sieve.pc ; \
+ )
+ # ======= Install the same to $(TARGET_DEST_DIR) =======
+ $(call install-into-devenv, $(IMAPD_PKG))
+ # ======= Tune libtool *.la search path to the target destination for development =======
+ @( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX) ; \
+ sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libcyrus.la libcyrus_imap.la \
+ libcyrus_min.la libcyrus_sieve.la ; \
+ sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" libcyrus.la libcyrus_imap.la \
+ libcyrus_min.la libcyrus_sieve.la ; \
+ )
+ # ======= Tune pkg-config *.pc files to the target destination for development =======
+ @( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/pkgconfig ; \
+ sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" libcyrus.pc libcyrus_imap.pc \
+ libcyrus_min.pc libcyrus_sieve.pc ; \
+ )
+ # ======= Strip binaries =======
+ @( cd $(IMAPD_PKG) ; \
+ find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
+ )
+ifeq ($(__ENABLE_STATIC__),yes)
+ @( cd $(IMAPD_PKG) ; \
+ find . | xargs file | grep "current ar archive" | cut -f 1 -d : | xargs $(STRIP) -g 2> /dev/null ; \
+ )
+endif
+ifneq ($(PATCHELF),)
+ # ======= Set RPATH/RUNPATH for target binaries =======
+ @( cd $(IMAPD_PKG)/usr ; \
+ for file in `find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
+ rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
+ if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
+ $(PATCHELF) --set-rpath $(TARGET_BIN_RPATH) $$file 1> /dev/null 2> /dev/null ; \
+ fi ; \
+ done ; \
+ )
+ # ======= Set RPATH/RUNPATH for target shared objects =======
+ @( cd $(IMAPD_PKG)/usr/lib$(LIBSUFFIX) ; \
+ for file in `find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
+ rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
+ if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
+ $(PATCHELF) --set-rpath $(TARGET_LIB_RPATH) $$file 1> /dev/null 2> /dev/null ; \
+ fi ; \
+ done ; \
+ )
+endif
+ @touch $@
+
+$(IMAPD_PKG_DESCRIPTION_FILE): $(IMAPD_PKG_DESCRIPTION_FILE_IN)
+ @cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
+
+$(IMAPD_PKG_INSTALL_SCRIPT): $(IMAPD_PKG_INSTALL_SCRIPT_IN)
+ @cat $< | $(SED) -e "s,@PERL_LOCAL_POD@,$(perl_local_pod),g" > $@
+
+$(pkg_certificate) : $(pkg_archive) ;
+$(pkg_signature) : $(pkg_archive) ;
+$(pkg_description) : $(pkg_archive) ;
+
+$(pkg_archive): $(install_target) $(IMAPD_PKG_DESCRIPTION_FILE) $(IMAPD_PKG_INSTALL_SCRIPT)
+ @cp $(IMAPD_PKG_DESCRIPTION_FILE) $(IMAPD_PKG)/.DESCRIPTION
+ @cp $(IMAPD_PKG_INSTALL_SCRIPT) $(IMAPD_PKG)/.INSTALL
+ @$(BUILD_PKG_REQUIRES) $(IMAPD_PKG)/.REQUIRES
+ @echo "pkgname=$(IMAPD_PKG_NAME)" > $(IMAPD_PKG)/.PKGINFO ; \
+ echo "pkgver=$(IMAPD_PKG_VERSION)" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "arch=$(IMAPD_PKG_ARCH)" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "distroname=$(IMAPD_PKG_DISTRO_NAME)" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "distrover=$(IMAPD_PKG_DISTRO_VERSION)" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "group=$(IMAPD_PKG_GROUP)" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "short_description=\"$(IMAPD_PKG_SHORT_DESCRIPTION)\"" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "url=$(IMAPD_PKG_URL)" >> $(IMAPD_PKG)/.PKGINFO ; \
+ echo "license=$(IMAPD_PKG_LICENSE)" >> $(IMAPD_PKG)/.PKGINFO
+ @$(PSEUDO) sh -c "cd $(IMAPD_PKG) && \
+ chown -R root:root . && \
+ chown -R 238:12 var/run/cyrus && \
+ chown -R 238:12 var/lib/imap && \
+ chown -R 238:12 var/lib/cyrus && \
+ chown -R 238:12 var/spool/cyrus && \
+ chown -R 238:12 var/spool/sieve && \
+ chown -R 238:12 etc/cyrus.conf.new && \
+ chown -R 238:12 etc/imapd.conf.new && \
+ chmod 750 var/run/cyrus/socket && \
+ chmod 750 var/lib/cyrus && \
+ chmod 750 var/spool/cyrus && \
+ chmod 600 etc/cyrus.conf.new && \
+ chmod 600 etc/imapd.conf.new && \
+ $(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."
Index: PATCHES
===================================================================
--- PATCHES (nonexistent)
+++ PATCHES (revision 5)
@@ -0,0 +1,3 @@
+
+../../../sources/packages/n/cyrus-imapd/patches/cyrus-imapd-3.4.4-gssapi-cross.patch -p0
+../../../sources/packages/n/cyrus-imapd/patches/cyrus-imapd-3.4.4-perl-cross.patch -p0
Index: cyrus-imapd-pkg-description.in
===================================================================
--- cyrus-imapd-pkg-description.in (nonexistent)
+++ cyrus-imapd-pkg-description.in (revision 5)
@@ -0,0 +1,19 @@
+# HOW TO EDIT THIS FILE:
+# The "handy ruler" below makes it easier to edit a package description. Line
+# up the first '|' above the ':' following the base package name, and the '|'
+# on the right side marks the last column you can put a character in. You must
+# make exactly 11 lines for the formatting to be correct. It's also
+# customary to leave one space after the ':'.
+
+ |-----handy-ruler------------------------------------------------------|
+cyrus-imapd: cyrus-imapd @VERSION@ (Cyrus IMAP server)
+cyrus-imapd:
+cyrus-imapd: The Cyrus IMAP (Internet Message Access Protocol) server provides
+cyrus-imapd: access to personal mail and system-wide bulletin boards through the
+cyrus-imapd: IMAP protocol.
+cyrus-imapd:
+cyrus-imapd:
+cyrus-imapd: Homepage: https://www.cyrusimap.org
+cyrus-imapd:
+cyrus-imapd:
+cyrus-imapd:
Index: cyrus-imapd-pkg-install.sh.in
===================================================================
--- cyrus-imapd-pkg-install.sh.in (nonexistent)
+++ cyrus-imapd-pkg-install.sh.in (revision 5)
@@ -0,0 +1,137 @@
+#!/bin/sh
+
+# Preserve new files
+install_file() {
+ NEW="$1"
+ OLD="`dirname $NEW`/`basename $NEW .new`"
+ # If there's no 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...
+}
+
+preserve_perms() {
+ NEW="$1"
+ OLD="$(dirname $NEW)/$(basename $NEW .new)"
+ if [ -e $OLD ]; then
+ cp -a $OLD ${NEW}.incoming
+ cat $NEW > ${NEW}.incoming
+ touch -r $NEW ${NEW}.incoming
+ mv ${NEW}.incoming $NEW
+ fi
+ install_file $NEW
+}
+
+
+# arg 1: the new package version
+pre_install() {
+ /bin/true
+}
+
+# arg 1: the new package version
+post_install() {
+ preserve_perms etc/rc.d/rc.cyrus-imapd.new
+ install_file etc/cyrus.conf.new
+ install_file etc/imapd.conf.new
+ if ! grep "DBI|" @PERL_LOCAL_POD@ 1> /dev/null 2> /dev/null ; then
+ cat << EOF >> @PERL_LOCAL_POD@
+=head2 Sat Nov 5 22:29:56 2022: C<Module> L<Cyrus::Annotator::Daemon|Cyrus::Annotator::Daemon>
+
+=over 4
+
+=item *
+
+C<installed into: /usr/share/perl5/vendor_perl>
+
+=item *
+
+C<LINKTYPE: dynamic>
+
+=item *
+
+C<VERSION: 1.00>
+
+=item *
+
+C<EXE_FILES: >
+
+=back
+
+=head2 Sat Nov 5 22:29:56 2022: C<Module> L<Cyrus::IMAP|Cyrus::IMAP>
+
+=over 4
+
+=item *
+
+C<installed into: /usr/share/perl5/vendor_perl>
+
+=item *
+
+C<LINKTYPE: dynamic>
+
+=item *
+
+C<VERSION: 1.00>
+
+=item *
+
+C<EXE_FILES: cyradm>
+
+=back
+
+=head2 Sat Nov 5 22:29:56 2022: C<Module> L<Cyrus::SIEVE::managesieve|Cyrus::SIEVE::managesieve>
+
+=over 4
+
+=item *
+
+C<installed into: /usr/share/perl5/vendor_perl>
+
+=item *
+
+C<LINKTYPE: dynamic>
+
+=item *
+
+C<VERSION: 0.01>
+
+=item *
+
+C<EXE_FILES: >
+
+=back
+
+EOF
+ fi
+}
+
+# arg 1: the new package version
+# arg 2: the old package version
+pre_update() {
+ /bin/true
+}
+
+# arg 1: the new package version
+# arg 2: the old package version
+post_update() {
+ post_install
+}
+
+# arg 1: the old package version
+pre_remove() {
+ /bin/true
+}
+
+# arg 1: the old package version
+post_remove() {
+ /bin/true
+}
+
+
+operation=$1
+shift
+
+$operation $*
Property changes on: cyrus-imapd-pkg-install.sh.in
___________________________________________________________________
Added: svn:executable
## -0,0 +1 ##
+*
\ No newline at end of property
Index: rc.d/rc.cyrus-imapd
===================================================================
--- rc.d/rc.cyrus-imapd (nonexistent)
+++ rc.d/rc.cyrus-imapd (revision 5)
@@ -0,0 +1,46 @@
+#!/bin/sh
+#
+# /etc/rc.d/rc.cyrus-imapd - Start/stop/restart the Cyrus IMAP daemon.
+#
+
+cyrus_start() {
+ if [ -x /usr/libexec/master ]; then
+ if [ -f /var/run/cyrus-master.pid ] \
+ && kill -0 $(cat /var/run/cyrus-master.pid) 2> /dev/null; then
+ echo "Cyrus IMAP daemon already running."
+ return
+ fi
+ echo "Starting Cyrus IMAP daemon: /usr/libexec/cyrus/master"
+ /usr/libexec/master -d
+ fi
+}
+
+cyrus_stop() {
+ if [ -f /var/run/cyrus-master.pid ]; then
+ echo "Stopping Cyrus IMAP daemon"
+ kill $(cat /var/run/cyrus-master.pid) 2> /dev/null \
+ && rm -f /var/run/cyrus-master.pid
+ else
+ echo "Cyrus IMAP daemon already stopped."
+ fi
+}
+
+cyrus_restart() {
+ cyrus_stop
+ sleep 1
+ cyrus_start
+}
+
+case "$1" in
+ start)
+ cyrus_start
+ ;;
+ stop)
+ cyrus_stop
+ ;;
+ restart)
+ cyrus_restart
+ ;;
+ *)
+ echo "usage $0 start|stop|restart"
+esac
Index: rc.d
===================================================================
--- rc.d (nonexistent)
+++ rc.d (revision 5)
Property changes on: rc.d
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~
Index: .
===================================================================
--- . (nonexistent)
+++ . (revision 5)
Property changes on: .
___________________________________________________________________
Added: svn:ignore
## -0,0 +1,73 ##
+
+# install dir
+dist
+
+# Target build dirs
+.a1x-newlib
+.a2x-newlib
+.at91sam7s-newlib
+
+.build-machine
+
+.a1x-glibc
+.a2x-glibc
+.h3-glibc
+.h5-glibc
+.i586-glibc
+.i686-glibc
+.imx6-glibc
+.jz47xx-glibc
+.makefile
+.am335x-glibc
+.omap543x-glibc
+.p5600-glibc
+.power8-glibc
+.power8le-glibc
+.power9-glibc
+.power9le-glibc
+.m1000-glibc
+.riscv64-glibc
+.rk328x-glibc
+.rk33xx-glibc
+.rk339x-glibc
+.s8xx-glibc
+.s9xx-glibc
+.x86_64-glibc
+
+# Hidden files (each file)
+.makefile
+.dist
+.rootfs
+
+# src & hw requires
+.src_requires
+.src_requires_depend
+.requires
+.requires_depend
+
+# Tarballs
+*.gz
+*.bz2
+*.lz
+*.xz
+*.tgz
+*.txz
+
+# Signatures
+*.asc
+*.sig
+*.sign
+*.sha1sum
+
+# Patches
+*.patch
+
+# Descriptions
+*.dsc
+*.txt
+
+# Default linux config files
+*.defconfig
+
+# backup copies
+*~