summaryrefslogtreecommitdiff
path: root/ipl/gprogs/findrpt.icn
blob: de9a6a26727e9712b1c14de3bdf6087f8caccea5 (plain)
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
96
97
98
99
100
############################################################################
#
#	File:     findrpt.icn
#
#	Subject:  Program to find smallest repeat in a repeat pattern
#
#	Author:   Ralph E. Griswold
#
#	Date:     December 5, 1995
#
############################################################################
#
#   This file is in the public domain.
#
############################################################################
#
#  This program produces the smallest motif in an image that will tile
#  to the image.
#
#  The image to be processed must be a "true" repeat -- pixel for pixel.
#
#  The options supported are:
#
#	-n s	suffix for output image, default _t.  The suffix is
#  		appended to the basename of the input image, as in
#		foo.gif -> foo_t.gif.
#
#	-s	show size; default produce image
#
#  Warning:  This program is *very* slow.
#
#
############################################################################
#
#  Requires:  Version 9 graphics
#
############################################################################
#
#  Links:  numbers, options, repetit, wopen
#
############################################################################

link numbers
link options
link repetit
link wopen

procedure main(args)
   local width, height, x, y, row, col, rows, cols, w, h, suffix, file
   local basename, opts

   opts := options(args, "n:s")
   suffix := \opts["s"] | "_t"

   every file := !args do {
      WOpen("canvas=hidden", "image=" || file) | {
         write(&errout, "*** cannot open ", file)
         next
         }
      file ? {
         basename := 1(tab(find(".gif")), move(0)) | "unname"
         }
      width := WAttrib("width")
      height := WAttrib("height")
   
      rows := []
      every y := 0 to height - 1 do {
         row := []
         every put(row,Pixel(0, y, width, 1))
         put(rows, repetit(row))
         }
      h := lcml ! rows
      h >:= height
   
      cols := []
      every x := 0 to width - 1 do {
         col := []
         every put(col, Pixel(x, 0, 1, height))
         put(cols, repetit(col))
         }
      w := lcml ! cols
      w >:= width

      if w = width & h = height then {
         write(&errout, file, " has no subrepeat")
         next
         }
   
      if \opts["s"] then
         write(file, ": ", w, "x", h)
      else
         WriteImage(basename || suffix || ".gif", 0, 0, w, h) | {
         write(&errout, "*** cannot write image for ", file)
         write(&errout, "w=", w, " h=", h)
         }
      WClose(&window)
      &window := &null
      }

end