Autotools Tutorial

Total Page:16

File Type:pdf, Size:1020Kb

Autotools Tutorial Autotools Tutorial Mengke HU ECE Department Drexel University ASPITRG Group Meeting Outline 1 Introduction 2 GNU Coding standards 3 Autoconf 4 Automake 5 Libtools 6 Demonstration The Basics of Autotools 1 The purpose of autotools I It serves the needs of your users (checking platform and libraries; compiling and installing ). I It makes your project incredibly portablefor dierent system platforms. 2 Why should we use autotools: I A lot of free softwares target Linux operating system. I Autotools allow your project to build successfully on future versions or distributions with virtually no changes to the build scripts. The Basics of Autotools 1 The purpose of autotools I It serves the needs of your users (checking platform and libraries; compiling and installing ). I It makes your project incredibly portablefor dierent system platforms. 2 Why should we use autotools: I A lot of free softwares target Linux operating system. I Autotools allow your project to build successfully on future versions or distributions with virtually no changes to the build scripts. The Basics of Autotools 1 3 GNU packages for GNU build system I Autoconf Generate a conguration script for a project I Automake Simplify the process of creating consistent and functional makeles I Libtool Provides an abstraction for the portable creation of shared libraries 2 Basic steps (commends) to build and install software I tar -zxvf package_name-version.tar.gz I cd package_name-version I ./congure I make I sudo make install The Basics of Autotools 1 3 GNU packages for GNU build system I Autoconf Generate a conguration script for a project I Automake Simplify the process of creating consistent and functional makeles I Libtool Provides an abstraction for the portable creation of shared libraries 2 Basic steps (commends) to build and install software I tar -zxvf package_name-version.tar.gz I cd package_name-version I ./congure I make I sudo make install Autoconf 1 Autoconf I autoconf I autoheader I autom4te I autoreconf I autoscan I autoupdate Data Flow Diagram for Autoconf Automake 1 automake I automake I aclocal Data Flow Diagram for aclocal Libtools 1 Libtools I libtool I libtoolize Data Flow Diagram for automake and libtool A simple project structure jupiter1.0 Makele I ./src/ F Makele F main.c Makele Makele layout var1=val1 var2=val2 ... target1 : t1_dep1 ... t1_depN <TAB> shell-command1a <TAB> shell-command1b ... target2 : t2_dep1 ... t2_depN <TAB> shell-command2a <TAB> shell-command2b ... File: /home/mengke/Desktop/backup2/jupiter/src/Makefile Page 1 of 1 Makele# src/Makefile. Example Generated from Makefile.in by configure. # Package-specific substitution variables package = Jupiter version = 1.0 tarname = jupiter distdir = $(tarname)-$(version) # VPATH-related substitution variables srcdir = . # Prefix-specific substitution variables prefix = /usr/local exec_prefix = ${prefix} bindir = ${exec_prefix}/bin #CFLAGS = -g -O0 all: jupiter jupiter: main.c gcc -g -O2 -o jupiter ../../src/main.c #$(CC) $(CPPFLAGS) $(CFLAGS) -o $@ main.c check: all ./jupiter | grep "Hello from .*jupiter!" @echo "*** ALL TESTS PASSED ***" install: install -d $(DESTDIR)$(bindir) #DESTDIR is to dsupport the staged installation install -m 0755 jupiter $(DESTDIR)$(bindir) cp jupiter /usr/bin chown root:toot /usr/bin/jupiter #change file owner and group chmod +x /usr/bin/jupiter uninstall: -rm $(DESTDIR)$(bindir)/jupiter Makefile: Makefile.in ../config.status cd .. && ./config.status src/$@ ../config.status: ../configure cd .. && ./config.status --recheck clean: -rm jupiter .PHONY: all clean check install uninstall Autoconf Syntax 1 Autoconf I Autoconf use M4 macro language. I M4 is for the purpose of macro language processor. 2 Syntax for congure.ac le AC_INIT([PackageName], [version]) AC_CONFIG_FILES([Makele src/Makele]) AC_OUTPUT Check Datatype 1 Check for types for dierent platforms I AC_TYPE_UINTN_T I AC_TYPE_INTN_T Where N = 8;16;32;64 2 How those macros work? I Check if stdint.h or inttypes.h have UINTN_T or UINTN_T I If not, dene UINTN_T or UINTN_T. Add automake functionality 1 Enabling Automake in congure.ac I AC_INIT([Jupiter], [1.0], [[email protected]]) I AM_INIT_AUTOMAKE I AC_CONFIG_SRCDIR([src/main.c]) 2 Makele.am for compiling sources I bin_PROGRAMS = jupiter I jupiter_SOURCES = main.c I jupiter_CPPFLAGS = -I$(top_srcdir)/common I jupiter_LDADD = ../common/libjupcommon.a Add convenience libraries (static library) Makele.am for convenience libraries I noinst_LIBRARIES = libjupcommon.a I libjupcommon_a_SOURCES = jupcommon.h print.c Shared Libraries Shared libraries contain only a small table of functions that programs require. Shared libraries make executable le smaller. It is easy to update shared libraries without recompiling projects. Shared libraries use dynamic linking, which provides chunks of executable code that the operating system can load into a program's address space and execute. Libtools 1 How the libtool works? I Libtool script is generated by congure script and ltmain.sh. I Libtool script then insulates the author of the build system from the nuances of building shared libraries on dierent platforms. 2 Add following lines in congure.ac: I AC_SEARCH_LIBS([dlopen], [dl]) I AC_SEARCH_LIBS([lt_dlopen], [ltdl]) Demo1: Makele for compiling? File:Project_Name/src/main.c /home/mengke/Research/autotoo…demo/demo1_makefile/src/main.c Page 1 of 1 #include <stdio.h> #include <stdlib.h> int main(int argc, char * argv[]) { printf("Hello from %s!\n", argv[0]); return 0; } Demo1: Makele for compiling? File:Project_Name/src/Makele /home/mengke/Research/autotoo…mo/demo1_makefile/src/Makefile Page 1 of 1 #TARGET1: refer to actions "HelloWorld" in TARGET2 all: HelloWorld #TARGET2: depends on HelloWorld.o, # ultimately depends on TARTET3 HelloWorld: HelloWorld.o gcc -o HelloWorld HelloWorld.o #TARGET3: depends on main.c HelloWorld.o: main.c cc -c -o HelloWorld.o main.c #TARGET4: delete HelloWorld and HelloWorld.o clean: rm HelloWorld HelloWorld.o #TARGET5: refer to actions "all" and "clean" .PHONY: all clean Demo2:Makele for Creating Source Distribution Archive File:Project_Name/Makele /home/mengke/Research/autotoo…emo/demo2_makePackage/Makefile Page 1 of 1 #TARGET1: refer to src/Makefile # 1. go into src folder # 2. run target "all" in src/Makefile all: cd src && make #TARGET2: creates distribution, refers to TARGET3 dist: HelloWorld-1.0.tar.gz #TARGET3: generate software package # ultimately depends on TARGET4 HelloWorld-1.0.tar.gz: HelloWorld-1.0 tar -zcvf HelloWorld-1.0.tar.gz HelloWorld-1.0 rm -rf HelloWorld-1.0 #TARGET4: create package distribution directory HelloWorld-1.0: mkdir -p HelloWorld-1.0/src cp Makefile HelloWorld-1.0 cp src/Makefile HelloWorld-1.0/src cp src/main.c HelloWorld-1.0/src #TARGET5: check the all the functions for both Makefile and src/Makefile distcheck: HelloWorld-1.0.tar.gz tar -zxvf HelloWorld-1.0.tar.gz cd HelloWorld-1.0 && make all cd HelloWorld-1.0 && make clean rm -rf Helloworld-1.0 @echo "**** Package Helloworld-1.0.tar.gz is ready for distribution." #TARGET6: refer to actions "all", "clean" and "dist" .PHONY: all clean dist Demo3: Autoconf for conguring project File: /home/mengke/Research/autotoo…mo3_configureFile/configure.ac Page 1 of 1 Project_Name/congure.ac #pass 'HelloWorld' to variable "package" in Makefile.in #pass '1.0' to variable "version" in Makefile.in AC_INIT([HelloWorld],[1.0]) #generate Makefile by running the script './configure' AC_CONFIG_FILES([Makefile src/Makefile]) AC_OUTPUT Demo3:File: /home/mengke/Research/autotoo…emo3_configureFile/Makefile.in Autoconf for conguring project Page 1 of 1 # Configure Input package = @PACKAGE_NAME@ version = @PACKAGE_VERSION@ tarname = @PACKAGE_TARNAME@ distdir = $(tarname)-$(version) #TARGET1: refer to src/Makefile # 1. go into src folder # 2. run target "all" in src/Makefile all clean check HelloWorld install uninstall: cd src && $(MAKE) $@ #TARGET2: creates distribution, refers to TARGET3 dist: $(distdir).tar.gz #TARGET3: generate software package # ultimately depends on TARGET4 $(distdir).tar.gz: $(distdir) tar -zcvf $(distdir).tar.gz $(distdir) rm -rf $(distdir) #TARGET4: create package distribution directory $(distdir): mkdir -p $(distdir)/src # cp Makefile $(distdir) # cp src/Makefile $(distdir)/src cp src/main.c $(distdir)/src cp configure.ac $(distdir) cp configure $(distdir) cp Makefile.in $(distdir) cp src/Makefile.in $(distdir)/src #TARGET5: check the all the functions for both Makefile and src/Makefile distcheck: $(distdir).tar.gz gzip -cd $(distdir).tar.gz | tar xvf - # tar -zxvf $(distdir).tar.gz cd $(distdir) && ./configure cd $(distdir) && $(MAKE) all cd $(distdir) && $(MAKE) check cd $(distdir) && $(MAKE) install cd $(distdir) && $(MAKE) uninstall cd $(distdir) && $(MAKE) clean rm -rf $(distdir) @echo "**** Package Helloworld-1.0.tar.gz is ready for distribution." #TARGET6: regenerate Makefile if its template (Makefile.in) has changed Makefile: Makefile.in config.status ./config.status $@ #TARGET7: rebuild config.status when configure changes config.status: configure ./config.status --recheck #TARGET8: refer to actions "all", "clean", "dist", "install" and "uninstall" .PHONY: all clean check dist distcheck install uninstall Demo3: Autoconf for conguring project autoreconf Generate congure script from congure.ac ./congure Generate Makele from Makele.in make dist Package the software project into tarball Demo4: Autoconf for automatic Makeles File: /home/mengke/Research/autotoo…/demo4_makefileam/configure.ac Page 1 of 1 congure.ac #Initializes the Autoconf system #pass 'HelloWorld'
Recommended publications
  • Source Code Trees in the VALLEY of THE
    PROGRAMMING GNOME Source code trees IN THE VALLEY OF THE CODETHORSTEN FISCHER So you’ve just like the one in Listing 1. Not too complex, eh? written yet another Unfortunately, creating a Makefile isn’t always the terrific GNOME best solution, as assumptions on programs program. Great! But locations, path names and others things may not be does it, like so many true in all cases, forcing the user to edit the file in other great programs, order to get it to work properly. lack something in terms of ease of installation? Even the Listing 1: A simple Makefile for a GNOME 1: CC=/usr/bin/gcc best and easiest to use programs 2: CFLAGS=`gnome-config —cflags gnome gnomeui` will cause headaches if you have to 3: LDFLAGS=`gnome-config —libs gnome gnomeui` type in lines like this, 4: OBJ=example.o one.o two.o 5: BINARIES=example With the help of gcc -c sourcee.c gnome-config —libs —cflags 6: gnome gnomeui gnomecanvaspixbuf -o sourcee.o 7: all: $(BINARIES) Automake and Autoconf, 8: you can create easily perhaps repeated for each of the files, and maybe 9: example: $(OBJ) with additional compiler flags too, only to then 10: $(CC) $(LDFLAGS) -o $@ $(OBJ) installed source code demand that everything is linked. And at the end, 11: do you then also have to copy the finished binary 12: .c.o: text trees. Read on to 13: $(CC) $(CFLAGS) -c $< manually into the destination directory? Instead, 14: find out how. wouldn’t you rather have an easy, portable and 15: clean: quick installation process? Well, you can – if you 16: rm -rf $(OBJ) $(BINARIES) know how.
    [Show full text]
  • Red Hat Enterprise Linux 6 Developer Guide
    Red Hat Enterprise Linux 6 Developer Guide An introduction to application development tools in Red Hat Enterprise Linux 6 Dave Brolley William Cohen Roland Grunberg Aldy Hernandez Karsten Hopp Jakub Jelinek Developer Guide Jeff Johnston Benjamin Kosnik Aleksander Kurtakov Chris Moller Phil Muldoon Andrew Overholt Charley Wang Kent Sebastian Red Hat Enterprise Linux 6 Developer Guide An introduction to application development tools in Red Hat Enterprise Linux 6 Edition 0 Author Dave Brolley [email protected] Author William Cohen [email protected] Author Roland Grunberg [email protected] Author Aldy Hernandez [email protected] Author Karsten Hopp [email protected] Author Jakub Jelinek [email protected] Author Jeff Johnston [email protected] Author Benjamin Kosnik [email protected] Author Aleksander Kurtakov [email protected] Author Chris Moller [email protected] Author Phil Muldoon [email protected] Author Andrew Overholt [email protected] Author Charley Wang [email protected] Author Kent Sebastian [email protected] Editor Don Domingo [email protected] Editor Jacquelynn East [email protected] Copyright © 2010 Red Hat, Inc. and others. The text of and illustrations in this document are licensed by Red Hat under a Creative Commons Attribution–Share Alike 3.0 Unported license ("CC-BY-SA"). An explanation of CC-BY-SA is available at http://creativecommons.org/licenses/by-sa/3.0/. In accordance with CC-BY-SA, if you distribute this document or an adaptation of it, you must provide the URL for the original version. Red Hat, as the licensor of this document, waives the right to enforce, and agrees not to assert, Section 4d of CC-BY-SA to the fullest extent permitted by applicable law.
    [Show full text]
  • GNU Build System
    Maemo Diablo Reference Manual for maemo 4.1 GNU Build System December 22, 2008 Contents 1 GNU Build System 2 1.1 Introduction .............................. 2 1.2 GNU Make and Makefiles ...................... 2 1.2.1 Simplest Real Example .................... 3 1.2.2 Anatomy of Makefile ..................... 6 1.2.3 Default Goal .......................... 7 1.2.4 On Names of Makefiles ................... 7 1.2.5 Questions ........................... 8 1.2.6 Adding Make Goals ..................... 8 1.2.7 Making One Target at a Time ................ 9 1.2.8 PHONY Keyword ...................... 9 1.2.9 Specifying Default Goal ................... 10 1.2.10 Other Common Phony Goals ................ 11 1.2.11 Variables in Makefiles .................... 11 1.2.12 Variable Flavors ........................ 11 1.2.13 Recursive Variables ...................... 12 1.2.14 Simple Variables ....................... 13 1.2.15 Automatic Variables ..................... 14 1.2.16 Integrating with Pkg-Config ................ 15 1.3 GNU Autotools ............................ 16 1.3.1 Brief History of Managing Portability ........... 17 1.3.2 GNU Autoconf ........................ 18 1.3.3 Substitutions ......................... 22 1.3.4 Introducing Automake .................... 24 1.3.5 Checking for Distribution Sanity .............. 29 1.3.6 Cleaning up .......................... 29 1.3.7 Integration with Pkg-Config ................ 30 1 Chapter 1 GNU Build System 1.1 Introduction The following code examples are used in this chapter: simple-make-files • autoconf-automake • 1.2 GNU Make and Makefiles The make program from the GNU project is a powerful tool to aid implementing automation in the software building process. Beside this, it can be used to automate any task that uses files and in which these files are transformed into some other form.
    [Show full text]
  • Beginning Portable Shell Scripting from Novice to Professional
    Beginning Portable Shell Scripting From Novice to Professional Peter Seebach 10436fmfinal 1 10/23/08 10:40:24 PM Beginning Portable Shell Scripting: From Novice to Professional Copyright © 2008 by Peter Seebach All rights reserved. No part of this work may be reproduced or transmitted in any form or by any means, electronic or mechanical, including photocopying, recording, or by any information storage or retrieval system, without the prior written permission of the copyright owner and the publisher. ISBN-13 (pbk): 978-1-4302-1043-6 ISBN-10 (pbk): 1-4302-1043-5 ISBN-13 (electronic): 978-1-4302-1044-3 ISBN-10 (electronic): 1-4302-1044-3 Printed and bound in the United States of America 9 8 7 6 5 4 3 2 1 Trademarked names may appear in this book. Rather than use a trademark symbol with every occurrence of a trademarked name, we use the names only in an editorial fashion and to the benefit of the trademark owner, with no intention of infringement of the trademark. Lead Editor: Frank Pohlmann Technical Reviewer: Gary V. Vaughan Editorial Board: Clay Andres, Steve Anglin, Ewan Buckingham, Tony Campbell, Gary Cornell, Jonathan Gennick, Michelle Lowman, Matthew Moodie, Jeffrey Pepper, Frank Pohlmann, Ben Renow-Clarke, Dominic Shakeshaft, Matt Wade, Tom Welsh Project Manager: Richard Dal Porto Copy Editor: Kim Benbow Associate Production Director: Kari Brooks-Copony Production Editor: Katie Stence Compositor: Linda Weidemann, Wolf Creek Press Proofreader: Dan Shaw Indexer: Broccoli Information Management Cover Designer: Kurt Krames Manufacturing Director: Tom Debolski Distributed to the book trade worldwide by Springer-Verlag New York, Inc., 233 Spring Street, 6th Floor, New York, NY 10013.
    [Show full text]
  • The GNOME Desktop Environment
    The GNOME desktop environment Miguel de Icaza ([email protected]) Instituto de Ciencias Nucleares, UNAM Elliot Lee ([email protected]) Federico Mena ([email protected]) Instituto de Ciencias Nucleares, UNAM Tom Tromey ([email protected]) April 27, 1998 Abstract We present an overview of the free GNU Network Object Model Environment (GNOME). GNOME is a suite of X11 GUI applications that provides joy to users and hackers alike. It has been designed for extensibility and automation by using CORBA and scripting languages throughout the code. GNOME is licensed under the terms of the GNU GPL and the GNU LGPL and has been developed on the Internet by a loosely-coupled team of programmers. 1 Motivation Free operating systems1 are excellent at providing server-class services, and so are often the ideal choice for a server machine. However, the lack of a consistent user interface and of consumer-targeted applications has prevented free operating systems from reaching the vast majority of users — the desktop users. As such, the benefits of free software have only been enjoyed by the technically savvy computer user community. Most users are still locked into proprietary solutions for their desktop environments. By using GNOME, free operating systems will have a complete, user-friendly desktop which will provide users with powerful and easy-to-use graphical applications. Many people have suggested that the cause for the lack of free user-oriented appli- cations is that these do not provide enough excitement to hackers, as opposed to system- level programming. Since most of the GNOME code had to be written by hackers, we kept them happy: the magic recipe here is to design GNOME around an adrenaline response by trying to use exciting models and ideas in the applications.
    [Show full text]
  • Why and How I Use Lilypond Daniel F
    Why and How I Use LilyPond Daniel F. Savarese Version 1.1 Copyright © 2018 Daniel F. Savarese1 even with an academic discount. I never got my money's Introduction worth out of it. At the time I couldn't explain exactly why, but I was never productive using it. In June of 2017, I received an email from someone using my classical guitar transcriptions inquiring about how I Years later, when I started playing piano, I upgraded to use LilyPond2 to typeset (or engrave) music. He was the latest version of Finale and suddenly found it easier dissatisfied with his existing WYSIWYG3 commercial to produce scores using the software. It had nothing to software and was looking for alternatives. He was im- do with new features in the product. After notating eight pressed with the appearance of my transcription of Lá- original piano compositions, I realized that my previous grima and wondered if I would share the source for it difficulties had to do with the idiosyncratic requirements and my other transcriptions. of guitar music that were not well-supported by the soft- ware. Nevertheless, note entry and the overall user inter- I sent the inquirer a lengthy response explaining that I'd face of Finale were tedious. I appreciated how accurate like to share the source for my transcriptions, but that it the MIDI playback could be with respect to dynamics, wouldn't be readily usable by anyone given the rather tempo changes, articulations, and so on. But I had little involved set of support files and programs I've built to need for MIDI output.
    [Show full text]
  • The Glib/GTK+ Development Platform
    The GLib/GTK+ Development Platform A Getting Started Guide Version 0.8 Sébastien Wilmet March 29, 2019 Contents 1 Introduction 3 1.1 License . 3 1.2 Financial Support . 3 1.3 Todo List for this Book and a Quick 2019 Update . 4 1.4 What is GLib and GTK+? . 4 1.5 The GNOME Desktop . 5 1.6 Prerequisites . 6 1.7 Why and When Using the C Language? . 7 1.7.1 Separate the Backend from the Frontend . 7 1.7.2 Other Aspects to Keep in Mind . 8 1.8 Learning Path . 9 1.9 The Development Environment . 10 1.10 Acknowledgments . 10 I GLib, the Core Library 11 2 GLib, the Core Library 12 2.1 Basics . 13 2.1.1 Type Definitions . 13 2.1.2 Frequently Used Macros . 13 2.1.3 Debugging Macros . 14 2.1.4 Memory . 16 2.1.5 String Handling . 18 2.2 Data Structures . 20 2.2.1 Lists . 20 2.2.2 Trees . 24 2.2.3 Hash Tables . 29 2.3 The Main Event Loop . 31 2.4 Other Features . 33 II Object-Oriented Programming in C 35 3 Semi-Object-Oriented Programming in C 37 3.1 Header Example . 37 3.1.1 Project Namespace . 37 3.1.2 Class Namespace . 39 3.1.3 Lowercase, Uppercase or CamelCase? . 39 3.1.4 Include Guard . 39 3.1.5 C++ Support . 39 1 3.1.6 #include . 39 3.1.7 Type Definition . 40 3.1.8 Object Constructor . 40 3.1.9 Object Destructor .
    [Show full text]
  • Using GNU Autotools to Manage a “Minimal Project”
    05AAL Ch 04 9/12/00 10:14 AM Page 21 4 Using GNU Autotools to Manage a “Minimal Project” This chapter describes how to manage a minimal project using the GNU Autotools. For this discussion, a minimal project refers to the smallest possible project that can still illustrate a sufficient number of principles related to using the tools. Studying a smaller project makes it easier to understand the more complex interactions between these tools when larger projects require advanced features. The example project used throughout this chapter is a fictitious command interpreter called ‘foonly’. ‘foonly’ is written in C, but like many interpreters, uses a lexical analyzer and a parser expressed using the lex and yacc tools. The package is developed to adhere to the GNU ‘Makefile’ standard, which is the default behavior for Automake. This project does not use many features of the GNU Autotools. The most note- worthy one is libraries; this package does not produce any libraries of its own, so Libtool does not feature them in this chapter. The more complex projects presented in Chapter 7, “A Small GNU Autotools Project” and Chapter 11, “A Large GNU Autotools Project” illustrate how Libtool participates in the build system. The essence of this chapter is to provide a high-level overview of the user-written files and how they interact. 4.1 User-Provided Input Files The smallest project requires the user to provide only two files. The GNU Autotools generate the remainder of the files needed to build the package are in Section 4.2, “Generated Output Files.”
    [Show full text]
  • The Starlink Build System SSN/78.1 —Abstract I
    SSN/78.1 Starlink Project Starlink System Note 78.1 Norman Gray, Peter W Draper, Mark B Taylor, Steven E Rankin 11 April 2005 Copyright 2004-5, Council for the Central Laboratory of the Research Councils Copyright 2007, Particle Physics and Astronomy Research Council Copyright 2007, Science and Technology Facilities Council The Starlink Build System SSN/78.1 —Abstract i Abstract This document provides an introduction to the Starlink build system. It describes how to use the Starlink versions of the GNU autotools (autoconf, automake and libtool), how to build the software set from a checkout, how to add and configure new components, and acts as a reference manual for the Starlink-specific autoconf macros and Starlink automake features. It does not describe the management of the CVS repository in detail, nor any other source maintainance patterns. It should be read in conjunction with the detailed build instructions in the README file at the top of the source tree (which takes precedence over any instructions in this document, though there should be no major disagreements), and with sun248, which additionally includes platform-specific notes. Copyright 2004-5, Council for the Central Laboratory of the Research Councils Copyright 2007, Particle Physics and Astronomy Research Council Copyright 2007, Science and Technology Facilities Council ii SSN/78.1—Contents Contents 1 Introduction 1 1.1 Quick entry-points . 2 2 Tools 3 2.1 Overview of the Autotools . 3 2.1.1 Autoconf . 5 2.1.2 Automake . 9 2.1.3 Libtool . 13 2.1.4 Autoreconf: why you don’t need to know about aclocal .
    [Show full text]
  • 1 What Is Gimp? 3 2 Default Short Cuts and Dynamic Keybinding 9
    GUM The Gimp User Manual version 1.0.0 Karin Kylander & Olof S Kylander legalities Legalities The Gimp user manual may be reproduced and distributed, subject to the fol- lowing conditions: Copyright © 1997 1998 by Karin Kylander Copyright © 1998 by Olof S Kylander E-mail: [email protected] (summer 98 [email protected]) The Gimp User Manual is an open document; you may reproduce it under the terms of the Graphic Documentation Project Copying Licence (aka GDPL) as published by Frozenriver. This document is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANT- ABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Graphic Documentation Project Copying License for more details. GRAPHIC DOCUMENTATION PROJECT COPYING LICENSE The following copyright license applies to all works by the Graphic Docu- mentation Project. Please read the license carefully---it is similar to the GNU General Public License, but there are several conditions in it that differ from what you may be used to. The Graphic Documentation Project manuals may be reproduced and distrib- uted in whole, subject to the following conditions: The Gimp User Manual Page i Legalities All Graphic Documentation Project manuals are copyrighted by their respective authors. THEY ARE NOT IN THE PUBLIC DOMAIN. • The copyright notice above and this permission notice must be preserved complete. • All work done under the Graphic Documentation Project Copying License must be available in source code for anyone who wants to obtain it. The source code for a work means the preferred form of the work for making modifications to it.
    [Show full text]
  • Supporting the Development Process of the Datagrid Workload Management System Software with GNU Autotools, CVS And
    Supporting the Development Process of the DataGrid Workload Management ∗ System Software with GNU autotools, CVS and RPM A. Gianelle, R. Pelusoy , M. Sgaravatto, INFN Sezione di Padova, Via Marzolo 8, I-35131 Padova, Italy F. Giacomini, E. Ronchieriz , INFN CNAF, Viale Berti Pichat 6/2 , I-40127 Bologna, Italy G. Avellino, B. Cantalupo, S. Beco, A. Maraschini, F. Pacini, DATAMAT S.p.A., Via Laurentina 760, I-00143 Roma, Italy A. Guarise, R. Piro, A. Werbrouck, INFN Sezione di Torino, Via P. Giuria 1, I-10125 Torino, Italy D. Kouril, A. Krenek, Z. Kabela, L. Matyska, M. Mulac, J. Pospisil, M. Ruda., Z. Salvet, J. Sitera, M. Vocu, CESNET z.s.p.o., Zikova 4, 160 00 Praha 6, Czech Republic M. Mezzadri, F. Prelzx , INFN Sezione di Milano, Via Celoria, 16, I-20133 Milano, Italy S. Monforte, M. Pappalardo, INFN Sezione di Catania, Via S. Sofia 64, I-95123 Catania, Italy D. Colling, Imperial College London, Blackett Laboratory, Prince Consort Road, London, SW7 2BW, UK Abstract The EDG WMS package contains daemons, libraries, test programs, documentation, etc. It is divided into com- Supporting the development of the Workload Manage- ponents that encapsulate independent functionalities part ment System in the context of the European DataGrid was of the package. The whole package is organised in a sin- a challenging task as the team was characterized by a high gle directory tree. Each component is identified by a sub- geographic and administrative dispersion, with developers directory and the main directory name is “workload”. Fur- distributed in various institutions and countries. Further, ther levels are present inside each component sub-directory.
    [Show full text]
  • Empirical Comparison of Scons and GNU Make
    Großer Beleg Empirical Comparison of SCons and GNU Make Ludwig Hähne August 21, 2008 Technical University Dresden Department of Computer Science Institute for System Architecture Chair for Operating Systems Professor: Prof. Dr. rer. nat. Hermann Härtig Tutor: Dipl.-Inf. Norman Feske Dipl.-Inf. Christian Helmuth Erklärung Hiermit erkläre ich, dass ich diese Arbeit selbstständig erstellt und keine anderen als die angegebenen Hilfsmittel benutzt habe. Dresden, den 26. Juni 2008 Ludwig Hähne Abstract Build systems are an integral part of every software developer’s tool kit. Next to the well-known Make build system, numerous alternative solutions emerged during the last decade. Even though the new systems introduced superior concepts like content signa- tures and promise to provide better build accuracy, Make is still the de facto standard. This paper examines GNU Make and SCons as representatives of two conceptually distinct approaches to conduct software builds. General build-system concepts and their respective realizations are discussed. The performance and scalability are empirically evaluated by confronting the two competitors with comparable real and synthetic build tasks. V Contents 1 Introduction 1 2 Background 3 2.1 Design Goals . .3 2.1.1 Convenience . .3 2.1.2 Correctness . .3 2.1.3 Performance . .3 2.1.4 Scalability . .4 2.2 Software Rebuilding . .4 2.2.1 Dependency analysis . .4 2.2.1.1 File signatures . .4 2.2.1.2 Fine grained dependencies . .5 2.2.1.3 Dependency declaration . .5 2.2.1.4 Dependency types . .5 2.2.2 Build infrastructure . .6 2.2.3 Command scheduling . .6 2.3 Build System Features .
    [Show full text]