cpkg 0.9.1

A dead simple C package manager.
<h1 align="center"> cpkg </h1>

<div align="center">
	<a href="https://github.com/DvvCz/cpkg/actions">
		<img alt="GitHub Actions Workflow Status" src="https://img.shields.io/github/actions/workflow/status/DvvCz/cpkg/nightly.yml?label=nightly">
	</a>
	<a href="https://crates.io/crates/cpkg">
		<img alt="Crates.io Version" src="https://img.shields.io/crates/v/cpkg">
	</a>
	<a href="https://github.com/DvvCz/cpkg/releases/latest">
		<img alt="GitHub Release" src="https://img.shields.io/github/v/release/DvvCz/cpkg">
	</a>
</div>

> A dead simple C package manager.

This is an all-in-one wrapper for `gcc`, `clang`, `doxygen`, `clang-format`, etc.  
It automatically detects which are present on your system, allowing you to use them with one simple cli.

Inspired by the convenience of modern tools like `cargo` and `bun`.

## Usage

```bash
cpkg init
cpkg run
```

## Features

### 🧑‍💻 Project Runner

You can create a project with `new` or `init`, and then run `/src/main.c` with `cpkg run` or `cpkg build`.

You can run tests located in `/src/*.test.c` and `/tests/*.c` with `cpkg test`.

### 📦 Package Management

You can add local paths with `cpkg add <name> --path /path/to/dependency` and git dependencies with `cpkg add <name> --git https://github.com/nothings/stb/tree/master`.

### 🗄️ Project File Generation

Project files can be generated using `cpkg generate`.

This creates a project file that acts as if you ran `cpkg build`, without `cpkg`.

*Currently only supports basic [`Makefile`](https://www.gnu.org/software/make) generation*

### 🛠️ Other Components

`cpkg` supports other functionalities:

* Formatting using [`clang-format`]https://clang.llvm.org/docs/ClangFormat.html
* Documenting using [`doxygen`]https://www.doxygen.nl

## ⏬ Installation

### 📩 Releases

You can download the `cpkg` binary from [the releases](https://github.com/DvvCz/cpkg/releases) (or a nightly build from [actions](https://github.com/DvvCz/cpkg/actions))

### 📦 Cargo

If you have `cargo` you can install from crates.io.

```
cargo install cpkg
```

Or clone the repository and install it locally.

```
git clone https://github.com/DvvCz/cpkg
cargo install --path cpkg
```

### 🔄 Upgrading

You can easily upgrade your `cpkg` binary using the `cpkg upgrade` command.