返回技能列表

apply-semantic-versioning

pjt222
更新于 Yesterday
6 次查看
17
2
17
在 GitHub 上查看
其他general

关于

This skill analyzes code changes to determine the correct semantic version increment (major, minor, or patch) according to SemVer 2.0.0. It helps developers automatically version releases by detecting breaking changes, handling pre-release identifiers, and resolving versioning disagreements. Use it when preparing releases, before tagging commits, or to assess if changes are incompatible.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/apply-semantic-versioning

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档

Apply Semantic Versioning

Determinar y aplicar el incremento de versión semántico correcto analizando los cambios desde el último lanzamiento. Esta habilidad lee archivos de versión, clasifica cambios como incompatibles (mayor), funcionalidad (menor) o corrección (parche), calcula el nuevo número de versión y actualiza los archivos apropiados. Sigue la especificación SemVer 2.0.0.

Cuándo Usar

  • Preparar un nuevo lanzamiento y necesitar determinar el número de versión correcto
  • Después de fusionar un conjunto de cambios y antes de etiquetar un lanzamiento
  • Evaluar si un cambio constituye un cambio incompatible
  • Agregar identificadores de pre-lanzamiento (alpha, beta, rc) a una versión
  • Resolver desacuerdos sobre qué incremento de versión es apropiado

Entradas

  • Requerido: Directorio raíz del proyecto que contiene un archivo de versión (DESCRIPTION, package.json, Cargo.toml, pyproject.toml o VERSION)
  • Requerido: Historial de Git desde el último lanzamiento (etiqueta o commit)
  • Opcional: Convención de commits en uso (Conventional Commits, forma libre)
  • Opcional: Etiqueta de pre-lanzamiento a aplicar (alpha, beta, rc)
  • Opcional: Versión anterior si no es legible desde los archivos

Procedimiento

Paso 1: Leer la Versión Actual

Localizar y leer el archivo de versión en la raíz del proyecto.

# R packages
grep "^Version:" DESCRIPTION

# Node.js
grep '"version"' package.json

# Rust
grep '^version' Cargo.toml

# Python
grep 'version' pyproject.toml

# Plain file
cat VERSION

Analizar la versión actual en componentes mayor.menor.parche. Si la versión contiene un sufijo de pre-lanzamiento (ej., 1.2.0-beta.1), anotarlo por separado.

Esperado: Versión actual identificada como MAYOR.MENOR.PARCHE[-PRELANZAMIENTO].

En caso de fallo: Si no se encuentra un archivo de versión, buscar un archivo VERSION o etiquetas de git (git describe --tags --abbrev=0). Si no existe ninguna versión, comenzar en 0.1.0 para desarrollo inicial o 1.0.0 si el proyecto tiene una API pública estable.

Paso 2: Analizar los Cambios Desde el Último Lanzamiento

Obtener la lista de cambios desde el último lanzamiento etiquetado.

# Find the last version tag
git describe --tags --abbrev=0

# List commits since that tag
git log --oneline v1.2.3..HEAD

# If using Conventional Commits, filter by type
git log --oneline v1.2.3..HEAD | grep -E "^[a-f0-9]+ (feat|fix|BREAKING)"

Si no existen etiquetas, comparar contra el commit inicial o una línea base conocida.

Esperado: Una lista de commits con mensajes que pueden clasificarse por tipo de cambio.

En caso de fallo: Si el historial de git no está disponible o faltan etiquetas, pedir al desarrollador que describa los cambios manualmente. Clasificar basándose en su descripción.

Paso 3: Clasificar los Cambios

Aplicar las reglas de clasificación SemVer:

Tipo de CambioIncremento de VersiónEjemplos
Incompatible (cambio de API incompatible)MAYORFunción pública renombrada/eliminada, tipo de retorno cambiado, parámetro eliminado, comportamiento predeterminado cambiado
Funcionalidad (nueva funcionalidad retrocompatible)MENORNueva función exportada, nuevo parámetro con valor predeterminado, soporte de nuevo formato de archivo
Corrección (corrección de error retrocompatible)PARCHECorrección de error, corrección de documentación, mejora de rendimiento con la misma API

Reglas de clasificación:

  1. Si CUALQUIER cambio es incompatible, el incremento es MAYOR (reinicia menor y parche a 0)
  2. Si no hay cambios incompatibles pero HAY nuevas funcionalidades, el incremento es MENOR (reinicia parche a 0)
  3. Si solo hay correcciones, el incremento es PARCHE

Casos especiales:

  • Pre-1.0.0: Durante el desarrollo inicial (0.x.y), los incrementos menores pueden contener cambios incompatibles. Documentar claramente.
  • Deprecación: Deprecar una función es un cambio MENOR (aún funciona). Eliminarla es MAYOR.
  • Cambios internos: Refactorización que no cambia la API pública es PARCHE.

Esperado: Cada cambio clasificado como incompatible/funcionalidad/corrección, y el nivel de incremento general determinado.

En caso de fallo: Si los cambios son ambiguos, errar hacia un incremento mayor. Un incremento mayor conservador es mejor que un incremento menor que rompe código dependiente.

Paso 4: Calcular la Nueva Versión

Aplicar el incremento a la versión actual:

ActualIncrementoNueva Versión
1.2.3MAYOR2.0.0
1.2.3MENOR1.3.0
1.2.3PARCHE1.2.4
0.9.5MENOR0.10.0
2.0.0-rc.1(lanzamiento)2.0.0

Si se solicita una etiqueta de pre-lanzamiento:

  • 1.3.0-alpha.1 para la primera alpha del próximo 1.3.0
  • 1.3.0-beta.1 para la primera beta
  • 1.3.0-rc.1 para el primer candidato a lanzamiento

Precedencia de pre-lanzamiento: alpha < beta < rc < (lanzamiento).

Esperado: Nuevo número de versión calculado siguiendo las reglas de SemVer.

En caso de fallo: Si la versión actual tiene formato incorrecto o no es SemVer, normalizarla primero. Por ejemplo, 1.2 se convierte en 1.2.0.

Paso 5: Actualizar los Archivos de Versión

Escribir la nueva versión en el o los archivos apropiados.

# R: Update DESCRIPTION
# Change "Version: 1.2.3" to "Version: 1.3.0"
// Node.js: Update package.json
// Change "version": "1.2.3" to "version": "1.3.0"
// Also update package-lock.json if present
# Rust: Update Cargo.toml
# Change version = "1.2.3" to version = "1.3.0"

Si el proyecto tiene múltiples archivos que referencian la versión (ej., _pkgdown.yml, CITATION, codemeta.json), actualizar todos.

Esperado: Todos los archivos de versión actualizados consistentemente al nuevo número de versión.

En caso de fallo: Si la actualización de un archivo falla, revertir todos los cambios para mantener la consistencia. Nunca dejar archivos de versión en un estado parcialmente actualizado.

Paso 6: Crear la Etiqueta de Versión

Después de hacer commit del incremento de versión, crear una etiqueta de git.

# Annotated tag (preferred)
git tag -a v1.3.0 -m "Release v1.3.0"

# Lightweight tag (acceptable)
git tag v1.3.0

Usar el formato de etiqueta establecido del proyecto:

Esperado: Etiqueta de Git creada coincidiendo con la nueva versión.

En caso de fallo: Si la etiqueta ya existe, la versión no se incrementó correctamente. Verificar etiquetas duplicadas con git tag -l "v1.3*" y resolver antes de continuar.

Validación

  • La versión actual se leyó del archivo de versión correcto
  • Todos los commits desde el último lanzamiento fueron analizados
  • Cada cambio se clasifica como incompatible, funcionalidad o corrección
  • El nivel de incremento coincide con el cambio de mayor severidad (incompatible > funcionalidad > corrección)
  • La nueva versión sigue el formato SemVer 2.0.0: MAYOR.MENOR.PARCHE[-PRELANZAMIENTO][+COMPILACIÓN]
  • Todos los archivos de versión en el proyecto están actualizados consistentemente
  • No se saltó ninguna versión (ej., 1.2.3 a 1.4.0 sin que 1.3.0 fuera lanzada)
  • La etiqueta de Git coincide con la nueva versión y la convención de formato de etiqueta del proyecto
  • El sufijo de pre-lanzamiento, si se usa, sigue la precedencia correcta (alpha < beta < rc)

Errores Comunes

  • Saltar versiones menores: Ir de 1.2.3 directamente a 1.4.0 porque "agregamos dos funcionalidades." Cada lanzamiento obtiene un incremento; el número de funcionalidades no determina la versión.
  • Tratar la deprecación como incompatible: Deprecar una función (agregar una advertencia) es un cambio menor. Solo eliminarla es un cambio incompatible.
  • Olvidar las reglas pre-1.0.0: Antes de 1.0.0, la API se considera inestable. Algunos proyectos incrementan menor para cambios incompatibles durante esta fase, pero debería documentarse.
  • Archivos de versión inconsistentes: Actualizar package.json pero no package-lock.json, o actualizar DESCRIPTION pero no CITATION. Todas las referencias de versión deben mantenerse sincronizadas.
  • Confusión de metadatos de compilación: Los metadatos de compilación (+build.123) no afectan la precedencia de versión. 1.0.0+build.1 y 1.0.0+build.2 tienen la misma precedencia.
  • No etiquetar lanzamientos: Sin etiquetas de git, los futuros incrementos de versión no pueden determinar la línea base para el análisis de cambios.

Habilidades Relacionadas

  • manage-changelog -- Mantener entradas de registro de cambios que se emparejan con incrementos de versión
  • plan-release-cycle -- Planificar hitos de lanzamiento que determinan cuándo ocurren los incrementos de versión
  • release-package-version -- Flujo de trabajo de lanzamiento específico de R que incluye incremento de versión
  • commit-changes -- Hacer commit del incremento de versión con un mensaje apropiado
  • create-github-release -- Crear un lanzamiento de GitHub desde la etiqueta de versión

GitHub 仓库

pjt222/agent-almanac
路径: i18n/es/skills/apply-semantic-versioning
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

llamaguard

其他

LlamaGuard是Meta推出的7-8B参数内容审核模型,专门用于过滤LLM的输入和输出内容。它能检测六大安全风险类别(暴力/仇恨、性内容、武器、违禁品、自残、犯罪计划),准确率达94-95%。开发者可通过HuggingFace、vLLM或Sagemaker快速部署,并能与NeMo Guardrails集成实现自动化安全防护。

查看技能

cost-optimization

其他

这个Claude Skill帮助开发者优化云成本,通过资源调整、标记策略和预留实例来降低AWS、Azure和GCP的开支。它适用于减少云支出、分析基础设施成本或实施成本治理策略的场景。关键功能包括提供成本可视化、资源规模调整指导和定价模型优化建议。

查看技能

quantizing-models-bitsandbytes

其他

这个Skill使用bitsandbytes库量化大语言模型,能在GPU内存有限时通过8位或4位量化减少50-75%内存占用,同时保持精度损失最小。它支持INT8、NF4、FP4等多种量化格式,可与HuggingFace Transformers无缝集成,适用于需要部署更大模型或加速推理的场景。还提供QLoRA训练和8位优化器支持,让开发者能轻松实现高效模型压缩。

查看技能

dispatching-parallel-agents

其他

该Skill用于并行处理3个以上无依赖关系的独立故障,可为每个问题域分派专属Claude代理同时执行调查修复。它通过并发处理多个独立问题显著提升故障排查效率,特别适用于测试文件、子系统等无共享状态的场景。

查看技能