.ig common.roff This file is part of groff, the GNU roff type-setting system. Copyright (C) 2010-2020 Free Software Foundation, Inc. written by Joachim Walsdorff . groff is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. groff is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . .. . . .ds common common.roff\" name for diagnostic messages .mso hdtbl.tmac\" load table macros . .\" ****************************************************************** .\" ** Some macros and the page setup used by the examples ** .\" ****************************************************************** . .\" ****************************************************************** .\" ** Header macro for the examples ** .\" ****************************************************************** .de H . nr *w* (17 * \w\\$* / 10 + 4n) . TBL border=1n \ bc=yellow \ bgc=red4 \ fgc=yellow \ csp=0 \ fst=TB \ "fsz=1.7 1.5" \ hal=c \ tal=c \ "width=(\\n[*w*]+4n) 16)) \ . tm \\*[common]: \\n[.F]:\\n[.c]: d2x: invalid base '\\$2' . el \ . nr b# \\$2 . \}\} . el \ . nr b# 16 . . nr xb# 1 . . ie (\\n[b#] == 1) \{\ . nr dec# +1 . while \\n-[dec#] \ . as hex# |\" . \} . el \{\ . while (\\n[dec#] - \\n[xb#]) \{\ . nr xb# (\\n[xb#] * \\n[b#]) . nr j# +1 . \} . . while (\\n+[i#] < \\n[j#]) \{\ . nr ** (\\n[dec#] / \\n[xb#]) . as hex# \\*[d2x-\\n[**]]\" . nr dec# (\\n[dec#] - (\\n[xb#] * \\n[**])) . nr xb# (\\n[xb#] / \\n[b#]) . \} . \} . . \" strip leading zero, if any . ds * \\*[hex#]\" . substring * 0 0 . if "\\*[*]"0" \ . substring hex# 1 -1 . . if (\\$1 < 0) \ . ds hex# -\\*[hex#]\" . . if !"\\$3"" \{\ . ie !\A\\$3 \ . tm \\*[common]: \\n[.F]:\\n[.c]: d2x: invalid string name '\\$3' . el \ . ds \\$3 \\*[hex#]\" . \} .. . . .\" Utility macro: .random# .\" .random-seed seed1 seed2 .\" .\" Return pseudo-random numbers in the range 0..0xFFFFFF, .\" represented as the concatenation of '#' and six .\" hexadecimal digits, in the string '#random'. The .\" macro 'random-seed' can be used to set seed values, .\" which should be integers in the range 1..2147483562 and .\" 1..2147483398 for 'seed1' and 'seed2', respectively .\" (the macro applies a modulo operation to assure this .\" range). If 'random-seed' isn't called the registers .\" start at some constant, arbitrary values. .\" .\" The used generator is presented in L'Ecuyer's 1988 paper .\" 'Efficient and Portable Combined Random Number .\" Generators', which combines two Multiplicative Linear .\" Congruential Generators (MLCGs) to achieve a period of .\" 2.3*10^18. .\" .\" Since this just generates example output, .\" we don't need good randomness. . .de random-seed . if !(\\n[.$] == 2) \{\ . tm \\*[common]: random-seed: Invalid number of arguments. . tm \\*[common]: usage: '.random-seed seed1 seed2' . return . \} . . nr random-s1 (\\$1 % 2147483562) . nr random-s2 (\\$2 % 2147483398) .. .random-seed 131545532 19201711 . . .de random# . nr * (\\n[random-s1] / 53668) . nr random-s1 (40014 * (\\n[random-s1] - (\\n[*] * 53668)) \ - (\\n[*] * 12211)) . if !\\n[random-s1] \ . nr random-s1 +2147483563 . . nr * (\\n[random-s2] / 52774) . nr random-s2 (40692 * (\\n[random-s2] - (\\n[*] * 52774)) \ - (\\n[*] * 3791)) . if !\\n[random-s2] \ . nr random-s2 +2147483399 . . nr * (\\n[random-s1] - \\n[random-s2]) . if (\\n[*] < 1) \ . nr * +2147483562 . . \" reduce the result to the leftmost 24 bits . nr * (\\n[*] / 128) . . d2x \\n[*] . ds hex# 000000\\*[hex#]\" . substring hex# -6 . ds #random #\\*[hex#]\" .. . . .\" ****************************************************************** .\" ** minimal Page setup ** .\" ****************************************************************** . .nr s \n[.ps] .nr v \n[.v] .nr p \n[.p] .nr o \n[.o] .nr l 6.6i \" set text width .ll \n[t*l]u .nr o 2c \" set offset .po \n[o]u .nr p 29.7c \" set paper length (A4) .pl \n[p]u .nr tH 1i \" set top margin .sp |\n[tH]u . .ds t*HM //arbitrary text for page header, except on the first page//\" .ds t*BM //arbitrary text for page footer, except on the last page/\\n[%]/\" . .ev 99 .lt \n[t*l]u .ev . . .de HM . sp |.5i \" print header in top margin . tl \\*[t*HM] . sp |\\n[tH]u . ev .. . . .de BM . ev 99 . sp |(\\n[p]u - .5i) \" print footer in bottom margin . tl \\*[t*BM] . bp .. . . .de EM . rm BM \" no page number at bottom of last page . t*EM .. . . .wh 0 HM .wh 0-1.5i BM .em EM . .\" Some packages (-mm) define their own .SP macro. .\" Use ours if another one isn't already available. .if !d SP .als SP t*SP . .if "\n[.m]"" \ . gcolor black .if "\n[.M]"" \ . fcolor white . .\" Local Variables: .\" mode: nroff .\" fill-column: 72 .\" End: .\" vim: set filetype=groff textwidth=72: