Skip to content

Commit 524245a

Browse files
unify how taggedobjects get decoded
1 parent aa03671 commit 524245a

File tree

1 file changed

+7
-13
lines changed

1 file changed

+7
-13
lines changed

Diff for: src/main/java/org/jruby/ext/openssl/ASN1.java

+7-13
Original file line numberDiff line numberDiff line change
@@ -1063,20 +1063,14 @@ else if ( obj instanceof ASN1GraphicString ) {
10631063
break;
10641064
}
10651065

1066-
if (taggedObj.getTagClass() == BERTags.APPLICATION) {
1067-
try {
1068-
final ASN1Sequence sequence = (ASN1Sequence) taggedObj.getBaseUniversal(false, SEQUENCE);
1069-
@SuppressWarnings("unchecked")
1070-
final RubyArray valArr = decodeObjects(context, ASN1, sequence.getObjects());
1071-
return ASN1.getClass("ASN1Data").newInstance(context, new IRubyObject[] { valArr, tag, tag_class }, Block.NULL_BLOCK);
1072-
} catch (IllegalStateException e) {
1073-
IRubyObject val = decodeObject(context, ASN1, taggedObj.getBaseObject()).callMethod(context, "value");
1074-
return ASN1.getClass("ASN1Data").newInstance(context, new IRubyObject[] { val, tag, tag_class }, Block.NULL_BLOCK);
1075-
}
1076-
} else {
1077-
IRubyObject val = decodeObject(context, ASN1, taggedObj.getBaseObject());
1078-
final RubyArray valArr = runtime.newArray(val);
1066+
try {
1067+
final ASN1Sequence sequence = (ASN1Sequence) taggedObj.getBaseUniversal(false, SEQUENCE);
1068+
@SuppressWarnings("unchecked")
1069+
final RubyArray valArr = decodeObjects(context, ASN1, sequence.getObjects());
10791070
return ASN1.getClass("ASN1Data").newInstance(context, new IRubyObject[] { valArr, tag, tag_class }, Block.NULL_BLOCK);
1071+
} catch (IllegalStateException e) {
1072+
IRubyObject val = decodeObject(context, ASN1, taggedObj.getBaseObject()).callMethod(context, "value");
1073+
return ASN1.getClass("ASN1Data").newInstance(context, new IRubyObject[] { val, tag, tag_class }, Block.NULL_BLOCK);
10801074
}
10811075
}
10821076

0 commit comments

Comments
 (0)