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();
}