Skip to content

Commit 747fc64

Browse files
fix: corrected READMEs and info on doc generation
1 parent 0c204f5 commit 747fc64

File tree

7 files changed

+459
-8
lines changed

7 files changed

+459
-8
lines changed

.gitignore

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -57,6 +57,9 @@ compile_commands.json
5757
coverage/
5858
coverage.info
5959

60+
# Documentation
61+
docs/
62+
6063
# IDE
6164
.vscode/*
6265
!.vscode/settings.json

CODE_OF_CONDUCT.md

Lines changed: 128 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,128 @@
1+
# Contributor Covenant Code of Conduct
2+
3+
## Our Pledge
4+
5+
We as members, contributors, and leaders pledge to make participation in our
6+
community a harassment-free experience for everyone, regardless of age, body
7+
size, visible or invisible disability, ethnicity, sex characteristics, gender
8+
identity and expression, level of experience, education, socio-economic status,
9+
nationality, personal appearance, race, religion, or sexual identity
10+
and orientation.
11+
12+
We pledge to act and interact in ways that contribute to an open, welcoming,
13+
diverse, inclusive, and healthy community.
14+
15+
## Our Standards
16+
17+
Examples of behavior that contributes to a positive environment for our
18+
community include:
19+
20+
* Demonstrating empathy and kindness toward other people
21+
* Being respectful of differing opinions, viewpoints, and experiences
22+
* Giving and gracefully accepting constructive feedback
23+
* Accepting responsibility and apologizing to those affected by our mistakes,
24+
and learning from the experience
25+
* Focusing on what is best not just for us as individuals, but for the
26+
overall community
27+
28+
Examples of unacceptable behavior include:
29+
30+
* The use of sexualized language or imagery, and sexual attention or
31+
advances of any kind
32+
* Trolling, insulting or derogatory comments, and personal or political attacks
33+
* Public or private harassment
34+
* Publishing others' private information, such as a physical or email
35+
address, without their explicit permission
36+
* Other conduct which could reasonably be considered inappropriate in a
37+
professional setting
38+
39+
## Enforcement Responsibilities
40+
41+
Community leaders are responsible for clarifying and enforcing our standards of
42+
acceptable behavior and will take appropriate and fair corrective action in
43+
response to any behavior that they deem inappropriate, threatening, offensive,
44+
or harmful.
45+
46+
Community leaders have the right and responsibility to remove, edit, or reject
47+
comments, commits, code, wiki edits, issues, and other contributions that are
48+
not aligned to this Code of Conduct, and will communicate reasons for moderation
49+
decisions when appropriate.
50+
51+
## Scope
52+
53+
This Code of Conduct applies within all community spaces, and also applies when
54+
an individual is officially representing the community in public spaces.
55+
Examples of representing our community include using an official e-mail address,
56+
posting via an official social media account, or acting as an appointed
57+
representative at an online or offline event.
58+
59+
## Enforcement
60+
61+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
62+
reported to the community leaders responsible for enforcement at
63+
[INSERT CONTACT METHOD].
64+
All complaints will be reviewed and investigated promptly and fairly.
65+
66+
All community leaders are obligated to respect the privacy and security of the
67+
reporter of any incident.
68+
69+
## Enforcement Guidelines
70+
71+
Community leaders will follow these Community Impact Guidelines in determining
72+
the consequences for any action they deem in violation of this Code of Conduct:
73+
74+
### 1. Correction
75+
76+
**Community Impact**: Use of inappropriate language or other behavior deemed
77+
unprofessional or unwelcome in the community.
78+
79+
**Consequence**: A private, written warning from community leaders, providing
80+
clarity around the nature of the violation and an explanation of why the
81+
behavior was inappropriate. A public apology may be requested.
82+
83+
### 2. Warning
84+
85+
**Community Impact**: A violation through a single incident or series
86+
of actions.
87+
88+
**Consequence**: A warning with consequences for continued behavior. No
89+
interaction with the people involved, including unsolicited interaction with
90+
those enforcing the Code of Conduct, for a specified period of time. This
91+
includes avoiding interactions in community spaces as well as external channels
92+
like social media. Violating these terms may lead to a temporary or
93+
permanent ban.
94+
95+
### 3. Temporary Ban
96+
97+
**Community Impact**: A serious violation of community standards, including
98+
sustained inappropriate behavior.
99+
100+
**Consequence**: A temporary ban from any sort of interaction or public
101+
communication with the community for a specified period of time. No public or
102+
private interaction with the people involved, including unsolicited interaction
103+
with those enforcing the Code of Conduct, is allowed during this period.
104+
Violating these terms may lead to a permanent ban.
105+
106+
### 4. Permanent Ban
107+
108+
**Community Impact**: Demonstrating a pattern of violation of community
109+
standards, including sustained inappropriate behavior, harassment of an
110+
individual, or aggression toward or disparagement of classes of individuals.
111+
112+
**Consequence**: A permanent ban from any sort of public interaction within
113+
the community.
114+
115+
## Attribution
116+
117+
This Code of Conduct is adapted from the [Contributor Covenant][homepage],
118+
version 2.0, available at
119+
https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
120+
121+
Community Impact Guidelines were inspired by [Mozilla's code of conduct
122+
enforcement ladder](https://github.com/mozilla/diversity).
123+
124+
[homepage]: https://www.contributor-covenant.org
125+
126+
For answers to common questions about this code of conduct, see the FAQ at
127+
https://www.contributor-covenant.org/faq. Translations are available at
128+
https://www.contributor-covenant.org/translations.

CONTRIBUTING.md

Lines changed: 189 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,189 @@
1+
# Contributing
2+
3+
Thank you for your interest in contributing! This guide will help you get started.
4+
5+
## Development Setup
6+
7+
### Prerequisites
8+
9+
- CMake 3.25+
10+
- C++23 compatible compiler (GCC 14+ or Clang 16+)
11+
- Python 3.7+ (for pre-commit hooks)
12+
- (Optional) lcov for coverage reports
13+
14+
### Initial Setup
15+
16+
```bash
17+
# Clone the repository
18+
git clone <your-repo-url>
19+
cd modern-cpp-project-template
20+
21+
# Install pre-commit hooks
22+
pip install pre-commit
23+
pre-commit install
24+
```
25+
26+
## Building the Project
27+
28+
### Using Convenience Scripts
29+
30+
```bash
31+
# Build in release mode (default)
32+
./scripts/build.sh
33+
34+
# Build in debug mode
35+
./scripts/build.sh debug
36+
37+
# Build with Thread Sanitizer
38+
./scripts/build.sh tsan
39+
```
40+
41+
### Manual CMake
42+
43+
```bash
44+
cmake -B build -S . -DCMAKE_BUILD_TYPE=Release
45+
cmake --build build
46+
```
47+
48+
## Running Tests
49+
50+
```bash
51+
# Run all tests
52+
./scripts/test.sh
53+
54+
# Or manually
55+
cd build && ctest --output-on-failure
56+
```
57+
58+
## Running Benchmarks
59+
60+
```bash
61+
# Quick benchmarks
62+
./scripts/benchmark.sh
63+
64+
# Full benchmarks
65+
./build/benchmarks/hello_world_benchmark
66+
```
67+
68+
## Code Coverage
69+
70+
```bash
71+
# Generate coverage report
72+
./scripts/coverage.sh
73+
74+
# View results
75+
open coverage/html/index.html # macOS
76+
xdg-open coverage/html/index.html # Linux
77+
```
78+
79+
## Code Style
80+
81+
### Formatting (clang-format)
82+
83+
This project uses **Google C++ Style** with clang-format.
84+
85+
```bash
86+
# Format all files
87+
pre-commit run clang-format --all-files
88+
89+
# Or manually
90+
clang-format -i src/*.cpp include/*.h
91+
```
92+
93+
Pre-commit hooks will automatically format code before commits.
94+
95+
## Documentation Style
96+
97+
Use Doxygen comments for all public APIs:
98+
99+
```cpp
100+
/**
101+
* @brief Brief description of the function
102+
*
103+
* Detailed description if needed.
104+
*
105+
* @param name Parameter description
106+
* @return Description of return value
107+
*/
108+
std::string my_function(const std::string& name);
109+
```
110+
111+
See `include/hello_world.h` for examples.
112+
113+
### Generating Documentation
114+
115+
```bash
116+
# Install Doxygen (if not already installed)
117+
brew install doxygen # macOS
118+
# or
119+
sudo apt install doxygen # Linux
120+
121+
# Generate documentation
122+
./scripts/docs.sh
123+
124+
# Or manually
125+
doxygen Doxyfile
126+
127+
# View generated docs
128+
open docs/html/index.html # macOS
129+
xdg-open docs/html/index.html # Linux
130+
```
131+
132+
The generated documentation will be in the `docs/` directory (git-ignored).
133+
134+
## Pull Request Process
135+
136+
1. **Create a branch** from `master` for your changes
137+
2. **Make your changes** following the code style
138+
3. **Add tests** for new functionality
139+
4. **Run tests and coverage** to ensure nothing breaks
140+
5. **Update documentation** if adding features
141+
6. **Run pre-commit hooks**: `pre-commit run --all-files`
142+
7. **Submit a PR** with a clear description of changes
143+
144+
### PR Checklist
145+
146+
- [ ] Code follows style guide (clang-format applied)
147+
- [ ] All tests pass (`./scripts/test.sh`)
148+
- [ ] New tests added for new features
149+
- [ ] Documentation updated (if needed)
150+
- [ ] Pre-commit hooks pass
151+
- [ ] No compiler warnings
152+
153+
## Commit Messages
154+
155+
Write clear, concise commit messages:
156+
157+
```
158+
Brief summary (50 chars or less)
159+
160+
More detailed explanation if needed. Wrap at 72 characters.
161+
Explain the problem this commit solves and why this approach
162+
was chosen.
163+
```
164+
165+
## Project Structure
166+
167+
```
168+
.
169+
├── src/ # Source files (.cpp)
170+
├── include/ # Public headers (.h)
171+
├── tests/ # Unit tests (Google Test)
172+
├── benchmarks/ # Performance benchmarks (Google Benchmark)
173+
├── scripts/ # Build/test convenience scripts
174+
├── .github/workflows/ # CI/CD configuration
175+
├── CMakeLists.txt # Main CMake configuration
176+
├── Doxyfile # Doxygen configuration for API docs
177+
├── .clang-format # Code formatting rules
178+
└── .pre-commit-config.yaml # Pre-commit hooks
179+
```
180+
181+
## Getting Help
182+
183+
- Open an issue for bugs or feature requests
184+
- Check existing issues before creating new ones
185+
- Be respectful and constructive in discussions
186+
187+
## License
188+
189+
By contributing, you agree that your contributions will be licensed under the same license as the project.

0 commit comments

Comments
 (0)