mkproj/mkproj.1

351 lines
10 KiB
Groff
Raw Permalink Normal View History

2024-12-31 14:45:50 +01:00
.Dd December 31, 2024
2024-12-27 10:02:39 +01:00
.Dt mkproj 1
.Os
.Sh NAME
.Nm mkproj
.Nd Create C++ project directory with predefined templates
.\" .Sh LIBRARY
.\" For sections 2, 3, and 9 only.
.\" Not used in OpenBSD.
.Sh SYNOPSIS
.Nm
.Fl v
.Nm
2024-12-31 14:34:36 +01:00
.Op Fl f | Fl l | Fl n | Fl s
2024-12-27 10:02:39 +01:00
.Oo
.Op Fl d
.Fl g Ar gitroot
.Oc
.Op Fl t Ar tplroot
.Ar project
.Sh DESCRIPTION
The
.Nm
script creates a C++ project directory structure with some predefined
boilerplate files, ready to be built using
.Xr make 1 .
2024-12-31 14:34:36 +01:00
.Pp
Please note that you will need GNU Make to use the supplied Makefiles, which is
standard on Linux systems.
On BSD systems, use
.Xr gmake 1 ,
which is usually available through a package manager for the platform.
.Pp
2024-12-27 10:02:39 +01:00
.Nm
can create a directory for a simple project using a single source file; a
general project suitable for many source files; a general project setup as a
standard UNIX filter; and a library project, setup to create a static as well as
a shared library.
.Pp
It will also setup the project for use with
.Xr git 1 ,
and do a first commit for the project's files.
.Pp
The main.cpp source files for the general and filter projects already have code
in place to do complete option handling, for long and short options. It can also
display a version string, containing the
.Xr git 1
commit hash, after you have built the tool at least once.
.Pp
2024-12-31 14:34:36 +01:00
The options for
.Nm
are as follows:
2024-12-27 10:02:39 +01:00
.Ss General Options
.Bl -tag -width Ds
2024-12-31 14:34:36 +01:00
.It Fl d
Save default Git URL to clone from.
Will only have any effect when also using the
.Fl g
option.
It will cause the
.Ar gitroot
argument for
.Fl g
to be saved into the
.Nm
configuration file, for later use with the
.Fl G
option.
.It Fl g Ar gitroot
2024-12-27 10:02:39 +01:00
Clone a
.Xr git 1
repo from the supplied git URL.
When combined with the
.Fl d
option, the supplied git URL will be saved into the
.Nm
configuration file.
2024-12-31 14:34:36 +01:00
.It Fl G
Use the Git URL saved earlier to clone a repo from.
.It Fl t Ar tplroot
2024-12-27 10:02:39 +01:00
Specify the root directory where the project templates can be found.
This option is useful when you want to use a modified set of files to base your
projects on.
2024-12-31 14:34:36 +01:00
.It Fl v
Print version info and exit.
2024-12-27 10:02:39 +01:00
.El
.Ss Project Type Options
.Bl -tag -width Ds
2024-12-31 14:34:36 +01:00
.It Fl f
Create a filter tool project.
.It Fl l
2024-12-27 10:02:39 +01:00
Create a library project.
2024-12-31 14:34:36 +01:00
.It Fl n
Create a normal tool project.
This is the default.
.It Fl s
Create a simple tool project.
2024-12-27 10:02:39 +01:00
.El
.Pp
Without any
.Sx Project Type Options ,
A general project for a command line tool with multiple source files will be
created.
.Pp
The
.Sx Project Type Options
are mutually exclusive.
.\" .Sh CONTEXT
.\" For section 9 functions only.
.\" .Sh IMPLEMENTATION NOTES
.\" Not used in OpenBSD.
.\" .Sh RETURN VALUES
.\" For sections 2, 3, and 9 function return values only.
.\" .Sh ENVIRONMENT
.\" For sections 1, 6, 7, and 8 only.
2024-12-27 10:21:21 +01:00
.Sh FILES
.Bl -tag -width Ds
.It Pa ~/.config/mkprojrc
This file is sourced by the
.Nm
script, and will at least contain the definition for the
.Sq tplroot
variable, and possibly also the definition of the
.Sq gitroot
variable.
Since it is shell syntax, paths should be properly quoted, and comments are
allowed.
.El
2024-12-27 10:02:39 +01:00
.Sh EXIT STATUS
.\" For sections 1, 6, and 8 only.
.Nm
exits 0 on success, and 1 if an error occurs.
.\" .Sh EXAMPLES
.\" .Sh DIAGNOSTICS
.\" For sections 1, 4, 6, 7, 8, and 9 printf/stderr messages only.
.\" .Sh ERRORS
.\" For sections 2, 3, 4, and 9 errno settings only.
.Sh PROJECT DESCRIPTION
The project created by
.Nm
has the following features.
2024-12-31 14:45:50 +01:00
.Ss Normal Tool Project
This creates a full-featured project for a tool, with the following layout:
2024-12-27 10:02:39 +01:00
.Bd -literal
mytool
2024-12-30 13:17:06 +01:00
|-- Makefile
|-- man
| `-- man1
| `-- mytool.1
|-- premake.make
|-- src
| |-- main.cpp
| |-- precomp.hpp
| |-- version.cpp
| `-- version.hpp
`-- tests
|-- Makefile -> ../Makefile
|-- postmake.make
|-- premake.make
`-- src
|-- main.cpp
`-- precomp.hpp -> ../../src/precomp.hpp
2024-12-27 10:02:39 +01:00
.Ed
.Pp
2024-12-27 10:21:21 +01:00
In this example, the project name is
.Dq mytool .
2024-12-27 10:02:39 +01:00
.Pp
Description:
.Bl -tag -width Ds
.It Makefile
This is a universal Makefile, which should not be edited.
All customization should be done in premake.make, and, optionally,
postmake.make.
The idea is that you should be able to replace it, at any time, with a newer
version, without affecting the overall functionality.
See
.Sx Makefile targets
below for more details about what's possible here.
.It man directories
Contains a boilerplate man page, ready to be edited with relevant content.
If the project needs multiple man pages, possibly also for man chapter 3 and/or
5, they can be added here.
The structure will be merged into a man directory hierarchy at install time.
.It premake.make
This file will be included by the Makefile, as a first action.
In it, several important project-related Makefile variables can and will be
defined.
.Bl -tag -width Ds
.It LDLIBS
Initially empty, this is where you can specify library dependencies, like
-lsqlite3, or -lpthread.
.It PROJ
By default, this will evaluate to the project directory's name.
Alter only if you really want another name for the tool you'll build.
Defined here, so you can use it inside the premake.make, should you need to
derive other variables from it.
.It UNAME_S
Should not be changed; here as a convenience to be able to conditionally define
Makefile rules, dependent on the type of operating system.
Defined here, so you can use it inside the premake.make.
.It PRODUCT
2024-12-27 10:21:21 +01:00
Only two values allowed:
.Dq tool ,
or
.Dq lib .
2024-12-27 10:02:39 +01:00
Used by the Makefile to do the right thing for either type of project.
.It MAJOR, MINOR, PATCH
Together, they form the version for your project.
Important: this is the single source of truth for the version numbering, and
will be used in the Makefile as well as in the preinstalled sources.
.It CXXFLAGS
This is where the C++ standard is defined.
Change if needed for your project.
2024-12-27 10:21:21 +01:00
Note the
.Dq +=
2024-12-31 14:34:36 +01:00
operator here, so a possibly defined
.Ev CXXFLAGS
environment variable will be honored.
2024-12-27 10:02:39 +01:00
.It PRECOMPILE
The project can generate and use a precompiled header.
By default, the precomp.hpp file contains the C++ Standard Library headers, but
you could add more to that file, if you like (for example, other library
headers).
By default, it is switched off.
Set to 1 if you want to switch it on.
.It PLUGINS
If your project supports plugins of any type, define the directory name(s) here.
The Makefile will then automatically build and install plugins as well.
Leave empty if your project does not use any plugins.
.El
.It src directory
Subdirectory for headers and source files.
The file already present can be used to compile and build the tool, providing
some nice features out of the box.
See
.Sx Tool Features
below for more information.
.It tests directory
Subdirectory for unit tests, using the Boost Unit Test Framework.
.El
2024-12-31 14:45:50 +01:00
.Ss Filter Tool Project
The filter tool project has an identical structure as the normal type, but adds
some functionality to make the tool behave as a real UNIX filter.
2024-12-27 10:02:39 +01:00
See
.Sx Tool Features
below for more information.
2024-12-31 14:45:50 +01:00
.Ss Library Project
2024-12-27 10:02:39 +01:00
The library project has been set up to produce a static and dynamic library from
your sources.
Its directory structure is almost identical to that of a tool.
The only differences are, that the man page is for man chapter 3, and there is
no main.cpp source file.
.Pp
When building the library, a static and dynamic library are produced, containing
by default a single function which can return a version string.
.Pp
TODO describe lib header generation, honoring @exclude
2024-12-31 14:45:50 +01:00
.Ss Simple Tool Project
The simple tool project is just a directory with a single source file and a
Makefile.
2024-12-27 10:02:39 +01:00
The idea is that you use this for simple, quick proof-of-concept tools.
Here, the source file has the same name as the project, and is almost empty, so
nothing is in the way to make it do what you want.
2024-12-27 10:21:21 +01:00
The Makefile is very simple, can do a
.Dq make
as well as a
.Dq make clean ,
but no more.
2024-12-27 10:02:39 +01:00
Possible library dependencies should be added to the Makefile.
.Ss Makefile targets
2024-12-31 14:45:50 +01:00
The description below is valid for all project types, except the simple tool
project.
2024-12-27 10:02:39 +01:00
.Bl -tag -width Ds
.It make
Use this to compile and link your tool.
2024-12-31 14:34:36 +01:00
When doing this for the first time, or after doing a
2024-12-27 10:21:21 +01:00
.Dq make dist-clean ,
a
.Dq build
subdirectory will be created.
Inside it, an
.Dq obj
subdirectory appears, which will contain all object files
2024-12-27 10:02:39 +01:00
(*.o), and all dependency files (*.dep), used by the Makefile.
2024-12-27 10:21:21 +01:00
Also, either a
.Dq debug
or
.Dq release
subdirectory will appear, depending on the
definition of the
.Ev DEBUG
environment variable.
2024-12-27 10:02:39 +01:00
This is the place where your tool or libraries will appear.
For convenience, a symlink is created on the top level of your project, pointing
to the executable, if it's a tool.
2024-12-27 10:21:21 +01:00
That way, you can simply do
.Ql ./mytool
to run it.
2024-12-27 10:02:39 +01:00
.It make test
This will build and run a test tool from the tests directory.
You are expected to add your tests to the tests/src/main.cpp file, using
assertions from the Boost Unit Test Framework.
Running tests will report successes and failures.
.It make install
When installing your tool and its man page outside your home directory, prefix
2024-12-27 10:21:21 +01:00
with
.Dq sudo ,
or
.Dq doas ,
depending on your system.
2024-12-27 10:02:39 +01:00
.It make clean
This will remove compiled object files and dependency files, but keep the
previously built tool and precompiled header intact.
.It make dist-clean
This brings the project directory back to a pristine state, removing everything
2024-12-27 10:21:21 +01:00
that is generated using the various
.Dq make
invocations.
2024-12-27 10:02:39 +01:00
.It make uninstall
2024-12-27 10:21:21 +01:00
Remove the files that are installed by the
2024-12-31 14:34:36 +01:00
.Dq make install
2024-12-27 10:21:21 +01:00
invocation.
2024-12-27 10:02:39 +01:00
Please note that no dependency checks are done, so removal could break other
tools or libraries that depend on the removed files.
2024-12-31 14:34:36 +01:00
.Pp
Also, if the install also created standard directories, like
.Pa /usr/local/bin ,
.Pa /usr/local/lib ,
.Pa /usr/local/include ,
etc., and they end up empty after the uninstall, they won't be removed.
2024-12-27 10:02:39 +01:00
.El
.Ss Tool Features, out of the box
TODO describe main.cpp and version.cpp here.
.Sh SEE ALSO
.Xr make 1 ,
.Xr git 1 .
.\" .Xr foobar 1
.\" .Sh STANDARDS
.\" .Sh HISTORY
.Sh AUTHORS
Bob Polis
.\" .Sh CAVEATS
.Sh BUGS
.Nm
does no error checking for using multiple
.Sx Project Type Options
at once.
You are at the mercy of the script which type will be created in that case.
.\" .Sh SECURITY CONSIDERATIONS
.\" Not used in OpenBSD.