EAPI=8 PYTHON_COMPAT=( python3_13 ) DISTUTILS_SINGLE_IMPL=1 DISTUTILS_USE_PEP517=no inherit cmake distutils-r1 S=$WORKDIR/nextpnr-$P DESCRIPTION="portable FPGA place and route tool" HOMEPAGE="https://github.com/YosysHQ/nextpnr" SRC_URI="https://github.com/YosysHQ/nextpnr/archive/$P.tar.gz" LICENSE=ISC SLOT=0 KEYWORDS="amd64" #IUSE="ice40 ecp5 machxo2 nexus gowin gui" IUSE="ice40 ecp5 machxo2 nexus gui" DEPEND="ice40? ( sci-electronics/icestorm ) ecp5? ( sci-electronics/prjtrellis ) machxo2? ( sci-electronics/prjtrellis ) nexus? ( sci-electronics/prjoxide ) >=sci-electronics/yosys-0.8 gui? ( dev-qt/qtcore:5 virtual/opengl ) dev-libs/boost dev-cpp/eigen" # gowin? ( sci-electronics/apicula ) src_unpack() { unpack $P.tar.gz rmdir $S/3rdparty/fpga-interchange-schema # $S/3rdparty/abseil-cpp } src_prepare() { default eapply "${FILESDIR}/${P}-no-tests-gui.patch" cmake_src_prepare distutils-r1_src_prepare } src_configure() { #-DARCH=generic$(usex ice40 ";ice40" "")$(usex ecp5 ";ecp5" "")$(usex machxo2 ";machxo2" "")$(usex nexus ";nexus" "")$(usex gowin ";gowin" "") local mycmakeargs=( -DARCH=generic$(usex ice40 ";ice40" "")$(usex ecp5 ";ecp5" "")$(usex machxo2 ";machxo2" "")$(usex nexus ";nexus" "") $(usex ice40 "-DICESTORM_INSTALL_PREFIX=/usr" "") $(usex ecp5 "-DTRELLIS_INSTALL_PREFIX=/usr" "") $(usex machxo2 "-DTRELLIS_INSTALL_PREFIX=/usr" "") $(usex nexus "-DOXIDE_INSTALL_PREFIX=/usr" "") $(usex gui -DBUILD_GUI=ON "") ) cmake_src_configure distutils-r1_src_configure } src_compile() { cmake_src_compile } src_install() { cmake_src_install }