commit:     64d35d122bebca3cb10dfb4d9c05e118b3bc847a
Author:     ArsenShnurkov <Arsen.Shnurkov <AT> gmail <DOT> com>
AuthorDate: Mon Jul 20 19:36:12 2015 +0000
Commit:     Heather Cynede <cynede <AT> gentoo <DOT> org>
CommitDate: Mon Jul 20 19:36:12 2015 +0000
URL:        https://gitweb.gentoo.org/proj/dotnet.git/commit/?id=64d35d12

mono-4.0.3.13.ebuild

 dev-lang/mono/metadata.xml                      |   1 +
 dev-lang/mono/mono-4.0.3.13.ebuild              | 171 ++++++++++++++++++++++++
 dev-util/monodevelop/monodevelop-5.9.5.5.ebuild |   6 +-
 3 files changed, 175 insertions(+), 3 deletions(-)

diff --git a/dev-lang/mono/metadata.xml b/dev-lang/mono/metadata.xml
index 9529ca5..4f96674 100644
--- a/dev-lang/mono/metadata.xml
+++ b/dev-lang/mono/metadata.xml
@@ -5,5 +5,6 @@
 <use>
        <flag name='pax_kernel'>Enable if the user plans to run the package 
under a pax enabled hardened kernel</flag>
        <flag name='xen'>Make mono generate code that is considerably faster on 
xen VMs but slightly slower on for normal systems.</flag>
+       <flag name='sgen'>Endble SGen garbage collector</flag>
 </use>
 </pkgmetadata>

diff --git a/dev-lang/mono/mono-4.0.3.13.ebuild 
b/dev-lang/mono/mono-4.0.3.13.ebuild
new file mode 100644
index 0000000..67f224e
--- /dev/null
+++ b/dev-lang/mono/mono-4.0.3.13.ebuild
@@ -0,0 +1,171 @@
+# Copyright 1999-2015 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI=5
+AUTOTOOLS_PRUNE_LIBTOOL_FILES="all"
+
+inherit eutils linux-info mono-env flag-o-matic pax-utils autotools-utils
+
+DESCRIPTION="Mono runtime and class libraries, a C# compiler/interpreter"
+HOMEPAGE="http://www.mono-project.com/Main_Page";
+SRC_URI="http://download.mono-project.com/sources/${PN}/${P}.tar.bz2";
+
+LICENSE="MIT LGPL-2.1 GPL-2 BSD-4 NPL-1.1 Ms-PL GPL-2-with-linking-exception 
IDPL"
+SLOT="0"
+
+KEYWORDS="~amd64 ~ppc ~ppc64 ~x86 ~amd64-linux"
+
+#IUSE="nls minimal pax_kernel xen doc debug sgen llvm"
+IUSE="nls minimal pax_kernel xen doc debug sgen"
+
+COMMONDEPEND="
+       !minimal? ( >=dev-dotnet/libgdiplus-2.10 )
+       ia64? ( sys-libs/libunwind )
+       nls? ( sys-devel/gettext )
+"
+RDEPEND="${COMMONDEPEND}
+       || ( www-client/links www-client/lynx )
+"
+DEPEND="${COMMONDEPEND}
+       sys-devel/bc
+       virtual/yacc
+       pax_kernel? ( sys-apps/elfix )
+"
+
+MAKEOPTS="${MAKEOPTS} -j1" #nowarn
+S="${WORKDIR}/${PN}-4.0.3"
+
+pkg_pretend() {
+       # If CONFIG_SYSVIPC is not set in your kernel .config, mono will hang 
while compiling.
+       # See http://bugs.gentoo.org/261869 for more info."
+       CONFIG_CHECK="SYSVIPC"
+       use kernel_linux && check_extra_config
+}
+
+pkg_setup() {
+       linux-info_pkg_setup
+       mono-env_pkg_setup
+}
+
+src_prepare() {
+       # we need to sed in the paxctl-ng -mr in the runtime/mono-wrapper.in so 
it don't
+       # get killed in the build proces when MPROTEC is enable. #286280
+       # RANDMMAP kill the build proces to #347365
+       if use pax_kernel ; then
+               ewarn "We are disabling MPROTECT on the mono binary."
+
+               # issue 9 : https://github.com/Heather/gentoo-dotnet/issues/9
+               sed '/exec "/ i\paxctl-ng -mr "$r/@mono_runtime@"' -i 
"${S}"/runtime/mono-wrapper.in || die "Failed to sed mono-wrapper.in"
+       fi
+
+       # strip-flags and append-flags are from
+       # 
https://devmanual.gentoo.org/eclass-reference/flag-o-matic.eclass/index.html
+       # (common functions to manipulate and query toolchain flags)
+
+       # mono build system can fail otherwise
+       strip-flags
+
+       # Remove this at your own peril. Mono will barf in unexpected ways.
+       append-flags -fno-strict-aliasing
+
+       #fix vb targets http://osdir.com/ml/general/2015-05/msg20808.html
+       epatch "${FILESDIR}/add_missing_vb_portable_targets.patch"
+
+       autotools-utils_src_prepare
+       epatch "${FILESDIR}/systemweb3.patch"
+}
+
+src_configure() {
+       # Very handy to specify ./configure argument without modifying .ebuild:
+       # EXTRA_ECONF="--enable-foo ......" emerge package
+       # see also
+       # 
https://devmanual.gentoo.org/ebuild-writing/functions/src_configure/configuring/index.html
+       # https://devmanual.gentoo.org/eclass-reference/autotools.eclass/
+
+       # NOTE: We need the static libs for now so mono-debugger works.
+       # See http://bugs.gentoo.org/show_bug.cgi?id=256264 for details
+       #
+       # --without-moonlight since www-plugins/moonlight is not the only one
+       # using mono: https://bugzilla.novell.com/show_bug.cgi?id=641005#c3
+       #
+       # --with-profile4 needs to be always enabled since it's used by default
+       # and, otherwise, problems like bug #340641 appear.
+       #
+       # sgen fails on ppc, bug #359515
+       local myeconfargs=(
+               --enable-system-aot=yes
+               --enable-static
+               --disable-quiet-build
+               --without-moonlight
+               --with-libgdiplus=$(usex minimal no installed)
+               $(use_with xen xen_opt)
+               --without-ikvm-native
+               --with-jit
+               --disable-dtrace
+               --with-profile4
+               --with-sgen=$(usex ppc no yes)
+               $(use_with doc mcs-docs)
+               $(use_enable debug)
+               $(use_enable nls)
+       )
+
+#      # "included" is default option - 
https://github.com/mono/mono#configuration-options
+#      if use boehm-gc; then
+#              myeconfargs+=(
+#                      --with-gc=included
+#              )
+#      fi
+
+# this will lead to error
+# make[3]: *** No rule to make target 
'../../mono/metadata/libmonoruntime-static.a', needed by 'monodis'.  Stop.
+#      if ! use sgen; then
+#              myeconfargs+=(
+#                      --with-sgen=no
+#              )
+#      fi
+
+#      if use llvm; then
+#              myeconfargs+=(
+#                      --enable-llvm
+#                      --enable-loadedllvm
+#              )
+#      fi
+
+       elog "myeconfargs=${myeconfargs}"
+       autotools-utils_src_configure
+
+       # FIX for uncompilable 3.4.0 sources
+       
FF="${WORKDIR}/mono-3.4.0/mcs/tools/xbuild/targets/Microsoft.Portable.Common.targets"
+       rm -f $FF
+       touch $FF
+       echo '<Project 
xmlns="http://schemas.microsoft.com/developer/msbuild/2003";>' >> $FF
+       echo '    <Import Project="..\\Microsoft.Portable.Core.props" />' >> $FF
+       echo '    <Import Project="..\\Microsoft.Portable.Core.targets" />' >> 
$FF
+       echo '</Project>' >> $FF
+}
+
+src_compile() {
+       nonfatal autotools-utils_src_compile || {
+               eqawarn "maintainer of this ebuild has no idea why it fails. If 
you happen to know how to fix it - please let me know"
+               autotools-utils_src_compile
+        }
+}
+
+src_test() {
+       cd mcs/tests || die
+       emake check
+}
+
+src_install() {
+       autotools-utils_src_install
+
+       elog "Rewriting symlink"
+       # you have mono-boehm and mono-sgen executables
+       # mono is just a symlink to mono-sgen
+       if use sgen; then
+               dosym mono-sgen /usr/bin/mono
+       else
+               dosym mono-boehm /usr/bin/mono
+       fi
+}

diff --git a/dev-util/monodevelop/monodevelop-5.9.5.5.ebuild 
b/dev-util/monodevelop/monodevelop-5.9.5.5.ebuild
index a2902ad..a4fd5d8 100644
--- a/dev-util/monodevelop/monodevelop-5.9.5.5.ebuild
+++ b/dev-util/monodevelop/monodevelop-5.9.5.5.ebuild
@@ -87,18 +87,18 @@ src_prepare() {
        #fix ASP.Net
        cd "${T}/${P}/main"
        epatch "${FILESDIR}/5.7-downgrade_to_mvc3.patch"
-       
+
        # fix for https://github.com/gentoo/dotnet/issues/42
        epatch "${FILESDIR}/aspnet-template-references-fix.patch"
        use gnome || epatch "${FILESDIR}/5.9.5-kill-gnome.patch"
        use qtcurve && epatch "${FILESDIR}/kill-qtcurve-warning.patch"
-       
+
        #prepare dist package
        cd "${T}/${P}"
        epatch "${FILESDIR}/5.9.5-skip_merged_tar.patch"
        ./configure --profile=default || die
        make dist || die
-       
+
        #move it
        mv -f "${T}/${P}/tarballs/"monodevelop-*/* "${S}" || die
 

Reply via email to