Hi all, I thought I was being very clever by creating a virtual machine build environment so I didn’t have to litter my main computer with 100s of packages to build emacs. So I built it in a gnomebox and set the prefix to $home/.local/opt/emacs as I saw someone do. It runs fine in the virtual machine
The issue is now, I’d like to move the install or the built files to my host machine and run it, but it won’t run. If I just try to move the $home/.local/opt/emacs folder to my own computer, and run it I get the following:
./emacs-29.1.90: error while loading shared libraries: libgpm.so.2: cannot open shared object file: No such file or directory
When I try to move the whole directory (source code and the build directories inside there) out of the virtual machine into the Host and try to run make install (this is after make and compilation completed) it says
make install
if [ -x ./config.status ]; then \
./config.status --recheck; \
else \
../configure --cache-file=/dev/null; \
fi
/bin/sh: line 4: ../configure: Permission denied
make: *** [Makefile:573: config.status] Error 126
I have tried to chown -R : ./ to the whole directory but it still gives me the permission denied.
Any ideas how I might accomplish this task?
Thanks!
Yeah, you’re sort of fundamentally misunderstanding the relationship between a host and guest VM, here. The guest VM is an entirely different machine. It shares nothing with the host. Including shared libraries and other build chain dependencies.
I had thought that the libraries may have been linked in statically into a binary that “just worked” but indeed that is not the case. It will work on the host once I install some of the dependencies (of course, making the whole project a bit of a moot point. Though I will say it is a bit fewer than what was needed to build…)
This is not a useful plan. Building eMacs produces a binary that depends at runtime on loads of libraries that you haven’t installed on the outer system.
Just don’t bother doing this.
creating a virtual machine build environment so I didn’t have to litter my main computer with 100s of packages to build emacs.
That’s is a good idea! Despite what all others say. I’m doing this since years with my Linux box(es).
But you need to know, that self compiled programms should be stored below the filesystem tree
/usr/local/
.
There is a tool calledstow
, it has a package in most Linux distributions.
Installstow
into host and VM and create a directory/usr/local/stow/
in both (host an VM).
When compiling Emacs or other programs use the--prefix
option ofconfigure
. E.g.cd emacs-src; ./configure --prefix=/usr/local/stow/emacs-v29.1
. Then compile Emacs and install it in the virtual machine. After that, tar the folder/usr/local/stow/emacs-v29.1
and unpack it onto the host into the same directory. Then change dir into/usr/local/stow
and runsudo stow emacs-v29.1
. Maybe you need to install some libraries onto the host, useldd /usr/local/bin/emacs
to see, what libs you need. Then you are ready to use emacs. It is possible to have multiple versions of emacs installed and only one needs to be “activated” via stow.Consider building and running in a podman/docker container. Distrobox is a popular way to do this.