/* * Copyright 2017 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ package org.webrtc; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * @CalledByNativeUnchecked is used to generate JNI bindings that do not check for exceptions. * It only makes sense to use this annotation on methods that declare a throws... spec. * However, note that the exception received native side maybe an 'unchecked' (RuntimeExpception) * such as NullPointerException, so the native code should differentiate these cases. * Usage of this should be very rare; where possible handle exceptions in the Java side and use a * return value to indicate success / failure. */ @Target(ElementType.METHOD) @Retention(RetentionPolicy.CLASS) public @interface CalledByNativeUnchecked { /* * If present, tells which inner class the method belongs to. */ public String value() default ""; }