File: trees.ld

package info (click to toggle)
cuyo 2.1.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 10,756 kB
  • sloc: cpp: 12,451; ml: 6,341; sh: 1,228; pascal: 754; yacc: 558; makefile: 261; lex: 244; perl: 204; sed: 5
file content (105 lines) | stat: -rw-r--r-- 2,996 bytes parent folder | download | duplicates (2)
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
101
102
103
104
105
#
#   Copyright 2010-2012 by Mark Weyer
#   Maintenance modifications 2014 by the cuyo developers
#
#   This program 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 2 of the License, or
#   (at your option) any later version.
#
#   This program 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, write to the Free Software
#   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
#

Trees2 = {
  name = "Holes"
  # TRANSLATORS: "singly connected", or simply connected is a term from
  # mathematics, more specifically topology
  name[geek] = "Singly connected"
  author = "Mark Weyer"
  description = "Groups with holes explode."
  # TRANSLATORS: "complex", "nonpositive" and "Euler characteristic" are terms
  # from mathematics. "Complex" is here used in the sense of simplicial
  # complexes or CW complexes.
  description[geek] = "Complexes with nonpositive Euler characteristic explode."
  anzahl[easy] = 3
  anzahl = 4
  anzahl[hard] = 5
  w_loch[easy] = 1000000
  w_loch = 100
  w_loch[hard] = 50
  pics = Graph * <anzahl>
  startpic = mtrGras.xpm
  greypic = mtrGrau.xpm
  neighbours = <neighbours_hex6>
  startdist[easy] = "..**..*...","****..***."
  startdist = "......*...","..**..***.","****..****"
  startdist[hard] = "..**..*...","****..***.","****..****"
  numexplode = 0

  <<
    var doppel;

    semiglobal = {
      if doppel -> {
        message("Multiple holes");
        bonus(300);
      };
      doppel=0;
    };
  >>

  Graph = {
    pics = mtr1.xpm, mtr2.xpm, mtr3.xpm, mtr4.xpm, mtr5.xpm
    <<
      Graph = {
        if exploding==1 && size>0 -> doppel@@=1;

        weight = 1????? + ?1???? + ?????1 - 1 - 11???? - 1????1;
        file = kind-Graph;
        switch {
          1???11 -> F;
	  1???01 -> E;
          1????0 -> D;
          0???11 -> B;
          0???01 -> C;
          0????0 -> A;
        };
        if pos%3==1 -> qu=Q_BL_TL else -> qu=Q_TL; *;
        switch {
          111??? -> D;
	  110??? -> E;
          10???? -> F;
          011??? -> B;
          010??? -> A;
          00???? -> C;
        };
        if pos%3==1 -> qu=Q_BR_TR else -> qu=Q_TR; *;
        switch {
          ???111 -> E;
	  ???110 -> C;
          ???10? -> A;
          ???011 -> F;
          ???010 -> B;
          ???00? -> D;
        };
        if pos%3==1 -> qu=Q_TL_BL else -> qu=Q_BL; *;
        switch {
          ?111?? -> E;
	  ?011?? -> A;
          ??01?? -> C;
          ?110?? -> D;
          ?010?? -> B;
          ??00?? -> F;
        };
        if pos%3==1 -> qu=Q_TR_BR else -> qu=Q_BR; *;
      };
    >>
  }
}