buildframework/helium/sf/java/sbs/src/com/nokia/helium/sbs/plexus/SBSErrorStreamConsumer.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
package com.nokia.helium.sbs.plexus;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    18
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    19
import java.io.BufferedWriter;
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    20
import java.io.File;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    21
import java.io.FileNotFoundException;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    22
import java.io.IOException;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    23
import java.util.regex.Matcher;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    24
import java.util.regex.Pattern;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    25
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    26
import org.apache.log4j.Logger;
628
7c4a911dc066 helium_11.0.0-e00f171ca185
wbernard
parents: 587
diff changeset
    27
587
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    28
import com.nokia.helium.core.plexus.FileStreamConsumer;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    29
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    30
/**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    31
 * Record a stream into a file. 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    32
 *
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    33
 */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    34
public class SBSErrorStreamConsumer extends FileStreamConsumer {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    35
    private Logger log = Logger.getLogger(SBSErrorStreamConsumer.class);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    36
    private String errorPattern ;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    37
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    38
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    39
     * Create a FileStreamConsumer which will record content to 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    40
     * the output file.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    41
     * @param output the file to write the output to.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    42
     * @param string 
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    43
     * @throws FileNotFoundException if an error occur while opening the file.
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    44
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    45
    public SBSErrorStreamConsumer(File output, String string) throws FileNotFoundException {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    46
        super(output);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    47
        this.errorPattern = string;
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    48
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    49
    
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    50
    /**
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    51
     * {@inheritDoc}
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    52
     */
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    53
    @Override
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    54
    public synchronized void consumeLine(String line) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    55
        if (this.errorPattern == null) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    56
            try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    57
                BufferedWriter writer = getWriter();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    58
                writer.write("Error:" + line);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    59
                writer.newLine();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    60
            } catch (IOException e) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    61
                log.error("Error while writing to file: " + e.getMessage(), e);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    62
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    63
        } else {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    64
            try {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    65
                Pattern pattern = Pattern.compile(this.errorPattern, Pattern.CASE_INSENSITIVE);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    66
                Matcher match = pattern.matcher(line);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    67
                if (match.find()) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    68
                    BufferedWriter writer = getWriter();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    69
                    writer.write("Error:" + line);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    70
                    writer.newLine();
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    71
                }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    72
                
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    73
            } catch (IOException e) {
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    74
                log.error("Error while writing to file: " + e.getMessage(), e);
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    75
            }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    76
        }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    77
        
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    78
    }
85df38eb4012 helium_9.0-a7879c935424
wbernard
parents:
diff changeset
    79
}