Skip to content

Commit

Permalink
feat!: 1.0.0 release
Browse files Browse the repository at this point in the history
  • Loading branch information
VoodooHillbilly committed Apr 14, 2024
1 parent d0c468e commit c21bf73
Show file tree
Hide file tree
Showing 30 changed files with 586 additions and 99 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -174,7 +174,7 @@ jobs:
mkdir $TARGETDIR
for file in *;do test "$file" != "$TARGETDIR" && cp -r "$file" "$TARGETDIR/";done
rm -rf "$TARGETDIR/node_modules"
rm "$TARGETDIR/package.json" "$TARGETDIR/package-lock.json" "$TARGETDIR/README.md"
rm "$TARGETDIR/package.json" "$TARGETDIR/package-lock.json" "$TARGETDIR/project.json" "$TARGETDIR/README.md"
- name: Create ZIP
if: ${{ steps.newVersion.outputs.new-release-version }}
Expand Down
103 changes: 12 additions & 91 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,102 +1,23 @@
# Simple Mod Framework mod template
# No KO Grenades

The preferred template for Simple Mod Framework mods.
A Hitman: World of Assassination mod that customizes grenade lock-on.

## Why should I use this?
## Features

### Better changelog handling
Modify thrown grenades, impact explosives, and a couple of mines to either knock down NPCs or disable lock-on entirely.

Changelogs in mod updates are often not particularly helpful to users. Let's look at an example: Notex's [Portable Chair mod](https://www.nexusmods.com/hitman3/mods/453). Initially, the mod was released (like all mods) at version `1.0.0`. It was then given an update to `1.1.0` with the following changes:
Has a toggle to disable dropping the impact explosive balls, Molotov, Nitroglycerin, and Octane Booster. Helpful for clumsy fingers.

![Portable Chair 1.1.0 changelog](https://hitman-resources.netlify.app/assets/portablechair-1.1.0.png)
Has a toggle to enable online use.

It was then given another update, to `1.2.0`, with the following changes:
- If you enable this and use the Peacock server, you need to also install [Peacock Strings](https://github.com/thepeacockproject/peacock-strings "Peacock Strings") for Peacock’s text to display properly.

![Portable Chair 1.2.0 changelog](https://hitman-resources.netlify.app/assets/portablechair-1.2.0.png)
## Recommendations

If Portable Chair didn't use the `smf-mod` template, a user on `1.0.0` would only see that last changelog, and would be completely unaware of the changes from `1.1.0` (which are "skipped over"). Because it uses the template, the Simple Mod Framework is able to use the GitHub releases published automatically to find the older changelog and merge it with the newer one. Because of that, users of the mod are able to see all the changes which lead up to the version they're updating to, not just the ones from the last version.
Also installing [Throwable Lock-On - Instinct Adjustments](https://www.nexusmods.com/hitman3/mods/738 "Throwable Lock-On - Instinct Adjustments") allows you to quickly disable lock-on by holding Instinct, for when you don’t want to hit someone in the head at all.

### Other features
## Installation

- Automatic versioning
- Versions of the mod are automatically zipped, releases are automatically made and the mod update JSON are automatically updated
- Conventional commits mean that you don't have to do anything; any change you make to your mod can automatically be converted into a release with the versions all handled for you
- This also means that your versions are fully compatible with Semantic Versioning, which improves the framework's ability to know how your mod has changed
- Your mod's manifest will be edited for you; you don't have to set anything up yourself
- Automatic formatting
- Prettier is run before each commit, and a pre-made configuration for it is included
- LGPLv3 license
- Mods created with this template are permissively licensed; anyone can alter your mod, but they have to give credit and provide a list of what they have changed
- Automatic updating of `frameworkVersion`
- Most mod developers don't bother updating this property; the template automatically brings it in line with the version your mod is actually being tested against
- Automatic README generation
- The template will update the README for the repository automatically with each new release
- If you want to write your own, just modify it yourself and the template won't touch it
You need Hitman: World of Assassination and Simple Mod Framework.

### The benefits of Git/GitHub

If you're new to Git and GitHub, you might also want to know why they're recommended. To answer that, think to yourself whether you've ever accidentally modified a file irreversibly and not been able to get back the old version; alternatively, think to yourself whether you've ever wanted to keep certain sets of changes for later while working on something else, or whether you've ever wanted to have a history of your changes to see how you did something a while ago. Git does all of that.

GitHub is a place for hosting Git repositories, which lets you more easily see branches, track issues and collaborate with other people.

## How do I use this?

### Requirements

You'll need Git, obviously, and preferably also a GUI client if you aren't experienced with Git's command line interface. GitHub Desktop is recommended, but VS Code includes its own as well (though it can be unintuitive at times and functions more as a list of Git commands than as an easy-to-use interface).

You'll also want Node.js for formatting and using other tools (QuickEntity Editor, for example, requires it for game-file extensions). You can download the latest release from [here](https://nodejs.org/en) - either LTS or Current is fine.

### Cloning the template

To get started, click the green "Use this template" button on GitHub and create a new repository. Give it whatever name you like and make it public or private (if you want to make it private, then make sure to change it back to public when the mod is released, else there's no point in this template). You can then clone the repository directly into your Mods folder (so the repository gets its own folder under Mods where you can work).

Once you've done that, go to the new folder in your Mods folder and run the commands `npm install` and `npm run prepare` to set up automatic formatting.

### Making a new mod

First, edit `manifest.json` to use the correct mod ID and create a commit along the lines of `feat: initial mod`. From then, you can work on your mod and make whatever commits you like (per the following section).

An important note: the version for the mod starts at `0.1.0`, which means the mod is in development - you can make as many changes as you like at `0.x.x`. When you finalise the mod for its first release, add an exclamation mark before the `:` (like `feat!: final feature`) and the version will automatically be bumped to `1.0.0`.

Don't worry about updating your manifest's version or `updateCheck` property; the template will configure all that for you. A tip for mod releases - whenever you want to push an update to Nexus, you can just download the `mod.framework.zip` file on the GitHub release generated by the template and upload it to Nexus, which saves having to do it yourself.

### Transferring an existing mod

If you're looking to integrate this into an existing mod you have, copy everything from that mod over to this template, create a commit named something like `chore: transfer existing mod` and then tag that commit with the currently released version of the mod (the initial commit will still automatically be tagged 0.1.0, which is fine). For example, a mod which is currently at 1.1.0 would be copied over, a commit containing the current mod version would be created under whatever name, and that commit would be tagged `1.1.0`.

Don't worry about updating your manifest's version or `updateCheck` property; the template will configure all that for you.

### How to make commits

This template will do everything for you, including versioning, generating changelogs and creating mod ZIPs; just make sure you follow [conventional commits](https://www.conventionalcommits.org/en/v1.0.0).

As a rule of thumb, anything that doesn't drastically alter the mod or make sweeping changes that could break other mods should be either an `enhancement` (for improvements to existing parts of the mod), `feat` (for new parts of the mod) or `fix` (for bugfixes). You can specify the part of the mod you're changing in parentheses like so: `fix(localisation): typo in French text`.

If you do drastically alter the mod or make sweeping changes that could break other mods, add an exclamation mark just before the `:`, and write `BREAKING CHANGE: This thing is now this thing, which means this.` in the "description" or "footer" of the commit.

### How to not make a release for every change

If you want to have multiple new features in a release, just make conventional commits in a new branch and then merge them into the main branch once you want to release. When the branch is merged, the template will detect all the new commits and adjust the changelog/version appropriately.

### How to not use conventional commits for making lots of small changes

If you're making a lot of trivial changes that you'd ordinarily call names like `whatever` or `fix that thing from before`, you should be working in a feature branch. In a branch you can make as many commits as you like to work on a specific feature under whatever name, and then use the GitHub "squash and merge" feature to combine them all into one `feat: name of new feature` commit.

To combine this advice with the last, you can work like this:

- create a `next-release` branch
- create a `new-feature-1` branch
- make whatever commits you like on `new-feature-1`: "do half the work", "whoops, fix that"
- squash and merge `new-feature-1` onto `next-release` under the commit `feat: new feature 1`
- create an `improvement-whatever` branch
- make whatever commits you like on `improvement-whatever`: "improve that part", "finish it off"
- squash and merge `improvement-whatever` onto `next-release` under the commit `enhancement: some improvement`
- standard merge `next-release` onto `main`

The result of this would be a changelog like this:

- New Features
- new feature 1
- Improvements
- some improvement
[Install the mod directly with SMF](https://hitman-resources.netlify.app/smf-install-link/https://github.com/VoodooHillbilly/h3-no-ko-grenades/releases/latest/download/mod.framework.zip) or [Download the mod to install manually](https://github.com/VoodooHillbilly/h3-no-ko-grenades/releases/latest/download/mod.framework.zip)
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"2ecc0dde-5d5f-4961-af76-e7c63d7d3405": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"59e407df-c49b-4abe-a1be-0806b026e47e": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"2ecc0dde-5d5f-4961-af76-e7c63d7d3405": {
"ThrowType": "THROW_NORMAL"
},
"59e407df-c49b-4abe-a1be-0806b026e47e": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"b988422a-02a6-499e-b796-302a782be3d1": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"b988422a-02a6-499e-b796-302a782be3d1": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"042fae7b-fe9e-4a83-ac7b-5c914a71b2ca": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"6b55c267-c83d-494e-85df-5b4c81439bf6": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"a02af9a5-aefb-47e0-9d67-51cc9ec89774": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"d7890635-7e81-4a72-822e-65990b666d81": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"042fae7b-fe9e-4a83-ac7b-5c914a71b2ca": {
"ThrowType": "THROW_NORMAL"
},
"6b55c267-c83d-494e-85df-5b4c81439bf6": {
"ThrowType": "THROW_NORMAL"
},
"a02af9a5-aefb-47e0-9d67-51cc9ec89774": {
"ThrowType": "THROW_NORMAL"
},
"d7890635-7e81-4a72-822e-65990b666d81": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"3f9cf03f-b84f-4419-b831-4704cff9775c": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"b1ad87c7-5bec-4ce6-a584-96058e11fae0": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"ba5cd3a3-9b90-4088-9b5b-25ca5f3b21b5": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
{
"3f9cf03f-b84f-4419-b831-4704cff9775c": {
"ThrowType": "THROW_NORMAL"
},
"b1ad87c7-5bec-4ce6-a584-96058e11fae0": {
"ThrowType": "THROW_NORMAL"
},
"ba5cd3a3-9b90-4088-9b5b-25ca5f3b21b5": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"af82349c-259f-4bdd-8be7-d5ff61695c29": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"af82349c-259f-4bdd-8be7-d5ff61695c29": {
"ThrowType": "THROW_PACIFY_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"594b10df-5345-4012-beae-fc2790f00c9a": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"a49fe9f6-aa5a-4000-8aec-2902ab57b4b7": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"594b10df-5345-4012-beae-fc2790f00c9a": {
"ThrowType": "THROW_NORMAL"
},
"a49fe9f6-aa5a-4000-8aec-2902ab57b4b7": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"2a493cf9-7cb1-4aad-b892-17abf8b329f4": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"8b7c3ec6-c072-4a21-a323-0f8751028052": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"b75010e8-ed6e-4646-ba22-73a30a7a990d": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"c95c55aa-34e5-42bd-bf27-32be3978b269": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"2a493cf9-7cb1-4aad-b892-17abf8b329f4": {
"ThrowType": "THROW_NORMAL"
},
"8b7c3ec6-c072-4a21-a323-0f8751028052": {
"ThrowType": "THROW_NORMAL"
},
"b75010e8-ed6e-4646-ba22-73a30a7a990d": {
"ThrowType": "THROW_NORMAL"
},
"c95c55aa-34e5-42bd-bf27-32be3978b269": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"f04bd2e9-3f3a-42cd-9150-b7845e952d67": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"f04bd2e9-3f3a-42cd-9150-b7845e952d67": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"a83349bf-3d9c-43ec-92ee-c8c98cbeabc1": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"a83349bf-3d9c-43ec-92ee-c8c98cbeabc1": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"af8a7b6c-692c-4a76-b9bc-2b91ce32bcbc": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
},
"c82fefa7-febe-46c8-90ec-c945fbef0cb4": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"af8a7b6c-692c-4a76-b9bc-2b91ce32bcbc": {
"ThrowType": "THROW_NORMAL"
},
"c82fefa7-febe-46c8-90ec-c945fbef0cb4": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"b6108af4-702f-4954-ae7f-1204460833c7": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"b6108af4-702f-4954-ae7f-1204460833c7": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"2a493cf9-7cb1-4aad-b892-17abf8b329f4": {
"CanBeDropped": false
},
"8b7c3ec6-c072-4a21-a323-0f8751028052": {
"CanBeDropped": false
},
"a83349bf-3d9c-43ec-92ee-c8c98cbeabc1": {
"CanBeDropped": false
},
"af8a7b6c-692c-4a76-b9bc-2b91ce32bcbc": {
"CanBeDropped": false
},
"b75010e8-ed6e-4646-ba22-73a30a7a990d": {
"CanBeDropped": false
},
"c82fefa7-febe-46c8-90ec-c945fbef0cb4": {
"CanBeDropped": false
},
"c95c55aa-34e5-42bd-bf27-32be3978b269": {
"CanBeDropped": false
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"637a7b20-39b1-48c6-9908-8fb628488262": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"637a7b20-39b1-48c6-9908-8fb628488262": {
"ThrowType": "THROW_NORMAL"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"09c37e1a-c2b3-4dba-9e26-50fac96d3f65": {
"ThrowType": "THROW_KNOCKDOWN_LIGHT"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"09c37e1a-c2b3-4dba-9e26-50fac96d3f65": {
"ThrowType": "THROW_NORMAL"
}
}
Loading

0 comments on commit c21bf73

Please sign in to comment.