1/*
2 * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20 * or visit www.oracle.com if you need additional information or have any
21 * questions.
22 */
23
24package compiler.compilercontrol.share.scenario;
25
26import compiler.compilercontrol.share.method.MethodDescriptor;
27
28/**
29 * Compile Command description interface
30 */
31public class CompileCommand {
32    public final Command command;
33    public final MethodDescriptor methodDescriptor;
34    public final Scenario.Compiler compiler;
35    public final Scenario.Type type;
36
37    public CompileCommand(Command command,
38                          MethodDescriptor methodDescriptor,
39                          Scenario.Compiler compiler,
40                          Scenario.Type type) {
41        this.command = command;
42        this.methodDescriptor = methodDescriptor;
43        this.compiler = compiler;
44        this.type = type;
45    }
46
47    /**
48     * Shows that this compile command is valid
49     *
50     * @return true if this is a valid command
51     */
52    public boolean isValid() {
53        if (command == Command.NONEXISTENT) {
54            return false;
55        }
56        return methodDescriptor.isValid();
57    }
58
59    /**
60     * Prints compile command to the system output
61     */
62    public void print() {
63        System.out.printf("%s (type: %s): %s (valid: %b)%n", command.name(),
64                type.name(), methodDescriptor.getString(), isValid());
65    }
66}
67