This project has retired. For details please refer to its Attic page.
Source code
001/**
002 * Licensed to the Apache Software Foundation (ASF) under one
003 * or more contributor license agreements.  See the NOTICE file
004 * distributed with this work for additional information
005 * regarding copyright ownership.  The ASF licenses this file
006 * to you under the Apache License, Version 2.0 (the
007 * "License"); you may not use this file except in compliance
008 * with the License.  You may obtain a copy of the License at
009 *
010 *   http://www.apache.org/licenses/LICENSE-2.0
011 *
012 * Unless required by applicable law or agreed to in writing,
013 * software distributed under the License is distributed on an
014 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
015 * KIND, either express or implied.  See the License for the
016 * specific language governing permissions and limitations
017 * under the License.
018 */
019package org.apache.reef.tang.implementation;
020
021import org.apache.reef.tang.BindLocation;
022
023import java.util.Arrays;
024
025public class StackBindLocation implements BindLocation {
026  final StackTraceElement[] stack;
027
028  public StackBindLocation() {
029    StackTraceElement[] stack = new Throwable().getStackTrace();
030    if (stack.length != 0) {
031      this.stack = Arrays.copyOfRange(stack, 1, stack.length);
032    } else {
033      this.stack = new StackTraceElement[0];
034    }
035  }
036
037  @Override
038  public String toString() {
039    StringBuffer sb = new StringBuffer("[\n");
040    for (StackTraceElement e : stack) {
041      sb.append(e.toString() + "\n");
042    }
043    sb.append("]\n");
044    return sb.toString();
045  }
046}