新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍了Rugged::Commit类怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Rugged::Commit类怎么使用文章都会有所收获,下面我们一起来看看吧。
站在用户的角度思考问题,与客户深入沟通,找到峨眉山网站设计与峨眉山网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都网站设计、网站建设、企业官网、英文网站、手机端网站、网站推广、域名注册、雅安服务器托管、企业邮箱。业务覆盖峨眉山地区。
1.遍历仓库的Commits
Rugged::Walker是用来对仓库的commits集合进行遍历的。
walker = Rugged::Walker.new(repo) #c walker.sorting(Rugged::SORT_TOPO | Rugged::SORT_REVERSE) #遍历方式(按拓扑逆序,也可以采用时间顺序) walker.push(hex_sha_interesting) #感兴趣的commit的oid(sha)值,从该sha开始进行遍历 walker.hide(hex_sha_uninteresting) #不希望遍历的sha(由此包括其前面的sha) walker.each { |c| puts c.inspect } #遍历输出 walker.reset
2.创建Commit
author = {:email=>"zouqilin@csu.edu.cn", :time=>Time.now, :name=>"zouqilin"}#代码作者 committer = {:email=>"zouqilin@csu.edu.cn", :time=>Time.now, :name=>"zouqilin"}#提交者 Rugged::Commit.create(r, :author => author, :message => "Hello world\n\n",#提交信息 :committer => author, :parents => ["2cb831a8aea28b2c1b9c63385585b864e4d3bad1"],#父提交 :tree => some_tree,#构建的根树 :update_ref => "HEAD"#需要更新的分支名 #=> "f148106ca58764adc93ad4e2d6b1d168422b9796"#返回值,创建的commit sha值(oid)
3.获取Commit的相关属性和目录,文件以及submodule
lastest_cmt = repo.head.target#获取HEAD指向的Commit root_tree = lastest_cmt.tree#获取根树 entries = root_tree.entries#获取根树的文件和目录(包括submodule)列表 entries.each{|e|puts e}#打印 #结果如下 {:type=>:blob, :oid=>"99e7edb53db9355f10c6f2dfaa5a183f205d93bf", :filemode=>100644, :name=>".gitignore"} { :type => :tree, :name => "lib", :oid => "e1253910439ea902cf49be8a9f02f3c08d89ac73", :filemode => 040000 } { :type => :blob, :name => "README.md", :oid => "81b68f040b120c9627518213f7fc317d1ed18e1c", :filemode => 0100644 } raw_blob = repo.lookup("81b68f040b120c9627518213f7fc317d1ed18e1c")#获取raw_blob从而得到文件大小和内容 raw_blob.size #文件大小 raw_blob.data# ascii编码内容 raw_blob.text#utf-8文本 raw_tree = repo.lookup("e1253910439ea902cf49be8a9f02f3c08d89ac73") raw.entries#目录下的entry raw.count#目录下的entries count raw.path("lib/string.h")#获取string.h的entry
关于“Rugged::Commit类怎么使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Rugged::Commit类怎么使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注创新互联行业资讯频道。