1
0
mirror of https://github.com/tw93/Mole.git synced 2026-02-04 19:09:43 +00:00

feat: Add git hooks to enforce universal binary builds and improve CPU metric calculation.

This commit is contained in:
Tw93
2025-12-22 16:30:22 +08:00
parent d2dc68da90
commit 87fdd26272
8 changed files with 127 additions and 9 deletions

2
.gitignore vendored
View File

@@ -52,4 +52,4 @@ cmd/analyze/analyze
cmd/status/status
/status
mole-analyze
# Note: bin/analyze-go and bin/status-go are released binaries and should be tracked
# Note: bin/analyze-go and bin/status-go are tracked as release binaries

View File

@@ -5,6 +5,9 @@
```bash
# Install development tools
brew install shfmt shellcheck bats-core
# Install git hooks (validates universal binaries)
./scripts/setup-hooks.sh
```
## Development
@@ -154,7 +157,24 @@ Format: `[MODULE_NAME] message` output to stderr.
- Format code with `gofmt -w ./cmd/...`
- Run `go vet ./cmd/...` to check for issues
- Build with `go build ./...` to verify all packages compile
- Build universal binaries via `./scripts/build-status.sh` and `./scripts/build-analyze.sh`
**Building Universal Binaries:**
⚠️ **IMPORTANT**: Never use `go build` directly to create `bin/analyze-go` or `bin/status-go`!
Mole must support both Intel and Apple Silicon Macs. Always use the build scripts:
```bash
# Build universal binaries (x86_64 + arm64)
./scripts/build-analyze.sh
./scripts/build-status.sh
```
For local development/testing, you can use:
- `go run ./cmd/status` or `go run ./cmd/analyze` (quick iteration)
- `go build ./cmd/status` (creates single-arch binary for testing)
The pre-commit hook will prevent you from accidentally committing non-universal binaries.
**Guidelines:**

Binary file not shown.

View File

@@ -31,7 +31,13 @@ func collectCPU() (CPUStatus, error) {
logical = 1
}
percents, err := cpu.Percent(cpuSampleInterval, true)
// Use two-call pattern for more reliable CPU measurements
// First call: initialize/store current CPU times
cpu.Percent(0, true)
// Wait for sampling interval
time.Sleep(cpuSampleInterval)
// Second call: get actual percentages based on difference
percents, err := cpu.Percent(0, true)
var totalPercent float64
perCoreEstimated := false
if err != nil || len(percents) == 0 {
@@ -247,10 +253,10 @@ func fallbackCPUUtilization(logical int) (float64, []float64, error) {
total = maxTotal
}
perCore := make([]float64, logical)
avg := total / float64(logical)
perCore := make([]float64, logical)
for i := range perCore {
perCore[i] = avg
}
return total, perCore, nil
return avg, perCore, nil
}

View File

@@ -4,8 +4,6 @@
set -euo pipefail
export CGO_ENABLED=0
cd "$(dirname "$0")/.."
# Check if Go is installed

View File

@@ -4,8 +4,6 @@
set -euo pipefail
export CGO_ENABLED=0
cd "$(dirname "$0")/.."
if ! command -v go > /dev/null 2>&1; then

68
scripts/hooks/pre-commit Executable file
View File

@@ -0,0 +1,68 @@
#!/bin/bash
# Pre-commit hook to ensure bin/analyze-go and bin/status-go are universal binaries
set -e
# ANSI color codes
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
NC='\033[0m' # No Color
# Check if binaries are being committed
binaries=()
if git diff --cached --name-only | grep -q "^bin/analyze-go$"; then
binaries+=("bin/analyze-go")
fi
if git diff --cached --name-only | grep -q "^bin/status-go$"; then
binaries+=("bin/status-go")
fi
# If no binaries are being committed, exit early
if [[ ${#binaries[@]} -eq 0 ]]; then
exit 0
fi
echo -e "${YELLOW}Checking compiled binaries...${NC}"
# Verify each binary is a universal binary
all_valid=true
for binary in "${binaries[@]}"; do
if [[ ! -f "$binary" ]]; then
echo -e "${RED}✗ $binary not found${NC}"
all_valid=false
continue
fi
# Check if it's a universal binary
if file "$binary" | grep -q "Mach-O universal binary"; then
# Verify it contains both x86_64 and arm64
if lipo -info "$binary" 2>/dev/null | grep -q "x86_64 arm64"; then
echo -e "${GREEN}✓ $binary is a universal binary (x86_64 + arm64)${NC}"
elif lipo -info "$binary" 2>/dev/null | grep -q "arm64 x86_64"; then
echo -e "${GREEN}✓ $binary is a universal binary (x86_64 + arm64)${NC}"
else
echo -e "${RED}✗ $binary is missing required architectures${NC}"
lipo -info "$binary"
all_valid=false
fi
else
echo -e "${RED}✗ $binary is not a universal binary${NC}"
file "$binary"
all_valid=false
fi
done
if [[ "$all_valid" == "false" ]]; then
echo ""
echo -e "${RED}Commit rejected: binaries must be universal (x86_64 + arm64)${NC}"
echo ""
echo "To create universal binaries, run:"
echo " ./scripts/build-analyze.sh"
echo " ./scripts/build-status.sh"
echo ""
exit 1
fi
echo -e "${GREEN}All binaries verified!${NC}"
exit 0

28
scripts/setup-hooks.sh Executable file
View File

@@ -0,0 +1,28 @@
#!/bin/bash
# Install git hooks for Mole development
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
REPO_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
HOOKS_DIR="$REPO_ROOT/.git/hooks"
if [[ ! -d "$REPO_ROOT/.git" ]]; then
echo "Error: Not in a git repository"
exit 1
fi
echo "Installing git hooks..."
# Install pre-commit hook
if [[ -f "$SCRIPT_DIR/hooks/pre-commit" ]]; then
cp "$SCRIPT_DIR/hooks/pre-commit" "$HOOKS_DIR/pre-commit"
chmod +x "$HOOKS_DIR/pre-commit"
echo "✓ Installed pre-commit hook (validates universal binaries)"
fi
echo ""
echo "Git hooks installed successfully!"
echo ""
echo "The pre-commit hook will ensure that bin/analyze-go and bin/status-go"
echo "are universal binaries (x86_64 + arm64) before allowing commits."