Skip to content
Patrick van Kleef edited this page Sep 25, 2023 · 10 revisions

Using Virtuoso Open Source Edition GIT Tree

Copyright © 1998-2023 OpenLink Software [email protected]

Introduction

This document describes how to checkout a copy of the git tree for development purposes. It also lists the packages that need to be installed prior to generating the necessary scripts and Makefiles to build the project.

Git access is only needed for developers who want to actively track progress of the Virtuoso source code and contribute bugfixes or enhancements to the project. It requires basic knowledge of git itself, the general layout of open source and GNU projects, the use of autoconf and automake etc, which is beyond the scope of this document.

If you have any questions, please email us at [email protected] or open a GitHub issue.

Git Archive Server Access

For main development OpenLink Software will publish the Virtuoso Open Source tree to GitHub and encourages everyone who is interested in tracking the project, to make an account there.

Users who mainly just want to track the code can use the following command to get a copy of the tree:

$ git clone git://github.com/openlink/virtuoso-opensource.git

At this point you can create your own work branch based on any of the branches available, create bug-fixes and commit them to your own branch and then use the git format-patch command to generate the appropriate diffs to send to:

Developers are encouraged to fork the project using GitHub, create their own branches to make enhancements/bug-fixes and then send pull requests using the excellent GitHub interface for the OpenLink team to examine and incorporate the fixes into the master tree for an upcoming release.

Github has excellent documentation on how to fork a project, send pull requests, track the projectcompleteness, etc., on:

http://help.github.com/

OpenLink Software will continue to use sourceforge.net for the source tarball releases and certain binary releases, and for completeness will also provides read-only Git Archive access.

For more information, see our project page on SourceForge

Package Dependencies

To generate the configure script and all other build files necessary, please make sure the following packages and recommended versions are installed on your system.

Package Minimum Upto From
autoconf 2.57 2.69 http://www.gnu.org/software/autoconf/
automake 1.9 1.16.1 http://www.gnu.org/software/automake/
libtool 1.5 2.4.6 http://www.gnu.org/software/libtool/
flex 2.5.33 2.6.4 http://flex.sourceforge.net/
bison 2.3 3.5.1 http://www.gnu.org/software/bison/
gperf 3.0.1 3.1 http://www.gnu.org/software/gperf/
gawk 3.1.1 5.0.1 http://www.gnu.org/software/gawk/
m4 1.4.1 1.4.18 http://www.gnu.org/software/m4/
make 3.79.1 4.2.1 http://www.gnu.org/software/make/
OpenSSL 0.9.8e 3.1.x http://www.openssl.org/

and any GNU packages required by these. The autogen.sh and configure scripts check for the presence and right version of some of the required components.

The Minimum column contains the oldest known versions of these packages capable of building Virtuoso. Older versions of these packages can sometimes be used, but could cause build problems.

The Upto column contains the most recently tested version of these packages.

To check the version number of the tools installed on your system, use one of the following commands:

  • autoconf --version
  • automake --version
  • libtoolize --version
  • flex --version
  • bison --version
  • gperf --version
  • gawk --version
  • m4 --version
  • make --version
  • openssl version

If you have an older version than automake version 1.9 you can edit the configure.ac script around line 47 using the examples provided for each version.

Mac OS X 10.10 and above

Apple removed a number of programs from their Xcode.app commandline installation including the autoconf, automake, libtool, gperf and some other tools needed to build Virtuoso from a newly checked out GIT tree.

We suggest using the HomeBrew package manager from http://brew.sh/ to install these tools.

RedHat Enterprise Linux 7

On RedHat 7, the gperf tool is no longer available from the default repos, but can be installed using the following command:

$ sudo yum --enablerepo=rhui-REGION-rhel-server-optional install gperf

RedHat Enterprise Linux 8

On RedHat 8, the gperf tool is no longer available from the default repos, but can be installed using the following command:

$ sudo yum --enablerepo=PowerTools install gperf

Diskspace Requirements

The build produces a demo database and Virtuoso application packages that are quite large. At least 800 MB of free space should be available in the build file system.

When running `make install', the target file system should have about 460 MB free. By default, the install target directories are under /usr/local/, but you can instead specify:

./configure --prefix=/path/to/dir

The minimum working configuration consists of the server executable and config files plus database, no more than a few MB for the server executable, depending on platform and options.

Generate build files

To (re)generate the configure script and all related build files, use use the supplied script in your working directory:

$ ./autogen.sh

If the above command succeed without any error messages, please use the following command to check out all the options you can use:

$ ./configure --help

Certain build targets are only enabled when the --enable-maintainer-mode flag is added to configure.

Please read the files INSTALL and README in this directory for further information on how to configure the package and install it on your system.