nineMinecraft is a joke site.
nineMinecraft is in no way affiliated with Modrinth or 9minecraft.

open-hands-lib

Mod

Open Hands Lib is a library for Minecraft. Each hand has its own hit cooldown, and the damage and tool are passed through the hand that your mod chooses; the same can be enabled for breaking blocks

Client and server EquipmentGame MechanicsLibrary

5 downloads
0 followers
Created8 days ago
Updated8 days ago

Open Hands Lib

Per-hand melee cooldowns and mining for NeoForge content mods.

If you are not a mod developer, this is a dependency mod.
Install it only when another mod lists open_hands_lib as a required dependency. On its own it does not add items, blocks, or gameplay.


What is Open Hands Lib?

A NeoForge library that splits attack and mining logic across main hand and off hand. Each hand gets its own cooldown timer; your content mod decides when the system is active and which hand to use.

The library owns timers, mixins, and state. Your mod registers enable conditions and handles events — the library does not pick duelist logic for you.


Features

Combat (when enabled for a player)

  • Independent cooldown per hand
  • Attacks only land at full charge — partial swings are rejected on purpose
  • Hand selection via ResolveAttackHandEvent (alternation, best weapon, etc.)
  • Damage, enchantments, and weapon effects use the resolved hand
  • Optional rules to attack with the main hand while the off hand is using an item

Combat activates when any registered condition is true (OR).

Mining (when enabled)

  • Tool, harvest check, speed, and durability follow the resolved hand
  • Hand selection via ResolveMiningHandEvent
  • Per-block session cache until mining stops

Mining activates when any registered condition is true (OR).


Requirements

NeoForge 21.1.219+
Kotlin for Forge 5.9.0+ (required)
Mod ID open_hands_lib
Author Thow New Error

Installation

  1. Install NeoForge
  2. Install Kotlin for Forge
  3. Install Open Hands Lib and the content mod that depends on it

Do not rename the mod or swap the jar for an unofficial build in public modpacks.


For mod developers

Register when your gameplay should turn on, then listen for hand events:

OpenHandsLib.registerEnableCondition(
    ResourceLocation.fromNamespaceAndPath("your_mod", "dual_wield"),
) { player -> /* your check */ true }

NeoForge.EVENT_BUS.register(object {
    @SubscribeEvent
    fun onResolveAttackHand(event: ResolveAttackHandEvent) {
        event.hand = InteractionHand.MAIN_HAND
    }

    @SubscribeEvent
    fun onAttackHandCompleted(event: AttackHandCompletedEvent) {
        // alternation, etc.
    }
})

Mining: registerMiningEnableCondition + ResolveMiningHandEvent.

Public API

  • mod.openhandslib.api.OpenHandsLib — entry point
  • ResolveAttackHandEvent, AttackHandCompletedEvent, OpenHandsCombatStateClearEvent
  • ResolveMiningHandEvent

Project members

ThrowNewError

Owner


Technical information

License
ARR
Client side
required
Server side
required
Project ID
Expand Down