Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.lang.postscript > #4019 > unrolled thread

Parse ASN.1 DER format

Started bynews@zzo38computer.org.invalid
First post2025-10-22 14:38 -0700
Last post2025-10-22 14:38 -0700
Articles 1 — 1 participant

Back to article view | Back to comp.lang.postscript


Contents

  Parse ASN.1 DER format news@zzo38computer.org.invalid - 2025-10-22 14:38 -0700

#4019 — Parse ASN.1 DER format

Fromnews@zzo38computer.org.invalid
Date2025-10-22 14:38 -0700
SubjectParse ASN.1 DER format
Message-ID<1761168222.bystand@zzo38computer.org>
I wrote a PostScript code to parse ASN.1 DER format. (This file is
public domain.)

Currently it only implements decoding and not encoding. Also, it only
decodes the framing and does not decode values.

/ASN1class [/Universal /Application /Context /Private] def

/ASN1parse {
  dup read {
    << >> begin
    /Tag exch def
    /File exch def
    /Constructed Tag -5 bitshift 0 ne def
    /Class //ASN1class Tag -6 bitshift get def
    /Tag Tag 16#1F and dup 16#1F eq {
      pop 0 {File read {
        exch 7 bitshift 1 index 16#7F and or
        exch 16#80 lt {exit} if
      } {exit} ifelse} loop
    } if def
    /Length File read pop def
    Length 16#80 ge {
      /Length 0 Length 16#7F and {
        8 bitshift File read {or} if
      } repeat def
    } if
    /Data Constructed {
      /File File Length () /SubFileDecode filter def
      [{File ASN1parse not {exit} if} loop]
    } {
      Length 0 eq {()} {File Length string readstring pop} ifelse
    } ifelse def
    {File Constructed Length} {currentdict exch undef} forall
    currentdict end //true
  } {
    pop //false
  } ifelse
} bind def

-- 
Don't laugh at the moon when it is day time in France.

[toc] | [standalone]


Back to top | Article view | comp.lang.postscript


csiph-web