Welcome to ONSAS.jl contributor brief guide. Everyone is kindly welcome and of course there are several things to do. Contributing into this does not require Julia experience or even advanced programming knowledge.
First we strongly recommend to join the regular community meets or via slack. Also you can mail us at: [email protected], [email protected] and [email protected]
Here you can find things about:
If you want to contribute to a software package, but you're new to open source development you can check on this page to get started. Additionally, if you're interested in contributing to a Julia package, you may find the video Open source, Julia packages, git, and GitHub to be a valuable resource.
If you have found a bug or a problem with ONSAS.jl you can open an [issue][new-issue]. Try to include as much information about the problem as possible and preferably some code that can be copy-pasted to reproduce it (see How to create a Minimal, Reproducible Example). If you can identify a fix for the bug you can submit a pull request without first opening an issue, see Code changes.
Starting to contribute to a new project's documentation is an excellent way to begin. As a new user, you bring a fresh perspective and can easily identify what areas need better documentation or explanation. If something is confusing to you, chances are other users have similar questions. It's important to remember that even small contributions, such as correcting typos, are valuable. If you're not sure where to begin, you can check out the open issues for specific areas that need improvement.
Making small changes is simple using GitHub's web interface (refer to Editing files). For every page in the documentation, there is an Edit on GitHub button at the top, which redirects you to the relevant source file. If you need guidance on how to make Julia documentation better, check out the step by step tutorial: Making Julia documentation better.
Making larger changes is easier locally after cloning the repository. For this process the documenting Julia manual and documentation for Documenter.jl
are essential. To preview the docs you should move into the ./docs/
folder and run:
julia --project=.
Followed by:
include("make.jl")
A new docs/build/
folder will be automatically created, to preview the docs open the index.html
file.
In case you encounter a bug or issue with ONSAS.jl, you can create an issue by providing as much information as possible about the problem. Ideally, include some code that can be easily copied and pasted to replicate the issue (refer to How to create a Minimal, Reproducible Example). If you're able to identify a solution for the bug, please create an issue and then a pull request solving it.
The code style is based on the Julia style guide and is done automatically using JuliaFormatter.jl. Moreover, this items should be considered:
-
Naming files:
- The abstract interfaces should be named in plural like
Entities.jl
,Materials.jl
,LinearElasticMaterials.jl
LoadBoundaryConditions.jl
, etc. - The concrete implementations should wrapped into a module and named in singular. For instance if a
GlobalLoad
object is defined then the file name should beGlobalLoadBoundaryCondition.jl
. - Each file should be a module named as the file name without the extension. For instance,
Entities.jl
should bemodule Entities
.
- The abstract interfaces should be named in plural like
-
Testing files:
- They should be named
<module_name>.jl
and placed in thetest/
folder. - Unitary tests should use
using ONSAS.Module
as the module name. And also usingONSAS.OtherModule
if needed. - End-to-end tests should use
using ONSAS
.
- They should be named
-
How to import packages and overload methods:
- First, external packages are included via
using
(e.g.using LinearAlgebra
) without specifying the method:
. Also a,
should be used to separate packages instead of an enter. - Then , internal packages are included (e.g.
using ..Module
) without:
followed by an enter. - Finally, if a method is overloaded the module should export that method too. For that, use
@reexport import ONSAS.Module: method
with:
. If the method lives inBase
just useBase.method(...)
in-place to overload.
- First, external packages are included via
Here is an example:
using ExternalPkgs, Reexport
using ..Materials
using ..Entities
@reexport import ..Entities: strain_energy
Note that the use of ..
and ...
depends on the number of levels you need to go up in the module hierarchy.
- How to use docstrings:
- Use
"
to start and end a docstring for a function. - Use
"""
to start and end a docstring for a module, struct, type, etc. - Start with
Return
,Set
,Add
... depending on the function. - Include docstrings before the
struct
field definition. - Abstract types should include Abstract Methods and Abstract fields sections.
- Use
The authorship of the code is based on the criteria defined by the JOSS journal. The co-authors have collaborated in tasks such as: design, important new features development or extensive documentation contributions.