/* * Copyright (c) 2016, Oracle and/or its affiliates. * * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are * permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list of * conditions and the following disclaimer in the documentation and/or other materials provided * with the distribution. * * 3. Neither the name of the copyright holder nor the names of its contributors may be used to * endorse or promote products derived from this software without specific prior written * permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. */ package com.oracle.truffle.llvm.parser.metadata; public final class MDLexicalBlock implements MDBaseNode { private final MDReference scope; private final MDReference file; private final long line; private final long column; private MDLexicalBlock(MDReference scope, MDReference file, long line, long column) { this.scope = scope; this.file = file; this.line = line; this.column = column; } @Override public void accept(MetadataVisitor visitor) { visitor.visit(this); } public MDReference getFile() { return file; } public long getLine() { return line; } public long getColumn() { return column; } public MDReference getScope() { return scope; } @Override public String toString() { return String.format("LexicalBlock (scope=%s, file=%s, line=%d, column=%d)", scope, file, line, column); } private static final int ARGINDEX_38_SCOPE = 1; private static final int ARGINDEX_38_FILE = 2; private static final int ARGINDEX_38_LINE = 3; private static final int ARGINDEX_38_COLUMN = 4; public static MDLexicalBlock create38(long[] args, MetadataList md) { // [distinct, scope, file, line, column] final MDReference scope = md.getMDRefOrNullRef(args[ARGINDEX_38_SCOPE]); final MDReference file = md.getMDRefOrNullRef(args[ARGINDEX_38_FILE]); final long line = args[ARGINDEX_38_LINE]; final long column = args[ARGINDEX_38_COLUMN]; return new MDLexicalBlock(scope, file, line, column); } private static final int ARGINDEX_32_SCOPE = 1; private static final int ARGINDEX_32_LINE = 2; private static final int ARGINDEX_32_COLUMN = 3; private static final int ARGINDEX_32_FILE = 4; public static MDLexicalBlock create32(MDTypedValue[] args) { final MDReference scope = ParseUtil.getReference(args[ARGINDEX_32_SCOPE]); final long line = ParseUtil.asInt32(args[ARGINDEX_32_LINE]); final long column = ParseUtil.asInt32(args[ARGINDEX_32_COLUMN]); final MDReference file = ParseUtil.getReference(args[ARGINDEX_32_FILE]); // asInt32(args[5); // Unique ID to identify blocks from a template function return new MDLexicalBlock(scope, file, line, column); } }