Egit: Set gitignore to ignore all eclipse project files - java

I have a project up on github and I want to remove all eclipse related files from it and allow people who clone it to use any ide they want. Here is the project: https://github.com/vedi0boy/Archipelo
What would I have to put in my gitignore? I'm still very new to the whole version control manager thing so you don't have to tell me exactly what to put but maybe explain how it works and what to be careful about so that it will still work.
By the way, it uses gradle so I would also like it so that the gradle related files remain untouched since cloners will need them to build the project and I plan to remove 'APIs' folder and just use gradle dependencies.

For excluding configuration files you have to configure .gitignore to something as follows:
# Eclipse
.classpath
.project
.settings/
# Intellij
.idea/
*.iml
*.iws
# Mac
.DS_Store
# Maven
log/
target/
And, only after this, you have to push your project because now you have to push your configuration to the remote repo.
And you can not delete it locally and push. You have to delete it from remote repo only:
git rm --cached .project
For a directory:
git rm --cached -r target

One of my .gitignore files looks like this:
/bin
/.classpath
/.project
/.settings
/target
You can look at other projects at e.g. GitHub to let you inspire what you might want to put into your .gitignore, e.g.:
https://github.com/spring-projects/spring-framework/blob/master/.gitignore
https://github.com/spring-projects/spring-social/blob/master/.gitignore
However, I think my example above should be sufficient to start with.

Add all the eclipse files to the .gitignore and, to remove them from the remote repository, you will have to
git rm (-r) --cached eclipseProjectFile
The above command will remove the file from the repo, but not from your machine.

1 - create .gitignore file on your GIT project root direcotry (where you have typed "git init" (near .git directory) ). With content of nazar_art noticed or you can add some other pattern for ignore.
2 - git rm -r --cached file_1 file_n directory_1 directory_n ...
3 - git commit -m "removed some files and directories from remote repo and created gitignore :))"
4 - git push -u origin --all (this will synch all branch of your remote (origin) repo) or you can type git push [remote] [branch]
i know it is late. but may be helpful somebody who just beginning

This is general answer to ignore any file extension from git staging.
In Eclipse go to windows->preferences->git->ignore resources (you can simply search "ignore resources").
Check any class extensions that you want to avoid staging in git staging area.
If you do not find your extension there, you have the option to add any extension that you need to ignore.

Related

gitignore file not hide .idea directory for github

I have a project with gitignore file:
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
Temp*
RationalValues*
https://github.com/hhlTer/quadraticEquation
but .idea directory still pushed in my repository...why?
This makes coding very difficult and inaccessible in branches.
I did add to gitignore all files from .idea, but all files still in repository
### IntelliJ IDEA ###
.idea
*.iws
*.iml
*.ipr
Temp*
RationalValues*
compiler.xml
encodings.xml
misc.xml
uiDesigner.xml
vcs.xml
workspace.xml
.gitignore will only make git ignore files in your local repository, and will not apply to files already pushed to the remote repo.
If you wish to remove the files from the remote repository, you can use
git rm --cached -r .idea
Please also see this answer
Good luck! :-)
If they are being pushed, it means they were added at some point to your git.
To ignore them, you must remove them from your repository first, commit the changes and then they won't be added again, as they are on the .gitignore.
To remove the files from git without deleting them, you can do: git rm -r --cached .idea
Please, find more about here: http://www.codeblocq.com/2016/01/Untrack-files-already-added-to-git-repository-based-on-gitignore/
You may had a "/" character after each directory reference.
To ignore .idea directory, you have to write
.idea/

How to push a project folder from IDEA to Github repository

I have a clean Github repository. If I initiate a local Git repo and do Initital commit and then do the following:
git remote add origin https://github.com/kirill-ch/my-repo.git
git push -u origin master
then I get there my project files - the /scr/ folder and pom.xml.
I would like to have a folder in my repository in which I can hold my project so that I can commit different projects in different folders in the future.
How can I do these from the command line or from IDEA?
I have seen the question: Adding a folder from local machine to github
however I don't understand what there going on.
1. If the folder you want is not yet being tracked by git
Just place your folder with the data in your repository root directory and then add the changes and commit.
Move the files to a new directory in your repository root directory.
If you run git status you should now see a list of all the files you have added to your repository.
In the command line, locate to your repository root directory and then run git add ..
Commit the changes: git commit -m "Your commit message".
Push your changes: git push.
Note that git does not know anything about directories/folders, so you cannot add an empty directory in your git repository, git won't find it.
2. The folder/files are already being tracked by git
You can move your /src/ and pom.xml to another directory say test by running the following command (assuming those files are already being tracked by git):
git mv src test
git mv pom.xml test
These will allow git know that you have moved your files to another directory so you now just need to commit and push the changes to the remote repo.
Please note that you cannot have a single local git repo with different multiple remote repos for different directories in your local repo. What you can do instead, is to have multiple local git repos with each having their corresponding remote repos and just house all of them under a single directory on your system (not git directory, just a normal directory).

how to remove unwanted files from maven project

I am currently working with a spring web project. In my project, i am using git,maven and eclipse as IDE. when viewing git status in terminal these three files are present in all cases:
.classpath
.gitignore
.settings
how can in remove these unwanted files. i have no idea how these present in my project. my colleagues have also experiencing this issue.
any suggestions will be helpful.
As its a git repository, you can include below lines in your .gitignore file and then commit your .gitignore file to your central git repository, after that your local git repository won't show the ignore files which you added.
.settings
.classpath
Read more about .gitignore here https://help.github.com/articles/ignoring-files/.
Edit :- You these files are already unchecked then you need to run below command (If you already have a file checked in, and you want to ignore it, Git will not ignore the file if you add a rule later. In those cases, you must untrack the file first, by running the following command in your terminal:) :-
git rm --cached FILENAME
So in you case above command will look like git rm --cached .classpath and git rm --cached .settings.
Create .gitignore file in your project root directory and specify file path you want to untrack, for example:
.classpath
.project
.settings
target/
.mvn/
As other guys mentioned - you should add .gitignore file to the root of the project. There is a good Github project - gitignore. You could concat this files into one:
Java.gitignore
Maven.gitignore
Eclipse.gitignore
You could read more about .gitignore in a project description
You can directly open your workspace and open your project, after that you can manually delete those files... Make sure you check "show hidden files" if you are using windows and before deleting please close eclipse and then remove the files.
In SVN Repository can use Add to svn:ignore. using this one can remove unwanted files.

Add .jar files into a git repository

I have a project on eclipse where recently i created a new folder called lib and added some .jar files inside.
I cannot seem to commit the changes to git. It just doesnt appear in the tracked list of files..
I have removed .jar from .gitignore in my branch and commited the changes, and still the same.
The way I got it working for me was -
git add --force /path/to/the/NAME_Of_THE_JAR.jar
in the .gitignore file present in your project, you need to make sure that you allow *.jar files to be pushed. In my case, *.jar files was listed in ignore list. So I removed it from that list and git was able to detect it and I was able to push it.
You put your files in the project package, but you didn't put them under version control. All you need is to add them to VCS by "git add" command. Here is good documentation.
You should use this command in git bash or in terminal (if you have added git to path)
Also I recommend you to use build manager as Maven, Gradle or Ant to add you dependencies. Good luck!
You can identify if your .jar is needed to be added using the command git diff, git will indicate if you need to add the files to your repository.
Them use git add . and your files will be available for commit.
If the lib folder is ignored by .gitignore you can force adding them to the VCS using the following command:
git add /path/to/lib -f

how can i ignore the .idea folder in .gitignore file?

I ignored the .idea folder(for intellij IDE), all file and folder that is in the .idea is removed. I am seeing the .idea in intellij but no this folder in github. And also when i clone this project there is no again .idea, because of it this project is not working on intellij idea project. I am not adding new developer.
Git doesn't track directories, it tracks only files. When you untrack all files from within a directory, you are in essence untracking the directory as well.
If you want to keep the directory around in your repository on other machines, while ignoring all the files within it, you could add an empty dummy .gitkeep file.
However, since the desired behavior is to not track any files within the directory, we can use a directory specific .gitignore as the dummy file here which has a single ignore rule for ignoring everything.
So, basically, this translates into the following commands:
$ cd $PROJECT_DIR
$ echo "*" >> .idea/.gitignore
$ git add -f .idea/.gitignore && git commit -m "Ignoring all files within .idea"

Categories

Resources