aboutsummaryrefslogtreecommitdiff
path: root/doc/plugins/contrib/sar.mdwn
blob: 77c41a95594baa84c9314c2168994f710f3fc0d4 (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
101
102
103
104
105
106
107
108
109
[[!template id=plugin name=sar author="[[VictorMoral]]"]]
[[!tag type/chrome type/slow ]]

The `sar` plugin is useful to make global or local search and replace operations
using common or specific terms.

The characteristics are:

- Support for a global dictionary page (optional but recommended).
- Is possible to replace the first appearance with a text and the rest with
other.

The global dictionary page is like this:

    ## Sites and projects

    - [[!sar search="ikiwiki" first="[IkiWiki](http://ikiwiki.info)" next="_IkiWiki_"]]
    - [[!sar search="debian" first="[Debian](http://debian.org)" next="_Debian_"]]
    - [[!sar search="perl" first="[Perl](http://perl.org)" next="_Perl_"]]
    - [[!sar search="linux" replace="GNU/Linux"]]
   
    ## Persons
    - [[!sar search="joey" first="[Joey Hess](http://ikiwiki.info/users/joey]]" next="_Joey_" ]]
    - [[!sar search="angel" first="[Angel](http://triptico.com)" next="Angel"]]

    ## Technical terms

    - [[!sar search="smtp" first="\[[!wp SMTP]]" next="‘SMTP‘"]]
    - [[!sar search="pop3" first="\[[!wp POP3]]" next="’POP3’"]]

The search expressions must be surrounded by double dashes in a source ikiwiki
page, like this:

    Mis programas están escritos en lenguaje --perl--, funcionando con el 
    sistema --debian--, y mis páginas web funcionan con --ikiwiki-- cuyo autor
    es --joey--.

    --ikiwiki-- es un buen software.

After a filter operation the content is:

    Mis programas están escritos en lenguaje [Perl](http://perl.org),
    funcionando con el sistema [Debian](http://debian.org), y mis páginas web
    funcionan con [IkiWiki](http://ikiwiki.info) cuyo autor es [Joey
    Hess](http://ikiwiki.info/users/joey).

    _IkiWiki_ es un buen software.

_Note_: I chose this syntax because don't clashes with markdown and it is easy to write. 

A _search and replace_ directive has the following parameters:

- `search`: define the text to search.
- `first`: define the replace text in the first match.
- `next`: define the replace text in all matches except the first.
- `replace`: define the replace text in all matches.

Now the code is used at my site without problems, and the author will
appreciate any help with his development or his english. 

## Configuration

The plugin need the following global values:

- `sar_mainpage`: define the global dictionary page. The default value is `sar`.
- `sar_pagespec`: enable the plugin with a selection of pages. The default
value is `*`, but a recommended value is `link(tag/sar)`.

## Synopsis

In a ikiwiki source page we can write this

    \[[!sar search=debian replace="__Debian__"]]

for define a global replace for the term `--debian--` or

    \[[!sar search=ibm first=’[IBM](http://www.ibm.com)’
            next="_IBM_"]]

to define a replace for the first match of the string `--ibm--` and a different
replace for the rest.

## Changelog

### version 0.8

- First functional version with the new sar expressions.

### version 0.7 

- New design for the search expressions.

### version 0.6

- Minor bugfixes in the pages selection.
- Call to add_depends() for every page filtered

### version 0.5

- This is the first functional version.

## Download 

The module can be downloaded from:

- [My personal site](http://taquiones.net/files/misc)
- [My personal Debian repository](http://taquiones.net/files/debian)