10

If I have a "vendors" directory in my .gitignore, is there a way I can set up a remote that will receive that directory anyway when I do a push?

Alexander Trauzzi
  • 7,277
  • 13
  • 68
  • 112
  • 2
    "that will receive that directory anyway" - sorry, what do you mean? a directory is either ignored or not... – Basic Aug 03 '12 at 01:57
  • It may be that it's fundamentally not possible. In which case, feel free to answer my question saying as much if you're positive of it :) – Alexander Trauzzi Aug 03 '12 at 02:02
  • I'm not 100% sure what you're after. I've posted an answer with some possibilities from other SO Qs. If that's not quite what you're after, let us know – Basic Aug 03 '12 at 02:23

4 Answers4

8

Your .gitignore file has nothing to do with pushing. It is used by things like git status and git add to figure out what files should be (or could be) part of a future commit. You can add things that are ignored using the git add command; it will throw an error unless you use the -f option:

The following paths are ignored by one of your .gitignore files:
somefilename
Use -f if you really want to add them.
fatal: no files added

Once you've added the file to the repository, it will be pushed along with any other changes.

larsks
  • 277,717
  • 41
  • 399
  • 399
  • 2
    Problem is, I don't want to commit this directory to my repo, I only want it to be included on a push to a specific remote (appfog). In this case, it's a directory with automatically managed dependencies. – Alexander Trauzzi Aug 03 '12 at 02:12
  • That's fine, but it is still the case that the `.gitignore` file does not control what gets pushed where. – larsks Aug 03 '12 at 12:58
8

I think the functionality you're looking for can be achieved by having a branch used to deploy to your Cloud Provider.

Setup a dev branch which includes your .gitignore file, check your incremental work into that branch.

Merge your dev branch into your deploy branch which doesn't contain a .gitignore file but contains the vendors directory.

once you've completed your merge, push to the deployment remote from your deploy branch.

cory-fowler
  • 4,020
  • 2
  • 18
  • 29
2

use -f to forcefully add.

Here is the example.

git add -f path/to/file
Nishad Up
  • 3,457
  • 1
  • 28
  • 32
0

Nishad-up's answer is correct: git commit and git push will only handle the content you set to update to the remote. But when you call git add on something that's in .gitignore, or inside a folder that's listed there, git doesn't accept the command, and throws the error you got.
You have to force staging such files or folders using git add -f relative-path-to/my-file.png or whatever file(s) you want, the rest is the same (git commit, git push, etc).
*I couldn't figure out how to do this through the VS-Code source control bar, I had to do it in the terminal.