Domanda

Sto cercando di convertire libcsv ad uso libtool modo da poter utilizzare su Mac OS X senza pressare il makefile. Quando provo a fare funzionare il makefile generato dagli strumenti ottengo il seguente errore:

~/software/libcsv (gnu_tools) $ make 
tag=CC   --mode=compile gcc -DPACKAGE_NAME=\"\" -DPACKAGE_TARNAME=\"\" -DPACKAGE_VERSION=\"\"
-DPACKAGE_STRING=\"\" -DPACKAGE_BUGREPORT=\"\" -DPACKAGE_URL=\"\" -DPACKAGE=\"libcsv\" 
-DVERSION=\"3.0.1\" -I.     -g -O2 -MT libcsv.lo -MD -MP -MF .deps/libcsv.Tpo -c -o libcsv.lo  
libcsv.c
/bin/sh: --mode=compile: command not found
make: [libcsv.lo] Error 127 (ignored)
mv -f .deps/libcsv.Tpo .deps/libcsv.Plo
mv: rename .deps/libcsv.Tpo to .deps/libcsv.Plo: No such file or directory
make: *** [libcsv.lo] Error 1

Sono in esecuzione OS X 10.5. Così, dopo un po 'di fossicking circa ho notato che il makefile generato ha un libtool var vuoto:

<generated makefile>
LD = 
LDFLAGS = 
LIBOBJS = 
LIBS = 
LIBTOOL = 
LIPO = 
LN_S = 
LTLIBOBJS = 
<more generated makefile>

Se ho impostato libtool a libtool, allora tutto va bene. Suppongo che ho fatto un errore nel mio autoconf o automake file che sono al di sotto:

Makefile.am
lib_LTLIBRARIES = libcsv.la
libcsv_la_SOURCES = libcsv.c
include_HEADERS = csv.h
libcsv_la_LDFLAGS = -version-info 3:1:0
ACLOCAL_AMFLAGS = -I m4

configure.ac
dn1 Process this file with autoconf to produce a configure script.
AC_INIT(libcsv.c)
AM_INIT_AUTOMAKE(libcsv, 3.0.1)
AC_PROG_CC
AC_OUTPUT(Makefile)
AC_PROG_LIBTOOL
AC_CONFIG_MACRO_DIR([m4])
AC_CHECK_FUNCS([strerror])
AC_FUNC_MALLOC
C_PROG_RANLIB
AC_PROG_CXX
LT_INIT
LT_OUTPUT
AC_TYPE_SIZE_T

Se si tratta di alcun aiuto qui fa parte del config.log:

## ------------------ ##
## Running config.lt. ##
## ------------------ ##
config.lt:680: creating libtool
configure:17115: checking for size_t
configure:17115: gcc -c -g -O2  conftest.c >&5
configure:17115: $? = 0
configure:17115: gcc -c -g -O2  conftest.c >&5
conftest.c: In function 'main':
conftest.c:62: error: syntax error before ')' token
configure:17115: $? = 1
configure: failed program was:
| /* confdefs.h */
| #define PACKAGE_NAME ""
| #define PACKAGE_TARNAME ""
| #define PACKAGE_VERSION ""
| #define PACKAGE_STRING ""
| #define PACKAGE_BUGREPORT ""
| #define PACKAGE_URL ""
| #define PACKAGE "libcsv"
| #define VERSION "3.0.1"
| #define STDC_HEADERS 1
| #define HAVE_SYS_TYPES_H 1
| #define HAVE_SYS_STAT_H 1
| #define HAVE_STDLIB_H 1
| #define HAVE_STRING_H 1
| #define HAVE_MEMORY_H 1
| #define HAVE_STRINGS_H 1
| #define HAVE_INTTYPES_H 1
| #define HAVE_STDINT_H 1
| #define HAVE_UNISTD_H 1
| #define HAVE_DLFCN_H 1
| #define LT_OBJDIR ".libs/"
| #define HAVE_STRERROR 1
| #define HAVE_STDLIB_H 1
| #define HAVE_MALLOC 1
| /* end confdefs.h.  */
| #include <stdio.h>
| #ifdef HAVE_SYS_TYPES_H
| # include <sys/types.h>
| #endif
| #ifdef HAVE_SYS_STAT_H
| # include <sys/stat.h>
| #endif
| #ifdef STDC_HEADERS
| # include <stdlib.h>
| # include <stddef.h>
| #else
| # ifdef HAVE_STDLIB_H
| #  include <stdlib.h>
| # endif
| #endif
| #ifdef HAVE_STRING_H
| # if !defined STDC_HEADERS && defined HAVE_MEMORY_H
| #  include <memory.h>
| # endif
| # include <string.h>
| #endif
| #ifdef HAVE_STRINGS_H
| # include <strings.h>
| #endif
| #ifdef HAVE_INTTYPES_H
| # include <inttypes.h>
| #endif
| #ifdef HAVE_STDINT_H
| # include <stdint.h>
| #endif
| #ifdef HAVE_UNISTD_H
| # include <unistd.h>
| #endif
| int
| main ()
| {
| if (sizeof ((size_t)))
|       return 0;
|   ;
|   return 0;
| }
configure:17115: result: yes

Quindi, qualcuno sa quello che ho torto?

Grazie in anticipo.

È stato utile?

Soluzione

Non ho una risposta definitiva per voi, ma la prima cosa che avevo suggst è quello di mettere la vostra AC_OUTPUT alla fine del vostro configure.ac, dopo il LT_INIT. Non è completamente questo semplice, ma non è lontano sbagliato pensare dei contenuti di configure.ac come l'espansione, a sua volta a frammenti di script di shell che vengono eseguiti a turno. Se si emettono il Makefile configurato prima di aver trovato libtool, quindi che potrebbe spiegare LIBTOOL essere vuota.

Un layout abbastanza convenzionale del vostro configure.ac sarebbe il seguente:

dnl Process this file with autoconf to produce a configure script.
AC_INIT(libcsv.c)
AM_INIT_AUTOMAKE(libcsv, 3.0.1)
AC_CONFIG_MACRO_DIR([m4])

dnl find programs
AC_PROG_CC
AC_PROG_CXX
LT_INIT
AC_PROG_RANLIB

dnl check functionality
AC_CHECK_FUNCS([strerror])
AC_FUNC_MALLOC
AC_TYPE_SIZE_T

AC_OUTPUT(Makefile)

Non credo che avevi bisogno LT_OUTPUT, e il docs nota che AC_PROG_LIBTOOL è sinonimo deprecato per LT_INIT (in modo da avere entrambi è probabilmente in cerca di guai).

(a proposito di niente molto, si noti che OS X ha un comando chiamato libtool, che è niente a che fare con GNU Libtool. Sono abbastanza sicuro che non è il problema qui, ma è un Gotcha che ha confuso le persone prima)

Altri suggerimenti

Si può cercare di rinforzare l'integrazione libtool eseguendo libtoolize --force (ho avuto un sacco di problemi con diverse versioni libtool incomatible su host diversi, libtoolize --force aiuta molto in questi casi). Anche attenzione l'uscita di configurazione per i messaggi libtool, devono leggere in questo modo:

checking if libtool supports shared libraries... yes
configure: creating libtool
appending configuration tag "CXX" to libtool
appending configuration tag "F77" to libtool

particolare la linea configure: creating libtool deve essere presente nell'output.

Il mio configure.ac ha solo:

LT_INIT([dlopen])
AC_SUBST([LIBTOOL_DEPS])

Il LT_OUTPUT è per l'utilizzo di libtool per le prove successive all'interno di configurare se stessa, e richiede un config.lt alle cose impostare. Non ho mai dovuto usarlo, quindi non so tutto quello che comporta, ma non sarebbe male prendere quella linea e vedere se questo risolve il problema.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top