diff --git a/build_linux_package.sh b/build_linux_package.sh
index db9e329..b036c4f 100755
--- a/build_linux_package.sh
+++ b/build_linux_package.sh
@@ -3,7 +3,7 @@
curdir=`pwd`
rm -rf buildtmp
mkdir buildtmp
-LDFLAGS=-static-libstdc++ meson buildtmp --buildtype=release --prefix=/tmp/sernatur --libdir=lib --strip
+LDFLAGS=-static-libstdc++ meson buildtmp -D bundle_libs=true --buildtype=release --prefix=/tmp/sernatur --libdir=lib --strip
ninja -C buildtmp install
rm -rf buildtmp
cp README.md /tmp/sernatur
diff --git a/data/desktop/meson.build b/data/desktop/meson.build
new file mode 100644
index 0000000..c9ea07b
--- /dev/null
+++ b/data/desktop/meson.build
@@ -0,0 +1 @@
+install_data('sernatur.desktop', install_dir: join_paths(get_option('datadir'), 'applications'))
diff --git a/data/sernatur.desktop b/data/desktop/sernatur.desktop
similarity index 100%
rename from data/sernatur.desktop
rename to data/desktop/sernatur.desktop
diff --git a/data/etc/meson.build b/data/etc/meson.build
new file mode 100644
index 0000000..383e9b0
--- /dev/null
+++ b/data/etc/meson.build
@@ -0,0 +1 @@
+install_data('sernatur.conf', install_dir: join_paths(get_option('prefix'), get_option('sysconfdir'), 'sernatur'))
diff --git a/data/etc/sernatur.conf b/data/etc/sernatur.conf
new file mode 100644
index 0000000..8845aa9
--- /dev/null
+++ b/data/etc/sernatur.conf
@@ -0,0 +1,9 @@
+database : {
+ host = "localhost";
+ port = 5432;
+ options = "";
+ gtty = "";
+ db_name = "bdd";
+ login = "bdd";
+ pwd = "bdd";
+};
diff --git a/data/gschema/cl.cromer.ubb.sernatur.gschema.xml b/data/gschema/cl.cromer.ubb.sernatur.gschema.xml
new file mode 100644
index 0000000..f46a80a
--- /dev/null
+++ b/data/gschema/cl.cromer.ubb.sernatur.gschema.xml
@@ -0,0 +1,18 @@
+
+
+
+ "localhost"
+ Host to connect to
+
+ Host to connect to
+
+
+
+ "5432"
+ Port number to use
+
+ Port number to use
+
+
+
+
diff --git a/data/gschema/meson.build b/data/gschema/meson.build
new file mode 100644
index 0000000..b4d2538
--- /dev/null
+++ b/data/gschema/meson.build
@@ -0,0 +1 @@
+install_data('cl.cromer.ubb.sernatur.gschema.xml', install_dir: join_paths(get_option('prefix'), get_option('datadir'), 'glib-2.0', 'schemas'))
diff --git a/data/icons/meson.build b/data/icons/meson.build
new file mode 100644
index 0000000..2ce5335
--- /dev/null
+++ b/data/icons/meson.build
@@ -0,0 +1,17 @@
+install_data('8x8/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/8x8/apps'))
+install_data('16x16/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/16x16/apps'))
+install_data('22x22/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/22x22/apps'))
+install_data('24x24/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/24x24/apps'))
+install_data('32x32/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/32x32/apps'))
+install_data('36x36/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/36x36/apps'))
+install_data('42x42/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/42x42/apps'))
+install_data('48x48/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/48x48/apps'))
+install_data('64x64/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/64x64/apps'))
+install_data('72x72/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/72x72/apps'))
+install_data('96x96/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/96x96/apps'))
+install_data('128x128/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/128x128/apps'))
+install_data('192x192/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/192x192/apps'))
+install_data('256x256/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/256x256/apps'))
+install_data('480x480/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/480x480/apps'))
+install_data('512x512/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/512x512/apps'))
+install_data('512x512/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons'))
diff --git a/data/meson.build b/data/meson.build
index 1e52a2f..ef46c1c 100644
--- a/data/meson.build
+++ b/data/meson.build
@@ -1,19 +1,5 @@
-install_data('sernatur.desktop', install_dir: join_paths(get_option('datadir'), 'applications'))
-install_data('icons/8x8/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/8x8/apps'))
-install_data('icons/16x16/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/16x16/apps'))
-install_data('icons/22x22/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/22x22/apps'))
-install_data('icons/24x24/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/24x24/apps'))
-install_data('icons/32x32/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/32x32/apps'))
-install_data('icons/36x36/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/36x36/apps'))
-install_data('icons/42x42/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/42x42/apps'))
-install_data('icons/48x48/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/48x48/apps'))
-install_data('icons/64x64/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/64x64/apps'))
-install_data('icons/72x72/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/72x72/apps'))
-install_data('icons/96x96/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/96x96/apps'))
-install_data('icons/128x128/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/128x128/apps'))
-install_data('icons/192x192/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/192x192/apps'))
-install_data('icons/256x256/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/256x256/apps'))
-install_data('icons/480x480/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/480x480/apps'))
-install_data('icons/512x512/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons/hicolor/512x512/apps'))
-install_data('icons/512x512/apps/sernatur.png', install_dir: join_paths(get_option('datadir'), 'icons'))
subdir('ui')
+subdir('etc')
+subdir('gschema')
+subdir('desktop')
+subdir('icons')
diff --git a/docs/MER.dia b/doc/MER.dia
similarity index 100%
rename from docs/MER.dia
rename to doc/MER.dia
diff --git a/doc/meson.build b/doc/meson.build
new file mode 100644
index 0000000..433baad
--- /dev/null
+++ b/doc/meson.build
@@ -0,0 +1,36 @@
+docs_enabled = get_option('valadocs')
+valadoc = find_program('valadoc', required: docs_enabled)
+vala_doc_sources = vala_sources
+if docs_enabled
+ valadocs_deps = get_option('valadocs_deps')
+ docs_deps = ['--pkg=gtk+-3.0']
+ docs_deps += ['--pkg=libpq']
+ docs_deps += ['--pkg=libconfig']
+ docs_deps += ['--pkg=posix']
+ if valadocs_deps
+ docs_deps += ['--deps']
+ endif
+ custom_target('valadoc',
+ input: vala_doc_sources,
+ output: 'valadoc',
+ command: [ valadoc,
+ docs_deps,
+ '--use-svg-images',
+ '--doclet=html',
+ '--force',
+ '--package-name=@0@'.format(meson.project_name()),
+ '--package-version=@0@'.format(meson.project_version()),
+ '--vapidir=@0@'.format(join_paths(meson.source_root(), 'src/vapi')),
+ '--directory=@OUTDIR@/valadoc',
+ vala_doc_sources,
+ ],
+ build_by_default: true,
+ install: true,
+ install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name())
+ )
+endif
+
+install_data('trabajoSemestral(E1).pdf', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
+install_data('MER.dia', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
+install_data('../LICENSE', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
+install_data('../README.md', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
diff --git a/docs/trabajoSemestral(E1).pdf b/doc/trabajoSemestral(E1).pdf
similarity index 100%
rename from docs/trabajoSemestral(E1).pdf
rename to doc/trabajoSemestral(E1).pdf
diff --git a/docs/meson.build b/docs/meson.build
deleted file mode 100644
index dab0a81..0000000
--- a/docs/meson.build
+++ /dev/null
@@ -1,50 +0,0 @@
-docs_enabled = get_option('valadocs')
-valadoc = find_program('valadoc', required: docs_enabled)
-if docs_enabled
- docs_deps = get_option('valadocs_deps')
- if docs_deps
- custom_target('valadoc',
- input: vala_sources,
- output: 'valadoc',
- command: [ valadoc,
- '--deps',
- '--use-svg-images',
- '--doclet=html',
- '--force',
- '--package-name=@0@'.format(meson.project_name()),
- '--package-version=@0@'.format(meson.project_version()),
- '--pkg=gtk+-3.0',
- '--pkg=libpq',
- '--vapidir=@0@'.format(join_paths(meson.source_root(), 'src/vapi')),
- '--directory=@OUTDIR@/valadoc',
- vala_sources,
- ],
- build_by_default: true,
- install: true,
- install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name())
- )
- else
- custom_target('valadoc',
- input: vala_sources,
- output: 'valadoc',
- command: [ valadoc,
- '--use-svg-images',
- '--doclet=html',
- '--force',
- '--package-name=@0@'.format(meson.project_name()),
- '--package-version=@0@'.format(meson.project_version()),
- '--pkg=gtk+-3.0',
- '--pkg=libpq',
- '--vapidir=@0@'.format(join_paths(meson.source_root(), 'src/vapi')),
- '--directory=@OUTDIR@/valadoc',
- vala_sources,
- ],
- build_by_default: true,
- install: true,
- install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name())
- )
- endif
-endif
-
-install_data('trabajoSemestral(E1).pdf', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
-install_data('MER.dia', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
diff --git a/git-1.4.0.tar.gz b/git-1.4.0.tar.gz
new file mode 100644
index 0000000..e69de29
diff --git a/meson.build b/meson.build
index 822adc6..8e28b77 100644
--- a/meson.build
+++ b/meson.build
@@ -10,11 +10,12 @@ project('sernatur',
)
add_global_arguments('-DGETTEXT_PACKAGE="sernatur"', language: 'c')
-subdir('po')
+add_project_arguments(['--vapidir',
+ join_paths(meson.current_source_dir(), 'src/vapi')],
+ language: 'vala')
+
+#subdir('po')
subdir('data')
subdir('src')
+#subdir('doc')
subdir('script')
-subdir('docs')
-
-install_data('LICENSE', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
-install_data('README.md', install_dir: join_paths(get_option('datadir'), 'doc', meson.project_name()))
diff --git a/meson_options.txt b/meson_options.txt
index 0b62f85..d0a845f 100644
--- a/meson_options.txt
+++ b/meson_options.txt
@@ -6,3 +6,7 @@ option('valadocs_deps',
type: 'boolean',
value: false,
description: 'Build the valadocs of the deps of sernatur')
+option('bundle_libs',
+ type: 'boolean',
+ value: false,
+ description: 'Bundle the libs that the executable is linked against')
diff --git a/po/POTFILES b/po/POTFILES
index 6251550..11d7560 100644
--- a/po/POTFILES
+++ b/po/POTFILES
@@ -1,3 +1,4 @@
src/sernatur.vala
src/sernatur-window.vala
data/ui/sernatur.window.ui
+data/cl.cromer.ubb.sernatur.gschema.xml
diff --git a/po/es.po b/po/es.po
index 6b3aec5..925eaaf 100644
--- a/po/es.po
+++ b/po/es.po
@@ -7,8 +7,8 @@ msgid ""
msgstr ""
"Project-Id-Version: sernatur\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2018-10-23 21:06-0300\n"
-"PO-Revision-Date: 2018-10-18 14:58-0300\n"
+"POT-Creation-Date: 2018-11-01 18:21-0300\n"
+"PO-Revision-Date: 2018-10-31 18:05-0300\n"
"Last-Translator: Chris Cromer \n"
"Language-Team: none\n"
"Language: es\n"
@@ -18,6 +18,40 @@ msgstr ""
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
"X-Generator: Poedit 2.0.6\n"
-#: src/sernatur-window.vala:65
+#: src/sernatur-window.vala:84
+msgid "Error"
+msgstr "Error"
+
+#: src/sernatur-window.vala:96
+msgid "Connection failed"
+msgstr "Conexión falló"
+
+#: src/sernatur-window.vala:124
msgid "Server version:"
msgstr "Versión del servidor:"
+
+#: data/ui/sernatur.window.ui:37
+msgid "_File"
+msgstr ""
+
+#: data/ui/sernatur.window.ui:102
+msgid "_Edit"
+msgstr ""
+
+#: data/ui/sernatur.window.ui:152
+msgid "_View"
+msgstr ""
+
+#: data/ui/sernatur.window.ui:160
+msgid "_Help"
+msgstr ""
+
+#: data/cl.cromer.ubb.sernatur.gschema.xml:5
+#: data/cl.cromer.ubb.sernatur.gschema.xml:6
+msgid "Host to connect to"
+msgstr ""
+
+#: data/cl.cromer.ubb.sernatur.gschema.xml:12
+#: data/cl.cromer.ubb.sernatur.gschema.xml:13
+msgid "Port number to use"
+msgstr ""
diff --git a/po/sernatur.pot b/po/sernatur.pot
index 779e7b7..b23ea71 100644
--- a/po/sernatur.pot
+++ b/po/sernatur.pot
@@ -8,7 +8,7 @@ msgid ""
msgstr ""
"Project-Id-Version: sernatur\n"
"Report-Msgid-Bugs-To: \n"
-"POT-Creation-Date: 2018-10-23 21:06-0300\n"
+"POT-Creation-Date: 2018-11-01 18:21-0300\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME \n"
"Language-Team: LANGUAGE \n"
@@ -17,6 +17,40 @@ msgstr ""
"Content-Type: text/plain; charset=CHARSET\n"
"Content-Transfer-Encoding: 8bit\n"
-#: src/sernatur-window.vala:65
+#: src/sernatur-window.vala:84
+msgid "Error"
+msgstr ""
+
+#: src/sernatur-window.vala:96
+msgid "Connection failed"
+msgstr ""
+
+#: src/sernatur-window.vala:124
msgid "Server version:"
msgstr ""
+
+#: data/ui/sernatur.window.ui:37
+msgid "_File"
+msgstr ""
+
+#: data/ui/sernatur.window.ui:102
+msgid "_Edit"
+msgstr ""
+
+#: data/ui/sernatur.window.ui:152
+msgid "_View"
+msgstr ""
+
+#: data/ui/sernatur.window.ui:160
+msgid "_Help"
+msgstr ""
+
+#: data/cl.cromer.ubb.sernatur.gschema.xml:5
+#: data/cl.cromer.ubb.sernatur.gschema.xml:6
+msgid "Host to connect to"
+msgstr ""
+
+#: data/cl.cromer.ubb.sernatur.gschema.xml:12
+#: data/cl.cromer.ubb.sernatur.gschema.xml:13
+msgid "Port number to use"
+msgstr ""
diff --git a/script/compile_schemas.sh b/script/compile_schemas.sh
new file mode 100755
index 0000000..f6fbae5
--- /dev/null
+++ b/script/compile_schemas.sh
@@ -0,0 +1,4 @@
+#!/bin/sh -eu
+
+echo "Compiling gsettings schemas..."
+glib-compile-schemas "${MESON_INSTALL_DESTDIR_PREFIX}/share/glib-2.0/schemas"
diff --git a/script/linux_bundler.sh b/script/linux_bundler.sh
index 6451184..589c4af 100755
--- a/script/linux_bundler.sh
+++ b/script/linux_bundler.sh
@@ -1,8 +1,15 @@
#!/bin/sh -eu
-libdir="${MESON_INSTALL_PREFIX}/lib"
+libdir="${MESON_INSTALL_DESTDIR_PREFIX}/lib"
mkdir -p $libdir
-libfile=`ldd ${MESON_INSTALL_PREFIX}/bin/sernatur | grep libpq | cut -d ' ' -f 3`
-cp $libfile "${libdir}"
-strip "${libdir}/libpq"*
+#libfile=`ldd ${MESON_INSTALL_DESTDIR_PREFIX}/bin/sernatur | grep libpq | cut -d ' ' -f 3`
+#cp $libfile "${libdir}"
+#strip "${libdir}/libpq"*
+
+if [ -f "${MESON_INSTALL_DESTDIR_PREFIX}"/bin/sernatur ]; then
+ echo "Copying linked dynamic libs..."
+ ldd "${MESON_INSTALL_DESTDIR_PREFIX}"/bin/sernatur | grep "=> /" | awk '{print $3}' | xargs -I '{}' cp -v '{}' "${libdir}"
+fi
+echo "Stripping libs..."
+strip --strip-debug "${libdir}/"*
diff --git a/script/meson.build b/script/meson.build
index a7e977c..e3b44ec 100644
--- a/script/meson.build
+++ b/script/meson.build
@@ -1,2 +1,7 @@
-install_data('sernatur.sh', install_dir: '.')
-meson.add_install_script('linux_bundler.sh')
+bundle_libs = get_option('bundle_libs')
+if bundle_libs
+ install_data('sernatur.sh', install_dir: '.')
+ meson.add_install_script('linux_bundler.sh')
+endif
+valadoc = find_program('glib-compile-schemas')
+meson.add_install_script('compile_schemas.sh')
diff --git a/script/sernatur.sh b/script/sernatur.sh
index 081f85c..a78448b 100755
--- a/script/sernatur.sh
+++ b/script/sernatur.sh
@@ -3,4 +3,5 @@
cd "${0%/*}"
export LD_LIBRARY_PATH="`pwd`/lib"
+export GSETTINGS_SCHEMA_DIR="`pwd`/share/glib-2.0/schemas"
bin/sernatur
diff --git a/src/meson.build b/src/meson.build
index cefb721..c8a6c94 100644
--- a/src/meson.build
+++ b/src/meson.build
@@ -1,13 +1,19 @@
+glib_dep = dependency('glib-2.0')
+gobject_dep = dependency('gobject-2.0')
gtk_dep = dependency('gtk+-3.0', version: '>=3.0.0')
# gmodule-export-2.0 is needed to connect the handlers
gmodule_dep = dependency('gmodule-2.0', version: '>=2.0')
-libpq_dep = dependency('libpq', version: '>=10.0')
+pq_dep = dependency('libpq', version: '>=10.0')
+posix_dep = meson.get_compiler('vala').find_library('posix')
+
+libconfig_lib = meson.get_compiler('c').find_library('libconfig')
+libconfig_vapi = meson.get_compiler('vala').find_library('libconfig', dirs: join_paths(meson.current_source_dir(), 'vapi'))
+libconfig_dep = declare_dependency(dependencies: [libconfig_lib, libconfig_vapi], version: '1.5')
# this is how to link against a c lib
#libsystemd_lib = meson.get_compiler('c').find_library('libsystemd')
-cc = meson.get_compiler('c')
-
+#cc = meson.get_compiler('c')
# -no-pie so that the executable is double clickable in gui
#if cc.get_id() == 'gcc'
# c_args = ['-no-pie']
@@ -33,5 +39,5 @@ vala_args += ['--gresources='+join_paths(meson.source_root(),'data/ui/sernatur.g
exe = executable('sernatur',
sources,
vala_args: vala_args,
- dependencies: [gtk_dep, gmodule_dep, libpq_dep],
+ dependencies: [glib_dep, gobject_dep, gtk_dep, gmodule_dep, pq_dep, libconfig_dep, posix_dep],
install: true)
diff --git a/src/sernatur-window.vala b/src/sernatur-window.vala
index e144617..f1f83ba 100644
--- a/src/sernatur-window.vala
+++ b/src/sernatur-window.vala
@@ -17,6 +17,7 @@
*/
namespace Sernatur {
using Postgres;
+ using LibConfig;
/**
* The MainWindow class
@@ -32,10 +33,53 @@ namespace Sernatur {
GLib.Object (application: application);
Database conn;
- conn = set_db_login ("localhost", "", "", "", "postgres", "bdd", "bdd");
+ Config config = Config();
+ if (!config.read_file ("/etc/sernatur/sernatur.conf")) {
+ stderr.printf ("%s\n", config.error_message ());
+ application.quit ();
+ return;
+ }
+
+ Setting setting = config.lookup("database");
+ string* host;
+ int port;
+ string* options;
+ string* gtty;
+ string* db_name;
+ string* login;
+ string* pwd;
+ setting.lookup_string("host", out host);
+ setting.lookup_int("port", out port);
+ setting.lookup_string("options", out options);
+ setting.lookup_string("gtty", out gtty);
+ setting.lookup_string("db_name", out db_name);
+ setting.lookup_string("login", out login);
+ setting.lookup_string("pwd", out pwd);
+
+ Settings settings = new Settings ("cl.cromer.ubb.sernatur");
+ var host2 = settings.get_string ("host");
+
+ conn = set_db_login (host2, port.to_string (), options, gtty, db_name, login, pwd);
if (conn.get_status () != ConnectionStatus.OK) {
stderr.printf ("%s\n", conn.get_error_message ());
- application.quit ();
+ Gtk.MessageDialog msg = new Gtk.MessageDialog (this,
+ Gtk.DialogFlags.MODAL,
+ Gtk.MessageType.ERROR,
+ Gtk.ButtonsType.CLOSE,
+ conn.get_error_message ());
+ msg.response.connect ((response_id) => {
+ switch (response_id) {
+ case Gtk.ResponseType.CLOSE:
+ application.quit ();
+ break;
+ case Gtk.ResponseType.DELETE_EVENT:
+ application.quit ();
+ break;
+ }
+ msg.destroy();
+ });
+ msg.set_title (dgettext (null, "Error"));
+ msg.show ();
return;
}
diff --git a/src/sernatur.vala b/src/sernatur.vala
index 6568664..b309f23 100644
--- a/src/sernatur.vala
+++ b/src/sernatur.vala
@@ -37,7 +37,7 @@ namespace Sernatur {
*/
public override void activate () {
window = new MainWindow (this);
- window.maximize ();
+ //window.maximize ();
window.present ();
}
@@ -54,6 +54,7 @@ namespace Sernatur {
/**
* The main function
* @param args Arguments passed from the command line
+ * @return success of the application
*/
public static int main (string[] args) {
var application = new Application ();
diff --git a/src/vapi/libconfig.vapi b/src/vapi/libconfig.vapi
new file mode 100644
index 0000000..2c8c111
--- /dev/null
+++ b/src/vapi/libconfig.vapi
@@ -0,0 +1,224 @@
+/*
+ * Copyright 2018 Chris Cromer
+ *
+ * Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
+ *
+ * 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
+ *
+ * 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+[CCode (cprefix = "", lower_case_cprefix = "", cheader_filename = "libconfig.h")]
+namespace LibConfig {
+ using Posix; // Needed for Posix.FILE
+
+ [CCode (cname = "uint", cprefix = "LIBCONFIG_VER_", has_type_id = false)]
+ public enum Version {
+ MAJOR,
+ MINOR,
+ REVISION;
+ /**
+ * Convert the enum value into a string with a version number
+ * This method is here to override default enum to_string which will print the enum variable name by default
+ * @return string with version number
+ */
+ public string to_string () {
+ int x_value = this;
+ return x_value.to_string();
+ }
+ }
+
+ [CCode (cname = "int", cprefix = "CONFIG_ERR_", has_type_id = false)]
+ public enum ConfigError {
+ NONE = 0,
+ FILE_IO = 1,
+ PARSE = 2
+ }
+
+ [CCode (cname = "int", cprefix = "CONFIG_OPTION_", has_type_id = false)]
+ [Flags]
+ public enum ConfigOption {
+ AUTOCONVERT = 0x01,
+ SEMICOLON_SEPARATORS = 0x02,
+ COLON_ASSIGNMENT_FOR_GROUPS = 0x04,
+ COLON_ASSIGNMENT_FOR_NON_GROUPS = 0x08,
+ OPEN_BRACE_ON_SEPARATE_LINE = 0x10,
+ [Version (since = "1.7")]
+ ALLOW_SCIENTIFIC_NOTATION = 0x20,
+ [Version (since = "1.7.1")]
+ FSYNC = 0x40
+ }
+
+ [CCode (cname = "int", cprefix = "CONFIG_TYPE_", has_type_id = false)]
+ public enum ConfigType {
+ NONE = 0,
+ GROUP = 1,
+ INT = 2,
+ INT64 = 3,
+ FLOAT = 4,
+ STRING = 5,
+ BOOL = 6,
+ ARRAY = 7,
+ LIST = 8
+ }
+
+ [CCode (cname = "int", cprefix = "CONFIG_FORMAT_", has_type_id = false)]
+ public enum ConfigFormat {
+ DEFAULT = 0,
+ HEX = 1
+ }
+
+ [CCode (cname = "config_t", cprefix = "config_", destroy_function = "config_destroy", has_type_id = false)]
+ public struct Config {
+ [CCode (cname = "config_init")]
+ public Config();
+
+ [Version (since = "1.7")]
+ public void clear ();
+
+ public bool read (FILE stream);
+ public bool read_file (string filename);
+ public bool read_string (string str);
+
+ public void write (FILE stream);
+ public bool write_file (string filename);
+
+ public void set_include_dir (string include_dir);
+ public string get_include_dir ();
+
+ //[Version (since = "1.7")]
+ //void config_set_include_func (config_include_fn_t func)
+
+ [Version (since = "1.6")]
+ public ushort get_float_precision ();
+ [Version (since = "1.6")]
+ public void set_float_precision (ushort digits);
+
+ public ConfigOption get_options ();
+ public void set_options (ConfigOption options);
+
+ [Version (since = "1.7")]
+ public ConfigOption get_option (int option);
+ [Version (since = "1.7")]
+ public void set_option (ConfigOption option, int flag);
+
+ [Version (deprecated = true, replacement = "get_option")]
+ public int get_auto_convert ();
+ [Version (deprecated = true, replacement = "set_option")]
+ public void set_auto_convert (int flag);
+
+ public ConfigFormat get_default_format ();
+ public void set_default_format (ConfigFormat format);
+
+ public ushort get_tab_width ();
+ public void set_tab_width (ushort width);
+
+ public bool lookup_int (string path, out int x_value);
+ public bool lookup_int64 (string path, out int64 x_value);
+ public bool lookup_float (string path, out float x_value);
+ public bool lookup_bool (string path, out bool x_value);
+ public bool lookup_string (string path, out string x_value);
+
+ public Setting? lookup (string path);
+
+ public Setting root_setting ();
+
+ [CCode (simple_generics = true)]
+ [Version (since = "1.7")]
+ public void set_hook (T hook);
+
+ [CCode (simple_generics = true)]
+ [Version (since = "1.7")]
+ public T get_hook ();
+
+ //[CCode (simple_generics = true)]
+ //public void set_destructor (T void (* destructor));
+
+ public unowned string error_text ();
+ public unowned string? error_file ();
+ public int error_line ();
+ public ConfigError error_type ();
+
+ public string error_message () {
+ return this.error_file () + ":" + this.error_line ().to_string() + " - " + this.error_text ();
+ }
+
+ public string version() {
+ return Version.MAJOR.to_string () + "." + Version.MINOR.to_string () + "." + Version.REVISION.to_string ();
+ }
+ }
+
+ [CCode (cname = "config_setting_t", cprefix = "config_setting_", free_function = "", has_type_id = false, has_target = false)]
+ [Compact]
+ public class Setting {
+ public Setting? lookup (string path);
+
+ public int? get_int ();
+ public int64? get_int64 ();
+ public float? get_float ();
+ public bool? get_bool ();
+ public unowned string? get_string ();
+
+ public bool set_int (int x_value);
+ public bool set_int64 (int64 x_value);
+ public bool set_float (float x_value);
+ public bool set_bool (bool x_value);
+ public bool set_string (string x_value);
+
+ public bool lookup_int (string name, out int x_value);
+ public bool lookup_int64 (string name, out int64 x_value);
+ public bool lookup_float (string name, out float x_value);
+ public bool lookup_bool (string name, out bool x_value);
+ public bool lookup_string (string name, out string x_value);
+
+ public ConfigFormat get_format ();
+ public bool set_format (ConfigFormat format);
+
+ public Setting? get_member (string name);
+
+ public Setting? get_elem (uint index);
+
+ public int? get_int_elem (int index);
+ public int64? get_int64_elem (int index);
+ public float? get_float_elem (int index);
+ public bool? get_bool_elem (int index);
+ public unowned string? get_string_elem (int index);
+
+ public Setting? set_int_elem (int index, int x_value);
+ public Setting? set_int64_elem (int index, int64 x_value);
+ public Setting? set_float_elem (int index, float x_value);
+ public Setting? set_bool_elem (int index, bool x_value);
+ public Setting? set_string_elem (int index, string x_value);
+
+ public Setting? add (Setting parent, string? name, ConfigType type);
+ public bool remove (Setting parent, string name);
+ public int remove_elem (Setting parent, uint index);
+
+ public unowned string? name ();
+ public Setting? parent ();
+
+ public bool is_root ();
+
+ public int index ();
+
+ public int length ();
+
+ public ConfigType type ();
+
+ public bool is_group ();
+ public bool is_array ();
+ public bool is_list ();
+
+ public bool is_aggregate ();
+ public bool is_scalar ();
+ public bool is_number ();
+
+ public unowned string? source_file ();
+
+ public uint source_line ();
+ }
+}