git-flow-branch-creator
Intelligent Git Flow branch creator that analyzes git status/diff and creates appropriate branches following the nvie Git Flow branching model.
What this skill does
### Instructions ```xml <instructions> <title>Git Flow Branch Creator</title> <description>This prompt analyzes your current git changes using git status and git diff (or git diff --cached), then intelligently determines the appropriate branch type according to the Git Flow branching model and creates a semantic branch name.</description> <note> Just run this prompt and Copilot will analyze your changes and create the appropriate Git Flow branch for you. </note> </instructions> ``` ### Workflow **Follow these steps:** 1. Run `git status` to review the current repository state and changed files. 2. Run `git diff` (for unstaged changes) or `git diff --cached` (for staged changes) to analyze the nature of changes. 3. Analyze the changes using the Git Flow Branch Analysis Framework below. 4. Determine the appropriate branch type based on the analysis. 5. Generate a semantic branch name following Git Flow conventions. 6. Create the branch and switch to it automatically. 7. Provide a summary of the analysis and next steps. ### Git Flow Branch Analysis Framework ```xml <analysis-framework> <branch-types> <feature> <purpose>New features, enhancements, non-critical improvements</purpose> <branch-from>develop</branch-from> <merge-to>develop</merge-to> <naming>feature/descriptive-name or feature/ticket-number-description</naming> <indicators> <indicator>New functionality being added</indicator> <indicator>UI/UX improvements</indicator> <indicator>New API endpoints or methods</indicator> <indicator>Database schema additions (non-breaking)</indicator> <indicator>New configuration options</indicator> <indicator>Performance improvements (non-critical)</indicator> </indicators> </feature> <release> <purpose>Release preparation, version bumps, final testing</purpose> <branch-from>develop</branch-from> <merge-to>develop AND master</merge-to> <naming>release-X.Y.Z</naming> <indicators> <indicator>Version number changes</indicator> <indicator>Build configuration updates</indicator> <indicator>Documentation finalization</indicator> <indicator>Minor bug fixes before release</indicator> <indicator>Release notes updates</indicator> <indicator>Dependency version locks</indicator> </indicators> </release> <hotfix> <purpose>Critical production bug fixes requiring immediate deployment</purpose> <branch-from>master</branch-from> <merge-to>develop AND master</merge-to> <naming>hotfix-X.Y.Z or hotfix/critical-issue-description</naming> <indicators> <indicator>Security vulnerability fixes</indicator> <indicator>Critical production bugs</indicator> <indicator>Data corruption fixes</indicator> <indicator>Service outage resolution</indicator> <indicator>Emergency configuration changes</indicator> </indicators> </hotfix> </branch-types> </analysis-framework> ``` ### Branch Naming Conventions ```xml <naming-conventions> <feature-branches> <format>feature/[ticket-number-]descriptive-name</format> <examples> <example>feature/user-authentication</example> <example>feature/PROJ-123-shopping-cart</example> <example>feature/api-rate-limiting</example> <example>feature/dashboard-redesign</example> </examples> </feature-branches> <release-branches> <format>release-X.Y.Z</format> <examples> <example>release-1.2.0</example> <example>release-2.1.0</example> <example>release-1.0.0</example> </examples> </release-branches> <hotfix-branches> <format>hotfix-X.Y.Z OR hotfix/critical-description</format> <examples> <example>hotfix-1.2.1</example> <example>hotfix/security-patch</example> <example>hotfix/payment-gateway-fix</example> <example>hotfix-2.1.1</example> </examples> </hotfix-branches> </naming-conventions> ``` ### Analysis Process ```xml <analysis-process> <step-1> <title>Change Nature Analysis</title> <description>Examine the types of files modified and the nature of changes</description> <criteria> <files-modified>Look at file extensions, directory structure, and purpose</files-modified> <change-scope>Determine if changes are additive, corrective, or preparatory</change-scope> <urgency-level>Assess if changes address critical issues or are developmental</urgency-level> </criteria> </step-1> <step-2> <title>Git Flow Classification</title> <description>Map the changes to appropriate Git Flow branch type</description> <decision-tree> <question>Are these critical fixes for production issues?</question> <if-yes>Consider hotfix branch</if-yes> <if-no> <question>Are these release preparation changes (version bumps, final tweaks)?</question> <if-yes>Consider release branch</if-yes> <if-no>Default to feature branch</if-no> </if-no> </decision-tree> </step-2> <step-3> <title>Branch Name Generation</title> <description>Create semantic, descriptive branch name</description> <guidelines> <use-kebab-case>Use lowercase with hyphens</use-kebab-case> <be-descriptive>Name should clearly indicate the purpose</be-descriptive> <include-context>Add ticket numbers or project context when available</include-context> <keep-concise>Avoid overly long names</keep-concise> </guidelines> </step-3> </analysis-process> ``` ### Edge Cases and Validation ```xml <edge-cases> <mixed-changes> <scenario>Changes include both features and bug fixes</scenario> <resolution>Prioritize the most significant change type or suggest splitting into multiple branches</resolution> </mixed-changes> <no-changes> <scenario>No changes detected in git status/diff</scenario> <resolution>Inform user and suggest checking git status or making changes first</resolution> </no-changes> <existing-branch> <scenario>Already on a feature/hotfix/release branch</scenario> <resolution>Analyze if new branch is needed or if current branch is appropriate</resolution> </existing-branch> <conflicting-names> <scenario>Suggested branch name already exists</scenario> <resolution>Append incremental suffix or suggest alternative name</resolution> </conflicting-names> </edge-cases> ``` ### Examples ```xml <examples> <example-1> <scenario>Added new user registration API endpoint</scenario> <analysis>New functionality, additive changes, not critical</analysis> <branch-type>feature</branch-type> <branch-name>feature/user-registration-api</branch-name> <command>git checkout -b feature/user-registration-api develop</command> </example-1> <example-2> <scenario>Fixed critical security vulnerability in authentication</scenario> <analysis>Security fix, critical for production, immediate deployment needed</analysis> <branch-type>hotfix</branch-type> <branch-name>hotfix/auth-security-patch</branch-name> <command>git checkout -b hotfix/auth-security-patch master</command> </example-2> <example-3> <scenario>Updated version to 2.1.0 and finalized release notes</scenario> <analysis>Release preparation, version bump, documentation</analysis> <branch-type>release</branch-type> <branch-name>release-2.1.0</branch-name> <command>git checkout -b release-2.1.0 develop</command> </example-3> <example-4> <scenario>Improved database query performance and updated caching</scenario> <analysis>Performance improvement, non-critical enhancement</analysis> <branch-type>feature</branch-type> <branch-name>feature/database-performance-optimization</branch-name> <command>git checkout -b feature/database-performance-optimization develop</command> </example-4> </examples> ``` ### Validation Checklist ```xml <validation> <pre-analysis> <check>Repository is in a clean state (no uncommitted changes that would conflict)</check> <check>Current branch is appropriate starting point (develop for features/releases, master for hotfixes)</check> <check>Remote repository is up to date</check> </pre-analysis> <analysis-quality> <check>Chan
Related in General
modeling-omnistudio-epc-catalog
IncludedSalesforce Industries CME EPC product-modeling skill for Product2-based catalog creation. Use when creating EPC products, configuring product attributes, building offer bundles with Product Child Items, or reviewing EPC DataPack JSON metadata for product catalog changes. TRIGGER when: user creates or updates Product2 EPC records, AttributeAssignment payloads, AttributeMetadata/AttributeDefaultValues, Offer bundles, or ProductChildItem relationships. DO NOT TRIGGER when: designing OmniScripts/FlexCards/Integration Procedures (use building-omnistudio-omniscript, building-omnistudio-flexcard, or building-omnistudio-integration-procedure), implementing Apex business logic (use generating-apex), or troubleshooting deployment pipelines (use deploying-metadata).
relationship-science-coach
IncludedUse this skill for direct, practical adult relationship coaching: couples conflict, repair, trust, marriage, dating, flirting, attachment patterns, emotional connection, sex, desire differences, eroticism, kink negotiation, affection, love languages, breakups, and long-term passion. Draw on Gottman, EFT and Hold Me Tight, attachment science, modern sex research, Perel, Nagoski, Kerner, Schnarch, Love and Stosny, and flexible love-language tools. Be concrete and low-hedge. Redirect only for imminent danger, abuse, coercive control, minors, non-consent, self-harm, stalking, or medical/legal/psychiatric decisions.
building-sf-integrations
IncludedSalesforce integration architecture and runtime plumbing with 120-point scoring. Use this skill to set up Named Credentials, External Credentials, External Services, REST/SOAP callout patterns, Platform Events, and Change Data Capture. TRIGGER when: user sets up Named Credentials, External Services, REST/SOAP callouts, Platform Events, CDC, or touches .namedCredential-meta.xml files. DO NOT TRIGGER when: Connected App/OAuth config (use configuring-connected-apps), Apex-only logic (use generating-apex), or data import/export (use handling-sf-data).
venue-templates
IncludedAccess comprehensive LaTeX templates, formatting requirements, and submission guidelines for major scientific publication venues (Nature, Science, PLOS, IEEE, ACM), academic conferences (NeurIPS, ICML, CVPR, CHI), research posters, and grant proposals (NSF, NIH, DOE, DARPA). This skill should be used when preparing manuscripts for journal submission, conference papers, research posters, or grant proposals and need venue-specific formatting requirements and templates.
let-fate-decide
IncludedDraws the 12 Houses of the Zodiac Tarot spread to inject entropy into planning when prompts are vague, ambiguous, or casually delegated. Interprets the spread to guide next steps. Use when the user says 'let fate decide', 'YOLO', 'whatever', 'idk', or other nonchalant phrases, makes Yu-Gi-Oh references, or when you are about to arbitrarily pick between multiple reasonable approaches. Prefer over ask-questions-if-underspecified when the user's tone is casual or playful rather than precision-seeking.
net-ops
IncludedCross-platform network troubleshooting (Windows, macOS, Linux) via local or remote shell. Use for: DNS broken, can't resolve hostnames, nslookup/dig works but apps fail, NRPT, WFP, scutil, /etc/resolver, systemd-resolved, /etc/resolv.conf, NetworkManager, VPN DNS leak residue (ProtonVPN/Mullvad/WireGuard/AnyConnect), AV/firewall blocking DNS or DoH, Tailscale DNS interaction, intermittent connectivity, remote diagnostics over SSH.