mirror of
https://github.com/edeproject/ede.git
synced 2023-08-10 21:13:03 +03:00
Importing svn2cl as it is used from script that makes release archives.
Making code DBus optional; all DBus related code is wrapped inside EDELIB_HAVE_DBUS.
This commit is contained in:
parent
0ad6617df4
commit
c26b526dcd
@ -106,10 +106,7 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if test -n "$with_edelib_path"; then
|
if test -n "$with_edelib_path"; then
|
||||||
export PKG_CONFIG_PATH="$PKG_CONFIG_PATH:$with_edelib_path"
|
export PKG_CONFIG_PATH="$PKG_CONFIG_PATH:$with_edelib_path/lib/pkgconfig"
|
||||||
else
|
|
||||||
dnl TODO: remove this in release
|
|
||||||
export PKG_CONFIG_PATH="$PKG_CONFIG_PATH:/opt/ede/lib/pkgconfig"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
PKG_CHECK_MODULES(EDELIB, [edelib],, [have_edelib=no])
|
PKG_CHECK_MODULES(EDELIB, [edelib],, [have_edelib=no])
|
||||||
@ -129,7 +126,7 @@ fi
|
|||||||
|
|
||||||
PKG_CHECK_MODULES(EDELIB_DBUS, [edelib-dbus],, [have_edelib_dbus=no])
|
PKG_CHECK_MODULES(EDELIB_DBUS, [edelib-dbus],, [have_edelib_dbus=no])
|
||||||
if test "$have_edelib_dbus" = "no"; then
|
if test "$have_edelib_dbus" = "no"; then
|
||||||
AC_MSG_ERROR(edelib-dbus not found! You must install it first)
|
AC_MSG_RESULT(edelib is compiled without DBus so EDE will be compiled without DBus support)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dnl find edelib documentation
|
dnl find edelib documentation
|
||||||
|
@ -224,7 +224,10 @@ Desktop::~Desktop() {
|
|||||||
|
|
||||||
delete gisett;
|
delete gisett;
|
||||||
delete selbox;
|
delete selbox;
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
delete dbus;
|
delete dbus;
|
||||||
|
#endif
|
||||||
|
|
||||||
DirWatch::shutdown();
|
DirWatch::shutdown();
|
||||||
foreign_callback_remove(settings_changed_cb);
|
foreign_callback_remove(settings_changed_cb);
|
||||||
@ -244,12 +247,14 @@ void Desktop::init_internals(void) {
|
|||||||
wallpaper = new Wallpaper(0, 0, w(), h());
|
wallpaper = new Wallpaper(0, 0, w(), h());
|
||||||
end();
|
end();
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
dbus = new edelib::EdbusConnection();
|
dbus = new edelib::EdbusConnection();
|
||||||
if(!dbus->connect(edelib::EDBUS_SESSION)) {
|
if(!dbus->connect(edelib::EDBUS_SESSION)) {
|
||||||
E_WARNING(E_STRLOC ": Unable to connect to session bus. Disabling dbus interface...\n");
|
E_WARNING(E_STRLOC ": Unable to connect to session bus. Disabling dbus interface...\n");
|
||||||
delete dbus;
|
delete dbus;
|
||||||
dbus = NULL;
|
dbus = NULL;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* read main config */
|
/* read main config */
|
||||||
read_config();
|
read_config();
|
||||||
@ -820,6 +825,7 @@ void Desktop::notify_desktop_changed(void) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
if(dbus) {
|
if(dbus) {
|
||||||
edelib::EdbusMessage msg;
|
edelib::EdbusMessage msg;
|
||||||
/* send org.equinoxproject.Desktop.DesktopChanged(int32, string) signal */
|
/* send org.equinoxproject.Desktop.DesktopChanged(int32, string) signal */
|
||||||
@ -827,6 +833,7 @@ void Desktop::notify_desktop_changed(void) {
|
|||||||
msg << num << names[num];
|
msg << num << names[num];
|
||||||
dbus->send(msg);
|
dbus->send(msg);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
XFreeStringList(names);
|
XFreeStringList(names);
|
||||||
}
|
}
|
||||||
|
@ -27,9 +27,12 @@
|
|||||||
#include <edelib/String.h>
|
#include <edelib/String.h>
|
||||||
#include <edelib/Resource.h>
|
#include <edelib/Resource.h>
|
||||||
#include <edelib/List.h>
|
#include <edelib/List.h>
|
||||||
#include <edelib/EdbusConnection.h>
|
|
||||||
#include <edelib/MenuButton.h>
|
#include <edelib/MenuButton.h>
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
|
# include <edelib/EdbusConnection.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#define EDAMAGE_CHILD_LABEL 0x10
|
#define EDAMAGE_CHILD_LABEL 0x10
|
||||||
#define EDAMAGE_OVERLAY 0x20
|
#define EDAMAGE_OVERLAY 0x20
|
||||||
|
|
||||||
@ -109,7 +112,10 @@ private:
|
|||||||
|
|
||||||
edelib::MenuButton* dmenu;
|
edelib::MenuButton* dmenu;
|
||||||
Wallpaper* wallpaper;
|
Wallpaper* wallpaper;
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
edelib::EdbusConnection* dbus;
|
edelib::EdbusConnection* dbus;
|
||||||
|
#endif
|
||||||
|
|
||||||
DesktopIconList icons;
|
DesktopIconList icons;
|
||||||
DesktopIconList selectionbuf;
|
DesktopIconList selectionbuf;
|
||||||
|
@ -1,13 +1,21 @@
|
|||||||
/*
|
/*
|
||||||
* $Id$
|
* $Id$
|
||||||
*
|
*
|
||||||
* ede-launch, launch external application
|
* Copyright (C) 2012 Sanel Zukan
|
||||||
* Part of Equinox Desktop Environment (EDE).
|
|
||||||
* Copyright (c) 2008-2009 EDE Authors.
|
|
||||||
*
|
*
|
||||||
* This program is licensed under terms of the
|
* This program is free software; you can redistribute it and/or
|
||||||
* GNU General Public License version 2 or newer.
|
* modify it under the terms of the GNU General Public License
|
||||||
* See COPYING for details.
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
@ -47,6 +55,7 @@
|
|||||||
#include <edelib/StrUtil.h>
|
#include <edelib/StrUtil.h>
|
||||||
#include <edelib/Debug.h>
|
#include <edelib/Debug.h>
|
||||||
#include <edelib/Regex.h>
|
#include <edelib/Regex.h>
|
||||||
|
#include <edelib/Util.h>
|
||||||
#include <edelib/Ede.h>
|
#include <edelib/Ede.h>
|
||||||
#include "StartupNotify.h"
|
#include "StartupNotify.h"
|
||||||
|
|
||||||
@ -63,13 +72,14 @@
|
|||||||
#define REGEX_PATTERN_URL "((http|https|ftp|gopher|!file):\\/\\/|www)[a-zA-Z0-9\\-\\._]+\\/?[a-zA-Z0-9_\\.\\-\\?\\+\\/~=&#;,]*[a-zA-Z0-9\\/]{1}"
|
#define REGEX_PATTERN_URL "((http|https|ftp|gopher|!file):\\/\\/|www)[a-zA-Z0-9\\-\\._]+\\/?[a-zA-Z0-9_\\.\\-\\?\\+\\/~=&#;,]*[a-zA-Z0-9\\/]{1}"
|
||||||
|
|
||||||
EDELIB_NS_USING_AS(Window, LaunchWindow)
|
EDELIB_NS_USING_AS(Window, LaunchWindow)
|
||||||
EDELIB_NS_USING_LIST(12, (Resource,
|
EDELIB_NS_USING_LIST(14, (Resource,
|
||||||
Regex,
|
Regex,
|
||||||
String,
|
String,
|
||||||
|
list,
|
||||||
DesktopFile,
|
DesktopFile,
|
||||||
RES_USER_ONLY,
|
RES_USER_ONLY,
|
||||||
DESK_FILE_TYPE_APPLICATION,
|
DESK_FILE_TYPE_APPLICATION,
|
||||||
run_sync, run_async, alert, file_path, window_center_on_screen, str_ends))
|
run_sync, run_async, alert, file_path, window_center_on_screen, str_ends, system_data_dirs))
|
||||||
|
|
||||||
static Fl_Pixmap image_run((const char**)run_xpm);
|
static Fl_Pixmap image_run((const char**)run_xpm);
|
||||||
static Fl_Input* dialog_input;
|
static Fl_Input* dialog_input;
|
||||||
@ -348,6 +358,17 @@ FAIL:
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool start_via_mime_cache(const char *arg) {
|
||||||
|
list<String> dirs;
|
||||||
|
E_RETURN_VAL_IF_FAIL(system_data_dirs(dirs) > 0, false);
|
||||||
|
|
||||||
|
DesktopFile d;
|
||||||
|
list<String>::iterator it = dirs.begin(), ite = dirs.end();
|
||||||
|
|
||||||
|
for(; it != ite; ++it) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* concat all arguments preparing it for start_child() */
|
/* concat all arguments preparing it for start_child() */
|
||||||
static void join_args(int start, int argc, char **argv, const char *program, String &ret, bool is_mailto = false) {
|
static void join_args(int start, int argc, char **argv, const char *program, String &ret, bool is_mailto = false) {
|
||||||
String args;
|
String args;
|
||||||
|
@ -26,11 +26,13 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
|
||||||
|
#include <edelib/Ede.h>
|
||||||
|
#include <edelib/Debug.h>
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
#include <FL/Fl.H>
|
#include <FL/Fl.H>
|
||||||
#include <FL/Fl_Shared_Image.H>
|
#include <FL/Fl_Shared_Image.H>
|
||||||
|
|
||||||
#include <edelib/Ede.h>
|
|
||||||
#include <edelib/Debug.h>
|
|
||||||
#include <edelib/EdbusConnection.h>
|
#include <edelib/EdbusConnection.h>
|
||||||
#include <edelib/EdbusMessage.h>
|
#include <edelib/EdbusMessage.h>
|
||||||
#include <edelib/EdbusData.h>
|
#include <edelib/EdbusData.h>
|
||||||
@ -63,7 +65,6 @@
|
|||||||
#define WINDOWS_PADDING 10
|
#define WINDOWS_PADDING 10
|
||||||
|
|
||||||
#define IS_MEMBER(m, s1) (strcmp((m->member()), (s1)) == 0)
|
#define IS_MEMBER(m, s1) (strcmp((m->member()), (s1)) == 0)
|
||||||
#define CHECK_ARGV(argv, pshort, plong) ((strcmp(argv, pshort) == 0) || (strcmp(argv, plong) == 0))
|
|
||||||
|
|
||||||
EDELIB_NS_USING(EdbusConnection)
|
EDELIB_NS_USING(EdbusConnection)
|
||||||
EDELIB_NS_USING(EdbusMessage)
|
EDELIB_NS_USING(EdbusMessage)
|
||||||
@ -298,6 +299,8 @@ static int notifications_dbus_method_cb(const EdbusMessage *m, void *d) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* EDELIB_HAVE_DBUS */
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
static int notifications_dbus_signal_cb(const EdbusMessage *m, void *d) {
|
static int notifications_dbus_signal_cb(const EdbusMessage *m, void *d) {
|
||||||
E_DEBUG("+=> %s\n", m->member());
|
E_DEBUG("+=> %s\n", m->member());
|
||||||
@ -313,6 +316,8 @@ static void help(void) {
|
|||||||
puts(" -n, --no-daemon do not run in background");
|
puts(" -n, --no-daemon do not run in background");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define CHECK_ARGV(argv, pshort, plong) ((strcmp(argv, pshort) == 0) || (strcmp(argv, plong) == 0))
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
/* daemon behaves as GUI app, as will use icon theme and etc. */
|
/* daemon behaves as GUI app, as will use icon theme and etc. */
|
||||||
EDE_APPLICATION("ede-notify-daemon");
|
EDE_APPLICATION("ede-notify-daemon");
|
||||||
@ -329,6 +334,7 @@ int main(int argc, char **argv) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
server_running = false;
|
server_running = false;
|
||||||
notify_id = 0;
|
notify_id = 0;
|
||||||
EdbusConnection dbus;
|
EdbusConnection dbus;
|
||||||
@ -359,5 +365,8 @@ int main(int argc, char **argv) {
|
|||||||
Fl::wait(FOREVER);
|
Fl::wait(FOREVER);
|
||||||
|
|
||||||
IconLoader::shutdown();
|
IconLoader::shutdown();
|
||||||
|
#else
|
||||||
|
E_WARNING(E_STRLOC ": edelib is compiled without DBus so notification daemon is not able to receive notification messages\n");
|
||||||
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -26,8 +26,11 @@
|
|||||||
#include <edelib/MessageBox.h>
|
#include <edelib/MessageBox.h>
|
||||||
#include <edelib/Nls.h>
|
#include <edelib/Nls.h>
|
||||||
#include <edelib/Run.h>
|
#include <edelib/Run.h>
|
||||||
|
|
||||||
|
#if EDELIB_HAVE_DBUS
|
||||||
#include <edelib/EdbusMessage.h>
|
#include <edelib/EdbusMessage.h>
|
||||||
#include <edelib/EdbusConnection.h>
|
#include <edelib/EdbusConnection.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "EvokeService.h"
|
#include "EvokeService.h"
|
||||||
#include "Splash.h"
|
#include "Splash.h"
|
||||||
@ -37,11 +40,6 @@
|
|||||||
|
|
||||||
EDELIB_NS_USING(Config)
|
EDELIB_NS_USING(Config)
|
||||||
EDELIB_NS_USING(Resource)
|
EDELIB_NS_USING(Resource)
|
||||||
EDELIB_NS_USING(EdbusMessage)
|
|
||||||
EDELIB_NS_USING(EdbusConnection)
|
|
||||||
EDELIB_NS_USING(EdbusError)
|
|
||||||
EDELIB_NS_USING(EDBUS_SESSION)
|
|
||||||
EDELIB_NS_USING(EDBUS_SYSTEM)
|
|
||||||
EDELIB_NS_USING(RES_SYS_ONLY)
|
EDELIB_NS_USING(RES_SYS_ONLY)
|
||||||
EDELIB_NS_USING(file_remove)
|
EDELIB_NS_USING(file_remove)
|
||||||
EDELIB_NS_USING(file_test)
|
EDELIB_NS_USING(file_test)
|
||||||
@ -51,6 +49,14 @@ EDELIB_NS_USING(alert)
|
|||||||
EDELIB_NS_USING(ask)
|
EDELIB_NS_USING(ask)
|
||||||
EDELIB_NS_USING(FILE_TEST_IS_REGULAR)
|
EDELIB_NS_USING(FILE_TEST_IS_REGULAR)
|
||||||
|
|
||||||
|
#if EDELIB_HAVE_DBUS
|
||||||
|
EDELIB_NS_USING(EdbusMessage)
|
||||||
|
EDELIB_NS_USING(EdbusConnection)
|
||||||
|
EDELIB_NS_USING(EdbusError)
|
||||||
|
EDELIB_NS_USING(EDBUS_SESSION)
|
||||||
|
EDELIB_NS_USING(EDBUS_SYSTEM)
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef USE_LOCAL_CONFIG
|
#ifdef USE_LOCAL_CONFIG
|
||||||
# define CONFIG_GET_STRVAL(object, section, key, buff) object.get(section, key, buff, sizeof(buff))
|
# define CONFIG_GET_STRVAL(object, section, key, buff) object.get(section, key, buff, sizeof(buff))
|
||||||
#else
|
#else
|
||||||
@ -90,17 +96,21 @@ static int get_int_property_value(Atom at) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void send_dbus_ede_quit(void) {
|
static void send_dbus_ede_quit(void) {
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
EdbusConnection c;
|
EdbusConnection c;
|
||||||
E_RETURN_IF_FAIL(c.connect(EDBUS_SESSION));
|
E_RETURN_IF_FAIL(c.connect(EDBUS_SESSION));
|
||||||
|
|
||||||
EdbusMessage msg;
|
EdbusMessage msg;
|
||||||
msg.create_signal("/org/equinoxproject/Shutdown", "org.equinoxproject.Shutdown", "Shutdown");
|
msg.create_signal("/org/equinoxproject/Shutdown", "org.equinoxproject.Shutdown", "Shutdown");
|
||||||
c.send(msg);
|
c.send(msg);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool do_shutdown_or_restart(bool restart) {
|
static bool do_shutdown_or_restart(bool restart) {
|
||||||
const char *action;
|
const char *action;
|
||||||
|
int r = 1;
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
EdbusConnection c;
|
EdbusConnection c;
|
||||||
if(!c.connect(EDBUS_SYSTEM)) {
|
if(!c.connect(EDBUS_SYSTEM)) {
|
||||||
alert(_("Unable to connect to HAL daemon. Make sure both D-BUS and HAL daemons are running"));
|
alert(_("Unable to connect to HAL daemon. Make sure both D-BUS and HAL daemons are running"));
|
||||||
@ -131,8 +141,9 @@ static bool do_shutdown_or_restart(bool restart) {
|
|||||||
if((*it).to_bool() == true)
|
if((*it).to_bool() == true)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
int r = ask(_("You are not allowed to execute this command. Please consult ConsoleKit documentation on how to allow privileged actions. "
|
r = ask(_("You are not allowed to execute this command. Please consult ConsoleKit documentation on how to allow privileged actions. "
|
||||||
"Would you like to try to execute system commands?"));
|
"Would you like to try to execute system commands?"));
|
||||||
|
#endif /* EDELIB_HAVE_DBUS */
|
||||||
|
|
||||||
/* try to do things manually */
|
/* try to do things manually */
|
||||||
if(!r) return false;
|
if(!r) return false;
|
||||||
|
107
evoke/Xsm.cpp
107
evoke/Xsm.cpp
@ -26,7 +26,10 @@
|
|||||||
#include <edelib/File.h>
|
#include <edelib/File.h>
|
||||||
#include <edelib/Resource.h>
|
#include <edelib/Resource.h>
|
||||||
#include <edelib/Nls.h>
|
#include <edelib/Nls.h>
|
||||||
#include <edelib/EdbusList.h>
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
|
# include <edelib/EdbusList.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "Xsm.h"
|
#include "Xsm.h"
|
||||||
|
|
||||||
@ -41,9 +44,12 @@ EDELIB_NS_USING(Resource)
|
|||||||
EDELIB_NS_USING(XSettingsSetting)
|
EDELIB_NS_USING(XSettingsSetting)
|
||||||
EDELIB_NS_USING(XSettingsList)
|
EDELIB_NS_USING(XSettingsList)
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
EDELIB_NS_USING(EdbusMessage)
|
EDELIB_NS_USING(EdbusMessage)
|
||||||
EDELIB_NS_USING(EdbusData)
|
EDELIB_NS_USING(EdbusData)
|
||||||
EDELIB_NS_USING(EdbusList)
|
EDELIB_NS_USING(EdbusList)
|
||||||
|
EDELIB_NS_USING(EDBUS_SESSION)
|
||||||
|
#endif
|
||||||
|
|
||||||
EDELIB_NS_USING(dir_home)
|
EDELIB_NS_USING(dir_home)
|
||||||
EDELIB_NS_USING(file_remove)
|
EDELIB_NS_USING(file_remove)
|
||||||
@ -58,7 +64,8 @@ EDELIB_NS_USING(color_fltk_to_html)
|
|||||||
EDELIB_NS_USING(XSETTINGS_TYPE_COLOR)
|
EDELIB_NS_USING(XSETTINGS_TYPE_COLOR)
|
||||||
EDELIB_NS_USING(XSETTINGS_TYPE_INT)
|
EDELIB_NS_USING(XSETTINGS_TYPE_INT)
|
||||||
EDELIB_NS_USING(XSETTINGS_TYPE_STRING)
|
EDELIB_NS_USING(XSETTINGS_TYPE_STRING)
|
||||||
EDELIB_NS_USING(EDBUS_SESSION)
|
|
||||||
|
#define STR_CMP(s1, s2) (strcmp((s1), (s2)) == 0)
|
||||||
|
|
||||||
struct ResourceMap {
|
struct ResourceMap {
|
||||||
const char* name;
|
const char* name;
|
||||||
@ -83,6 +90,7 @@ static int ignore_xerrors(Display* display, XErrorEvent* xev) {
|
|||||||
return True;
|
return True;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
static void handle_get_type(XSettingsData* mdata, const EdbusMessage* orig, EdbusMessage& reply) {
|
static void handle_get_type(XSettingsData* mdata, const EdbusMessage* orig, EdbusMessage& reply) {
|
||||||
if(orig->size() != 1) {
|
if(orig->size() != 1) {
|
||||||
reply.create_error_reply(*orig, _("This function accepts only one parameter"));
|
reply.create_error_reply(*orig, _("This function accepts only one parameter"));
|
||||||
@ -247,13 +255,75 @@ static void handle_set(Xsm* xsm, XSettingsData* mdata, const EdbusMessage* orig,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define XSM_OBJECT_PATH "/org/equinoxproject/Xsettings"
|
||||||
|
|
||||||
|
#define XSM_INTROSPECTION_XML \
|
||||||
|
"<node>\n"\
|
||||||
|
" <interface name=\"org.equinoxproject.Xsettings\">\n" \
|
||||||
|
" <method name=\"GetType\">\n" \
|
||||||
|
" <arg name=\"name\" type=\"s\" direction=\"in\"/>\n" \
|
||||||
|
" <arg name=\"type\" type=\"s\" direction=\"out\"/>\n" \
|
||||||
|
" <annotation name=\"org.equinoxproject.DBus.DocString\" value=\"Returns type for given name.\" />\n" \
|
||||||
|
" </method>\n" \
|
||||||
|
" <method name=\"GetAll\">\n" \
|
||||||
|
" <arg name=\"all\" type=\"as\" direction=\"out\"/>\n" \
|
||||||
|
" <annotation name=\"org.equinoxproject.DBus.DocString\" value=\"Get all settings currently registered.\" />\n" \
|
||||||
|
" </method>\n" \
|
||||||
|
" <method name=\"GetValue\">\n" \
|
||||||
|
" <arg name=\"name\" type=\"s\" direction=\"in\"/>\n" \
|
||||||
|
" <arg name=\"value\" type=\"v\" direction=\"out\"/>\n" \
|
||||||
|
" <annotation name=\"org.equinoxproject.DBus.DocString\" value=\"Returns value for named setting.\" />\n" \
|
||||||
|
" </method>\n" \
|
||||||
|
" <method name=\"Remove\">\n" \
|
||||||
|
" <arg name=\"name\" type=\"s\" direction=\"in\"/>\n" \
|
||||||
|
" <annotation name=\"org.equinoxproject.DBus.DocString\" value=\"Removes named setting. If not exists, does nothing.\" />\n" \
|
||||||
|
" </method>\n" \
|
||||||
|
" <method name=\"Flush\">\n" \
|
||||||
|
" <annotation name=\"org.equinoxproject.DBus.DocString\" value=\"Flushes all settings to disk.\" />\n" \
|
||||||
|
" </method>\n" \
|
||||||
|
" <method name=\"Set\">\n" \
|
||||||
|
" <arg name=\"status\" type=\"b\" direction=\"out\"/>\n" \
|
||||||
|
" <arg name=\"name\" type=\"s\" direction=\"in\"/>\n" \
|
||||||
|
" <arg name=\"value\" type=\"v\" direction=\"in\"/>\n" \
|
||||||
|
" <annotation name=\"org.equinoxproject.DBus.DocString\" value=\"Set named setting to given value. Returns true if set or false if failed.\" />\n" \
|
||||||
|
" </method>\n" \
|
||||||
|
" </interface>\n" \
|
||||||
|
"</node>\n";
|
||||||
|
|
||||||
static int xsettings_dbus_cb(const EdbusMessage* m, void* data) {
|
static int xsettings_dbus_cb(const EdbusMessage* m, void* data) {
|
||||||
Xsm* x = (Xsm*)data;
|
Xsm* x = (Xsm*)data;
|
||||||
XSettingsData* md = x->get_manager_data();
|
XSettingsData* md = x->get_manager_data();
|
||||||
|
|
||||||
|
/* introspection */
|
||||||
|
if(STR_CMP(m->member(), "Introspect") &&
|
||||||
|
STR_CMP(m->interface(), "org.freedesktop.DBus.Introspectable") &&
|
||||||
|
STR_CMP(m->destination(), "org.equinoxproject.Xsettings"))
|
||||||
|
{
|
||||||
|
String ret = EDBUS_INTROSPECTION_DTD;
|
||||||
|
|
||||||
|
if(STR_CMP(m->path(), XSM_OBJECT_PATH)) {
|
||||||
|
ret += XSM_INTROSPECTION_XML;
|
||||||
|
} else {
|
||||||
|
ret += "<node>\n <node ";
|
||||||
|
if(STR_CMP(m->path(), "/"))
|
||||||
|
ret += "name=\"org\"";
|
||||||
|
else if(STR_CMP(m->path(), "/org"))
|
||||||
|
ret += "name=\"equinoxproject\"";
|
||||||
|
else if(STR_CMP(m->path(), "/org/equinoxproject"))
|
||||||
|
ret += "name=\"Xsettings\"";
|
||||||
|
|
||||||
|
ret += " />\n</node>\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
EdbusMessage reply;
|
||||||
|
reply.create_reply(*m);
|
||||||
|
reply << EdbusData::from_string(ret.c_str());
|
||||||
|
x->get_dbus_connection()->send(reply);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
/* string GetType(string name) */
|
/* string GetType(string name) */
|
||||||
if(strcmp(m->member(), "GetType") == 0) {
|
if(STR_CMP(m->member(), "GetType")) {
|
||||||
EdbusMessage reply;
|
EdbusMessage reply;
|
||||||
handle_get_type(md, m, reply);
|
handle_get_type(md, m, reply);
|
||||||
|
|
||||||
@ -262,7 +332,7 @@ static int xsettings_dbus_cb(const EdbusMessage* m, void* data) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* string-array GetAll(void) */
|
/* string-array GetAll(void) */
|
||||||
if(strcmp(m->member(), "GetAll") == 0) {
|
if(STR_CMP(m->member(), "GetAll")) {
|
||||||
EdbusMessage reply;
|
EdbusMessage reply;
|
||||||
handle_get_all(md, m, reply);
|
handle_get_all(md, m, reply);
|
||||||
|
|
||||||
@ -272,7 +342,7 @@ static int xsettings_dbus_cb(const EdbusMessage* m, void* data) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* [string|array|int32] GetValue(string name) */
|
/* [string|array|int32] GetValue(string name) */
|
||||||
if(strcmp(m->member(), "GetValue") == 0) {
|
if(STR_CMP(m->member(), "GetValue")) {
|
||||||
EdbusMessage reply;
|
EdbusMessage reply;
|
||||||
handle_get_value(md, m, reply);
|
handle_get_value(md, m, reply);
|
||||||
|
|
||||||
@ -282,19 +352,19 @@ static int xsettings_dbus_cb(const EdbusMessage* m, void* data) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* void Remove(string name) */
|
/* void Remove(string name) */
|
||||||
if(strcmp(m->member(), "Remove") == 0) {
|
if(STR_CMP(m->member(), "Remove")) {
|
||||||
handle_remove(x, md, m);
|
handle_remove(x, md, m);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* void Flush(void) */
|
/* void Flush(void) */
|
||||||
if(strcmp(m->member(), "Flush") == 0) {
|
if(STR_CMP(m->member(), "Flush")) {
|
||||||
x->save_serialized();
|
x->save_serialized();
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* bool Set(string name, [string|array|int32] value) */
|
/* bool Set(string name, [string|array|int32] value) */
|
||||||
if(strcmp(m->member(), "Set") == 0) {
|
if(STR_CMP(m->member(), "Set")) {
|
||||||
EdbusMessage reply;
|
EdbusMessage reply;
|
||||||
handle_set(x, md, m, reply);
|
handle_set(x, md, m, reply);
|
||||||
|
|
||||||
@ -302,13 +372,10 @@ static int xsettings_dbus_cb(const EdbusMessage* m, void* data) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
Xsm::~Xsm() {
|
#endif /* EDELIB_HAVE_DBUS */
|
||||||
E_DEBUG(E_STRLOC ": Xsm::~Xsm()\n");
|
|
||||||
delete dbus_conn;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is a short explaination how evoke's XSETTINGS part is combined
|
* This is a short explaination how evoke's XSETTINGS part is combined
|
||||||
@ -373,7 +440,7 @@ void Xsm::xresource_replace(void) {
|
|||||||
/* check if resource is present */
|
/* check if resource is present */
|
||||||
status = XrmGetResource(db, resource_map[i].xresource_key, resource_map[i].xresource_klass, &type, &xrmv);
|
status = XrmGetResource(db, resource_map[i].xresource_key, resource_map[i].xresource_klass, &type, &xrmv);
|
||||||
|
|
||||||
if(status && strcmp(type, "String") == 0) {
|
if(status && STR_CMP(type, "String")) {
|
||||||
E_DEBUG(E_STRLOC ": %s.%s found in database\n",
|
E_DEBUG(E_STRLOC ": %s.%s found in database\n",
|
||||||
resource_map[i].xresource_klass, resource_map[i].xresource_key);
|
resource_map[i].xresource_klass, resource_map[i].xresource_key);
|
||||||
}
|
}
|
||||||
@ -427,6 +494,7 @@ void Xsm::xresource_undo(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Xsm::xsettings_dbus_serve(void) {
|
void Xsm::xsettings_dbus_serve(void) {
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
E_RETURN_IF_FAIL(!dbus_conn);
|
E_RETURN_IF_FAIL(!dbus_conn);
|
||||||
|
|
||||||
EdbusConnection* d = new EdbusConnection;
|
EdbusConnection* d = new EdbusConnection;
|
||||||
@ -443,11 +511,12 @@ void Xsm::xsettings_dbus_serve(void) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
d->register_object("/org/equinoxproject/Xsettings");
|
d->register_object(XSM_OBJECT_PATH);
|
||||||
d->method_callback(xsettings_dbus_cb, this);
|
d->method_callback(xsettings_dbus_cb, this);
|
||||||
|
|
||||||
d->setup_listener_with_fltk();
|
d->setup_listener_with_fltk();
|
||||||
dbus_conn = d;
|
dbus_conn = d;
|
||||||
|
#endif /* EDELIB_HAVE_DBUS */
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Xsm::load_serialized(void) {
|
bool Xsm::load_serialized(void) {
|
||||||
@ -481,7 +550,7 @@ bool Xsm::load_serialized(void) {
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
for(elem = elem->FirstChildElement(); elem; elem = elem->NextSibling()) {
|
for(elem = elem->FirstChildElement(); elem; elem = elem->NextSibling()) {
|
||||||
if(strcmp(elem->Value(), "setting") != 0) {
|
if(!STR_CMP(elem->Value(), "setting")) {
|
||||||
E_WARNING(E_STRLOC ": Got unknown child in 'ede-setting' %s\n", elem->Value());
|
E_WARNING(E_STRLOC ": Got unknown child in 'ede-setting' %s\n", elem->Value());
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -498,11 +567,11 @@ bool Xsm::load_serialized(void) {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(strcmp(type, "int") == 0)
|
if(STR_CMP(type, "int"))
|
||||||
cmp = 1;
|
cmp = 1;
|
||||||
else if(strcmp(type, "string") == 0)
|
else if(STR_CMP(type, "string"))
|
||||||
cmp = 2;
|
cmp = 2;
|
||||||
else if(strcmp(type, "color") == 0)
|
else if(STR_CMP(type, "color"))
|
||||||
cmp = 3;
|
cmp = 3;
|
||||||
else {
|
else {
|
||||||
E_WARNING(E_STRLOC ": Unknown type %s\n", type);
|
E_WARNING(E_STRLOC ": Unknown type %s\n", type);
|
||||||
|
14
evoke/Xsm.h
14
evoke/Xsm.h
@ -14,15 +14,20 @@
|
|||||||
#define __XSM_H__
|
#define __XSM_H__
|
||||||
|
|
||||||
#include <edelib/XSettingsManager.h>
|
#include <edelib/XSettingsManager.h>
|
||||||
#include <edelib/EdbusConnection.h>
|
|
||||||
|
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
|
# include <edelib/EdbusConnection.h>
|
||||||
EDELIB_NS_USING(EdbusConnection)
|
EDELIB_NS_USING(EdbusConnection)
|
||||||
|
#endif
|
||||||
|
|
||||||
EDELIB_NS_USING(XSettingsData)
|
EDELIB_NS_USING(XSettingsData)
|
||||||
|
|
||||||
/* XSETTINGS manager with serialization capability. Also it will write/undo to xrdb (X Resource database). */
|
/* XSETTINGS manager with serialization capability. Also it will write/undo to xrdb (X Resource database). */
|
||||||
class Xsm : public edelib::XSettingsManager {
|
class Xsm : public edelib::XSettingsManager {
|
||||||
private:
|
private:
|
||||||
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
EdbusConnection* dbus_conn;
|
EdbusConnection* dbus_conn;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* replace XResource values from one from XSETTINGS */
|
/* replace XResource values from one from XSETTINGS */
|
||||||
void xresource_replace(void);
|
void xresource_replace(void);
|
||||||
@ -33,11 +38,14 @@ private:
|
|||||||
/* serve XSETTINGS via D-Bus */
|
/* serve XSETTINGS via D-Bus */
|
||||||
void xsettings_dbus_serve(void);
|
void xsettings_dbus_serve(void);
|
||||||
public:
|
public:
|
||||||
Xsm() : dbus_conn(NULL) { }
|
#ifdef EDELIB_HAVE_DBUS
|
||||||
~Xsm();
|
Xsm() { dbus_conn = NULL; }
|
||||||
|
|
||||||
|
~Xsm() { delete dbus_conn; }
|
||||||
|
|
||||||
/* return loaded D-Bus connection */
|
/* return loaded D-Bus connection */
|
||||||
EdbusConnection* get_dbus_connection(void) { return dbus_conn; }
|
EdbusConnection* get_dbus_connection(void) { return dbus_conn; }
|
||||||
|
#endif
|
||||||
|
|
||||||
/* access to manager content */
|
/* access to manager content */
|
||||||
XSettingsData* get_manager_data(void) { return manager_data; }
|
XSettingsData* get_manager_data(void) { return manager_data; }
|
||||||
|
@ -6,12 +6,21 @@ RELEASE_VERSION="2.0"
|
|||||||
|
|
||||||
############################################
|
############################################
|
||||||
|
|
||||||
|
script_dir="$( cd "$( dirname "$0" )" && pwd )"
|
||||||
|
release_dir="release-$RELEASE_VERSION"
|
||||||
|
release_dir_full="`pwd`/$release_dir"
|
||||||
|
|
||||||
dprint() {
|
dprint() {
|
||||||
echo "* $1"
|
echo "* $1"
|
||||||
}
|
}
|
||||||
|
|
||||||
release_dir="release-$RELEASE_VERSION"
|
generate_changelog() {
|
||||||
release_dir_full="`pwd`/$release_dir"
|
$script_dir/svn2cl/svn2cl.sh --authors=$script_dir/svn2cl/authors.xml -o $1/ChangeLog $1
|
||||||
|
}
|
||||||
|
|
||||||
|
upload_file() {
|
||||||
|
scp $1-$2.tar.gz karijes@frs.sourceforge.net:/home/frs/project/ede/$1/$2/$1-$2.tar.gz
|
||||||
|
}
|
||||||
|
|
||||||
# prepare location dir
|
# prepare location dir
|
||||||
rm -Rf $release_dir
|
rm -Rf $release_dir
|
||||||
@ -31,13 +40,15 @@ svn copy "$ede_svn_trunk/edelib" "$ede_svn_tags/edelib-$RELEASE_VERSION" -m "Tag
|
|||||||
dprint "Tagging ede"
|
dprint "Tagging ede"
|
||||||
svn copy "$ede_svn_trunk/ede2" "$ede_svn_tags/ede-$RELEASE_VERSION" -m "Tagging ede to $RELEASE_VERSION"
|
svn copy "$ede_svn_trunk/ede2" "$ede_svn_tags/ede-$RELEASE_VERSION" -m "Tagging ede to $RELEASE_VERSION"
|
||||||
|
|
||||||
############################################
|
###########################################
|
||||||
|
|
||||||
package="edelib-$RELEASE_VERSION"
|
package="edelib-$RELEASE_VERSION"
|
||||||
|
|
||||||
dprint "Getting edelib..."
|
dprint "Getting edelib..."
|
||||||
svn co "$ede_svn_trunk/edelib" $package
|
svn co "$ede_svn_trunk/edelib" $package
|
||||||
|
|
||||||
|
generate_changelog $package
|
||||||
|
|
||||||
cd $package
|
cd $package
|
||||||
find . -name ".svn" -type d | xargs rm -Rf
|
find . -name ".svn" -type d | xargs rm -Rf
|
||||||
./autogen.sh
|
./autogen.sh
|
||||||
@ -54,6 +65,8 @@ package="ede-$RELEASE_VERSION"
|
|||||||
dprint "Getting ede..."
|
dprint "Getting ede..."
|
||||||
svn co "$ede_svn_trunk/ede2" $package
|
svn co "$ede_svn_trunk/ede2" $package
|
||||||
|
|
||||||
|
generate_changelog $package
|
||||||
|
|
||||||
cd $package
|
cd $package
|
||||||
find . -name ".svn" -type d | xargs rm -Rf
|
find . -name ".svn" -type d | xargs rm -Rf
|
||||||
./autogen.sh
|
./autogen.sh
|
||||||
@ -77,3 +90,7 @@ cd ..
|
|||||||
tar -czpvf $package.tar.gz $package
|
tar -czpvf $package.tar.gz $package
|
||||||
md5sum $package.tar.gz >> checksum
|
md5sum $package.tar.gz >> checksum
|
||||||
|
|
||||||
|
############################################
|
||||||
|
|
||||||
|
#upload_file edelib $RELEASE_VERSION
|
||||||
|
#upload_file ede $RELEASE_VERSION
|
||||||
|
9
tools/svn2cl/authors.xml
Normal file
9
tools/svn2cl/authors.xml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<authors xmlns:html="http://www.w3.org/1999/xhtml">
|
||||||
|
<author uid="karijes">
|
||||||
|
Sanel Zukan <karijes@users.sourceforge.net>
|
||||||
|
</author>
|
||||||
|
<author uid="vljubovic">
|
||||||
|
Vedran Ljubovic <vljubovic@users.sourceforge.net>
|
||||||
|
</author>
|
||||||
|
</authors>
|
343
tools/svn2cl/svn2cl.sh
Executable file
343
tools/svn2cl/svn2cl.sh
Executable file
@ -0,0 +1,343 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# svn2cl.sh - front end shell script for svn2cl.xsl, calls xsltproc
|
||||||
|
# with the correct parameters
|
||||||
|
#
|
||||||
|
# Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010 Arthur de Jong.
|
||||||
|
#
|
||||||
|
# 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. The name of the author may not be used to endorse or promote
|
||||||
|
# products derived from this software without specific prior
|
||||||
|
# written permission.
|
||||||
|
#
|
||||||
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
|
||||||
|
|
||||||
|
# exit on any failures
|
||||||
|
set -e
|
||||||
|
# report unset variables
|
||||||
|
set -u
|
||||||
|
|
||||||
|
# svn2cl version
|
||||||
|
VERSION="0.13"
|
||||||
|
|
||||||
|
# set default parameters
|
||||||
|
PWD=`pwd`
|
||||||
|
STRIPPREFIX="AUTOMATICALLY-DETERMINED"
|
||||||
|
LINELEN=75
|
||||||
|
GROUPBYDAY="no"
|
||||||
|
INCLUDEREV="no"
|
||||||
|
BREAKBEFOREMSG="no"
|
||||||
|
REPARAGRAPH="no"
|
||||||
|
SEPARATEDAYLOGS="no"
|
||||||
|
ACTIONS="no"
|
||||||
|
CHANGELOG=""
|
||||||
|
OUTSTYLE="cl"
|
||||||
|
SVNLOGCMD="svn --verbose --xml log"
|
||||||
|
SVNINFOCMD="svn --non-interactive info"
|
||||||
|
AUTHORSFILE=""
|
||||||
|
IGNORE_MESSAGE_STARTING=""
|
||||||
|
TITLE="ChangeLog"
|
||||||
|
REVISION_LINK="#r"
|
||||||
|
TICKET_LINK=""
|
||||||
|
TMPFILES=""
|
||||||
|
AWK="awk"
|
||||||
|
|
||||||
|
# do command line checking
|
||||||
|
prog=`basename "$0"`
|
||||||
|
while [ $# -gt 0 ]
|
||||||
|
do
|
||||||
|
case "$1" in
|
||||||
|
--strip-prefix)
|
||||||
|
STRIPPREFIX="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--strip-prefix=*)
|
||||||
|
STRIPPREFIX=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--linelen)
|
||||||
|
LINELEN="$2";
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--linelen=*)
|
||||||
|
LINELEN=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--group-by-day)
|
||||||
|
GROUPBYDAY="yes";
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--separate-daylogs)
|
||||||
|
SEPARATEDAYLOGS="yes"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-i|--include-rev)
|
||||||
|
INCLUDEREV="yes";
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-a|--include-actions)
|
||||||
|
ACTIONS="yes"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--break-before-msg|--breaks-before-msg)
|
||||||
|
# FIXME: if next argument is numeric use that as a parameter
|
||||||
|
BREAKBEFOREMSG="yes"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--break-before-msg=*|--breaks-before-msg=*)
|
||||||
|
BREAKBEFOREMSG=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--reparagraph)
|
||||||
|
REPARAGRAPH="yes"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--title)
|
||||||
|
TITLE="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--title=*)
|
||||||
|
TITLE=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--revision-link)
|
||||||
|
REVISION_LINK="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--revision-link=*)
|
||||||
|
REVISION_LINK=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--ticket-link)
|
||||||
|
TICKET_LINKK="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--ticket-link=*)
|
||||||
|
TICKET_LINK=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--ignore-message-starting)
|
||||||
|
IGNORE_MESSAGE_STARTING="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--ignore-message-starting=*)
|
||||||
|
IGNORE_MESSAGE_STARTING=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-f|--file|-o|--output)
|
||||||
|
CHANGELOG="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--file=*|--output=*)
|
||||||
|
CHANGELOG=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--stdout)
|
||||||
|
CHANGELOG="-"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--authors)
|
||||||
|
AUTHORSFILE="$2"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--authors=*)
|
||||||
|
AUTHORSFILE=`echo "$1" | sed 's/^--[a-z-]*=//'`
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--html)
|
||||||
|
OUTSTYLE="html"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-r|--revision|-c|--change|--targets|-l|--limit)
|
||||||
|
# add these as extra options to the log command (with argument)
|
||||||
|
arg=`echo "$2" | sed "s/'/'\"'\"'/g"`
|
||||||
|
SVNLOGCMD="$SVNLOGCMD $1 '$arg'"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--revision=*|--change=*|--targets=*|--limit=*)
|
||||||
|
# these are single argument versions of the above (with argument)
|
||||||
|
arg=`echo "$1" | sed "s/'/'\"'\"'/g"`
|
||||||
|
SVNLOGCMD="$SVNLOGCMD '$arg'"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--username|--password|--config-dir|--config-option)
|
||||||
|
# add these as extra options to the log and info commands (with argument)
|
||||||
|
arg=`echo "$2" | sed "s/'/'\"'\"'/g"`
|
||||||
|
SVNLOGCMD="$SVNLOGCMD $1 '$arg'"
|
||||||
|
SVNINFOCMD="$SVNINFOCMD $1 '$arg'"
|
||||||
|
shift 2 || { echo "$prog: option requires an argument -- $1";exit 1; }
|
||||||
|
;;
|
||||||
|
--username=*|--password=*|--config-dir=*|--config-option=*)
|
||||||
|
# these are single argument versions of the above (with argument)
|
||||||
|
arg=`echo "$1" | sed "s/'/'\"'\"'/g"`
|
||||||
|
SVNLOGCMD="$SVNLOGCMD '$arg'"
|
||||||
|
SVNINFOCMD="$SVNINFOCMD '$arg'"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-g|--use-merge-history|--stop-on-copy)
|
||||||
|
# add these as simple options to the log command
|
||||||
|
SVNLOGCMD="$SVNLOGCMD $1"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--no-auth-cache|--non-interactive|--trust-server-cert)
|
||||||
|
# add these as simple options to both the log and info commands
|
||||||
|
SVNLOGCMD="$SVNLOGCMD $1"
|
||||||
|
SVNINFOCMD="$SVNINFOCMD $1"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
-V|--version)
|
||||||
|
echo "$prog $VERSION";
|
||||||
|
echo "Written by Arthur de Jong."
|
||||||
|
echo ""
|
||||||
|
echo "Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010 Arthur de Jong."
|
||||||
|
echo "This is free software; see the source for copying conditions. There is NO"
|
||||||
|
echo "warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
-h|--help)
|
||||||
|
echo "Usage: $prog [OPTION]... [PATH]..."
|
||||||
|
echo "Generate a ChangeLog from a subversion repository."
|
||||||
|
echo ""
|
||||||
|
echo " --strip-prefix=NAME prefix to strip from all entries, defaults path"
|
||||||
|
echo " inside the repository"
|
||||||
|
echo " --linelen=NUM maximum length of an output line"
|
||||||
|
echo " --group-by-day group changelog entries by day"
|
||||||
|
echo " --separate-daylogs put a blank line between grouped by day entries"
|
||||||
|
echo " -i, --include-rev include revision numbers"
|
||||||
|
echo " -a, --include-actions add [ADD], [DEL] and [CPY] tags to files"
|
||||||
|
echo " --break-before-msg[=NUM] add a line break (or multiple breaks)"
|
||||||
|
echo " between the paths and the log message"
|
||||||
|
echo " --reparagraph rewrap lines inside a paragraph"
|
||||||
|
echo " --title=NAME title used in html file"
|
||||||
|
echo " --revision-link=NAME link revision numbers in html output"
|
||||||
|
echo " --ticket-link=NAME change #foo strings to links"
|
||||||
|
echo " --ignore-message-starting=STRING"
|
||||||
|
echo " ignore messages starting with the string"
|
||||||
|
echo " -o, --output=FILE output to FILE instead of ChangeLog"
|
||||||
|
echo " -f, --file=FILE alias for -o, --output"
|
||||||
|
echo " --stdout output to stdout instead of ChangeLog"
|
||||||
|
echo " --authors=FILE file to read for authors"
|
||||||
|
echo " --html output as html instead of plain text"
|
||||||
|
echo " -h, --help display this help and exit"
|
||||||
|
echo " -V, --version output version information and exit"
|
||||||
|
echo ""
|
||||||
|
echo "PATH arguments and the following options are passed to the svn log"
|
||||||
|
echo "command: -r, --revision, -g, --use-merge-history, -c, --change,"
|
||||||
|
echo "--targets, --stop-on-copy, -l, --username, --password, --no-auth-cache,"
|
||||||
|
echo "--non-interactive, --trust-server-cert, --config-dir and --config-option"
|
||||||
|
echo "(see 'svn help log' for more information)."
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
-*)
|
||||||
|
echo "$prog: invalid option -- $1"
|
||||||
|
echo "Try '$prog --help' for more information."
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
arg=`echo "$1" | sed "s/'/'\"'\"'/g"`
|
||||||
|
SVNLOGCMD="$SVNLOGCMD '$arg'"
|
||||||
|
SVNINFOCMD="$SVNINFOCMD '$arg'"
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
# find the directory that this script resides in
|
||||||
|
prog="$0"
|
||||||
|
while [ -h "$prog" ]
|
||||||
|
do
|
||||||
|
dir=`dirname "$prog"`
|
||||||
|
prog=`ls -ld "$prog" | sed "s/^.*-> \(.*\)/\1/;/^[^/]/s,^,$dir/,"`
|
||||||
|
done
|
||||||
|
dir=`dirname "$prog"`
|
||||||
|
dir=`cd "$dir" && pwd`
|
||||||
|
XSL="$dir/svn2${OUTSTYLE}.xsl"
|
||||||
|
|
||||||
|
# check if the authors file is formatted as a legacy
|
||||||
|
# colon separated file
|
||||||
|
if [ -n "$AUTHORSFILE" ] && \
|
||||||
|
egrep '^(#.*|[a-zA-Z0-9].*:)' "$AUTHORSFILE" > /dev/null 2>/dev/null
|
||||||
|
then
|
||||||
|
# create a temporary file
|
||||||
|
tmpfile=`mktemp -t svn2cl.XXXXXX 2> /dev/null || tempfile -s .svn2cl 2> /dev/null || echo "$AUTHORSFILE.$$.xml"`
|
||||||
|
arg=`echo "$tmpfile" | sed "s/'/'\"'\"'/g"`
|
||||||
|
TMPFILES="$TMPFILES '$arg'"
|
||||||
|
# generate an authors.xml file on the fly
|
||||||
|
echo '<authors>' > "$tmpfile"
|
||||||
|
sed -n 's/&/\&/g;s/</\</g;s/>/\>/g;s|^\([a-zA-Z0-9][^:]*\):\(.*\)$| <author uid="\1">\2</author>|p' \
|
||||||
|
< "$AUTHORSFILE" >> "$tmpfile"
|
||||||
|
echo '</authors>' >> "$tmpfile"
|
||||||
|
AUTHORSFILE="$tmpfile"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# find the absolute path of the authors file
|
||||||
|
# (otherwise xsltproc will find the file relative to svn2cl.xsl)
|
||||||
|
pwd=`pwd`
|
||||||
|
AUTHORSFILE=`echo "$AUTHORSFILE" | sed "/^[^/]/s|^|$pwd/|"`
|
||||||
|
|
||||||
|
# if no filename was specified, make one up
|
||||||
|
if [ -z "$CHANGELOG" ]
|
||||||
|
then
|
||||||
|
CHANGELOG="ChangeLog"
|
||||||
|
if [ "$OUTSTYLE" != "cl" ]
|
||||||
|
then
|
||||||
|
CHANGELOG="$CHANGELOG.$OUTSTYLE"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# try to determin a prefix to strip from all paths
|
||||||
|
if [ "$STRIPPREFIX" = "AUTOMATICALLY-DETERMINED" ]
|
||||||
|
then
|
||||||
|
STRIPPREFIX=`LANG=C eval "$SVNINFOCMD" | $AWK '/^URL:/{url=$2} /^Repository Root:/{root=$3} END{if(root){print substr(url,length(root)+2)}else{n=split(url,u,"/");print u[n]}}'`
|
||||||
|
STRIPPREFIX=`echo "$STRIPPREFIX" | sed 's/%20/ /g'`
|
||||||
|
fi
|
||||||
|
|
||||||
|
# redirect stdout to the changelog file if needed
|
||||||
|
if [ "x$CHANGELOG" != "x-" ]
|
||||||
|
then
|
||||||
|
exec > "$CHANGELOG"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# actually run the command we need
|
||||||
|
eval "$SVNLOGCMD" | \
|
||||||
|
xsltproc --stringparam strip-prefix "$STRIPPREFIX" \
|
||||||
|
--stringparam linelen "$LINELEN" \
|
||||||
|
--stringparam groupbyday "$GROUPBYDAY" \
|
||||||
|
--stringparam separate-daylogs "$SEPARATEDAYLOGS" \
|
||||||
|
--stringparam include-rev "$INCLUDEREV" \
|
||||||
|
--stringparam include-actions "$ACTIONS" \
|
||||||
|
--stringparam breakbeforemsg "$BREAKBEFOREMSG" \
|
||||||
|
--stringparam reparagraph "$REPARAGRAPH" \
|
||||||
|
--stringparam authorsfile "$AUTHORSFILE" \
|
||||||
|
--stringparam title "$TITLE" \
|
||||||
|
--stringparam revision-link "$REVISION_LINK" \
|
||||||
|
--stringparam ticket-link "$TICKET_LINK" \
|
||||||
|
--stringparam ignore-message-starting "$IGNORE_MESSAGE_STARTING" \
|
||||||
|
--nowrite \
|
||||||
|
--nomkdir \
|
||||||
|
--nonet \
|
||||||
|
"$XSL" -
|
||||||
|
|
||||||
|
# clean up temporary files
|
||||||
|
[ -n "$TMPFILES" ] && eval "rm -f $TMPFILES"
|
||||||
|
|
||||||
|
# we're done (the previous command could return false)
|
||||||
|
exit 0
|
457
tools/svn2cl/svn2cl.xsl
Normal file
457
tools/svn2cl/svn2cl.xsl
Normal file
@ -0,0 +1,457 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
|
||||||
|
svn2cl.xsl - xslt stylesheet for converting svn log to a normal
|
||||||
|
changelog
|
||||||
|
|
||||||
|
version 0.13
|
||||||
|
|
||||||
|
Usage (replace ++ with two minus signs which aren't allowed
|
||||||
|
inside xml comments):
|
||||||
|
svn ++verbose ++xml log | \
|
||||||
|
xsltproc ++stringparam strip-prefix `basename $(pwd)` \
|
||||||
|
++stringparam linelen 75 \
|
||||||
|
++stringparam groupbyday yes \
|
||||||
|
++stringparam separate-daylogs yes \
|
||||||
|
++stringparam include-rev yes \
|
||||||
|
++stringparam include-actions yes \
|
||||||
|
++stringparam breakbeforemsg yes/2 \
|
||||||
|
++stringparam reparagraph yes \
|
||||||
|
++stringparam authorsfile FILE \
|
||||||
|
++stringparam ignore-message-starting \
|
||||||
|
svn2cl.xsl - > ChangeLog
|
||||||
|
|
||||||
|
This file is based on several implementations of this conversion
|
||||||
|
that I was not completely happy with and some other common
|
||||||
|
xslt constructs found on the web.
|
||||||
|
|
||||||
|
Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Arthur de Jong.
|
||||||
|
|
||||||
|
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. The name of the author may not be used to endorse or promote
|
||||||
|
products derived from this software without specific prior
|
||||||
|
written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
|
||||||
|
|
||||||
|
-->
|
||||||
|
|
||||||
|
<xsl:stylesheet
|
||||||
|
version="1.0"
|
||||||
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
||||||
|
|
||||||
|
<xsl:output
|
||||||
|
method="text"
|
||||||
|
encoding="utf-8"
|
||||||
|
media-type="text/plain"
|
||||||
|
omit-xml-declaration="yes"
|
||||||
|
standalone="yes"
|
||||||
|
indent="no" />
|
||||||
|
|
||||||
|
<xsl:strip-space elements="*" />
|
||||||
|
|
||||||
|
<!-- the prefix of pathnames to strip -->
|
||||||
|
<xsl:param name="strip-prefix" select="'/'" />
|
||||||
|
|
||||||
|
<!-- the length of a line to wrap messages at -->
|
||||||
|
<xsl:param name="linelen" select="75" />
|
||||||
|
|
||||||
|
<!-- whether entries should be grouped by day -->
|
||||||
|
<xsl:param name="groupbyday" select="'no'" />
|
||||||
|
|
||||||
|
<!-- whether to seperate log messages by empty lines -->
|
||||||
|
<xsl:param name="separate-daylogs" select="'no'" />
|
||||||
|
|
||||||
|
<!-- whether a revision number should be included -->
|
||||||
|
<xsl:param name="include-rev" select="'no'" />
|
||||||
|
|
||||||
|
<!-- whether aaction labels should be added to files -->
|
||||||
|
<xsl:param name="include-actions" select="'no'" />
|
||||||
|
|
||||||
|
<!-- whether the log message should start on a new line -->
|
||||||
|
<xsl:param name="breakbeforemsg" select="'no'" />
|
||||||
|
|
||||||
|
<!-- whether the message should be rewrapped within one paragraph -->
|
||||||
|
<xsl:param name="reparagraph" select="'no'" />
|
||||||
|
|
||||||
|
<!-- whether certain messages should be ignored -->
|
||||||
|
<xsl:param name="ignore-message-starting" select="''" />
|
||||||
|
|
||||||
|
<!-- location of authors file if any -->
|
||||||
|
<xsl:param name="authorsfile" select="''" />
|
||||||
|
<xsl:key name="author-lookup" match="author" use="@uid" />
|
||||||
|
<xsl:variable name="authors-top" select="document($authorsfile)/authors" />
|
||||||
|
|
||||||
|
<!-- determin the path part to strip -->
|
||||||
|
<xsl:variable name="strip-path">
|
||||||
|
<!-- if strip-prefix does not start with a slash, prepend it -->
|
||||||
|
<xsl:if test="not(starts-with($strip-prefix,'/'))">
|
||||||
|
<xsl:text>/</xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
<!-- the prefix itself -->
|
||||||
|
<xsl:value-of select="$strip-prefix" />
|
||||||
|
<!-- if strip-prefix does not start with a slash, append it -->
|
||||||
|
<xsl:if test="substring($strip-prefix,string-length($strip-prefix),1)!='/'">
|
||||||
|
<xsl:text>/</xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:variable>
|
||||||
|
|
||||||
|
<!-- match the topmost log entry -->
|
||||||
|
<xsl:template match="log">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="$ignore-message-starting != ''">
|
||||||
|
<!-- only handle logentries with don't contain the string -->
|
||||||
|
<xsl:apply-templates select="logentry[not(starts-with(msg,$ignore-message-starting))]" />
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:apply-templates select="logentry" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
<!-- add newlines at the end of the changelog -->
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- format one entry from the log -->
|
||||||
|
<xsl:template match="logentry">
|
||||||
|
<xsl:choose>
|
||||||
|
<!-- if we're grouping we should omit some headers -->
|
||||||
|
<xsl:when test="$groupbyday='yes'">
|
||||||
|
<!-- fetch previous entry's date -->
|
||||||
|
<xsl:variable name="prevdate">
|
||||||
|
<xsl:apply-templates select="preceding-sibling::logentry[position()=1]/date" />
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- fetch previous entry's author -->
|
||||||
|
<xsl:variable name="prevauthor">
|
||||||
|
<xsl:value-of select="normalize-space(preceding-sibling::logentry[position()=1]/author)" />
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- fetch this entry's date -->
|
||||||
|
<xsl:variable name="date">
|
||||||
|
<xsl:apply-templates select="date" />
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- fetch this entry's author -->
|
||||||
|
<xsl:variable name="author">
|
||||||
|
<xsl:value-of select="normalize-space(author)" />
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- check if header is changed -->
|
||||||
|
<xsl:if test="($prevdate!=$date) or ($prevauthor!=$author)">
|
||||||
|
<!-- add newline -->
|
||||||
|
<xsl:if test="not(position()=1)">
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
<!-- date -->
|
||||||
|
<xsl:value-of select="$date" />
|
||||||
|
<!-- two spaces -->
|
||||||
|
<xsl:text>  </xsl:text>
|
||||||
|
<!-- author's name -->
|
||||||
|
<xsl:apply-templates select="author" />
|
||||||
|
<!-- two newlines -->
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
<xsl:if test="$separate-daylogs!='yes'"><xsl:text> </xsl:text></xsl:if>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:when>
|
||||||
|
<!-- write the log header -->
|
||||||
|
<xsl:otherwise>
|
||||||
|
<!-- add newline -->
|
||||||
|
<xsl:if test="not(position()=1)">
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
<!-- date -->
|
||||||
|
<xsl:apply-templates select="date" />
|
||||||
|
<!-- two spaces -->
|
||||||
|
<xsl:text>  </xsl:text>
|
||||||
|
<!-- author's name -->
|
||||||
|
<xsl:apply-templates select="author" />
|
||||||
|
<!-- two newlines -->
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
<!-- get paths string -->
|
||||||
|
<xsl:variable name="paths">
|
||||||
|
<xsl:apply-templates select="paths" />
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- get revision number -->
|
||||||
|
<xsl:variable name="rev">
|
||||||
|
<xsl:if test="$include-rev='yes'">
|
||||||
|
<xsl:text>[r</xsl:text>
|
||||||
|
<xsl:value-of select="@revision" />
|
||||||
|
<xsl:text>] </xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- trim trailing newlines -->
|
||||||
|
<xsl:variable name="msg">
|
||||||
|
<!-- add a line break before the log message -->
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="$breakbeforemsg='yes'">
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:when test="number($breakbeforemsg)>0">
|
||||||
|
<xsl:call-template name="newlines">
|
||||||
|
<xsl:with-param name="count" select="number($breakbeforemsg)" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
</xsl:choose>
|
||||||
|
<xsl:call-template name="trim-newln">
|
||||||
|
<xsl:with-param name="txt" select="msg" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- add newline here if separate-daylogs is in effect -->
|
||||||
|
<xsl:if test="$groupbyday='yes' and $separate-daylogs='yes'"><xsl:text> </xsl:text></xsl:if>
|
||||||
|
<!-- first line is indented (other indents are done in wrap template) -->
|
||||||
|
<xsl:text>	* </xsl:text>
|
||||||
|
<!-- set up the text to wrap -->
|
||||||
|
<xsl:variable name="txt">
|
||||||
|
<xsl:value-of select="$rev" />
|
||||||
|
<xsl:if test="$paths!=''">
|
||||||
|
<xsl:value-of select="concat($paths,': ')" />
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:value-of select="$msg" />
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- print the paths and message nicely wrapped -->
|
||||||
|
<xsl:call-template name="wrap">
|
||||||
|
<xsl:with-param name="txt" select="$txt" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- format date -->
|
||||||
|
<xsl:template match="date">
|
||||||
|
<xsl:variable name="date" select="normalize-space(.)" />
|
||||||
|
<!-- output date part -->
|
||||||
|
<xsl:value-of select="substring($date,1,10)" />
|
||||||
|
<!-- output time part -->
|
||||||
|
<xsl:if test="$groupbyday!='yes'">
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
<xsl:value-of select="substring($date,12,5)" />
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- format author -->
|
||||||
|
<xsl:template match="author">
|
||||||
|
<xsl:variable name="uid" select="normalize-space(.)" />
|
||||||
|
<!-- try to lookup author in authorsfile -->
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="$authorsfile!=''">
|
||||||
|
<xsl:for-each select="$authors-top">
|
||||||
|
<xsl:variable name="author" select="key('author-lookup',$uid)" />
|
||||||
|
<!-- present result -->
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="string($author/.)">
|
||||||
|
<xsl:apply-templates select="$author/node()" mode="copy" />
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="$uid" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="$uid" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- copy but normalize text -->
|
||||||
|
<xsl:template match="text()" mode="copy">
|
||||||
|
<xsl:value-of select="normalize-space(.)" />
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- simple copy template -->
|
||||||
|
<xsl:template match="@*|node()" mode="copy">
|
||||||
|
<xsl:copy>
|
||||||
|
<xsl:apply-templates select="@*|node()" mode="copy" />
|
||||||
|
</xsl:copy>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- present a list of paths names -->
|
||||||
|
<xsl:template match="paths">
|
||||||
|
<xsl:choose>
|
||||||
|
<!-- only handle paths that begin with the path and strip the path -->
|
||||||
|
<xsl:when test="$strip-prefix != ''">
|
||||||
|
<!-- filter on all entries within directory -->
|
||||||
|
<xsl:for-each select="path[starts-with(concat(normalize-space(.),'/'),$strip-path)]">
|
||||||
|
<xsl:sort select="normalize-space(.)" data-type="text" />
|
||||||
|
<!-- unless we are the first entry, add a comma -->
|
||||||
|
<xsl:if test="not(position()=1)">
|
||||||
|
<xsl:text>, </xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
<!-- get path part -->
|
||||||
|
<xsl:variable name="path" select="substring(normalize-space(.),string-length($strip-path)+1)" />
|
||||||
|
<!-- translate empty string to dot and print result -->
|
||||||
|
<xsl:if test="$path = ''">
|
||||||
|
<xsl:text>.</xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
<xsl:value-of select="$path" />
|
||||||
|
<!-- add the action flag -->
|
||||||
|
<xsl:if test="$include-actions='yes'">
|
||||||
|
<xsl:apply-templates select="." mode="action"/>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:when>
|
||||||
|
<!-- print a simple list of all paths -->
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:for-each select="path">
|
||||||
|
<xsl:sort select="normalize-space(.)" data-type="text" />
|
||||||
|
<!-- unless we are the first entry, add a comma -->
|
||||||
|
<xsl:if test="not(position()=1)">
|
||||||
|
<xsl:text>, </xsl:text>
|
||||||
|
</xsl:if>
|
||||||
|
<!-- print the path name -->
|
||||||
|
<xsl:value-of select="normalize-space(.)" />
|
||||||
|
<!-- add the action flag -->
|
||||||
|
<xsl:if test="$include-actions='yes'">
|
||||||
|
<xsl:apply-templates select="." mode="action"/>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:for-each>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<xsl:template match="path" mode="action">
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="@action='D'">
|
||||||
|
<xsl:text>[DEL]</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:when test="@copyfrom-path">
|
||||||
|
<xsl:text>[CPY]</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:when test="@action='A'">
|
||||||
|
<xsl:text>[ADD]</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- string-wrapping template -->
|
||||||
|
<xsl:template name="wrap">
|
||||||
|
<xsl:param name="txt" />
|
||||||
|
<xsl:variable name="normtxt" select="normalize-space($txt)" />
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="contains($txt,' ')">
|
||||||
|
<!-- text contains newlines, do the first line -->
|
||||||
|
<xsl:call-template name="wrap">
|
||||||
|
<xsl:with-param name="txt" select="substring-before($txt,' ')" />
|
||||||
|
</xsl:call-template>
|
||||||
|
<!-- print tab -->
|
||||||
|
<xsl:text>	  </xsl:text>
|
||||||
|
<!-- wrap the rest of the text -->
|
||||||
|
<xsl:call-template name="wrap">
|
||||||
|
<xsl:with-param name="txt" select="substring-after($txt,' ')" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:when test="(string-length($normtxt) < (($linelen)-9)) or not(contains($normtxt,' '))">
|
||||||
|
<!-- this is easy, nothing to do -->
|
||||||
|
<xsl:value-of select="$normtxt" />
|
||||||
|
<!-- add newline -->
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<!-- find the first line -->
|
||||||
|
<xsl:variable name="tmp" select="substring($normtxt,1,(($linelen)-9))" />
|
||||||
|
<xsl:variable name="line">
|
||||||
|
<xsl:choose>
|
||||||
|
<!-- if our attempt contains spaces wrap on that -->
|
||||||
|
<xsl:when test="contains($tmp,' ')">
|
||||||
|
<xsl:call-template name="find-line">
|
||||||
|
<xsl:with-param name="txt" select="$tmp" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<!-- otherwise use the first non-space characters from the text -->
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="substring-before($normtxt,' ')" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:variable>
|
||||||
|
<!-- print line -->
|
||||||
|
<xsl:value-of select="$line" />
|
||||||
|
<!-- print newline and tab -->
|
||||||
|
<xsl:text> 	  </xsl:text>
|
||||||
|
<!-- wrap the rest of the text -->
|
||||||
|
<xsl:call-template name="wrap">
|
||||||
|
<xsl:with-param name="txt" select="normalize-space(substring($normtxt,string-length($line)+1))" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- template to trim line to contain space as last char -->
|
||||||
|
<xsl:template name="find-line">
|
||||||
|
<xsl:param name="txt" />
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="substring($txt,string-length($txt),1)=' '">
|
||||||
|
<xsl:value-of select="substring($txt,1,string-length($txt)-1)" />
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:call-template name="find-line">
|
||||||
|
<xsl:with-param name="txt" select="substring($txt,1,string-length($txt)-1)" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- template to trim trailing and starting newlines -->
|
||||||
|
<xsl:template name="trim-newln">
|
||||||
|
<xsl:param name="txt" />
|
||||||
|
<xsl:choose>
|
||||||
|
<!-- find starting newlines -->
|
||||||
|
<xsl:when test="substring($txt,1,1) = ' '">
|
||||||
|
<xsl:call-template name="trim-newln">
|
||||||
|
<xsl:with-param name="txt" select="substring($txt,2)" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<!-- find trailing newlines -->
|
||||||
|
<xsl:when test="substring($txt,string-length($txt),1) = ' '">
|
||||||
|
<xsl:call-template name="trim-newln">
|
||||||
|
<xsl:with-param name="txt" select="substring($txt,1,string-length($txt)-1)" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<!-- if the message has paragraphs, find the first one -->
|
||||||
|
<xsl:when test="$reparagraph='yes' and contains($txt,' ')">
|
||||||
|
<!-- remove newlines from first paragraph -->
|
||||||
|
<xsl:value-of select="normalize-space(substring-before($txt,' '))" />
|
||||||
|
<!-- paragraph separator -->
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
<!-- do the rest of the text -->
|
||||||
|
<xsl:call-template name="trim-newln">
|
||||||
|
<xsl:with-param name="txt" select="substring-after($txt,' ')" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<!-- remove more single newlines -->
|
||||||
|
<xsl:when test="$reparagraph='yes'">
|
||||||
|
<xsl:value-of select="normalize-space($txt)" />
|
||||||
|
</xsl:when>
|
||||||
|
<!-- no newlines found, we're done -->
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="$txt" />
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- insert a number of newlines -->
|
||||||
|
<xsl:template name="newlines">
|
||||||
|
<xsl:param name="count" />
|
||||||
|
<xsl:text> </xsl:text>
|
||||||
|
<xsl:if test="$count>1">
|
||||||
|
<xsl:call-template name="newlines">
|
||||||
|
<xsl:with-param name="count" select="($count)-1" />
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:if>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
</xsl:stylesheet>
|
Loading…
Reference in New Issue
Block a user