Rejuvenating Autoconf
Rejuvenating Autoconf
Posted Oct 24, 2020 2:56 UTC (Sat) by felixfix (subscriber, #242)Parent article: Rejuvenating Autoconf
./configure && make && make install
      Posted Oct 24, 2020 11:15 UTC (Sat)
                               by rzaa (guest, #130641)
                              [Link] (4 responses)
       
./configure --prefix=$HOME/.local/stow/progname_progversion && make && make install 
     
    
      Posted Oct 24, 2020 14:30 UTC (Sat)
                               by felixfix (subscriber, #242)
                              [Link] 
       
I remember well the first time I installed anything with autoconf.  It was like magic. 
     
      Posted Oct 25, 2020 10:07 UTC (Sun)
                               by nix (subscriber, #2304)
                              [Link] (2 responses)
       
/configure --prefix=$HOME/.local && make && \ 
(or make install prefix=... with a sufficiently old package) 
The configure-time prefix is the prefix the package *runs* from, and only provides a default for the prefix it is installed to. Stowed packages do not run from their installation location: that's the whole point of stow... 
     
    
      Posted Oct 25, 2020 19:38 UTC (Sun)
                               by rzaa (guest, #130641)
                              [Link] (1 responses)
       
     
    
      Posted Oct 26, 2020 15:27 UTC (Mon)
                               by nix (subscriber, #2304)
                              [Link] 
       
     
      Posted Oct 26, 2020 7:17 UTC (Mon)
                               by wtarreau (subscriber, #51152)
                              [Link] 
       
No, the usual way to use it, sadly, is still: 
  ./configure || vi configure 
This is why this tool is wrong by design. 
 
     
      Posted Oct 27, 2020 10:42 UTC (Tue)
                               by hholzgra (subscriber, #11737)
                              [Link] (8 responses)
       
The true power, on the developer side, only shows with 
  make distcheck 
though.  
Lack of this kind of end-to-end test is one of my main pain points with CMake, where it is all to easy to get things like out-of-source builds wrong. 
(and don't get me started on CMake and "make uninstall" ...) 
     
    
      Posted Oct 27, 2020 11:37 UTC (Tue)
                               by mathstuf (subscriber, #69389)
                              [Link] 
       
Alas, yes, it is. The thing is that it's tribal knowledge and due to the way things interact, hard to document effectively (it comes back to our lack of guide-level documentation). One also has issues with projects being embeddable into others (alas, also a more common occurrence today) with assumptions about what the top-level project means and such. 
> make uninstall 
This is because CMake allows for arbitrary code during installation (`install(<CODE|SCRIPT>)`) which can easily escape `install_manifest.txt`'s view of things. I wish the "everything is via `install(<FILES|DIRECTORIES|TARGETS|EXPORT>)`" flag to indicate that `install_manifest.txt` is at least potentially trustworthy were easier to toggle though. 
     
      Posted Oct 27, 2020 18:15 UTC (Tue)
                               by Cyberax (✭ supporter ✭, #52523)
                              [Link] (6 responses)
       
     
    
      Posted Oct 27, 2020 18:27 UTC (Tue)
                               by madscientist (subscriber, #16861)
                              [Link] 
       
You can't have both in-tree and out-of-tree builds at the same time and you can't switch from in-tree to out-of-tree without a full clean first. 
     
      Posted Oct 27, 2020 18:44 UTC (Tue)
                               by hholzgra (subscriber, #11737)
                              [Link] (4 responses)
       
The problem is that you can have build rules that touch files in the source dir instead of build dir. 
The autotools distcheck targets catches this by doing: 
* creating a dist tarball 
This will, among other things, catch any file created or touched in sourcedir instead of destdir. 
With CMake, at least the last time I dealt with it, this needed to be tested manually ...  
(... and I remember several cases over the years where a build rule touching source dir files slipped in into MySQL / MariaDB and stayed undetected for extended periods of time) 
     
    
      Posted Oct 27, 2020 18:55 UTC (Tue)
                               by Cyberax (✭ supporter ✭, #52523)
                              [Link] 
       
     
      Posted Oct 28, 2020 16:07 UTC (Wed)
                               by mathstuf (subscriber, #69389)
                              [Link] (2 responses)
       
The steps that are done could be done with CMake as well, though not many projects use CMake to make their source tarballs (`git archive` is usually enough; I think autotools gained that mechanism for itself because it effectively patches the source for distribution in practice). I'd find it useful if the normal CMake (or any build tool!) procedures in distro builds would set the source directory as read-only and started filing bugs with projects about not supporting out-of-source builds. 
     
    
      Posted Oct 28, 2020 19:25 UTC (Wed)
                               by hholzgra (subscriber, #11737)
                              [Link] (1 responses)
       
yes, it can do it, but it is not advertised much, unlike CMake where it's the recommended method 
> I think autotools gained that mechanism for itself because it 
unlike "git archive" etc. you can control which files to exclude from being distributed and other things 
that's also one of the things the distcheck target checks for: does the build from the dist tarball fail due to any file missing from the dist tarball? 
it also creates tarballs with proper version number included in the tarball filename, can check that the ChangeLog file really has an entry for that version, etc. ... 
As basically most of this is in the Makefile template anyway it shouldn't be much of a problem for CMake to provide the same for the make backend, but somehow this never seems to have happened. 
     
    
      Posted Oct 28, 2020 21:49 UTC (Wed)
                               by mathstuf (subscriber, #69389)
                              [Link] 
       
The `export-ignore` attribute exists for this. `git archive` does suck at submodules, but just about everything does in practice anyways. `git archive-all` exists for those cases and handles a bad situation well enough (it is pure porcelain and is lacking plumbing for use in alternative automated tasks where it would be useful). 
> it also creates tarballs with proper version number included in the tarball filename, can check that the ChangeLog file really has an entry for that version, etc. ... 
Changelog strategies vary wildly from project to project. Some don't have them, some autogenerate them from commit logs (ugh), others are overly verbose to the point of uselessness (IMO, GCC is one of these). 
> As basically most of this is in the Makefile template anyway it shouldn't be much of a problem for CMake to provide the same for the make backend, but somehow this never seems to have happened. 
File an issue (or ping one that already exists). There's enough work that we don't actively seek out features to implement; it is mostly demand-driven. However, note that the Makefiles generator targets POSIX make, not GNU Make or any other specific flavor. Single-generator features also have a high bar for implementation (generally they need to be at least extremely difficult or specifically targeting that backend). I don't think making any "source tarball creation" built-in target would get over either bar, so it'd need to be available for any generator backend. But I think it is more CPack's wheelhouse anyways. 
     
    Rejuvenating Autoconf
      
cd $HOME/.local/stow/ 
stow progname_progversion
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
    make install DESTDIR=/home./local/stow/progname_progversion
cd $HOME/.local/stow/
stow progname_progversion
Rejuvenating Autoconf
      
I realized that I haven't used these prefixes correctly. 
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
>
> ./configure && make && make install
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
Uh... I'm pretty sure CMake always runs with out-of-tree builds. Can you even make it in-tree?
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
* unpacking that into a subdirectory
* changing that directory and its contents to read-only
* creating a build directory
* doing an out of source build
* AFAIR: doing "make test", too
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
Rejuvenating Autoconf
      
all the time.
effectively patches the source for distribution in practice
Rejuvenating Autoconf
      
 
           