Skip to content

Backporting Tutorial

stfx edited this page Sep 2, 2015 · 14 revisions

This tutorial was written by stfx for developers to correctly backport commits and shows an example on backporting from mangos-wotlk to mangos-tbc.

1. Set up the directory

  • Clone mangos-tbc repo
  • Add mangos-wotlk remote: git remote add wotlk _url_

2. Backport commits

  • Fetch from mangos-wotlk every time something changes there: git fetch wotlk
  • Start backport tool with hash of commit to backport: contrib/backporting/mangos-backport.sh _commit_hash_
  • Check and resolve conflicts if any exist
    • Amend the commit after resolving conflicts: git commit -s --amend

2.1. Backport commits with sql changes

  • Fetch from mangos-wotlk (like before)
  • Use backport tool (like before)
  • Check and resolve conflicts (like before)
  • Rename the sql updates in sql/updates directory by adding this commit's version number at the start of the filename like so: 11754_01_mangos_mangos_string.sql -> s1415_11754_01_mangos_mangos_string.sql
  • Remove the line related to db_version change (usually the first line in each sql update file)
  • Amend commit (like before)

2.2. Number commits with sql changes using git_id

  • Build git_id tool in release mode if you did not already (located in contrib\git_id)
  • Push every outstanding commit because git_id.exe checks last version from remote
  • Use git_id in git bash: contrib/git_id/Release/git_id.exe
    • This automatically writes all db_version changes to mangos.sql and in the sql/updates/*.sql

3. Push the commits

  • Check correct authorship
  • Check commit number for commits with sql changes
  • Push to the mangos-tbc remote: git push origin master (assuming you named the mangos-tbc remote 'origin' which is the default after cloning)
Clone this wiki locally