summaryrefslogtreecommitdiff
path: root/Tools/Java/Source/PcdTools/org/tianocore/pcd/action/BuildAction.java
blob: 9d30a76bdc02de32b373f2f6fa85546d5df7e999 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/** @file
  BuildAction class.

  BuildAction is the parent class for all action related to ant Task. This class will
  define some common utility functionality, such as logMsg, warningMsg..etc.
 
Copyright (c) 2006, Intel Corporation
All rights reserved. This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License
which accompanies this distribution.  The full text of the license may be found at
http://opensource.org/licenses/bsd-license.php
 
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

**/
package org.tianocore.pcd.action;

import org.apache.tools.ant.Task;
import org.apache.tools.ant.Project;
import org.tianocore.pcd.exception.BuildActionException;

/** BuildAction is the parent class for all action related to ant Task. This class will
    define some common utility functionality, such as logMsg, warningMsg..etc.
**/
public abstract class BuildAction extends Task {
    ///
    /// Original message level before this action. This value will 
    /// be restored when quit this action.
    ///
    private int originalMessageLevel;

    /**
      checkParameter function check all parameter valid.

      This function will be overrided by child class.
    **/
    public abstract void checkParameter() throws BuildActionException;

    /**
     performAction is to execute the detail action.
      
     This function will be overrided by child class.
    **/
    public abstract void performAction() throws BuildActionException;

    /**
      execute function is the main flow for all build action class.

      This workflow will be:
      1) Check paramet of this action.
      2) Perform the child class action function.
      3) Restore the message level.
     
      @throws BuildActionException
    **/  
    public void execute() throws BuildActionException {
        checkParameter();
        performAction();
    }
}