Major Git projects commonly have a contributor workflow where other contributors
fork
a primary Git repository, make changes, and then contribute back to the primary project.
This article describe the contributor workflow.
The maintainer workflow is in a separate article.
The contributor forks the primary project Git repo.
On the local copy of the fork, create a feature branch:
git switch -c add-feature1
Once the new work is complete, make the branch consistent with the primary repo by pulling in
the latest changes from the primary repo:
git switch main
# whatever the primary or development branch of the primary repo isgit remote add upstream https://github.invalid/primary/repo_url
git fetch upstream
git rebase upstream/main
Update the local branch to remote main
git switch add-feature1
git rebase main
Test the final updated code.
Create the
Pull Request
/
Merge Request
for the maintainer to evaluate the changes and possibly put them into the primary project.
OpenMPI 4.x uses temporary files for UNIX sockets, which are limited to 100 character path length.
This can become an issue on macOS, which by default sets POSIX environment variable TMPDIR to a pseudorandom path under “/var” about 50 character long.
We have experienced this as a race condition that becomes more likely as the number of MPI workers is eight or more.
A
workaround
is to set an alias for mpiexec or within CMake test properties etc. such that mpiexec gets a sufficiently short working path so that UNIX sockets don’t fail due to excessive path length.
Midnight Commander
is an
open source
Terminal-based GUI for browsing filesystems.
It’s useful to have a non-graphical method to manage and view files, particularly on remote systems over SSH.
Installing Midnight Commander is done by:
Fortran 2018 contiguous arrays are discussed in pp.139-145 of “Modern Fortran Explained: Incorporating Fortran 2018”.
In general, operating on contiguous arrays is faster than non-contiguous arrays.
Contiguous variables happen by default, so unless using pointers or array striding, the variable is likely to be contiguous for simple Fortran code.
Check contiguous status of a variable with is_contiguous intrinsic function.
A non-contiguous array actual argument into a contiguous subroutine dummy argument is made contiguous by copy-in, copy-out.
This copy-in copy-out as needed is part of the
Fortran 2008
and
Fortran 2018
standard.
GCC ≥ 9,
Intel oneAPI,
IBM Open XL Fortran,
etc. work to Fortran 2008+ standard for contiguous dummy argument copy-in, copy-out for non-contiguous actual argument.
CMake can use clang-tidy as a build option for a CMake project by adding a few parameters to CMakeLists.txt.
It’s also possible to use clang-tidy without modifying CMakeLists.txt.
Generate the file compile_commands.json used by clang-tidy.
You don’t have to build the project as we are interested in checking and possibly fixing the C++ source code.
To install clang-tidy:
macOS: brew install llvm, then edit ~/.zshrc, adding the line alias clang-tidy=$(brew --prefix llvm)/bin/clang-tidy or similar
Linux: apt install clang-tidy or similar
cmake -Bbuild -DCMAKE_EXPORT_COMPILE_COMMANDS=on
Run clang-tidy. Specify options or use a file .clang-tidy, which is usually in the top directory of the project.
A project switched to Fortran
mpi_f08
after realizing runtime crashes in very large simulations were due to MPI-2.
The Fortran mpi_f08 interface was released in 2012 and is well supported by contemporary compilers and MPI libraries.
MPICH reqiures
ISO_Fortran_binding.h.
GCC + MPICH or Clang + OpenMPI and many other combinations work.
CMake can retrieve the current time in local (default), UTC, or other timezone via
string(TIMESTAMP).
Elapsed time can also readily be computed or compared using timestamp format %s
Currently, CMake
math
command cannot handle floating point numbers, only integers.
Git
history browsing
can be easier with a GUI, which are available for most platforms.
Git installs
can come with a GUI by default.
However, many package managers make the GUI a separate install to save considerable time and space on cloud servers, virtual machines and similar.
Here are a few example commands to install
gitk,
a basic Git history browser:
macOS: brew install git-gui
Linux: apt install gitk or dnf install gitk or similar
Windows: winget install Git.Git that comes with “gitk”
For those using GitHub,
GitHub Desktop
is a popular Git GUI.