1、当天站立式会议照片

会议内容:

本次会议为第六次会议

本次会议在陆大楼3楼召开,本次会议内容:

①:检查总结上次任务完成情况

②:安排今天的分工

③:对昨天的问题进行讨论

④:遇到困难,及时群里反馈

2. 每个人的工作 (有work item 的ID)

工作中遇到的困难:

随着beta计划的进行,到现在已经六天了,渐渐的我们的项目越来越完善,同时也会遇到很多困难,但是我们每天都会召开团队会议,对前一天遇到的问题进行讨论并想方法解决,马上beta计划就也要结束了,相信我们会成功发布项目。

3. 发布项目燃尽图;请用专业的工具完成



横坐标:工作日,以天为单位,一共七天,代表着beta冲刺阶段的时间一共为7天

纵坐标:剩余卡片数,以卡片数为单位,代表着每一个任务。

黄线:代表设置的卡片数在规定的工作日内的理想的完成情况。

蓝线:表示我们实际完成的卡片数。

4. 代码签入记录:

https://coding.net/u/hts-technology/p/CodeManagement/git/tree/master

部分代码:

/**
* 打开远程仓库
*
* @param repositoryPath
* @return
*/
public static Repository openRepository(String repositoryPath) {
Repository repository = null;
try {
Git git = Git.open(new File(repositoryPath));
repository = git.getRepository();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} // 將本地倉庫打開
return repository;
} /**
* git pull
*
* @param repositoryPath
*/
public static Repository pullFromRemoteRepository(Git git) {
try {
git.pull().call();
} catch (GitAPIException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return git.getRepository();
} /**
* 統計給定commitID后所有commit信息
*
*/
public static void diffBetweenCommit(String repositoryPath, String lastcommitId) {
Git git;
Repository repository;
try {
git = Git.open(new File(repositoryPath));
repository = pullFromRemoteRepository(git);
RevWalk walk = new RevWalk(repository);
Ref head = repository.findRef("HEAD");
List<RevCommit> commitList = new ArrayList<>();
Iterable<RevCommit> commits;
try {
commits = git.log().all().call();
for (RevCommit commit : commits) {
commitList.add(commit);
}
int numCommit = commitList.size(); // 获取上一次的commit在list中的位置
int fromIdToWirte = 0;
for (int i = numCommit - 1; i > 0; i--) {
if (commitList.get(i).getId().getName().equals(lastcommitId)) {
fromIdToWirte = i;
break;
}
} for (int i = fromIdToWirte; i > 0; i--) { // 得到commit的时间
long sec = commitList.get(i).getCommitTime() * 1000;
Date dat = new Date(sec);
GregorianCalendar gc = new GregorianCalendar();
gc.setTime(dat);
java.text.SimpleDateFormat format = new java.text.SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
String newCommitTime = format.format(gc.getTime()); // 得到两次commit的不同之处
AbstractTreeIterator oldTree = prepareTreeParser(repository, commitList.get(i));
AbstractTreeIterator newTree = prepareTreeParser(repository, commitList.get(i - 1));
List<DiffEntry> diff = git.diff().setOldTree(oldTree).setNewTree(newTree)
.setShowNameAndStatusOnly(true).call(); // 格式化输出格式
ByteArrayOutputStream out = new ByteArrayOutputStream();
DiffFormatter df = new DiffFormatter(out);
df.setDiffComparator(RawTextComparator.WS_IGNORE_ALL);// 设置比较器为忽略空白字符对比(Ignores
// all
// whitespace) df.setRepository(git.getRepository()); //统计newCommit与OldCommit新增了多少行,减少了多少行
for (DiffEntry diffEntry : diff) { // 获取文件差异位置,从而统计差异的行数,如增加行数,减少行数
FileHeader fileHeader;
fileHeader = df.toFileHeader(diffEntry);
List<HunkHeader> hunks = (List<HunkHeader>) fileHeader.getHunks();
int addSize = 0;
int subSize = 0;
for (HunkHeader hunkHeader : hunks) {
EditList editList = hunkHeader.toEditList();
for (Edit edit : editList) {
subSize += edit.getEndA() - edit.getBeginA();
addSize += edit.getEndB() - edit.getBeginB();
}
}
out.reset();
} }
} catch (GitAPIException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} } public static AbstractTreeIterator prepareTreeParser(Repository repository, RevCommit commit) throws IOException {
System.out.println(commit.getId());
try (RevWalk walk = new RevWalk(repository)) {
System.out.println(commit.getTree().getId());
RevTree tree = walk.parseTree(commit.getTree().getId());
CanonicalTreeParser oldTreeParser = new CanonicalTreeParser();
try (ObjectReader oldReader = repository.newObjectReader()) {
oldTreeParser.reset(oldReader, tree.getId());
}
walk.dispose();
return oldTreeParser;
} catch (Exception e) { }
return null;
}

团队作业8——第二次项目冲刺(Beta阶段)5.25的更多相关文章

  1. 团队作业8 ----第二次项目冲刺(Beta阶段)博客汇总

    一.冲刺计划安排 团队作业8--Beta版本冲刺计划及安排 二.七天冲刺汇总 [Beta]第一次Daily Scrum Meeting [Beta]第二次Daily Scrum Meeting [Be ...

  2. 团队作业7——第二次项目冲刺-Beta版本项目计划

    上一个阶段的总结: 在Alpha阶段,我们小组已近完成了大部分的功能要求,小组的每一个成员都发挥了自己的用处.经过了这么久的磨合,小组的成员之间越来越默契,相信在接下来的合作中,我们的开发速度会越来越 ...

  3. 团队作业7——第二次项目冲刺(Beta版本)

    团队作业7——第二次项目冲刺-Beta版本项目计划 团队作业7——第二次项目冲刺(Beta版本)-第一篇 团队作业7——第二次项目冲刺(Beta版本)-第二篇 团队作业7——第二次项目冲刺(Beta版 ...

  4. 【集美大学1411_助教博客】团队作业8——第二次项目冲刺(Beta阶段)

    写在前面的话 此次团队作业8可以拆分成两部分:1.beta阶段冲刺计划安排,2.7天敏捷冲刺."我们很低调"没有使用leangoo,经过与张老师的商议,张老师同意他们不使用lean ...

  5. 【1414软工助教】团队作业8——第二次项目冲刺(Beta阶段) 得分榜

    题目 团队作业8--第二次项目冲刺(Beta阶段) 往期成绩 个人作业1:四则运算控制台 结对项目1:GUI 个人作业2:案例分析 结对项目2:单元测试 团队作业1:团队展示 团队作业2:需求分析&a ...

  6. 团队作业8——第二次项目冲刺(Beta阶段)--5.19 first day

    团队作业8--第二次项目冲刺(Beta阶段)--5.19 Day one: 会议照片 项目进展 由于今天是Beta版本项目冲刺的第一天,所以没有昨天已完成任务.以下是今日具体的任务安排. 队员 今日计 ...

  7. 团队作业8——第二次项目冲刺(Beta阶段)--5.21 second day

    团队作业8--第二次项目冲刺(Beta阶段)--5.21 second day Day two: 会议照片 项目进展 今天是beta冲刺的第二天,组长还在准备考试当中,我们继续做前端改进和后端安排,今 ...

  8. 团队作业8——第二次项目冲刺(Beta阶段)--5.23 third day

    团队作业8--第二次项目冲刺(Beta阶段)--5.23 third day Day three: 会议照片 项目进展 今天是beta冲刺的第三天,组长回到了队伍当中,正式开始改进alpha中存在的功 ...

  9. 团队作业8——第二次项目冲刺(Beta阶段)--5.24 forth day

    团队作业8--第二次项目冲刺(Beta阶段)--5.24 forth day Day four: 会议照片 项目进展 Beta冲刺的第四天,以下是今天具体任务安排: 队员 昨天已完成的任务 今日计划完 ...

  10. 团队作业8——第二次项目冲刺(Beta阶段)--5.25 5th day

    团队作业8--第二次项目冲刺(Beta阶段)--5.25 fifth day Day five: 会议照片 项目进展 Beta冲刺的第四天,以下是今天具体任务安排: 队员 昨天已完成的任务 今日计划完 ...

随机推荐

  1. Tp3.2提交表单与操作表单

    笔记笔记 先去建个表———— 然后把我输入的东西 存到表里: <input type="submit" id="tijiao" value="提 ...

  2. PAT1074 Reversing Linked List (25)详细题解

    02-1. Reversing Linked List (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue ...

  3. 【机器学习笔记之一】深入浅出学习K-Means算法

    摘要:在数据挖掘中,K-Means算法是一种 cluster analysis 的算法,其主要是来计算数据聚集的算法,主要通过不断地取离种子点最近均值的算法. 在数据挖掘中,K-Means算法是一种c ...

  4. /dev/null 2>&1解释

    /dev/null 2>&1 解释 crontab内容 :50 18 5-30 * * /script/myscript.sh 1> /dev/null 2>&1 其 ...

  5. 关于virtualenvwrapper的python, pip 的版本的问题

    关于virtualenvwrapper的python, pip 的版本的问题: 在创建虚拟环境时, 我们可以用 mkvirtualenv THE_NAME_OF_VENV --python=pytho ...

  6. 【每天一道算法题】Lucky String

    A string s is LUCKY if and only if the number of different characters in s is a fibonacci number. Gi ...

  7. Response乱码时的处理方法

    有时候我们看到Response中的HTML是乱码的, 这是因为HTML被压缩了, 我们可以通过两种方法去解压缩. 步骤:方法一:点击红框内容"Response body is encoude ...

  8. 关于《Unity3D/2D游戏开发从0到1》书籍再版说明

    关于<Unity3D/2D游戏开发从0到1>第一版本在2015年7月1日全国发行,累计得到不少国内高校教师.培训机构的好评.但是由于Unity官方对于技术不断的升级与版本的快速迭代,基于U ...

  9. css知识点

    css知识点 一.盒模型知识 border: 边框 border-width:边框的宽度 border-color:边框的颜色 border-style:边框的线型 border-top:上边框 bo ...

  10. 7.21.06 java内存模型

    资料来源:http://www.cnblogs.com/smile361/archive/2013/11/25/3441553.html 程序计数器: 当前线程所执行的字节码的行号指示器 本地方法栈: ...