Mercurial > hg > graal-compiler
view graal/com.oracle.truffle.api/src/com/oracle/truffle/api/instrument/StandardSyntaxTag.java @ 17001:5d16da2ca0c8
Instrumentation: Removed extends SyntaxTagged from Wrapper interface.
SL/Instrumentation: Removed unnecessary methods related to above change.
author | David Piorkowski <david.piorkowski@oracle.com> |
---|---|
date | Fri, 29 Aug 2014 15:21:39 -0700 |
parents | a01fe4b301a8 |
children | e3c95cbbb50c |
line wrap: on
line source
/* * Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.oracle.truffle.api.instrument; /** * A somewhat language-agnostic set of user-sensible syntactic categories, suitable for conventional * imperative languages, and is being developed incrementally. * <p> * The need for alternative sets of tags is likely to arise, perhaps for other families of languages * (for example for mostly expression-oriented languages) or even for specific languages. * <p> * <strong>Disclaimer:</strong> experimental interface under development. * * @see Probe * @see Wrapper */ public enum StandardSyntaxTag implements SyntaxTag { /** * Marker for a variable assignment. */ ASSIGNMENT("assignment", "a variable assignment"), /** * Marker for a call site. */ CALL("call", "a method/procedure call site"), /** * Marker for a location where a guest language exception is about to be thrown. */ THROW("throw", "creator of an exception"), /** * Marker for a location where ordinary "stepping" should halt. */ STATEMENT("statement", "basic unit of the language, suitable for \"stepping\" in a debugger"), /** * Marker for the start of the body of a method. */ START_METHOD("start-method", "start of the body of a method"), /** * Marker for the start of the body of a loop. */ START_LOOP("start-loop", "start of the body of a loop"), /** * Marker that is attached to some arbitrary locations that appear often-enough in an AST so * that a location with this tag is regularly executed. Could be the start of method and loop * bodies. May be used to implement some kind of safepoint functionality. */ PERIODIC("periodic", "arbitrary locations that appear often-enough in an AST so that a location with this tag is regularly executed"); private final String name; private final String description; private StandardSyntaxTag(String name, String description) { this.name = name; this.description = description; } public String getName() { return name; } public String getDescription() { return description; } }