File: data_validation.xml

package info (click to toggle)
libgda5 5.2.10-8
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 76,168 kB
  • sloc: ansic: 495,319; xml: 10,486; yacc: 5,165; sh: 4,451; makefile: 4,095; php: 1,416; java: 1,300; javascript: 1,298; python: 896; sql: 879; perl: 116
file content (133 lines) | stat: -rw-r--r-- 5,823 bytes parent folder | download | duplicates (8)
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
<?xml version="1.0"?>
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
          "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"[
<!ENTITY LIBGDA          "<application>Libgda</application>">
]>
<sect1 id="data-validation">
  <title>Custom data validation</title>
  <para>
    &LIBGDA; allows the programmer to specify some rules of his own to control data changes (for example
    business rules). This section details the various control points, how to implement them, and how or when
    they are invoked.
  </para>

  <sect2 id="data-validation-GdaHolder">
    <title>GdaHolder controls</title>
    <para>
      The <link linkend="GdaHolder">GdaHolder</link> object holds a single value 
      (as a <link linkend="GValue">GValue</link>). When that value is to be modified, using for example
      <link linkend="gda-holder-set-value">gda_holder_set_value()</link>, 
      then the proposed new value's validation process is executed:
      <orderedlist>
	<listitem><para>it is determined if the proposed new value is of the correct type and
	    if it respects the holder's policy (for example a NULL value won't be accepted if 
	    the holder can't be NULL). If the proposed value does not respect the policy, then
	    the value change will be rejected</para></listitem>
	<listitem><para>the <link linkend="GdaHolder-validate-change">"validate-change"</link> signal is
	    emitted. If any handler for this signal returns a pointer to a filled <link linkend="GError">GError</link>
	    structure, then the signal's propagation is stopped and the value change will be rejected.</para></listitem>
      </orderedlist>
    </para>
    <para>
      An example illustrating how to use the <link linkend="GdaHolder-validate-change">"validate-change"</link> signal
      is:
      <programlisting>
static GError *
my_validate_change_cb (GdaHolder *h, const GValue *value, gpointer data)
{
        GError *error = NULL;

        /* for example check that value is inferior to 5 and not NULL */
        if (gda_value_is_null (value)) 
                g_set_error (&amp;error, YOUR_DOMAIN, YOUR_CODE, "NULL values are not allowed!");
        else if (g_value_get_int (value) &gt;= 5)
                g_set_error (&amp;error, YOUR_DOMAIN, YOUR_CODE, "Value sould be inferior to 5");

        return error;
}

{
        GdaHolder *holder;
        GError *error = NULL;
        [...]
        g_signal_connect (G_OBJECT (holder), "validate-change",
                G_CALLBACK (my_validate_change_cb), NULL);
        if (! gda_holder_set_value (holder, value, &amp;error)) {
                g_print ("Error: %s\n", error->message);
                g_error_free (error);
		[...]
	}
}
      </programlisting>
    </para>
    <para>
      <mediaobject>
	<imageobject role="html">
          <imagedata fileref="data_validation_holder.png" format="PNG" contentwidth="100mm"/>
	</imageobject>
	<textobject>
          <phrase>GdaHolder's value change control</phrase>
	</textobject>
      </mediaobject>
    </para>
  </sect2>

  <sect2 id="data-validation-GdaSet">
    <title>GdaSet controls</title>
    <para>
      The <link linkend="GdaSet">GdaSet</link> object is an ordered list (or vector) of values,
      each represented by a <link linkend="GdaHolder">GdaHolder</link> object. One can place controls
      at two key events:
      <itemizedlist>
	<listitem><para>
	    When any value of a <link linkend="GdaHolder">GdaHolder</link> changes, where
	    the <link linkend="GdaSet-validate-holder-change">"validate-holder-change"</link> signal is
	    emitted. If any handler for this signal returns a pointer to a filled <link linkend="GError">GError</link>
	    structure, then the signal's propagation is stopped and the value change will be rejected. This
	    key event allows one to control each holder's value change as they occur.
	</para></listitem>
	<listitem><para>
	    When the <link linkend="gda-set-is-valid">gda_set_is_valid()</link> method is called,
	    the <link linkend="GdaSet-validate-set">"validate-set"</link> signal is
	    emitted. If any handler for this signal returns a pointer to a filled <link linkend="GError">GError</link>
	    structure, then the signal's propagation is stopped and the calling method will return the generated
	    error. This key event allows one to control the validity of a set of values altogether (for example
	    before writing to a table).
	</para></listitem>
      </itemizedlist>
    </para>
    <para>
      <mediaobject>
	<imageobject role="html">
          <imagedata fileref="data_validation_set.png" format="PNG" contentwidth="180mm"/>
	</imageobject>
	<textobject>
          <phrase>GdaSet's changes controls</phrase>
	</textobject>
      </mediaobject>
    </para>
  </sect2>

  <sect2 id="data-validation-GdaDataProxy">
    <title>GdaDataProxy controls</title>
    <para>
      The <link linkend="GdaDataProxy">GdaDataProxy</link> data model allows one to store temporary modifications
      to a data model, and then apply (write to the proxied data model) those modifications row by row. Before
      applying any row modification, the <link linkend="GdaDataProxy">GdaDataProxy</link> data model emits
      the <link linkend="GdaDataProxy-validate-row-changes">"validate-row-changes"</link> signal, and
      if handler for this signal returns a pointer to a filled <link linkend="GError">GError</link>
      structure, then the signal's propagation is stopped and the row's modifications are not applied.
    </para>
    <para>
      <mediaobject>
	<imageobject role="html">
          <imagedata fileref="data_validation_proxy.png" format="PNG" contentwidth="100mm"/>
	</imageobject>
	<textobject>
          <phrase>GdaDataProxy's changes controls</phrase>
	</textobject>
      </mediaobject>
    </para>
  </sect2>
  
</sect1>