-
Notifications
You must be signed in to change notification settings - Fork 88
Git Problems and Fixes
"Can we create a Git channel here?" - Mizipzor
Use this page for FAQ and problems with using Git and ways how to fix them for others to see and learn.
Github resources for learning Git and Github
Pro Git: the official git book, written by Scott Chacon and Ben Straub and published by Apress (free to read online -- dead tree version available for $)
Many of you would like to skip the command line in order to help with the project.
Here is the solution: Source Tree. It's a simple way to view the project's progress, and it's available for Mac and Windows. [//]: # (removed "only available" because mac and windows are the only OS's that unity supports, so if you don't have either, you can't really contribute to the project at all.)
You'll have to fetch the master from TeamPorcupine (master) and then merge with your local master before you merge your "feature" branch every time you want to push. (I recommend fetch and merge and not straight up pull because if it happens that you are on the wrong branch you wouldn't lose anything). ###!!Tutorial Coming
This can be because of a few reasons; the first being that we do have a pretty restrictive .gitignore
but even so there can be a few tricky situations that take ages to figure out why a certain thing is occurring. If this is occurring and you have checked the gitignore under the ProjectPorcupine folder and it's all okay, then type git check-ignore -v <path to file in question>
and then you will receive a nice little log of where the pesky extra gitignore file is located. For example an issue that occurred for one of the contributors was he had Visual Studio 2017 installed and was using that and that version decided to go and create a 'global' gitignore file which had a setting which ignored all Dlls, so when he entered that command he got something like C:\\Users\\New\\Documents\\gitignore_global.txt":22:*.dll Assets/Plugins/UnityDebugger.dll
, this clued him into where it was and sure enough in that folder there was that file which was creating a global occurrence, a quick delete of that file fixed the issue.
Now that we have integrated with Travis, there will be times when your Pull Request will fail to build in travis, and will be shamefully marked with a red X for all to see. If your PR failed to build in travis one of the following happened:
- Your Pull Request has a compilation error
- Your Pull Request causes a unit test to fail (or you wrote a new unit test that fails)
- Travis is being dumb <- most likely option
To see which occurred, click on the red x, and show detail so you are taken to the build on travis-ci.org. Read the log output and see what the last few messages are.
-
Results file not found!
- you have a compilation error. -
1 unit test failed!
- your PR breaks a unit test. obviously. -
No output has been received in the last __
- Travis being dumb.
Remember, Travis checks your PR after it is merged into master, so if it detects an error that you don't have, make sure to merge the latest version of master into your branch. You can check unit tests by going to Window > Editor Test Runner
in Unity.
When you fix your error, commit your changes as normal and Travis will retry the build.
You can also run the Travis script locally by running
$ ./Scripts/test.sh
from the command line. You cannot have the Unity editor open for this to work, however. If you get a complaint that it cannot find your Unity, find the Unity executable wherever you installed it on your system and run
$ export unityPath="/path/to/your/Unity.exe"
then try test.sh
.
You can set test.sh
to run automatically before pushing. This makes sure that you never push code that causes Travis builds to fail. To set this up run
$ cp Scripts/test.sh .git/hooks/pre-push
If tests are failing and for some reason you want to push anyway you can do git push --no-verify
.
If your build failed due to Travis being dumb, then you don't have to change your code. Instead you can either continue pushing commits if you are still working, or simply close and reopen your PR. Either will cause Travis to rebuild your PR. Hopefully Travis will actually work the second time around.
For any further questions on Travis and CI Builds, ask @bjubes on the discord help channel.
Many people have been having this issue, so hopefully this section can solve your problems.
The best way to avoid adding extra files to your pull request is to never add them to your commits. Before you create a commit, check what is going to be added by looking at what is checked off in your GUI.
Uncheck files that you do not want to include before you commit, and they will never end up in your PR.
Warning! This is an advanced git feature, so it may be easier to start over again in a new PR for smaller changes.
If your PR has additional files already, you must locate the commit where the files were added and rebase your PR to remove them. Rebase is potentially destructive, so use care to follow this tutorial exactly. If you are unsure of how to rebase to fix your specific issue, don't hesitate to ask @bjubes in your PR. There is additionally documentation on the git rebase command and a section in the official git book on rewriting history for further guidance.
- Rebase is easiest to do in the command line, so lets open it.
- On Windows open git bash by typing "git bash" into search or by right clicking inside the root of Project Porcupine and finding the git bash option in the context menu.
- On mac, open Terminal.exe from spotlight.
- use the
cd
command to change directories until you are at the root of Project Porcupine. - switch to your PR's branch by typing
git checkout <feature-branch-name>
- type in
git rebase -i HEAD~3
, replacing "3" with the number of commits ago you added the files you need to remove. - Vim will open a new file that will let you modify your previous commits. Vim is not very intuitive, so follow along carefully.
-
When vim opens, you cannot directly edit the text as if in a word processor like notepad. Instead you must first hit the
a
key to get into insertion mode. When you hita
,--INSERT--
will appear at the bottom left of the screen. -
If you added files in a commit and want to delete that commit in its entirety, use the arrow keys to move the cursor to the line the commit is on and delete it. In this case I will delete
Update GIT_TUTORIAL
. -
If you added files in a commit and want to modify the commit, but not delete it entirely, change
pick
toe
on that line.
-
Once you are done choosing which commits to delete or edit, hit
esc
to exit--INSERT--
mode. To save your changes type in:wq
(this should appear on the bottom left as you type) and hit Enter. If you messed up, delete everything in the file to abort by holding downd
until the file is only~
. Then save with:wq
. -
If you deleted commits only, you are done! finalize your changes by committing
git commit -m "remove extra files"
and pushinggit push -f
. This will permanently delete the commits you selected in step 5. If you chose to edit commits, read on. -
When you save in Vim, the console will then tell you to how to proceed.
-
Remove files by using the command
git rm <filepath>
and then typegit rebase --continue
when you are done. type:wq
when the commit appears in vim.
10.keep removing, continuing, and saving the new commit until the rebase is done. Then go back to step 7.
- Features
-
Roadmap
- Milestone 0.3
- Milestone 0.2 (reached)
- Milestone 0.1 (reached)
- Gameplay
- Frequently Asked Questions