- S2E-AOBC is the user-side repository of the S2E for the AOCS module developed by ISSL/UT, Seiren, and JAXA.
- Support platforms
- Windows Visual Studio 2022 C++ compiler with 32bit build
- Linux g++ compiler version 11 with 32bit build
- We use GitHub Actions to check the build errors in these compilers continuously.
- How to use
The main developers
of the AOCS module directly use this repository to add new features and improve the module.General users
of the AOCS module do not need to use and edit this repository directly. They need to create a project-specific repository and define spacecraft-specific parameters within the repository.
- We use Semantic Versioning 2.0.0 as the versioning style
- Basic version format is
<major>.<minor>.<patch>
(like4.0.0
) - Public API is declared in the code itself (currently, there is no definitive list)
- Basic version format is
- All releases should be tagged as
v<semver>
(likev4.0.0
)
- We recommend making a project-specific repository named
s2e-aobc-project-name
. - Users can refer to the
s2e-aobc/example
directory to make a directory construction ofs2e-aobc-project-name
.- NOTE Please change all words like
example, EXAMPLE, or Example
in the files in this directory to suit your project name.
- s2e-aobc (git submodule) - We recommend to use a released version of s2e-aobc. - data - CMakeLists.txt - CMakeSettings.json - README.md
- NOTE Please change all words like
- To construct the
s2e-aobc
directory, we recommend to usegit submodule
to take in thes2e-aobc
repository.- Reference: Git Tools Submodule.
CMakeLists.txt
- Please change all words
example, EXAMPLE, or Example
in the file to suit your project name.
- Please change all words
- Please see the README.md in the
example
directly.
- When general users add new features or remove this repository's bugs, please make upstream pull requests from a forked repository.
- Before making PRs, please carefully read the following
Development style
. - If you have any questions, please feel free to ask us.
git submodule
- This repository includes s2e-core with the
git submodule
. Please use the following commands to construct the directory.$ git clone [email protected]:ut-issl/s2e-aobc.git $ cd s2e-aobc/ $ git submodule init $ git submodule update
- Or use the following commands to clone the repository.
$ git clone --recursive [email protected]:ut-issl/s2e-aobc.git
- This repository includes s2e-core with the
- External Libraries
- Users can use
s2e-aobc/s2e-core/ExtLibraries/CMakeLists.txt
to download the external libraries. - Please find how to download the
ExtLibraries
in the s2e-document.
- Users can use
- Make the
FlightSW
directory at the same directory withs2e-aobc
- Clone the C2A-AOBC repository into
FlightSW
- Current support version: v7.0.0
- Directory Construction
- s2e-aobc - FlightSW - c2a-aobc
- You can build
s2e-aobc
usingCMake
together withc2a-aobc
.
-
Repository settings
- Branch structure
- main # The latest operation guaranteed codes for general users - develop # The latest buildable codes for S2E primary developers - feature/* # Developing codes - hotfix/* # Bug Fix codes
- Push to
main
anddevelop
is prohibited. All developers have to develop withfeature/*
orhotfix/*
branch and make a pull request.
- Branch structure
-
Flow of development
- Make a
feature/*
branch from thedevelop
branch.- To fix the small bugs in the latest release codes, please make
hotfix/*
branch from themain
branch.
- To fix the small bugs in the latest release codes, please make
- Edit, commit, and push in the branch.
- Please check the coding convention and the
code format
in the next section.
- Please check the coding convention and the
- Create a new pull request to the
develop
branch.- The target branch becomes the
main
branch for thehotfix/*
branches.
- The target branch becomes the
- A maintainer reviews the pull request. If some problems are found, the maintainer proposes modifications.
- According to the maintainer's proposal, the developer modifies the codes and goes back to 3.
- The maintainer merges the
feature/*
branch with thedevelop
branch. - The code owners decide to merge the
develop
branch to themain
branch and release a new version.
- Make a
-
Binary files
- Binary file commit is prohibited.
- Please write the link to such files, or make a script file to get the files.
- Exception
- Images for markdown document files are allowable when the file size is smaller than 200K Bytes.
-
Code format
- We use clang-format to format the source code.
- We recommend installing the
clang-format
and format code before the commit. It also will be checked on CI. - Some modern editor has plugin/extension for code format. It will be very useful.
- VSCode: C/C++
- Vim: vim-clang-format
- 21st Apr. 2020: Development started in a private repository at GitLab.
- 26th Sep. 2022: Initial development was finished.
- 03rd Mar. 2023: Move to a private repository at GitHub to prepare to publish as OSS.
- 14th Jul. 2023: Convert to a public repository.
- ISSL, UT
- Satoshi Ikari: 158 commits
- Hirotaka Sekine: 47 commits
- Toshio Imamura: 42 commits
- Toshihiro Suzuki: 37 commits
- Ryo Suzumoto: 20 commits
- Takayuki Hosonuma: 14 commits
- Masahiro Fujiwara: 13 commits
- Nobuhiro Funabiki: 12 commits
- Ryohei Takahashi: 4 commits
- Toshifumi Igeta: 2 commits
- Yoshinari Gyu: 1 commit
- Keidai Iiyama: 1 commit
- S. Ikari, and et al., "Development of Compact and Highly Capable Integrated AOCS Module for CubeSats", 2022-f-41, 33rd ISTS, 2022.