source: general/prog/vala.xml@ 948ffd7b

12.1 ken/TL2024 lazarus plabs/newcss rahul/power-profiles-daemon trunk xry111/llvm18
Last change on this file since 948ffd7b was 3525199c, checked in by Douglas R. Reno <renodr@…>, 6 months ago

Typo fixes from rhubarbpieguy

  • Property mode set to 100644
File size: 8.3 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY vala-download-http "&gnome-download-http;/vala/&vala-major-version;/vala-&vala-version;.tar.xz">
8 <!ENTITY vala-download-ftp " ">
9 <!ENTITY vala-md5sum "30dea3532368e3357d642b64c8a1f473">
10 <!ENTITY vala-size "3.8 MB">
11 <!ENTITY vala-buildsize "160 MB (add 18 MB for tests)">
12 <!ENTITY vala-time "0.5 SBU (add 1.0 SBU for tests; both using parallelism=4)">
13]>
14
15<sect1 id="vala" xreflabel="Vala-&vala-version;">
16 <?dbhtml filename="vala.html"?>
17
18 <title>Vala-&vala-version;</title>
19
20 <indexterm zone="vala">
21 <primary sortas="a-Vala">Vala</primary>
22 </indexterm>
23
24 <sect2 role="package">
25 <title>Introduction to Vala</title>
26
27 <para>
28 <application>Vala</application> is a new programming language that
29 aims to bring modern programming language features to
30 <application>GNOME</application> developers without imposing any
31 additional runtime requirements and without using a different ABI
32 compared to applications and libraries written in C.
33 </para>
34
35 &lfs120_checked;
36
37 <bridgehead renderas="sect3">Package Information</bridgehead>
38 <itemizedlist spacing="compact">
39 <listitem>
40 <para>
41 Download (HTTP): <ulink url="&vala-download-http;"/>
42 </para>
43 </listitem>
44 <listitem>
45 <para>
46 Download (FTP): <ulink url="&vala-download-ftp;"/>
47 </para>
48 </listitem>
49 <listitem>
50 <para>
51 Download MD5 sum: &vala-md5sum;
52 </para>
53 </listitem>
54 <listitem>
55 <para>
56 Download size: &vala-size;
57 </para>
58 </listitem>
59 <listitem>
60 <para>
61 Estimated disk space required: &vala-buildsize;
62 </para>
63 </listitem>
64 <listitem>
65 <para>
66 Estimated build time: &vala-time;
67 </para>
68 </listitem>
69 </itemizedlist>
70
71 <bridgehead renderas="sect3">Vala Dependencies</bridgehead>
72
73 <bridgehead renderas="sect4">Required</bridgehead>
74 <para role="required">
75 <xref linkend="glib2"/>
76 </para>
77
78 <bridgehead renderas="sect4">Recommended</bridgehead>
79 <para role="recommended">
80 <xref linkend="graphviz"/> (Required for valadoc)
81 </para>
82
83 <bridgehead renderas="sect4">Optional</bridgehead>
84 <para role="optional">
85 <xref linkend="dbus"/> (Required for the tests),
86 <xref linkend="libxslt"/> (Required for generating the documentation),
87 <ulink url="https://ftpmirror.gnu.org/gnu/help2man/">help2man</ulink>,
88 <ulink url="https://github.com/relaxng/jing-trang">jing</ulink>, and
89 <ulink url="https://weasyprint.org/">weasyprint</ulink>
90 </para>
91
92 </sect2>
93
94 <sect2 role="installation">
95 <title>Installation of Vala</title>
96
97 <!-- https://gitlab.gnome.org/GNOME/vala/-/issues/1485 -->
98 <!-- Fixed in vala-0.56.14
99 <para>
100 At first, fix an issue causing <command>vapigen</command> to crash
101 building some packages (for example NetworkManager):
102 </para>
103
104<screen><userinput>sed -e "/next_pos =/s/$/ \
105 char buf[16]; \
106 Memory.copy (buf, next_pos, \
107 (end - next_pos >= buf.length ? buf.length - 1 : end - next_pos));/" \
108 -e 's/(string) next_pos/(string) buf/' \
109 -i vala/valamarkupreader.vala</userinput></screen>
110 -->
111
112 <para>
113 Install <application>Vala</application> by running the following
114 commands:
115 </para>
116
117<screen><userinput>./configure --prefix=/usr &amp;&amp;
118make</userinput></screen>
119
120 <para>
121 To test the results, issue: <command>make check</command>.
122 </para>
123
124 <para>
125 Now, as the <systemitem class="username">root</systemitem> user:
126 </para>
127
128<screen role="root"><userinput>make install</userinput></screen>
129
130 </sect2>
131
132 <sect2 role="commands">
133 <title>Command Explanations</title>
134
135 <para>
136 <option>bootstrap</option>: This <command>make</command>
137 target forces the building system to build the package twice and use
138 the <command>vala</command> executable produced in the first build
139 to regenerate the <filename class="extension">.c</filename> files
140 from the <filename class="extension">.vala</filename> files if needed.
141 If a <command>vala</command> executable is not installed yet and
142 you've modified any <filename class="extension">.vala</filename> files
143 in the source tree, run <command>make bootstrap</command> instead of
144 <command>make</command>.
145 </para>
146
147 <para>
148 <option>--disable-valadoc</option>: This option is
149 required if <xref linkend="graphviz"/> is not installed.
150 </para>
151 </sect2>
152
153 <sect2 role="content">
154 <title>Contents</title>
155
156 <segmentedlist>
157 <segtitle>Installed Programs</segtitle>
158 <segtitle>Installed Library</segtitle>
159 <segtitle>Installed Directories</segtitle>
160
161 <seglistitem>
162 <seg>
163 vala,
164 vala-&vala-major-version;,
165 valac,
166 valadoc,
167 vala-gen-introspect, and
168 vapigen (symlinks);
169
170 valac-&vala-major-version;,
171 valadoc-&vala-major-version;,
172 vala-gen-introspect-&vala-major-version;, and
173 vapigen-&vala-major-version;
174 </seg>
175 <seg>
176 libvala-&vala-major-version;.so and
177 libvaladoc-&vala-major-version;.so
178 </seg>
179 <seg>
180 /usr/include/vala-&vala-major-version;,
181 /usr/include/valadoc-&vala-major-version;,
182 /usr/lib/vala-&vala-major-version;,
183 /usr/lib/valadoc-&vala-major-version;,
184 /usr/share/vala,
185 /usr/share/vala-&vala-major-version;,
186 /usr/share/valadoc-&vala-major-version;, and
187 /usr/share/devhelp/books/vala-&vala-major-version;
188 </seg>
189 </seglistitem>
190 </segmentedlist>
191
192 <variablelist>
193 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
194 <?dbfo list-presentation="list"?>
195 <?dbhtml list-presentation="table"?>
196
197 <varlistentry id="valac">
198 <term><command>valac</command></term>
199 <listitem>
200 <para>
201 is a compiler that translates <application>Vala</application>
202 source code into C source and header files
203 </para>
204 <indexterm zone="vala valac">
205 <primary sortas="b-valac">valac</primary>
206 </indexterm>
207 </listitem>
208 </varlistentry>
209
210 <varlistentry id="valadoc">
211 <term><command>valadoc</command></term>
212 <listitem>
213 <para>
214 is a documentation generator for generating API documentation
215 from <application>Vala</application> source code based on libvala
216 </para>
217 <indexterm zone="vala valadoc">
218 <primary sortas="b-valadoc">valadoc</primary>
219 </indexterm>
220 </listitem>
221 </varlistentry>
222
223 <varlistentry id="vala-gen-introspect">
224 <term><command>vala-gen-introspect</command></term>
225 <listitem>
226 <para>
227 generates a GI file for GObject and
228 <application>GLib</application> based packages
229 </para>
230 <indexterm zone="vala vala-gen-introspect">
231 <primary sortas="b-vala-gen-introspect">vala-gen-introspect</primary>
232 </indexterm>
233 </listitem>
234 </varlistentry>
235
236 <varlistentry id="vapigen">
237 <term><command>vapigen</command></term>
238 <listitem>
239 <para>
240 is an utility which generates <application>Vala</application> API
241 (VAPI) files from GI files
242 </para>
243 <indexterm zone="vala vapigen">
244 <primary sortas="b-vapigen">vapigen</primary>
245 </indexterm>
246 </listitem>
247 </varlistentry>
248
249 <varlistentry id="libvala">
250 <term><filename class="libraryfile">libvala-&vala-major-version;.so</filename></term>
251 <listitem>
252 <para>
253 contains the <application>Vala</application> API functions
254 </para>
255 <indexterm zone="vala libvala">
256 <primary sortas="c-libvala">libvala-&vala-major-version;.so</primary>
257 </indexterm>
258 </listitem>
259 </varlistentry>
260
261 </variablelist>
262
263 </sect2>
264
265</sect1>
Note: See TracBrowser for help on using the repository browser.