Opened 14 years ago
Closed 14 years ago
#25107 closed defect (fixed)
texlive_base doesn't fully support changing build_arch
Reported by: | elebel@… | Owned by: | drkp (Dan Ports) |
---|---|---|---|
Priority: | Normal | Milestone: | |
Component: | ports | Version: | 1.8.2 |
Keywords: | Cc: | ryandesign (Ryan Carsten Schmidt) | |
Port: | texlive_base |
Description (last modified by ryandesign (Ryan Carsten Schmidt))
Hi There,
I needed to compile libzzip with
sudo port -f install libzzip +universal
and got this error:
[...]
---> Building texlive_base Error: Target org.macports.build returned: shell command " cd "/opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_ports_tex_texlive_base/work/texlive_base-2007" && /usr/bin/make all " returned error 2 Command output: -isystem/opt/local/include -O2 -arch i386 yesno.c -o yesno.o /usr/bin/gcc-4.2 -DHAVE_CONFIG_H -DHAVE_NCURSES -DUSE_COLORS -DLIBDIR=\"/opt/local/lib\" -DINCLUDEDIR=\"/opt/local/include\" -c -I. -I. \ -isystem/opt/local/include -O2 -arch i386 radiolist.c -o radiolist.o radiolist.c: In function 'dialog_radiolist': radiolist.c:312: warning: format not a string literal and no format arguments /usr/bin/gcc-4.2 -DHAVE_CONFIG_H -DHAVE_NCURSES -DUSE_COLORS -DLIBDIR=\"/opt/local/lib\" -DINCLUDEDIR=\"/opt/local/include\" -c -I. -I. \ -isystem/opt/local/include -O2 -arch i386 gauge.c -o gauge.o /usr/bin/gcc-4.2 -DHAVE_CONFIG_H -DHAVE_NCURSES -DUSE_COLORS -DLIBDIR=\"/opt/local/lib\" -DINCLUDEDIR=\"/opt/local/include\" -c -I. -I. \ -isystem/opt/local/include -O2 -arch i386 rc.c -o rc.o /usr/bin/gcc-4.2 -DHAVE_CONFIG_H -DHAVE_NCURSES -DUSE_COLORS -DLIBDIR=\"/opt/local/lib\" -DINCLUDEDIR=\"/opt/local/include\" -c -I. -I. \ -isystem/opt/local/include -O2 -arch i386 strcasecmp.c -o strcasecmp.o /usr/bin/gcc-4.2 -L/opt/local/lib dialog.o checklist.o inputbox.o menubox.o msgbox.o textbox.o yesno.o radiolist.o gauge.o rc.o strcasecmp.o -o dialog -lncurses ld: warning: in dialog.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in checklist.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in inputbox.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in menubox.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in msgbox.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in textbox.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in yesno.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in radiolist.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in gauge.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in rc.o, file was built for i386 which is not the architecture being linked (x86_64) ld: warning: in strcasecmp.o, file was built for i386 which is not the architecture being linked (x86_64) Undefined symbols: "_main", referenced from: start in crt1.10.6.o ld: symbol(s) not found collect2: ld returned 1 exit status make[1]: *** [dialog] Error 1 make: *** [all] Error 1 Error: The following dependencies failed to build: xmlto texlive texlive_base Error: Status 1 encountered during processing. Before reporting a bug, first run the command again with the -d flag to get complete output.
that package links by default 64 bits even tough every .o file were compile i386. To fix this I had to change every Makefiles and add -arch i386 to the linker flags when there and add the same thing to every other lines when the compiler linked something (line with a -o in it)....arrrggg....
This should be fix cause, now, since it compiled, all the makefiles I changed are gone...
I'm sure this probleme is in other relatively old package too...
Change History (6)
comment:1 Changed 14 years ago by mf2k (Frank Schima)
Keywords: | i386 removed |
---|---|
Port: | texlive_base added |
comment:2 Changed 14 years ago by ryandesign (Ryan Carsten Schmidt)
Cc: | ryandesign@… added |
---|---|
Description: | modified (diff) |
comment:3 Changed 14 years ago by elebel@…
I set the build to i386 by setting build_arch i386 in /opt/local/etc/macports/macports.conf.
build_arch i386 // simply uncomment this one universal_archs x86_64 i386 // didn't touch that one...
I'm compiling on a core i7 Macbook Pro.
I used the -f cause otherwise it wouldn't compile at all. Sorry I don't have the console error anymore.
comment:4 Changed 14 years ago by ryandesign (Ryan Carsten Schmidt)
Summary: | libzzip and i386 compile still links 64 bits. → texlive_base doesn't fully support changing build_arch |
---|
I am able to reproduce this problem building texlive_base if build_arch is set to i386 on a 64-bit machine running Snow Leopard. Most of the objects get built i386, but these don't:
$ find . -name '*.o' | xargs lipo -info | grep -v i386 Non-fat file: ./texk/web2c/cmaps.o is architecture: x86_64 Non-fat file: ./texk/web2c/FontTableCache.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXFontInst.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXFontInst_FT2.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXFontMgr.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXFontMgr_FC.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXLayoutInterface.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXOTLayoutEngine.o is architecture: x86_64 Non-fat file: ./texk/web2c/XeTeXOTMath.o is architecture: x86_64
comment:5 Changed 14 years ago by jmroot (Joshua Root)
Owner: | changed from macports-tickets@… to dports@… |
---|
Is this still a problem with texlive-bin @2009_2?
comment:6 Changed 14 years ago by drkp (Dan Ports)
Resolution: | → fixed |
---|---|
Status: | new → closed |
Seems fixed. +atsui forces it to build 32-bit, and all binaries produced are i386.
I did have to put in a patch or two to the makefiles/autoconf stuff to fix a similar-looking problem (though with different files)
libzzip is definitely unrelated. If anything, you appear to be having trouble building texlive_base.
What is build_arch set to in macports.conf? What about universal_archs? What kind of Mac is this exactly, what processor? I assume it's a 64-bit Intel processor?
You should not be in the habit of using the force ("-f") flag.