Skip to content

Commit

Permalink
Re-incorporate libkent into package build process
Browse files Browse the repository at this point in the history
  • Loading branch information
nvictus committed Mar 12, 2023
1 parent ea8ee18 commit 575c45d
Show file tree
Hide file tree
Showing 5 changed files with 85 additions and 57 deletions.
10 changes: 5 additions & 5 deletions MANIFEST.in
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
include LICENSE
include README.md
include Makefile
graft tests
graft include
include bbi/cbbi.pyx
include bbi/cbbi.pxd
graft src
graft include
graft tests

global-include *.pyx
global-include *.pxd

recursive-exclude venv *
global-exclude __pycache__/*
global-exclude *.o
global-exclude *.a
Expand Down
12 changes: 5 additions & 7 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -5,26 +5,24 @@ UNAME_S := $(shell uname -s)

ifeq (${MACHTYPE},)
MACHTYPE:=$(shell uname -m)
# $(info MACHTYPE was empty, set to: ${MACHTYPE})
endif
ifneq (,$(findstring -,$(MACHTYPE)))
# $(info MACHTYPE has - sign ${MACHTYPE})
MACHTYPE:=$(shell uname -m)
# $(info MACHTYPE has - sign set to: ${MACHTYPE})
endif
export MACHTYPE

export CC ?= gcc
export COPTS=-g -pthread -fPIC -static
export CFLAGS=-Wall $(shell pkg-config --static --cflags-only-other openssl zlib libpng)
export DEFS=-D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_GNU_SOURCE -DMACHTYPE_${MACHTYPE} -DUSE_SSL
export LDFLAGS=-L${current_dir}/src/${MACHTYPE} $(shell pkg-config --static --libs openssl zlib libpng)
export INC=-I${current_dir}/include $(shell pkg-config --static --cflags-only-I openssl zlib libpng)
export DEFS=-D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -D_GNU_SOURCE -DMACHTYPE_${MACHTYPE} -DUSE_SSL
# pass through COREDUMP
ifneq (${COREDUMP},)
DEFS+=-DCOREDUMP
endif

# Append values to CFLAGS and LDFLAGS
CFLAGS += $(shell echo $$CFLAGS)
LDFLAGS += $(shell echo $$LDFLAGS)


all: build

Expand Down
22 changes: 5 additions & 17 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -71,27 +71,15 @@ repository = "https://github.com/nvictus/pybbi"
[tool.cibuildwheel]
build = ["cp38-*", "cp39-*", "cp310-*", "cp311-*"]
skip = "*-musllinux*"

build-verbosity = 3

[tool.cibuildwheel.linux]
archs = ["x86_64", "aarch64"]
before-all = "yum install -y gcc make zlib-devel openssl-devel libpng-devel"
before-build = "make build-ucsc"

[tools.cibuildwheel.linux.environment]
LDFLAGS = "-Wl,--no-as-needed"


[tool.cibuildwheel.macos]
archs = ["x86_64"]
before-all = "brew install pkg-config openssl libpng"
before-build = "make build-ucsc"

[tool.cibuildwheel.macos.environment]
LDFLAGS = "-L/usr/local/opt/openssl/lib -L/opt/homebrew/opt/openssl/lib"
CPPFLAGS = "-I/usr/local/opt/openssl/include -I/opt/homebrew/opt/openssl/include"
PATH = "/usr/local/opt/openssl/bin:/opt/homebrew/opt/openssl/bin:$PATH"
PKG_CONFIG_PATH = "/usr/local/opt/openssl/lib/pkgconfig:/opt/homebrew/opt/openssl/lib/pkgconfig:$PKG_CONFIG_PATH"
C_INCLUDE_PATH = "/usr/local/include/libpng:/usr/local/opt/openssl/include:$C_INCLUDE_PATH"
BLDSHARED = 'gcc -bundle -undefined dynamic_lookup -arch x86_64 -g'
LDSHARED = 'gcc -bundle -undefined dynamic_lookup -arch x86_64 -g'
archs = ["x86_64"] # "arm64" is not yet supported by GitHub Actions (Needs M1 runner)
before-all = """
brew install pkg-config openssl libpng # -> /usr/local (x86_64)
"""
84 changes: 61 additions & 23 deletions setup.py
Original file line number Diff line number Diff line change
@@ -1,29 +1,71 @@
import os
import os.path
import pathlib
import subprocess
import sys

import numpy
import pkgconfig
from Cython.Build import cythonize
from Cython.Distutils.build_ext import new_build_ext as cython_build_ext
from setuptools import Extension, setup

ARCH = os.uname().machine
# Determine architecture for build; defaults to machine architecture.
# cibuildwheel sets ARCHFLAGS on macos runners
# user can also set ARCH to override
MACHINE_ARCH = os.uname().machine
if sys.platform == "darwin" and "ARCHFLAGS" in os.environ:
ARCH = os.environ["ARCHFLAGS"].split()[-1]
elif "ARCH" in os.environ:
ARCH = os.environ["ARCH"]
else:
ARCH = MACHINE_ARCH

deps = {}
if "sdist" not in sys.argv:

if "sdist" in sys.argv:
# Skip compilation when building a source distribution
setup()

else:
import numpy
import pkgconfig
from Cython.Build import cythonize
from Cython.Distutils.build_ext import new_build_ext as cython_build_ext

# 1. Compile the UCSC library (libkent.a)
# Pass the target architecture to the makefile
os.environ["MACHTYPE"] = ARCH

# Platform and architecture-specific flags
if sys.platform == "darwin":
brew_optdir = None
if ARCH.startswith("arm"):
brew_optdir = "/opt/homebrew/opt"
else:
brew_optdir = "/usr/local/opt"
os.environ["CFLAGS"] = f"-arch {ARCH}"
if brew_optdir is not None:
os.environ["LDFLAGS"] = f"-L{brew_optdir}/openssl/lib {os.environ.get('LDFLAGS', '')}"
os.environ["C_INCLUDE_PATH"] = f"{brew_optdir}/openssl/include:{brew_optdir}/libpng/include:{os.environ.get('C_INCLUDE_PATH', '')}"
os.environ["PKG_CONFIG_PATH"] = f"{brew_optdir}/openssl/lib/pkgconfig:{os.environ.get('PKG_CONFIG_PATH', '')}"

# Parse pkg-config dependencies
# This will let us know if something is missing
deps = pkgconfig.parse("zlib openssl libpng")

# Build the UCSC library
if not pathlib.Path("src", ARCH, "libkent.a").exists():
raise RuntimeError(
f"src/{ARCH}/libkent.a not found. "
"Please run `make build-ucsc`."
)
subprocess.run(["make", "clean-ucsc"])
ret = subprocess.run(["make", "build-ucsc"], check=True)
if ret.returncode != 0:
raise RuntimeError("Failed to build UCSC library.")


def get_extension_modules():
ext_modules = [
# 2. Compile cython extension module, link to libkent and other dependencies
# Platform and architecture-specific linker flags
if sys.platform == "darwin":
os.environ["BLDSHARED"] = f'gcc -bundle -undefined dynamic_lookup -arch {ARCH} -g'
os.environ["LDSHARED"] = f'gcc -bundle -undefined dynamic_lookup -arch {ARCH} -g'
elif sys.platform == "linux":
os.environ["LDFLAGS"] = f"-Wl,--no-as-needed {os.environ.get('LDFLAGS', '')}"

# Configure and cythonize pyx to C extension module
ext_modules = cythonize([
Extension(
name="bbi.cbbi",
sources=[os.path.join("bbi", "cbbi.pyx")],
Expand All @@ -39,14 +81,10 @@ def get_extension_modules():
+ deps.pop("include_dirs", []),
**deps,
),
]
if "sdist" in sys.argv:
return ext_modules
else:
return cythonize(ext_modules)
])


setup(
ext_modules=get_extension_modules(),
build_ext=cython_build_ext,
)
setup(
ext_modules=ext_modules,
build_ext=cython_build_ext,
)
14 changes: 9 additions & 5 deletions src/makefile
Original file line number Diff line number Diff line change
Expand Up @@ -54,17 +54,21 @@ $(MACHTYPE)/libkent.a: $(O) $(MACHTYPE)
$(MACHTYPE):
mkdir $(MACHTYPE)

.PHONY: all
all: $(MACHTYPE)/libkent.a

%.o: %.c
${CC} ${COPTS} ${CFLAGS} ${DEFS} ${LDFLAGS} ${INC} -o $@ -c $<

.PHONY: test
test:
cd tests && ${MAKE} test

.PHONY: clean
clean:
rm -f ${O} $(MACHTYPE)/libkent.a
cd tests && ${MAKE} clean

.PHONY: tags
tags:
etags ../inc/*.h ../lib/*.h ../lib/*.c ../hg/inc/*.h ../hg/lib/*.h ../hg/lib/*.c ../hg/hgTracks/*.c ../hg/hgc/*.c ../hg/hgTrackUi/*.c

%.o: %.c
${CC} ${COPTS} ${CFLAGS} ${DEFS} ${LDFLAGS} ${INC} -o $@ -c $<

all: $(MACHTYPE)/libkent.a

0 comments on commit 575c45d

Please sign in to comment.