summaryrefslogtreecommitdiff
path: root/lib/parameter.c
diff options
context:
space:
mode:
authorMartin Baulig <martin@home-of-linux.org>1999-12-19 00:30:18 +0000
committerMartin Baulig <martin@src.gnome.org>1999-12-19 00:30:18 +0000
commitd2d8d38db402132df3baefc828233278f2ccfa9f (patch)
treef232bcbbbf2f771d281efee8038e1ae596ffc272 /lib/parameter.c
parent0dee417e1d60108ce8b49e10e3639f6ed8f51f77 (diff)
downloadlibgtop-d2d8d38db402132df3baefc828233278f2ccfa9f.tar.gz
New file. We define `GLIBTOP_ERROR_*' error constants here.
1999-12-19 Martin Baulig <martin@home-of-linux.org> * include/glibtop/errors.h: New file. We define `GLIBTOP_ERROR_*' error constants here. * lib/errors.c: New file. (glibtop_error_strings): Array of error messages. (glibtop_get_error_string_l): Get error message. * include/glibtop/parameter.h: Added `GLIBTOP_PARAM_REMOTE_USER' and `GLIBTOP_PARAM_PATH_RSH'. * lib/parameter.c (glibtop_get_parameter_l): Changed return value from `size_t' to `ssize_t' and let it return an error constant. (glibtop_get_parameter_size_l): New function. (glibtop_set_parameter_l): Changed return value from `void' to `int' and let it return an error constant on error. * structures.def (glibtop_sysdeps): Added.
Diffstat (limited to 'lib/parameter.c')
-rw-r--r--lib/parameter.c78
1 files changed, 69 insertions, 9 deletions
diff --git a/lib/parameter.c b/lib/parameter.c
index 83a8bfe7..bd3731b7 100644
--- a/lib/parameter.c
+++ b/lib/parameter.c
@@ -22,10 +22,12 @@
*/
#include <glibtop.h>
+#include <glibtop/xmalloc.h>
#include <glibtop/parameter.h>
#define _write_data(ptr,size) \
- if ((data_ptr == NULL) || (data_size < size)) return -size; \
+ if ((data_ptr == NULL) || (data_size < size)) \
+ return -GLIBTOP_ERROR_SIZE_MISMATCH; \
if (ptr == NULL) { strcpy (data_ptr, ""); return 1; } \
memcpy (data_ptr, ptr, size); \
return size;
@@ -35,12 +37,12 @@
glibtop_warn_r (server, "glibtop_set_parameter (%d): " \
"Expected %lu bytes but got %lu.", \
parameter, size, data_size); \
- return; \
+ return -GLIBTOP_ERROR_SIZE_MISMATCH; \
}
#define _strlen(ptr) (ptr ? strlen (ptr) : 0)
-size_t
+ssize_t
glibtop_get_parameter_l (glibtop *server, const unsigned parameter,
void *data_ptr, size_t data_size)
{
@@ -60,6 +62,12 @@ glibtop_get_parameter_l (glibtop *server, const unsigned parameter,
case GLIBTOP_PARAM_PORT:
_write_data (&server->server_port,
sizeof (server->server_port));
+ case GLIBTOP_PARAM_REMOTE_USER:
+ _write_data (server->server_user,
+ _strlen(server->server_user));
+ case GLIBTOP_PARAM_PATH_RSH:
+ _write_data (server->server_rsh,
+ _strlen(server->server_rsh));
case GLIBTOP_PARAM_ERROR_METHOD:
_write_data (&server->error_method,
sizeof (server->error_method));
@@ -68,10 +76,37 @@ glibtop_get_parameter_l (glibtop *server, const unsigned parameter,
sizeof (server->required));
}
- return 0;
+ return -GLIBTOP_ERROR_NO_SUCH_PARAMETER;
}
-void
+int
+glibtop_get_parameter_size_l (glibtop *server, const unsigned parameter)
+{
+ switch (parameter) {
+ case GLIBTOP_PARAM_METHOD:
+ return sizeof (server->method);
+ case GLIBTOP_PARAM_FEATURES:
+ return sizeof (server->features);
+ case GLIBTOP_PARAM_COMMAND:
+ return _strlen(server->server_command);
+ case GLIBTOP_PARAM_HOST:
+ return _strlen(server->server_host);
+ case GLIBTOP_PARAM_PORT:
+ return sizeof (server->server_port);
+ case GLIBTOP_PARAM_REMOTE_USER:
+ return _strlen(server->server_user);
+ case GLIBTOP_PARAM_PATH_RSH:
+ return _strlen(server->server_rsh);
+ case GLIBTOP_PARAM_ERROR_METHOD:
+ return sizeof (server->error_method);
+ case GLIBTOP_PARAM_REQUIRED:
+ return sizeof (server->required);
+ }
+
+ return -GLIBTOP_ERROR_NO_SUCH_PARAMETER;
+}
+
+int
glibtop_set_parameter_l (glibtop *server, const unsigned parameter,
const void *data_ptr, size_t data_size)
{
@@ -81,10 +116,31 @@ glibtop_set_parameter_l (glibtop *server, const unsigned parameter,
memcpy (&server->method, data_ptr, data_size);
break;
case GLIBTOP_PARAM_FEATURES:
- /* You should not be allowed to set this field. */
- glibtop_warn_r (server, "glibtop_set_parameter (%d): " \
- "Cannot modify read-only value.",
- parameter);
+ return -GLIBTOP_ERROR_READONLY_VALUE;
+ break;
+ case GLIBTOP_PARAM_COMMAND:
+ if (server->server_command)
+ glibtop_free_r (server, server->server_command);
+ server->server_command = glibtop_strdup_r (server, data_ptr);
+ break;
+ case GLIBTOP_PARAM_HOST:
+ if (server->server_host)
+ glibtop_free_r (server, server->server_host);
+ server->server_host = glibtop_strdup_r (server, data_ptr);
+ break;
+ case GLIBTOP_PARAM_PORT:
+ _check_data (sizeof (server->server_port));
+ memcpy (&server->server_port, data_ptr, data_size);
+ break;
+ case GLIBTOP_PARAM_REMOTE_USER:
+ if (server->server_user)
+ glibtop_free_r (server, server->server_user);
+ server->server_user = glibtop_strdup_r (server, data_ptr);
+ break;
+ case GLIBTOP_PARAM_PATH_RSH:
+ if (server->server_rsh)
+ glibtop_free_r (server, server->server_rsh);
+ server->server_rsh = glibtop_strdup_r (server, data_ptr);
break;
case GLIBTOP_PARAM_ERROR_METHOD:
_check_data (sizeof (server->error_method));
@@ -94,5 +150,9 @@ glibtop_set_parameter_l (glibtop *server, const unsigned parameter,
_check_data (sizeof (server->required));
memcpy (&server->required, data_ptr, data_size);
break;
+ default:
+ return -GLIBTOP_ERROR_NO_SUCH_PARAMETER;
}
+
+ return 0;
}