private void writeAgentTrackTraceTelemetryMethod()

in agent/agent-tooling/src/main/java/com/microsoft/applicationinsights/agent/internal/legacysdk/TelemetryClientClassFileTransformer.java [912:1015]


    private void writeAgentTrackTraceTelemetryMethod() {
      MethodVisitor mv =
          cw.visitMethod(
              ACC_PRIVATE,
              "agent$trackTraceTelemetry",
              "(L" + unshadedPrefix + "/telemetry/TraceTelemetry;)V",
              null,
              null);
      mv.visitCode();
      Label label0 = new Label();
      mv.visitLabel(label0);
      mv.visitVarInsn(ALOAD, 1);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TraceTelemetry",
          "getSeverityLevel",
          "()L" + unshadedPrefix + "/telemetry/SeverityLevel;",
          false);
      mv.visitVarInsn(ASTORE, 2);
      Label label1 = new Label();
      mv.visitLabel(label1);
      mv.visitVarInsn(ALOAD, 2);
      Label label2 = new Label();
      mv.visitJumpInsn(IFNULL, label2);
      mv.visitVarInsn(ALOAD, 2);
      mv.visitMethodInsn(
          INVOKEVIRTUAL, unshadedPrefix + "/telemetry/SeverityLevel", "getValue", "()I", false);
      Label label3 = new Label();
      mv.visitJumpInsn(GOTO, label3);
      mv.visitLabel(label2);
      mv.visitFrame(
          Opcodes.F_APPEND, 1, new Object[] {unshadedPrefix + "/telemetry/SeverityLevel"}, 0, null);
      mv.visitInsn(ICONST_M1);
      mv.visitLabel(label3);
      mv.visitFrame(Opcodes.F_SAME1, 0, null, 1, new Object[] {Opcodes.INTEGER});
      mv.visitVarInsn(ISTORE, 3);
      Label label4 = new Label();
      mv.visitLabel(label4);
      mv.visitVarInsn(ALOAD, 1);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TraceTelemetry",
          "getTimestamp",
          "()Ljava/util/Date;",
          false);
      mv.visitVarInsn(ALOAD, 1);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TraceTelemetry",
          "getMessage",
          "()Ljava/lang/String;",
          false);
      mv.visitVarInsn(ILOAD, 3);
      mv.visitVarInsn(ALOAD, 1);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TraceTelemetry",
          "getProperties",
          "()Ljava/util/Map;",
          false);
      mv.visitVarInsn(ALOAD, 1);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TraceTelemetry",
          "getContext",
          "()L" + unshadedPrefix + "/telemetry/TelemetryContext;",
          false);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TelemetryContext",
          "getTags",
          "()Ljava/util/concurrent/ConcurrentMap;",
          false);
      mv.visitVarInsn(ALOAD, 1);
      Label label5 = new Label();
      mv.visitLabel(label5);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TraceTelemetry",
          "getContext",
          "()L" + unshadedPrefix + "/telemetry/TelemetryContext;",
          false);
      mv.visitMethodInsn(
          INVOKEVIRTUAL,
          unshadedPrefix + "/telemetry/TelemetryContext",
          "getInstrumentationKey",
          "()Ljava/lang/String;",
          false);
      Label label6 = new Label();
      mv.visitLabel(label6);
      mv.visitMethodInsn(
          INVOKESTATIC,
          BYTECODE_UTIL_INTERNAL_NAME,
          "trackTrace",
          "(Ljava/util/Date;Ljava/lang/String;ILjava/util/Map;Ljava/util/Map;Ljava/lang/String;)V",
          false);
      Label label7 = new Label();
      mv.visitLabel(label7);
      mv.visitInsn(RETURN);
      Label label8 = new Label();
      mv.visitLabel(label8);
      mv.visitMaxs(6, 4);
      mv.visitEnd();
    }