summaryrefslogtreecommitdiff
path: root/src/stringprep
diff options
context:
space:
mode:
authorBadlop <badlop@process-one.net>2011-12-21 12:15:21 +0100
committerBadlop <badlop@process-one.net>2011-12-21 12:15:21 +0100
commit2029e39299aebe3c4882a26294f4caadc8881265 (patch)
tree1e4b7391dbd3dcc42b21f64ffdae7a721e047dd7 /src/stringprep
parentReplace regexp with ejabberd_regexp (diff)
Support Erlang/OTP R15B driver (EJAB-1521)
Diffstat (limited to 'src/stringprep')
-rw-r--r--src/stringprep/stringprep_drv.c30
1 files changed, 26 insertions, 4 deletions
diff --git a/src/stringprep/stringprep_drv.c b/src/stringprep/stringprep_drv.c
index f4d98f84..e3246e80 100644
--- a/src/stringprep/stringprep_drv.c
+++ b/src/stringprep/stringprep_drv.c
@@ -30,6 +30,16 @@
#define NODEPREP_COMMAND 2
#define RESOURCEPREP_COMMAND 3
+/*
+ * R15B changed several driver callbacks to use ErlDrvSizeT and
+ * ErlDrvSSizeT typedefs instead of int.
+ * This provides missing typedefs on older OTP versions.
+ */
+#if ERL_DRV_EXTENDED_MAJOR_VERSION < 2
+typedef int ErlDrvSizeT;
+typedef int ErlDrvSSizeT;
+#endif
+
typedef struct {
ErlDrvPort port;
} stringprep_data;
@@ -194,10 +204,10 @@ static int compose(int ch1, int ch2)
-static int stringprep_erl_control(ErlDrvData drv_data,
+static ErlDrvSSizeT stringprep_erl_control(ErlDrvData drv_data,
unsigned int command,
- char *buf, int len,
- char **rbuf, int rlen)
+ char *buf, ErlDrvSizeT len,
+ char **rbuf, ErlDrvSizeT rlen)
{
int i, j, pos=1;
unsigned char c;
@@ -400,7 +410,19 @@ ErlDrvEntry stringprep_driver_entry = {
NULL, /* handle */
stringprep_erl_control, /* F_PTR control, port_command callback */
NULL, /* F_PTR timeout, reserved */
- NULL /* F_PTR outputv, reserved */
+ NULL, /* F_PTR outputv, reserved */
+ /* Added in Erlang/OTP R15B: */
+ NULL, /* ready_async */
+ NULL, /* flush */
+ NULL, /* call */
+ NULL, /* event */
+ ERL_DRV_EXTENDED_MARKER, /* extended_marker */
+ ERL_DRV_EXTENDED_MAJOR_VERSION, /* major_version */
+ ERL_DRV_EXTENDED_MINOR_VERSION, /* minor_version */
+ 0, /* driver_flags */
+ NULL, /* handle2 */
+ NULL, /* process_exit */
+ NULL /* stop_select */
};
DRIVER_INIT(stringprep_erl) /* must match name in driver_entry */