當前位置: 首頁>>代碼示例>>C#>>正文


C# Git.Rm方法代碼示例

本文整理匯總了C#中NGit.Api.Git.Rm方法的典型用法代碼示例。如果您正苦於以下問題:C# Git.Rm方法的具體用法?C# Git.Rm怎麽用?C# Git.Rm使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在NGit.Api.Git的用法示例。


在下文中一共展示了Git.Rm方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: FailingPathsShouldNotResultInOKReturnValue

 public virtual void FailingPathsShouldNotResultInOKReturnValue()
 {
     FilePath folder1 = new FilePath(db.WorkTree, "folder1");
     FileUtils.Mkdir(folder1);
     FilePath file = new FilePath(folder1, "file1.txt");
     Write(file, "folder1--file1.txt");
     file = new FilePath(folder1, "file2.txt");
     Write(file, "folder1--file2.txt");
     Git git = new Git(db);
     git.Add().AddFilepattern(folder1.GetName()).Call();
     RevCommit @base = git.Commit().SetMessage("adding folder").Call();
     RecursiveDelete(folder1);
     git.Rm().AddFilepattern("folder1/file1.txt").AddFilepattern("folder1/file2.txt").
         Call();
     RevCommit other = git.Commit().SetMessage("removing folders on 'other'").Call();
     git.Checkout().SetName(@base.Name).Call();
     file = new FilePath(db.WorkTree, "unrelated.txt");
     Write(file, "unrelated");
     git.Add().AddFilepattern("unrelated").Call();
     RevCommit head = git.Commit().SetMessage("Adding another file").Call();
     // Untracked file to cause failing path for delete() of folder1
     file = new FilePath(folder1, "file3.txt");
     Write(file, "folder1--file3.txt");
     ResolveMerger merger = new ResolveMerger(db, false);
     merger.SetCommitNames(new string[] { "BASE", "HEAD", "other" });
     merger.SetWorkingTreeIterator(new FileTreeIterator(db));
     bool ok = merger.Merge(head.Id, other.Id);
     NUnit.Framework.Assert.IsFalse(merger.GetFailingPaths().IsEmpty());
     NUnit.Framework.Assert.IsFalse(ok);
 }
開發者ID:dprothero,項目名稱:ngit,代碼行數:30,代碼來源:ResolveMergerTest.cs

示例2: SetUp

		public override void SetUp()
		{
			base.SetUp();
			git = new Git(db);
			// commit something
			WriteTrashFile(FILE, "Hello world");
			git.Add().AddFilepattern(FILE).Call();
			commit1 = git.Commit().SetMessage("Initial commit").Call();
			git.Rm().AddFilepattern(FILE).Call();
			commit2 = git.Commit().SetMessage("Removed file").Call();
			git.NotesAdd().SetObjectId(commit1).SetMessage("data").Call();
		}
開發者ID:shoff,項目名稱:ngit,代碼行數:12,代碼來源:NotesCommandTest.cs

示例3: DeleteCore

		void DeleteCore (FilePath[] localPaths, bool force, IProgressMonitor monitor)
		{
			foreach (var group in localPaths.GroupBy (p => GetRepository (p))) {
				var repository = group.Key;
				var files = group;

				var git = new NGit.Api.Git (repository);
				RmCommand rm = git.Rm ();
				foreach (var f in files)
					rm.AddFilepattern (repository.ToGitPath (f));
				rm.Call ();
			}
		}
開發者ID:kthguru,項目名稱:monodevelop,代碼行數:13,代碼來源:GitRepository.cs

示例4: TestModifiedAndRenamed

 public virtual void TestModifiedAndRenamed()
 {
     // this test is essentially the same as testDeletionOnSideConflict,
     // however if once rename support is added this test should result in a
     // successful merge instead of a conflict
     Git git = new Git(db);
     WriteTrashFile("x", "add x");
     git.Add().AddFilepattern("x").Call();
     RevCommit initial = git.Commit().SetMessage("add x").Call();
     CreateBranch(initial, "refs/heads/d1");
     CreateBranch(initial, "refs/heads/d2");
     // rename x to y on d1
     CheckoutBranch("refs/heads/d1");
     new FilePath(db.WorkTree, "x").RenameTo(new FilePath(db.WorkTree, "y"));
     git.Rm().AddFilepattern("x").Call();
     git.Add().AddFilepattern("y").Call();
     RevCommit d1Commit = git.Commit().SetMessage("d1 rename x -> y").Call();
     CheckoutBranch("refs/heads/d2");
     WriteTrashFile("x", "d2 change");
     git.Add().AddFilepattern("x").Call();
     RevCommit d2Commit = git.Commit().SetMessage("d2 change in x").Call();
     CheckoutBranch("refs/heads/master");
     MergeCommandResult d1Merge = git.Merge().Include(d1Commit).Call();
     NUnit.Framework.Assert.AreEqual(MergeStatus.FAST_FORWARD, d1Merge.GetMergeStatus(
         ));
     MergeCommandResult d2Merge = git.Merge().Include(d2Commit).Call();
     NUnit.Framework.Assert.AreEqual(MergeStatus.CONFLICTING, d2Merge.GetMergeStatus()
         );
     NUnit.Framework.Assert.AreEqual(1, d2Merge.GetConflicts().Count);
     NUnit.Framework.Assert.AreEqual(3, d2Merge.GetConflicts().Get("x")[0].Length);
 }
開發者ID:OrangeCloudNetworks,項目名稱:ngit,代碼行數:31,代碼來源:MergeCommandTest.cs

示例5: TestMergeRemovingFoldersWithoutFastForward

 public virtual void TestMergeRemovingFoldersWithoutFastForward()
 {
     FilePath folder1 = new FilePath(db.WorkTree, "folder1");
     FilePath folder2 = new FilePath(db.WorkTree, "folder2");
     FileUtils.Mkdir(folder1);
     FileUtils.Mkdir(folder2);
     FilePath file = new FilePath(folder1, "file1.txt");
     Write(file, "folder1--file1.txt");
     file = new FilePath(folder1, "file2.txt");
     Write(file, "folder1--file2.txt");
     file = new FilePath(folder2, "file1.txt");
     Write(file, "folder--file1.txt");
     file = new FilePath(folder2, "file2.txt");
     Write(file, "folder2--file2.txt");
     Git git = new Git(db);
     git.Add().AddFilepattern(folder1.GetName()).AddFilepattern(folder2.GetName()).Call
         ();
     RevCommit @base = git.Commit().SetMessage("adding folders").Call();
     RecursiveDelete(folder1);
     RecursiveDelete(folder2);
     git.Rm().AddFilepattern("folder1/file1.txt").AddFilepattern("folder1/file2.txt").
         AddFilepattern("folder2/file1.txt").AddFilepattern("folder2/file2.txt").Call();
     RevCommit other = git.Commit().SetMessage("removing folders on 'branch'").Call();
     git.Checkout().SetName(@base.Name).Call();
     file = new FilePath(folder2, "file3.txt");
     Write(file, "folder2--file3.txt");
     git.Add().AddFilepattern(folder2.GetName()).Call();
     git.Commit().SetMessage("adding another file").Call();
     MergeCommandResult result = git.Merge().Include(other.Id).SetStrategy(MergeStrategy
         .RESOLVE).Call();
     NUnit.Framework.Assert.AreEqual(MergeStatus.MERGED, result.GetMergeStatus());
     NUnit.Framework.Assert.IsFalse(folder1.Exists());
 }
開發者ID:OrangeCloudNetworks,項目名稱:ngit,代碼行數:33,代碼來源:MergeCommandTest.cs

示例6: TestDeletionOnSideConflict

 public virtual void TestDeletionOnSideConflict()
 {
     Git git = new Git(db);
     WriteTrashFile("a", "1\na\n3\n");
     WriteTrashFile("b", "1\nb\n3\n");
     git.Add().AddFilepattern("a").AddFilepattern("b").Call();
     RevCommit initialCommit = git.Commit().SetMessage("initial").Call();
     // create side branch and delete "a"
     CreateBranch(initialCommit, "refs/heads/side");
     CheckoutBranch("refs/heads/side");
     git.Rm().AddFilepattern("a").Call();
     RevCommit secondCommit = git.Commit().SetMessage("side").Call();
     // update a on master to generate conflict
     CheckoutBranch("refs/heads/master");
     WriteTrashFile("a", "1\na(main)\n3\n");
     git.Add().AddFilepattern("a").Call();
     git.Commit().SetMessage("main").Call();
     // merge side with master
     MergeCommandResult result = git.Merge().Include(secondCommit.Id).SetStrategy(MergeStrategy
         .RESOLVE).Call();
     NUnit.Framework.Assert.AreEqual(MergeStatus.CONFLICTING, result.GetMergeStatus());
     NUnit.Framework.Assert.IsTrue(new FilePath(db.WorkTree, "a").Exists());
     NUnit.Framework.Assert.AreEqual("1\na(main)\n3\n", Read(new FilePath(db.WorkTree,
         "a")));
     NUnit.Framework.Assert.AreEqual("1\nb\n3\n", Read(new FilePath(db.WorkTree, "b"))
         );
     NUnit.Framework.Assert.AreEqual(1, result.GetConflicts().Count);
     NUnit.Framework.Assert.AreEqual(3, result.GetConflicts().Get("a")[0].Length);
 }
開發者ID:OrangeCloudNetworks,項目名稱:ngit,代碼行數:29,代碼來源:MergeCommandTest.cs

示例7: DeleteCore

		void DeleteCore (FilePath[] localPaths, bool force, IProgressMonitor monitor, bool keepLocal)
		{
			foreach (var group in GroupByRepository (localPaths)) {
				List<FilePath> backupFiles = new List<FilePath> ();
				var repository = group.Key;
				var files = group;

				var git = new NGit.Api.Git (repository);
				RmCommand rm = git.Rm ();
				foreach (var f in files) {
					// Create backups.
					if (keepLocal) {
						string newPath = "";
						if (f.IsDirectory) {
							newPath = FileService.CreateTempDirectory ();
							FileService.CopyDirectory (f, newPath);
						} else {
							newPath = Path.GetTempFileName ();
							File.Copy (f, newPath, true);
						}
						backupFiles.Add (newPath);
					}

					rm.AddFilepattern (repository.ToGitPath (f));
				}

				try {
					rm.Call ();
				} finally {
					// Restore backups.
					if (keepLocal) {
						foreach (var backup in backupFiles) {
							if (backup.IsDirectory)
								FileService.MoveDirectory (backup, files.ElementAt (backupFiles.IndexOf (backup)));
							else
								File.Move (backup, files.ElementAt (backupFiles.IndexOf (backup)));
						}
					}
				}
			}
		}
開發者ID:Chertolom,項目名稱:monodevelop,代碼行數:41,代碼來源:GitRepository.cs

示例8: TestResetHardFromIndexEntryWithoutFileToTreeWithoutFile

 public virtual void TestResetHardFromIndexEntryWithoutFileToTreeWithoutFile()
 {
     Git git = new Git(db);
     WriteTrashFile("x", "x");
     git.Add().AddFilepattern("x").Call();
     RevCommit id1 = git.Commit().SetMessage("c1").Call();
     WriteTrashFile("f/g", "f/g");
     git.Rm().AddFilepattern("x").Call();
     git.Add().AddFilepattern("f/g").Call();
     git.Commit().SetMessage("c2").Call();
     DeleteTrashFile("f/g");
     DeleteTrashFile("f");
     // The actual test
     git.Reset().SetMode(ResetCommand.ResetType.HARD).SetRef(id1.GetName()).Call();
     AssertIndex(Mkmap("x", "x"));
 }
開發者ID:JamesChan,項目名稱:ngit,代碼行數:16,代碼來源:DirCacheCheckoutTest.cs

示例9: TestRename

		public virtual void TestRename()
		{
			Git git = new Git(db);
			string[] content1 = new string[] { "a", "b", "c" };
			WriteTrashFile("file.txt", Join(content1));
			git.Add().AddFilepattern("file.txt").Call();
			RevCommit commit1 = git.Commit().SetMessage("create file").Call();
			WriteTrashFile("file1.txt", Join(content1));
			git.Add().AddFilepattern("file1.txt").Call();
			git.Rm().AddFilepattern("file.txt").Call();
			git.Commit().SetMessage("moving file").Call();
			string[] content2 = new string[] { "a", "b", "c2" };
			WriteTrashFile("file1.txt", Join(content2));
			git.Add().AddFilepattern("file1.txt").Call();
			RevCommit commit3 = git.Commit().SetMessage("editing file").Call();
			BlameCommand command = new BlameCommand(db);
			command.SetFollowFileRenames(true);
			command.SetFilePath("file1.txt");
			BlameResult lines = command.Call();
			NUnit.Framework.Assert.AreEqual(commit1, lines.GetSourceCommit(0));
			NUnit.Framework.Assert.AreEqual(0, lines.GetSourceLine(0));
			NUnit.Framework.Assert.AreEqual("file.txt", lines.GetSourcePath(0));
			NUnit.Framework.Assert.AreEqual(commit1, lines.GetSourceCommit(1));
			NUnit.Framework.Assert.AreEqual(1, lines.GetSourceLine(1));
			NUnit.Framework.Assert.AreEqual("file.txt", lines.GetSourcePath(1));
			NUnit.Framework.Assert.AreEqual(commit3, lines.GetSourceCommit(2));
			NUnit.Framework.Assert.AreEqual(2, lines.GetSourceLine(2));
			NUnit.Framework.Assert.AreEqual("file1.txt", lines.GetSourcePath(2));
		}
開發者ID:shoff,項目名稱:ngit,代碼行數:29,代碼來源:BlameCommandTest.cs

示例10: DeleteDirectories

		public override void DeleteDirectories (FilePath[] localPaths, bool force, IProgressMonitor monitor)
		{
			NGit.Api.Git git = new NGit.Api.Git (repo);
			RmCommand rm = git.Rm ();
			foreach (var f in localPaths)
				rm.AddFilepattern (repo.ToGitPath (f));
			rm.Call ();
			
			// Untracked files are not deleted by the rm command, so delete them now
			foreach (var f in localPaths) {
				if (Directory.Exists (f))
					Directory.Delete (f, true);
			}
		}
開發者ID:JamesChan,項目名稱:monodevelop,代碼行數:14,代碼來源:GitRepository.cs

示例11: TestUntrackedFolders

 public virtual void TestUntrackedFolders()
 {
     Git git = new Git(db);
     IndexDiff diff = new IndexDiff(db, Constants.HEAD, new FileTreeIterator(db));
     diff.Diff();
     NUnit.Framework.CollectionAssert.AreEquivalent(Collections<string>.EMPTY_SET, diff.GetUntrackedFolders()
         );
     WriteTrashFile("readme", string.Empty);
     WriteTrashFile("src/com/A.java", string.Empty);
     WriteTrashFile("src/com/B.java", string.Empty);
     WriteTrashFile("src/org/A.java", string.Empty);
     WriteTrashFile("src/org/B.java", string.Empty);
     WriteTrashFile("target/com/A.java", string.Empty);
     WriteTrashFile("target/com/B.java", string.Empty);
     WriteTrashFile("target/org/A.java", string.Empty);
     WriteTrashFile("target/org/B.java", string.Empty);
     git.Add().AddFilepattern("src").AddFilepattern("readme").Call();
     git.Commit().SetMessage("initial").Call();
     diff = new IndexDiff(db, Constants.HEAD, new FileTreeIterator(db));
     diff.Diff();
     NUnit.Framework.CollectionAssert.AreEquivalent(new HashSet<string>(Arrays.AsList("target")), diff
         .GetUntrackedFolders());
     WriteTrashFile("src/tst/A.java", string.Empty);
     WriteTrashFile("src/tst/B.java", string.Empty);
     diff = new IndexDiff(db, Constants.HEAD, new FileTreeIterator(db));
     diff.Diff();
     NUnit.Framework.CollectionAssert.AreEquivalent(new HashSet<string>(Arrays.AsList("target", "src/tst"
         )), diff.GetUntrackedFolders());
     git.Rm().AddFilepattern("src/com/B.java").AddFilepattern("src/org").Call();
     git.Commit().SetMessage("second").Call();
     WriteTrashFile("src/org/C.java", string.Empty);
     diff = new IndexDiff(db, Constants.HEAD, new FileTreeIterator(db));
     diff.Diff();
     NUnit.Framework.CollectionAssert.AreEquivalent(new HashSet<string>(Arrays.AsList("src/org", "src/tst"
         , "target")), diff.GetUntrackedFolders());
 }
開發者ID:sharwell,項目名稱:ngit,代碼行數:36,代碼來源:IndexDiffTest.cs

示例12: TestConflictingDeletedAndModified

 public virtual void TestConflictingDeletedAndModified()
 {
     Git git = new Git(db);
     WriteTrashFile("a", "1\na\n3\n");
     WriteTrashFile("b", "1\nb\n3\n");
     git.Add().AddFilepattern("a").AddFilepattern("b").Call();
     RevCommit initialCommit = git.Commit().SetMessage("initial").Call();
     // create side branch and delete "a"
     CreateBranch(initialCommit, "refs/heads/side");
     CheckoutBranch("refs/heads/side");
     git.Rm().AddFilepattern("a").Call();
     RevCommit secondCommit = git.Commit().SetMessage("side").Call();
     // update a on master to generate conflict
     CheckoutBranch("refs/heads/master");
     WriteTrashFile("a", "1\na(main)\n3\n");
     git.Add().AddFilepattern("a").Call();
     git.Commit().SetMessage("main").Call();
     // merge side with master
     MergeCommandResult result = git.Merge().Include(secondCommit.Id).SetStrategy(MergeStrategy
         .RESOLVE).Call();
     NUnit.Framework.Assert.AreEqual(MergeStatus.CONFLICTING, result.GetMergeStatus());
     FileTreeIterator iterator = new FileTreeIterator(db);
     IndexDiff diff = new IndexDiff(db, Constants.HEAD, iterator);
     diff.Diff();
     NUnit.Framework.Assert.AreEqual("[]", new TreeSet<string>(diff.GetChanged()).ToString
         ());
     NUnit.Framework.CollectionAssert.IsEmpty(diff.GetAdded());
     NUnit.Framework.CollectionAssert.IsEmpty(diff.GetRemoved());
     NUnit.Framework.CollectionAssert.IsEmpty(diff.GetMissing());
     NUnit.Framework.CollectionAssert.IsEmpty(diff.GetModified());
     NUnit.Framework.Assert.AreEqual("a", diff.GetConflicting().First ());
     NUnit.Framework.Assert.AreEqual(1, diff.GetConflicting().Count ());
     NUnit.Framework.CollectionAssert.IsEmpty(diff.GetUntrackedFolders()
         );
 }
開發者ID:sharwell,項目名稱:ngit,代碼行數:35,代碼來源:IndexDiffTest.cs

示例13: TestRenamedBoundLineDelete

		public virtual void TestRenamedBoundLineDelete()
		{
			Git git = new Git(db);
			string FILENAME_1 = "subdir/file1.txt";
			string FILENAME_2 = "subdir/file2.txt";
			string[] content1 = new string[] { "first", "second" };
			WriteTrashFile(FILENAME_1, Join(content1));
			git.Add().AddFilepattern(FILENAME_1).Call();
			RevCommit c1 = git.Commit().SetMessage("create file1").Call();
			// rename it
			WriteTrashFile(FILENAME_2, Join(content1));
			git.Add().AddFilepattern(FILENAME_2).Call();
			DeleteTrashFile(FILENAME_1);
			git.Rm().AddFilepattern(FILENAME_1).Call();
			git.Commit().SetMessage("rename file1.txt to file2.txt").Call();
			// and change the new file
			string[] content2 = new string[] { "third", "first", "second" };
			WriteTrashFile(FILENAME_2, Join(content2));
			git.Add().AddFilepattern(FILENAME_2).Call();
			RevCommit c2 = git.Commit().SetMessage("change file2").Call();
			BlameGenerator generator = new BlameGenerator(db, FILENAME_2);
			try
			{
				generator.Push(null, db.Resolve(Constants.HEAD));
				NUnit.Framework.Assert.AreEqual(3, generator.GetResultContents().Size());
				NUnit.Framework.Assert.IsTrue(generator.Next());
				NUnit.Framework.Assert.AreEqual(c2, generator.GetSourceCommit());
				NUnit.Framework.Assert.AreEqual(1, generator.GetRegionLength());
				NUnit.Framework.Assert.AreEqual(0, generator.GetResultStart());
				NUnit.Framework.Assert.AreEqual(1, generator.GetResultEnd());
				NUnit.Framework.Assert.AreEqual(0, generator.GetSourceStart());
				NUnit.Framework.Assert.AreEqual(1, generator.GetSourceEnd());
				NUnit.Framework.Assert.AreEqual(FILENAME_2, generator.GetSourcePath());
				NUnit.Framework.Assert.IsTrue(generator.Next());
				NUnit.Framework.Assert.AreEqual(c1, generator.GetSourceCommit());
				NUnit.Framework.Assert.AreEqual(2, generator.GetRegionLength());
				NUnit.Framework.Assert.AreEqual(1, generator.GetResultStart());
				NUnit.Framework.Assert.AreEqual(3, generator.GetResultEnd());
				NUnit.Framework.Assert.AreEqual(0, generator.GetSourceStart());
				NUnit.Framework.Assert.AreEqual(2, generator.GetSourceEnd());
				NUnit.Framework.Assert.AreEqual(FILENAME_1, generator.GetSourcePath());
				NUnit.Framework.Assert.IsFalse(generator.Next());
			}
			finally
			{
				generator.Release();
			}
			// and test again with other BlameGenerator API:
			generator = new BlameGenerator(db, FILENAME_2);
			try
			{
				generator.Push(null, db.Resolve(Constants.HEAD));
				BlameResult result = generator.ComputeBlameResult();
				NUnit.Framework.Assert.AreEqual(3, result.GetResultContents().Size());
				NUnit.Framework.Assert.AreEqual(c2, result.GetSourceCommit(0));
				NUnit.Framework.Assert.AreEqual(FILENAME_2, result.GetSourcePath(0));
				NUnit.Framework.Assert.AreEqual(c1, result.GetSourceCommit(1));
				NUnit.Framework.Assert.AreEqual(FILENAME_1, result.GetSourcePath(1));
				NUnit.Framework.Assert.AreEqual(c1, result.GetSourceCommit(2));
				NUnit.Framework.Assert.AreEqual(FILENAME_1, result.GetSourcePath(2));
			}
			finally
			{
				generator.Release();
			}
		}
開發者ID:LunarLanding,項目名稱:ngit,代碼行數:66,代碼來源:BlameGeneratorTest.cs

示例14: Prepare_f3_f2_14

		/// <exception cref="System.Exception"></exception>
		private void Prepare_f3_f2_14(Git git, int state, bool include_f2)
		{
			FilePath f2 = null;
			if (include_f2)
			{
				f2 = WriteTrashFile(F2, "c2");
				git.Add().AddFilepattern(F2).Call();
				git.Commit().SetMessage(MSG).Call();
			}
			if (state >= 1)
			{
				WriteTrashFile(F3, "c3");
				git.Add().AddFilepattern(F3).Call();
			}
			if (state >= 2)
			{
				git.Commit().SetMessage(MSG).Call();
			}
			if (state >= 3)
			{
				git.Rm().AddFilepattern(F3).Call();
			}
			if (state == 4)
			{
				WriteTrashFile(F3, "c3'");
				git.Add().AddFilepattern(F3).Call();
			}
			if (include_f2)
			{
				Write(f2, "c2'");
				git.Add().AddFilepattern(F2).Call();
				Write(f2, "c2''");
			}
		}
開發者ID:LunarLanding,項目名稱:ngit,代碼行數:35,代碼來源:CommitOnlyTest.cs

示例15: Prepare_f1_3

		/// <exception cref="System.Exception"></exception>
		private FilePath Prepare_f1_3(Git git)
		{
			FilePath f1 = Prepare_f1_7(git);
			git.Rm().AddFilepattern(F1).Call();
			return f1;
		}
開發者ID:LunarLanding,項目名稱:ngit,代碼行數:7,代碼來源:CommitOnlyTest.cs


注:本文中的NGit.Api.Git.Rm方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。