Hex Artifact Content

Artifact a953fb49d0ad856571713acfaa54fd67daf87ec6:


0000: 23 21 20 2f 75 73 72 2f 62 69 6e 2f 65 6e 76 20  #! /usr/bin/env 
0010: 74 63 6c 73 68 0a 0a 73 65 74 20 6d 6f 64 75 6c  tclsh..set modul
0020: 75 73 20 31 36 37 37 37 32 35 39 0a 0a 70 72 6f  us 16777259..pro
0030: 63 20 66 69 6c 65 64 5f 68 61 73 68 20 7b 73 74  c filed_hash {st
0040: 72 20 6d 6f 64 7d 20 7b 0a 09 73 65 74 20 72 65  r mod} {..set re
0050: 74 76 61 6c 20 5b 65 78 70 72 20 7b 24 6d 6f 64  tval [expr {$mod
0060: 20 2d 20 31 7d 5d 0a 09 73 65 74 20 70 72 65 76   - 1}]..set prev
0070: 20 5b 65 78 70 72 20 7b 24 6d 6f 64 20 25 20 32   [expr {$mod % 2
0080: 35 35 7d 5d 0a 09 66 6f 72 20 7b 73 65 74 20 69  55}]..for {set i
0090: 64 78 20 30 7d 20 7b 24 69 64 78 20 3c 20 5b 73  dx 0} {$idx < [s
00a0: 74 72 69 6e 67 20 6c 65 6e 67 74 68 20 24 73 74  tring length $st
00b0: 72 5d 7d 20 7b 69 6e 63 72 20 69 64 78 7d 20 7b  r]} {incr idx} {
00c0: 0a 09 09 73 65 74 20 63 75 72 72 20 5b 73 74 72  ...set curr [str
00d0: 69 6e 67 20 69 6e 64 65 78 20 24 73 74 72 20 24  ing index $str $
00e0: 69 64 78 5d 0a 09 09 62 69 6e 61 72 79 20 73 63  idx]...binary sc
00f0: 61 6e 20 24 63 75 72 72 20 48 2a 20 63 75 72 72  an $curr H* curr
0100: 0a 09 09 73 65 74 20 63 75 72 72 20 5b 66 6f 72  ...set curr [for
0110: 6d 61 74 20 25 75 20 30 78 24 63 75 72 72 5d 0a  mat %u 0x$curr].
0120: 0a 09 09 69 66 20 7b 24 63 75 72 72 20 3c 20 33  ...if {$curr < 3
0130: 32 7d 20 7b 0a 09 09 09 73 65 74 20 63 75 72 72  2} {....set curr
0140: 20 5b 65 78 70 72 20 7b 32 35 35 20 2d 20 24 63   [expr {255 - $c
0150: 75 72 72 7d 5d 0a 09 09 7d 20 65 6c 73 65 20 7b  urr}]...} else {
0160: 0a 09 09 09 73 65 74 20 63 75 72 72 20 5b 65 78  ....set curr [ex
0170: 70 72 20 7b 24 63 75 72 72 20 2d 20 33 32 7d 5d  pr {$curr - 32}]
0180: 0a 09 09 7d 0a 0a 09 09 69 66 20 7b 24 70 72 65  ...}....if {$pre
0190: 76 20 3c 20 24 63 75 72 72 7d 20 7b 0a 09 09 09  v < $curr} {....
01a0: 73 65 74 20 64 69 66 66 20 5b 65 78 70 72 20 7b  set diff [expr {
01b0: 24 63 75 72 72 20 2d 20 24 70 72 65 76 7d 5d 0a  $curr - $prev}].
01c0: 09 09 7d 20 65 6c 73 65 20 7b 0a 09 09 09 73 65  ..} else {....se
01d0: 74 20 64 69 66 66 20 5b 65 78 70 72 20 7b 24 70  t diff [expr {$p
01e0: 72 65 76 20 2d 20 24 63 75 72 72 7d 5d 0a 09 09  rev - $curr}]...
01f0: 7d 0a 0a 09 09 73 65 74 20 70 72 65 76 20 24 63  }....set prev $c
0200: 75 72 72 0a 0a 09 09 73 65 74 20 72 65 74 76 61  urr....set retva
0210: 6c 20 5b 65 78 70 72 20 7b 28 24 72 65 74 76 61  l [expr {($retva
0220: 6c 20 3c 3c 20 33 29 20 26 20 30 78 66 66 66 66  l << 3) & 0xffff
0230: 66 66 66 66 7d 5d 0a 09 09 73 65 74 20 72 65 74  ffff}]...set ret
0240: 76 61 6c 20 5b 65 78 70 72 20 7b 24 72 65 74 76  val [expr {$retv
0250: 61 6c 20 5e 20 24 64 69 66 66 7d 5d 0a 09 7d 0a  al ^ $diff}]..}.
0260: 0a 09 73 65 74 20 72 65 74 76 61 6c 20 5b 65 78  ..set retval [ex
0270: 70 72 20 7b 24 72 65 74 76 61 6c 20 25 20 24 6d  pr {$retval % $m
0280: 6f 64 7d 5d 0a 0a 09 72 65 74 75 72 6e 20 24 72  od}]...return $r
0290: 65 74 76 61 6c 0a 0a 7d 0a 0a 73 65 74 20 6d 69  etval..}..set mi
02a0: 6d 65 69 6e 66 6f 66 69 6c 65 20 22 2f 65 74 63  meinfofile "/etc
02b0: 2f 68 74 74 70 64 2f 6d 69 6d 65 2e 74 79 70 65  /httpd/mime.type
02c0: 73 22 0a 0a 73 65 74 20 66 64 20 5b 6f 70 65 6e  s"..set fd [open
02d0: 20 24 6d 69 6d 65 69 6e 66 6f 66 69 6c 65 5d 0a   $mimeinfofile].
02e0: 73 65 74 20 6d 69 6d 65 69 6e 66 6f 20 5b 72 65  set mimeinfo [re
02f0: 61 64 20 24 66 64 5d 0a 63 6c 6f 73 65 20 24 66  ad $fd].close $f
0300: 64 0a 0a 66 6f 72 65 61 63 68 20 6c 69 6e 65 20  d..foreach line 
0310: 5b 73 70 6c 69 74 20 24 6d 69 6d 65 69 6e 66 6f  [split $mimeinfo
0320: 20 22 5c 6e 22 5d 20 7b 0a 09 72 65 67 73 75 62   "\n"] {..regsub
0330: 20 7b 23 2e 2a 7d 20 24 6c 69 6e 65 20 7b 7d 20   {#.*} $line {} 
0340: 6c 69 6e 65 0a 09 73 65 74 20 6c 69 6e 65 20 5b  line..set line [
0350: 73 74 72 69 6e 67 20 74 72 69 6d 20 24 6c 69 6e  string trim $lin
0360: 65 5d 0a 0a 09 69 66 20 7b 24 6c 69 6e 65 20 3d  e]...if {$line =
0370: 3d 20 22 22 7d 20 7b 0a 09 09 63 6f 6e 74 69 6e  = ""} {...contin
0380: 75 65 0a 09 7d 0a 0a 09 73 65 74 20 6c 69 6e 65  ue..}...set line
0390: 20 5b 73 70 6c 69 74 20 24 6c 69 6e 65 5d 0a 0a   [split $line]..
03a0: 09 73 65 74 20 6d 69 6d 65 20 5b 6c 69 6e 64 65  .set mime [linde
03b0: 78 20 24 6c 69 6e 65 20 30 5d 0a 09 73 65 74 20  x $line 0]..set 
03c0: 65 78 74 65 6e 73 69 6f 6e 73 20 5b 6c 72 61 6e  extensions [lran
03d0: 67 65 20 24 6c 69 6e 65 20 31 20 65 6e 64 5d 0a  ge $line 1 end].
03e0: 0a 09 66 6f 72 65 61 63 68 20 65 78 74 65 6e 73  ..foreach extens
03f0: 69 6f 6e 20 24 65 78 74 65 6e 73 69 6f 6e 73 20  ion $extensions 
0400: 7b 0a 09 09 69 66 20 7b 24 65 78 74 65 6e 73 69  {...if {$extensi
0410: 6f 6e 20 3d 3d 20 22 22 7d 20 7b 0a 09 09 09 63  on == ""} {....c
0420: 6f 6e 74 69 6e 75 65 0a 09 09 7d 0a 0a 09 09 73  ontinue...}....s
0430: 65 74 20 65 78 74 65 6e 73 69 6f 6e 69 6e 66 6f  et extensioninfo
0440: 28 24 65 78 74 65 6e 73 69 6f 6e 29 20 24 6d 69  ($extension) $mi
0450: 6d 65 0a 09 7d 0a 7d 0a 0a 66 6f 72 65 61 63 68  me..}.}..foreach
0460: 20 65 78 74 65 6e 73 69 6f 6e 20 5b 61 72 72 61   extension [arra
0470: 79 20 6e 61 6d 65 73 20 65 78 74 65 6e 73 69 6f  y names extensio
0480: 6e 69 6e 66 6f 5d 20 7b 0a 09 73 65 74 20 68 61  ninfo] {..set ha
0490: 73 68 5f 69 64 20 5b 66 69 6c 65 64 5f 68 61 73  sh_id [filed_has
04a0: 68 20 24 65 78 74 65 6e 73 69 6f 6e 20 24 6d 6f  h $extension $mo
04b0: 64 75 6c 75 73 5d 0a 0a 09 6c 61 70 70 65 6e 64  dulus]...lappend
04c0: 20 68 61 73 68 69 6e 66 6f 28 24 68 61 73 68 5f   hashinfo($hash_
04d0: 69 64 29 20 24 65 78 74 65 6e 73 69 6f 6e 0a 0a  id) $extension..
04e0: 7d 0a 70 75 74 73 20 22 5c 74 73 77 69 74 63 68  }.puts "\tswitch
04f0: 20 28 66 69 6c 65 64 5f 68 61 73 68 28 28 63 6f   (filed_hash((co
0500: 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61  nst unsigned cha
0510: 72 20 2a 29 20 70 2c 20 24 6d 6f 64 75 6c 75 73  r *) p, $modulus
0520: 29 29 20 5c 7b 22 0a 66 6f 72 65 61 63 68 20 68  )) \{".foreach h
0530: 61 73 68 20 5b 6c 73 6f 72 74 20 2d 69 6e 74 65  ash [lsort -inte
0540: 67 65 72 20 2d 69 6e 63 72 65 61 73 69 6e 67 20  ger -increasing 
0550: 5b 61 72 72 61 79 20 6e 61 6d 65 73 20 68 61 73  [array names has
0560: 68 69 6e 66 6f 5d 5d 20 7b 0a 09 70 75 74 73 20  hinfo]] {..puts 
0570: 22 5c 74 5c 74 63 61 73 65 20 24 68 61 73 68 3a  "\t\tcase $hash:
0580: 22 0a 09 66 6f 72 65 61 63 68 20 65 78 74 65 6e  "..foreach exten
0590: 73 69 6f 6e 20 24 68 61 73 68 69 6e 66 6f 28 24  sion $hashinfo($
05a0: 68 61 73 68 29 20 7b 0a 09 09 70 75 74 73 20 22  hash) {...puts "
05b0: 5c 74 5c 74 5c 74 69 66 20 28 73 74 72 63 6d 70  \t\t\tif (strcmp
05c0: 28 70 2c 20 5c 22 24 65 78 74 65 6e 73 69 6f 6e  (p, \"$extension
05d0: 5c 22 29 20 3d 3d 20 30 29 20 5c 7b 22 0a 09 09  \") == 0) \{"...
05e0: 70 75 74 73 20 22 5c 74 5c 74 5c 74 5c 74 72 65  puts "\t\t\t\tre
05f0: 74 75 72 6e 28 5c 22 24 65 78 74 65 6e 73 69 6f  turn(\"$extensio
0600: 6e 69 6e 66 6f 28 24 65 78 74 65 6e 73 69 6f 6e  ninfo($extension
0610: 29 5c 22 29 3b 22 0a 09 09 70 75 74 73 20 22 5c  )\");"...puts "\
0620: 74 5c 74 5c 74 5c 7d 22 0a 09 7d 0a 09 70 75 74  t\t\t\}"..}..put
0630: 73 20 22 5c 74 5c 74 5c 74 72 65 74 75 72 6e 28  s "\t\t\treturn(
0640: 46 49 4c 45 44 5f 44 45 46 41 55 4c 54 5f 54 59  FILED_DEFAULT_TY
0650: 50 45 29 3b 22 0a 7d 0a 70 75 74 73 20 22 5c 74  PE);".}.puts "\t
0660: 5c 7d 22 0a                                      \}".