File: rot.tcl

package info (click to toggle)
tcllib 1.20%2Bdfsg-1
  • links: PTS
  • area: main
  • in suites: bullseye
  • size: 68,064 kB
  • sloc: tcl: 216,842; ansic: 14,250; sh: 2,846; xml: 1,766; yacc: 1,145; pascal: 881; makefile: 107; perl: 84; f90: 84; python: 33; ruby: 13; php: 11
file content (95 lines) | stat: -rw-r--r-- 2,500 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# -*- tcl -*-
# # ## ### ##### ######## #############
# (C) 2009 Andreas Kupries

# @@ Meta Begin
# Package tcl::transform::rot 1
# Meta as::author {Andreas Kupries}
# Meta as::copyright 2009
# Meta as::license BSD
# Meta description Implementation of a rot
# Meta description encryption transformation. Based on Tcl
# Meta description 8.6's transformation reflection support.
# Meta description The key byte is
# Meta description configured at construction time. Exports
# Meta description a single command adding a new
# Meta description transformation of this type to a channel.
# Meta description Two arguments, the channel to extend,
# Meta description plus the key byte.
# Meta description No result.
# Meta platform tcl
# Meta require tcl::transform::core
# Meta require {Tcl 8.6}
# @@ Meta End

# # ## ### ##### ######## #############

package require Tcl 8.6
package require tcl::transform::core

# # ## ### ##### ######## #############

namespace eval ::tcl::transform {}

proc ::tcl::transform::rot {chan key} {
    ::chan push $chan [rot::implementation new $key]
}

oo::class create ::tcl::transform::rot::implementation {
    superclass tcl::transform::core ;# -> initialize, finalize, destructor

    # This transformation is intended for streaming operation. Seeking
    # the channel while it is active may cause undesirable
    # output. Proper behaviour may require the destruction of the
    # transform before seeking.

    method write {c data} {
	return [my Rot $data $key]
    }

    method read {c data} {
	return [my Rot $data $ikey]
    }

    # # ## ### ##### ######## #############

    constructor {thekey} {
	set key [expr {$thekey % 26}]
	set ikey [expr {26 - $key}]
	return
    }

    # # ## ### ##### ######## #############

    variable key ikey

    # # ## ### ##### ######## #############

    method Rot {data key} {
	# rot'ation is done byte-wise. Note that we are having binary
	# data at this point, making it necessary to convert into
	# numbers (scan), and back (binary format).

	set result {}
	foreach d [split $data {}] {
	    set dx [scan $d %c]
	    if {(65 <= $dx)  && ($dx <= 90)} {
		set n [binary format c \
			   [expr { (($dx - 65 + $key) % 26) + 65 }]]
	    } elseif {(97 <= $dx) && ($dx <= 122)} {
		set n [binary format c \
			   [expr { (($dx - 97 + $key) % 26) + 97 }]]
	    } else {
		set n $d
	    }

	    append result $n
		
	}
	return $result
    }
}

# # ## ### ##### ######## #############
package provide tcl::transform::rot 1
return