laag-nasm 2.13.03.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (455) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +57 -0
  3. data/LICENSE.txt +29 -0
  4. data/README.org +34 -0
  5. data/ext/laag/nasm/extconf.rb +16 -0
  6. data/laag-nasm.gemspec +20 -0
  7. data/lib/laag/nasm.rb +29 -0
  8. data/patches/Makefile.in.patch +13 -0
  9. data/vendor/repo.or.cz/nasm/.gitignore +102 -0
  10. data/vendor/repo.or.cz/nasm/AUTHORS +137 -0
  11. data/vendor/repo.or.cz/nasm/CHANGES +2 -0
  12. data/vendor/repo.or.cz/nasm/ChangeLog +2905 -0
  13. data/vendor/repo.or.cz/nasm/INSTALL +102 -0
  14. data/vendor/repo.or.cz/nasm/LICENSE +29 -0
  15. data/vendor/repo.or.cz/nasm/Makefile.in +855 -0
  16. data/vendor/repo.or.cz/nasm/Mkfiles/README +46 -0
  17. data/vendor/repo.or.cz/nasm/Mkfiles/msvc.mak +732 -0
  18. data/vendor/repo.or.cz/nasm/Mkfiles/openwcom.mak +706 -0
  19. data/vendor/repo.or.cz/nasm/README +23 -0
  20. data/vendor/repo.or.cz/nasm/SubmittingPatches +116 -0
  21. data/vendor/repo.or.cz/nasm/TODO +376 -0
  22. data/vendor/repo.or.cz/nasm/aclocal.m4 +139 -0
  23. data/vendor/repo.or.cz/nasm/asm/assemble.c +2957 -0
  24. data/vendor/repo.or.cz/nasm/asm/assemble.h +54 -0
  25. data/vendor/repo.or.cz/nasm/asm/directiv.c +566 -0
  26. data/vendor/repo.or.cz/nasm/asm/directiv.dat +92 -0
  27. data/vendor/repo.or.cz/nasm/asm/error.c +202 -0
  28. data/vendor/repo.or.cz/nasm/asm/eval.c +1014 -0
  29. data/vendor/repo.or.cz/nasm/asm/eval.h +49 -0
  30. data/vendor/repo.or.cz/nasm/asm/exprdump.c +79 -0
  31. data/vendor/repo.or.cz/nasm/asm/exprlib.c +200 -0
  32. data/vendor/repo.or.cz/nasm/asm/float.c +952 -0
  33. data/vendor/repo.or.cz/nasm/asm/float.h +54 -0
  34. data/vendor/repo.or.cz/nasm/asm/labels.c +540 -0
  35. data/vendor/repo.or.cz/nasm/asm/listing.c +346 -0
  36. data/vendor/repo.or.cz/nasm/asm/listing.h +113 -0
  37. data/vendor/repo.or.cz/nasm/asm/nasm.c +1855 -0
  38. data/vendor/repo.or.cz/nasm/asm/parser.c +1167 -0
  39. data/vendor/repo.or.cz/nasm/asm/parser.h +45 -0
  40. data/vendor/repo.or.cz/nasm/asm/phash.pl +109 -0
  41. data/vendor/repo.or.cz/nasm/asm/pptok.dat +96 -0
  42. data/vendor/repo.or.cz/nasm/asm/pptok.pl +271 -0
  43. data/vendor/repo.or.cz/nasm/asm/pragma.c +218 -0
  44. data/vendor/repo.or.cz/nasm/asm/preproc-nop.c +188 -0
  45. data/vendor/repo.or.cz/nasm/asm/preproc.c +5459 -0
  46. data/vendor/repo.or.cz/nasm/asm/preproc.h +55 -0
  47. data/vendor/repo.or.cz/nasm/asm/quote.c +479 -0
  48. data/vendor/repo.or.cz/nasm/asm/quote.h +44 -0
  49. data/vendor/repo.or.cz/nasm/asm/rdstrnum.c +68 -0
  50. data/vendor/repo.or.cz/nasm/asm/segalloc.c +51 -0
  51. data/vendor/repo.or.cz/nasm/asm/stdscan.c +345 -0
  52. data/vendor/repo.or.cz/nasm/asm/stdscan.h +49 -0
  53. data/vendor/repo.or.cz/nasm/asm/strfunc.c +359 -0
  54. data/vendor/repo.or.cz/nasm/asm/tokens.dat +135 -0
  55. data/vendor/repo.or.cz/nasm/asm/tokhash.pl +284 -0
  56. data/vendor/repo.or.cz/nasm/autogen.sh +9 -0
  57. data/vendor/repo.or.cz/nasm/common/common.c +122 -0
  58. data/vendor/repo.or.cz/nasm/config/msvc.h +192 -0
  59. data/vendor/repo.or.cz/nasm/config/unknown.h +51 -0
  60. data/vendor/repo.or.cz/nasm/config/watcom.h +74 -0
  61. data/vendor/repo.or.cz/nasm/configure.ac +253 -0
  62. data/vendor/repo.or.cz/nasm/contrib/MSVC6.txt +25 -0
  63. data/vendor/repo.or.cz/nasm/contrib/VSrules/nasm.README +16 -0
  64. data/vendor/repo.or.cz/nasm/contrib/VSrules/nasm.rules +79 -0
  65. data/vendor/repo.or.cz/nasm/disasm/disasm.c +1735 -0
  66. data/vendor/repo.or.cz/nasm/disasm/disasm.h +49 -0
  67. data/vendor/repo.or.cz/nasm/disasm/ndisasm.c +397 -0
  68. data/vendor/repo.or.cz/nasm/disasm/sync.c +132 -0
  69. data/vendor/repo.or.cz/nasm/disasm/sync.h +45 -0
  70. data/vendor/repo.or.cz/nasm/doc/Makefile.in +86 -0
  71. data/vendor/repo.or.cz/nasm/doc/README +20 -0
  72. data/vendor/repo.or.cz/nasm/doc/afmmetrics.ph +102 -0
  73. data/vendor/repo.or.cz/nasm/doc/changes.src +2588 -0
  74. data/vendor/repo.or.cz/nasm/doc/findfont.ph +180 -0
  75. data/vendor/repo.or.cz/nasm/doc/genps.pl +1294 -0
  76. data/vendor/repo.or.cz/nasm/doc/inslist.pl +108 -0
  77. data/vendor/repo.or.cz/nasm/doc/internal.doc +290 -0
  78. data/vendor/repo.or.cz/nasm/doc/local.css +1 -0
  79. data/vendor/repo.or.cz/nasm/doc/nasmdoc.css +150 -0
  80. data/vendor/repo.or.cz/nasm/doc/nasmdoc.src +8309 -0
  81. data/vendor/repo.or.cz/nasm/doc/nasmlogo.eps +212 -0
  82. data/vendor/repo.or.cz/nasm/doc/nasmlogw.png +0 -0
  83. data/vendor/repo.or.cz/nasm/doc/psfonts.ph +53 -0
  84. data/vendor/repo.or.cz/nasm/doc/pspdf.pl +98 -0
  85. data/vendor/repo.or.cz/nasm/doc/pswidth.ph +25 -0
  86. data/vendor/repo.or.cz/nasm/doc/rdsrc.pl +1111 -0
  87. data/vendor/repo.or.cz/nasm/doc/ttfmetrics.ph +63 -0
  88. data/vendor/repo.or.cz/nasm/headers/c +33 -0
  89. data/vendor/repo.or.cz/nasm/headers/doc +33 -0
  90. data/vendor/repo.or.cz/nasm/headers/mac +33 -0
  91. data/vendor/repo.or.cz/nasm/headers/perl +33 -0
  92. data/vendor/repo.or.cz/nasm/include/compiler.h +277 -0
  93. data/vendor/repo.or.cz/nasm/include/disp8.h +45 -0
  94. data/vendor/repo.or.cz/nasm/include/error.h +135 -0
  95. data/vendor/repo.or.cz/nasm/include/hashtbl.h +85 -0
  96. data/vendor/repo.or.cz/nasm/include/iflag.h +173 -0
  97. data/vendor/repo.or.cz/nasm/include/insns.h +76 -0
  98. data/vendor/repo.or.cz/nasm/include/labels.h +60 -0
  99. data/vendor/repo.or.cz/nasm/include/md5.h +21 -0
  100. data/vendor/repo.or.cz/nasm/include/nasm.h +1246 -0
  101. data/vendor/repo.or.cz/nasm/include/nasmint.h +219 -0
  102. data/vendor/repo.or.cz/nasm/include/nasmlib.h +524 -0
  103. data/vendor/repo.or.cz/nasm/include/opflags.h +271 -0
  104. data/vendor/repo.or.cz/nasm/include/perfhash.h +52 -0
  105. data/vendor/repo.or.cz/nasm/include/raa.h +46 -0
  106. data/vendor/repo.or.cz/nasm/include/rbtree.h +51 -0
  107. data/vendor/repo.or.cz/nasm/include/rdoff.h +169 -0
  108. data/vendor/repo.or.cz/nasm/include/saa.h +94 -0
  109. data/vendor/repo.or.cz/nasm/include/strlist.h +55 -0
  110. data/vendor/repo.or.cz/nasm/include/tables.h +70 -0
  111. data/vendor/repo.or.cz/nasm/include/ver.h +47 -0
  112. data/vendor/repo.or.cz/nasm/install-sh +250 -0
  113. data/vendor/repo.or.cz/nasm/macros/altreg.mac +107 -0
  114. data/vendor/repo.or.cz/nasm/macros/fp.mac +54 -0
  115. data/vendor/repo.or.cz/nasm/macros/ifunc.mac +48 -0
  116. data/vendor/repo.or.cz/nasm/macros/macros.pl +294 -0
  117. data/vendor/repo.or.cz/nasm/macros/smartalign.mac +189 -0
  118. data/vendor/repo.or.cz/nasm/macros/standard.mac +226 -0
  119. data/vendor/repo.or.cz/nasm/misc/Doxyfile +752 -0
  120. data/vendor/repo.or.cz/nasm/misc/Nindent +18 -0
  121. data/vendor/repo.or.cz/nasm/misc/README +2 -0
  122. data/vendor/repo.or.cz/nasm/misc/c16.mac +82 -0
  123. data/vendor/repo.or.cz/nasm/misc/c32.mac +52 -0
  124. data/vendor/repo.or.cz/nasm/misc/crcgen.c +44 -0
  125. data/vendor/repo.or.cz/nasm/misc/exebin.mac +57 -0
  126. data/vendor/repo.or.cz/nasm/misc/exebin2.mac +114 -0
  127. data/vendor/repo.or.cz/nasm/misc/fmtinsns.pl +40 -0
  128. data/vendor/repo.or.cz/nasm/misc/genfma.pl +63 -0
  129. data/vendor/repo.or.cz/nasm/misc/hints.txt +26 -0
  130. data/vendor/repo.or.cz/nasm/misc/magic +6 -0
  131. data/vendor/repo.or.cz/nasm/misc/myC32.mac +121 -0
  132. data/vendor/repo.or.cz/nasm/misc/nasm.sl +320 -0
  133. data/vendor/repo.or.cz/nasm/misc/nasmstab +296 -0
  134. data/vendor/repo.or.cz/nasm/misc/omfdump.c +517 -0
  135. data/vendor/repo.or.cz/nasm/misc/pmw.bat +9 -0
  136. data/vendor/repo.or.cz/nasm/misc/proc32.ash +441 -0
  137. data/vendor/repo.or.cz/nasm/misc/scitech.mac +1223 -0
  138. data/vendor/repo.or.cz/nasm/misc/xcrcgen.c +80 -0
  139. data/vendor/repo.or.cz/nasm/nasm.spec.in +83 -0
  140. data/vendor/repo.or.cz/nasm/nasm.spec.sed +3 -0
  141. data/vendor/repo.or.cz/nasm/nasm.txt +306 -0
  142. data/vendor/repo.or.cz/nasm/nasmlib/badenum.c +43 -0
  143. data/vendor/repo.or.cz/nasm/nasmlib/bsi.c +77 -0
  144. data/vendor/repo.or.cz/nasm/nasmlib/crc64.c +189 -0
  145. data/vendor/repo.or.cz/nasm/nasmlib/file.c +259 -0
  146. data/vendor/repo.or.cz/nasm/nasmlib/file.h +128 -0
  147. data/vendor/repo.or.cz/nasm/nasmlib/filename.c +69 -0
  148. data/vendor/repo.or.cz/nasm/nasmlib/hashtbl.c +232 -0
  149. data/vendor/repo.or.cz/nasm/nasmlib/ilog2.c +168 -0
  150. data/vendor/repo.or.cz/nasm/nasmlib/malloc.c +108 -0
  151. data/vendor/repo.or.cz/nasm/nasmlib/md5c.c +247 -0
  152. data/vendor/repo.or.cz/nasm/nasmlib/mmap.c +139 -0
  153. data/vendor/repo.or.cz/nasm/nasmlib/path.c +186 -0
  154. data/vendor/repo.or.cz/nasm/nasmlib/perfhash.c +55 -0
  155. data/vendor/repo.or.cz/nasm/nasmlib/perfhash.pl +362 -0
  156. data/vendor/repo.or.cz/nasm/nasmlib/raa.c +173 -0
  157. data/vendor/repo.or.cz/nasm/nasmlib/rbtree.c +119 -0
  158. data/vendor/repo.or.cz/nasm/nasmlib/readnum.c +172 -0
  159. data/vendor/repo.or.cz/nasm/nasmlib/realpath.c +135 -0
  160. data/vendor/repo.or.cz/nasm/nasmlib/saa.c +431 -0
  161. data/vendor/repo.or.cz/nasm/nasmlib/srcfile.c +128 -0
  162. data/vendor/repo.or.cz/nasm/nasmlib/string.c +242 -0
  163. data/vendor/repo.or.cz/nasm/nasmlib/strlist.c +100 -0
  164. data/vendor/repo.or.cz/nasm/nasmlib/ver.c +51 -0
  165. data/vendor/repo.or.cz/nasm/nasmlib/zerobuf.c +42 -0
  166. data/vendor/repo.or.cz/nasm/ndisasm.txt +94 -0
  167. data/vendor/repo.or.cz/nasm/nsis/NASMMultiUser.nsh +478 -0
  168. data/vendor/repo.or.cz/nasm/nsis/getpearch.pl +76 -0
  169. data/vendor/repo.or.cz/nasm/nsis/nasm-un.ico +0 -0
  170. data/vendor/repo.or.cz/nasm/nsis/nasm.ico +0 -0
  171. data/vendor/repo.or.cz/nasm/nsis/nasm.nsi +241 -0
  172. data/vendor/repo.or.cz/nasm/output/codeview.c +814 -0
  173. data/vendor/repo.or.cz/nasm/output/dwarf.h +566 -0
  174. data/vendor/repo.or.cz/nasm/output/elf.h +537 -0
  175. data/vendor/repo.or.cz/nasm/output/legacy.c +112 -0
  176. data/vendor/repo.or.cz/nasm/output/nulldbg.c +93 -0
  177. data/vendor/repo.or.cz/nasm/output/nullout.c +51 -0
  178. data/vendor/repo.or.cz/nasm/output/outaout.c +954 -0
  179. data/vendor/repo.or.cz/nasm/output/outaout.mac +37 -0
  180. data/vendor/repo.or.cz/nasm/output/outas86.c +650 -0
  181. data/vendor/repo.or.cz/nasm/output/outas86.mac +37 -0
  182. data/vendor/repo.or.cz/nasm/output/outbin.c +1713 -0
  183. data/vendor/repo.or.cz/nasm/output/outbin.mac +40 -0
  184. data/vendor/repo.or.cz/nasm/output/outcoff.c +1242 -0
  185. data/vendor/repo.or.cz/nasm/output/outcoff.mac +43 -0
  186. data/vendor/repo.or.cz/nasm/output/outdbg.c +425 -0
  187. data/vendor/repo.or.cz/nasm/output/outelf.c +3370 -0
  188. data/vendor/repo.or.cz/nasm/output/outelf.h +156 -0
  189. data/vendor/repo.or.cz/nasm/output/outelf.mac +41 -0
  190. data/vendor/repo.or.cz/nasm/output/outform.c +120 -0
  191. data/vendor/repo.or.cz/nasm/output/outform.h +379 -0
  192. data/vendor/repo.or.cz/nasm/output/outieee.c +1528 -0
  193. data/vendor/repo.or.cz/nasm/output/outlib.c +58 -0
  194. data/vendor/repo.or.cz/nasm/output/outlib.h +63 -0
  195. data/vendor/repo.or.cz/nasm/output/outmacho.c +2387 -0
  196. data/vendor/repo.or.cz/nasm/output/outmacho.mac +49 -0
  197. data/vendor/repo.or.cz/nasm/output/outobj.c +2725 -0
  198. data/vendor/repo.or.cz/nasm/output/outobj.mac +49 -0
  199. data/vendor/repo.or.cz/nasm/output/outrdf.mac +40 -0
  200. data/vendor/repo.or.cz/nasm/output/outrdf2.c +791 -0
  201. data/vendor/repo.or.cz/nasm/output/outrdf2.mac +43 -0
  202. data/vendor/repo.or.cz/nasm/output/pecoff.h +532 -0
  203. data/vendor/repo.or.cz/nasm/output/stabs.h +144 -0
  204. data/vendor/repo.or.cz/nasm/perllib/crc64.ph +158 -0
  205. data/vendor/repo.or.cz/nasm/perllib/gensv.pl +34 -0
  206. data/vendor/repo.or.cz/nasm/perllib/phash.ph +200 -0
  207. data/vendor/repo.or.cz/nasm/perllib/random_sv_vectors.ph +67 -0
  208. data/vendor/repo.or.cz/nasm/rdoff/README +185 -0
  209. data/vendor/repo.or.cz/nasm/rdoff/collectn.c +44 -0
  210. data/vendor/repo.or.cz/nasm/rdoff/collectn.h +22 -0
  211. data/vendor/repo.or.cz/nasm/rdoff/doc/Makefile +37 -0
  212. data/vendor/repo.or.cz/nasm/rdoff/doc/rdoff.texi +137 -0
  213. data/vendor/repo.or.cz/nasm/rdoff/doc/v1-v2.txt +62 -0
  214. data/vendor/repo.or.cz/nasm/rdoff/hash.c +122 -0
  215. data/vendor/repo.or.cz/nasm/rdoff/hash.h +17 -0
  216. data/vendor/repo.or.cz/nasm/rdoff/ldrdf.1 +41 -0
  217. data/vendor/repo.or.cz/nasm/rdoff/ldrdf.c +1395 -0
  218. data/vendor/repo.or.cz/nasm/rdoff/ldsegs.h +59 -0
  219. data/vendor/repo.or.cz/nasm/rdoff/rdf2bin.1 +65 -0
  220. data/vendor/repo.or.cz/nasm/rdoff/rdf2bin.c +431 -0
  221. data/vendor/repo.or.cz/nasm/rdoff/rdf2com.1 +1 -0
  222. data/vendor/repo.or.cz/nasm/rdoff/rdf2ihx.1 +1 -0
  223. data/vendor/repo.or.cz/nasm/rdoff/rdf2ith.1 +1 -0
  224. data/vendor/repo.or.cz/nasm/rdoff/rdf2srec.1 +1 -0
  225. data/vendor/repo.or.cz/nasm/rdoff/rdfdump.1 +24 -0
  226. data/vendor/repo.or.cz/nasm/rdoff/rdfdump.c +347 -0
  227. data/vendor/repo.or.cz/nasm/rdoff/rdflib.1 +39 -0
  228. data/vendor/repo.or.cz/nasm/rdoff/rdflib.c +434 -0
  229. data/vendor/repo.or.cz/nasm/rdoff/rdfload.c +213 -0
  230. data/vendor/repo.or.cz/nasm/rdoff/rdfload.h +29 -0
  231. data/vendor/repo.or.cz/nasm/rdoff/rdfutils.h +165 -0
  232. data/vendor/repo.or.cz/nasm/rdoff/rdlar.c +492 -0
  233. data/vendor/repo.or.cz/nasm/rdoff/rdlar.h +34 -0
  234. data/vendor/repo.or.cz/nasm/rdoff/rdlib.c +290 -0
  235. data/vendor/repo.or.cz/nasm/rdoff/rdlib.h +62 -0
  236. data/vendor/repo.or.cz/nasm/rdoff/rdoff.c +621 -0
  237. data/vendor/repo.or.cz/nasm/rdoff/rdx.1 +21 -0
  238. data/vendor/repo.or.cz/nasm/rdoff/rdx.c +90 -0
  239. data/vendor/repo.or.cz/nasm/rdoff/segtab.c +172 -0
  240. data/vendor/repo.or.cz/nasm/rdoff/segtab.h +45 -0
  241. data/vendor/repo.or.cz/nasm/rdoff/symtab.c +159 -0
  242. data/vendor/repo.or.cz/nasm/rdoff/symtab.h +55 -0
  243. data/vendor/repo.or.cz/nasm/rdoff/test/Makefile +10 -0
  244. data/vendor/repo.or.cz/nasm/rdoff/test/makelib.sh +14 -0
  245. data/vendor/repo.or.cz/nasm/rdoff/test/rdfseg.asm +20 -0
  246. data/vendor/repo.or.cz/nasm/rdoff/test/rdfseg2.asm +12 -0
  247. data/vendor/repo.or.cz/nasm/rdoff/test/rdftest1.asm +54 -0
  248. data/vendor/repo.or.cz/nasm/rdoff/test/rdftest2.asm +33 -0
  249. data/vendor/repo.or.cz/nasm/rdoff/test/rdtlib.asm +48 -0
  250. data/vendor/repo.or.cz/nasm/rdoff/test/rdtmain.asm +47 -0
  251. data/vendor/repo.or.cz/nasm/rdoff/test/testlib.asm +18 -0
  252. data/vendor/repo.or.cz/nasm/stdlib/snprintf.c +29 -0
  253. data/vendor/repo.or.cz/nasm/stdlib/strlcpy.c +51 -0
  254. data/vendor/repo.or.cz/nasm/stdlib/strnlen.c +46 -0
  255. data/vendor/repo.or.cz/nasm/stdlib/vsnprintf.c +51 -0
  256. data/vendor/repo.or.cz/nasm/test/Makefile +106 -0
  257. data/vendor/repo.or.cz/nasm/test/_file_.asm +5 -0
  258. data/vendor/repo.or.cz/nasm/test/_version.asm +2 -0
  259. data/vendor/repo.or.cz/nasm/test/a32offs.asm +9 -0
  260. data/vendor/repo.or.cz/nasm/test/absolute.asm +40 -0
  261. data/vendor/repo.or.cz/nasm/test/addr64x.asm +18 -0
  262. data/vendor/repo.or.cz/nasm/test/align13.asm +19 -0
  263. data/vendor/repo.or.cz/nasm/test/align13s.asm +20 -0
  264. data/vendor/repo.or.cz/nasm/test/alonesym-obj.asm +166 -0
  265. data/vendor/repo.or.cz/nasm/test/andbyte.asm +15 -0
  266. data/vendor/repo.or.cz/nasm/test/aoutso.asm +99 -0
  267. data/vendor/repo.or.cz/nasm/test/aouttest.asm +86 -0
  268. data/vendor/repo.or.cz/nasm/test/aouttest.c +36 -0
  269. data/vendor/repo.or.cz/nasm/test/avx.asm +46 -0
  270. data/vendor/repo.or.cz/nasm/test/avx005.asm +529 -0
  271. data/vendor/repo.or.cz/nasm/test/avx2.asm +1608 -0
  272. data/vendor/repo.or.cz/nasm/test/avx512cd.asm +106 -0
  273. data/vendor/repo.or.cz/nasm/test/avx512er.asm +144 -0
  274. data/vendor/repo.or.cz/nasm/test/avx512f.asm +7000 -0
  275. data/vendor/repo.or.cz/nasm/test/avx512pf.asm +88 -0
  276. data/vendor/repo.or.cz/nasm/test/bcd.asm +23 -0
  277. data/vendor/repo.or.cz/nasm/test/binexe.asm +35 -0
  278. data/vendor/repo.or.cz/nasm/test/bintest.asm +59 -0
  279. data/vendor/repo.or.cz/nasm/test/bisect.sh +22 -0
  280. data/vendor/repo.or.cz/nasm/test/br1879590.asm +25 -0
  281. data/vendor/repo.or.cz/nasm/test/br2003451.asm +17 -0
  282. data/vendor/repo.or.cz/nasm/test/br2030823.asm +7 -0
  283. data/vendor/repo.or.cz/nasm/test/br2148476.asm +221 -0
  284. data/vendor/repo.or.cz/nasm/test/br2222615.asm +19 -0
  285. data/vendor/repo.or.cz/nasm/test/br2496848.asm +42 -0
  286. data/vendor/repo.or.cz/nasm/test/br3005117.asm +26 -0
  287. data/vendor/repo.or.cz/nasm/test/br3026808.asm +20 -0
  288. data/vendor/repo.or.cz/nasm/test/br3028880.asm +8 -0
  289. data/vendor/repo.or.cz/nasm/test/br3041451.asm +59 -0
  290. data/vendor/repo.or.cz/nasm/test/br3058845.asm +14 -0
  291. data/vendor/repo.or.cz/nasm/test/br3066383.asm +70 -0
  292. data/vendor/repo.or.cz/nasm/test/br3074517.asm +12 -0
  293. data/vendor/repo.or.cz/nasm/test/br3092924.asm +25 -0
  294. data/vendor/repo.or.cz/nasm/test/br3104312.asm +11 -0
  295. data/vendor/repo.or.cz/nasm/test/br3109604.asm +9 -0
  296. data/vendor/repo.or.cz/nasm/test/br3174983.asm +9 -0
  297. data/vendor/repo.or.cz/nasm/test/br3187743.asm +7 -0
  298. data/vendor/repo.or.cz/nasm/test/br3189064.asm +7 -0
  299. data/vendor/repo.or.cz/nasm/test/br3200749.asm +9 -0
  300. data/vendor/repo.or.cz/nasm/test/br3385573.asm +11 -0
  301. data/vendor/repo.or.cz/nasm/test/br3392252.asm +43 -0
  302. data/vendor/repo.or.cz/nasm/test/br3392259.asm +8 -0
  303. data/vendor/repo.or.cz/nasm/test/br3392363.asm +4 -0
  304. data/vendor/repo.or.cz/nasm/test/br3392392.asm +16 -0
  305. data/vendor/repo.or.cz/nasm/test/br3392396.asm +5 -0
  306. data/vendor/repo.or.cz/nasm/test/br3392411.asm +22 -0
  307. data/vendor/repo.or.cz/nasm/test/br3392418.asm +3 -0
  308. data/vendor/repo.or.cz/nasm/test/br3392439.asm +25 -0
  309. data/vendor/repo.or.cz/nasm/test/br3392442.asm +6 -0
  310. data/vendor/repo.or.cz/nasm/test/br560575.asm +17 -0
  311. data/vendor/repo.or.cz/nasm/test/br560873.asm +27 -0
  312. data/vendor/repo.or.cz/nasm/test/br890790.asm +7 -0
  313. data/vendor/repo.or.cz/nasm/test/br890790_i.asm +1 -0
  314. data/vendor/repo.or.cz/nasm/test/br978756.asm +7 -0
  315. data/vendor/repo.or.cz/nasm/test/changed.asm +383 -0
  316. data/vendor/repo.or.cz/nasm/test/cofftest.asm +85 -0
  317. data/vendor/repo.or.cz/nasm/test/cofftest.c +35 -0
  318. data/vendor/repo.or.cz/nasm/test/crc32.asm +37 -0
  319. data/vendor/repo.or.cz/nasm/test/cv8struc.asm +14 -0
  320. data/vendor/repo.or.cz/nasm/test/dtbcd.asm +72 -0
  321. data/vendor/repo.or.cz/nasm/test/elf64so.asm +118 -0
  322. data/vendor/repo.or.cz/nasm/test/elfso.asm +100 -0
  323. data/vendor/repo.or.cz/nasm/test/elftest.asm +87 -0
  324. data/vendor/repo.or.cz/nasm/test/elftest.c +38 -0
  325. data/vendor/repo.or.cz/nasm/test/elftest64.c +43 -0
  326. data/vendor/repo.or.cz/nasm/test/elif.asm +39 -0
  327. data/vendor/repo.or.cz/nasm/test/expimp.asm +90 -0
  328. data/vendor/repo.or.cz/nasm/test/far64.asm +10 -0
  329. data/vendor/repo.or.cz/nasm/test/float.asm +186 -0
  330. data/vendor/repo.or.cz/nasm/test/float8.asm +135 -0
  331. data/vendor/repo.or.cz/nasm/test/floatb.asm +35 -0
  332. data/vendor/repo.or.cz/nasm/test/floatexp.asm +382 -0
  333. data/vendor/repo.or.cz/nasm/test/floatize.asm +19 -0
  334. data/vendor/repo.or.cz/nasm/test/floattest.asm +28 -0
  335. data/vendor/repo.or.cz/nasm/test/floatx.asm +525 -0
  336. data/vendor/repo.or.cz/nasm/test/fpu.asm +127 -0
  337. data/vendor/repo.or.cz/nasm/test/fwdopt.asm +133 -0
  338. data/vendor/repo.or.cz/nasm/test/fwdoptpp.asm +150 -0
  339. data/vendor/repo.or.cz/nasm/test/gas2nasm.py +104 -0
  340. data/vendor/repo.or.cz/nasm/test/gather.asm +11 -0
  341. data/vendor/repo.or.cz/nasm/test/gotoff64.asm +25 -0
  342. data/vendor/repo.or.cz/nasm/test/hexfp.asm +25 -0
  343. data/vendor/repo.or.cz/nasm/test/hle.asm +19 -0
  344. data/vendor/repo.or.cz/nasm/test/ifelse.asm +46 -0
  345. data/vendor/repo.or.cz/nasm/test/ifenv.asm +31 -0
  346. data/vendor/repo.or.cz/nasm/test/ifmacro.asm +413 -0
  347. data/vendor/repo.or.cz/nasm/test/iftoken.asm +317 -0
  348. data/vendor/repo.or.cz/nasm/test/iftoken.pl +32 -0
  349. data/vendor/repo.or.cz/nasm/test/ilog2.asm +271 -0
  350. data/vendor/repo.or.cz/nasm/test/imacro.asm +8 -0
  351. data/vendor/repo.or.cz/nasm/test/imm.asm +23 -0
  352. data/vendor/repo.or.cz/nasm/test/imm64.asm +61 -0
  353. data/vendor/repo.or.cz/nasm/test/immwarn.asm +91 -0
  354. data/vendor/repo.or.cz/nasm/test/imul.asm +117 -0
  355. data/vendor/repo.or.cz/nasm/test/inc1.asm +6 -0
  356. data/vendor/repo.or.cz/nasm/test/inc2.asm +8 -0
  357. data/vendor/repo.or.cz/nasm/test/incbin.asm +7 -0
  358. data/vendor/repo.or.cz/nasm/test/incbin.data +2 -0
  359. data/vendor/repo.or.cz/nasm/test/inctest.asm +15 -0
  360. data/vendor/repo.or.cz/nasm/test/insnlbl.asm +12 -0
  361. data/vendor/repo.or.cz/nasm/test/invlpga.asm +11 -0
  362. data/vendor/repo.or.cz/nasm/test/jmp64.asm +19 -0
  363. data/vendor/repo.or.cz/nasm/test/lar_lsl.asm +124 -0
  364. data/vendor/repo.or.cz/nasm/test/larlsl.asm +23 -0
  365. data/vendor/repo.or.cz/nasm/test/lnxhello.asm +54 -0
  366. data/vendor/repo.or.cz/nasm/test/local.asm +19 -0
  367. data/vendor/repo.or.cz/nasm/test/loopoffs.asm +12 -0
  368. data/vendor/repo.or.cz/nasm/test/lwp.asm +213 -0
  369. data/vendor/repo.or.cz/nasm/test/macro-defaults.asm +64 -0
  370. data/vendor/repo.or.cz/nasm/test/macroerr.asm +12 -0
  371. data/vendor/repo.or.cz/nasm/test/macroerr.inc +3 -0
  372. data/vendor/repo.or.cz/nasm/test/mmxsize.asm +38 -0
  373. data/vendor/repo.or.cz/nasm/test/movd.asm +12 -0
  374. data/vendor/repo.or.cz/nasm/test/movd64.asm +15 -0
  375. data/vendor/repo.or.cz/nasm/test/movimm.asm +28 -0
  376. data/vendor/repo.or.cz/nasm/test/movnti.asm +10 -0
  377. data/vendor/repo.or.cz/nasm/test/mpx-64.asm +120 -0
  378. data/vendor/repo.or.cz/nasm/test/mpx.asm +89 -0
  379. data/vendor/repo.or.cz/nasm/test/multisection.asm +96 -0
  380. data/vendor/repo.or.cz/nasm/test/nasmformat.asm +17 -0
  381. data/vendor/repo.or.cz/nasm/test/new +9 -0
  382. data/vendor/repo.or.cz/nasm/test/newrdwr.asm +24 -0
  383. data/vendor/repo.or.cz/nasm/test/nop.asm +17 -0
  384. data/vendor/repo.or.cz/nasm/test/nullfile.asm +4 -0
  385. data/vendor/repo.or.cz/nasm/test/objexe.asm +30 -0
  386. data/vendor/repo.or.cz/nasm/test/objlink.c +33 -0
  387. data/vendor/repo.or.cz/nasm/test/objtest.asm +85 -0
  388. data/vendor/repo.or.cz/nasm/test/optimization.asm +104 -0
  389. data/vendor/repo.or.cz/nasm/test/org.asm +18 -0
  390. data/vendor/repo.or.cz/nasm/test/paste.asm +12 -0
  391. data/vendor/repo.or.cz/nasm/test/pcrel.asm +52 -0
  392. data/vendor/repo.or.cz/nasm/test/perf/label.pl +18 -0
  393. data/vendor/repo.or.cz/nasm/test/perf/macro.pl +18 -0
  394. data/vendor/repo.or.cz/nasm/test/perf/token.pl +23 -0
  395. data/vendor/repo.or.cz/nasm/test/performtest.pl +192 -0
  396. data/vendor/repo.or.cz/nasm/test/pextrw.asm +3 -0
  397. data/vendor/repo.or.cz/nasm/test/pinsr16.asm +53 -0
  398. data/vendor/repo.or.cz/nasm/test/pinsr32.asm +53 -0
  399. data/vendor/repo.or.cz/nasm/test/pinsr64.asm +68 -0
  400. data/vendor/repo.or.cz/nasm/test/popcnt.asm +32 -0
  401. data/vendor/repo.or.cz/nasm/test/ppindirect.asm +42 -0
  402. data/vendor/repo.or.cz/nasm/test/pragma.asm +12 -0
  403. data/vendor/repo.or.cz/nasm/test/prefix66.asm +28 -0
  404. data/vendor/repo.or.cz/nasm/test/ptr.asm +4 -0
  405. data/vendor/repo.or.cz/nasm/test/pushseg.asm +17 -0
  406. data/vendor/repo.or.cz/nasm/test/r13.asm +15 -0
  407. data/vendor/repo.or.cz/nasm/test/radix.asm +54 -0
  408. data/vendor/repo.or.cz/nasm/test/rdpid.asm +21 -0
  409. data/vendor/repo.or.cz/nasm/test/reldef.asm +57 -0
  410. data/vendor/repo.or.cz/nasm/test/relocs.asm +20 -0
  411. data/vendor/repo.or.cz/nasm/test/riprel.asm +5357 -0
  412. data/vendor/repo.or.cz/nasm/test/riprel.pl +29 -0
  413. data/vendor/repo.or.cz/nasm/test/riprel2.asm +11 -0
  414. data/vendor/repo.or.cz/nasm/test/sha-64.asm +30 -0
  415. data/vendor/repo.or.cz/nasm/test/sha.asm +31 -0
  416. data/vendor/repo.or.cz/nasm/test/smartalign16.asm +36 -0
  417. data/vendor/repo.or.cz/nasm/test/smartalign32.asm +36 -0
  418. data/vendor/repo.or.cz/nasm/test/smartalign64.asm +36 -0
  419. data/vendor/repo.or.cz/nasm/test/splitea.asm +11 -0
  420. data/vendor/repo.or.cz/nasm/test/sreg.asm +65 -0
  421. data/vendor/repo.or.cz/nasm/test/strlen.asm +5 -0
  422. data/vendor/repo.or.cz/nasm/test/struc.asm +33 -0
  423. data/vendor/repo.or.cz/nasm/test/test67.asm +38 -0
  424. data/vendor/repo.or.cz/nasm/test/testdos.asm +13 -0
  425. data/vendor/repo.or.cz/nasm/test/testnos3.asm +973 -0
  426. data/vendor/repo.or.cz/nasm/test/time.asm +11 -0
  427. data/vendor/repo.or.cz/nasm/test/times.asm +21 -0
  428. data/vendor/repo.or.cz/nasm/test/timesneg.asm +3 -0
  429. data/vendor/repo.or.cz/nasm/test/tmap.nas +1447 -0
  430. data/vendor/repo.or.cz/nasm/test/uscore.asm +15 -0
  431. data/vendor/repo.or.cz/nasm/test/utf.asm +82 -0
  432. data/vendor/repo.or.cz/nasm/test/vaesenc.asm +22 -0
  433. data/vendor/repo.or.cz/nasm/test/vex.asm +9 -0
  434. data/vendor/repo.or.cz/nasm/test/vgather.asm +76 -0
  435. data/vendor/repo.or.cz/nasm/test/vmread.asm +26 -0
  436. data/vendor/repo.or.cz/nasm/test/weirdpaste.asm +29 -0
  437. data/vendor/repo.or.cz/nasm/test/xchg.asm +96 -0
  438. data/vendor/repo.or.cz/nasm/test/xcrypt.asm +24 -0
  439. data/vendor/repo.or.cz/nasm/test/xmm0.asm +12 -0
  440. data/vendor/repo.or.cz/nasm/test/zerobyte.asm +22 -0
  441. data/vendor/repo.or.cz/nasm/tools/cleanfile +176 -0
  442. data/vendor/repo.or.cz/nasm/tools/cleanpatch +258 -0
  443. data/vendor/repo.or.cz/nasm/tools/mkdep.pl +261 -0
  444. data/vendor/repo.or.cz/nasm/tools/release +105 -0
  445. data/vendor/repo.or.cz/nasm/tools/syncfiles.pl +137 -0
  446. data/vendor/repo.or.cz/nasm/tools/tag-release +58 -0
  447. data/vendor/repo.or.cz/nasm/version +1 -0
  448. data/vendor/repo.or.cz/nasm/version.pl +189 -0
  449. data/vendor/repo.or.cz/nasm/x86/disp8.c +131 -0
  450. data/vendor/repo.or.cz/nasm/x86/insns-iflags.ph +280 -0
  451. data/vendor/repo.or.cz/nasm/x86/insns.dat +5371 -0
  452. data/vendor/repo.or.cz/nasm/x86/insns.pl +1043 -0
  453. data/vendor/repo.or.cz/nasm/x86/regs.dat +138 -0
  454. data/vendor/repo.or.cz/nasm/x86/regs.pl +204 -0
  455. metadata +520 -0
@@ -0,0 +1,189 @@
1
+ ;; --------------------------------------------------------------------------
2
+ ;;
3
+ ;; Copyright 1996-2017 The NASM Authors - All Rights Reserved
4
+ ;; See the file AUTHORS included with the NASM distribution for
5
+ ;; the specific copyright holders.
6
+ ;;
7
+ ;; Redistribution and use in source and binary forms, with or without
8
+ ;; modification, are permitted provided that the following
9
+ ;; conditions are met:
10
+ ;;
11
+ ;; * Redistributions of source code must retain the above copyright
12
+ ;; notice, this list of conditions and the following disclaimer.
13
+ ;; * Redistributions in binary form must reproduce the above
14
+ ;; copyright notice, this list of conditions and the following
15
+ ;; disclaimer in the documentation and/or other materials provided
16
+ ;; with the distribution.
17
+ ;;
18
+ ;; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19
+ ;; CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20
+ ;; INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21
+ ;; MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22
+ ;; DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
23
+ ;; CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24
+ ;; SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25
+ ;; NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26
+ ;; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27
+ ;; HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28
+ ;; CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29
+ ;; OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30
+ ;; EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
+ ;;
32
+ ;; --------------------------------------------------------------------------
33
+
34
+ ;
35
+ ; Smart alignment macros
36
+ ;
37
+ USE: smartalign
38
+
39
+ %imacro alignmode 1-2.nolist
40
+ %ifidni %1,nop
41
+ %define __ALIGN_JMP_THRESHOLD__ 16
42
+
43
+ %define __ALIGN_16BIT_1B__ 0x90
44
+ %define __ALIGN_16BIT_GROUP__ 1
45
+
46
+ %define __ALIGN_32BIT_1B__ 0x90
47
+ %define __ALIGN_32BIT_GROUP__ 1
48
+
49
+ %define __ALIGN_64BIT_1B__ 0x90
50
+ %define __ALIGN_64BIT_GROUP__ 1
51
+ %elifidni %1,generic
52
+ %define __ALIGN_JMP_THRESHOLD__ 8
53
+
54
+ %define __ALIGN_16BIT_1B__ 0x90
55
+ %define __ALIGN_16BIT_2B__ 0x89,0xf6
56
+ %define __ALIGN_16BIT_3B__ 0x8d,0x74,0x00
57
+ %define __ALIGN_16BIT_4B__ 0x8d,0xb4,0x00,0x00
58
+ %define __ALIGN_16BIT_5B__ 0x8d,0xb4,0x00,0x00,0x90
59
+ %define __ALIGN_16BIT_6B__ 0x8d,0xb4,0x00,0x00,0x89,0xff
60
+ %define __ALIGN_16BIT_7B__ 0x8d,0xb4,0x00,0x00,0x8d,0x7d,0x00
61
+ %define __ALIGN_16BIT_8B__ 0x8d,0xb4,0x00,0x00,0x8d,0xbd,0x00,0x00
62
+ %define __ALIGN_16BIT_GROUP__ 8
63
+
64
+ %define __ALIGN_32BIT_1B__ 0x90
65
+ %define __ALIGN_32BIT_2B__ 0x89,0xf6
66
+ %define __ALIGN_32BIT_3B__ 0x8d,0x76,0x00
67
+ %define __ALIGN_32BIT_4B__ 0x8d,0x74,0x26,0x00
68
+ %define __ALIGN_32BIT_5B__ 0x90,0x8d,0x74,0x26,0x00
69
+ %define __ALIGN_32BIT_6B__ 0x8d,0xb6,0x00,0x00,0x00,0x00
70
+ %define __ALIGN_32BIT_7B__ 0x8d,0xb4,0x26,0x00,0x00,0x00,0x00
71
+ %define __ALIGN_32BIT_GROUP__ 7
72
+
73
+ %define __ALIGN_64BIT_1B__ 0x90
74
+ %define __ALIGN_64BIT_2B__ 0x66,0x90
75
+ %define __ALIGN_64BIT_3B__ 0x66,0x66,0x90
76
+ %define __ALIGN_64BIT_4B__ 0x66,0x66,0x66,0x90
77
+ %define __ALIGN_64BIT_GROUP__ 4
78
+ %elifidni %1,k8
79
+ %define __ALIGN_JMP_THRESHOLD__ 16
80
+
81
+ %define __ALIGN_16BIT_1B__ 0x90
82
+ %define __ALIGN_16BIT_2B__ 0x66,0x90
83
+ %define __ALIGN_16BIT_3B__ 0x66,0x66,0x90
84
+ %define __ALIGN_16BIT_4B__ 0x66,0x66,0x66,0x90
85
+ %define __ALIGN_16BIT_GROUP__ 4
86
+
87
+ %define __ALIGN_32BIT_1B__ 0x90
88
+ %define __ALIGN_32BIT_2B__ 0x66,0x90
89
+ %define __ALIGN_32BIT_3B__ 0x66,0x66,0x90
90
+ %define __ALIGN_32BIT_4B__ 0x66,0x66,0x66,0x90
91
+ %define __ALIGN_32BIT_GROUP__ 4
92
+
93
+ %define __ALIGN_64BIT_1B__ 0x90
94
+ %define __ALIGN_64BIT_2B__ 0x66,0x90
95
+ %define __ALIGN_64BIT_3B__ 0x66,0x66,0x90
96
+ %define __ALIGN_64BIT_4B__ 0x66,0x66,0x66,0x90
97
+ %define __ALIGN_64BIT_GROUP__ 4
98
+ %elifidni %1,k7
99
+ %define __ALIGN_JMP_THRESHOLD__ 16
100
+
101
+ %define __ALIGN_16BIT_1B__ 0x90
102
+ %define __ALIGN_16BIT_2B__ 0x66,0x90
103
+ %define __ALIGN_16BIT_3B__ 0x66,0x66,0x90
104
+ %define __ALIGN_16BIT_4B__ 0x66,0x66,0x66,0x90
105
+ %define __ALIGN_64BIT_GROUP__ 4
106
+
107
+ %define __ALIGN_32BIT_1B__ 0x90
108
+ %define __ALIGN_32BIT_2B__ 0x8b,0xc0
109
+ %define __ALIGN_32BIT_3B__ 0x8d,0x04,0x20
110
+ %define __ALIGN_32BIT_4B__ 0x8d,0x44,0x20,0x00
111
+ %define __ALIGN_32BIT_5B__ 0x8d,0x44,0x20,0x00,0x90
112
+ %define __ALIGN_32BIT_6B__ 0x8d,0x80,0x00,0x00,0x00,0x00
113
+ %define __ALIGN_32BIT_7B__ 0x8d,0x04,0x05,0x00,0x00,0x00,0x00
114
+ %define __ALIGN_32BIT_GROUP__ 7
115
+
116
+ %define __ALIGN_64BIT_1B__ 0x90
117
+ %define __ALIGN_64BIT_2B__ 0x66,0x90
118
+ %define __ALIGN_64BIT_3B__ 0x66,0x66,0x90
119
+ %define __ALIGN_64BIT_4B__ 0x66,0x66,0x66,0x90
120
+ %define __ALIGN_64BIT_GROUP__ 4
121
+ %elifidni %1,p6
122
+ %define __ALIGN_JMP_THRESHOLD__ 16
123
+
124
+ %define __ALIGN_16BIT_1B__ 0x90
125
+ %define __ALIGN_16BIT_2B__ 0x66,0x90
126
+ %define __ALIGN_16BIT_3B__ 0x0f,0x1f,0x00
127
+ %define __ALIGN_16BIT_4B__ 0x0f,0x1f,0x40,0x00
128
+ %define __ALIGN_16BIT_GROUP__ 4
129
+
130
+ %define __ALIGN_32BIT_1B__ 0x90
131
+ %define __ALIGN_32BIT_2B__ 0x66,0x90
132
+ %define __ALIGN_32BIT_3B__ 0x0f,0x1f,0x00
133
+ %define __ALIGN_32BIT_4B__ 0x0f,0x1f,0x40,0x00
134
+ %define __ALIGN_32BIT_5B__ 0x0f,0x1f,0x44,0x00,0x00
135
+ %define __ALIGN_32BIT_6B__ 0x66,0x0f,0x1f,0x44,0x00,0x00
136
+ %define __ALIGN_32BIT_7B__ 0x0f,0x1f,0x80,0x00,0x00,0x00,0x00
137
+ %define __ALIGN_32BIT_8B__ 0x0f,0x1f,0x84,0x00,0x00,0x00,0x00,0x00
138
+ %define __ALIGN_32BIT_GROUP__ 8
139
+
140
+ %define __ALIGN_64BIT_1B__ 0x90
141
+ %define __ALIGN_64BIT_2B__ 0x66,0x90
142
+ %define __ALIGN_64BIT_3B__ 0x0f,0x1f,0x00
143
+ %define __ALIGN_64BIT_4B__ 0x0f,0x1f,0x40,0x00
144
+ %define __ALIGN_64BIT_5B__ 0x0f,0x1f,0x44,0x00,0x00
145
+ %define __ALIGN_64BIT_6B__ 0x66,0x0f,0x1f,0x44,0x00,0x00
146
+ %define __ALIGN_64BIT_7B__ 0x0f,0x1f,0x80,0x00,0x00,0x00,0x00
147
+ %define __ALIGN_64BIT_8B__ 0x0f,0x1f,0x84,0x00,0x00,0x00,0x00,0x00
148
+ %define __ALIGN_64BIT_GROUP__ 8
149
+ %else
150
+ %error unknown alignment mode: %1
151
+ %endif
152
+ %ifnempty %2
153
+ %ifidni %2,nojmp
154
+ %xdefine __ALIGN_JMP_THRESHOLD__ -1
155
+ %else
156
+ %xdefine __ALIGN_JMP_THRESHOLD__ %2
157
+ %endif
158
+ %endif
159
+ %xdefine __ALIGNMODE__ %1,__ALIGN_JMP_THRESHOLD__
160
+ %endmacro
161
+
162
+ %unimacro align 1-2+.nolist
163
+ %imacro align 1-2+.nolist
164
+ sectalign %1 ; align a segment as well
165
+ %ifnempty %2
166
+ times (((%1) - (($-$$) % (%1))) % (%1)) %2
167
+ %elif __PASS__ == 0 || __PASS__ == 3
168
+ times (((%1) - (($-$$) % (%1))) % (%1)) nop
169
+ %else
170
+ %push
171
+ %assign %$pad (((%1) - (($-$$) % (%1))) % (%1))
172
+ %if __ALIGN_JMP_THRESHOLD__ != -1 && %$pad > __ALIGN_JMP_THRESHOLD__
173
+ jmp %$end
174
+ ; We can't re-use %$pad here as $ will have changed!
175
+ times (((%1) - (($-$$) % (%1))) % (%1)) nop
176
+ %else
177
+ times (%$pad / __ALIGN_%[__BITS__]BIT_GROUP__) \
178
+ db __ALIGN_%[__BITS__]BIT_%[__ALIGN_%[__BITS__]BIT_GROUP__]B__
179
+ %assign %$pad %$pad % __ALIGN_%[__BITS__]BIT_GROUP__
180
+ %if %$pad > 0
181
+ db __ALIGN_%[__BITS__]BIT_%[%$pad]B__
182
+ %endif
183
+ %endif
184
+ %$end:
185
+ %pop
186
+ %endif
187
+ %endmacro
188
+
189
+ alignmode generic
@@ -0,0 +1,226 @@
1
+ ;; --------------------------------------------------------------------------
2
+ ;;
3
+ ;; Copyright 1996-2016 The NASM Authors - All Rights Reserved
4
+ ;; See the file AUTHORS included with the NASM distribution for
5
+ ;; the specific copyright holders.
6
+ ;;
7
+ ;; Redistribution and use in source and binary forms, with or without
8
+ ;; modification, are permitted provided that the following
9
+ ;; conditions are met:
10
+ ;;
11
+ ;; * Redistributions of source code must retain the above copyright
12
+ ;; notice, this list of conditions and the following disclaimer.
13
+ ;; * Redistributions in binary form must reproduce the above
14
+ ;; copyright notice, this list of conditions and the following
15
+ ;; disclaimer in the documentation and/or other materials provided
16
+ ;; with the distribution.
17
+ ;;
18
+ ;; THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
19
+ ;; CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
20
+ ;; INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21
+ ;; MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22
+ ;; DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
23
+ ;; CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24
+ ;; SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
25
+ ;; NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26
+ ;; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27
+ ;; HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28
+ ;; CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29
+ ;; OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30
+ ;; EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
+ ;;
32
+ ;; --------------------------------------------------------------------------
33
+
34
+ ; Standard macro set for NASM -*- nasm -*-
35
+
36
+ ; Macros to make NASM ignore some TASM directives
37
+ STD: tasm
38
+ %idefine IDEAL
39
+ %idefine JUMPS
40
+ %idefine P386
41
+ %idefine P486
42
+ %idefine P586
43
+ %idefine END
44
+
45
+ ; The normal standard macros
46
+ STD: nasm
47
+
48
+ ; Note that although some user-level forms of directives are defined
49
+ ; here, not all of them are: the user-level form of a format-specific
50
+ ; directive should be defined in the module for that directive.
51
+
52
+ ; These three need to be defined, though the actual definitions will
53
+ ; be constantly updated during preprocessing.
54
+ %define __FILE__
55
+ %define __LINE__
56
+ %define __BITS__
57
+
58
+ %define __SECT__ ; it ought to be defined, even if as nothing
59
+
60
+ %imacro section 1+.nolist
61
+ %define __SECT__ [section %1]
62
+ __SECT__
63
+ %endmacro
64
+
65
+ %imacro segment 1+.nolist
66
+ %define __SECT__ [segment %1]
67
+ __SECT__
68
+ %endmacro
69
+
70
+ %define __SECTALIGN_ALIGN_UPDATES_SECTION__ 1
71
+ %imacro sectalign 1.nolist
72
+ %ifnum %1
73
+ %if __SECTALIGN_ALIGN_UPDATES_SECTION__ = 1
74
+ [sectalign %1]
75
+ %endif
76
+ %else
77
+ %ifidni %1,off
78
+ %define __SECTALIGN_ALIGN_UPDATES_SECTION__ 0
79
+ %elifidni %1,on
80
+ %define __SECTALIGN_ALIGN_UPDATES_SECTION__ 1
81
+ %endif
82
+ %endif
83
+ %endmacro
84
+
85
+ %imacro absolute 1+.nolist
86
+ %define __SECT__ [absolute %1]
87
+ __SECT__
88
+ %endmacro
89
+
90
+ %imacro struc 1-2.nolist 0
91
+ %push
92
+ %define %$strucname %1
93
+ [absolute %2]
94
+ %$strucname: ; allow definition of `.member' to work sanely
95
+ %endmacro
96
+
97
+ %imacro endstruc 0.nolist
98
+ %{$strucname}_size equ ($-%$strucname)
99
+ %pop
100
+ __SECT__
101
+ %endmacro
102
+
103
+ %imacro istruc 1.nolist
104
+ %push
105
+ %define %$strucname %1
106
+ %$strucstart:
107
+ %endmacro
108
+
109
+ %imacro at 1-2+.nolist
110
+ times (%1-%$strucname)-($-%$strucstart) db 0
111
+ %2
112
+ %endmacro
113
+
114
+ %imacro iend 0.nolist
115
+ times %{$strucname}_size-($-%$strucstart) db 0
116
+ %pop
117
+ %endmacro
118
+
119
+ %imacro align 1-2+.nolist nop
120
+ sectalign %1
121
+ times (((%1) - (($-$$) % (%1))) % (%1)) %2
122
+ %endmacro
123
+
124
+ %imacro alignb 1-2+.nolist
125
+ sectalign %1
126
+ %ifempty %2
127
+ resb (((%1) - (($-$$) % (%1))) % (%1))
128
+ %else
129
+ times (((%1) - (($-$$) % (%1))) % (%1)) %2
130
+ %endif
131
+ %endmacro
132
+
133
+ %imacro extern 1-*.nolist
134
+ %rep %0
135
+ [extern %1]
136
+ %rotate 1
137
+ %endrep
138
+ %endmacro
139
+
140
+ %imacro bits 1+.nolist
141
+ [bits %1]
142
+ %endmacro
143
+
144
+ %imacro use16 0.nolist
145
+ [bits 16]
146
+ %endmacro
147
+
148
+ %imacro use32 0.nolist
149
+ [bits 32]
150
+ %endmacro
151
+
152
+ %imacro use64 0.nolist
153
+ [bits 64]
154
+ %endmacro
155
+
156
+ %imacro global 1-*.nolist
157
+ %rep %0
158
+ [global %1]
159
+ %rotate 1
160
+ %endrep
161
+ %endmacro
162
+
163
+ %imacro common 1-*.nolist
164
+ %rep %0
165
+ [common %1]
166
+ %rotate 1
167
+ %endrep
168
+ %endmacro
169
+
170
+ %imacro cpu 1+.nolist
171
+ [cpu %1]
172
+ %endmacro
173
+
174
+ %define __FLOAT_DAZ__ nodaz
175
+ %define __FLOAT_ROUND__ near
176
+ ; __FLOAT__ contains the whole floating-point configuration so it can
177
+ ; be saved and restored
178
+ %define __FLOAT__ __FLOAT_DAZ__,__FLOAT_ROUND__
179
+
180
+ %imacro float 1-*.nolist
181
+ %rep %0
182
+ [float %1]
183
+ %ifidni %1,daz
184
+ %define __FLOAT_DAZ__ daz
185
+ %elifidni %1,nodaz
186
+ %define __FLOAT_DAZ__ nodaz
187
+ %elifidni %1,near
188
+ %define __FLOAT_ROUND__ near
189
+ %elifidni %1,up
190
+ %define __FLOAT_ROUND__ up
191
+ %elifidni %1,down
192
+ %define __FLOAT_ROUND__ down
193
+ %elifidni %1,zero
194
+ %define __FLOAT_ROUND__ zero
195
+ %elifidni %1,default
196
+ %define __FLOAT_DAZ__ nodaz
197
+ %define __FLOAT_ROUND__ near
198
+ %endif
199
+ %rotate 1
200
+ %endrep
201
+ %endmacro
202
+
203
+ %imacro default 1+.nolist
204
+ [default %1]
205
+ %endmacro
206
+
207
+ %imacro userel 0.nolist
208
+ [default rel]
209
+ %endmacro
210
+ %imacro useabs 0.nolist
211
+ [default abs]
212
+ %endmacro
213
+ %imacro usebnd 0.nolist
214
+ [default bnd]
215
+ %endmacro
216
+ %imacro usenobnd 0.nolist
217
+ [default nobnd]
218
+ %endmacro
219
+
220
+ %imacro incbin 1-2+.nolist 0
221
+ %push
222
+ %pathsearch %$dep %1
223
+ %depend %$dep
224
+ %? %$dep,%2
225
+ %pop
226
+ %endmacro
@@ -0,0 +1,752 @@
1
+ # Doxyfile 1.2.5
2
+
3
+ # This file describes the settings to be used by doxygen for a project
4
+ #
5
+ # All text after a hash (#) is considered a comment and will be ignored
6
+ # The format is:
7
+ # TAG = value [value, ...]
8
+ # For lists items can also be appended using:
9
+ # TAG += value [value, ...]
10
+ # Values that contain spaces should be placed between quotes (" ")
11
+
12
+ #---------------------------------------------------------------------------
13
+ # General configuration options
14
+ #---------------------------------------------------------------------------
15
+
16
+ # The PROJECT_NAME tag is a single word (or a sequence of words surrounded
17
+ # by quotes) that should identify the project.
18
+
19
+ PROJECT_NAME = "NASM - the Netwide Assembler"
20
+
21
+ # The PROJECT_NUMBER tag can be used to enter a project or revision number.
22
+ # This could be handy for archiving the generated documentation or
23
+ # if some version control system is used.
24
+
25
+ PROJECT_NUMBER = 0.98
26
+
27
+ # The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute)
28
+ # base path where the generated documentation will be put.
29
+ # If a relative path is entered, it will be relative to the location
30
+ # where doxygen was started. If left blank the current directory will be used.
31
+
32
+ OUTPUT_DIRECTORY = doxy
33
+
34
+ # The OUTPUT_LANGUAGE tag is used to specify the language in which all
35
+ # documentation generated by doxygen is written. Doxygen will use this
36
+ # information to generate all constant output in the proper language.
37
+ # The default language is English, other supported languages are:
38
+ # Dutch, French, Italian, Czech, Swedish, German, Finnish, Japanese,
39
+ # Korean, Hungarian, Norwegian, Spanish, Romanian, Russian, Croatian,
40
+ # Polish, Portuguese and Slovene.
41
+
42
+ OUTPUT_LANGUAGE = English
43
+
44
+ # If the EXTRACT_ALL tag is set to YES doxygen will assume all entities in
45
+ # documentation are documented, even if no documentation was available.
46
+ # Private class members and static file members will be hidden unless
47
+ # the EXTRACT_PRIVATE and EXTRACT_STATIC tags are set to YES
48
+
49
+ EXTRACT_ALL = YES
50
+
51
+ # If the EXTRACT_PRIVATE tag is set to YES all private members of a class
52
+ # will be included in the documentation.
53
+
54
+ EXTRACT_PRIVATE = NO
55
+
56
+ # If the EXTRACT_STATIC tag is set to YES all static members of a file
57
+ # will be included in the documentation.
58
+
59
+ EXTRACT_STATIC = YES
60
+
61
+ # If the HIDE_UNDOC_MEMBERS tag is set to YES, Doxygen will hide all
62
+ # undocumented members of documented classes, files or namespaces.
63
+ # If set to NO (the default) these members will be included in the
64
+ # various overviews, but no documentation section is generated.
65
+ # This option has no effect if EXTRACT_ALL is enabled.
66
+
67
+ HIDE_UNDOC_MEMBERS = NO
68
+
69
+ # If the HIDE_UNDOC_CLASSES tag is set to YES, Doxygen will hide all
70
+ # undocumented classes that are normally visible in the class hierarchy.
71
+ # If set to NO (the default) these class will be included in the various
72
+ # overviews. This option has no effect if EXTRACT_ALL is enabled.
73
+
74
+ HIDE_UNDOC_CLASSES = NO
75
+
76
+ # If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will
77
+ # include brief member descriptions after the members that are listed in
78
+ # the file and class documentation (similar to JavaDoc).
79
+ # Set to NO to disable this.
80
+
81
+ BRIEF_MEMBER_DESC = YES
82
+
83
+ # If the REPEAT_BRIEF tag is set to YES (the default) Doxygen will prepend
84
+ # the brief description of a member or function before the detailed description.
85
+ # Note: if both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the
86
+ # brief descriptions will be completely suppressed.
87
+
88
+ REPEAT_BRIEF = YES
89
+
90
+ # If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then
91
+ # Doxygen will generate a detailed section even if there is only a brief
92
+ # description.
93
+
94
+ ALWAYS_DETAILED_SEC = NO
95
+
96
+ # If the FULL_PATH_NAMES tag is set to YES then Doxygen will prepend the full
97
+ # path before files name in the file list and in the header files. If set
98
+ # to NO the shortest path that makes the file name unique will be used.
99
+
100
+ FULL_PATH_NAMES = NO
101
+
102
+ # If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag
103
+ # can be used to strip a user defined part of the path. Stripping is
104
+ # only done if one of the specified strings matches the left-hand part of
105
+ # the path. It is allowed to use relative paths in the argument list.
106
+
107
+ STRIP_FROM_PATH =
108
+
109
+ # The INTERNAL_DOCS tag determines if documentation
110
+ # that is typed after a \internal command is included. If the tag is set
111
+ # to NO (the default) then the documentation will be excluded.
112
+ # Set it to YES to include the internal documentation.
113
+
114
+ INTERNAL_DOCS = NO
115
+
116
+ # If the CLASS_DIAGRAMS tag is set to YES (the default) Doxygen will
117
+ # generate a class diagram (in Html and LaTeX) for classes with base or
118
+ # super classes. Setting the tag to NO turns the diagrams off.
119
+
120
+ CLASS_DIAGRAMS = YES
121
+
122
+ # If the SOURCE_BROWSER tag is set to YES then a list of source files will
123
+ # be generated. Documented entities will be cross-referenced with these sources.
124
+
125
+ SOURCE_BROWSER = YES
126
+
127
+ # Setting the INLINE_SOURCES tag to YES will include the body
128
+ # of functions and classes directly in the documentation.
129
+
130
+ INLINE_SOURCES = NO
131
+
132
+ # Setting the STRIP_CODE_COMMENTS tag to YES (the default) will instruct
133
+ # doxygen to hide any special comment blocks from generated source code
134
+ # fragments. Normal C and C++ comments will always remain visible.
135
+
136
+ STRIP_CODE_COMMENTS = YES
137
+
138
+ # If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate
139
+ # file names in lower case letters. If set to YES upper case letters are also
140
+ # allowed. This is useful if you have classes or files whose names only differ
141
+ # in case and if your file system supports case sensitive file names. Windows
142
+ # users are adviced to set this option to NO.
143
+
144
+ CASE_SENSE_NAMES = YES
145
+
146
+ # If the HIDE_SCOPE_NAMES tag is set to NO (the default) then Doxygen
147
+ # will show members with their full class and namespace scopes in the
148
+ # documentation. If set to YES the scope will be hidden.
149
+
150
+ HIDE_SCOPE_NAMES = NO
151
+
152
+ # If the VERBATIM_HEADERS tag is set to YES (the default) then Doxygen
153
+ # will generate a verbatim copy of the header file for each class for
154
+ # which an include is specified. Set to NO to disable this.
155
+
156
+ VERBATIM_HEADERS = YES
157
+
158
+ # If the SHOW_INCLUDE_FILES tag is set to YES (the default) then Doxygen
159
+ # will put list of the files that are included by a file in the documentation
160
+ # of that file.
161
+
162
+ SHOW_INCLUDE_FILES = YES
163
+
164
+ # If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen
165
+ # will interpret the first line (until the first dot) of a JavaDoc-style
166
+ # comment as the brief description. If set to NO, the JavaDoc
167
+ # comments will behave just like the Qt-style comments (thus requiring an
168
+ # explict @brief command for a brief description.
169
+
170
+ JAVADOC_AUTOBRIEF = NO
171
+
172
+ # If the INHERIT_DOCS tag is set to YES (the default) then an undocumented
173
+ # member inherits the documentation from any documented member that it
174
+ # reimplements.
175
+
176
+ INHERIT_DOCS = YES
177
+
178
+ # If the INLINE_INFO tag is set to YES (the default) then a tag [inline]
179
+ # is inserted in the documentation for inline members.
180
+
181
+ INLINE_INFO = YES
182
+
183
+ # If the SORT_MEMBER_DOCS tag is set to YES (the default) then doxygen
184
+ # will sort the (detailed) documentation of file and class members
185
+ # alphabetically by member name. If set to NO the members will appear in
186
+ # declaration order.
187
+
188
+ SORT_MEMBER_DOCS = YES
189
+
190
+ # If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC
191
+ # tag is set to YES, then doxygen will reuse the documentation of the first
192
+ # member in the group (if any) for the other members of the group. By default
193
+ # all members of a group must be documented explicitly.
194
+
195
+ DISTRIBUTE_GROUP_DOC = NO
196
+
197
+ # The TAB_SIZE tag can be used to set the number of spaces in a tab.
198
+ # Doxygen uses this value to replace tabs by spaces in code fragments.
199
+
200
+ TAB_SIZE = 4
201
+
202
+ # The ENABLE_SECTIONS tag can be used to enable conditional
203
+ # documentation sections, marked by \if sectionname ... \endif.
204
+
205
+ ENABLED_SECTIONS =
206
+
207
+ # The GENERATE_TODOLIST tag can be used to enable (YES) or
208
+ # disable (NO) the todo list. This list is created by putting \todo
209
+ # commands in the documentation.
210
+
211
+ GENERATE_TODOLIST = YES
212
+
213
+ # The GENERATE_TESTLIST tag can be used to enable (YES) or
214
+ # disable (NO) the test list. This list is created by putting \test
215
+ # commands in the documentation.
216
+
217
+ GENERATE_TESTLIST = YES
218
+
219
+ # This tag can be used to specify a number of aliases that acts
220
+ # as commands in the documentation. An alias has the form "name=value".
221
+ # For example adding "sideeffect=\par Side Effects:\n" will allow you to
222
+ # put the command \sideeffect (or @sideeffect) in the documentation, which
223
+ # will result in a user defined paragraph with heading "Side Effects:".
224
+ # You can put \n's in the value part of an alias to insert newlines.
225
+
226
+ ALIASES =
227
+
228
+ # The MAX_INITIALIZER_LINES tag determines the maximum number of lines
229
+ # the initial value of a variable or define consist of for it to appear in
230
+ # the documentation. If the initializer consists of more lines than specified
231
+ # here it will be hidden. Use a value of 0 to hide initializers completely.
232
+ # The appearance of the initializer of individual variables and defines in the
233
+ # documentation can be controlled using \showinitializer or \hideinitializer
234
+ # command in the documentation regardless of this setting.
235
+
236
+ MAX_INITIALIZER_LINES = 30
237
+
238
+ # Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources
239
+ # only. Doxygen will then generate output that is more tailored for C.
240
+ # For instance some of the names that are used will be different. The list
241
+ # of all members will be omitted, etc.
242
+
243
+ OPTIMIZE_OUTPUT_FOR_C = NO
244
+
245
+ #---------------------------------------------------------------------------
246
+ # configuration options related to warning and progress messages
247
+ #---------------------------------------------------------------------------
248
+
249
+ # The QUIET tag can be used to turn on/off the messages that are generated
250
+ # by doxygen. Possible values are YES and NO. If left blank NO is used.
251
+
252
+ QUIET = NO
253
+
254
+ # The WARNINGS tag can be used to turn on/off the warning messages that are
255
+ # generated by doxygen. Possible values are YES and NO. If left blank
256
+ # NO is used.
257
+
258
+ WARNINGS = YES
259
+
260
+ # If WARN_IF_UNDOCUMENTED is set to YES, then doxygen will generate warnings
261
+ # for undocumented members. If EXTRACT_ALL is set to YES then this flag will
262
+ # automatically be disabled.
263
+
264
+ WARN_IF_UNDOCUMENTED = YES
265
+
266
+ # The WARN_FORMAT tag determines the format of the warning messages that
267
+ # doxygen can produce. The string should contain the $file, $line, and $text
268
+ # tags, which will be replaced by the file and line number from which the
269
+ # warning originated and the warning text.
270
+
271
+ WARN_FORMAT = "$file:$line: $text"
272
+
273
+ # The WARN_LOGFILE tag can be used to specify a file to which warning
274
+ # and error messages should be written. If left blank the output is written
275
+ # to stderr.
276
+
277
+ WARN_LOGFILE =
278
+
279
+ #---------------------------------------------------------------------------
280
+ # configuration options related to the input files
281
+ #---------------------------------------------------------------------------
282
+
283
+ # The INPUT tag can be used to specify the files and/or directories that contain
284
+ # documented source files. You may enter file names like "myfile.cpp" or
285
+ # directories like "/usr/src/myproject". Separate the files or directories
286
+ # with spaces.
287
+
288
+ INPUT = .
289
+
290
+ # If the value of the INPUT tag contains directories, you can use the
291
+ # FILE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp
292
+ # and *.h) to filter out the source-files in the directories. If left
293
+ # blank all files are included.
294
+
295
+ FILE_PATTERNS = *.c *.h
296
+
297
+ # The RECURSIVE tag can be used to turn specify whether or not subdirectories
298
+ # should be searched for input files as well. Possible values are YES and NO.
299
+ # If left blank NO is used.
300
+
301
+ RECURSIVE = NO
302
+
303
+ # The EXCLUDE tag can be used to specify files and/or directories that should
304
+ # excluded from the INPUT source files. This way you can easily exclude a
305
+ # subdirectory from a directory tree whose root is specified with the INPUT tag.
306
+
307
+ EXCLUDE =
308
+
309
+ # If the value of the INPUT tag contains directories, you can use the
310
+ # EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude
311
+ # certain files from those directories.
312
+
313
+ EXCLUDE_PATTERNS =
314
+
315
+ # The EXAMPLE_PATH tag can be used to specify one or more files or
316
+ # directories that contain example code fragments that are included (see
317
+ # the \include command).
318
+
319
+ EXAMPLE_PATH =
320
+
321
+ # If the value of the EXAMPLE_PATH tag contains directories, you can use the
322
+ # EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp
323
+ # and *.h) to filter out the source-files in the directories. If left
324
+ # blank all files are included.
325
+
326
+ EXAMPLE_PATTERNS =
327
+
328
+ # The IMAGE_PATH tag can be used to specify one or more files or
329
+ # directories that contain image that are included in the documentation (see
330
+ # the \image command).
331
+
332
+ IMAGE_PATH =
333
+
334
+ # The INPUT_FILTER tag can be used to specify a program that doxygen should
335
+ # invoke to filter for each input file. Doxygen will invoke the filter program
336
+ # by executing (via popen()) the command <filter> <input-file>, where <filter>
337
+ # is the value of the INPUT_FILTER tag, and <input-file> is the name of an
338
+ # input file. Doxygen will then use the output that the filter program writes
339
+ # to standard output.
340
+
341
+ INPUT_FILTER =
342
+
343
+ # If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using
344
+ # INPUT_FILTER) will be used to filter the input files when producing source
345
+ # files to browse.
346
+
347
+ FILTER_SOURCE_FILES = NO
348
+
349
+ #---------------------------------------------------------------------------
350
+ # configuration options related to the alphabetical class index
351
+ #---------------------------------------------------------------------------
352
+
353
+ # If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index
354
+ # of all compounds will be generated. Enable this if the project
355
+ # contains a lot of classes, structs, unions or interfaces.
356
+
357
+ ALPHABETICAL_INDEX = NO
358
+
359
+ # If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then
360
+ # the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns
361
+ # in which this list will be split (can be a number in the range [1..20])
362
+
363
+ COLS_IN_ALPHA_INDEX = 5
364
+
365
+ # In case all classes in a project start with a common prefix, all
366
+ # classes will be put under the same header in the alphabetical index.
367
+ # The IGNORE_PREFIX tag can be used to specify one or more prefixes that
368
+ # should be ignored while generating the index headers.
369
+
370
+ IGNORE_PREFIX =
371
+
372
+ #---------------------------------------------------------------------------
373
+ # configuration options related to the HTML output
374
+ #---------------------------------------------------------------------------
375
+
376
+ # If the GENERATE_HTML tag is set to YES (the default) Doxygen will
377
+ # generate HTML output.
378
+
379
+ GENERATE_HTML = YES
380
+
381
+ # The HTML_OUTPUT tag is used to specify where the HTML docs will be put.
382
+ # If a relative path is entered the value of OUTPUT_DIRECTORY will be
383
+ # put in front of it. If left blank `html' will be used as the default path.
384
+
385
+ HTML_OUTPUT = html
386
+
387
+ # The HTML_HEADER tag can be used to specify a personal HTML header for
388
+ # each generated HTML page. If it is left blank doxygen will generate a
389
+ # standard header.
390
+
391
+ HTML_HEADER =
392
+
393
+ # The HTML_FOOTER tag can be used to specify a personal HTML footer for
394
+ # each generated HTML page. If it is left blank doxygen will generate a
395
+ # standard footer.
396
+
397
+ HTML_FOOTER =
398
+
399
+ # The HTML_STYLESHEET tag can be used to specify a user defined cascading
400
+ # style sheet that is used by each HTML page. It can be used to
401
+ # fine-tune the look of the HTML output. If the tag is left blank doxygen
402
+ # will generate a default style sheet
403
+
404
+ HTML_STYLESHEET =
405
+
406
+ # If the HTML_ALIGN_MEMBERS tag is set to YES, the members of classes,
407
+ # files or namespaces will be aligned in HTML using tables. If set to
408
+ # NO a bullet list will be used.
409
+
410
+ HTML_ALIGN_MEMBERS = YES
411
+
412
+ # If the GENERATE_HTMLHELP tag is set to YES, additional index files
413
+ # will be generated that can be used as input for tools like the
414
+ # Microsoft HTML help workshop to generate a compressed HTML help file (.chm)
415
+ # of the generated HTML documentation.
416
+
417
+ GENERATE_HTMLHELP = NO
418
+
419
+ # The DISABLE_INDEX tag can be used to turn on/off the condensed index at
420
+ # top of each HTML page. The value NO (the default) enables the index and
421
+ # the value YES disables it.
422
+
423
+ DISABLE_INDEX = NO
424
+
425
+ # This tag can be used to set the number of enum values (range [1..20])
426
+ # that doxygen will group on one line in the generated HTML documentation.
427
+
428
+ ENUM_VALUES_PER_LINE = 4
429
+
430
+ # If the GENERATE_TREEVIEW tag is set to YES, a side panel will be
431
+ # generated containing a tree-like index structure (just like the one that
432
+ # is generated for HTML Help). For this to work a browser that supports
433
+ # JavaScript and frames is required (for instance Netscape 4.0+
434
+ # or Internet explorer 4.0+).
435
+
436
+ GENERATE_TREEVIEW = YES
437
+
438
+ # If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be
439
+ # used to set the initial width (in pixels) of the frame in which the tree
440
+ # is shown.
441
+
442
+ TREEVIEW_WIDTH = 250
443
+
444
+ #---------------------------------------------------------------------------
445
+ # configuration options related to the LaTeX output
446
+ #---------------------------------------------------------------------------
447
+
448
+ # If the GENERATE_LATEX tag is set to YES (the default) Doxygen will
449
+ # generate Latex output.
450
+
451
+ GENERATE_LATEX = YES
452
+
453
+ # The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put.
454
+ # If a relative path is entered the value of OUTPUT_DIRECTORY will be
455
+ # put in front of it. If left blank `latex' will be used as the default path.
456
+
457
+ LATEX_OUTPUT = latex
458
+
459
+ # If the COMPACT_LATEX tag is set to YES Doxygen generates more compact
460
+ # LaTeX documents. This may be useful for small projects and may help to
461
+ # save some trees in general.
462
+
463
+ COMPACT_LATEX = NO
464
+
465
+ # The PAPER_TYPE tag can be used to set the paper type that is used
466
+ # by the printer. Possible values are: a4, a4wide, letter, legal and
467
+ # executive. If left blank a4wide will be used.
468
+
469
+ PAPER_TYPE = a4wide
470
+
471
+ # The EXTRA_PACKAGES tag can be to specify one or more names of LaTeX
472
+ # packages that should be included in the LaTeX output.
473
+
474
+ EXTRA_PACKAGES =
475
+
476
+ # The LATEX_HEADER tag can be used to specify a personal LaTeX header for
477
+ # the generated latex document. The header should contain everything until
478
+ # the first chapter. If it is left blank doxygen will generate a
479
+ # standard header. Notice: only use this tag if you know what you are doing!
480
+
481
+ LATEX_HEADER =
482
+
483
+ # If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated
484
+ # is prepared for conversion to pdf (using ps2pdf). The pdf file will
485
+ # contain links (just like the HTML output) instead of page references
486
+ # This makes the output suitable for online browsing using a pdf viewer.
487
+
488
+ PDF_HYPERLINKS = NO
489
+
490
+ # If the USE_PDFLATEX tag is set to YES, pdflatex will be used instead of
491
+ # plain latex in the generated Makefile. Set this option to YES to get a
492
+ # higher quality PDF documentation.
493
+
494
+ USE_PDFLATEX = NO
495
+
496
+ # If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \\batchmode.
497
+ # command to the generated LaTeX files. This will instruct LaTeX to keep
498
+ # running if errors occur, instead of asking the user for help.
499
+ # This option is also used when generating formulas in HTML.
500
+
501
+ LATEX_BATCHMODE = NO
502
+
503
+ #---------------------------------------------------------------------------
504
+ # configuration options related to the RTF output
505
+ #---------------------------------------------------------------------------
506
+
507
+ # If the GENERATE_RTF tag is set to YES Doxygen will generate RTF output
508
+ # The RTF output is optimised for Word 97 and may not look very pretty with
509
+ # other RTF readers or editors.
510
+
511
+ GENERATE_RTF = YES
512
+
513
+ # The RTF_OUTPUT tag is used to specify where the RTF docs will be put.
514
+ # If a relative path is entered the value of OUTPUT_DIRECTORY will be
515
+ # put in front of it. If left blank `rtf' will be used as the default path.
516
+
517
+ RTF_OUTPUT = rtf
518
+
519
+ # If the COMPACT_RTF tag is set to YES Doxygen generates more compact
520
+ # RTF documents. This may be useful for small projects and may help to
521
+ # save some trees in general.
522
+
523
+ COMPACT_RTF = NO
524
+
525
+ # If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated
526
+ # will contain hyperlink fields. The RTF file will
527
+ # contain links (just like the HTML output) instead of page references.
528
+ # This makes the output suitable for online browsing using a WORD or other.
529
+ # programs which support those fields.
530
+ # Note: wordpad (write) and others do not support links.
531
+
532
+ RTF_HYPERLINKS = NO
533
+
534
+ # Load stylesheet definitions from file. Syntax is similar to doxygen's
535
+ # config file, i.e. a series of assigments. You only have to provide
536
+ # replacements, missing definitions are set to their default value.
537
+
538
+ RTF_STYLESHEET_FILE =
539
+
540
+ #---------------------------------------------------------------------------
541
+ # configuration options related to the man page output
542
+ #---------------------------------------------------------------------------
543
+
544
+ # If the GENERATE_MAN tag is set to YES (the default) Doxygen will
545
+ # generate man pages
546
+
547
+ GENERATE_MAN = YES
548
+
549
+ # The MAN_OUTPUT tag is used to specify where the man pages will be put.
550
+ # If a relative path is entered the value of OUTPUT_DIRECTORY will be
551
+ # put in front of it. If left blank `man' will be used as the default path.
552
+
553
+ MAN_OUTPUT = man
554
+
555
+ # The MAN_EXTENSION tag determines the extension that is added to
556
+ # the generated man pages (default is the subroutine's section .3)
557
+
558
+ MAN_EXTENSION = .3
559
+
560
+ #---------------------------------------------------------------------------
561
+ # Configuration options related to the preprocessor
562
+ #---------------------------------------------------------------------------
563
+
564
+ # If the ENABLE_PREPROCESSING tag is set to YES (the default) Doxygen will
565
+ # evaluate all C-preprocessor directives found in the sources and include
566
+ # files.
567
+
568
+ ENABLE_PREPROCESSING = YES
569
+
570
+ # If the MACRO_EXPANSION tag is set to YES Doxygen will expand all macro
571
+ # names in the source code. If set to NO (the default) only conditional
572
+ # compilation will be performed. Macro expansion can be done in a controlled
573
+ # way by setting EXPAND_ONLY_PREDEF to YES.
574
+
575
+ MACRO_EXPANSION = NO
576
+
577
+ # If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES
578
+ # then the macro expansion is limited to the macros specified with the
579
+ # PREDEFINED and EXPAND_AS_PREDEFINED tags.
580
+
581
+ EXPAND_ONLY_PREDEF = NO
582
+
583
+ # If the SEARCH_INCLUDES tag is set to YES (the default) the includes files
584
+ # in the INCLUDE_PATH (see below) will be search if a #include is found.
585
+
586
+ SEARCH_INCLUDES = YES
587
+
588
+ # The INCLUDE_PATH tag can be used to specify one or more directories that
589
+ # contain include files that are not input files but should be processed by
590
+ # the preprocessor.
591
+
592
+ INCLUDE_PATH =
593
+
594
+ # You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard
595
+ # patterns (like *.h and *.hpp) to filter out the header-files in the
596
+ # directories. If left blank, the patterns specified with FILE_PATTERNS will
597
+ # be used.
598
+
599
+ INCLUDE_FILE_PATTERNS =
600
+
601
+ # The PREDEFINED tag can be used to specify one or more macro names that
602
+ # are defined before the preprocessor is started (similar to the -D option of
603
+ # gcc). The argument of the tag is a list of macros of the form: name
604
+ # or name=definition (no spaces). If the definition and the = are
605
+ # omitted =1 is assumed.
606
+
607
+ PREDEFINED =
608
+
609
+ # If the MACRO_EXPANSION and EXPAND_PREDEF_ONLY tags are set to YES then
610
+ # this tag can be used to specify a list of macro names that should be expanded.
611
+ # The macro definition that is found in the sources will be used.
612
+ # Use the PREDEFINED tag if you want to use a different macro definition.
613
+
614
+ EXPAND_AS_DEFINED =
615
+
616
+ #---------------------------------------------------------------------------
617
+ # Configuration::addtions related to external references
618
+ #---------------------------------------------------------------------------
619
+
620
+ # The TAGFILES tag can be used to specify one or more tagfiles.
621
+
622
+ TAGFILES =
623
+
624
+ # When a file name is specified after GENERATE_TAGFILE, doxygen will create
625
+ # a tag file that is based on the input files it reads.
626
+
627
+ GENERATE_TAGFILE =
628
+
629
+ # If the ALLEXTERNALS tag is set to YES all external classes will be listed
630
+ # in the class index. If set to NO only the inherited external classes
631
+ # will be listed.
632
+
633
+ ALLEXTERNALS = NO
634
+
635
+ # The PERL_PATH should be the absolute path and name of the perl script
636
+ # interpreter (i.e. the result of `which perl').
637
+
638
+ PERL_PATH = /usr/bin/perl
639
+
640
+ #---------------------------------------------------------------------------
641
+ # Configuration options related to the dot tool
642
+ #---------------------------------------------------------------------------
643
+
644
+ # If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is
645
+ # available from the path. This tool is part of Graphviz, a graph visualization
646
+ # toolkit from AT&T and Lucent Bell Labs. The other options in this section
647
+ # have no effect if this option is set to NO (the default)
648
+
649
+ HAVE_DOT = NO
650
+
651
+ # If the CLASS_GRAPH and HAVE_DOT tags are set to YES then doxygen
652
+ # will generate a graph for each documented class showing the direct and
653
+ # indirect inheritance relations. Setting this tag to YES will force the
654
+ # the CLASS_DIAGRAMS tag to NO.
655
+
656
+ CLASS_GRAPH = YES
657
+
658
+ # If the COLLABORATION_GRAPH and HAVE_DOT tags are set to YES then doxygen
659
+ # will generate a graph for each documented class showing the direct and
660
+ # indirect implementation dependencies (inheritance, containment, and
661
+ # class references variables) of the class with other documented classes.
662
+
663
+ COLLABORATION_GRAPH = YES
664
+
665
+ # If the ENABLE_PREPROCESSING, INCLUDE_GRAPH, and HAVE_DOT tags are set to
666
+ # YES then doxygen will generate a graph for each documented file showing
667
+ # the direct and indirect include dependencies of the file with other
668
+ # documented files.
669
+
670
+ INCLUDE_GRAPH = YES
671
+
672
+ # If the ENABLE_PREPROCESSING, INCLUDED_BY_GRAPH, and HAVE_DOT tags are set to
673
+ # YES then doxygen will generate a graph for each documented header file showing
674
+ # the documented files that directly or indirectly include this file
675
+
676
+ INCLUDED_BY_GRAPH = YES
677
+
678
+ # If the GRAPHICAL_HIERARCHY and HAVE_DOT tags are set to YES then doxygen
679
+ # will graphical hierarchy of all classes instead of a textual one.
680
+
681
+ GRAPHICAL_HIERARCHY = YES
682
+
683
+ # The tag DOT_PATH can be used to specify the path where the dot tool can be
684
+ # found. If left blank, it is assumed the dot tool can be found on the path.
685
+
686
+ DOT_PATH =
687
+
688
+ # The MAX_DOT_GRAPH_WIDTH tag can be used to set the maximum allowed width
689
+ # (in pixels) of the graphs generated by dot. If a graph becomes larger than
690
+ # this value, doxygen will try to truncate the graph, so that it fits within
691
+ # the specified constraint. Beware that most browsers cannot cope with very
692
+ # large images.
693
+
694
+ MAX_DOT_GRAPH_WIDTH = 1024
695
+
696
+ # The MAX_DOT_GRAPH_HEIGHT tag can be used to set the maximum allows height
697
+ # (in pixels) of the graphs generated by dot. If a graph becomes larger than
698
+ # this value, doxygen will try to truncate the graph, so that it fits within
699
+ # the specified constraint. Beware that most browsers cannot cope with very
700
+ # large images.
701
+
702
+ MAX_DOT_GRAPH_HEIGHT = 1024
703
+
704
+ # If the GENERATE_LEGEND tag is set to YES (the default) Doxygen will
705
+ # generate a legend page explaining the meaning of the various boxes and
706
+ # arrows in the dot generated graphs.
707
+
708
+ GENERATE_LEGEND = YES
709
+
710
+ #---------------------------------------------------------------------------
711
+ # Configuration::addtions related to the search engine
712
+ #---------------------------------------------------------------------------
713
+
714
+ # The SEARCHENGINE tag specifies whether or not a search engine should be
715
+ # used. If set to NO the values of all tags below this one will be ignored.
716
+
717
+ SEARCHENGINE = NO
718
+
719
+ # The CGI_NAME tag should be the name of the CGI script that
720
+ # starts the search engine (doxysearch) with the correct parameters.
721
+ # A script with this name will be generated by doxygen.
722
+
723
+ CGI_NAME = search.cgi
724
+
725
+ # The CGI_URL tag should be the absolute URL to the directory where the
726
+ # cgi binaries are located. See the documentation of your http daemon for
727
+ # details.
728
+
729
+ CGI_URL =
730
+
731
+ # The DOC_URL tag should be the absolute URL to the directory where the
732
+ # documentation is located. If left blank the absolute path to the
733
+ # documentation, with file:// prepended to it, will be used.
734
+
735
+ DOC_URL =
736
+
737
+ # The DOC_ABSPATH tag should be the absolute path to the directory where the
738
+ # documentation is located. If left blank the directory on the local machine
739
+ # will be used.
740
+
741
+ DOC_ABSPATH =
742
+
743
+ # The BIN_ABSPATH tag must point to the directory where the doxysearch binary
744
+ # is installed.
745
+
746
+ BIN_ABSPATH = /usr/local/bin/
747
+
748
+ # The EXT_DOC_PATHS tag can be used to specify one or more paths to
749
+ # documentation generated for other projects. This allows doxysearch to search
750
+ # the documentation for these projects as well.
751
+
752
+ EXT_DOC_PATHS =