當前位置: 首頁>>代碼示例>>Java>>正文


Java ThisLiteralNode類代碼示例

本文整理匯總了Java中org.checkerframework.dataflow.cfg.node.ThisLiteralNode的典型用法代碼示例。如果您正苦於以下問題:Java ThisLiteralNode類的具體用法?Java ThisLiteralNode怎麽用?Java ThisLiteralNode使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ThisLiteralNode類屬於org.checkerframework.dataflow.cfg.node包,在下文中一共展示了ThisLiteralNode類的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: populateElementsRec

import org.checkerframework.dataflow.cfg.node.ThisLiteralNode; //導入依賴的package包/類
@Nullable
private static Root populateElementsRec(Node node, List<Element> elements) {
  Root result;
  if (node instanceof FieldAccessNode) {
    FieldAccessNode fieldAccess = (FieldAccessNode) node;
    if (fieldAccess.isStatic()) {
      // this is the root
      result = new Root(fieldAccess.getElement());
    } else {
      // instance field access
      result = populateElementsRec(fieldAccess.getReceiver(), elements);
      elements.add(fieldAccess.getElement());
    }
  } else if (node instanceof MethodInvocationNode) {
    MethodInvocationNode invocation = (MethodInvocationNode) node;
    // only support zero-argument methods
    if (invocation.getArguments().size() > 0) {
      return null;
    }
    MethodAccessNode accessNode = invocation.getTarget();
    result = populateElementsRec(accessNode.getReceiver(), elements);
    elements.add(accessNode.getMethod());
  } else if (node instanceof LocalVariableNode) {
    result = new Root(((LocalVariableNode) node).getElement());
  } else if (node instanceof ThisLiteralNode) {
    result = new Root();
  } else {
    // don't handle any other cases
    result = null;
  }
  return result;
}
 
開發者ID:uber,項目名稱:NullAway,代碼行數:33,代碼來源:AccessPath.java

示例2: visitAssignment

import org.checkerframework.dataflow.cfg.node.ThisLiteralNode; //導入依賴的package包/類
@Override
public TransferResult<Nullness, NullnessStore<Nullness>> visitAssignment(
    AssignmentNode node, TransferInput<Nullness, NullnessStore<Nullness>> input) {
  ReadableUpdates updates = new ReadableUpdates();
  Nullness value = values(input).valueOfSubNode(node.getExpression());
  Node target = node.getTarget();

  if (target instanceof LocalVariableNode) {
    updates.set((LocalVariableNode) target, value);
  }

  if (target instanceof ArrayAccessNode) {
    setNonnullIfAnalyzeable(updates, ((ArrayAccessNode) target).getArray());
  }

  if (target instanceof FieldAccessNode) {
    // we don't allow arbitrary access paths to be tracked from assignments
    // here we still require an access of a field of this, or a static field
    FieldAccessNode fieldAccessNode = (FieldAccessNode) target;
    Node receiver = fieldAccessNode.getReceiver();
    if ((receiver instanceof ThisLiteralNode || fieldAccessNode.isStatic())
        && fieldAccessNode.getElement().getKind().equals(ElementKind.FIELD)) {
      updates.set(fieldAccessNode, value);
    }
  }

  return updateRegularStore(value, input, updates);
}
 
開發者ID:uber,項目名稱:NullAway,代碼行數:29,代碼來源:AccessPathNullnessPropagation.java

示例3: internalReprOf

import org.checkerframework.dataflow.cfg.node.ThisLiteralNode; //導入依賴的package包/類
/**
 * We ignore operations such as widening and
 * narrowing when computing the internal representation.
 *
 * @return The internal representation (as {@link Receiver}) of any
 *         {@link Node}. Might contain {@link Unknown}.
 */
public static Receiver internalReprOf(AnnotationProvider provider,
        Node receiverNode, boolean allowNonDeterminitic) {
    Receiver receiver = null;
    if (receiverNode instanceof FieldAccessNode) {
        receiver = internalReprOfFieldAccess(provider,
                (FieldAccessNode) receiverNode);
    } else if (receiverNode instanceof ThisLiteralNode) {
        receiver = new ThisReference(receiverNode.getType());
    } else if (receiverNode instanceof SuperNode) {
        receiver = new ThisReference(receiverNode.getType());
    } else if (receiverNode instanceof LocalVariableNode) {
        LocalVariableNode lv = (LocalVariableNode) receiverNode;
        receiver = new LocalVariable(lv);
    } else if (receiverNode instanceof ArrayAccessNode) {
        ArrayAccessNode a = (ArrayAccessNode) receiverNode;
        receiver = internalReprOfArrayAccess(provider, a);
    } else if (receiverNode instanceof StringConversionNode) {
        // ignore string conversion
        return internalReprOf(provider,
                ((StringConversionNode) receiverNode).getOperand());
    } else if (receiverNode instanceof WideningConversionNode) {
        // ignore widening
        return internalReprOf(provider,
                ((WideningConversionNode) receiverNode).getOperand());
    } else if (receiverNode instanceof NarrowingConversionNode) {
        // ignore narrowing
        return internalReprOf(provider,
                ((NarrowingConversionNode) receiverNode).getOperand());
    } else if (receiverNode instanceof ClassNameNode) {
        ClassNameNode cn = (ClassNameNode) receiverNode;
        receiver = new ClassName(cn.getType());
    } else if (receiverNode instanceof ValueLiteralNode) {
        ValueLiteralNode vn = (ValueLiteralNode) receiverNode;
        receiver = new ValueLiteral(vn.getType(), vn);
    } else if (receiverNode instanceof MethodInvocationNode) {
        MethodInvocationNode mn = (MethodInvocationNode) receiverNode;
        ExecutableElement invokedMethod = TreeUtils.elementFromUse(mn
                .getTree());

        // check if this represents a boxing operation of a constant, in which
        // case we treat the method call as deterministic, because there is no way
        // to behave differently in two executions where two constants are being used.
        boolean considerDeterministic = false;
        if (invokedMethod.toString().equals("valueOf(long)")
                && mn.getTarget().getReceiver().toString().equals("Long")) {
            Node arg = mn.getArgument(0);
            if (arg instanceof ValueLiteralNode) {
                considerDeterministic = true;
            }
        }

        if (PurityUtils.isDeterministic(provider, invokedMethod) || allowNonDeterminitic || considerDeterministic) {
            List<Receiver> parameters = new ArrayList<>();
            for (Node p : mn.getArguments()) {
                parameters.add(internalReprOf(provider, p));
            }
            Receiver methodReceiver;
            if (ElementUtils.isStatic(invokedMethod)) {
                methodReceiver = new ClassName(mn.getTarget().getReceiver()
                        .getType());
            } else {
                methodReceiver = internalReprOf(provider, mn.getTarget()
                        .getReceiver());
            }
            receiver = new PureMethodCall(mn.getType(), invokedMethod,
                    methodReceiver, parameters);
        }
    }

    if (receiver == null) {
        receiver = new Unknown(receiverNode.getType());
    }
    return receiver;
}
 
開發者ID:reprogrammer,項目名稱:checker-framework,代碼行數:82,代碼來源:FlowExpressions.java


注:本文中的org.checkerframework.dataflow.cfg.node.ThisLiteralNode類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。