buildframework/helium/sf/java/scm/src/com/nokia/maven/scm/provider/hg/command/log/HgChangeLogConsumer.java
author wbernard
Fri, 13 Aug 2010 14:59:05 +0300
changeset 628 7c4a911dc066
parent 587 85df38eb4012
permissions -rw-r--r--
helium_11.0.0-e00f171ca185
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     1
/*
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     2
 * Copyright (c) 2007-2008 Nokia Corporation and/or its subsidiary(-ies).
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     3
 * All rights reserved.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     5
 * under the terms of the License "Eclipse Public License v1.0"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     8
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
     9
 * Initial Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    10
 * Nokia Corporation - initial contribution.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    11
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    12
 * Contributors:
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    13
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    14
 * Description:  
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    15
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    16
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    17
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    18
package com.nokia.maven.scm.provider.hg.command.log;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    19
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    20
import java.text.ParseException;
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    21
import java.text.SimpleDateFormat;
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    22
import java.util.ArrayList;
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    23
import java.util.Date;
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    24
import java.util.List;
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    26
import org.apache.maven.scm.ChangeFile;
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    27
import org.apache.maven.scm.ScmBranch;
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
import org.apache.maven.scm.ScmException;
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    29
import org.apache.maven.scm.ScmFileStatus;
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    30
import org.apache.maven.scm.ScmRevision;
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
import org.apache.maven.scm.ScmTag;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
import org.apache.maven.scm.log.ScmLogger;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
import org.apache.maven.scm.provider.hg.command.HgConsumer;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    34
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    35
import com.nokia.maven.scm.provider.hg.VersionChangeSet;
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    37
/**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
 * Consumer of 'hg changelog' command output.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    39
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    40
public class HgChangeLogConsumer extends HgConsumer {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    42
    private static final String TIME_PATTERN = "EEE MMM dd HH:mm:ss yyyy Z";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    44
    private static final String REVNO_TAG = "changeset: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
    private static final String TAG_BRANCH = "branch: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
    private static final String TAG_TAG = "tag: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
    private static final String AUTHOR_TAG = "user: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    52
    private static final String TIME_STAMP_TOKEN = "date: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    53
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    54
    private static final String MESSAGE_TOKEN = "description:";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
    private static final String MERGED_TOKEN = "merged: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
    private static final String FILES_TOKEN = "files: ";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
    private String prevLine = "";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    62
    private String prevPrevLine = "";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
    private ArrayList<VersionChangeSet> logEntries = new ArrayList<VersionChangeSet>();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
    private VersionChangeSet currentChange;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    68
    private VersionChangeSet lastChange;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
    private boolean isMergeEntry;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
    private String currentRevision;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
    private String currentTag; // don't know what to do with this
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
    private String currentBranch;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    77
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    78
    private String userDatePattern;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    79
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    80
    private boolean spoolingComments;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    81
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    82
    private List<String> currentComment;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    83
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    84
    public HgChangeLogConsumer(ScmLogger logger, String userDatePattern) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    85
        super(logger);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    86
        this.userDatePattern = userDatePattern;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    87
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    88
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    89
    public List<VersionChangeSet> getModifications() {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    90
        return logEntries;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    91
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    92
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    93
    /** {@inheritDoc} */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    94
    public void consumeLine(String line) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    95
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    96
        // override default behavior which tries to pick through things for
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    97
        // some standard messages. that
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    98
        // does not apply here
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    99
        doConsume(null, line);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   100
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   101
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   102
    /** {@inheritDoc} */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   103
    public void doConsume(ScmFileStatus status, String line) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   104
        String tmpLine = line;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   105
        // If current status == null then this is a new entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   106
        // If the line == "" and previous line was "", then this is also a new
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   107
        // entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   108
        if ((line.equals("") && (prevLine.equals("") && prevPrevLine.equals("")))
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   109
                || currentComment == null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   110
            if (currentComment != null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   111
                StringBuffer comment = new StringBuffer();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   112
                int i = 0;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   113
                for (String eachComment : currentComment) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   114
                    comment.append(eachComment);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   115
                    if (i + 1 < currentComment.size() - 1) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   116
                        comment.append('\n');
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   117
                    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   118
                    i += 1;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   119
                }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   120
                currentChange.setComment(comment.toString());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   121
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   122
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   123
            spoolingComments = false;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   124
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   125
            // If last entry was part a merged entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   126
            if (isMergeEntry && lastChange != null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   127
                String comment = lastChange.getComment();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   128
                comment += "\n[MAVEN]: Merged from "
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   129
                        + currentChange.getAuthor();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   130
                comment += "\n[MAVEN]:    " + currentChange.getDateFormatted();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   131
                comment += "\n[MAVEN]:    " + currentChange.getComment();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   132
                lastChange.setComment(comment);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   133
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   134
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   135
            // Init a new changeset
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   136
            currentChange = new VersionChangeSet();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   137
            currentChange.setFiles(new ArrayList<ChangeFile>());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   138
            logEntries.add(currentChange);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   139
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   140
            // Reset member vars
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   141
            currentComment = new ArrayList<String>();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   142
            currentRevision = "";
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   143
            isMergeEntry = false;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   144
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   145
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   146
        if (spoolingComments) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   147
            currentComment.add(line);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   148
        } else if (line.startsWith(MESSAGE_TOKEN)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   149
            spoolingComments = true;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   150
        } else if (line.startsWith(MERGED_TOKEN)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   151
            // This is part of lastChange and is not a separate log entry
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   152
            isMergeEntry = true;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   153
            logEntries.remove(currentChange);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   154
            if (logEntries.size() > 0) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   155
                lastChange = logEntries.get(logEntries
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   156
                        .size() - 1);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   157
            } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   158
                getLogger().warn("First entry was unexpectedly a merged entry");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   159
                lastChange = null;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   160
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   161
        } else if (line.startsWith(REVNO_TAG)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   162
            tmpLine = line.substring(REVNO_TAG.length()).trim();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   163
            currentRevision = tmpLine;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   164
            try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   165
                currentChange.setScmVersion(new ScmRevision(tmpLine));
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   166
            } catch (ScmException se) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   167
                getLogger().warn(se.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   168
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   169
        } else if (line.startsWith(TAG_TAG)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   170
            tmpLine = line.substring(TAG_TAG.length()).trim();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   171
            currentTag = tmpLine;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   172
            try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   173
                currentChange.setScmVersion(new ScmTag(tmpLine));
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   174
            } catch (ScmException se) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   175
                getLogger().warn(se.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   176
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   177
        } else if (line.startsWith(TAG_BRANCH)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   178
            tmpLine = line.substring(TAG_BRANCH.length()).trim();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   179
            currentBranch = tmpLine;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   180
            try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   181
                currentChange.setScmVersion(new ScmBranch(tmpLine));
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   182
            } catch (ScmException se) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   183
                getLogger().warn(se.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   184
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   185
        } else if (line.startsWith(AUTHOR_TAG)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   186
            tmpLine = line.substring(AUTHOR_TAG.length());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   187
            tmpLine = tmpLine.trim();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   188
            currentChange.setAuthor(tmpLine);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   189
        } else if (line.startsWith(TIME_STAMP_TOKEN)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   190
            tmpLine = line.substring(TIME_STAMP_TOKEN.length()).trim();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   191
            Date date = null;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   192
            try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   193
                SimpleDateFormat format = new SimpleDateFormat(TIME_PATTERN);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   194
                date = format.parse(tmpLine);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   195
                currentChange.setDate(date);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   196
            } catch (ParseException e) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   197
                getLogger().warn(
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   198
                        "Consumer Change Log Date Format not supported:"
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   199
                                + e.getMessage());
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   200
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   201
        } else if (line.startsWith(FILES_TOKEN)) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   202
            tmpLine = line.substring(FILES_TOKEN.length()).trim();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   203
            String[] files = tmpLine.split(" ");
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   204
            for (String eachFile : files) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   205
                ChangeFile changeFile = new ChangeFile(eachFile, currentRevision);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   206
                currentChange.addFile(changeFile);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   207
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   208
        } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   209
            if (!line.equals("")) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   210
                getLogger().warn("Could not figure out: " + line);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   211
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   212
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   213
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   214
        // record previous line
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   215
        prevLine = line;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   216
        prevPrevLine = prevLine;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   217
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
   218
}