Compare commits
82 Commits
v1.4.0-bet
...
v1.4.0
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9ce09713b6 | ||
|
|
4fa6faf608 | ||
|
|
a24ae13d9c | ||
|
|
64dd0d1b45 | ||
|
|
da63b1223c | ||
|
|
36f32c2aef | ||
|
|
063acadc3b | ||
|
|
81c720c05b | ||
|
|
edcdcb945a | ||
|
|
5df6430bb2 | ||
|
|
9a0096d07c | ||
|
|
25d33d6057 | ||
|
|
ab4c6247c7 | ||
|
|
1b69dbb38b | ||
|
|
bfdd488b00 | ||
|
|
54c8809bf4 | ||
|
|
0873665bec | ||
|
|
02b3033ca3 | ||
|
|
a27c8ad90c | ||
|
|
18a58f73de | ||
|
|
d1451a3c90 | ||
|
|
0bef47b2f3 | ||
|
|
ccc05d6658 | ||
|
|
c15de69156 | ||
|
|
8bfb44fd28 | ||
|
|
79d3b84fad | ||
|
|
b97701586e | ||
|
|
b120345fe7 | ||
|
|
ec5c65a530 | ||
|
|
77e7a1fa8d | ||
|
|
f6d45b68ef | ||
|
|
24d76a0d75 | ||
|
|
c3326efe94 | ||
|
|
c0e056bb84 | ||
|
|
8a7df36701 | ||
|
|
39ec6b1bb2 | ||
|
|
30b2406533 | ||
|
|
076d5dda0e | ||
|
|
e78eab46ff | ||
|
|
19a08f8d5e | ||
|
|
c6319117fd | ||
|
|
4c10ed4ada | ||
|
|
b0ab3ca80b | ||
|
|
9f89a2fe76 | ||
|
|
e386bfb550 | ||
|
|
0189a3f1bd | ||
|
|
d3a333e03c | ||
|
|
04d3e282fb | ||
|
|
4be5f970d5 | ||
|
|
31ceff181e | ||
|
|
42abf4101c | ||
|
|
f09cae74fb | ||
|
|
13a6393ec5 | ||
|
|
ace57f9dd4 | ||
|
|
e5117a98c9 | ||
|
|
c1f7af7e6f | ||
|
|
b4c116e2a2 | ||
|
|
a19a960b5e | ||
|
|
29d2094626 | ||
|
|
c3b82e6818 | ||
|
|
1a7c89326b | ||
|
|
3a1f04ac2d | ||
|
|
2c8e95a0f4 | ||
|
|
a9d94ef732 | ||
|
|
2756d17873 | ||
|
|
34d7f84fc2 | ||
|
|
cea9b389bf | ||
|
|
71b1e881d8 | ||
|
|
7ba47e9d44 | ||
|
|
be48cb646c | ||
|
|
47eb5ff1d9 | ||
|
|
b608f5a670 | ||
|
|
e81dc34c4e | ||
|
|
1603e627a3 | ||
|
|
bf978b3e0f | ||
|
|
0fdaf33288 | ||
|
|
367c4153c1 | ||
|
|
395c673a24 | ||
|
|
22de23c651 | ||
|
|
23926d2461 | ||
|
|
c03f31b6ba | ||
|
|
a1060a8538 |
1
.gitignore
vendored
@@ -1,3 +1,4 @@
|
|||||||
|
.gitmodules
|
||||||
*build*/
|
*build*/
|
||||||
*flymake*
|
*flymake*
|
||||||
CMakeLists.txt.user*
|
CMakeLists.txt.user*
|
||||||
|
|||||||
3
.gitmodules
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
[submodule "doc/ocdoc"]
|
||||||
|
path = doc/ocdoc
|
||||||
|
url = https://github.com/owncloud/documentation
|
||||||
@@ -13,12 +13,16 @@ else ()
|
|||||||
include ( ${CMAKE_SOURCE_DIR}/OWNCLOUD.cmake )
|
include ( ${CMAKE_SOURCE_DIR}/OWNCLOUD.cmake )
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if (NOT DEFINED APPLICATION_SHORTNAME)
|
||||||
|
set ( APPLICATION_SHORTNAME ${APPLICATION_NAME} )
|
||||||
|
endif()
|
||||||
|
|
||||||
include(${CMAKE_SOURCE_DIR}/VERSION.cmake)
|
include(${CMAKE_SOURCE_DIR}/VERSION.cmake)
|
||||||
configure_file( ${CMAKE_SOURCE_DIR}/src/mirall/version.h.in "${CMAKE_CURRENT_BINARY_DIR}/src/mirall/version.h" )
|
configure_file( ${CMAKE_SOURCE_DIR}/src/mirall/version.h.in "${CMAKE_CURRENT_BINARY_DIR}/src/mirall/version.h" )
|
||||||
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR} "${CMAKE_CURRENT_BINARY_DIR}/src/mirall/")
|
include_directories(BEFORE ${CMAKE_CURRENT_BINARY_DIR} "${CMAKE_CURRENT_BINARY_DIR}/src/mirall/")
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
include(DefineInstallationPaths)
|
||||||
include(GetGitRevisionDescription)
|
include(GetGitRevisionDescription)
|
||||||
get_git_head_revision(GIT_REFSPEC GIT_SHA1)
|
get_git_head_revision(GIT_REFSPEC GIT_SHA1)
|
||||||
|
|
||||||
@@ -34,10 +38,8 @@ if (${GIT_SHA1} STREQUAL "GITDIR-NOTFOUND")
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
## stupid, we should upstream this
|
set(SYSCONFDIR ${SYSCONF_INSTALL_DIR})
|
||||||
if("${CMAKE_INSTALL_PREFIX}" STREQUAL "/usr" AND NOT CMAKE_INSTALL_SYSCONFDIR)
|
set(DATADIR ${DATA_INSTALL_DIR})
|
||||||
set(CMAKE_INSTALL_SYSCONFDIR "/etc")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
#####
|
#####
|
||||||
## handle BUILD_OWNCLOUD_OSX_BUNDLE
|
## handle BUILD_OWNCLOUD_OSX_BUNDLE
|
||||||
@@ -83,25 +85,6 @@ set(USE_INOTIFY ${INOTIFY_FOUND})
|
|||||||
|
|
||||||
configure_file(config.h.in ${CMAKE_CURRENT_BINARY_DIR}/config.h)
|
configure_file(config.h.in ${CMAKE_CURRENT_BINARY_DIR}/config.h)
|
||||||
|
|
||||||
set(CPACK_SOURCE_IGNORE_FILES
|
|
||||||
# hidden files
|
|
||||||
"/\\\\..+$"
|
|
||||||
# temporary files
|
|
||||||
"\\\\.swp$"
|
|
||||||
# backup files
|
|
||||||
"~$"
|
|
||||||
# others
|
|
||||||
"\\\\.#"
|
|
||||||
"/#"
|
|
||||||
"/build/"
|
|
||||||
"/_build/"
|
|
||||||
# used before
|
|
||||||
"\\\\.o$"
|
|
||||||
"\\\\.lo$"
|
|
||||||
"\\\\.la$"
|
|
||||||
"Makefile\\\\.in$"
|
|
||||||
)
|
|
||||||
|
|
||||||
include(OwnCloudCPack.cmake)
|
include(OwnCloudCPack.cmake)
|
||||||
|
|
||||||
add_definitions(-DUNICODE)
|
add_definitions(-DUNICODE)
|
||||||
@@ -123,5 +106,5 @@ endif(UNIT_TESTING)
|
|||||||
if(BUILD_OWNCLOUD_OSX_BUNDLE)
|
if(BUILD_OWNCLOUD_OSX_BUNDLE)
|
||||||
configure_file(sync-exclude.lst ${OWNCLOUD_OSX_BUNDLE}/Contents/Resources/sync-exclude.lst COPYONLY)
|
configure_file(sync-exclude.lst ${OWNCLOUD_OSX_BUNDLE}/Contents/Resources/sync-exclude.lst COPYONLY)
|
||||||
else()
|
else()
|
||||||
install( FILES sync-exclude.lst DESTINATION ${CMAKE_INSTALL_SYSCONFDIR} )
|
install( FILES sync-exclude.lst DESTINATION ${SYSCONFDIR}/${APPLICATION_SHORTNAME} )
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
ChangeLog
|
ChangeLog
|
||||||
=========
|
=========
|
||||||
version 1.4.0beta1 (release 2013-08-08 ), csync 0.81.0 required
|
version 1.4.0 (release 2013-09-04 ), csync 0.90.0 required
|
||||||
|
|
||||||
* New Scheduler: Only sync when there are actual changes in the server
|
* New Scheduler: Only sync when there are actual changes in the server
|
||||||
* Add a Settings Dialog, move Proxy Settings there
|
* Add a Settings Dialog, move Proxy Settings there
|
||||||
@@ -19,6 +19,9 @@ version 1.4.0beta1 (release 2013-08-08 ), csync 0.81.0 required
|
|||||||
* Add an editor for ingore patterns
|
* Add an editor for ingore patterns
|
||||||
* ALlow to flag certain ignore patterns as discardable
|
* ALlow to flag certain ignore patterns as discardable
|
||||||
* Ensure to ship with all valid translations
|
* Ensure to ship with all valid translations
|
||||||
|
* Progress Dialog now preserves the last syncned items across sync runs
|
||||||
|
* Split Setup Wizard into multiple pages again
|
||||||
|
* Implement "--logfile -" to log to stdout
|
||||||
* Add preliminary support for Shibboleth authentication
|
* Add preliminary support for Shibboleth authentication
|
||||||
* Linux: Provide more icon sizes
|
* Linux: Provide more icon sizes
|
||||||
* Linux: Do not trigger notifier on ignored files
|
* Linux: Do not trigger notifier on ignored files
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
set( APPLICATION_SHORTNAME "owncloud" )
|
|
||||||
set( APPLICATION_NAME "ownCloud" )
|
set( APPLICATION_NAME "ownCloud" )
|
||||||
set( APPLICATION_EXECUTABLE "owncloud" )
|
#set( APPLICATION_SHORTNAME ${APPLICATION_NAME} )
|
||||||
set( APPLICATION_DOMAIN "owncloud.com" )
|
set( APPLICATION_EXECUTABLE "owncloud" )
|
||||||
set( APPLICATION_VENDOR "ownCloud, Inc" )
|
set( APPLICATION_DOMAIN "owncloud.com" )
|
||||||
set( THEME_CLASS "ownCloudTheme" )
|
set( APPLICATION_VENDOR "ownCloud, Inc" )
|
||||||
|
set( THEME_CLASS "ownCloudTheme" )
|
||||||
set( APPLICATION_REV_DOMAIN "com.owncloud.desktopclient" )
|
set( APPLICATION_REV_DOMAIN "com.owncloud.desktopclient" )
|
||||||
set( WIN_SETUP_BITMAP_PATH "${CMAKE_SOURCE_DIR}/admin/win/nsi" )
|
set( WIN_SETUP_BITMAP_PATH "${CMAKE_SOURCE_DIR}/admin/win/nsi" )
|
||||||
# set( THEME_INCLUDE "${OEM_THEME_DIR}/mytheme.h" )
|
# set( THEME_INCLUDE "${OEM_THEME_DIR}/mytheme.h" )
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
set( VERSION_MAJOR 1 )
|
set( VERSION_MAJOR 1 )
|
||||||
set( VERSION_MINOR 4 )
|
set( VERSION_MINOR 4 )
|
||||||
set( VERSION_PATCH 0 )
|
set( VERSION_PATCH 0 )
|
||||||
set( VERSION "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}${VERSION_SUFFIX}beta2")
|
set( VERSION "${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}${VERSION_SUFFIX}")
|
||||||
set( SOVERSION 0 )
|
set( SOVERSION 0 )
|
||||||
|
|
||||||
|
|||||||
@@ -10,8 +10,7 @@ mount="/Volumes/$(basename $src_dmg|cut -d"-" -f1)"
|
|||||||
|
|
||||||
test -e $tmp_dmg && rm -rf $tmp_dmg
|
test -e $tmp_dmg && rm -rf $tmp_dmg
|
||||||
hdiutil convert $src_dmg -format UDRW -o $tmp_dmg
|
hdiutil convert $src_dmg -format UDRW -o $tmp_dmg
|
||||||
open $tmp_dmg
|
hdiutil attach $tmp_dmg
|
||||||
sleep 12s
|
|
||||||
pushd $mount
|
pushd $mount
|
||||||
codesign -s "$identity" $mount/*.app
|
codesign -s "$identity" $mount/*.app
|
||||||
popd
|
popd
|
||||||
|
|||||||
108
cmake/modules/DefineInstallationPaths.cmake
Normal file
@@ -0,0 +1,108 @@
|
|||||||
|
if (UNIX)
|
||||||
|
# Suffix for Linux
|
||||||
|
SET(LIB_SUFFIX
|
||||||
|
CACHE STRING "Define suffix of directory name (32/64)"
|
||||||
|
)
|
||||||
|
|
||||||
|
SET(EXEC_INSTALL_PREFIX
|
||||||
|
"${CMAKE_INSTALL_PREFIX}"
|
||||||
|
CACHE PATH "Base directory for executables and libraries"
|
||||||
|
)
|
||||||
|
SET(SHARE_INSTALL_PREFIX
|
||||||
|
"${CMAKE_INSTALL_PREFIX}/share"
|
||||||
|
CACHE PATH "Base directory for files which go to share/"
|
||||||
|
)
|
||||||
|
SET(DATA_INSTALL_PREFIX
|
||||||
|
"${SHARE_INSTALL_PREFIX}/${APPLICATION_SHORT_NAME}"
|
||||||
|
CACHE PATH "The parent directory where applications can install their data")
|
||||||
|
|
||||||
|
# The following are directories where stuff will be installed to
|
||||||
|
SET(BIN_INSTALL_DIR
|
||||||
|
"${EXEC_INSTALL_PREFIX}/bin"
|
||||||
|
CACHE PATH "The ${APPLICATION_SHORT_NAME} binary install dir (default prefix/bin)"
|
||||||
|
)
|
||||||
|
SET(SBIN_INSTALL_DIR
|
||||||
|
"${EXEC_INSTALL_PREFIX}/sbin"
|
||||||
|
CACHE PATH "The ${APPLICATION_SHORT_NAME} sbin install dir (default prefix/sbin)"
|
||||||
|
)
|
||||||
|
SET(LIB_INSTALL_DIR
|
||||||
|
"${EXEC_INSTALL_PREFIX}/lib${LIB_SUFFIX}"
|
||||||
|
CACHE PATH "The subdirectory relative to the install prefix where libraries will be installed (default is prefix/lib)"
|
||||||
|
)
|
||||||
|
SET(LIBEXEC_INSTALL_DIR
|
||||||
|
"${EXEC_INSTALL_PREFIX}/libexec"
|
||||||
|
CACHE PATH "The subdirectory relative to the install prefix where libraries will be installed (default is prefix/libexec)"
|
||||||
|
)
|
||||||
|
SET(PLUGIN_INSTALL_DIR
|
||||||
|
"${LIB_INSTALL_DIR}/${APPLICATION_SHORT_NAME}"
|
||||||
|
CACHE PATH "The subdirectory relative to the install prefix where plugins will be installed (default is prefix/lib/${APPLICATION_SHORT_NAME})"
|
||||||
|
)
|
||||||
|
SET(INCLUDE_INSTALL_DIR
|
||||||
|
"${CMAKE_INSTALL_PREFIX}/include"
|
||||||
|
CACHE PATH "The subdirectory to the header prefix (default prefix/include)"
|
||||||
|
)
|
||||||
|
|
||||||
|
SET(DATA_INSTALL_DIR
|
||||||
|
"${DATA_INSTALL_PREFIX}"
|
||||||
|
CACHE PATH "The parent directory where applications can install their data (default prefix/share/${APPLICATION_SHORT_NAME})"
|
||||||
|
)
|
||||||
|
SET(HTML_INSTALL_DIR
|
||||||
|
"${DATA_INSTALL_PREFIX}/doc/HTML"
|
||||||
|
CACHE PATH "The HTML install dir for documentation (default data/doc/html)"
|
||||||
|
)
|
||||||
|
SET(ICON_INSTALL_DIR
|
||||||
|
"${DATA_INSTALL_PREFIX}/icons"
|
||||||
|
CACHE PATH "The icon install dir (default data/icons/)"
|
||||||
|
)
|
||||||
|
SET(SOUND_INSTALL_DIR
|
||||||
|
"${DATA_INSTALL_PREFIX}/sounds"
|
||||||
|
CACHE PATH "The install dir for sound files (default data/sounds)"
|
||||||
|
)
|
||||||
|
|
||||||
|
SET(LOCALE_INSTALL_DIR
|
||||||
|
"${SHARE_INSTALL_PREFIX}/locale"
|
||||||
|
CACHE PATH "The install dir for translations (default prefix/share/locale)"
|
||||||
|
)
|
||||||
|
|
||||||
|
SET(XDG_APPS_DIR
|
||||||
|
"${SHARE_INSTALL_PREFIX}/applications/"
|
||||||
|
CACHE PATH "The XDG apps dir"
|
||||||
|
)
|
||||||
|
SET(XDG_DIRECTORY_DIR
|
||||||
|
"${SHARE_INSTALL_PREFIX}/desktop-directories"
|
||||||
|
CACHE PATH "The XDG directory"
|
||||||
|
)
|
||||||
|
|
||||||
|
IF(NOT "${EXEC_INSTALL_PREFIX}" STREQUAL "/usr")
|
||||||
|
SET(SYSCONFDIR_INSTALL_PREFIX "${EXEC_INSTALL_PREFIX}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
SET(SYSCONF_INSTALL_DIR
|
||||||
|
"${SYSCONFDIR_INSTALL_PREFIX}/etc"
|
||||||
|
CACHE PATH "The ${APPLICATION_SHORT_NAME} sysconfig install dir (default prefix/etc)"
|
||||||
|
)
|
||||||
|
SET(MAN_INSTALL_DIR
|
||||||
|
"${SHARE_INSTALL_PREFIX}/man"
|
||||||
|
CACHE PATH "The ${APPLICATION_SHORT_NAME} man install dir (default prefix/man)"
|
||||||
|
)
|
||||||
|
SET(INFO_INSTALL_DIR
|
||||||
|
"${SHARE_INSTALL_PREFIX}/info"
|
||||||
|
CACHE PATH "The ${APPLICATION_SHORT_NAME} info install dir (default prefix/info)"
|
||||||
|
)
|
||||||
|
endif (UNIX)
|
||||||
|
|
||||||
|
if (WIN32)
|
||||||
|
# Same same
|
||||||
|
set(SHARE_INSTALL_PREFIX "share" CACHE PATH "-")
|
||||||
|
set(BIN_INSTALL_DIR "." CACHE PATH "-")
|
||||||
|
set(SBIN_INSTALL_DIR "." CACHE PATH "-")
|
||||||
|
set(LIB_INSTALL_DIR "lib" CACHE PATH "-")
|
||||||
|
set(INCLUDE_INSTALL_DIR "include" CACHE PATH "-")
|
||||||
|
set(PLUGIN_INSTALL_DIR "plugins" CACHE PATH "-")
|
||||||
|
set(HTML_INSTALL_DIR "doc/HTML" CACHE PATH "-")
|
||||||
|
set(ICON_INSTALL_DIR "." CACHE PATH "-")
|
||||||
|
set(SOUND_INSTALL_DIR "." CACHE PATH "-")
|
||||||
|
set(LOCALE_INSTALL_DIR "lang" CACHE PATH "-")
|
||||||
|
set(SYSCONF_INSTALL_DIR "config" CACHE PATH "-")
|
||||||
|
set(MAN_INSTALL_DIR "man" CACHE PATH "-")
|
||||||
|
endif (WIN32)
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
;ownCloud installer script.
|
;ownCloud installer script.
|
||||||
|
|
||||||
!define APPLICATION_SHORTNAME "@APPLICATION_SHORTNAME@"
|
!define APPLICATION_SHORTNAME "@APPLICATION_EXECUTABLE@"
|
||||||
!define APPLICATION_NAME "@APPLICATION_NAME@"
|
!define APPLICATION_NAME "@APPLICATION_NAME@"
|
||||||
!define APPLICATION_VENDOR "@APPLICATION_VENDOR@"
|
!define APPLICATION_VENDOR "@APPLICATION_VENDOR@"
|
||||||
!define APPLICATION_EXECUTABLE "@APPLICATION_EXECUTABLE@.exe"
|
!define APPLICATION_EXECUTABLE "@APPLICATION_EXECUTABLE@.exe"
|
||||||
|
|||||||
@@ -8,4 +8,10 @@
|
|||||||
#cmakedefine APPLICATION_DOMAIN @APPLICATION_DOMAIN@
|
#cmakedefine APPLICATION_DOMAIN @APPLICATION_DOMAIN@
|
||||||
#cmakedefine THEME_CLASS @THEME_CLASS@
|
#cmakedefine THEME_CLASS @THEME_CLASS@
|
||||||
#cmakedefine THEME_INCLUDE @THEME_INCLUDE@
|
#cmakedefine THEME_INCLUDE @THEME_INCLUDE@
|
||||||
|
|
||||||
|
#cmakedefine APPLICATION_NAME "@APPLICATION_NAME@"
|
||||||
|
#cmakedefine APPLICATION_SHORTNAME "@APPLICATION_SHORTNAME@"
|
||||||
|
|
||||||
|
#cmakedefine SYSCONFDIR "@SYSCONFDIR@"
|
||||||
|
#cmakedefine DATADIR "@DATADIR@"
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -22,6 +22,11 @@ if(SPHINX_FOUND)
|
|||||||
add_custom_target(doc DEPENDS doc-html doc-man COMMENT "Building documentation...")
|
add_custom_target(doc DEPENDS doc-html doc-man COMMENT "Building documentation...")
|
||||||
endif(WITH_DOC)
|
endif(WITH_DOC)
|
||||||
|
|
||||||
|
if (EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/ocdoc")
|
||||||
|
add_dependencies(doc doc-html-org)
|
||||||
|
add_dependencies(doc doc-html-com)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(PDFLATEX_FOUND)
|
if(PDFLATEX_FOUND)
|
||||||
# if this still fails on Debian/Ubuntu, run
|
# if this still fails on Debian/Ubuntu, run
|
||||||
# apt-get install texlive-latex-recommended texlive-latex-extra texlive-fonts-recommended
|
# apt-get install texlive-latex-recommended texlive-latex-extra texlive-fonts-recommended
|
||||||
@@ -56,7 +61,19 @@ if(SPHINX_FOUND)
|
|||||||
-q -c . -b html
|
-q -c . -b html
|
||||||
-d ${SPHINX_CACHE_DIR}/html
|
-d ${SPHINX_CACHE_DIR}/html
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
${SPHINX_HTML_DIR} )
|
${SPHINX_HTML_DIR}/unthemed )
|
||||||
|
add_custom_target( doc-html-org ${SPHINX_EXECUTABLE}
|
||||||
|
-q -c . -b html
|
||||||
|
-d ${SPHINX_CACHE_DIR}/html
|
||||||
|
-D html_theme=owncloud_org
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
${SPHINX_HTML_DIR}/org )
|
||||||
|
add_custom_target( doc-html-com ${SPHINX_EXECUTABLE}
|
||||||
|
-q -c . -b html
|
||||||
|
-d ${SPHINX_CACHE_DIR}/html
|
||||||
|
-D html_theme=owncloud_com
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
${SPHINX_HTML_DIR}/com )
|
||||||
add_custom_target( doc-man ${SPHINX_EXECUTABLE}
|
add_custom_target( doc-man ${SPHINX_EXECUTABLE}
|
||||||
-q -c . -b man
|
-q -c . -b man
|
||||||
-d ${SPHINX_CACHE_DIR}/man
|
-d ${SPHINX_CACHE_DIR}/man
|
||||||
|
|||||||
37
doc/accountsetup.rst
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
Setting up an Account
|
||||||
|
=====================
|
||||||
|
|
||||||
|
If no account has been configured, ownCloud Client will automatically assist
|
||||||
|
you in connecting to your ownCloud Server after the application has been
|
||||||
|
started.
|
||||||
|
|
||||||
|
As a first step, specify the URL to your Server, just
|
||||||
|
like you would when you open your ownCloud instance inside a browser.
|
||||||
|
|
||||||
|
.. image:: images/wizard_url.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
.. note:: Make sure to use ``https://`` if the server supports it. Otherwise,
|
||||||
|
your password and all data will be transferred to the server unencrypted.
|
||||||
|
This makes it easy for third parties to intercept your communication, and
|
||||||
|
getting hold of your password!
|
||||||
|
|
||||||
|
Next, you are prompted for your username and password. Again, use the same
|
||||||
|
credentials that you would use to log on via the web interface.
|
||||||
|
|
||||||
|
.. image:: images/wizard_user.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
Finally, choose the folder that ownCloud Client is supposed to sync the
|
||||||
|
contents of your ownCloud account with. By default, this is a folder
|
||||||
|
called `ownCloud`, which will reside in your home directory.
|
||||||
|
|
||||||
|
.. image:: images/wizard_targetfolder.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
After pressing `Connect`, ownCloud Client will commence with the syncing
|
||||||
|
process. The next screen will give you the opportunity to review your
|
||||||
|
settings:
|
||||||
|
|
||||||
|
.. image:: images/wizard_overview.png
|
||||||
|
:scale: 50 %
|
||||||
14
doc/advancedusage.rst
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
Advanced Usage
|
||||||
|
==============
|
||||||
|
|
||||||
|
.. index:: Advanced Usage
|
||||||
|
|
||||||
|
Options
|
||||||
|
-------
|
||||||
|
.. index:: command line switches, command line, options, parameters
|
||||||
|
.. include:: options.rst
|
||||||
|
|
||||||
|
Config File
|
||||||
|
-----------
|
||||||
|
.. index:: config file
|
||||||
|
.. include:: conffile.rst
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
Architecture
|
Appendix B: Architecture
|
||||||
============
|
========================
|
||||||
|
|
||||||
.. index:: architecture
|
.. index:: architecture
|
||||||
|
|
||||||
The ownCloud project provides desktop sync clients to synchronize the
|
The ownCloud project provides desktop sync clients to synchronize the
|
||||||
@@ -11,11 +12,10 @@ csync was written to synchronize with ownCloud’s built-in WebDAV server.
|
|||||||
|
|
||||||
The ownCloud sync client is based on a tool called mirall initially written by
|
The ownCloud sync client is based on a tool called mirall initially written by
|
||||||
Duncan Mac Vicar. Later Klaas Freitag joined the project and enhanced it to work
|
Duncan Mac Vicar. Later Klaas Freitag joined the project and enhanced it to work
|
||||||
with ownCloud server. Both mirall and ownCloud Client (oCC) build from the same
|
with ownCloud server.
|
||||||
source, currently hosted in the ownCloud source repo on gitorious.
|
|
||||||
|
|
||||||
oCC is written in C++ using the `Qt Framework`_. As a result oCC runs on the
|
ownCloud Client is written in C++ using the `Qt Framework`_. As a result, the
|
||||||
three important platforms Linux, Windows and MacOS.
|
ownCloud Client runs on the three important platforms Linux, Windows and MacOS.
|
||||||
|
|
||||||
.. _csync: http://www.csync.org
|
.. _csync: http://www.csync.org
|
||||||
.. _`Qt Framework`: http://www.qt-project.org
|
.. _`Qt Framework`: http://www.qt-project.org
|
||||||
@@ -23,8 +23,8 @@ three important platforms Linux, Windows and MacOS.
|
|||||||
The Sync Process
|
The Sync Process
|
||||||
----------------
|
----------------
|
||||||
|
|
||||||
First it is important to recall what syncing is. Syncing tries to keep the files
|
First it is important to recall what syncing is: It tries to keep the files
|
||||||
on both repositories the same. That means if a file is added to one repository
|
on two repositories the same. That means if a file is added to one repository
|
||||||
it is going to be copied to the other repository. If a file is changed on one
|
it is going to be copied to the other repository. If a file is changed on one
|
||||||
repository, the change is propagated to the other repository. Also, if a file
|
repository, the change is propagated to the other repository. Also, if a file
|
||||||
is deleted on one side, it is deleted on the other. As a matter of fact, in
|
is deleted on one side, it is deleted on the other. As a matter of fact, in
|
||||||
@@ -34,10 +34,10 @@ server is always master.
|
|||||||
This is the major difference to other systems like a file backup where just
|
This is the major difference to other systems like a file backup where just
|
||||||
changes and new files are propagated but files never get deleted.
|
changes and new files are propagated but files never get deleted.
|
||||||
|
|
||||||
The oCC checks both repositories for changes frequently after a certain time
|
The ownCloud Client checks both repositories for changes frequently after a
|
||||||
span. That is refered to as a sync run. In between the local repository is
|
certain time span. That is refered to as a sync run. In between the local
|
||||||
monitored by a file system monitor system that starts a sync run immediately
|
repository is monitored by a file system monitor system that starts a sync run
|
||||||
if something was edited, added or removed.
|
immediately if something was edited, added or removed.
|
||||||
|
|
||||||
Sync by Time versus ETag
|
Sync by Time versus ETag
|
||||||
------------------------
|
------------------------
|
||||||
@@ -62,16 +62,18 @@ machines.
|
|||||||
Since this strategy is rather fragile without NTP, ownCloud 4.5 introduced a
|
Since this strategy is rather fragile without NTP, ownCloud 4.5 introduced a
|
||||||
unique number, which changes whenever the file changes. Although it is a unique
|
unique number, which changes whenever the file changes. Although it is a unique
|
||||||
value, it is not a hash of the file, but a randomly chosen number, which it will
|
value, it is not a hash of the file, but a randomly chosen number, which it will
|
||||||
transmit in the Etag_ field. Since the file number is guaranteed to change if the
|
transmit in the Etag_ field. Since the file number is guaranteed to change if
|
||||||
file changes, it can now be used to determine if one of the files has changed.
|
the file changes, it can now be used to determine if one of the files has
|
||||||
|
changed.
|
||||||
|
|
||||||
.. note:: oCC 1.1 and newer require file ID capabilities on the ownCloud server,
|
.. note:: ownCloud Client 1.1 and newer require file ID capabilities on the
|
||||||
hence using them with a server earlier than 4.5.0 is not supported.
|
ownCloud server, hence using them with a server earlier than 4.5.0 is
|
||||||
|
not supported.
|
||||||
|
|
||||||
Before the 1.3.0 release of the client the sync process might create faux conflict
|
Before the 1.3.0 release of the client the sync process might create faux
|
||||||
files if time deviates. The original and the conflict files only differed in the
|
conflict files if time deviates. The original and the conflict files only
|
||||||
timestamp, but not in content. This behaviour was changed towards a binary check
|
differed in the timestamp, but not in content. This behaviour was changed
|
||||||
if the files are different.
|
towards a binary check if the files are different.
|
||||||
|
|
||||||
Just like files, directories also hold a unique id, which changes whenever
|
Just like files, directories also hold a unique id, which changes whenever
|
||||||
one of the contained files or directories gets modified. Since this is a
|
one of the contained files or directories gets modified. Since this is a
|
||||||
@@ -105,7 +107,8 @@ are involved and one of them is not in sync with NTP time.
|
|||||||
.. _Etag: http://en.wikipedia.org/wiki/HTTP_ETag
|
.. _Etag: http://en.wikipedia.org/wiki/HTTP_ETag
|
||||||
|
|
||||||
Comparison and Conflict Cases
|
Comparison and Conflict Cases
|
||||||
----------------------------
|
-----------------------------
|
||||||
|
|
||||||
In a sync run the client first has to detect if one of the two repositories have
|
In a sync run the client first has to detect if one of the two repositories have
|
||||||
changed files. On the local repository, the client traverses the file
|
changed files. On the local repository, the client traverses the file
|
||||||
tree and compares the modification time of each file with the value it was
|
tree and compares the modification time of each file with the value it was
|
||||||
@@ -118,25 +121,41 @@ For the remote (ie. ownCloud) repository, the client compares the ETag of each
|
|||||||
file with it's previous value. Again the previous value is queried from the
|
file with it's previous value. Again the previous value is queried from the
|
||||||
database. If the ETag is still the same, the file has not changed.
|
database. If the ETag is still the same, the file has not changed.
|
||||||
|
|
||||||
So what happens if a file has changed on both, the local and the remote repository
|
In case a file has changed on both, the local and the remote repository since
|
||||||
since the last sync run? That means it can not easily be decided which version
|
the last sync run, it can not easily be decided which version of the file is
|
||||||
of the file is the one that should be used. Moreover, changes to any side must
|
the one that should be used. However, changes to any side must not be lost.
|
||||||
not be lost. That is called the conflict case and the client solves it by creating
|
|
||||||
a conflict file of the older of the two files and save the newer one under the
|
That is called a **conflict case**. The client solves it by creating a conflict
|
||||||
original file name. Conflict files are always created on the client and never on
|
file of the older of the two files and save the newer one under the original
|
||||||
the server. The conflict file has the same name as the original file appended
|
file name. Conflict files are always created on the client and never on the
|
||||||
with the timestamp of the conflict detection.
|
server. The conflict file has the same name as the original file appended with
|
||||||
|
the timestamp of the conflict detection.
|
||||||
|
|
||||||
|
|
||||||
|
.. _ignored-files-label:
|
||||||
|
|
||||||
|
Ignored Files
|
||||||
|
-------------
|
||||||
|
|
||||||
|
ownCloud Client will refuse to sync the following files:
|
||||||
|
|
||||||
|
* Files matched by one of the pattern in :ref:`ignoredFilesEditor-label`
|
||||||
|
* Files containing characters that do not work on certain file systems.
|
||||||
|
Currently, these characters are: `\, :, ?, *, ", >, <, |`
|
||||||
|
* Files starting in ``.csync_journal.db`` (reserved for journalling)
|
||||||
|
|
||||||
The Sync Journal
|
The Sync Journal
|
||||||
----------------
|
----------------
|
||||||
The client stores the ETag number in a per-directory database, called the journal.
|
|
||||||
It is located in the application directory (until version 1.1) or as a hidden file
|
|
||||||
right in the directory to be synced (later versions).
|
|
||||||
|
|
||||||
If the journal database gets removed, oCC's CSync backend will rebuild the database
|
The client stores the ETag number in a per-directory database,
|
||||||
by comparing the files and their modification times. Thus it should be made sure
|
called the journal. It is a hidden file right in the directory
|
||||||
that both server and client synchronized to NTP time before restarting the client
|
to be synced.
|
||||||
after a database removal.
|
|
||||||
|
|
||||||
The oCC also provides a button in the Settings Dialog that allows to "reset" the
|
If the journal database gets removed, ownCloud Client's CSync backend will
|
||||||
journal. That can be used to recreate the journal database.
|
rebuild the database by comparing the files and their modification times. Thus
|
||||||
|
it should be made sure that both server and client synchronized with NTP time
|
||||||
|
before restarting the client after a database removal.
|
||||||
|
|
||||||
|
Pressing ``F5`` in the Account Settings Dialog that allows to "reset" the
|
||||||
|
journal. That can be used to recreate the journal database. Use this only
|
||||||
|
if advised to do so by the developer or support staff.
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
Building the Client
|
.. _building-label:
|
||||||
===================
|
|
||||||
|
Appendix A: Building the Client
|
||||||
|
===============================
|
||||||
|
|
||||||
This section explains how to build the ownCloud Client from source
|
This section explains how to build the ownCloud Client from source
|
||||||
for all major platforms. You should read this section if you want
|
for all major platforms. You should read this section if you want
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ import sys, os
|
|||||||
extensions = ['sphinx.ext.todo']
|
extensions = ['sphinx.ext.todo']
|
||||||
|
|
||||||
# Add any paths that contain templates here, relative to this directory.
|
# Add any paths that contain templates here, relative to this directory.
|
||||||
#templates_path = ['templates']
|
templates_path = ['@CMAKE_CURRENT_SOURCE_DIR@/ocdoc/_shared_assets/templates']
|
||||||
|
|
||||||
# The suffix of source filenames.
|
# The suffix of source filenames.
|
||||||
source_suffix = '.rst'
|
source_suffix = '.rst'
|
||||||
@@ -95,7 +95,7 @@ pygments_style = 'sphinx'
|
|||||||
#html_theme_options = {}
|
#html_theme_options = {}
|
||||||
|
|
||||||
# Add any paths that contain custom themes here, relative to this directory.
|
# Add any paths that contain custom themes here, relative to this directory.
|
||||||
#html_theme_path = ['themes']
|
html_theme_path = ['@CMAKE_CURRENT_SOURCE_DIR@/ocdoc/_shared_assets/themes']
|
||||||
|
|
||||||
# The theme to use for HTML and HTML Help pages. See the documentation for
|
# The theme to use for HTML and HTML Help pages. See the documentation for
|
||||||
# a list of builtin themes.
|
# a list of builtin themes.
|
||||||
@@ -120,7 +120,7 @@ html_short_title = "Client Manual"
|
|||||||
# Add any paths that contain custom static files (such as style sheets) here,
|
# Add any paths that contain custom static files (such as style sheets) here,
|
||||||
# relative to this directory. They are copied after the builtin static files,
|
# relative to this directory. They are copied after the builtin static files,
|
||||||
# so a file named "default.css" will overwrite the builtin "default.css".
|
# so a file named "default.css" will overwrite the builtin "default.css".
|
||||||
#html_static_path = ['static']
|
html_static_path = ['@CMAKE_CURRENT_SOURCE_DIR@/ocdoc/_shared_assets/static']
|
||||||
|
|
||||||
# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,
|
# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,
|
||||||
# using the given strftime format.
|
# using the given strftime format.
|
||||||
|
|||||||
@@ -4,8 +4,8 @@ Glossary
|
|||||||
.. glossary::
|
.. glossary::
|
||||||
:sorted:
|
:sorted:
|
||||||
|
|
||||||
|
ownCloud Sync Client
|
||||||
ownCloud Client
|
ownCloud Client
|
||||||
oCC
|
|
||||||
Name of the official ownCloud syncing client for desktop, which runs on
|
Name of the official ownCloud syncing client for desktop, which runs on
|
||||||
Windows, Mac OS X and Linux. It is based Mirall, and uses the CSync
|
Windows, Mac OS X and Linux. It is based Mirall, and uses the CSync
|
||||||
sync engine for synchronization with the ownCloud server.
|
sync engine for synchronization with the ownCloud server.
|
||||||
@@ -23,6 +23,7 @@ Glossary
|
|||||||
exist in the client directory.
|
exist in the client directory.
|
||||||
|
|
||||||
unique id
|
unique id
|
||||||
|
ETag
|
||||||
ID assigned to every file starting with ownCloud server 4.5 and submitted
|
ID assigned to every file starting with ownCloud server 4.5 and submitted
|
||||||
via the HTTP ``Etag``. Used to check if files on client and server have
|
via the HTTP ``Etag``. Used to check if files on client and server have
|
||||||
changed.
|
changed.
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 45 KiB |
BIN
doc/images/icon.png
Normal file
|
After Width: | Height: | Size: 1.3 KiB |
BIN
doc/images/ignored_files_editor.png
Normal file
|
After Width: | Height: | Size: 48 KiB |
BIN
doc/images/menu.png
Normal file
|
After Width: | Height: | Size: 18 KiB |
BIN
doc/images/settings_account.png
Normal file
|
After Width: | Height: | Size: 72 KiB |
BIN
doc/images/settings_general.png
Normal file
|
After Width: | Height: | Size: 50 KiB |
BIN
doc/images/settings_network.png
Normal file
|
After Width: | Height: | Size: 59 KiB |
BIN
doc/images/sync_protocol.png
Normal file
|
After Width: | Height: | Size: 168 KiB |
BIN
doc/images/wizard_overview.png
Normal file
|
After Width: | Height: | Size: 40 KiB |
BIN
doc/images/wizard_targetfolder.png
Normal file
|
After Width: | Height: | Size: 39 KiB |
BIN
doc/images/wizard_url.png
Normal file
|
After Width: | Height: | Size: 39 KiB |
BIN
doc/images/wizard_user.png
Normal file
|
After Width: | Height: | Size: 37 KiB |
@@ -6,8 +6,11 @@ Contents
|
|||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
|
|
||||||
install
|
introduction
|
||||||
usage
|
accountsetup
|
||||||
|
visualtour
|
||||||
|
advancedusage
|
||||||
|
|
||||||
building
|
building
|
||||||
architecture
|
architecture
|
||||||
troubleshooting
|
troubleshooting
|
||||||
|
|||||||
@@ -1,36 +0,0 @@
|
|||||||
Installation
|
|
||||||
============
|
|
||||||
|
|
||||||
General
|
|
||||||
-------
|
|
||||||
|
|
||||||
The latest version of ownCloud client can be obtained at
|
|
||||||
http://owncloud.org/sync-clients/.
|
|
||||||
|
|
||||||
Windows
|
|
||||||
-------
|
|
||||||
|
|
||||||
ownCloud client for Windows is provided as a NSIS-based setup file for
|
|
||||||
machine-wide install.
|
|
||||||
|
|
||||||
Mac OS X
|
|
||||||
--------
|
|
||||||
|
|
||||||
Installing the ownCloud client on your Mac follows the normal app installation
|
|
||||||
pattern:
|
|
||||||
|
|
||||||
1. Download the installation file Click ownCloud-x.y.z.dmg, a window with the
|
|
||||||
2. ownCloud icon opens In that window, drag the ownCloud application into the
|
|
||||||
3. ‘Applications’ folder on the right hand side From ‘Applications’, choose
|
|
||||||
ownCloud
|
|
||||||
|
|
||||||
Linux
|
|
||||||
------
|
|
||||||
|
|
||||||
The ownCloud client is provided as in a convenient repository for a wide range
|
|
||||||
of popular Linux distributions. If you want to build the sources instead.
|
|
||||||
|
|
||||||
Supported distributions are CentOS/RHEL, Fedora, SLES, openSUSE, Ubuntu and
|
|
||||||
Debian.
|
|
||||||
|
|
||||||
To support other distributions, a source build is required.
|
|
||||||
37
doc/introduction.rst
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
Introduction
|
||||||
|
============
|
||||||
|
|
||||||
|
This is the documentation for the ownCloud Sync Client, also referred to as
|
||||||
|
the ownCloud Client.
|
||||||
|
|
||||||
|
The ownCloud Sync Client is a desktop program you install on your computer.
|
||||||
|
Specify one ore more directories on the local machine to sync your ownCloud
|
||||||
|
server, and always have your latest files wherever you are. Make a change to the
|
||||||
|
files on one computer, it will flow across the others using these desktop sync
|
||||||
|
clients.
|
||||||
|
|
||||||
|
ownCloud Client is available for Windows, Mac OS X and various Linux
|
||||||
|
distributions. See below for details on how to obtain the Client.
|
||||||
|
|
||||||
|
Obtaining the Client
|
||||||
|
--------------------
|
||||||
|
|
||||||
|
The latest version of the ownCloud Client can be obtained at
|
||||||
|
http://owncloud.org/sync-clients/.
|
||||||
|
|
||||||
|
ownCloud client for **Windows** is provided as a NSIS-based setup file for
|
||||||
|
machine-wide install. Installing the ownCloud client on **Mac OS** follows
|
||||||
|
the normal app bundle installation pattern:
|
||||||
|
|
||||||
|
1. Download the installation file: Click ``ownCloud-x.y.z.dmg``, a window with
|
||||||
|
the ownCloud icon opens.
|
||||||
|
2. In that window, drag the ownCloud application into the ``Applications``
|
||||||
|
folder.
|
||||||
|
3. On the right hand side From ``Applications``, choose ``ownCloud``.
|
||||||
|
|
||||||
|
The ownCloud Client is also provided as in a convenient repository for a wide
|
||||||
|
range of popular **Linux distributions**. If you want to build the sources
|
||||||
|
instead.
|
||||||
|
|
||||||
|
Supported distributions are Fedora, openSUSE, Ubuntu and Debian.
|
||||||
|
To support other distributions, a is required, see :ref:`building-label`
|
||||||
1
doc/ocdoc
Submodule
@@ -15,9 +15,6 @@ ownCloud Client supports the following command line switches:
|
|||||||
``--logflush``
|
``--logflush``
|
||||||
flush the log file after every write.
|
flush the log file after every write.
|
||||||
|
|
||||||
``--monoicons``
|
|
||||||
Use black/white pictograms for systray.
|
|
||||||
|
|
||||||
``--confdir`` `<dirname>`
|
``--confdir`` `<dirname>`
|
||||||
Use the given configuration directory.
|
Use the given configuration directory.
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
Troubleshooting
|
Appendix C: Troubleshooting
|
||||||
===============
|
===========================
|
||||||
|
|
||||||
If the client fails to start syncing it basically can have two
|
If the client fails to start syncing it basically can have two
|
||||||
basic reasons: Either the server setup has a problem or the client
|
basic reasons: Either the server setup has a problem or the client
|
||||||
@@ -55,6 +55,12 @@ ownCloud is not shared with other syncing apps.
|
|||||||
not be attempted. In the worst case, doing so can result in data
|
not be attempted. In the worst case, doing so can result in data
|
||||||
loss.
|
loss.
|
||||||
|
|
||||||
|
If some files do not get take a look at the sync protocol. Some files are
|
||||||
|
automatically automatically being ignored because they are system files,
|
||||||
|
others get ignored because their file name contains characters that cannot
|
||||||
|
be represented on certain file systems. See :ref:`_ignored-files-label` for
|
||||||
|
details.
|
||||||
|
|
||||||
If you are operating your own server and use the local storage backend (the
|
If you are operating your own server and use the local storage backend (the
|
||||||
default), make sure that ownCloud has exclusive access to the directory.
|
default), make sure that ownCloud has exclusive access to the directory.
|
||||||
|
|
||||||
@@ -65,13 +71,15 @@ If you are using a different backend, you can try to exclude a bug in the
|
|||||||
backend by reverting to the local backend.
|
backend by reverting to the local backend.
|
||||||
|
|
||||||
Logfiles
|
Logfiles
|
||||||
========
|
--------
|
||||||
|
|
||||||
Doing effective debugging requires to provide as much as relevant logs as
|
Doing effective debugging requires to provide as much as relevant logs as
|
||||||
possible. The log output can help you with tracking down problem, and if you
|
possible. The log output can help you with tracking down problem, and if you
|
||||||
report a bug, you're advised to include the output.
|
report a bug, you're advised to include the output.
|
||||||
|
|
||||||
:Client Logfile:
|
Client Logfile
|
||||||
|
~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Start the client with ``--logwindow``. That opens a window providing a view
|
Start the client with ``--logwindow``. That opens a window providing a view
|
||||||
on the current log. It provides a Save button to let you save the log to a
|
on the current log. It provides a Save button to let you save the log to a
|
||||||
file.
|
file.
|
||||||
@@ -97,11 +105,14 @@ given expiry period.
|
|||||||
|
|
||||||
For example, for a long running test where you intend to keep the log data of the
|
For example, for a long running test where you intend to keep the log data of the
|
||||||
last two days, this would be the command line:
|
last two days, this would be the command line:
|
||||||
|
|
||||||
```
|
```
|
||||||
owncloud --logdir /tmp/owncloud_logs --logexpire 48
|
owncloud --logdir /tmp/owncloud_logs --logexpire 48
|
||||||
```
|
```
|
||||||
|
|
||||||
:ownCloud server Logfile:
|
ownCloud server Logfile
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
The ownCloud server maintains an ownCloud specific logfile as well. It can and
|
The ownCloud server maintains an ownCloud specific logfile as well. It can and
|
||||||
must be enabled through the ownCloud Administration page. There you can adjust
|
must be enabled through the ownCloud Administration page. There you can adjust
|
||||||
the loglevel. It is advisable to set it to a verbose level like ``Debug`` or
|
the loglevel. It is advisable to set it to a verbose level like ``Debug`` or
|
||||||
@@ -110,7 +121,9 @@ the loglevel. It is advisable to set it to a verbose level like ``Debug`` or
|
|||||||
The logfile can be viewed either in the web interface or can be found in the
|
The logfile can be viewed either in the web interface or can be found in the
|
||||||
filesystem in the ownCloud server data dir.
|
filesystem in the ownCloud server data dir.
|
||||||
|
|
||||||
:Webserver Logfiles:
|
Webserver Logfiles
|
||||||
|
~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Also, please take a look at your webservers error log file to check if there
|
Also, please take a look at your webservers error log file to check if there
|
||||||
are problems. For Apache on Linux, the error logs usually can be found at
|
are problems. For Apache on Linux, the error logs usually can be found at
|
||||||
``/var/log/apache2``. A file called ``error_log`` shows errors like PHP code
|
``/var/log/apache2``. A file called ``error_log`` shows errors like PHP code
|
||||||
|
|||||||
@@ -1,95 +0,0 @@
|
|||||||
Usage
|
|
||||||
=====
|
|
||||||
.. index:: usage, client sync usage
|
|
||||||
|
|
||||||
To start ownCloud Client, click on the desktop icon or start it from the
|
|
||||||
application menu. In the system tray, an ownCloud icon appears.
|
|
||||||
|
|
||||||
.. index:: start application
|
|
||||||
|
|
||||||
Overview
|
|
||||||
--------
|
|
||||||
|
|
||||||
ownCloud is represented by an icon in the Desktop's system tray, also known
|
|
||||||
as notification area.
|
|
||||||
|
|
||||||
The clients menu is accessed with a right click (Windows, Linux) or left click
|
|
||||||
(Mac OS).
|
|
||||||
|
|
||||||
The status of the current sync can be observed in the Status dialog, available
|
|
||||||
trough the ``Open status...`` option. On Windows, a left click on the tray icon
|
|
||||||
also opens the status dialog.
|
|
||||||
|
|
||||||
.. note:: Until the intial setup has finished, the Connection Wizard will be
|
|
||||||
shown instead when left-clicking on Windows.
|
|
||||||
|
|
||||||
The dialog provides an overview on the configured sync folders and allows to add
|
|
||||||
and remove more sync folder connections as well as pausing a sync connection.
|
|
||||||
|
|
||||||
Changing Your Password and Account Settings
|
|
||||||
-------------------------------------------
|
|
||||||
|
|
||||||
In the ``Settings`` Dialog, choose ``Account`` -> ``Modify Account``. It will open
|
|
||||||
Setup Wizard, which next to reconfiguring your connection to use a different
|
|
||||||
user or server also will allow to change the password for the local account,
|
|
||||||
or to switch from HTTP to HTTPS.
|
|
||||||
|
|
||||||
Setting up a Proxy
|
|
||||||
------------------
|
|
||||||
|
|
||||||
By default, the configured system proxy will be picked up. This may not be
|
|
||||||
working reliably on some Linux distributions, as only the ``http_proxy``
|
|
||||||
variable gets picked up. You can configure a proxy different from your
|
|
||||||
system default in the ``Network`` section of the ``Settings`` dialog.
|
|
||||||
|
|
||||||
The default settings assume an HTTP proxy, which is the typical use case.
|
|
||||||
If you require SOCKS 5 proxy, pick ``SOCKS5 proxy`` instead of ``HTTP(S) proxy``
|
|
||||||
from the drop down menu. SOCKS 5 proxies are typically provided by some
|
|
||||||
SSH implementations, for instance OpenSSH's ``-D`` parameter. This is
|
|
||||||
useful for scenarios where SSH is employed to securely tunnel a client
|
|
||||||
to the network running the ownCloud server.
|
|
||||||
|
|
||||||
Limiting Bandwidth
|
|
||||||
------------------
|
|
||||||
|
|
||||||
Starting with Version 1.4, the Client provides bandwidth limiter.
|
|
||||||
This option can be found in the ``Network`` section of the
|
|
||||||
``Settings Dialog``.
|
|
||||||
|
|
||||||
You will find two settings for ``Download Bandwidth`` and
|
|
||||||
``Upload Bandwidth``.
|
|
||||||
|
|
||||||
Upload Bandwidth
|
|
||||||
~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
The default is to automatically limit the upload. The rationale
|
|
||||||
for this default is that typically, Computers and laptops are
|
|
||||||
not directly connected to the server, but via a Cable Modems
|
|
||||||
or DSL lines, which provide significantly more downstream than
|
|
||||||
upstream bandwith. Sataurating the upstream bandwidth would
|
|
||||||
interfere with other applications, especially Voice-Over-IP or
|
|
||||||
Games.
|
|
||||||
|
|
||||||
The automatic limiter will throttle the speed to about 75%
|
|
||||||
of the available upstream bandwidth. If you are communicating
|
|
||||||
with the server via a fast, symetric connection, you can set the
|
|
||||||
Limiter to ``No Limit`` instead. If want a stronger limitation,
|
|
||||||
choose ``Limit to`` and specify a limit manually.
|
|
||||||
|
|
||||||
|
|
||||||
Download Bandwidth
|
|
||||||
~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
Because the download bandwidth is usually no concern, it is not
|
|
||||||
automatically limited. Should you find that the Client is taking
|
|
||||||
up too much bandwidth, you can manually specify a limit (in KB).
|
|
||||||
|
|
||||||
Options
|
|
||||||
-------
|
|
||||||
.. index:: command line switches, command line, options, parameters
|
|
||||||
.. include:: options.rst
|
|
||||||
|
|
||||||
Config File
|
|
||||||
-----------
|
|
||||||
.. index:: config file
|
|
||||||
.. include:: conffile.rst
|
|
||||||
178
doc/visualtour.rst
Normal file
@@ -0,0 +1,178 @@
|
|||||||
|
Visual Tour
|
||||||
|
===========
|
||||||
|
|
||||||
|
.. index:: visual tour, usage
|
||||||
|
|
||||||
|
ownCloud Client stays in the background, and is visible as an
|
||||||
|
icon in your system tray (Windows, KDE), status bar (Mac OS X)
|
||||||
|
or notification area (Ubuntu), like so:
|
||||||
|
|
||||||
|
.. image:: images/icon.png
|
||||||
|
|
||||||
|
If a setup is still required, it will open the setup. Otherwise, the
|
||||||
|
main menu is opened, which provides several options and displays
|
||||||
|
progress information:
|
||||||
|
|
||||||
|
.. image:: images/menu.png
|
||||||
|
|
||||||
|
Here is an explanation of the individual items in the menu:
|
||||||
|
|
||||||
|
* ``Open ownCloud in browser``: Opens the ownCloud web interface
|
||||||
|
* ``Open folder 'ownCloud'``: Opens the local folder. If you have
|
||||||
|
defined multiple sync targets, you should see multiple entries
|
||||||
|
here.
|
||||||
|
* **Disk space indicator**: Shows how much space is used up on the server.
|
||||||
|
* Operation indicator: Shows the status of the current sync process, or
|
||||||
|
``Up to date`` if server and client are in sync.
|
||||||
|
* **Recent Changes**: shows the last six files modified by sync operations,
|
||||||
|
and provides access to the Sync Protocol, which lists all changes
|
||||||
|
since the last restart of ownCloud Client.
|
||||||
|
* ``Settings...``: provides access to the settings menu.
|
||||||
|
* ``Help``: Opens a browser to display this help.
|
||||||
|
* ``Quit ownCloud``: Quits ownCloud, ending a currently running sync run.
|
||||||
|
|
||||||
|
The settings dialog is split up in three categories: ``Account Settings``,
|
||||||
|
``General Settings`` and ``Network Settings``:
|
||||||
|
|
||||||
|
Account Settings
|
||||||
|
~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. index:: account settings, user, password, Server URL
|
||||||
|
|
||||||
|
The ``Account Settings`` tab provides an executive summary about the synced
|
||||||
|
folders in your account and allows to modify them. It also provides a more
|
||||||
|
detailed report about the storage usage. Finally, it allows to change
|
||||||
|
the files that ownCloud Client should ignore (for details, see the
|
||||||
|
``Ignored Files Editor`` section below), and to modify various aspects
|
||||||
|
of the current account settings, such as user name, password and server URL.
|
||||||
|
|
||||||
|
.. image:: images/settings_account.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
General Settings
|
||||||
|
~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. index:: general settings, auto start, startup, desktop notifications
|
||||||
|
|
||||||
|
The tab provides several useful options:
|
||||||
|
|
||||||
|
.. image:: images/settings_general.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
* **Launch on System Startup**: This option is automatically activated
|
||||||
|
once a user has conimaged his account. Unchecking the box will cause
|
||||||
|
ownCloud client to not launch on startup for a particular user.
|
||||||
|
* **Show Desktop Nofications**: Do not show bubble notifications whenever
|
||||||
|
a set of sync operations has been performed.
|
||||||
|
* **Use Monochrome Icons**: Use less obstrusive icons. Especially useful
|
||||||
|
on Mac OS.
|
||||||
|
|
||||||
|
The acout menu provides information about authors as well as detailed
|
||||||
|
information about the build conditions. Those are particularly valuable
|
||||||
|
when filing a bug report.
|
||||||
|
|
||||||
|
Network Settings
|
||||||
|
~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. index:: proxy settings, SOCKS, bandwith, throttling, limiting
|
||||||
|
|
||||||
|
This tab consollidates ``Proxy Settings`` and ``Bandwith Limiting``:
|
||||||
|
|
||||||
|
.. image:: images/settings_network.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
Proxy Settings
|
||||||
|
^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
* ``No Proxy``: Check this if ownCloud Client should circumvent the default
|
||||||
|
proxy conimaged on the system.
|
||||||
|
* ``Use system proxy``: Default, will follow the systems proxy settings.
|
||||||
|
On Linux, this will only pick up the value of the variable ``http_proxy``.
|
||||||
|
* ``Specify proxy manually as``: Allows to specify custom proxy settings.
|
||||||
|
If you require to go through a HTTP(S) proxy server such as Squid or Microsoft
|
||||||
|
Forefront TMG, pick ``HTTP(S)``. ``SOCKSv5`` on the other hand is particulary
|
||||||
|
useful in special company LAN setups, or in combination with the OpenSSH
|
||||||
|
dynamic application level forwarding feature (see ``ssh -D``).
|
||||||
|
* ``Host``: Enter the host name or IP address of your proxy server, followed
|
||||||
|
by the port number. HTTP proxies usually listen on Ports 8080 (default) or
|
||||||
|
3128. SOCKS server usually listen on port 1080.
|
||||||
|
* ``Proxy Server requires authentication``: Should be checked if the proxy
|
||||||
|
server does not allow anonymous usage. If you check this option, you must
|
||||||
|
provide username and password in the fields below, or ownless Cloud will no
|
||||||
|
longer be able to connect successfully.
|
||||||
|
|
||||||
|
Bandwidth Limiting
|
||||||
|
^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
The ``Download Bandwidth`` (i.e. the bandwidth available for data flowing
|
||||||
|
from the ownCloud Server to the client) can be either ``Unlimited``
|
||||||
|
(the default), or limited to a custom value, specified in bytes
|
||||||
|
|
||||||
|
The ``Upload Bandwith`` (i.e. the bandwith available for data flowing
|
||||||
|
from the ownCloud Client to the server) additionally has the option
|
||||||
|
to ``Limit automatically``: When this option is checked, the ownCloud
|
||||||
|
Client will surrender available upstream bandwith to other applications.
|
||||||
|
Use this option if you expirience problems with real time communication,
|
||||||
|
such as Skype or other VoIP software, in conjunction with ownCloud Client.
|
||||||
|
This is commonly the case with asymmetric internet connection, such as
|
||||||
|
certain DSL lines with very limited upstream capacity.
|
||||||
|
|
||||||
|
ownCloud Client will pick up changes immediately, but ongoing operations
|
||||||
|
will finish using the old settings.
|
||||||
|
|
||||||
|
The Sync Protocol
|
||||||
|
~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. index:: sync protocol
|
||||||
|
|
||||||
|
The ``Sync Protocol`` window, which can be invoked from either from the main
|
||||||
|
menu (``Recent Changes`` -> ``Details...``) or the ``Account Settings``
|
||||||
|
(``Info`` button), will provide you with an in-depth summary of the recent
|
||||||
|
sync activity. It will also show files that have not been synched (ignored
|
||||||
|
files). Those are ignored either because they are listed in the ignored
|
||||||
|
files list (see ``Ignored Files Editor`` section below), or because they
|
||||||
|
cannot be synced in a cross-platform manner because they contain special
|
||||||
|
characters that cannot be stored on certain file systems.
|
||||||
|
|
||||||
|
.. image:: images/sync_protocol.png
|
||||||
|
:scale: 50 %
|
||||||
|
|
||||||
|
.. _ignoredFilesEditor-label:
|
||||||
|
|
||||||
|
The Ignored Files Editor
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. index:: ignored files, exclude files, pattern
|
||||||
|
|
||||||
|
The ignored files editor allows adding patterns for files or directories
|
||||||
|
that should be excluded from the sync process. Next to normal characters,
|
||||||
|
wildcards can be used to match an arbitrary number of characters, designated
|
||||||
|
by an asterisk (``*``) or a single character, designated by a question mark
|
||||||
|
(``?``).
|
||||||
|
|
||||||
|
Global defaults cannot be directly modified within the editor. Hovering
|
||||||
|
with the mouse will reveal the location of the global exclude definition
|
||||||
|
file.
|
||||||
|
|
||||||
|
In addition to this list, ownCloud Client always excludes files with
|
||||||
|
characters that cannot be synched down to other file systems,
|
||||||
|
see :ref:`ignored-files-label`.
|
||||||
|
|
||||||
|
.. note:: Modifying the global exclude definition file might render the
|
||||||
|
client unusable or cause undesired behavior.
|
||||||
|
|
||||||
|
.. note:: Custom entries are currently not validated for syntactical
|
||||||
|
correctness by the editor, but might fail to load correctly.
|
||||||
|
|
||||||
|
.. image:: images/ignored_files_editor.png
|
||||||
|
:scale: 50%
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
^^^^^^^^^
|
||||||
|
+-----------+------------------------------+
|
||||||
|
| Pattern | Matches |
|
||||||
|
+===========+==============================+
|
||||||
|
| ``~$*`` | ``~$foo``, ``~$example.doc`` |
|
||||||
|
+-----------+------------------------------+
|
||||||
|
| ``fl?p`` | ``flip``, ``flap`` |
|
||||||
|
+-----------+------------------------------+
|
||||||
@@ -4,5 +4,5 @@ Type=Application
|
|||||||
Exec=@APPLICATION_EXECUTABLE@
|
Exec=@APPLICATION_EXECUTABLE@
|
||||||
Name=@APPLICATION_NAME@ desktop sync client
|
Name=@APPLICATION_NAME@ desktop sync client
|
||||||
GenericName=Folder Sync
|
GenericName=Folder Sync
|
||||||
Icon=@APPLICATION_SHORTNAME@
|
Icon=@APPLICATION_EXECUTABLE@
|
||||||
Keywords=@APPLICATION_NAME@;syncing;file;sharing
|
Keywords=@APPLICATION_NAME@;syncing;file;sharing
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ else()
|
|||||||
set(theme_dir ${CMAKE_CURRENT_SOURCE_DIR}/../theme)
|
set(theme_dir ${CMAKE_CURRENT_SOURCE_DIR}/../theme)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(synclib_NAME ${APPLICATION_SHORTNAME}sync)
|
set(synclib_NAME ${APPLICATION_EXECUTABLE}sync)
|
||||||
|
|
||||||
set(mirall_UI
|
set(mirall_UI
|
||||||
mirall/folderwizardsourcepage.ui
|
mirall/folderwizardsourcepage.ui
|
||||||
@@ -168,8 +168,8 @@ if(NOT BUILD_OWNCLOUD_OSX_BUNDLE)
|
|||||||
)
|
)
|
||||||
if(NOT WIN32)
|
if(NOT WIN32)
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/mirall.desktop.in
|
configure_file(${CMAKE_SOURCE_DIR}/mirall.desktop.in
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/${APPLICATION_SHORTNAME}.desktop)
|
${CMAKE_CURRENT_BINARY_DIR}/${APPLICATION_EXECUTABLE}.desktop)
|
||||||
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${APPLICATION_SHORTNAME}.desktop DESTINATION share/applications )
|
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${APPLICATION_EXECUTABLE}.desktop DESTINATION share/applications )
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
install(TARGETS ${synclib_NAME} DESTINATION ${OWNCLOUD_OSX_BUNDLE}/Contents/MacOS)
|
install(TARGETS ${synclib_NAME} DESTINATION ${OWNCLOUD_OSX_BUNDLE}/Contents/MacOS)
|
||||||
@@ -254,7 +254,7 @@ set( final_src
|
|||||||
include( AddAppIconMacro )
|
include( AddAppIconMacro )
|
||||||
set(ownCloud_old ${ownCloud})
|
set(ownCloud_old ${ownCloud})
|
||||||
|
|
||||||
kde4_add_app_icon( ownCloud "${theme_dir}/colored/${APPLICATION_SHORTNAME}-icon*.png")
|
kde4_add_app_icon( ownCloud "${theme_dir}/colored/${APPLICATION_EXECUTABLE}-icon*.png")
|
||||||
list(APPEND final_src ${ownCloud})
|
list(APPEND final_src ${ownCloud})
|
||||||
set(ownCloud ${ownCloud_old})
|
set(ownCloud ${ownCloud_old})
|
||||||
|
|
||||||
@@ -262,16 +262,15 @@ if(NOT BUILD_OWNCLOUD_OSX_BUNDLE)
|
|||||||
set(BIN_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin")
|
set(BIN_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin")
|
||||||
|
|
||||||
if(NOT WIN32)
|
if(NOT WIN32)
|
||||||
file( GLOB _icons "${theme_dir}/colored/${APPLICATION_SHORTNAME}-icon-*.png" )
|
file( GLOB _icons "${theme_dir}/colored/${APPLICATION_EXECUTABLE}-icon-*.png" )
|
||||||
foreach( _file ${_icons} )
|
foreach( _file ${_icons} )
|
||||||
string( REPLACE "${theme_dir}/colored/${APPLICATION_SHORTNAME}-icon-" "" _res ${_file} )
|
string( REPLACE "${theme_dir}/colored/${APPLICATION_EXECUTABLE}-icon-" "" _res ${_file} )
|
||||||
string( REPLACE ".png" "" _res ${_res} )
|
string( REPLACE ".png" "" _res ${_res} )
|
||||||
install( FILES ${_file} RENAME ${APPLICATION_SHORTNAME}.png DESTINATION
|
install( FILES ${_file} RENAME ${APPLICATION_EXECUTABLE}.png DESTINATION ${DATADIR}/icons/hicolor/${_res}x${_res}/apps )
|
||||||
${CMAKE_INSTALL_DATADIR}/icons/hicolor/${_res}x${_res}/apps )
|
|
||||||
endforeach( _file )
|
endforeach( _file )
|
||||||
endif(NOT WIN32)
|
endif(NOT WIN32)
|
||||||
|
|
||||||
install(FILES ${mirall_I18N} DESTINATION share/${APPLICATION_SHORTNAME}/i18n)
|
install(FILES ${mirall_I18N} DESTINATION share/${APPLICATION_EXECUTABLE}/i18n)
|
||||||
|
|
||||||
# we may not add MACOSX_BUNDLE here, if not building one
|
# we may not add MACOSX_BUNDLE here, if not building one
|
||||||
|
|
||||||
|
|||||||
@@ -39,7 +39,7 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
if (!QSystemTrayIcon::isSystemTrayAvailable()) {
|
if (!QSystemTrayIcon::isSystemTrayAvailable() && qgetenv("DESKTOP_SESSION") != "ubuntu") {
|
||||||
QMessageBox::critical(0, qApp->translate("main.cpp", "System Tray not available"),
|
QMessageBox::critical(0, qApp->translate("main.cpp", "System Tray not available"),
|
||||||
qApp->translate("main.cpp", "%1 requires on a working system tray. "
|
qApp->translate("main.cpp", "%1 requires on a working system tray. "
|
||||||
"If you are running XFCE, please follow "
|
"If you are running XFCE, please follow "
|
||||||
|
|||||||
@@ -38,6 +38,16 @@
|
|||||||
|
|
||||||
namespace Mirall {
|
namespace Mirall {
|
||||||
|
|
||||||
|
static const char progressBarStyleC[] =
|
||||||
|
"QProgressBar {"
|
||||||
|
"border: 1px solid grey;"
|
||||||
|
"border-radius: 5px;"
|
||||||
|
"text-align: center;"
|
||||||
|
"}"
|
||||||
|
"QProgressBar::chunk {"
|
||||||
|
"background-color: %1; width: 1px;"
|
||||||
|
"}";
|
||||||
|
|
||||||
AccountSettings::AccountSettings(QWidget *parent) :
|
AccountSettings::AccountSettings(QWidget *parent) :
|
||||||
QWidget(parent),
|
QWidget(parent),
|
||||||
ui(new Ui::AccountSettings),
|
ui(new Ui::AccountSettings),
|
||||||
@@ -48,6 +58,7 @@ AccountSettings::AccountSettings(QWidget *parent) :
|
|||||||
_model = new FolderStatusModel;
|
_model = new FolderStatusModel;
|
||||||
_model->setParent(this);
|
_model->setParent(this);
|
||||||
FolderStatusDelegate *delegate = new FolderStatusDelegate;
|
FolderStatusDelegate *delegate = new FolderStatusDelegate;
|
||||||
|
delegate->setParent(this);
|
||||||
|
|
||||||
ui->_folderList->setItemDelegate( delegate );
|
ui->_folderList->setItemDelegate( delegate );
|
||||||
ui->_folderList->setModel( _model );
|
ui->_folderList->setModel( _model );
|
||||||
@@ -74,6 +85,8 @@ AccountSettings::AccountSettings(QWidget *parent) :
|
|||||||
connect(ui->_folderList, SIGNAL(clicked(QModelIndex)), SLOT(slotFolderActivated(QModelIndex)));
|
connect(ui->_folderList, SIGNAL(clicked(QModelIndex)), SLOT(slotFolderActivated(QModelIndex)));
|
||||||
connect(ui->_folderList, SIGNAL(doubleClicked(QModelIndex)),SLOT(slotDoubleClicked(QModelIndex)));
|
connect(ui->_folderList, SIGNAL(doubleClicked(QModelIndex)),SLOT(slotDoubleClicked(QModelIndex)));
|
||||||
|
|
||||||
|
QColor color = palette().highlight().color();
|
||||||
|
ui->quotaProgressBar->setStyleSheet(QString::fromLatin1(progressBarStyleC).arg(color.name()));
|
||||||
ownCloudInfo *ocInfo = ownCloudInfo::instance();
|
ownCloudInfo *ocInfo = ownCloudInfo::instance();
|
||||||
slotUpdateQuota(ocInfo->lastQuotaTotalBytes(), ocInfo->lastQuotaUsedBytes());
|
slotUpdateQuota(ocInfo->lastQuotaTotalBytes(), ocInfo->lastQuotaUsedBytes());
|
||||||
connect(ocInfo, SIGNAL(quotaUpdated(qint64,qint64)), SLOT(slotUpdateQuota(qint64,qint64)));
|
connect(ocInfo, SIGNAL(quotaUpdated(qint64,qint64)), SLOT(slotUpdateQuota(qint64,qint64)));
|
||||||
@@ -209,7 +222,11 @@ void AccountSettings::folderToModelItem( QStandardItem *item, Folder *f )
|
|||||||
SyncResult res = f->syncResult();
|
SyncResult res = f->syncResult();
|
||||||
SyncResult::Status status = res.status();
|
SyncResult::Status status = res.status();
|
||||||
|
|
||||||
QString errors = res.errorStrings().join(QLatin1String("<br/>"));
|
QStringList errorList = res.errorStrings();
|
||||||
|
QString errors;
|
||||||
|
if( ! errorList.isEmpty() ) {
|
||||||
|
errors = res.errorStrings().join(QLatin1String("<br/>"));
|
||||||
|
}
|
||||||
|
|
||||||
Theme *theme = Theme::instance();
|
Theme *theme = Theme::instance();
|
||||||
item->setData( theme->statusHeaderText( status ), Qt::ToolTipRole );
|
item->setData( theme->statusHeaderText( status ), Qt::ToolTipRole );
|
||||||
@@ -221,6 +238,12 @@ void AccountSettings::folderToModelItem( QStandardItem *item, Folder *f )
|
|||||||
item->setData( theme->statusHeaderText( status ), FolderStatusDelegate::FolderStatus );
|
item->setData( theme->statusHeaderText( status ), FolderStatusDelegate::FolderStatus );
|
||||||
item->setData( errors, FolderStatusDelegate::FolderErrorMsg );
|
item->setData( errors, FolderStatusDelegate::FolderErrorMsg );
|
||||||
|
|
||||||
|
if( errors.isEmpty() && (status == SyncResult::Error ||
|
||||||
|
status == SyncResult::SetupError ||
|
||||||
|
status == SyncResult::Unavailable )) {
|
||||||
|
item->setData( theme->statusHeaderText(status), FolderStatusDelegate::FolderErrorMsg);
|
||||||
|
}
|
||||||
|
|
||||||
bool ongoing = false;
|
bool ongoing = false;
|
||||||
item->setData( QVariant(res.warnCount()), FolderStatusDelegate::WarningCount );
|
item->setData( QVariant(res.warnCount()), FolderStatusDelegate::WarningCount );
|
||||||
if( status == SyncResult::SyncRunning ) {
|
if( status == SyncResult::SyncRunning ) {
|
||||||
@@ -425,7 +448,9 @@ void AccountSettings::slotOCInfo( const QString& url, const QString& versionStr,
|
|||||||
qDebug() << "#-------# oC found on " << url;
|
qDebug() << "#-------# oC found on " << url;
|
||||||
/* enable the open button */
|
/* enable the open button */
|
||||||
ui->connectLabel->setOpenExternalLinks(true);
|
ui->connectLabel->setOpenExternalLinks(true);
|
||||||
ui->connectLabel->setText( tr("Connected to <a href=\"%1\">%1</a>.").arg(url) );
|
QUrl safeUrl(url);
|
||||||
|
safeUrl.setPassword(QString()); // Remove the password from the URL to avoid showing it in the UI
|
||||||
|
ui->connectLabel->setText( tr("Connected to <a href=\"%1\">%2</a>.").arg(url, safeUrl.toString()) );
|
||||||
ui->connectLabel->setToolTip( tr("Version: %1 (%2)").arg(versionStr).arg(version));
|
ui->connectLabel->setToolTip( tr("Version: %1 (%2)").arg(versionStr).arg(version));
|
||||||
ui->_ButtonAdd->setEnabled(true);
|
ui->_ButtonAdd->setEnabled(true);
|
||||||
|
|
||||||
@@ -646,13 +671,23 @@ void AccountSettings::slotHideProgress()
|
|||||||
|
|
||||||
void AccountSettings::slotUpdateQuota(qint64 total, qint64 used)
|
void AccountSettings::slotUpdateQuota(qint64 total, qint64 used)
|
||||||
{
|
{
|
||||||
ui->quotaProgressBar->setEnabled(true);
|
if( total > 0 ) {
|
||||||
// workaround the label only accepting ints (which may be only 32 bit wide)
|
ui->quotaProgressBar->setVisible(true);
|
||||||
ui->quotaProgressBar->setMaximum(100);
|
ui->quotaInfoLabel->setVisible(true);
|
||||||
ui->quotaProgressBar->setValue(round(used/(double)total * 100));
|
ui->quotaProgressBar->setEnabled(true);
|
||||||
QString usedStr = Utility::octetsToString(used);
|
// workaround the label only accepting ints (which may be only 32 bit wide)
|
||||||
QString totalStr = Utility::octetsToString(total);
|
ui->quotaProgressBar->setMaximum(100);
|
||||||
ui->quotaLabel->setText(tr("%1 of %2 in use.").arg(usedStr, totalStr));
|
int qVal = qRound(used/(double)total * 100);
|
||||||
|
if( qVal > 100 ) qVal = 100;
|
||||||
|
ui->quotaProgressBar->setValue(qVal);
|
||||||
|
QString usedStr = Utility::octetsToString(used);
|
||||||
|
QString totalStr = Utility::octetsToString(total);
|
||||||
|
ui->quotaLabel->setText(tr("%1 of %2 in use.").arg(usedStr, totalStr));
|
||||||
|
} else {
|
||||||
|
ui->quotaProgressBar->setVisible(false);
|
||||||
|
ui->quotaInfoLabel->setVisible(false);
|
||||||
|
ui->quotaLabel->setText(tr("Currently there is no storage usage information available."));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AccountSettings::slotIgnoreFilesEditor()
|
void AccountSettings::slotIgnoreFilesEditor()
|
||||||
|
|||||||
@@ -37,19 +37,6 @@
|
|||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
|
||||||
<spacer name="verticalSpacer">
|
|
||||||
<property name="orientation">
|
|
||||||
<enum>Qt::Vertical</enum>
|
|
||||||
</property>
|
|
||||||
<property name="sizeHint" stdset="0">
|
|
||||||
<size>
|
|
||||||
<width>20</width>
|
|
||||||
<height>40</height>
|
|
||||||
</size>
|
|
||||||
</property>
|
|
||||||
</spacer>
|
|
||||||
</item>
|
|
||||||
</layout>
|
</layout>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
@@ -144,7 +131,7 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="label_2">
|
<widget class="QLabel" name="quotaInfoLabel">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string><b>Note:</b> Some folders, including network mounted or shared folders, might have different limits.</string>
|
<string><b>Note:</b> Some folders, including network mounted or shared folders, might have different limits.</string>
|
||||||
</property>
|
</property>
|
||||||
|
|||||||
@@ -16,6 +16,8 @@
|
|||||||
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
#include "mirall/application.h"
|
#include "mirall/application.h"
|
||||||
#include "mirall/systray.h"
|
#include "mirall/systray.h"
|
||||||
#include "mirall/folder.h"
|
#include "mirall/folder.h"
|
||||||
@@ -81,8 +83,7 @@ static const char optionsC[] =
|
|||||||
QString applicationTrPath()
|
QString applicationTrPath()
|
||||||
{
|
{
|
||||||
#ifdef Q_OS_LINUX
|
#ifdef Q_OS_LINUX
|
||||||
// FIXME - proper path!
|
return QString::fromLatin1(DATADIR"/i18n/");
|
||||||
return QString::fromLatin1("/usr/share/%1/i18n/").arg(Theme::instance()->appName());
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef Q_OS_MAC
|
#ifdef Q_OS_MAC
|
||||||
return QApplication::applicationDirPath()+QLatin1String("/../Resources/Translations"); // path defaults to app dir.
|
return QApplication::applicationDirPath()+QLatin1String("/../Resources/Translations"); // path defaults to app dir.
|
||||||
@@ -183,6 +184,11 @@ Application::Application(int &argc, char **argv) :
|
|||||||
|
|
||||||
Application::~Application()
|
Application::~Application()
|
||||||
{
|
{
|
||||||
|
if (_settingsDialog) {
|
||||||
|
delete _settingsDialog.data();
|
||||||
|
}
|
||||||
|
|
||||||
|
delete _logBrowser;
|
||||||
delete _tray; // needed, see ctor
|
delete _tray; // needed, see ctor
|
||||||
|
|
||||||
qDebug() << "* Mirall shutdown";
|
qDebug() << "* Mirall shutdown";
|
||||||
@@ -408,7 +414,9 @@ void Application::setupContextMenu()
|
|||||||
_contextMenu->addMenu(_recentActionsMenu);
|
_contextMenu->addMenu(_recentActionsMenu);
|
||||||
_contextMenu->addSeparator();
|
_contextMenu->addSeparator();
|
||||||
_contextMenu->addAction(_actionSettings);
|
_contextMenu->addAction(_actionSettings);
|
||||||
_contextMenu->addAction(_actionHelp);
|
if (!_theme->helpUrl().isEmpty()) {
|
||||||
|
_contextMenu->addAction(_actionHelp);
|
||||||
|
}
|
||||||
_contextMenu->addSeparator();
|
_contextMenu->addSeparator();
|
||||||
|
|
||||||
_contextMenu->addAction(_actionQuit);
|
_contextMenu->addAction(_actionQuit);
|
||||||
@@ -511,6 +519,9 @@ void Application::slotSetupProxy()
|
|||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FolderMan::instance()->setDirtyProxy(true);
|
||||||
|
FolderMan::instance()->slotScheduleAllFolders();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Application::slotRefreshQuotaDisplay( qint64 total, qint64 used )
|
void Application::slotRefreshQuotaDisplay( qint64 total, qint64 used )
|
||||||
@@ -552,9 +563,9 @@ void Application::rebuildRecentMenus()
|
|||||||
_recentActionsMenu->addAction(tr("No items synced recently"));
|
_recentActionsMenu->addAction(tr("No items synced recently"));
|
||||||
} else {
|
} else {
|
||||||
QListIterator<Progress::Info> i(progressInfoList);
|
QListIterator<Progress::Info> i(progressInfoList);
|
||||||
i.toBack();
|
|
||||||
while(i.hasPrevious()) {
|
while(i.hasNext()) {
|
||||||
Progress::Info info = i.previous();
|
Progress::Info info = i.next();
|
||||||
QString kindStr = Progress::asResultString(info.kind);
|
QString kindStr = Progress::asResultString(info.kind);
|
||||||
QString timeStr = info.timestamp.toString("hh:mm");
|
QString timeStr = info.timestamp.toString("hh:mm");
|
||||||
|
|
||||||
|
|||||||
@@ -140,19 +140,19 @@ QString CSyncThread::csyncErrorToString( CSYNC_ERROR_CODE err, const char *errSt
|
|||||||
errStr = tr("A HTTP transmission error happened.");
|
errStr = tr("A HTTP transmission error happened.");
|
||||||
break;
|
break;
|
||||||
case CSYNC_ERR_PERM:
|
case CSYNC_ERR_PERM:
|
||||||
errStr = tr("CSync failed due to not handled permission deniend.");
|
errStr = tr("CSync: Permission deniend.");
|
||||||
break;
|
break;
|
||||||
case CSYNC_ERR_NOT_FOUND:
|
case CSYNC_ERR_NOT_FOUND:
|
||||||
errStr = tr("CSync failed to find a specific file.");
|
errStr = tr("CSync: File not found.");
|
||||||
break;
|
break;
|
||||||
case CSYNC_ERR_EXISTS:
|
case CSYNC_ERR_EXISTS:
|
||||||
errStr = tr("CSync tried to create a directory that already exists.");
|
errStr = tr("CSync: Directory already exists.");
|
||||||
break;
|
break;
|
||||||
case CSYNC_ERR_NOSPC:
|
case CSYNC_ERR_NOSPC:
|
||||||
errStr = tr("CSync: No space on %1 server available.").arg(Theme::instance()->appNameGUI());
|
errStr = tr("CSync: No space left on %1 server.").arg(Theme::instance()->appNameGUI());
|
||||||
break;
|
break;
|
||||||
case CSYNC_ERR_UNSPEC:
|
case CSYNC_ERR_UNSPEC:
|
||||||
errStr = tr("CSync unspecified error.");
|
errStr = tr("CSync: unspecified error.");
|
||||||
|
|
||||||
default:
|
default:
|
||||||
errStr = tr("An internal error number %1 happend.").arg( (int) err );
|
errStr = tr("An internal error number %1 happend.").arg( (int) err );
|
||||||
@@ -187,7 +187,9 @@ int CSyncThread::treewalkFile( TREE_WALK_FILE *file, bool remote )
|
|||||||
item._file = QString::fromUtf8( file->path );
|
item._file = QString::fromUtf8( file->path );
|
||||||
item._instruction = file->instruction;
|
item._instruction = file->instruction;
|
||||||
item._dir = SyncFileItem::None;
|
item._dir = SyncFileItem::None;
|
||||||
|
if(file->error_string) {
|
||||||
|
item._errorString = QString::fromUtf8(file->error_string);
|
||||||
|
}
|
||||||
SyncFileItem::Direction dir;
|
SyncFileItem::Direction dir;
|
||||||
|
|
||||||
int re = 0;
|
int re = 0;
|
||||||
|
|||||||
@@ -205,7 +205,7 @@ void Folder::setSyncEnabled( bool doit )
|
|||||||
_syncResult.clearErrors();
|
_syncResult.clearErrors();
|
||||||
evaluateSync( QStringList() );
|
evaluateSync( QStringList() );
|
||||||
} else {
|
} else {
|
||||||
// disable folder. Done through the _enabled-flag set above
|
_pollTimer.stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -283,9 +283,13 @@ void Folder::bubbleUpSyncResult()
|
|||||||
SyncFileItem firstItemDeleted;
|
SyncFileItem firstItemDeleted;
|
||||||
SyncFileItem firstItemUpdated;
|
SyncFileItem firstItemUpdated;
|
||||||
|
|
||||||
|
Logger *logger = Logger::instance();
|
||||||
|
|
||||||
foreach (const SyncFileItem &item, _syncResult.syncFileItemVector() ) {
|
foreach (const SyncFileItem &item, _syncResult.syncFileItemVector() ) {
|
||||||
if( item._instruction == CSYNC_INSTRUCTION_ERROR ) {
|
if( item._instruction == CSYNC_INSTRUCTION_ERROR ) {
|
||||||
slotCSyncError( tr("File %1: %2").arg(item._file).arg(item._errorString) );
|
slotCSyncError( tr("File %1: %2").arg(item._file).arg(item._errorString) );
|
||||||
|
logger->postGuiLog(tr("File %1").arg(item._file), item._errorString);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (item._dir == SyncFileItem::Down) {
|
if (item._dir == SyncFileItem::Down) {
|
||||||
switch (item._instruction) {
|
switch (item._instruction) {
|
||||||
@@ -293,11 +297,21 @@ void Folder::bubbleUpSyncResult()
|
|||||||
newItems++;
|
newItems++;
|
||||||
if (firstItemNew.isEmpty())
|
if (firstItemNew.isEmpty())
|
||||||
firstItemNew = item;
|
firstItemNew = item;
|
||||||
|
|
||||||
|
if (item._type == SyncFileItem::Directory) {
|
||||||
|
_watcher->addPath(path() + item._file);
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case CSYNC_INSTRUCTION_REMOVE:
|
case CSYNC_INSTRUCTION_REMOVE:
|
||||||
removedItems++;
|
removedItems++;
|
||||||
if (firstItemDeleted.isEmpty())
|
if (firstItemDeleted.isEmpty())
|
||||||
firstItemDeleted = item;
|
firstItemDeleted = item;
|
||||||
|
|
||||||
|
if (item._type == SyncFileItem::Directory) {
|
||||||
|
_watcher->removePath(path() + item._file);
|
||||||
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case CSYNC_INSTRUCTION_UPDATED:
|
case CSYNC_INSTRUCTION_UPDATED:
|
||||||
updatedItems++;
|
updatedItems++;
|
||||||
@@ -321,8 +335,6 @@ void Folder::bubbleUpSyncResult()
|
|||||||
|
|
||||||
_syncResult.setWarnCount(ignoredItems);
|
_syncResult.setWarnCount(ignoredItems);
|
||||||
|
|
||||||
Logger *logger = Logger::instance();
|
|
||||||
|
|
||||||
qDebug() << "OO folder slotSyncFinished: result: " << int(_syncResult.status());
|
qDebug() << "OO folder slotSyncFinished: result: " << int(_syncResult.status());
|
||||||
if (newItems > 0) {
|
if (newItems > 0) {
|
||||||
QString file = QDir::toNativeSeparators(firstItemNew._file);
|
QString file = QDir::toNativeSeparators(firstItemNew._file);
|
||||||
@@ -486,6 +498,8 @@ void Folder::setProxy()
|
|||||||
csync_set_module_property(_csync_ctx, "proxy_port", &proxyPort );
|
csync_set_module_property(_csync_ctx, "proxy_port", &proxyPort );
|
||||||
csync_set_module_property(_csync_ctx, "proxy_user", proxy.user().toUtf8().data() );
|
csync_set_module_property(_csync_ctx, "proxy_user", proxy.user().toUtf8().data() );
|
||||||
csync_set_module_property(_csync_ctx, "proxy_pwd" , proxy.password().toUtf8().data() );
|
csync_set_module_property(_csync_ctx, "proxy_pwd" , proxy.password().toUtf8().data() );
|
||||||
|
|
||||||
|
FolderMan::instance()->setDirtyProxy(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -524,6 +538,8 @@ void Folder::startSync(const QStringList &pathList)
|
|||||||
QMetaObject::invokeMethod(this, "slotCSyncFinished", Qt::QueuedConnection);
|
QMetaObject::invokeMethod(this, "slotCSyncFinished", Qt::QueuedConnection);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
} else if (FolderMan::instance()->isDirtyProxy()) {
|
||||||
|
setProxy();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_thread && _thread->isRunning()) {
|
if (_thread && _thread->isRunning()) {
|
||||||
|
|||||||
@@ -37,7 +37,8 @@ FolderMan* FolderMan::_instance = 0;
|
|||||||
|
|
||||||
FolderMan::FolderMan(QObject *parent) :
|
FolderMan::FolderMan(QObject *parent) :
|
||||||
QObject(parent),
|
QObject(parent),
|
||||||
_syncEnabled( true )
|
_syncEnabled( true ),
|
||||||
|
_dirtyProxy( true )
|
||||||
{
|
{
|
||||||
// if QDir::mkpath would not be so stupid, I would not need to have this
|
// if QDir::mkpath would not be so stupid, I would not need to have this
|
||||||
// duplication of folderConfigPath() here
|
// duplication of folderConfigPath() here
|
||||||
|
|||||||
@@ -109,6 +109,9 @@ public slots:
|
|||||||
|
|
||||||
void slotScheduleAllFolders();
|
void slotScheduleAllFolders();
|
||||||
|
|
||||||
|
bool isDirtyProxy() { return _dirtyProxy; }
|
||||||
|
void setDirtyProxy(bool value = true) { _dirtyProxy = value; }
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
// slot to add a folder to the syncing queue
|
// slot to add a folder to the syncing queue
|
||||||
void slotScheduleSync( const QString & );
|
void slotScheduleSync( const QString & );
|
||||||
@@ -136,6 +139,7 @@ private:
|
|||||||
QString _currentSyncFolder;
|
QString _currentSyncFolder;
|
||||||
bool _syncEnabled;
|
bool _syncEnabled;
|
||||||
QQueue<QString> _scheduleQueue;
|
QQueue<QString> _scheduleQueue;
|
||||||
|
bool _dirtyProxy; // If the proxy need to be re-configured
|
||||||
|
|
||||||
explicit FolderMan(QObject *parent = 0);
|
explicit FolderMan(QObject *parent = 0);
|
||||||
static FolderMan *_instance;
|
static FolderMan *_instance;
|
||||||
|
|||||||
@@ -243,7 +243,7 @@ void FolderStatusDelegate::paint(QPainter *painter, const QStyleOptionViewItem &
|
|||||||
// Sync File Progress Bar: Show it if syncFile is not empty.
|
// Sync File Progress Bar: Show it if syncFile is not empty.
|
||||||
if( !overallString.isEmpty()) {
|
if( !overallString.isEmpty()) {
|
||||||
int fileNameTextHeight = subFm.boundingRect(tr("File")).height();
|
int fileNameTextHeight = subFm.boundingRect(tr("File")).height();
|
||||||
int barHeight = fileNameTextHeight;
|
int barHeight = qMax(fileNameTextHeight, aliasFm.height()+2); ;
|
||||||
int overallWidth = option.rect.width()-2*aliasMargin;
|
int overallWidth = option.rect.width()-2*aliasMargin;
|
||||||
|
|
||||||
painter->save();
|
painter->save();
|
||||||
@@ -260,6 +260,7 @@ void FolderStatusDelegate::paint(QPainter *painter, const QStyleOptionViewItem &
|
|||||||
pBRect.setWidth( overallWidth - progressTextWidth - margin );
|
pBRect.setWidth( overallWidth - progressTextWidth - margin );
|
||||||
|
|
||||||
QStyleOptionProgressBarV2 pBarOpt;
|
QStyleOptionProgressBarV2 pBarOpt;
|
||||||
|
|
||||||
pBarOpt.state = option.state | QStyle::State_Horizontal;
|
pBarOpt.state = option.state | QStyle::State_Horizontal;
|
||||||
pBarOpt.minimum = 0;
|
pBarOpt.minimum = 0;
|
||||||
pBarOpt.maximum = 100;
|
pBarOpt.maximum = 100;
|
||||||
@@ -280,6 +281,7 @@ void FolderStatusDelegate::paint(QPainter *painter, const QStyleOptionViewItem &
|
|||||||
|
|
||||||
QString elidedText = progressFm.elidedText(overallString, Qt::ElideLeft, overallProgressRect.width());
|
QString elidedText = progressFm.elidedText(overallString, Qt::ElideLeft, overallProgressRect.width());
|
||||||
painter->drawText( overallProgressRect, Qt::AlignRight+Qt::AlignVCenter, elidedText);
|
painter->drawText( overallProgressRect, Qt::AlignRight+Qt::AlignVCenter, elidedText);
|
||||||
|
// painter->drawRect(overallProgressRect);
|
||||||
|
|
||||||
// Individual File Progress
|
// Individual File Progress
|
||||||
QRect fileRect;
|
QRect fileRect;
|
||||||
|
|||||||
@@ -172,5 +172,16 @@ void FolderWatcher::changeDetected(const QString& f)
|
|||||||
setProcessTimer();
|
setProcessTimer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FolderWatcher::addPath(const QString &path )
|
||||||
|
{
|
||||||
|
_d->addPath(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FolderWatcher::removePath(const QString &path )
|
||||||
|
{
|
||||||
|
_d->removePath(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace Mirall
|
} // namespace Mirall
|
||||||
|
|
||||||
|
|||||||
@@ -88,6 +88,15 @@ public:
|
|||||||
void setEventInterval(int seconds);
|
void setEventInterval(int seconds);
|
||||||
|
|
||||||
QStringList ignores() const;
|
QStringList ignores() const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Not all backends are recursive by default.
|
||||||
|
* Those need to be notified when a directory is added or removed while the watcher is disabled.
|
||||||
|
* This is a no-op for backend that are recursive
|
||||||
|
*/
|
||||||
|
void addPath(const QString&);
|
||||||
|
void removePath(const QString&);
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* Enabled or disables folderChanged() events.
|
* Enabled or disables folderChanged() events.
|
||||||
|
|||||||
@@ -50,8 +50,7 @@ void FolderWatcherPrivate::slotAddFolderRecursive(const QString &path)
|
|||||||
qDebug() << "(+) Watcher:" << path;
|
qDebug() << "(+) Watcher:" << path;
|
||||||
|
|
||||||
if (!_inotify->addPath(path)) {
|
if (!_inotify->addPath(path)) {
|
||||||
FolderWatcher *fw = qobject_cast<FolderWatcher*>(parent());
|
emit _parent->error(tr("Could not monitor directories due to system limitations.\n"
|
||||||
emit fw->error(tr("Could not monitor directories due to system limitations.\n"
|
|
||||||
"The application will not work reliably. Please check the\n"
|
"The application will not work reliably. Please check the\n"
|
||||||
"documentation for possible fixes."));
|
"documentation for possible fixes."));
|
||||||
}
|
}
|
||||||
@@ -119,9 +118,8 @@ void FolderWatcherPrivate::slotINotifyEvent(int mask, int /*cookie*/, const QStr
|
|||||||
}
|
}
|
||||||
else if (mask & IN_DELETE) {
|
else if (mask & IN_DELETE) {
|
||||||
//qDebug() << cookie << " DELETE: " << path;
|
//qDebug() << cookie << " DELETE: " << path;
|
||||||
if ( QFileInfo(path).isDir() && _inotify->directories().contains(path) ) {
|
if ( QFileInfo(path).isDir() ) {
|
||||||
qDebug() << "(-) Watcher:" << path;
|
removePath(path);
|
||||||
_inotify->removePath(path);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (mask & IN_CLOSE_WRITE) {
|
else if (mask & IN_CLOSE_WRITE) {
|
||||||
@@ -160,4 +158,13 @@ void FolderWatcherPrivate::slotINotifyEvent(int mask, int /*cookie*/, const QStr
|
|||||||
_parent->setProcessTimer();
|
_parent->setProcessTimer();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FolderWatcherPrivate::removePath(const QString &path )
|
||||||
|
{
|
||||||
|
if (_inotify->directories().contains(path) ) {
|
||||||
|
qDebug() << "(-) Watcher:" << path;
|
||||||
|
_inotify->removePath(path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
} // namespace Mirall
|
} // namespace Mirall
|
||||||
|
|||||||
@@ -26,6 +26,8 @@ class FolderWatcherPrivate : public QObject {
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
FolderWatcherPrivate(FolderWatcher *p);
|
FolderWatcherPrivate(FolderWatcher *p);
|
||||||
|
void addPath(const QString &path) { slotAddFolderRecursive(path); }
|
||||||
|
void removePath(const QString &);
|
||||||
signals:
|
signals:
|
||||||
void error(const QString& error);
|
void error(const QString& error);
|
||||||
private slots:
|
private slots:
|
||||||
|
|||||||
@@ -31,6 +31,9 @@ public:
|
|||||||
FolderWatcherPrivate(FolderWatcher *p);
|
FolderWatcherPrivate(FolderWatcher *p);
|
||||||
~FolderWatcherPrivate();
|
~FolderWatcherPrivate();
|
||||||
|
|
||||||
|
void addPath(const QString &) {}
|
||||||
|
void removePath(const QString &) {}
|
||||||
|
|
||||||
void startWatching();
|
void startWatching();
|
||||||
void doNotifyParent();
|
void doNotifyParent();
|
||||||
|
|
||||||
|
|||||||
@@ -48,6 +48,10 @@ class FolderWatcherPrivate : public QObject {
|
|||||||
public:
|
public:
|
||||||
FolderWatcherPrivate(FolderWatcher *p);
|
FolderWatcherPrivate(FolderWatcher *p);
|
||||||
~FolderWatcherPrivate();
|
~FolderWatcherPrivate();
|
||||||
|
|
||||||
|
void addPath(const QString &) {}
|
||||||
|
void removePath(const QString &) {}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
FolderWatcher *_parent;
|
FolderWatcher *_parent;
|
||||||
WatcherThread *_thread;
|
WatcherThread *_thread;
|
||||||
|
|||||||
@@ -53,12 +53,9 @@ GeneralSettings::GeneralSettings(QWidget *parent) :
|
|||||||
|
|
||||||
// OEM themes are not obliged to ship mono icons, so there
|
// OEM themes are not obliged to ship mono icons, so there
|
||||||
// is no point in offering an option
|
// is no point in offering an option
|
||||||
QString themeDir = QString::fromLatin1(":/mirall/theme/1%1/")
|
QString themeDir = QString::fromLatin1(":/mirall/theme/%1/")
|
||||||
.arg(Theme::instance()->systrayIconFlavor(true));
|
.arg(Theme::instance()->systrayIconFlavor(true));
|
||||||
if (QDir(themeDir).exists())
|
_ui->monoIconsCheckBox->setVisible(QDir(themeDir).exists());
|
||||||
{
|
|
||||||
_ui->monoIconsCheckBox->setVisible(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -103,8 +103,11 @@ void ItemProgressDialog::setSyncResult( const SyncResult& result )
|
|||||||
for (i = items.begin(); i != items.end(); ++i) {
|
for (i = items.begin(); i != items.end(); ++i) {
|
||||||
const SyncFileItem& item = *i;
|
const SyncFileItem& item = *i;
|
||||||
QString errMsg;
|
QString errMsg;
|
||||||
|
QString tooltip;
|
||||||
// handle ignored files here.
|
// handle ignored files here.
|
||||||
if( item._instruction == CSYNC_INSTRUCTION_IGNORE ) {
|
|
||||||
|
if( item._instruction == CSYNC_INSTRUCTION_IGNORE
|
||||||
|
|| item._instruction == CSYNC_INSTRUCTION_CONFLICT ) {
|
||||||
QStringList columns;
|
QStringList columns;
|
||||||
QString timeStr = timeString(dt);
|
QString timeStr = timeString(dt);
|
||||||
QString longTimeStr = timeString(dt, QLocale::LongFormat);
|
QString longTimeStr = timeString(dt, QLocale::LongFormat);
|
||||||
@@ -112,22 +115,47 @@ void ItemProgressDialog::setSyncResult( const SyncResult& result )
|
|||||||
columns << timeStr;
|
columns << timeStr;
|
||||||
columns << item._file;
|
columns << item._file;
|
||||||
columns << folder;
|
columns << folder;
|
||||||
if( item._type == SyncFileItem::File ) {
|
if( item._instruction == CSYNC_INSTRUCTION_IGNORE) {
|
||||||
errMsg = tr("File ignored.");
|
if( item._type == SyncFileItem::SoftLink ) {
|
||||||
} else if( item._type == SyncFileItem::Directory ){
|
errMsg = tr("Soft Link ignored");
|
||||||
errMsg = tr("Directory ignored.");
|
tooltip = tr("Softlinks break the semantics of synchronization.\nPlease do not "
|
||||||
} else if( item._type == SyncFileItem::SoftLink ) {
|
"use them in synced directories");
|
||||||
errMsg = tr("Soft Link ignored.");
|
} else {
|
||||||
|
QString obj = tr("file");
|
||||||
|
if( item._type == SyncFileItem::Directory ) {
|
||||||
|
obj = tr("directory");
|
||||||
|
}
|
||||||
|
tooltip = tr("The %1 was ignored because it is listed in the clients ignore list\n"
|
||||||
|
"or the %1 name contains characters that are not syncable\nin a cross platform "
|
||||||
|
"environment").arg(obj);
|
||||||
|
errMsg = tr("Item ignored");
|
||||||
|
if( item._errorString == QLatin1String("File listed on ignore list.") ) {
|
||||||
|
errMsg = tr("%1 on ignore list").arg(obj);
|
||||||
|
tooltip = tr("The %1 was skipped because it is listed on the clients\n"
|
||||||
|
"list of names to ignore").arg(obj);
|
||||||
|
} else if( item._errorString == QLatin1String("File contains invalid characters.") ) {
|
||||||
|
errMsg = tr("Invalid characters");
|
||||||
|
tooltip = tr("The %1 name contains one or more invalid characters which break\n"
|
||||||
|
"syncing in a cross platform environment").arg(obj);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if( item._instruction == CSYNC_INSTRUCTION_CONFLICT ) {
|
||||||
|
errMsg = tr("Conflict file.");
|
||||||
|
tooltip = tr("The file was changed on server and local repository and as a result it\n"
|
||||||
|
"created a so called conflict. The local change is copied to the conflict\n"
|
||||||
|
"file while the file from the server side is available under the original\n"
|
||||||
|
"name");
|
||||||
} else {
|
} else {
|
||||||
errMsg = tr("Ignored.");
|
Q_ASSERT(!"unhandled instruction.");
|
||||||
}
|
}
|
||||||
columns << errMsg;
|
columns << errMsg;
|
||||||
|
|
||||||
QTreeWidgetItem *twitem = new QTreeWidgetItem(columns);
|
QTreeWidgetItem *twitem = new QTreeWidgetItem(columns);
|
||||||
twitem->setData(0, ErrorIndicatorRole, QVariant(true) );
|
twitem->setData(0, ErrorIndicatorRole, QVariant(true) );
|
||||||
twitem->setToolTip(0, longTimeStr);
|
twitem->setToolTip(0, longTimeStr);
|
||||||
|
twitem->setToolTip(3, tooltip);
|
||||||
twitem->setIcon(0, Theme::instance()->syncStateIcon(SyncResult::Problem, true));
|
twitem->setIcon(0, Theme::instance()->syncStateIcon(SyncResult::Problem, true));
|
||||||
_ui->_treeWidget->addTopLevelItem(twitem);
|
_ui->_treeWidget->insertTopLevelItem(0, twitem);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -181,28 +209,22 @@ void ItemProgressDialog::copyToClipboard()
|
|||||||
|
|
||||||
int topLevelItems = _ui->_treeWidget->topLevelItemCount();
|
int topLevelItems = _ui->_treeWidget->topLevelItemCount();
|
||||||
for (int i = 0; i < topLevelItems; i++) {
|
for (int i = 0; i < topLevelItems; i++) {
|
||||||
QTreeWidgetItem *item = _ui->_treeWidget->topLevelItem(i);
|
QTreeWidgetItem *child = _ui->_treeWidget->topLevelItem(i);
|
||||||
ts << left << qSetFieldWidth(0)
|
// time stamp
|
||||||
<< item->data(0, Qt::DisplayRole).toString()
|
ts << left << qSetFieldWidth(10)
|
||||||
<< endl;
|
<< child->data(0,Qt::DisplayRole).toString()
|
||||||
int childItems = item->childCount();
|
// file name
|
||||||
for (int j = 0; j < childItems; j++) {
|
<< qSetFieldWidth(64)
|
||||||
QTreeWidgetItem *child =item->child(j);
|
<< child->data(1,Qt::DisplayRole).toString()
|
||||||
// time stamp
|
<< qSetFieldWidth(0) << ' '
|
||||||
ts << left << qSetFieldWidth(10)
|
// action
|
||||||
<< child->data(0,Qt::DisplayRole).toString()
|
<< qSetFieldWidth(15)
|
||||||
// file name
|
<< child->data(3, Qt::DisplayRole).toString()
|
||||||
<< qSetFieldWidth(50)
|
// size
|
||||||
<< child->data(1,Qt::DisplayRole).toString()
|
<< qSetFieldWidth(10)
|
||||||
// action
|
<< child->data(4, Qt::DisplayRole).toString()
|
||||||
<< qSetFieldWidth(15)
|
<< qSetFieldWidth(0)
|
||||||
<< child->data(2, Qt::DisplayRole).toString()
|
<< endl;
|
||||||
// size
|
|
||||||
<< qSetFieldWidth(10)
|
|
||||||
<< child->data(3, Qt::DisplayRole).toString()
|
|
||||||
<< qSetFieldWidth(0)
|
|
||||||
<< endl;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QApplication::clipboard()->setText(text);
|
QApplication::clipboard()->setText(text);
|
||||||
@@ -272,7 +294,7 @@ void ItemProgressDialog::slotProgressErrors( const QString& folder, const Progre
|
|||||||
// by error_code. A quota problem is considered an error, others might not??
|
// by error_code. A quota problem is considered an error, others might not??
|
||||||
item->setIcon(0, Theme::instance()->syncStateIcon(SyncResult::Error, true));
|
item->setIcon(0, Theme::instance()->syncStateIcon(SyncResult::Error, true));
|
||||||
item->setToolTip(0, longTimeStr);
|
item->setToolTip(0, longTimeStr);
|
||||||
_ui->_treeWidget->addTopLevelItem(item);
|
_ui->_treeWidget->insertTopLevelItem(0, item);
|
||||||
Q_UNUSED(item);
|
Q_UNUSED(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -303,7 +325,7 @@ void ItemProgressDialog::slotProgressInfo( const QString& folder, const Progress
|
|||||||
|
|
||||||
QTreeWidgetItem *item = new QTreeWidgetItem(columns);
|
QTreeWidgetItem *item = new QTreeWidgetItem(columns);
|
||||||
item->setToolTip(0, longTimeStr);
|
item->setToolTip(0, longTimeStr);
|
||||||
_ui->_treeWidget->addTopLevelItem(item);
|
_ui->_treeWidget->insertTopLevelItem(0, item);
|
||||||
Q_UNUSED(item);
|
Q_UNUSED(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -39,9 +39,6 @@
|
|||||||
<property name="uniformRowHeights">
|
<property name="uniformRowHeights">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
</property>
|
</property>
|
||||||
<property name="sortingEnabled">
|
|
||||||
<bool>true</bool>
|
|
||||||
</property>
|
|
||||||
<property name="columnCount">
|
<property name="columnCount">
|
||||||
<number>4</number>
|
<number>4</number>
|
||||||
</property>
|
</property>
|
||||||
|
|||||||
@@ -128,11 +128,15 @@ LogBrowser::LogBrowser(QWidget *parent) :
|
|||||||
|
|
||||||
LogBrowser::~LogBrowser()
|
LogBrowser::~LogBrowser()
|
||||||
{
|
{
|
||||||
|
MirallConfigFile cfg;
|
||||||
|
cfg.saveGeometry(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void LogBrowser::slotNewLog( const QString& msg )
|
void LogBrowser::slotNewLog( const QString& msg )
|
||||||
{
|
{
|
||||||
_logWidget->appendPlainText( msg );
|
if( _logWidget->isVisible() ) {
|
||||||
|
_logWidget->appendPlainText( msg );
|
||||||
|
}
|
||||||
|
|
||||||
if( _logstream ) {
|
if( _logstream ) {
|
||||||
(*_logstream) << msg << endl;
|
(*_logstream) << msg << endl;
|
||||||
@@ -225,11 +229,4 @@ void LogBrowser::slotClearLog()
|
|||||||
_logWidget->clear();
|
_logWidget->clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void LogBrowser::closeEvent(QCloseEvent *event)
|
|
||||||
{
|
|
||||||
MirallConfigFile cfg;
|
|
||||||
cfg.saveGeometry(this);
|
|
||||||
QWidget::closeEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|||||||
@@ -47,9 +47,6 @@ public:
|
|||||||
|
|
||||||
void setLogFile(const QString& , bool );
|
void setLogFile(const QString& , bool );
|
||||||
|
|
||||||
protected:
|
|
||||||
void closeEvent(QCloseEvent *event);
|
|
||||||
|
|
||||||
protected slots:
|
protected slots:
|
||||||
void slotNewLog( const QString &msg );
|
void slotNewLog( const QString &msg );
|
||||||
void slotFind();
|
void slotFind();
|
||||||
|
|||||||
@@ -193,7 +193,7 @@ QString MirallConfigFile::excludeFile(Scope scope) const
|
|||||||
fi.setFile( QApplication::applicationDirPath(), exclFile );
|
fi.setFile( QApplication::applicationDirPath(), exclFile );
|
||||||
#endif
|
#endif
|
||||||
#ifdef Q_OS_UNIX
|
#ifdef Q_OS_UNIX
|
||||||
fi.setFile( QString("/etc/%1").arg(Theme::instance()->appName()), exclFile );
|
fi.setFile( QString( SYSCONFDIR "/%1").arg(Theme::instance()->appName()), exclFile );
|
||||||
#endif
|
#endif
|
||||||
#ifdef Q_OS_MAC
|
#ifdef Q_OS_MAC
|
||||||
// exec path is inside the bundle
|
// exec path is inside the bundle
|
||||||
@@ -595,7 +595,7 @@ QString MirallConfigFile::proxyPassword() const
|
|||||||
|
|
||||||
int MirallConfigFile::useUploadLimit() const
|
int MirallConfigFile::useUploadLimit() const
|
||||||
{
|
{
|
||||||
return getValue(useUploadLimitC, QString::null, -1).toInt();
|
return getValue(useUploadLimitC, QString::null, 0).toInt();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MirallConfigFile::useDownloadLimit() const
|
bool MirallConfigFile::useDownloadLimit() const
|
||||||
|
|||||||
@@ -113,7 +113,7 @@ void NetworkSettings::loadBWLimitSettings()
|
|||||||
if ( uploadLimit >= 1 ) {
|
if ( uploadLimit >= 1 ) {
|
||||||
_ui->uploadLimitRadioButton->setChecked(true);
|
_ui->uploadLimitRadioButton->setChecked(true);
|
||||||
} else if (uploadLimit == 0){
|
} else if (uploadLimit == 0){
|
||||||
_ui->noDownloadLimitRadioButton->setChecked(true);
|
_ui->noUploadLimitRadioButton->setChecked(true);
|
||||||
} else {
|
} else {
|
||||||
_ui->autoUploadLimitRadioButton->setChecked(true);
|
_ui->autoUploadLimitRadioButton->setChecked(true);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -229,7 +229,7 @@
|
|||||||
<item row="0" column="0" colspan="2">
|
<item row="0" column="0" colspan="2">
|
||||||
<widget class="QRadioButton" name="noDownloadLimitRadioButton">
|
<widget class="QRadioButton" name="noDownloadLimitRadioButton">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>No Limit</string>
|
<string>No limit</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="checked">
|
<property name="checked">
|
||||||
<bool>true</bool>
|
<bool>true</bool>
|
||||||
@@ -254,6 +254,12 @@
|
|||||||
</item>
|
</item>
|
||||||
<item row="1" column="1">
|
<item row="1" column="1">
|
||||||
<widget class="QGroupBox" name="groupBox_2">
|
<widget class="QGroupBox" name="groupBox_2">
|
||||||
|
<property name="sizePolicy">
|
||||||
|
<sizepolicy hsizetype="MinimumExpanding" vsizetype="Preferred">
|
||||||
|
<horstretch>0</horstretch>
|
||||||
|
<verstretch>0</verstretch>
|
||||||
|
</sizepolicy>
|
||||||
|
</property>
|
||||||
<property name="title">
|
<property name="title">
|
||||||
<string>Upload Bandwidth</string>
|
<string>Upload Bandwidth</string>
|
||||||
</property>
|
</property>
|
||||||
@@ -261,7 +267,7 @@
|
|||||||
<item row="0" column="0" colspan="2">
|
<item row="0" column="0" colspan="2">
|
||||||
<widget class="QRadioButton" name="noUploadLimitRadioButton">
|
<widget class="QRadioButton" name="noUploadLimitRadioButton">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>No Limit</string>
|
<string>No limit</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
|
|||||||
@@ -138,7 +138,10 @@ QNetworkReply* ownCloudInfo::mkdirRequest( const QString& dir )
|
|||||||
qDebug() << "OCInfo Making dir " << dir;
|
qDebug() << "OCInfo Making dir " << dir;
|
||||||
_authAttempts = 0;
|
_authAttempts = 0;
|
||||||
QNetworkRequest req;
|
QNetworkRequest req;
|
||||||
req.setUrl( QUrl( webdavUrl(_connection) + dir ) );
|
QUrl url = QUrl(webdavUrl(_connection));
|
||||||
|
url.setEncodedPath(url.encodedPath()+QUrl::toPercentEncoding(dir, "/"));
|
||||||
|
|
||||||
|
req.setUrl( url );
|
||||||
QNetworkReply *reply = davRequest("MKCOL", req, 0);
|
QNetworkReply *reply = davRequest("MKCOL", req, 0);
|
||||||
|
|
||||||
// remember the confighandle used for this request
|
// remember the confighandle used for this request
|
||||||
@@ -234,8 +237,9 @@ void ownCloudInfo::slotGetQuotaFinished()
|
|||||||
{
|
{
|
||||||
bool ok = false;
|
bool ok = false;
|
||||||
QNetworkReply *reply = qobject_cast<QNetworkReply *>(sender());
|
QNetworkReply *reply = qobject_cast<QNetworkReply *>(sender());
|
||||||
|
int http_result_code = reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
|
||||||
|
|
||||||
if (reply->attribute(QNetworkRequest::HttpStatusCodeAttribute) == 207) {
|
if (http_result_code == 207) {
|
||||||
// Parse DAV response
|
// Parse DAV response
|
||||||
QXmlStreamReader reader(reply);
|
QXmlStreamReader reader(reply);
|
||||||
reader.addExtraNamespaceDeclaration(QXmlStreamNamespaceDeclaration("d", "DAV:"));
|
reader.addExtraNamespaceDeclaration(QXmlStreamNamespaceDeclaration("d", "DAV:"));
|
||||||
@@ -268,6 +272,7 @@ void ownCloudInfo::slotGetQuotaFinished()
|
|||||||
emit quotaUpdated(total, quotaUsedBytes);
|
emit quotaUpdated(total, quotaUsedBytes);
|
||||||
_lastEtag = etag;
|
_lastEtag = etag;
|
||||||
} else {
|
} else {
|
||||||
|
qDebug() << "Quota request *not* successful, http result code is " << http_result_code;
|
||||||
_lastQuotaTotalBytes = 0;
|
_lastQuotaTotalBytes = 0;
|
||||||
_lastQuotaUsedBytes = 0;
|
_lastQuotaUsedBytes = 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -47,8 +47,11 @@ OwncloudSetupWizard::OwncloudSetupWizard(QObject* parent) :
|
|||||||
this, SLOT(slotConnectToOCUrl( const QString& )));
|
this, SLOT(slotConnectToOCUrl( const QString& )));
|
||||||
connect( _ocWizard, SIGNAL(createLocalAndRemoteFolders(QString, QString)),
|
connect( _ocWizard, SIGNAL(createLocalAndRemoteFolders(QString, QString)),
|
||||||
this, SLOT(slotCreateLocalAndRemoteFolders(QString, QString)));
|
this, SLOT(slotCreateLocalAndRemoteFolders(QString, QString)));
|
||||||
connect( _ocWizard, SIGNAL(finished(int)),this,SLOT(slotAssistantFinished(int)));
|
/* basicSetupFinished might be called from a reply from the network.
|
||||||
|
slotAssistantFinished might destroy the temporary QNetworkAccessManager.
|
||||||
|
Therefore Qt::QueuedConnection is required */
|
||||||
|
connect( _ocWizard, SIGNAL(basicSetupFinished(int)),
|
||||||
|
this, SLOT(slotAssistantFinished(int)), Qt::QueuedConnection);
|
||||||
connect( _ocWizard, SIGNAL(clearPendingRequests()),
|
connect( _ocWizard, SIGNAL(clearPendingRequests()),
|
||||||
this, SLOT(slotClearPendingRequests()));
|
this, SLOT(slotClearPendingRequests()));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -33,15 +33,6 @@ ownCloudTheme::ownCloudTheme()
|
|||||||
// qDebug() << " ** running ownCloud theme!";
|
// qDebug() << " ** running ownCloud theme!";
|
||||||
}
|
}
|
||||||
|
|
||||||
QString ownCloudTheme::appName() const
|
|
||||||
{
|
|
||||||
/* If this is changed, existing configs are not found any more
|
|
||||||
* because the value is used by QDesktopServices to find the config
|
|
||||||
* file. Be aware.
|
|
||||||
*/
|
|
||||||
return QLatin1String("ownCloud");
|
|
||||||
}
|
|
||||||
|
|
||||||
QString ownCloudTheme::configFileName() const
|
QString ownCloudTheme::configFileName() const
|
||||||
{
|
{
|
||||||
return QLatin1String("owncloud.cfg");
|
return QLatin1String("owncloud.cfg");
|
||||||
|
|||||||
@@ -25,7 +25,6 @@ class ownCloudTheme : public Theme
|
|||||||
public:
|
public:
|
||||||
ownCloudTheme();
|
ownCloudTheme();
|
||||||
|
|
||||||
virtual QString appName() const;
|
|
||||||
QString configFileName() const;
|
QString configFileName() const;
|
||||||
QString about() const;
|
QString about() const;
|
||||||
QPixmap splashScreen() const;
|
QPixmap splashScreen() const;
|
||||||
|
|||||||
@@ -16,7 +16,7 @@
|
|||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QMetaType>
|
#include <QMetaType>
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
|
#include <QCoreApplication>
|
||||||
|
|
||||||
namespace Mirall {
|
namespace Mirall {
|
||||||
|
|
||||||
@@ -28,35 +28,35 @@ QString Progress::asResultString( Kind kind )
|
|||||||
switch(kind) {
|
switch(kind) {
|
||||||
case Download:
|
case Download:
|
||||||
case EndDownload:
|
case EndDownload:
|
||||||
re = QObject::tr("Download");
|
re = QCoreApplication::translate( "progress", "Download");
|
||||||
break;
|
break;
|
||||||
case Upload:
|
case Upload:
|
||||||
re = QObject::tr("Upload");
|
re = QCoreApplication::translate( "progress", "Upload");
|
||||||
break;
|
break;
|
||||||
case Context:
|
case Context:
|
||||||
re = QObject::tr("Context");
|
re = QCoreApplication::translate( "progress", "Context" );
|
||||||
break;
|
break;
|
||||||
case Inactive:
|
case Inactive:
|
||||||
re = QObject::tr("Inactive");
|
re = QCoreApplication::translate( "progress", "Inactive");
|
||||||
break;
|
break;
|
||||||
case StartDownload:
|
case StartDownload:
|
||||||
re = QObject::tr("Download");
|
re = QCoreApplication::translate( "progress", "Download");
|
||||||
break;
|
break;
|
||||||
case StartUpload:
|
case StartUpload:
|
||||||
case EndUpload:
|
case EndUpload:
|
||||||
re = QObject::tr("Upload");
|
re = QCoreApplication::translate( "progress", "Upload");
|
||||||
break;
|
break;
|
||||||
case StartSync:
|
case StartSync:
|
||||||
re = QObject::tr("Start");
|
re = QCoreApplication::translate( "progress", "Start");
|
||||||
break;
|
break;
|
||||||
case EndSync:
|
case EndSync:
|
||||||
re = QObject::tr("Finished");
|
re = QCoreApplication::translate( "progress", "Finished");
|
||||||
break;
|
break;
|
||||||
case StartDelete:
|
case StartDelete:
|
||||||
re = QObject::tr("For deletion");
|
re = QCoreApplication::translate( "progress", "For deletion");
|
||||||
break;
|
break;
|
||||||
case EndDelete:
|
case EndDelete:
|
||||||
re = QObject::tr("deleted");
|
re = QCoreApplication::translate( "progress", "deleted");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
Q_ASSERT(false);
|
Q_ASSERT(false);
|
||||||
@@ -71,40 +71,40 @@ QString Progress::asActionString( Kind kind )
|
|||||||
|
|
||||||
switch(kind) {
|
switch(kind) {
|
||||||
case Download:
|
case Download:
|
||||||
re = QObject::tr("downloading");
|
re = QCoreApplication::translate( "progress", "downloading");
|
||||||
break;
|
break;
|
||||||
case Upload:
|
case Upload:
|
||||||
re = QObject::tr("uploading");
|
re = QCoreApplication::translate( "progress", "uploading");
|
||||||
break;
|
break;
|
||||||
case Context:
|
case Context:
|
||||||
re = QObject::tr("Context");
|
re = QCoreApplication::translate( "progress", "Context");
|
||||||
break;
|
break;
|
||||||
case Inactive:
|
case Inactive:
|
||||||
re = QObject::tr("inactive");
|
re = QCoreApplication::translate( "progress", "inactive");
|
||||||
break;
|
break;
|
||||||
case StartDownload:
|
case StartDownload:
|
||||||
re = QObject::tr("downloading");
|
re = QCoreApplication::translate( "progress", "downloading");
|
||||||
break;
|
break;
|
||||||
case StartUpload:
|
case StartUpload:
|
||||||
re = QObject::tr("uploading");
|
re = QCoreApplication::translate( "progress", "uploading");
|
||||||
break;
|
break;
|
||||||
case EndDownload:
|
case EndDownload:
|
||||||
re = QObject::tr("downloading");
|
re = QCoreApplication::translate( "progress", "downloading");
|
||||||
break;
|
break;
|
||||||
case EndUpload:
|
case EndUpload:
|
||||||
re = QObject::tr("uploading");
|
re = QCoreApplication::translate( "progress", "uploading");
|
||||||
break;
|
break;
|
||||||
case StartSync:
|
case StartSync:
|
||||||
re = QObject::tr("starting");
|
re = QCoreApplication::translate( "progress", "starting");
|
||||||
break;
|
break;
|
||||||
case EndSync:
|
case EndSync:
|
||||||
re = QObject::tr("finished");
|
re = QCoreApplication::translate( "progress", "finished");
|
||||||
break;
|
break;
|
||||||
case StartDelete:
|
case StartDelete:
|
||||||
re = QObject::tr("delete");
|
re = QCoreApplication::translate( "progress", "delete");
|
||||||
break;
|
break;
|
||||||
case EndDelete:
|
case EndDelete:
|
||||||
re = QObject::tr("deleted");
|
re = QCoreApplication::translate( "progress", "deleted");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
Q_ASSERT(false);
|
Q_ASSERT(false);
|
||||||
@@ -121,7 +121,7 @@ ProgressDispatcher* ProgressDispatcher::instance() {
|
|||||||
|
|
||||||
ProgressDispatcher::ProgressDispatcher(QObject *parent) :
|
ProgressDispatcher::ProgressDispatcher(QObject *parent) :
|
||||||
QObject(parent),
|
QObject(parent),
|
||||||
_problemQueueSize(50)
|
_QueueSize(50)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -163,9 +163,9 @@ void ProgressDispatcher::setProgressInfo(const QString& folder, const Progress::
|
|||||||
err.error_code = newProgress.current_file_bytes;
|
err.error_code = newProgress.current_file_bytes;
|
||||||
err.timestamp = QDateTime::currentDateTime();
|
err.timestamp = QDateTime::currentDateTime();
|
||||||
|
|
||||||
_recentProblems.enqueue( err );
|
_recentProblems.prepend( err );
|
||||||
if( _recentProblems.size() > _problemQueueSize ) {
|
if( _recentProblems.size() > _QueueSize ) {
|
||||||
_recentProblems.dequeue();
|
_recentProblems.removeLast();
|
||||||
}
|
}
|
||||||
emit progressSyncProblem( folder, err );
|
emit progressSyncProblem( folder, err );
|
||||||
} else {
|
} else {
|
||||||
@@ -180,7 +180,10 @@ void ProgressDispatcher::setProgressInfo(const QString& folder, const Progress::
|
|||||||
if( newProgress.kind == Progress::EndDownload ||
|
if( newProgress.kind == Progress::EndDownload ||
|
||||||
newProgress.kind == Progress::EndUpload ||
|
newProgress.kind == Progress::EndUpload ||
|
||||||
newProgress.kind == Progress::EndDelete ) {
|
newProgress.kind == Progress::EndDelete ) {
|
||||||
_recentChanges.enqueue(newProgress);
|
_recentChanges.prepend(newProgress);
|
||||||
|
if( _recentChanges.size() > _QueueSize ) {
|
||||||
|
_recentChanges.removeLast();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// store the last real action to help clients that start during
|
// store the last real action to help clients that start during
|
||||||
// the Context-phase of an upload or download.
|
// the Context-phase of an upload or download.
|
||||||
|
|||||||
@@ -25,9 +25,8 @@ namespace Mirall {
|
|||||||
/**
|
/**
|
||||||
* @brief The FolderScheduler class schedules folders for sync
|
* @brief The FolderScheduler class schedules folders for sync
|
||||||
*/
|
*/
|
||||||
class Progress
|
namespace Progress
|
||||||
{
|
{
|
||||||
public:
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
Invalid,
|
Invalid,
|
||||||
StartSync,
|
StartSync,
|
||||||
@@ -69,9 +68,9 @@ public:
|
|||||||
QDateTime timestamp;
|
QDateTime timestamp;
|
||||||
} SyncProblem;
|
} SyncProblem;
|
||||||
|
|
||||||
static QString asActionString( Kind );
|
QString asActionString( Kind );
|
||||||
static QString asResultString( Kind );
|
QString asResultString( Kind );
|
||||||
};
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @file progressdispatcher.h
|
* @file progressdispatcher.h
|
||||||
@@ -112,9 +111,9 @@ protected:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
ProgressDispatcher(QObject* parent = 0);
|
ProgressDispatcher(QObject* parent = 0);
|
||||||
const int _problemQueueSize;
|
const int _QueueSize;
|
||||||
QQueue<Progress::Info> _recentChanges;
|
QList<Progress::Info> _recentChanges;
|
||||||
QQueue<Progress::SyncProblem> _recentProblems;
|
QList<Progress::SyncProblem> _recentProblems;
|
||||||
|
|
||||||
QHash<QString, Progress::Kind> _currentAction;
|
QHash<QString, Progress::Kind> _currentAction;
|
||||||
static ProgressDispatcher* _instance;
|
static ProgressDispatcher* _instance;
|
||||||
|
|||||||
@@ -48,6 +48,10 @@ SettingsDialog::SettingsDialog(Application *app, QWidget *parent) :
|
|||||||
|
|
||||||
setWindowTitle(tr("%1").arg(Theme::instance()->appNameGUI()));
|
setWindowTitle(tr("%1").arg(Theme::instance()->appNameGUI()));
|
||||||
|
|
||||||
|
_accountSettings = new AccountSettings(this);
|
||||||
|
addAccount(tr("Account"), _accountSettings);
|
||||||
|
slotUpdateAccountState();
|
||||||
|
|
||||||
QIcon generalIcon(QLatin1String(":/mirall/resources/settings.png"));
|
QIcon generalIcon(QLatin1String(":/mirall/resources/settings.png"));
|
||||||
QListWidgetItem *general = new QListWidgetItem(generalIcon, tr("General"), _ui->labelWidget);
|
QListWidgetItem *general = new QListWidgetItem(generalIcon, tr("General"), _ui->labelWidget);
|
||||||
general->setSizeHint(QSize(0, 32));
|
general->setSizeHint(QSize(0, 32));
|
||||||
@@ -62,14 +66,9 @@ SettingsDialog::SettingsDialog(Application *app, QWidget *parent) :
|
|||||||
NetworkSettings *networkSettings = new NetworkSettings;
|
NetworkSettings *networkSettings = new NetworkSettings;
|
||||||
_ui->stack->addWidget(networkSettings);
|
_ui->stack->addWidget(networkSettings);
|
||||||
connect(networkSettings, SIGNAL(proxySettingsChanged()), app, SLOT(slotSetupProxy()));
|
connect(networkSettings, SIGNAL(proxySettingsChanged()), app, SLOT(slotSetupProxy()));
|
||||||
connect(networkSettings, SIGNAL(proxySettingsChanged()), FolderMan::instance(), SLOT(slotScheduleAllFolders()));
|
|
||||||
|
|
||||||
//connect(generalSettings, SIGNAL(resizeToSizeHint()), SLOT(resizeToSizeHint()));
|
//connect(generalSettings, SIGNAL(resizeToSizeHint()), SLOT(resizeToSizeHint()));
|
||||||
|
|
||||||
_accountSettings = new AccountSettings(this);
|
|
||||||
addAccount(tr("Account"), _accountSettings);
|
|
||||||
slotUpdateAccountState();
|
|
||||||
|
|
||||||
connect( app, SIGNAL(folderStateChanged(Folder*)), _accountSettings, SLOT(slotUpdateFolderState(Folder*)));
|
connect( app, SIGNAL(folderStateChanged(Folder*)), _accountSettings, SLOT(slotUpdateFolderState(Folder*)));
|
||||||
connect( app, SIGNAL(folderStateChanged(Folder*)), SLOT(slotUpdateAccountState()));
|
connect( app, SIGNAL(folderStateChanged(Folder*)), SLOT(slotUpdateAccountState()));
|
||||||
|
|
||||||
@@ -83,7 +82,7 @@ SettingsDialog::SettingsDialog(Application *app, QWidget *parent) :
|
|||||||
connect( ProgressDispatcher::instance(), SIGNAL(progressSyncProblem(QString,Progress::SyncProblem)),
|
connect( ProgressDispatcher::instance(), SIGNAL(progressSyncProblem(QString,Progress::SyncProblem)),
|
||||||
_accountSettings, SLOT(slotProgressProblem(QString,Progress::SyncProblem)) );
|
_accountSettings, SLOT(slotProgressProblem(QString,Progress::SyncProblem)) );
|
||||||
|
|
||||||
_ui->labelWidget->setCurrentRow(_ui->labelWidget->row(general));
|
_ui->labelWidget->setCurrentRow(_ui->labelWidget->row(_accountItem));
|
||||||
|
|
||||||
connect(_ui->labelWidget, SIGNAL(currentRowChanged(int)),
|
connect(_ui->labelWidget, SIGNAL(currentRowChanged(int)),
|
||||||
_ui->stack, SLOT(setCurrentIndex(int)));
|
_ui->stack, SLOT(setCurrentIndex(int)));
|
||||||
@@ -102,6 +101,9 @@ SettingsDialog::SettingsDialog(Application *app, QWidget *parent) :
|
|||||||
|
|
||||||
SettingsDialog::~SettingsDialog()
|
SettingsDialog::~SettingsDialog()
|
||||||
{
|
{
|
||||||
|
MirallConfigFile cfg;
|
||||||
|
cfg.saveGeometry(this);
|
||||||
|
|
||||||
delete _ui;
|
delete _ui;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -114,13 +116,6 @@ void SettingsDialog::addAccount(const QString &title, QWidget *widget)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SettingsDialog::closeEvent(QCloseEvent *event)
|
|
||||||
{
|
|
||||||
MirallConfigFile cfg;
|
|
||||||
cfg.saveGeometry(this);
|
|
||||||
QWidget::closeEvent(event);
|
|
||||||
}
|
|
||||||
|
|
||||||
void SettingsDialog::slotUpdateAccountState()
|
void SettingsDialog::slotUpdateAccountState()
|
||||||
{
|
{
|
||||||
FolderMan *folderMan = FolderMan::instance();
|
FolderMan *folderMan = FolderMan::instance();
|
||||||
|
|||||||
@@ -41,9 +41,6 @@ public:
|
|||||||
|
|
||||||
void addAccount(const QString &title, QWidget *widget);
|
void addAccount(const QString &title, QWidget *widget);
|
||||||
|
|
||||||
protected:
|
|
||||||
void closeEvent(QCloseEvent *event);
|
|
||||||
|
|
||||||
protected slots:
|
protected slots:
|
||||||
void slotUpdateAccountState();
|
void slotUpdateAccountState();
|
||||||
|
|
||||||
|
|||||||
@@ -6,15 +6,24 @@
|
|||||||
<rect>
|
<rect>
|
||||||
<x>0</x>
|
<x>0</x>
|
||||||
<y>0</y>
|
<y>0</y>
|
||||||
<width>704</width>
|
<width>693</width>
|
||||||
<height>299</height>
|
<height>457</height>
|
||||||
</rect>
|
</rect>
|
||||||
</property>
|
</property>
|
||||||
<property name="windowTitle">
|
<property name="windowTitle">
|
||||||
<string>Settings</string>
|
<string>Settings</string>
|
||||||
</property>
|
</property>
|
||||||
<layout class="QGridLayout" name="gridLayout">
|
<layout class="QGridLayout" name="gridLayout">
|
||||||
<property name="margin">
|
<property name="leftMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="topMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="rightMargin">
|
||||||
|
<number>0</number>
|
||||||
|
</property>
|
||||||
|
<property name="bottomMargin">
|
||||||
<number>0</number>
|
<number>0</number>
|
||||||
</property>
|
</property>
|
||||||
<property name="spacing">
|
<property name="spacing">
|
||||||
|
|||||||
@@ -45,35 +45,45 @@ QString Theme::statusHeaderText( SyncResult::Status status ) const
|
|||||||
|
|
||||||
switch( status ) {
|
switch( status ) {
|
||||||
case SyncResult::Undefined:
|
case SyncResult::Undefined:
|
||||||
resultStr = QObject::tr("Status undefined");
|
resultStr = QCoreApplication::translate("theme", "Status undefined");
|
||||||
break;
|
break;
|
||||||
case SyncResult::NotYetStarted:
|
case SyncResult::NotYetStarted:
|
||||||
resultStr = QObject::tr("Waiting to start sync");
|
resultStr = QCoreApplication::translate("theme", "Waiting to start sync");
|
||||||
break;
|
break;
|
||||||
case SyncResult::SyncRunning:
|
case SyncResult::SyncRunning:
|
||||||
resultStr = QObject::tr("Sync is running");
|
resultStr = QCoreApplication::translate("theme", "Sync is running");
|
||||||
break;
|
break;
|
||||||
case SyncResult::Success:
|
case SyncResult::Success:
|
||||||
resultStr = QObject::tr("Sync Success");
|
resultStr = QCoreApplication::translate("theme", "Sync Success");
|
||||||
break;
|
break;
|
||||||
case SyncResult::Problem:
|
case SyncResult::Problem:
|
||||||
resultStr = QObject::tr("Sync Success, problems with individual files.");
|
resultStr = QCoreApplication::translate("theme", "Sync Success, problems with individual files.");
|
||||||
break;
|
break;
|
||||||
case SyncResult::Error:
|
case SyncResult::Error:
|
||||||
resultStr = QObject::tr("Sync Error - Click info button for details.");
|
resultStr = QCoreApplication::translate("theme", "Sync Error - Click info button for details.");
|
||||||
break;
|
break;
|
||||||
case SyncResult::SetupError:
|
case SyncResult::SetupError:
|
||||||
resultStr = QObject::tr( "Setup Error" );
|
resultStr = QCoreApplication::translate("theme", "Setup Error" );
|
||||||
break;
|
break;
|
||||||
default:
|
case SyncResult::Unavailable:
|
||||||
resultStr = QObject::tr("Status undefined");
|
resultStr = QCoreApplication::translate("theme", "The server is currently unavailable" );
|
||||||
|
break;
|
||||||
|
case SyncResult::SyncPrepare:
|
||||||
|
resultStr = QCoreApplication::translate("theme", "Preparing to sync" );
|
||||||
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
return resultStr;
|
return resultStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString Theme::appNameGUI() const
|
QString Theme::appNameGUI() const
|
||||||
{
|
{
|
||||||
return appName();
|
return QLatin1String(APPLICATION_NAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString Theme::appName() const
|
||||||
|
{
|
||||||
|
return QLatin1String(APPLICATION_SHORTNAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString Theme::version() const
|
QString Theme::version() const
|
||||||
|
|||||||
@@ -48,7 +48,8 @@ public:
|
|||||||
* Use and redefine this if the human readable name contains spaces,
|
* Use and redefine this if the human readable name contains spaces,
|
||||||
* special chars and such.
|
* special chars and such.
|
||||||
*
|
*
|
||||||
* By default, appName() is returned.
|
* By default, the name is derived from the APPLICATION_NAME
|
||||||
|
* cmake variable.
|
||||||
*
|
*
|
||||||
* @return QString with human readable app name.
|
* @return QString with human readable app name.
|
||||||
*/
|
*/
|
||||||
@@ -61,9 +62,16 @@ public:
|
|||||||
* it is used for config files etc. If you need a more sophisticated
|
* it is used for config files etc. If you need a more sophisticated
|
||||||
* name in the GUI, redefine appNameGUI.
|
* name in the GUI, redefine appNameGUI.
|
||||||
*
|
*
|
||||||
|
* By default, the name is derived from the APPLICATION_SHORTNAME
|
||||||
|
* cmake variable, and should be the same. This method is only
|
||||||
|
* reimplementable for legacy reasons.
|
||||||
|
*
|
||||||
|
* Warning: Do not modify this value, as many things, e.g. settings
|
||||||
|
* depend on it! You most likely want to modify \ref appNameGUI().
|
||||||
|
*
|
||||||
* @return QString with app name.
|
* @return QString with app name.
|
||||||
*/
|
*/
|
||||||
virtual QString appName() const = 0;
|
virtual QString appName() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief configFileName
|
* @brief configFileName
|
||||||
|
|||||||
@@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
#include <QCoreApplication>
|
#include <QCoreApplication>
|
||||||
#include <QSettings>
|
#include <QSettings>
|
||||||
|
#include <QTextStream>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QUrl>
|
#include <QUrl>
|
||||||
@@ -102,33 +103,30 @@ void Utility::setupFavLink(const QString &folder)
|
|||||||
|
|
||||||
QString Utility::octetsToString( qint64 octets )
|
QString Utility::octetsToString( qint64 octets )
|
||||||
{
|
{
|
||||||
static const qint64 kb = 1024;
|
static const qint64 kb = 1000;
|
||||||
static const qint64 mb = 1024 * kb;
|
static const qint64 mb = 1000 * kb;
|
||||||
static const qint64 gb = 1024 * mb;
|
static const qint64 gb = 1000 * mb;
|
||||||
static const qint64 tb = 1024 * gb;
|
static const qint64 tb = 1000 * gb;
|
||||||
|
|
||||||
|
QString s;
|
||||||
|
qreal value = octets;
|
||||||
if (octets >= tb) {
|
if (octets >= tb) {
|
||||||
if (octets < 10*tb) {
|
s = QCoreApplication::translate("Utility", "%L1 TB");
|
||||||
return compactFormatDouble(qreal(octets)/qreal(tb), 1, QLatin1String("TB"));
|
value /= tb;
|
||||||
}
|
|
||||||
return QString::number(qRound64(qreal(octets)/qreal(tb))) + QLatin1String(" TB");
|
|
||||||
} else if (octets >= gb) {
|
} else if (octets >= gb) {
|
||||||
if (octets < 10*gb) {
|
s = QCoreApplication::translate("Utility", "%L1 GB");
|
||||||
return compactFormatDouble(qreal(octets)/qreal(gb), 1, QLatin1String("GB"));
|
value /= gb;
|
||||||
}
|
|
||||||
return QString::number(qRound64(qreal(octets)/qreal(gb))) + QLatin1String(" GB");
|
|
||||||
} else if (octets >= mb) {
|
} else if (octets >= mb) {
|
||||||
if (octets < 10*mb) {
|
s = QCoreApplication::translate("Utility", "%L1 MB");
|
||||||
return compactFormatDouble(qreal(octets)/qreal(mb), 1, QLatin1String("MB"));
|
value /= mb;
|
||||||
}
|
|
||||||
return QString::number(qRound64(qreal(octets)/qreal(mb))) + QLatin1String(" MB");
|
|
||||||
} else if (octets >= kb) {
|
} else if (octets >= kb) {
|
||||||
return QString::number(qRound64(qreal(octets)/qreal(kb))) + QLatin1String(" KB");
|
s = QCoreApplication::translate("Utility", "%L1 kB");
|
||||||
} else if (octets == 1){
|
value /= kb;
|
||||||
return QLatin1String("1 byte");
|
} else {
|
||||||
} else {
|
s = QCoreApplication::translate("Utility", "%L1 B");
|
||||||
return QString::number(octets) + QLatin1String(" bytes");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return (value > 9.95) ? s.arg(qRound(value)) : s.arg(value, 0, 'g', 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Qtified version of get_platforms() in csync_owncloud.c
|
// Qtified version of get_platforms() in csync_owncloud.c
|
||||||
@@ -286,16 +284,24 @@ void Utility::setLaunchOnStartup(const QString &appName, const QString& guiName,
|
|||||||
qDebug() << "Could not create autostart directory";
|
qDebug() << "Could not create autostart directory";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
QSettings desktopFile(desktopFileLocation, QSettings::IniFormat);
|
QFile iniFile(desktopFileLocation);
|
||||||
desktopFile.beginGroup("Desktop Entry");
|
if (!iniFile.open(QIODevice::WriteOnly)) {
|
||||||
desktopFile.setValue(QLatin1String("Name"), guiName);
|
qDebug() << "Could not write auto start entry" << desktopFileLocation;
|
||||||
desktopFile.setValue(QLatin1String("GenericName"), QLatin1String("File Synchronizer"));
|
return;
|
||||||
desktopFile.setValue(QLatin1String("Exec"), QCoreApplication::applicationFilePath());
|
}
|
||||||
desktopFile.setValue(QLatin1String("Terminal"), false);
|
QTextStream ts(&iniFile);
|
||||||
desktopFile.setValue(QLatin1String("Icon"), appName);
|
ts.setCodec("UTF-8");
|
||||||
desktopFile.setValue(QLatin1String("Categories"), QLatin1String("Network"));
|
ts << QLatin1String("[Desktop Entry]") << endl
|
||||||
desktopFile.setValue(QLatin1String("StartupNotify"), false);
|
<< QLatin1String("Name=") << guiName << endl
|
||||||
desktopFile.endGroup();
|
<< QLatin1String("GenericName=") << QLatin1String("File Synchronizer") << endl
|
||||||
|
<< QLatin1String("Exec=") << QCoreApplication::applicationFilePath() << endl
|
||||||
|
<< QLatin1String("Terminal=") << "false" << endl
|
||||||
|
<< QLatin1String("Icon=") << appName << endl
|
||||||
|
<< QLatin1String("Categories=") << QLatin1String("Network") << endl
|
||||||
|
<< QLatin1String("Type=") << QLatin1String("Application") << endl
|
||||||
|
<< QLatin1String("StartupNotify=") << "false" << endl
|
||||||
|
<< QLatin1String("X-GNOME-Autostart-enabled=") << "true" << endl
|
||||||
|
;
|
||||||
} else {
|
} else {
|
||||||
if (!QFile::remove(desktopFileLocation)) {
|
if (!QFile::remove(desktopFileLocation)) {
|
||||||
qDebug() << "Could not remove autostart desktop file";
|
qDebug() << "Could not remove autostart desktop file";
|
||||||
|
|||||||
@@ -54,6 +54,7 @@ OwncloudAdvancedSetupPage::OwncloudAdvancedSetupPage()
|
|||||||
setupCustomization();
|
setupCustomization();
|
||||||
|
|
||||||
connect( _ui.pbSelectLocalFolder, SIGNAL(clicked()), SLOT(slotSelectFolder()));
|
connect( _ui.pbSelectLocalFolder, SIGNAL(clicked()), SLOT(slotSelectFolder()));
|
||||||
|
setButtonText(QWizard::NextButton, tr("Connect..."));
|
||||||
}
|
}
|
||||||
|
|
||||||
void OwncloudAdvancedSetupPage::setupCustomization()
|
void OwncloudAdvancedSetupPage::setupCustomization()
|
||||||
|
|||||||
@@ -34,6 +34,9 @@
|
|||||||
<property name="alignment">
|
<property name="alignment">
|
||||||
<set>Qt::AlignCenter</set>
|
<set>Qt::AlignCenter</set>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="wordWrap">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
|
|||||||
@@ -108,6 +108,12 @@
|
|||||||
<property name="text">
|
<property name="text">
|
||||||
<string>TextLabel</string>
|
<string>TextLabel</string>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="alignment">
|
||||||
|
<set>Qt::AlignCenter</set>
|
||||||
|
</property>
|
||||||
|
<property name="wordWrap">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="4" column="0" colspan="3">
|
<item row="4" column="0" colspan="3">
|
||||||
@@ -121,7 +127,6 @@
|
|||||||
<zorder>horizontalSpacer</zorder>
|
<zorder>horizontalSpacer</zorder>
|
||||||
<zorder>verticalSpacer</zorder>
|
<zorder>verticalSpacer</zorder>
|
||||||
<zorder>horizontalSpacer_2</zorder>
|
<zorder>horizontalSpacer_2</zorder>
|
||||||
<zorder>horizontalLayoutWidget</zorder>
|
|
||||||
<zorder>topLabel</zorder>
|
<zorder>topLabel</zorder>
|
||||||
<zorder>bottomLabel</zorder>
|
<zorder>bottomLabel</zorder>
|
||||||
</widget>
|
</widget>
|
||||||
|
|||||||
@@ -46,11 +46,13 @@ OwncloudWizard::OwncloudWizard(QWidget *parent)
|
|||||||
_setupLog(),
|
_setupLog(),
|
||||||
_configExists(false)
|
_configExists(false)
|
||||||
{
|
{
|
||||||
setPage(WizardCommon::Page_ServerSetup, _setupPage );
|
setPage(WizardCommon::Page_ServerSetup, _setupPage);
|
||||||
setPage(WizardCommon::Page_HttpCreds, _httpCredsPage);
|
setPage(WizardCommon::Page_HttpCreds, _httpCredsPage);
|
||||||
setPage(WizardCommon::Page_ShibbolethCreds, _shibbolethCredsPage);
|
setPage(WizardCommon::Page_ShibbolethCreds, _shibbolethCredsPage);
|
||||||
setPage(WizardCommon::Page_AdvancedSetup, _advancedSetupPage);
|
setPage(WizardCommon::Page_AdvancedSetup, _advancedSetupPage);
|
||||||
setPage(WizardCommon::Page_Result, _resultPage );
|
setPage(WizardCommon::Page_Result, _resultPage);
|
||||||
|
|
||||||
|
connect(this, SIGNAL(finished(int)), SIGNAL(basicSetupFinished(int)));
|
||||||
|
|
||||||
// note: start Id is set by the calling class depending on if the
|
// note: start Id is set by the calling class depending on if the
|
||||||
// welcome text is to be shown or not.
|
// welcome text is to be shown or not.
|
||||||
@@ -145,12 +147,13 @@ void OwncloudWizard::slotCurrentPageChanged( int id )
|
|||||||
qDebug() << "Current Wizard page changed to " << id;
|
qDebug() << "Current Wizard page changed to " << id;
|
||||||
|
|
||||||
if( id == WizardCommon::Page_ServerSetup ) {
|
if( id == WizardCommon::Page_ServerSetup ) {
|
||||||
setButtonText( QWizard::NextButton, tr("Connect...") );
|
|
||||||
emit clearPendingRequests();
|
emit clearPendingRequests();
|
||||||
_setupPage->initializePage();
|
_setupPage->initializePage();
|
||||||
}
|
}
|
||||||
|
|
||||||
if( id == WizardCommon::Page_Result ) {
|
if( id == WizardCommon::Page_Result ) {
|
||||||
|
disconnect(this, SIGNAL(finished(int)), this, SIGNAL(basicSetupFinished(int)));
|
||||||
|
emit basicSetupFinished(QDialog::Accepted);
|
||||||
appendToConfigurationLog( QString::null );
|
appendToConfigurationLog( QString::null );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -69,6 +69,8 @@ signals:
|
|||||||
void determineAuthType(const QString&);
|
void determineAuthType(const QString&);
|
||||||
void connectToOCUrl( const QString& );
|
void connectToOCUrl( const QString& );
|
||||||
void createLocalAndRemoteFolders(const QString&, const QString&);
|
void createLocalAndRemoteFolders(const QString&, const QString&);
|
||||||
|
// make sure to connect to this, rather than finished(int)!!
|
||||||
|
void basicSetupFinished( int );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
OwncloudSetupPage* _setupPage;
|
OwncloudSetupPage* _setupPage;
|
||||||
|
|||||||
@@ -19,6 +19,9 @@
|
|||||||
<property name="text">
|
<property name="text">
|
||||||
<string>TextLabel</string>
|
<string>TextLabel</string>
|
||||||
</property>
|
</property>
|
||||||
|
<property name="wordWrap">
|
||||||
|
<bool>true</bool>
|
||||||
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item row="1" column="0">
|
<item row="1" column="0">
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
*.filepart
|
*.filepart
|
||||||
*~
|
*~
|
||||||
*.bak
|
|
||||||
*.part
|
*.part
|
||||||
*.crdownload
|
*.crdownload
|
||||||
|
|
||||||
@@ -17,10 +16,6 @@ csync_journal.db.ctmp
|
|||||||
desktop.ini
|
desktop.ini
|
||||||
|
|
||||||
*.kate-swp
|
*.kate-swp
|
||||||
*.aux
|
|
||||||
*.nav
|
|
||||||
*.out
|
|
||||||
*.toc
|
|
||||||
|
|
||||||
*_conflict-*
|
*_conflict-*
|
||||||
]*.~*
|
]*.~*
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ macro(owncloud_add_test test_class)
|
|||||||
add_executable(${OWNCLOUD_TEST_CLASS}Test test${OWNCLOUD_TEST_CLASS_LOWERCASE}.cpp ${${OWNCLOUD_TEST_CLASS}_MOCS})
|
add_executable(${OWNCLOUD_TEST_CLASS}Test test${OWNCLOUD_TEST_CLASS_LOWERCASE}.cpp ${${OWNCLOUD_TEST_CLASS}_MOCS})
|
||||||
|
|
||||||
target_link_libraries(${OWNCLOUD_TEST_CLASS}Test
|
target_link_libraries(${OWNCLOUD_TEST_CLASS}Test
|
||||||
${APPLICATION_SHORTNAME}sync
|
${APPLICATION_EXECUTABLE}sync
|
||||||
${QT_QTTEST_LIBRARY}
|
${QT_QTTEST_LIBRARY}
|
||||||
${QT_QTCORE_LIBRARY}
|
${QT_QTCORE_LIBRARY}
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -26,33 +26,51 @@ private slots:
|
|||||||
}
|
}
|
||||||
void testOctetsToString()
|
void testOctetsToString()
|
||||||
{
|
{
|
||||||
QVERIFY(octetsToString(1) == "1 byte");
|
QCOMPARE(octetsToString(999) , QString("999 B"));
|
||||||
QVERIFY(octetsToString(2) == "2 bytes");
|
QCOMPARE(octetsToString(1000) , QString("1 kB"));
|
||||||
QVERIFY(octetsToString(1024) == "1 KB");
|
QCOMPARE(octetsToString(1010) , QString("1 kB"));
|
||||||
QVERIFY(octetsToString(1024*1024) == "1 MB");
|
QCOMPARE(octetsToString(1110) , QString("1.1 kB"));
|
||||||
QVERIFY(octetsToString(1024LL*1024*1024) == "1 GB");
|
|
||||||
QVERIFY(octetsToString(1024LL*1024*1024*1024) == "1 TB");
|
QCOMPARE(octetsToString(9110) , QString("9.1 kB"));
|
||||||
|
QCOMPARE(octetsToString(9910) , QString("9.9 kB"));
|
||||||
|
QCOMPARE(octetsToString(9999) , QString("10 kB"));
|
||||||
|
|
||||||
|
QCOMPARE(octetsToString(123456) , QString("123 kB"));
|
||||||
|
QCOMPARE(octetsToString(1234567) , QString("1.2 MB"));
|
||||||
|
QCOMPARE(octetsToString(12345678) , QString("12 MB"));
|
||||||
|
QCOMPARE(octetsToString(123456789) , QString("123 MB"));
|
||||||
|
QCOMPARE(octetsToString(1000LL*1000*1000 * 5) , QString("5 GB"));
|
||||||
|
|
||||||
|
QCOMPARE(octetsToString(1), QString("1 B"));
|
||||||
|
QCOMPARE(octetsToString(2), QString("2 B"));
|
||||||
|
QCOMPARE(octetsToString(1024), QString("1 kB"));
|
||||||
|
QCOMPARE(octetsToString(1024*1024), QString("1 MB"));
|
||||||
|
QCOMPARE(octetsToString(1024LL*1024*1024), QString("1.1 GB"));
|
||||||
|
QCOMPARE(octetsToString(1024LL*1024*1024*1024), QString("1.1 TB"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void testLaunchOnStartup()
|
void testLaunchOnStartup()
|
||||||
{
|
{
|
||||||
const QString appName = "testLaunchOnStartup";
|
qsrand(QDateTime::currentDateTime().toTime_t());
|
||||||
const QString guiName = "LaunchOnStartup GUI Name";
|
QString postfix = QString::number(qrand());
|
||||||
|
|
||||||
QVERIFY(hasLaunchOnStartup(appName) == false);
|
const QString appName = QString::fromLatin1("testLaunchOnStartup.%1").arg(postfix);
|
||||||
setLaunchOnStartup(appName, guiName, true);
|
const QString guiName = "LaunchOnStartup GUI Name";
|
||||||
QVERIFY(hasLaunchOnStartup(appName) == true);
|
|
||||||
setLaunchOnStartup(appName, guiName, false);
|
QVERIFY(hasLaunchOnStartup(appName) == false);
|
||||||
QVERIFY(hasLaunchOnStartup(appName) == false);
|
setLaunchOnStartup(appName, guiName, true);
|
||||||
|
QVERIFY(hasLaunchOnStartup(appName) == true);
|
||||||
|
setLaunchOnStartup(appName, guiName, false);
|
||||||
|
QVERIFY(hasLaunchOnStartup(appName) == false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void testToCSyncScheme()
|
void testToCSyncScheme()
|
||||||
{
|
{
|
||||||
QVERIFY(toCSyncScheme("http://example.com/owncloud/") ==
|
QVERIFY(toCSyncScheme("http://example.com/owncloud/") ==
|
||||||
"owncloud://example.com/owncloud/");
|
"owncloud://example.com/owncloud/");
|
||||||
QVERIFY(toCSyncScheme("https://example.com/owncloud/") ==
|
QVERIFY(toCSyncScheme("https://example.com/owncloud/") ==
|
||||||
"ownclouds://example.com/owncloud/");
|
"ownclouds://example.com/owncloud/");
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||