Fix (again) the chicken-and-egg problem with cffi

Broken with previous commits :)
This commit is contained in:
J. David Ibáñez 2014-10-30 17:59:38 +01:00
parent a9fa063de3
commit 94f650a41d
5 changed files with 101 additions and 82 deletions

View File

@ -41,7 +41,7 @@ from .remote import Remote, get_credentials
from .repository import Repository from .repository import Repository
from .settings import Settings from .settings import Settings
from .utils import to_bytes from .utils import to_bytes
from .version import __version__ from ._utils import __version__
def init_repository(path, bare=False, def init_repository(path, bare=False,

92
pygit2/_utils.py Normal file
View File

@ -0,0 +1,92 @@
# -*- coding: utf-8 -*-
#
# Copyright 2010-2014 The pygit2 contributors
#
# This file 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.
#
# In addition to the permissions in the GNU General Public License,
# the authors give you unlimited permission to link the compiled
# version of this file into combinations with other programs,
# and to distribute those combinations without any restriction
# coming from the use of this file. (The General Public License
# restrictions do apply in other respects; for example, they cover
# modification of the file, and distribution when not linked into
# a combined executable.)
#
# This file 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; see the file COPYING. If not, write to
# the Free Software Foundation, 51 Franklin Street, Fifth Floor,
# Boston, MA 02110-1301, USA.
"""
This is an special module, it provides stuff used by setup.py and by
pygit2 at run-time.
"""
# Import from the Standard Library
import inspect
import codecs
import os
from os import getenv
from os.path import abspath, dirname
#
# The version number of pygit2
#
__version__ = '0.21.3'
#
# Utility functions to get the paths required for bulding extensions
#
def _get_libgit2_path():
# LIBGIT2 environment variable takes precedence
libgit2_path = getenv("LIBGIT2")
if libgit2_path is not None:
return libgit2_path
# Default
if os.name == 'nt':
return '%s\libgit2' % getenv("ProgramFiles")
return '/usr/local'
def get_libgit2_paths():
libgit2_path = _get_libgit2_path()
return (
os.path.join(libgit2_path, 'bin'),
os.path.join(libgit2_path, 'include'),
getenv('LIBGIT2_LIB', os.path.join(libgit2_path, 'lib')),
)
#
# Loads the cffi extension
#
def get_ffi():
from cffi import FFI
ffi = FFI()
# Load C definitions
dir_path = dirname(abspath(inspect.getfile(inspect.currentframe())))
decl_path = os.path.join(dir_path, 'decl.h')
with codecs.open(decl_path, 'r', 'utf-8') as header:
ffi.cdef(header.read())
# Load extension module
libgit2_bin, libgit2_include, libgit2_lib = get_libgit2_paths()
C = ffi.verify("#include <git2.h>", modulename='pygit2_cffi',
libraries=["git2"],
include_dirs=[libgit2_include], library_dirs=[libgit2_lib])
# Ok
return ffi, C

View File

@ -28,54 +28,8 @@
# Import from the future # Import from the future
from __future__ import absolute_import from __future__ import absolute_import
# Import from the Standard Library # Import from pygit2
import inspect from ._utils import get_ffi
import codecs
import os
from os import getenv
from os.path import abspath, dirname
# Import from cffi
from cffi import FFI
def _get_libgit2_path(): ffi, C = get_ffi()
# LIBGIT2 environment variable takes precedence
libgit2_path = getenv("LIBGIT2")
if libgit2_path is not None:
return libgit2_path
# Default
if os.name == 'nt':
return '%s\libgit2' % getenv("ProgramFiles")
return '/usr/local'
def get_libgit2_paths():
libgit2_path = _get_libgit2_path()
return (
os.path.join(libgit2_path, 'bin'),
os.path.join(libgit2_path, 'include'),
getenv('LIBGIT2_LIB', os.path.join(libgit2_path, 'lib')),
)
def init_ffi():
global C, ffi
ffi = FFI()
# Load C definitions
dir_path = dirname(abspath(inspect.getfile(inspect.currentframe())))
decl_path = os.path.join(dir_path, 'decl.h')
with codecs.open(decl_path, 'r', 'utf-8') as header:
ffi.cdef(header.read())
# Load extension module
libgit2_bin, libgit2_include, libgit2_lib = get_libgit2_paths()
C = ffi.verify("#include <git2.h>", modulename='pygit2_cffi',
libraries=["git2"],
include_dirs=[libgit2_include], library_dirs=[libgit2_lib])
init_ffi()

View File

@ -1,26 +0,0 @@
# Copyright 2010-2014 The pygit2 contributors
#
# This file 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.
#
# In addition to the permissions in the GNU General Public License,
# the authors give you unlimited permission to link the compiled
# version of this file into combinations with other programs,
# and to distribute those combinations without any restriction
# coming from the use of this file. (The General Public License
# restrictions do apply in other respects; for example, they cover
# modification of the file, and distribution when not linked into
# a combined executable.)
#
# This file 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; see the file COPYING. If not, write to
# the Free Software Foundation, 51 Franklin Street, Fifth Floor,
# Boston, MA 02110-1301, USA.
__version__ = '0.21.3'

View File

@ -43,11 +43,9 @@ from subprocess import Popen, PIPE
import sys import sys
import unittest import unittest
# Read version from local pygit2/version.py without pulling in # Import stuff from pygit2/_utils.py without loading the whole pygit2 package
# pygit2/__init__.py
sys.path.insert(0, 'pygit2') sys.path.insert(0, 'pygit2')
from version import __version__ from _utils import __version__, get_libgit2_paths, get_ffi
import ffi
del sys.path[0] del sys.path[0]
# Python 2 support # Python 2 support
@ -58,7 +56,7 @@ else:
u = str u = str
libgit2_bin, libgit2_include, libgit2_lib = ffi.get_libgit2_paths() libgit2_bin, libgit2_include, libgit2_lib = get_libgit2_paths()
pygit2_exts = [os.path.join('src', name) for name in os.listdir('src') pygit2_exts = [os.path.join('src', name) for name in os.listdir('src')
if name.endswith('.c')] if name.endswith('.c')]
@ -100,7 +98,8 @@ class CFFIBuild(build):
to add cffi as an extension. to add cffi as an extension.
""" """
def finalize_options(self): def finalize_options(self):
self.distribution.ext_modules.append(ffi.ffi.verifier.get_extension()) ffi, C = get_ffi()
self.distribution.ext_modules.append(ffi.verifier.get_extension())
build.finalize_options(self) build.finalize_options(self)