Module: sip-router
Branch: master
Commit: 8cf72b2de1ca86cafe7203433ff411e837d26dfa
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=8cf72b2…
Author: Daniel-Constantin Mierla <miconda(a)gmail.com>
Committer: Daniel-Constantin Mierla <miconda(a)gmail.com>
Date: Tue Apr 28 19:23:23 2009 +0200
kex: added km_append_branch
- K compatible append_branch() function
---
modules_k/kex/kex_mod.c | 5 +++
modules_k/kex/km_core.c | 67 +++++++++++++++++++++++++++++++++++++++++++++++
modules_k/kex/km_core.h | 30 +++++++++++++++++++++
3 files changed, 102 insertions(+), 0 deletions(-)
diff --git a/modules_k/kex/kex_mod.c b/modules_k/kex/kex_mod.c
index e4960c0..9baa48d 100644
--- a/modules_k/kex/kex_mod.c
+++ b/modules_k/kex/kex_mod.c
@@ -31,6 +31,7 @@
#include "../../mod_fix.h"
#include "flags.h"
+#include "km_core.h"
#include "mi_core.h"
#include "core_stats.h"
@@ -63,6 +64,10 @@ static cmd_export_t cmds[]={
0, ANY_ROUTE },
{"isbflagset", (cmd_function)w_isbflagset, 2,fixup_igp_igp,
0, ANY_ROUTE },
+ {"km_append_branch", (cmd_function)w_km_append_branch, 0, 0,
+ 0, REQUEST_ROUTE | FAILURE_ROUTE },
+ {"km_append_branch", (cmd_function)w_km_append_branch, 1, fixup_spve_null,
+ 0, REQUEST_ROUTE | FAILURE_ROUTE },
{0,0,0,0,0,0}
};
diff --git a/modules_k/kex/km_core.c b/modules_k/kex/km_core.c
new file mode 100644
index 0000000..beebb35
--- /dev/null
+++ b/modules_k/kex/km_core.c
@@ -0,0 +1,67 @@
+/**
+ * $Id$
+ *
+ * Copyright (C) 2009
+ *
+ * This file is part of SIP-Router.org, a free SIP server.
+ *
+ * SIP-Router is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version
+ *
+ * Kamailio is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+#include "../../dprint.h"
+#include "../../dset.h"
+#include "../../flags.h"
+#include "../../mod_fix.h"
+#include "km_core.h"
+
+int w_km_append_branch(struct sip_msg *msg, char *uri, str *sq)
+{
+ str suri;
+ int ret;
+ int q = Q_UNSPECIFIED;
+ flag_t branch_flags = 0;
+
+ getbflagsval(0, &branch_flags);
+ if (uri==NULL) {
+ ret = km_append_branch(msg, 0, &msg->dst_uri, &msg->path_vec,
+ q, branch_flags, msg->force_send_socket);
+ /* reset all branch info */
+ msg->force_send_socket = 0;
+ setbflagsval(0, 0);
+ if(msg->dst_uri.s!=0)
+ pkg_free(msg->dst_uri.s);
+ msg->dst_uri.s = 0;
+ msg->dst_uri.len = 0;
+ if(msg->path_vec.s!=0)
+ pkg_free(msg->path_vec.s);
+ msg->path_vec.s = 0;
+ msg->path_vec.len = 0;
+ } else {
+ if(fixup_get_svalue(msg, (gparam_p)uri, &suri)!=0)
+ {
+ LM_ERR("cannot get the URI parameter\n");
+ return -1;
+ }
+ ret = km_append_branch(msg, &suri, &msg->dst_uri,
+ &msg->path_vec, q, branch_flags,
+ msg->force_send_socket);
+ }
+ return ret;
+}
+
diff --git a/modules_k/kex/km_core.h b/modules_k/kex/km_core.h
new file mode 100644
index 0000000..a668c71
--- /dev/null
+++ b/modules_k/kex/km_core.h
@@ -0,0 +1,30 @@
+/**
+ * $Id$
+ *
+ * Copyright (C) 2009
+ *
+ * This file is part of SIP-Router.org, a free SIP server.
+ *
+ * SIP-Router is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version
+ *
+ * Kamailio is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#ifndef _KEX_CORE_H_
+#define _KEX_CORE_H_
+
+#include "../../sr_module.h"
+
+int w_km_append_branch(struct sip_msg *msg, char *uri, str *s2);
+
+#endif
Module: sip-router
Branch: master
Commit: d02a166db83db71b587cd1252db0b4d4954e8c93
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=d02a166…
Author: Daniel-Constantin Mierla <miconda(a)gmail.com>
Committer: Daniel-Constantin Mierla <miconda(a)gmail.com>
Date: Tue Apr 28 19:21:04 2009 +0200
core: renamed getbflsgs to getblagsval
- match the template of counterpart setblagsval
- swapped the parameters
---
dset.c | 2 +-
dset.h | 4 ++--
2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/dset.c b/dset.c
index cbc636b..9409557 100644
--- a/dset.c
+++ b/dset.c
@@ -126,7 +126,7 @@ int resetbflag(unsigned int branch, flag_t flag)
}
-int getbflags(flag_t* res, unsigned int branch)
+int getbflagsval(unsigned int branch, flag_t* res)
{
flag_t* flags;
if (res == NULL) return -1;
diff --git a/dset.h b/dset.h
index e350238..adba10e 100644
--- a/dset.h
+++ b/dset.h
@@ -126,11 +126,11 @@ int isbflagset(unsigned int branch, flag_t flag);
*
* This function returns the value of all branch flags
* combined in a single variable.
- * @param res A pointer to a variable to store the result
* @param branch Number of the branch (0 for the main Request-URI branch)
+ * @param res A pointer to a variable to store the result
* @return 1 on success, -1 on failure
*/
-int getbflags(flag_t* res, unsigned int branch);
+int getbflagsval(unsigned int branch, flag_t* res);
/**
* Set the value of all branch flags at once for a given branch.
Module: sip-router
Branch: andrei/type_conversion
Commit: 3c8fc182ae386713f15e6a0362924e72b257c31e
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=3c8fc18…
Author: Andrei Pelinescu-Onciul <andrei(a)iptel.org>
Committer: Andrei Pelinescu-Onciul <andrei(a)iptel.org>
Date: Tue Apr 28 18:34:03 2009 +0200
core expr eval: fix assoc., commut and 0 adding for +, ==
- fix associativity for the generic plus: because of the non-fixed
argument types (can work with strings integers or both in the
same type), RVE_PLUS_OP is associative _only_ if the operand
types match.
Non-assoc. example: "a" + 1 + "2" (can be "a12" or "a3").
Instead of adding extra checks for the same type, rely on the
optimizer having already replaced RVE_PLUS_OP with RVE_IPLUS_OP
or RVE_CONCAT_OP => RVE_PLUS_OP will be used only when the
operands types are mixed or cannot be determined (e.g. AVP), or
when script optimizations are turned off (-O0).
- fix commutativity for the generic plus. Similar to the above.
Non-commut. example: 1 + "2" == 3, but "2" + 1 == "21".
- fix commutativity for the generic == and !=.
Non. commut. example: 0 == "" , but "" != 0.
Similar fix as above, relying on the optimizer and the type specific
operators: RVE_IEQ_OP, RVE_IDIFF_OP, RVE_STREQ_OP and
RVE_STRDIFF_OP.
- fix $v + 0 / 0 + $v -> $v optimizations. Because of the generic
plus and recent changes that allow int + str, even if the result
is an int (left side operant is integer), 0 + $v can be
different from $v. E.g.: 0+"1" == 1, which is different from
"1".
---
rvalue.c | 37 +++++++++++++++++++++++++++----------
1 files changed, 27 insertions(+), 10 deletions(-)
diff --git a/rvalue.c b/rvalue.c
index 7e82503..9a74cda 100644
--- a/rvalue.c
+++ b/rvalue.c
@@ -2281,6 +2281,9 @@ static int rve_op_is_assoc(enum rval_expr_op op)
case RVE_MINUS_OP:
return 0;
case RVE_PLUS_OP:
+ /* the generic plus is not assoc, e.g.
+ "a" + 1 + "2" => "a12" in one case and "a3" in the other */
+ return 0;
case RVE_IPLUS_OP:
case RVE_CONCAT_OP:
case RVE_MUL_OP:
@@ -2308,7 +2311,7 @@ static int rve_op_is_assoc(enum rval_expr_op op)
/** returns true if the operator is commutative. */
-static int rve_op_is_commutative(enum rval_expr_op op, enum rval_type type)
+static int rve_op_is_commutative(enum rval_expr_op op)
{
switch(op){
case RVE_NONE_OP:
@@ -2325,7 +2328,10 @@ static int rve_op_is_commutative(enum rval_expr_op op, enum rval_type type)
case RVE_MINUS_OP:
return 0;
case RVE_PLUS_OP:
- return type==RV_INT; /* commutative only for INT*/
+ /* non commut. when diff. type
+ (e.g 1 + "2" != "2" + 1 ) => non commut. in general
+ (specific same type versions are covered by IPLUS & CONCAT) */
+ return 0;
case RVE_IPLUS_OP:
case RVE_MUL_OP:
case RVE_BAND_OP:
@@ -2345,11 +2351,11 @@ static int rve_op_is_commutative(enum rval_expr_op op, enum rval_type type)
return 0;
case RVE_DIFF_OP:
case RVE_EQ_OP:
-#if !defined(UNDEF_EQ_ALWAYS_FALSE) && !defined(UNDEF_EQ_UNDEF_TRUE)
- return 1;
-#else
+ /* non. commut. in general, only for same type e.g.:
+ "" == 0 diff. 0 == "" ( "" == "0" and 0 == 0)
+ same type versions are covered by IEQ, IDIFF, STREQ, STRDIFF
+ */
return 0 /* asymmetrical undef handling */;
-#endif
}
return 0;
}
@@ -2658,8 +2664,19 @@ static int rve_opt_01(struct rval_expr* rve, enum rval_type rve_type)
case RVE_PLUS_OP:
case RVE_IPLUS_OP:
/* we must make sure that this is an int PLUS
- (because "foo"+0 is valid => "foo0") */
- if ((i==0) && ((op==RVE_IPLUS_OP)||(rve_type==RV_INT))){
+ (because "foo"+0 is valid => "foo0")
+ Even if overall type is RV_INT, it's still not safe
+ to optimize a generic PLUS: 0 + $v is not always equivalent
+ to $v (e.g. 0+"1" ==1 != "1") => optimize only if
+ IPLUS (always safe since it converts to int first) or
+ if generic PLUS and result is integer (rve_type) and
+ expression is of the form $v+ct (and not ct+$v).
+ TODO: dropping PLUS_OP all together and relying on the
+ optimizer replacing safe PLUS_OP with IPLUS_OP or CONCAT_OP
+ will simplify things.
+ */
+ if ((i==0) && ((op==RVE_IPLUS_OP)||
+ (rve_type==RV_INT && ct_rve==rve->right.rve))){
/* $v + 0 -> $v
* 0 + $v -> $v */
rve_destroy(ct_rve);
@@ -2908,7 +2925,7 @@ static int rve_optimize(struct rval_expr* rve)
trv->v.s.len, trv->v.s.s, rve->op);
ret=1;
}else if (rve_is_constant(rve->left.rve->left.rve) &&
- rve_op_is_commutative(rve->op, type)){
+ rve_op_is_commutative(rve->op)){
/* op(op(a, $v), b) => op(op(a, b), $v) */
/* rv= op(a, b) */
tmp_rve.op=rve->op;
@@ -2950,7 +2967,7 @@ static int rve_optimize(struct rval_expr* rve)
if ((rve->op==rve->right.rve->op) && rve_op_is_assoc(rve->op)){
/* op(a, op(...)) */
if (rve_is_constant(rve->right.rve->right.rve) &&
- rve_op_is_commutative(rve->op, type)){
+ rve_op_is_commutative(rve->op)){
/* op(a, op($v, b)) => op(op(a, b), $v) */
/* rv= op(a, b) */
tmp_rve.op=rve->op;
Module: sip-router
Branch: andrei/type_conversion
Commit: bb4d414574c35b1ba2c0497e19313b4cd000f775
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=bb4d414…
Author: Andrei Pelinescu-Onciul <andrei(a)iptel.org>
Committer: Andrei Pelinescu-Onciul <andrei(a)iptel.org>
Date: Tue Apr 28 19:54:03 2009 +0200
news: update (new operators, expr. eval behaviour a.s.o.)
---
NEWS | 27 +++++++++++++++++++++++++++
1 files changed, 27 insertions(+), 0 deletions(-)
diff --git a/NEWS b/NEWS
index fade123..ed1ab96 100644
--- a/NEWS
+++ b/NEWS
@@ -6,6 +6,33 @@ $Id$
sip-router changes
core:
+ - new operators eq, ne for string compares and ieq, ine for interger
+ compares. The names are not yet final (use them at your own risk).
+ Future version might use ==/!= only for ints (ieq/ine) and eq/ne for
+ strings (under debate).
+ They are almost equivalent to == or !=, but they force the conversion
+ of their operands (eq to string and ieq to int), allowing among other
+ things better type checking on startup and more optimizations.
+ Non equiv. examples: 0 == "" (true) is not equivalent to 0 eq ""
+ (false: it evaluates to "0" eq ""). "a" ieq "b" (true: (int)"a" is 0
+ and (int)"b" is 0) is not equivalent to "a" == "b" (false).
+ Note: internally == and != are converted on startup to eq/ne/ieq/ine
+ whenever possible (both operand types can be safely determined at
+ start time and they are the same).
+ - try to guess what the user wanted when operators that support multiple
+ types are used on different typed operands. In general convert the
+ the right operand to the type of the left operand and then perform the
+ operation. Exception: the left operand is undef.
+ This applies to the following operators: +, == and !=.
+ Special case: undef as left operand:
+ For +: undef + expr -> undef is converted to string => "" + expr.
+ For == and !=: undef == expr -> undef is converted to type_of expr.
+ If expr is undef, then undef == undef is true (internally is converted
+ to string).
+ - expression evaluation changes: auto-convert to interger or string
+ in function of the operators:
+ int(undef)==0, int("")==0, int("123")==123, int("abc")==0
+ str(undef)=="", str(123)=="123".
- new script operators: defined, strlen, strempty
defined expr - returns true if expr is defined, and false if not.
Note: only a standalone avp or pvar can be
Module: sip-router
Branch: master
Commit: 313f52655841f1abf4c0db585699cd31e9494a3f
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=313f526…
Author: Daniel-Constantin Mierla <miconda(a)gmail.com>
Committer: Daniel-Constantin Mierla <miconda(a)gmail.com>
Date: Tue Apr 28 16:35:28 2009 +0200
kex: script and branch flags operations
- K script and branch flags operations included in kex module
- the parameters must be now enclosed in quotes
- the parameters can be now integer value or Pseudo-Variable with
integer value
- the optional 'branch' parameter for branch flags parameters is now the
second, for a more logical parameter mapping with the version without
this parameter
---
modules_k/kex/flags.c | 144 +++++++++++++++++++++++++++++++++++++++++++++++
modules_k/kex/flags.h | 35 +++++++++++
modules_k/kex/kex_mod.c | 29 +++++++++-
3 files changed, 205 insertions(+), 3 deletions(-)
diff --git a/modules_k/kex/flags.c b/modules_k/kex/flags.c
new file mode 100644
index 0000000..ae539d1
--- /dev/null
+++ b/modules_k/kex/flags.c
@@ -0,0 +1,144 @@
+/**
+ * $Id$
+ *
+ * Copyright (C) 2009
+ *
+ * This file is part of SIP-Router.org, a free SIP server.
+ *
+ * SIP-Router is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version
+ *
+ * Kamailio is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+#include "../../dprint.h"
+#include "../../flags.h"
+#include "../../dset.h"
+#include "../../mod_fix.h"
+#include "flags.h"
+
+int w_issflagset(struct sip_msg *msg, char *flag, str *s2)
+{
+ int fval=0;
+ if(fixup_get_ivalue(msg, (gparam_p)flag, &fval)!=0)
+ {
+ LM_ERR("no flag value\n");
+ return -1;
+ }
+ if(fval<0 || fval>31)
+ return -1;
+ return issflagset((flag_t)fval);
+}
+
+int w_resetsflag(struct sip_msg *msg, char *flag, str *s2)
+{
+ int fval=0;
+ if(fixup_get_ivalue(msg, (gparam_p)flag, &fval)!=0)
+ {
+ LM_ERR("no flag value\n");
+ return -1;
+ }
+ if(fval<0 || fval>31)
+ return -1;
+ return resetsflag((flag_t)fval);
+}
+
+int w_setsflag(struct sip_msg *msg, char *flag, char *s2)
+{
+ int fval=0;
+ if(fixup_get_ivalue(msg, (gparam_p)flag, &fval)!=0)
+ {
+ LM_ERR("no flag value\n");
+ return -1;
+ }
+ if(fval<0 || fval>31)
+ return -1;
+ return setsflag((flag_t)fval);
+}
+
+int w_isbflagset(struct sip_msg *msg, char *flag, str *idx)
+{
+ int fval=0;
+ int ival=0;
+ if(fixup_get_ivalue(msg, (gparam_p)flag, &fval)!=0)
+ {
+ LM_ERR("no flag value\n");
+ return -1;
+ }
+ if(fval<0 || fval>31)
+ return -1;
+ if(idx!=0)
+ {
+ if(fixup_get_ivalue(msg, (gparam_p)idx, &ival)!=0)
+ {
+ LM_ERR("no idx value\n");
+ return -1;
+ }
+ if(ival<0)
+ return -1;
+ }
+ return isbflagset(ival, (flag_t)fval);
+}
+
+int w_resetbflag(struct sip_msg *msg, char *flag, str *idx)
+{
+ int fval=0;
+ int ival=0;
+ if(fixup_get_ivalue(msg, (gparam_p)flag, &fval)!=0)
+ {
+ LM_ERR("no flag value\n");
+ return -1;
+ }
+ if(fval<0 || fval>31)
+ return -1;
+ if(idx!=0)
+ {
+ if(fixup_get_ivalue(msg, (gparam_p)idx, &ival)!=0)
+ {
+ LM_ERR("no idx value\n");
+ return -1;
+ }
+ if(ival<0)
+ return -1;
+ }
+ return resetbflag(ival, (flag_t)fval);
+
+}
+
+int w_setbflag(struct sip_msg *msg, char *flag, char *idx)
+{
+ int fval=0;
+ int ival=0;
+ if(fixup_get_ivalue(msg, (gparam_p)flag, &fval)!=0)
+ {
+ LM_ERR("no flag value\n");
+ return -1;
+ }
+ if(fval<0 || fval>31)
+ return -1;
+ if(idx!=0)
+ {
+ if(fixup_get_ivalue(msg, (gparam_p)idx, &ival)!=0)
+ {
+ LM_ERR("no idx value\n");
+ return -1;
+ }
+ if(ival<0)
+ return -1;
+ }
+ return setbflag(ival, (flag_t)fval);
+}
+
diff --git a/modules_k/kex/flags.h b/modules_k/kex/flags.h
new file mode 100644
index 0000000..d0dbad4
--- /dev/null
+++ b/modules_k/kex/flags.h
@@ -0,0 +1,35 @@
+/**
+ * $Id$
+ *
+ * Copyright (C) 2009
+ *
+ * This file is part of SIP-Router.org, a free SIP server.
+ *
+ * SIP-Router is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version
+ *
+ * Kamailio is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#ifndef _KEX_FLAGS_H_
+#define _KEX_FLAGS_H_
+
+#include "../../sr_module.h"
+
+int w_issflagset(struct sip_msg *msg, char *flag, str *s2);
+int w_resetsflag(struct sip_msg *msg, char *flag, str *s2);
+int w_setsflag(struct sip_msg *msg, char *flag, char *s2);
+int w_isbflagset(struct sip_msg *msg, char *flag, str *idx);
+int w_resetbflag(struct sip_msg *msg, char *flag, str *idx);
+int w_setbflag(struct sip_msg *msg, char *flag, char *idx);
+
+#endif
diff --git a/modules_k/kex/kex_mod.c b/modules_k/kex/kex_mod.c
index c9c3ae3..e4960c0 100644
--- a/modules_k/kex/kex_mod.c
+++ b/modules_k/kex/kex_mod.c
@@ -3,9 +3,9 @@
*
* Copyright (C) 2009
*
- * This file is part of Kamailio, a free SIP server.
+ * This file is part of SIP-Router.org, a free SIP server.
*
- * Kamailio is free software; you can redistribute it and/or modify
+ * SIP-Router is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version
@@ -26,7 +26,11 @@
#include "../../sr_module.h"
#include "../../dprint.h"
+#include "../../flags.h"
+#include "../../dset.h"
+#include "../../mod_fix.h"
+#include "flags.h"
#include "mi_core.h"
#include "core_stats.h"
@@ -38,10 +42,28 @@ MODULE_VERSION
/** module functions */
static int mod_init(void);
-
void destroy(void);
static cmd_export_t cmds[]={
+ {"setsflag", (cmd_function)w_setsflag, 1,fixup_igp_null,
+ 0, ANY_ROUTE },
+ {"resetsflag", (cmd_function)w_resetsflag, 1,fixup_igp_null,
+ 0, ANY_ROUTE },
+ {"issflagset", (cmd_function)w_issflagset, 1,fixup_igp_null,
+ 0, ANY_ROUTE },
+ {"setbflag", (cmd_function)w_setbflag, 1,fixup_igp_null,
+ 0, ANY_ROUTE },
+ {"setbflag", (cmd_function)w_setbflag, 2,fixup_igp_igp,
+ 0, ANY_ROUTE },
+ {"resetbflag", (cmd_function)w_resetbflag, 1,fixup_igp_null,
+ 0, ANY_ROUTE },
+ {"resetbflag", (cmd_function)w_resetbflag, 2,fixup_igp_igp,
+ 0, ANY_ROUTE },
+ {"isbflagset", (cmd_function)w_isbflagset, 1,fixup_igp_null,
+ 0, ANY_ROUTE },
+ {"isbflagset", (cmd_function)w_isbflagset, 2,fixup_igp_igp,
+ 0, ANY_ROUTE },
+
{0,0,0,0,0,0}
};
@@ -93,3 +115,4 @@ void destroy(void)
return;
}
+