frame 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. #------------------------------------------------------------------------------
  2. # $File: frame,v 1.19 2024/03/04 00:34:31 christos Exp $
  3. # frame: file(1) magic for FrameMaker files
  4. #
  5. # This stuff came on a FrameMaker demo tape, most of which is
  6. # copyright, but this file is "published" as witness the following:
  7. #
  8. # URL: https://en.wikipedia.org/wiki/Adobe_FrameMaker
  9. #
  10. # Update: Joerg Jenderek 2024 Mar
  11. # URL: http://fileformats.archiveteam.org/wiki/FrameMaker
  12. # Reference: http://mark0.net/download/triddefs_xml.7z/defs/f/fm.trid.xml
  13. # Note: called "FrameMaker document" by TrID and "Adobe FrameMaker document" by shared MIME-info database
  14. # skip "text" DROID samples like: fmt-190-signature-id-840.fm fmt-533-signature-id-837.fm fmt-534-signature-id-838.fm fmt-535-signature-id-839.fm fmt-536-signature-id-841.fm
  15. # fmt-537-signature-id-842.fm fmt-538-signature-id-843.fm fmt-539-signature-id-844.fm x-fmt-302-signature-id-395.fm
  16. 0 string/b \<MakerFile FrameMaker document
  17. #!:mime application/octet-stream
  18. # https://www.iana.org/assignments/media-types/application/vnd.framemaker
  19. !:mime application/vnd.framemaker
  20. # version string like 1.0 2.0 3.0 4.0 5.0 5.5 6.0 7.0 8.0 9.0 10.0
  21. >11 string x (%0.3s
  22. # before closing directive ">" is appended version letter like: F H J K Q Y
  23. >>14 ubyte >0x40 %c
  24. # or last digit of 4 character version string
  25. >>14 ubyte <0x41 \b%c
  26. # test again so that next default clause works
  27. >14 ubyte x
  28. # Reference: http://mark0.net/download/triddefs_xml.7z/defs/h/hlp-fm.trid.xml
  29. # Note: called "FrameMaker Help" by TrID
  30. # look for reference to FrameMaker help name suffix like in: index1.hlp
  31. >>18 search/9688/s .hlp: \b) help
  32. # the internal FrameMaker help are just FrameMaker document with hlp suffix; XREF.HLP is same as Xref-hlp.fm
  33. !:ext hlp
  34. # For control reason show link name like:
  35. # "Overview" "lastpage "firstpage "Add File" "Conditional Text" "Table Format" "Creating a reference frame" "firstpageCov" "Spot Colors" "Selecting text" "proceduresbl" "lastpageu" "Introducing HelpHe" "Menu of Syntax Descriptions" "Main FrameMaker window"
  36. #>>>&5 string x LINK_NAME "%s"
  37. >>>&5 string x
  38. # look for gotolink or openlink keyword before help file name
  39. >>>&-18 search/18/s link\040
  40. # link construct with help name like: "gotolink xref.hlp:Overview" "openlink syntax1.hlp:firstpage"
  41. >>>>&-4 regex/s =^\[A-Za-z0-9.:\040]{1,} with "%s"
  42. # if not FrameMaker Help assume it is "normal" FrameMaker document
  43. # shown with closing parenthesis to get look like in frame,v 1.18
  44. >>18 default x \b)
  45. # sometimes without suffix like: CHAPTER HARVARD LETTER MEMO1 NEWSLTR REPORT3
  46. # no samples found with .bk or .book extension
  47. # allchaps.ix (Framemaker Index) and others like:
  48. # title.fm4 wp.filt textre1.htr pmscript.ind change.nbh books.prd executiv.sum Hyper.Template
  49. !:ext /fm/doc/toc/ix
  50. # URL: http://fileformats.archiveteam.org/wiki/Maker_Interchange_Format
  51. # Reference: https://help.adobe.com/en_US/framemaker/mifreference/mifref.pdf
  52. # Update: Joerg Jenderek 2019 Nov
  53. 0 string \<MIFFile FrameMaker MIF (ASCII) file
  54. # https://www.iana.org/assignments/media-types/application/vnd.mif
  55. !:mime application/vnd.mif
  56. # mif most but also find bookTOC.framemif
  57. !:ext mif/framemif
  58. # followed by space~20h
  59. #>8 ubyte 0x20 \b, space before version
  60. # 3 characters of version number of the MIF language like 1.0, 2.0 ... 2015 ...
  61. >9 string x (%.3s
  62. # if not greater sign then display 4th character of version
  63. >12 ubyte =0x3e \b)
  64. >12 ubyte !0x3e \b%c)
  65. # comment starting with # shows the name+version number of generating program
  66. >13 search/3 #
  67. >>&0 string x "%s"
  68. # Update: Joerg Jenderek
  69. # Note: called "Adobe FrameMaker document" by shared MIME-info database from freedesktop.org
  70. 0 search/1 \<MakerDictionary FrameMaker Dictionary text
  71. #!:mime text/plain
  72. #!:mime application/x-mif
  73. !:mime application/vnd.framemaker
  74. # like site.dict but often extension is a 3 letters country code like in: hyphens.brt hyphens.eng
  75. !:ext dict/eng/brt
  76. # Reference: http://mark0.net/download/triddefs_xml.7z/defs/f/fm-hyph-dict-30.trid.xml
  77. # Note: called "FrameMaker hyphens dictionary (v3.0)" by TrID
  78. >17 string 3.0 (3.0)
  79. # Reference: http://mark0.net/download/triddefs_xml.7z/defs/f/fm-hyph-dict-20.trid.xml
  80. # Note: called "FrameMaker hyphens dictionary (v2.0)" by TrID
  81. >17 string 2.0 (2.0)
  82. >17 string 1.0 (1.x)
  83. # Reference: http://mark0.net/download/triddefs_xml.7z/defs/b/bfont.trid.xml
  84. # Update: Joerg Jenderek 2023
  85. # Note: called "XFrameMaker Bitmapped screen Font" by TrID and
  86. # "Adobe FrameMaker font" by shared MIME-info database from freedesktop.org
  87. 0 string \<MakerScreenFont FrameMaker Font file
  88. #!:mime application/octet-stream
  89. #!:mime application/x-mif
  90. !:mime application/x-font-framemaker
  91. !:ext bfont
  92. # Note: maybe also other version like: 1.x
  93. >17 string !1.01
  94. >>17 string x (%-0.4s)
  95. >17 string 1.01 (%s)
  96. # Reference: http://mark0.net/download/triddefs_xml.7z/defs/m/mml-fm.trid.xml
  97. # Update: Joerg Jenderek 2023 Nov
  98. # Note: called "FrameMaker Maker Markup Language" by TrID and
  99. # "Adobe FrameMaker document" by shared MIME-info database from freedesktop.org
  100. 0 string \<MML FrameMaker MML file
  101. #!:mime text/plain
  102. #!:mime application/x-mif
  103. !:mime application/vnd.framemaker
  104. !:ext mml
  105. # Note: sometimes followed by space and version like 1.00 (formats.mml sample.mml) and more text
  106. >5 string >0 (%-0.4s)
  107. # URL: http://fileformats.archiveteam.org/wiki/FrameMaker
  108. # Reference: http://mark0.net/download/triddefs_xml.7z
  109. # defs/b/book-fm.trid.xml
  110. # defs/b/bk-fm.trid.xml
  111. # Update: Joerg Jenderek 2023 Dez
  112. # Note: called "FrameMaker book (binary)" by TrID and
  113. # "Adobe FrameMaker document" by shared MIME-info database from freedesktop.org
  114. # look for BookFile, Bookfile (capitalized) or BOOKFILE (upcased) directive
  115. 0 string/c \<Bookfile FrameMaker Book file
  116. #!:mime application/octet-stream
  117. #!:mime application/x-mif
  118. !:mime application/vnd.framemaker
  119. # http://extension.nirsoft.net/book
  120. !:ext bk/book
  121. # version like: 1.0 2.0 3.0 4.0 5.0 5.5 6.0 7.0 8.0 10.0
  122. # 3 characters of version number string
  123. >10 string x (%-0.3s
  124. # if greater sign then exact 3 byte version string
  125. >13 ubyte =0x3e \b)
  126. # if digit then 4 byte version string
  127. >13 ubyte <0x3A \b%c)
  128. # if letter then this is appended sub level after 3 byte version string
  129. >13 ubyte >0x3A %c)
  130. # first directive typically is followed by one space character
  131. >9 ubyte !0x20 \b, no space before version
  132. # XXX - this book entry should be verified, if you find one, uncomment this
  133. #0 string \<Book\040 FrameMaker Book (ASCII) file
  134. #!:mime application/x-mif
  135. #>6 string 3.0 (3.0)
  136. #>6 string 2.0 (2.0)
  137. #>6 string 1.0 (1.0)
  138. 0 string \<Maker\040Intermediate\040Print\040File FrameMaker IPL file
  139. !:mime application/x-mif