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
  
// This is a roxen module. Copyright © 2000 - 2001, Roxen IS. 
 
// This is a small sample module intended to show how a newstyle tag 
// is written. Note that this is only a very brief overview and that 
// the new parser is still under development and incompatible changes 
// might be done in the future. 
 
// See fnord.pike for more information of what this tag does. 
 
// This variable is shown in the configinterface as the version of the module. 
constant cvs_version = "$Id: newstyle_fnord.pike,v 1.12 2001/09/03 18:05:11 nilsson Exp $"; 
 
// Tell Roxen that this module is threadsafe. 
constant thread_safe=1; 
 
// Inherit code that is needed in every module. 
inherit "module"; 
 
 
// moduke.h must be included to use the LOCALE macro below. 
#include <module.h> 
// Some defines for the translation system 
//  
//<locale-token project="mod_fnord">LOCALE</locale-token> 
#define LOCALE(X,Y)   _DEF_LOCALE("mod_fnord",X,Y) 
// end of the locale related stuff 
 
 
// Define the fnord tag class. It must begin with "Tag". 
class TagFnord { 
  inherit RXML.Tag; 
 
  // This constant tells the parser that the tag should be called "fnord". 
  constant name  = "fnord"; 
 
  // Declare the type of the attribute, which happens to be optional. 
  // Since we declare it to be text, we really don't need this line to 
  // get things to work. 
  mapping(string:RXML.Type) opt_arg_types = ([ "alt" : RXML.t_text(RXML.PEnt) ]); 
 
  // This class is where all the action are. 
  class Frame { 
    inherit RXML.Frame; 
 
    // When the parser starts to parse the tag it calls 
    // do_enter. We get a normal request object as argument. 
    // We also have an args mapping at our disposal, containing 
    // the attributes given to the tag. 
 
    // When do_enter has been called the function do_iterate 
    // will be called. If do_iterate is a number, as in this case, 
    // the contents will be iterated that number of times. 
 
    // Finally we want to set the return value if the attribute 
    // alt is set. We do this by modifying the result string. 
 
    array do_enter(RequestID id) { 
      if(id->prestate->fnord) 
        do_iterate=0; 
      else { 
        if(args->alt) 
          result=args->alt; 
        do_iterate=-1; 
      } 
      return 0; 
    } 
 
    int do_iterate; 
  } 
} 
 
 
// Some constants to register the module in the RXML parser. 
 
constant module_type = MODULE_TAG; 
LocaleString module_name = LOCALE(3,"Newstyle Fnord!"); 
LocaleString module_doc  = 
  LOCALE(4,"Adds an extra container tag, &lt;fnord&gt; that's supposed " 
         "to make things invisible unless the \"fnord\" prestate is present." 
         "<p>This module is here as an example of how to write a " 
         "very simple newstyle RXML-parsing module.</p>"); 
 
// Last, but not least, we want a documentation that can be integrated in the 
// online manual. The mapping tagdoc maps from container names to it's description. 
 
// Include this is if you use the TAGDOC system. 
#include <module.h> 
 
TAGDOCUMENTATION; 
#ifdef manual 
constant tagdoc=(["fnord":#"<desc cont>The fnord container tag hides its " 
  "contents for the user, unless the fnord prestate is used.</desc>" 
  "<attr name=alt value=string>An alternate text that should be written " 
  "in place of the hidden text.</attr>"]); 
#endif