# Makefile for DOCX MCP Server
.PHONY: help install dev-install format lint test dev mcp-info serve-http serve-sse test-http example-create clean
PYTHON ?= python3
HTTP_PORT ?= 9004
HTTP_HOST ?= localhost
help: ## Show help
@echo "DOCX MCP Server - Create and edit Microsoft Word documents"
@echo ""
@echo "Quick Start:"
@echo " make install Install FastMCP server"
@echo " make dev Run FastMCP server"
@echo ""
@echo "Available Commands:"
@awk 'BEGIN {FS=":.*?## "} /^[a-zA-Z_-]+:.*?## / {printf " %-20s %s\n", $$1, $$2}' $(MAKEFILE_LIST)
install: ## Install in editable mode
$(PYTHON) -m pip install -e .
dev-install: ## Install with dev extras
$(PYTHON) -m pip install -e ".[dev]"
format: ## Format (black + ruff --fix)
black . && ruff --fix .
lint: ## Lint (ruff, mypy)
ruff check . && mypy src/docx_server
test: ## Run tests
pytest -v --cov=docx_server --cov-report=term-missing
dev: ## Run FastMCP server (stdio)
@echo "Starting DOCX FastMCP server..."
$(PYTHON) -m docx_server.server_fastmcp
mcp-info: ## Show MCP client config
@echo "==================== MCP CLIENT CONFIGURATION ===================="
@echo ""
@echo "FastMCP Server:"
@echo '{"command": "python", "args": ["-m", "docx_server.server_fastmcp"], "cwd": "'$(PWD)'"}'
@echo ""
@echo "=================================================================="
serve-http: ## Run with native FastMCP HTTP
@echo "Starting FastMCP server with native HTTP support..."
@echo "HTTP endpoint: http://$(HTTP_HOST):$(HTTP_PORT)/mcp/"
@echo "API docs: http://$(HTTP_HOST):$(HTTP_PORT)/docs"
$(PYTHON) -m docx_server.server_fastmcp --transport http --host $(HTTP_HOST) --port $(HTTP_PORT)
serve-sse: ## Run with mcpgateway.translate (SSE bridge)
@echo "Starting with translate SSE bridge..."
@echo "SSE endpoint: http://$(HTTP_HOST):$(HTTP_PORT)/sse"
@echo "HTTP endpoint: http://$(HTTP_HOST):$(HTTP_PORT)/"
$(PYTHON) -m mcpgateway.translate --stdio "$(PYTHON) -m docx_server.server_fastmcp" --host $(HTTP_HOST) --port $(HTTP_PORT) --expose-sse
test-http: ## Basic HTTP checks
curl -s http://$(HTTP_HOST):$(HTTP_PORT)/ | head -20 || true
curl -s -X POST -H 'Content-Type: application/json' \
-d '{"jsonrpc":"2.0","id":1,"method":"tools/list","params":{}}' \
http://$(HTTP_HOST):$(HTTP_PORT)/ | head -40 || true
example-create: ## Example: Create document
@echo "Creating example document..."
@$(PYTHON) -c "from docx_server.server_fastmcp import doc_ops; \
result = doc_ops.create_document('/tmp/test_doc.docx', 'Test Document', 'Test Author'); \
import json; print(json.dumps(result, indent=2))"
clean: ## Remove caches
rm -rf .pytest_cache .ruff_cache .mypy_cache __pycache__ */__pycache__ *.egg-info build/ dist/