added translation files
This commit is contained in:
@@ -38,6 +38,7 @@
|
|||||||
|
|
||||||
|
|
||||||
AC_DEFUN([AX_CXX_QT_TOOL], [
|
AC_DEFUN([AX_CXX_QT_TOOL], [
|
||||||
|
PKG_PROG_PKG_CONFIG
|
||||||
if test -z "$HAVE_$1"; then
|
if test -z "$HAVE_$1"; then
|
||||||
HAVE_$1=1
|
HAVE_$1=1
|
||||||
AC_MSG_CHECKING([for $2])
|
AC_MSG_CHECKING([for $2])
|
||||||
@@ -61,7 +62,7 @@ AC_DEFUN([AX_CXX_QT_TOOL], [
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
AC_SUBST($1)
|
AC_SUBST($1)
|
||||||
AM_CONDITIONAL(HAVE_$1, test $HAVE_$1 -eq 1)
|
AM_CONDITIONAL(HAVE_$1, test $HAVE_[$1] -eq 1)
|
||||||
if test $HAVE_$1 -eq 1; then
|
if test $HAVE_$1 -eq 1; then
|
||||||
AC_MSG_RESULT([$$1])
|
AC_MSG_RESULT([$$1])
|
||||||
else
|
else
|
||||||
@@ -79,24 +80,6 @@ AC_DEFUN([AX_CXX_QT_TOOLS], [
|
|||||||
AX_CXX_QT_TOOL(LRELEASE, lrelease)
|
AX_CXX_QT_TOOL(LRELEASE, lrelease)
|
||||||
])
|
])
|
||||||
|
|
||||||
AC_DEFUN([AX_CHECK_VALID_FLAG], [
|
|
||||||
AC_MSG_CHECKING([m4_default([$2], [for valid flag in "$1"])])
|
|
||||||
save_cppflags="$CPPFLAGS"
|
|
||||||
newflag="no"
|
|
||||||
for test_flag in $1; do
|
|
||||||
CPPFLAGS+=" ${test_flag}"
|
|
||||||
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [
|
|
||||||
newflag="$test_flag"
|
|
||||||
CPPFLAGS="$save_cppflags"
|
|
||||||
CPPFLAGS+=" ${test_flag}"
|
|
||||||
break;
|
|
||||||
])
|
|
||||||
CPPFLAGS="$save_cppflags"
|
|
||||||
done
|
|
||||||
AC_SUBST(CPPFLAGS)
|
|
||||||
AC_MSG_RESULT([$newflag])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN([AX_CHECK_QT], [
|
AC_DEFUN([AX_CHECK_QT], [
|
||||||
qt_modules="$2"
|
qt_modules="$2"
|
||||||
qt_modules_optional="$3"
|
qt_modules_optional="$3"
|
||||||
@@ -148,8 +131,11 @@ AC_DEFUN([AX_CHECK_QT], [
|
|||||||
fi
|
fi
|
||||||
], [HAVE_$1=0])
|
], [HAVE_$1=0])
|
||||||
])
|
])
|
||||||
AM_CONDITIONAL(HAVE_$1, test $HAVE_$1 -eq 1)
|
AM_CONDITIONAL(HAVE_$1, test $HAVE_[$1] -eq 1)
|
||||||
AX_CHECK_VALID_FLAG([-fPIC -fPIE], [position independent code flag])
|
AX_CHECK_VALID_CXX_FLAG([-fPIC -fPIE], [position independent code flag])
|
||||||
|
if test "${MINGW}" != "no"; then
|
||||||
|
AX_CHECK_VALID_CXX_FLAG([-Wl,-subsystem,windows], [windows console flag])
|
||||||
|
fi
|
||||||
AC_SUBST(QTDIR)
|
AC_SUBST(QTDIR)
|
||||||
AC_SUBST(QT_PLUGIN_PATH)
|
AC_SUBST(QT_PLUGIN_PATH)
|
||||||
AC_SUBST(CPPFLAGS)
|
AC_SUBST(CPPFLAGS)
|
||||||
|
@@ -250,10 +250,10 @@ EOF
|
|||||||
# use this in configure.ac to support HTML data for webservers
|
# use this in configure.ac to support HTML data for webservers
|
||||||
AC_DEFUN([AX_BUILD_HTML], [
|
AC_DEFUN([AX_BUILD_HTML], [
|
||||||
AC_CONFIG_FILES([html/makefile])
|
AC_CONFIG_FILES([html/makefile])
|
||||||
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-example-targets], [html/makefile.in])
|
AX_ADD_MAKEFILE_TARGET_DEP([maintainer-clean-am], [maintainer-clean-html-targets], [html/makefile.in])
|
||||||
test -f html/makefile.in && cat >> examples/html.in <<EOF
|
test -f html/makefile.in && cat >> html/makefile.in <<EOF
|
||||||
#### Begin: Appended by $0
|
#### Begin: Appended by $0
|
||||||
maintainer-clean-example-targets:
|
maintainer-clean-html-targets:
|
||||||
-rm makefile.in
|
-rm makefile.in
|
||||||
#### End: $0
|
#### End: $0
|
||||||
EOF
|
EOF
|
||||||
@@ -430,7 +430,7 @@ AC_DEFUN([AX_PKG_REQUIRE], [
|
|||||||
], [
|
], [
|
||||||
for x in ${$1_CFLAGS}; do
|
for x in ${$1_CFLAGS}; do
|
||||||
AC_MSG_NOTICE([search for $3 in ${x[#]-I}])
|
AC_MSG_NOTICE([search for $3 in ${x[#]-I}])
|
||||||
for f in $(find ${x[#]-I} -name "$3"); do
|
for f in $(find ${x[#]-I} -name "$3" 2> /dev/null); do
|
||||||
if test -f "$f"; then
|
if test -f "$f"; then
|
||||||
$1_found=${tmp_package}
|
$1_found=${tmp_package}
|
||||||
$1_CFLAGS+=" -I${f%/*}"
|
$1_CFLAGS+=" -I${f%/*}"
|
||||||
@@ -446,7 +446,7 @@ AC_DEFUN([AX_PKG_REQUIRE], [
|
|||||||
tmp_includedir=$(${PKG_CONFIG} --variable=includedir $tmp_package)
|
tmp_includedir=$(${PKG_CONFIG} --variable=includedir $tmp_package)
|
||||||
for x in ${tmp_includedir}; do
|
for x in ${tmp_includedir}; do
|
||||||
AC_MSG_NOTICE([search for $3 in $x])
|
AC_MSG_NOTICE([search for $3 in $x])
|
||||||
for f in $(find ${x} -name "$3"); do
|
for f in $(find ${x} -name "$3" 2> /dev/null); do
|
||||||
if test -f "$f"; then
|
if test -f "$f"; then
|
||||||
$1_found=${tmp_package}
|
$1_found=${tmp_package}
|
||||||
$1_CFLAGS+=" -I${f%/*}"
|
$1_CFLAGS+=" -I${f%/*}"
|
||||||
@@ -501,7 +501,7 @@ AC_DEFUN([AX_PKG_CHECK], [
|
|||||||
], [
|
], [
|
||||||
HAVE_$1=0
|
HAVE_$1=0
|
||||||
])
|
])
|
||||||
AM_CONDITIONAL(HAVE_$1, test $HAVE_$1 -eq 1)
|
AM_CONDITIONAL(HAVE_$1, test $HAVE_[$1] -eq 1)
|
||||||
AC_SUBST(HAVE_$1)
|
AC_SUBST(HAVE_$1)
|
||||||
AC_SUBST(CPPFLAGS)
|
AC_SUBST(CPPFLAGS)
|
||||||
AC_SUBST(CXXFLAGS)
|
AC_SUBST(CXXFLAGS)
|
||||||
@@ -532,3 +532,95 @@ AC_DEFUN([AX_REQUIRE_HEADER], [
|
|||||||
], [])
|
], [])
|
||||||
], [])
|
], [])
|
||||||
])
|
])
|
||||||
|
|
||||||
|
# Check within a list of CPP-Flags for the first that is usable and
|
||||||
|
# configure it
|
||||||
|
# - parameter:
|
||||||
|
# $1 = white-space separated list of alternative flags
|
||||||
|
# $2 = module name (optional, if different from id)
|
||||||
|
AC_DEFUN([AX_CHECK_VALID_CPP_FLAG], [
|
||||||
|
AC_MSG_CHECKING([m4_default([$2], [for valid flag in "$1"])])
|
||||||
|
save_cppflags="$CPPFLAGS"
|
||||||
|
newflag="no"
|
||||||
|
for test_flag in $1; do
|
||||||
|
CPPFLAGS+=" ${test_flag}"
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [
|
||||||
|
newflag="$test_flag"
|
||||||
|
CPPFLAGS="$save_cppflags"
|
||||||
|
CPPFLAGS+=" ${test_flag}"
|
||||||
|
break;
|
||||||
|
])
|
||||||
|
CPPFLAGS="$save_cppflags"
|
||||||
|
done
|
||||||
|
AC_SUBST(CPPFLAGS)
|
||||||
|
AC_MSG_RESULT([$newflag in $CPPFLAGS])
|
||||||
|
])
|
||||||
|
|
||||||
|
# Check within a list of CXX-Flags for the first that is usable and
|
||||||
|
# configure it
|
||||||
|
# - parameter:
|
||||||
|
# $1 = white-space separated list of alternative flags
|
||||||
|
# $2 = module name (optional, if different from id)
|
||||||
|
AC_DEFUN([AX_CHECK_VALID_CXX_FLAG], [
|
||||||
|
AC_MSG_CHECKING([m4_default([$2], [for valid flag in "$1"])])
|
||||||
|
save_cxxflags="$CXXFLAGS"
|
||||||
|
newflag="no"
|
||||||
|
for test_flag in $1; do
|
||||||
|
CXXFLAGS+=" ${test_flag}"
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [
|
||||||
|
newflag="$test_flag"
|
||||||
|
CXXFLAGS="$save_cxxflags"
|
||||||
|
CXXFLAGS+=" ${test_flag}"
|
||||||
|
break;
|
||||||
|
])
|
||||||
|
CXXFLAGS="$save_cxxflags"
|
||||||
|
done
|
||||||
|
AC_SUBST(CXXFLAGS)
|
||||||
|
AC_MSG_RESULT([$newflag in $CXXFLAGS])
|
||||||
|
])
|
||||||
|
|
||||||
|
# Check within a list of C-Flags for the first that is usable and
|
||||||
|
# configure it
|
||||||
|
# - parameter:
|
||||||
|
# $1 = white-space separated list of alternative flags
|
||||||
|
# $2 = module name (optional, if different from id)
|
||||||
|
AC_DEFUN([AX_CHECK_VALID_C_FLAG], [
|
||||||
|
AC_MSG_CHECKING([m4_default([$2], [for valid flag in "$1"])])
|
||||||
|
save_cflags="$CFLAGS"
|
||||||
|
newflag="no"
|
||||||
|
for test_flag in $1; do
|
||||||
|
CFLAGS+=" ${test_flag}"
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [
|
||||||
|
newflag="$test_flag"
|
||||||
|
CFLAGS="$save_cflags"
|
||||||
|
CFLAGS+=" ${test_flag}"
|
||||||
|
break;
|
||||||
|
])
|
||||||
|
CFLAGS="$save_cflags"
|
||||||
|
done
|
||||||
|
AC_SUBST(CFLAGS)
|
||||||
|
AC_MSG_RESULT([$newflag in $CFLAGS])
|
||||||
|
])
|
||||||
|
|
||||||
|
# Check within a list of LD-Flags for the first that is usable and
|
||||||
|
# configure it
|
||||||
|
# - parameter:
|
||||||
|
# $1 = white-space separated list of alternative flags
|
||||||
|
# $2 = module name (optional, if different from id)
|
||||||
|
AC_DEFUN([AX_CHECK_VALID_LD_FLAG], [
|
||||||
|
AC_MSG_CHECKING([m4_default([$2], [for valid flag in "$1"])])
|
||||||
|
save_ldflags="$LDFLAGS"
|
||||||
|
newflag="no"
|
||||||
|
for test_flag in $1; do
|
||||||
|
LDFLAGS+=" ${test_flag}"
|
||||||
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [
|
||||||
|
newflag="$test_flag"
|
||||||
|
LDFLAGS="$save_ldflags"
|
||||||
|
LDFLAGS+=" ${test_flag}"
|
||||||
|
break;
|
||||||
|
])
|
||||||
|
LDFLAGS="$save_ldflags"
|
||||||
|
done
|
||||||
|
AC_SUBST(LDFLAGS)
|
||||||
|
AC_MSG_RESULT([$newflag in $LDFLAGS])
|
||||||
|
])
|
||||||
|
19
bootstrap.sh
19
bootstrap.sh
@@ -105,6 +105,8 @@ GENERATED FILES
|
|||||||
* ax_check_qt.m4 - auxiliary macro definition file
|
* ax_check_qt.m4 - auxiliary macro definition file
|
||||||
* mac-create-app-bundle.sh - script to create apple mac os-x app-bundle
|
* mac-create-app-bundle.sh - script to create apple mac os-x app-bundle
|
||||||
* AUTHORS - replace your name in AUTHORS before first run
|
* AUTHORS - replace your name in AUTHORS before first run
|
||||||
|
* NEWS - empty file add your project's news
|
||||||
|
* README - add project description (first line is header, followed by an empty line)
|
||||||
* configure.ac - global configuration file template
|
* configure.ac - global configuration file template
|
||||||
* makefile.am - global makefile template
|
* makefile.am - global makefile template
|
||||||
* src/makefile.am - if you enabled AX_USE_CXX
|
* src/makefile.am - if you enabled AX_USE_CXX
|
||||||
@@ -149,6 +151,7 @@ FILES TO EDIT
|
|||||||
|
|
||||||
The following files normally require editing:
|
The following files normally require editing:
|
||||||
* AUTHORS
|
* AUTHORS
|
||||||
|
* NEWS
|
||||||
* README
|
* README
|
||||||
* configure.ac
|
* configure.ac
|
||||||
* src/makefile.am
|
* src/makefile.am
|
||||||
@@ -178,6 +181,7 @@ FILES
|
|||||||
* AUTHORS: First line is the main author and used in Debian and RPM
|
* AUTHORS: First line is the main author and used in Debian and RPM
|
||||||
packaging, so there must be a GPG key that matches
|
packaging, so there must be a GPG key that matches
|
||||||
to this line.
|
to this line.
|
||||||
|
* NEWS: File to add project news.
|
||||||
* README: First line is a short description of your project, then an
|
* README: First line is a short description of your project, then an
|
||||||
empty line must follow. All remaining lines are a
|
empty line must follow. All remaining lines are a
|
||||||
long description of your project. this information
|
long description of your project. this information
|
||||||
@@ -388,6 +392,14 @@ fi
|
|||||||
to AUTHORS <<EOF && notice "please edit AUTHORS"
|
to AUTHORS <<EOF && notice "please edit AUTHORS"
|
||||||
$AUTHOR
|
$AUTHOR
|
||||||
EOF
|
EOF
|
||||||
|
to NEWS <<EOF && notice "please edit NEWS"
|
||||||
|
$(date) created ${DEFAULT_PROJECT_NAME}
|
||||||
|
EOF
|
||||||
|
to README <<EOF && notice "please edit README"
|
||||||
|
${DEFAULT_PROJECT_NAME}
|
||||||
|
|
||||||
|
add description for ${DEFAULT_PROJECT_NAME}
|
||||||
|
EOF
|
||||||
to configure.ac <<EOF && \
|
to configure.ac <<EOF && \
|
||||||
( notice "please edit configure.ac, then rerun $0"; exit 0 )
|
( notice "please edit configure.ac, then rerun $0"; exit 0 )
|
||||||
${HEADER}m4_define(x_package_name, ${DEFAULT_PROJECT_NAME}) # project's name
|
${HEADER}m4_define(x_package_name, ${DEFAULT_PROJECT_NAME}) # project's name
|
||||||
@@ -682,7 +694,7 @@ EOF
|
|||||||
Source: @PACKAGE_NAME@
|
Source: @PACKAGE_NAME@
|
||||||
Priority: extra
|
Priority: extra
|
||||||
Maintainer: @AUTHOR@
|
Maintainer: @AUTHOR@
|
||||||
Build-Depends: debhelper, subversion, pkg-config, autotools-dev, lsb-release $(if testtag AX_USE_DOXYGEN; then echo -n ", doxygen, graphviz, mscgen"; fi; if testtag AX_USE_CPPUNIT; then echo -n ", libcppunit-dev"; fi; if testtag AX_CXX_QT || testtag AX_CXX_CHECK_QT; then echo -n ", qtbase5-dev | libqt4-dev, qtbase5-dev-tools | qt4-dev-tools"; fi)
|
Build-Depends: debhelper, subversion, pkg-config, autotools-dev, lsb-release $(if testtag AX_USE_DOXYGEN; then echo -n ", doxygen, graphviz, mscgen"; fi; if testtag AX_USE_CPPUNIT; then echo -n ", libcppunit-dev"; fi; if testtag AX_CXX_QT || testtag AX_CXX_CHECK_QT; then echo -n ", qtbase5-dev | libqt4-dev, qtbase5-dev-tools | qt4-dev-tools, qttools5-dev-tools | qt4-dev-tools,"; fi)
|
||||||
|
|
||||||
Package: @PACKAGE_NAME@
|
Package: @PACKAGE_NAME@
|
||||||
Section: $(if testtag AX_USE_LIBTOOL; then echo "libs"; fi)
|
Section: $(if testtag AX_USE_LIBTOOL; then echo "libs"; fi)
|
||||||
@@ -794,7 +806,7 @@ rm -rf \$RPM_BUILD_ROOT
|
|||||||
$(if testtag AX_USE_LIBTOOL; then
|
$(if testtag AX_USE_LIBTOOL; then
|
||||||
echo '/usr/%_lib/@PACKAGE_NAME@.so.*'
|
echo '/usr/%_lib/@PACKAGE_NAME@.so.*'
|
||||||
else
|
else
|
||||||
echo /usr/bin/*
|
echo '/usr/bin/*'
|
||||||
fi)
|
fi)
|
||||||
%doc
|
%doc
|
||||||
$(if testtag AX_USE_LIBTOOL; then
|
$(if testtag AX_USE_LIBTOOL; then
|
||||||
@@ -807,7 +819,7 @@ $(if testtag AX_USE_LIBTOOL; then
|
|||||||
/usr/share/doc/packages/@PACKAGE_NAME@/README
|
/usr/share/doc/packages/@PACKAGE_NAME@/README
|
||||||
EOF2
|
EOF2
|
||||||
else
|
else
|
||||||
echo /usr/share/*
|
echo '/usr/share/*'
|
||||||
fi)
|
fi)
|
||||||
|
|
||||||
$(if testtag AX_USE_LIBTOOL; then
|
$(if testtag AX_USE_LIBTOOL; then
|
||||||
@@ -830,6 +842,7 @@ This Package contains all files required for developement.
|
|||||||
/usr/%_lib/pkgconfig
|
/usr/%_lib/pkgconfig
|
||||||
/usr/include/*
|
/usr/include/*
|
||||||
%doc
|
%doc
|
||||||
|
/usr/share/@PACKAGE_NAME@
|
||||||
/usr/share/doc/packages/@PACKAGE_NAME@/html
|
/usr/share/doc/packages/@PACKAGE_NAME@/html
|
||||||
EOF2
|
EOF2
|
||||||
fi)
|
fi)
|
||||||
|
@@ -24,6 +24,7 @@ AX_USE_RPM_PACKAGING
|
|||||||
AX_BUILD_EXAMPLES
|
AX_BUILD_EXAMPLES
|
||||||
|
|
||||||
AX_CHECK_QT([QT], [QtNetwork QtGui], [QtWidgets])
|
AX_CHECK_QT([QT], [QtNetwork QtGui], [QtWidgets])
|
||||||
|
AC_CONFIG_FILES([src/languages.qrc])
|
||||||
if test "${MINGW}" = "no"; then
|
if test "${MINGW}" = "no"; then
|
||||||
AX_PKG_CHECK([PROXY], [libproxy-1.0])
|
AX_PKG_CHECK([PROXY], [libproxy-1.0])
|
||||||
else
|
else
|
||||||
|
@@ -77,6 +77,7 @@ This Package contains all files required for developement.
|
|||||||
/usr/%_lib/pkgconfig
|
/usr/%_lib/pkgconfig
|
||||||
/usr/include/*
|
/usr/include/*
|
||||||
%doc
|
%doc
|
||||||
|
/usr/share/@PACKAGE_NAME@
|
||||||
/usr/share/doc/packages/@PACKAGE_NAME@/html
|
/usr/share/doc/packages/@PACKAGE_NAME@/html
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
9
src/languages.qrc.in
Normal file
9
src/languages.qrc.in
Normal file
@@ -0,0 +1,9 @@
|
|||||||
|
<!DOCTYPE RCC>
|
||||||
|
<RCC version="1.0">
|
||||||
|
<qresource prefix="/language">
|
||||||
|
<file alias="proxy_de.qm">@top_srcdir@/src/proxy_de.qm</file>
|
||||||
|
<file alias="proxy_fr.qm">@top_srcdir@/src/proxy_fr.qm</file>
|
||||||
|
<file alias="proxy_it.qm">@top_srcdir@/src/proxy_it.qm</file>
|
||||||
|
<file alias="proxy_en.qm">@top_srcdir@/src/proxy_en.qm</file>
|
||||||
|
</qresource>
|
||||||
|
</RCC>
|
@@ -7,6 +7,12 @@
|
|||||||
## 45678901234567890123456789012345678901234567890123456789012345678901234567890
|
## 45678901234567890123456789012345678901234567890123456789012345678901234567890
|
||||||
|
|
||||||
lib_LTLIBRARIES = libproxyface.la
|
lib_LTLIBRARIES = libproxyface.la
|
||||||
|
LANGUAGE_FILE_BASE = proxy
|
||||||
|
translationsdir = ${pkgdatadir}/translations
|
||||||
|
translations_DATA = ${LANGUAGE_FILE_BASE}_en.qm \
|
||||||
|
${LANGUAGE_FILE_BASE}_de.qm \
|
||||||
|
${LANGUAGE_FILE_BASE}_fr.qm \
|
||||||
|
${LANGUAGE_FILE_BASE}_it.qm
|
||||||
|
|
||||||
proxyfacedir = ${includedir}/proxyface
|
proxyfacedir = ${includedir}/proxyface
|
||||||
proxyface_HEADERS = proxyface/autoproxy.hxx proxyface/proxy.hxx \
|
proxyface_HEADERS = proxyface/autoproxy.hxx proxyface/proxy.hxx \
|
||||||
@@ -23,7 +29,14 @@ libproxyface_la_MOCFILES = proxyface/moc_proxy.cxx \
|
|||||||
libproxyface_la_RCCFILES = proxyface/qrc_resources.cxx
|
libproxyface_la_RCCFILES = proxyface/qrc_resources.cxx
|
||||||
BUILT_SOURCES = ${libproxyface_la_UIFILES} \
|
BUILT_SOURCES = ${libproxyface_la_UIFILES} \
|
||||||
${libproxyface_la_MOCFILES} \
|
${libproxyface_la_MOCFILES} \
|
||||||
${libproxyface_la_RCCFILES}
|
${libproxyface_la_RCCFILES} ${translations_DATA}
|
||||||
|
EXTRA_DIST_TR = ${libproxyface_la_MOCFILES:moc_%.cxx=%.hxx} \
|
||||||
|
${libproxyface_la_UIFILES:ui_%.hxx=%.ui}
|
||||||
|
EXTRA_DIST = ${EXTRA_DIST_TR} languages.qrc.in \
|
||||||
|
${translations_DATA:%.qm=%.ts}
|
||||||
|
|
||||||
endif
|
endif
|
||||||
libproxyface_la_SOURCES = version.cxx ${libproxyface_la_RCCFILES} \
|
libproxyface_la_SOURCES = version.cxx ${libproxyface_la_RCCFILES} \
|
||||||
${libproxyface_la_MOCFILES}
|
${libproxyface_la_MOCFILES}
|
||||||
|
|
||||||
|
DISTCLEANFILES = ${translations_DATA}
|
Reference in New Issue
Block a user