Commit 94e7ebf3 authored by Claes Sjofors's avatar Claes Sjofors

Adef flag PublicWrite added, and xtt script function SetAttribute()

parent d3a420fe
...@@ -72,6 +72,12 @@ public class GrowFrame implements GraphApplIfc { ...@@ -72,6 +72,12 @@ public class GrowFrame implements GraphApplIfc {
return 0; return 0;
} }
public int script(String script) {
if ( appl != null)
return appl.script(script);
return 0;
}
public void confirmNo() {} public void confirmNo() {}
public void confirmYes() {} public void confirmYes() {}
public void openConfirmDialog( Object dyn, String text, Object object) {} public void openConfirmDialog( Object dyn, String text, Object object) {}
......
include $(pwre_dir_symbols) include $(pwre_dir_symbols)
extern_java_sources := \ extern_java_sources := \
CcmApplIfc.java, \
CcmFloatvar.java, \
CcmIntvar.java, \
CcmStringvar.java, \
CcmLine.java, \
CcmReturn.java, \
CcmFileReturn.java, \
CcmArg.java, \
CcmVariable.java, \
CcmFunc.java, \
CcmOperand.java, \
CcmFuncCtx.java, \
CcmFileCtx.java, \
CcmRowCtx.java, \
CcmSysFunc.java, \
Ccm.java, \
JopgCcm.java, \
Glow.java,\ Glow.java,\
GlowCrypt.java, \ GlowCrypt.java, \
PrintfFormat.java,\ PrintfFormat.java,\
...@@ -44,6 +61,7 @@ extern_java_sources := \ ...@@ -44,6 +61,7 @@ extern_java_sources := \
GrowGroup.java,\ GrowGroup.java,\
GrowSlider.java,\ GrowSlider.java,\
GrowAxis.java,\ GrowAxis.java,\
GrowAxisArc.java,\
GrowArc.java,\ GrowArc.java,\
GrowLine.java,\ GrowLine.java,\
GrowPolyline.java,\ GrowPolyline.java,\
......
...@@ -47,7 +47,8 @@ import jpwr.rt.*; ...@@ -47,7 +47,8 @@ import jpwr.rt.*;
import jpwr.app.*; import jpwr.app.*;
import jpwr.jopg.*; import jpwr.jopg.*;
public class MainActivity extends Activity implements PlowAppl, GraphApplIfc, GdhApplIfc, OnClickListener, AEvAppl { public class MainActivity extends Activity implements PlowAppl, GraphApplIfc, GdhApplIfc, OnClickListener,
AEvAppl, CcmApplIfc {
static final int MODE_NO = 0; static final int MODE_NO = 0;
static final int MODE_SCROLL = 1; static final int MODE_SCROLL = 1;
static final int MODE_ZOOM = 2; static final int MODE_ZOOM = 2;
...@@ -2160,6 +2161,28 @@ System.out.println("MainActivity TimerTask " + currentCmn.type()); ...@@ -2160,6 +2161,28 @@ System.out.println("MainActivity TimerTask " + currentCmn.type());
return graph.loadSubgraph(reader); return graph.loadSubgraph(reader);
} }
public int externCmd( String cmd) {
return command( cmd);
}
public String defFilename( String filename) {
String fname = "http://" + pwrHost + "/" + pwrp_exe + filename;
if ( !fname.endsWith(".rtt_com"))
fname += ".rtt_com";
return fname;
}
public void errorMessage( String msg, int severity) {
}
public int confirmDialog( String title, String text) {
return 1;
}
public int getRootType() {
return Ccm.ROOT_AAPP;
}
public int script(String script) {
new JopgCcm( this, appl.gdh, null, script);
return 1;
}
static CliTable[] cliTable = new CliTable[] { static CliTable[] cliTable = new CliTable[] {
new CliTable( "OPEN", new String[] {"cli_arg1", "cli_arg2", "/NAME", new CliTable( "OPEN", new String[] {"cli_arg1", "cli_arg2", "/NAME",
"/FILE", "/SCROLLBAR", "/WIDTH", "/HEIGHT", "/MENU", "/NAVIGATOR", "/FILE", "/SCROLLBAR", "/WIDTH", "/HEIGHT", "/MENU", "/NAVIGATOR",
...@@ -2185,6 +2208,12 @@ System.out.println("MainActivity TimerTask " + currentCmn.type()); ...@@ -2185,6 +2208,12 @@ System.out.println("MainActivity TimerTask " + currentCmn.type());
return 0; return 0;
} }
if ( cmd.charAt(0) == '@') {
// Execute a script
new JopgCcm( this, gdh, cmd.substring(1), null);
return 1;
}
Cli cli = new Cli( cliTable); Cli cli = new Cli( cliTable);
String command = cli.parse( cmd); String command = cli.parse( cmd);
if (cli.oddSts()) { if (cli.oddSts()) {
......
...@@ -18,6 +18,7 @@ extern_java_sources := \ ...@@ -18,6 +18,7 @@ extern_java_sources := \
CliTable.java,\ CliTable.java,\
GdhApplIfc.java,\ GdhApplIfc.java,\
GdhrGetAttributeChar.java,\ GdhrGetAttributeChar.java,\
GdhrGetAttributeFlags.java,\
GdhrGetXttObj.java,\ GdhrGetXttObj.java,\
GdhrRefObjectInfo.java,\ GdhrRefObjectInfo.java,\
MhData.java,\ MhData.java,\
......
...@@ -165,6 +165,7 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_setObjectInfoInt ...@@ -165,6 +165,7 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_setObjectInfoInt
strcat( cstr, s1); strcat( cstr, s1);
} }
sts = gdh_SetObjectInfo( cstr, (void *) &val, sizeof(val)); sts = gdh_SetObjectInfo( cstr, (void *) &val, sizeof(val));
(*env)->ReleaseStringUTFChars( env, name, cstr); (*env)->ReleaseStringUTFChars( env, name, cstr);
jsts = (jint) sts; jsts = (jint) sts;
return_obj = (*env)->NewObject( env, pwrtStatus_id, return_obj = (*env)->NewObject( env, pwrtStatus_id,
...@@ -1642,6 +1643,7 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar ...@@ -1642,6 +1643,7 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar
unsigned int elements; unsigned int elements;
unsigned int offset; unsigned int offset;
pwr_eType type_id; pwr_eType type_id;
pwr_tAttrRef aref;
gdhrGetAttributeChar_id = (*env)->FindClass( env, gdhrGetAttributeChar_id = (*env)->FindClass( env,
"jpwr/rt/GdhrGetAttributeChar"); "jpwr/rt/GdhrGetAttributeChar");
...@@ -1652,8 +1654,11 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar ...@@ -1652,8 +1654,11 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar
cstr = (char *)str; cstr = (char *)str;
gdh_ConvertUTFstring( cstr, cstr); gdh_ConvertUTFstring( cstr, cstr);
sts = gdh_GetAttributeCharacteristics( cstr, &type_id, &size, &offset, sts = gdh_NameToAttrref( pwr_cNObjid, cstr, &aref);
if ( ODD(sts))
sts = gdh_GetAttributeCharAttrref( &aref, &type_id, &size, &offset,
&elements); &elements);
(*env)->ReleaseStringUTFChars( env, name, cstr); (*env)->ReleaseStringUTFChars( env, name, cstr);
jsts = (jint) sts; jsts = (jint) sts;
...@@ -1663,6 +1668,40 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar ...@@ -1663,6 +1668,40 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar
return return_obj; return return_obj;
} }
JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeFlags
(JNIEnv *env, jobject obj, jstring name)
{
int sts;
const char *str;
char *cstr;
jobject return_obj;
jint jsts;
jclass gdhrGetAttributeFlags_id;
jmethodID gdhrGetAttributeFlags_cid;
unsigned int flags;
pwr_tAttrRef aref;
gdhrGetAttributeFlags_id = (*env)->FindClass( env,
"jpwr/rt/GdhrGetAttributeFlags");
gdhrGetAttributeFlags_cid = (*env)->GetMethodID( env,
gdhrGetAttributeFlags_id, "<init>", "(II)V");
str = (*env)->GetStringUTFChars( env, name, 0);
cstr = (char *)str;
gdh_ConvertUTFstring( cstr, cstr);
sts = gdh_NameToAttrref( pwr_cNObjid, cstr, &aref);
if ( ODD(sts))
sts = gdh_GetAttributeFlags( &aref, &flags);
(*env)->ReleaseStringUTFChars( env, name, cstr);
jsts = (jint) sts;
return_obj = (*env)->NewObject( env, gdhrGetAttributeFlags_id,
gdhrGetAttributeFlags_cid, (jint)flags, jsts);
return return_obj;
}
JNIEXPORT jstring JNICALL Java_jpwr_rt_Gdh_translateFilename JNIEXPORT jstring JNICALL Java_jpwr_rt_Gdh_translateFilename
(JNIEnv *env, jclass obj, jstring filename) (JNIEnv *env, jclass obj, jstring filename)
{ {
......
...@@ -319,6 +319,14 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getNodeObject ...@@ -319,6 +319,14 @@ JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getNodeObject
JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeChar
(JNIEnv *, jobject, jstring); (JNIEnv *, jobject, jstring);
/*
* Class: jpwr_rt_Gdh
* Method: getAttributeFlags
* Signature: (Ljava/lang/String;)Ljpwr/rt/GdhrGetAttributeFlags;
*/
JNIEXPORT jobject JNICALL Java_jpwr_rt_Gdh_getAttributeFlags
(JNIEnv *, jobject, jstring);
/* /*
* Class: jpwr_rt_Gdh * Class: jpwr_rt_Gdh
* Method: getClassAttribute * Method: getClassAttribute
......
...@@ -88,10 +88,10 @@ public class JopSpider { ...@@ -88,10 +88,10 @@ public class JopSpider {
} }
} }
private static class JopCcmCb implements CcmApplIfc { private static class JopgCcmCb implements CcmApplIfc {
JopSession session; JopSession session;
JopCcmCb( JopSession session) { JopgCcmCb( JopSession session) {
this.session = session; this.session = session;
} }
...@@ -130,8 +130,11 @@ public class JopSpider { ...@@ -130,8 +130,11 @@ public class JopSpider {
System.out.println( "Confirm dialoga: " + title + ", " + text); System.out.println( "Confirm dialoga: " + title + ", " + text);
return 1; return 1;
} }
public Object getRoot() { public int getRootType() {
return session.getRoot(); if ( session.getRoot() instanceof JopApplet)
return Ccm.ROOT_APPLET;
else
return Ccm.ROOT_FRAME;
} }
} }
...@@ -195,7 +198,7 @@ public class JopSpider { ...@@ -195,7 +198,7 @@ public class JopSpider {
// Execute a script // Execute a script
Gdh gdh = session.getEngine().gdh; Gdh gdh = session.getEngine().gdh;
new JopCcm( new JopCcmCb(session), gdh, null, script); new JopgCcm( new JopgCcmCb(session), gdh, null, script);
return 1; return 1;
} }
...@@ -214,7 +217,7 @@ public class JopSpider { ...@@ -214,7 +217,7 @@ public class JopSpider {
if ( cmd.charAt(0) == '@') { if ( cmd.charAt(0) == '@') {
// Execute a script // Execute a script
new JopCcm( new JopCcmCb(session), gdh, cmd.substring(1), null); new JopgCcm( new JopgCcmCb(session), gdh, cmd.substring(1), null);
return 1; return 1;
} }
......
...@@ -9,23 +9,6 @@ local_java_sources := \ ...@@ -9,23 +9,6 @@ local_java_sources := \
GeColor.java \ GeColor.java \
JopDynamic.java \ JopDynamic.java \
LocalDb.java \ LocalDb.java \
CcmApplIfc.java \
CcmFloatvar.java \
CcmIntvar.java \
CcmStringvar.java \
CcmLine.java \
CcmReturn.java \
CcmFileReturn.java \
CcmArg.java \
CcmVariable.java \
CcmFunc.java \
CcmOperand.java \
CcmFuncCtx.java \
CcmFileCtx.java \
CcmRowCtx.java \
CcmSysFunc.java \
Ccm.java \
JopCcm.java \
JopCrypt.java \ JopCrypt.java \
JopEngine.java \ JopEngine.java \
JopSessionIfc.java \ JopSessionIfc.java \
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
import java.util.Vector; import java.util.Vector;
import java.util.Scanner; import java.util.Scanner;
import java.util.Calendar; import java.util.Calendar;
...@@ -45,6 +45,10 @@ import java.net.*; ...@@ -45,6 +45,10 @@ import java.net.*;
public class Ccm { public class Ccm {
static final boolean ccm_testmode = false; static final boolean ccm_testmode = false;
public static final int ROOT_APPLET = 1;
public static final int ROOT_FRAME = 2;
public static final int ROOT_AAPP = 3;
public static final int CCM__SUCCESS = 1; public static final int CCM__SUCCESS = 1;
public static final int CCM__EXITFUNC = 3; public static final int CCM__EXITFUNC = 3;
public static final int CCM__EXPRESSION = 2; public static final int CCM__EXPRESSION = 2;
...@@ -995,7 +999,8 @@ public class Ccm { ...@@ -995,7 +999,8 @@ public class Ccm {
try { try {
BufferedReader reader; BufferedReader reader;
if ( filectx.appl != null && filectx.appl.getRoot() instanceof JopApplet) { if ( filectx.appl != null &&
(filectx.appl.getRootType() == ROOT_APPLET || filectx.appl.getRootType() == ROOT_AAPP)) {
URL fileURL = new URL( filename); URL fileURL = new URL( filename);
InputStream in = fileURL.openStream(); InputStream in = fileURL.openStream();
InputStreamReader r2 = new InputStreamReader(in, "ISO-8859-1"); InputStreamReader r2 = new InputStreamReader(in, "ISO-8859-1");
......
...@@ -34,13 +34,13 @@ ...@@ -34,13 +34,13 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public interface CcmApplIfc { public interface CcmApplIfc {
public int externCmd( String cmd); public int externCmd( String cmd);
public String defFilename( String filename); public String defFilename( String filename);
public void errorMessage( String msg, int severity); public void errorMessage( String msg, int severity);
public int confirmDialog( String title, String text); public int confirmDialog( String title, String text);
public Object getRoot(); public int getRootType();
} }
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmArg { public class CcmArg {
public CcmArg() { public CcmArg() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
import java.util.Vector; import java.util.Vector;
public class CcmFileCtx { public class CcmFileCtx {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmFileReturn { public class CcmFileReturn {
public CcmFileReturn() { public CcmFileReturn() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmFloatvar { public class CcmFloatvar {
public CcmFloatvar() { public CcmFloatvar() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmFunc { public class CcmFunc {
public CcmFunc() { public CcmFunc() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
import java.util.Vector; import java.util.Vector;
public class CcmFuncCtx { public class CcmFuncCtx {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmIntvar { public class CcmIntvar {
public CcmIntvar() { public CcmIntvar() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmLine { public class CcmLine {
public CcmLine( String line, int row) { public CcmLine( String line, int row) {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmOperand { public class CcmOperand {
public CcmOperand() { public CcmOperand() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmReturn { public class CcmReturn {
public CcmReturn() { public CcmReturn() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
import java.util.Vector; import java.util.Vector;
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmStringvar { public class CcmStringvar {
public CcmStringvar() { public CcmStringvar() {
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmSysFunc { public class CcmSysFunc {
public String name; public String name;
......
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
public class CcmVariable { public class CcmVariable {
public CcmVariable() { public CcmVariable() {
......
...@@ -34,16 +34,16 @@ ...@@ -34,16 +34,16 @@
* General Public License plus this exception. * General Public License plus this exception.
*/ */
package jpwr.jop; package jpwr.jopg;
import jpwr.rt.*; import jpwr.rt.*;
public class JopCcm { public class JopgCcm {
Gdh gdh; Gdh gdh;
Ccm ccm; Ccm ccm;
CcmApplIfc appl; CcmApplIfc appl;
public JopCcm( CcmApplIfc appl, Gdh gdh, String cmd, String script) { public JopgCcm( CcmApplIfc appl, Gdh gdh, String cmd, String script) {
this.gdh = gdh; this.gdh = gdh;
this.appl = appl; this.appl = appl;
...@@ -58,6 +58,7 @@ public class JopCcm { ...@@ -58,6 +58,7 @@ public class JopCcm {
ccm.registerFunction( new CcmFuncGetChild("GetChild")); ccm.registerFunction( new CcmFuncGetChild("GetChild"));
ccm.registerFunction( new CcmFuncGetNextSibling("GetNextSibling")); ccm.registerFunction( new CcmFuncGetNextSibling("GetNextSibling"));
ccm.registerFunction( new CcmFuncGetAttribute("GetAttribute")); ccm.registerFunction( new CcmFuncGetAttribute("GetAttribute"));
ccm.registerFunction( new CcmFuncSetAttribute("SetAttribute"));
ccm.registerFunction( new CcmFuncMessageError("MessageError")); ccm.registerFunction( new CcmFuncMessageError("MessageError"));
ccm.registerFunction( new CcmFuncMessageInfo("MessageInfo")); ccm.registerFunction( new CcmFuncMessageInfo("MessageInfo"));
ccm.registerFunction( new CcmFuncConfirmDialog("ConfirmDialog")); ccm.registerFunction( new CcmFuncConfirmDialog("ConfirmDialog"));
...@@ -475,6 +476,153 @@ public class JopCcm { ...@@ -475,6 +476,153 @@ public class JopCcm {
} }
} }
public class CcmFuncSetAttribute extends CcmSysFunc {
public CcmFuncSetAttribute( String name) {
super(name);
}
public CcmReturn func( CcmFileCtx filectx, CcmArg[] args) {
int sts;
CcmReturn ret = new CcmReturn();
boolean publicwrite = false;
if ( !(args.length == 2 || args.length == 3)) {
ret.sts = Ccm.CCM__ARGMISM;
return ret;
}
if ( args[0].value_decl != Ccm.K_DECL_STRING) {
ret.sts = Ccm.CCM__VARTYPE;
return ret;
}
if ( args.length == 3 ) {
if ( args[2].value_decl != Ccm.K_DECL_INT) {
ret.sts = Ccm.CCM__ARGMISM;
return ret;
}
if ( args[2].value_int == 1)
publicwrite = true;
}
// Check authorization
boolean authorized = false;
if ( publicwrite) {
GdhrGetAttributeFlags retf = gdh.getAttributeFlags( args[0].value_string);
if ( Ccm.EVEN(retf.sts)) {
ret.decl = Ccm.K_DECL_INT;
ret.rint = retf.sts;
return ret;
}
if ( (retf.flags & Pwr.mAdef_publicwrite) != 0 &&
gdh.isAuthorized( Pwr.mPrv_RtRead | Pwr.mPrv_RtWrite | Pwr.mPrv_System |
Pwr.mPrv_Maintenance | Pwr.mPrv_Process |
Pwr.mPrv_Operator1 | Pwr.mPrv_Operator2 |
Pwr.mPrv_Operator3 | Pwr.mPrv_Operator4 |
Pwr.mPrv_Operator5 | Pwr.mPrv_Operator6 |
Pwr.mPrv_Operator7 | Pwr.mPrv_Operator8 |
Pwr.mPrv_Operator9 | Pwr.mPrv_Operator10))
authorized = true;
}
else {
if ( gdh.isAuthorized( Pwr.mPrv_RtWrite | Pwr.mPrv_System))
authorized = true;
}
if ( !authorized) {
ret.decl = Ccm.K_DECL_INT;
ret.rint = 0;
return ret;
}
GdhrGetAttributeChar retc = gdh.getAttributeChar( args[0].value_string);
if ( Ccm.EVEN(retc.sts)) {
ret.decl = Ccm.K_DECL_INT;
ret.rint = retc.sts;
return ret;
}
PwrtStatus rsts = null;
switch ( args[1].value_decl) {
case Ccm.K_DECL_STRING: {
rsts = gdh.setObjectInfo( args[0].value_string, args[1].value_string);
break;
}
case Ccm.K_DECL_INT: {
switch ( retc.typeId) {
case Pwr.eType_Int8:
case Pwr.eType_Int16:
case Pwr.eType_Int32:
case Pwr.eType_Int64:
case Pwr.eType_UInt8:
case Pwr.eType_UInt16:
case Pwr.eType_UInt32:
case Pwr.eType_UInt64:
case Pwr.eType_Enum:
case Pwr.eType_Mask:
case Pwr.eType_Status:
case Pwr.eType_NetStatus: {
int val = args[1].value_int;
System.out.println( "setObjectInfo val " + val);
rsts = gdh.setObjectInfo( args[0].value_string, val);
System.out.println( "setObjectInfo sts " + rsts.getSts());
break;
}
case Pwr.eType_Float32:
case Pwr.eType_Float64: {
float val = args[1].value_int;
rsts = gdh.setObjectInfo( args[0].value_string, val);
break;
}
case Pwr.eType_Boolean: {
boolean val = (args[1].value_int == 0 ? false : true);
rsts = gdh.setObjectInfo( args[0].value_string, val);
break;
}
}
break;
}
case Ccm.K_DECL_FLOAT: {
switch ( retc.typeId) {
case Pwr.eType_Int8:
case Pwr.eType_Int16:
case Pwr.eType_Int32:
case Pwr.eType_Int64:
case Pwr.eType_UInt8:
case Pwr.eType_UInt16:
case Pwr.eType_UInt32:
case Pwr.eType_UInt64:
case Pwr.eType_Enum:
case Pwr.eType_Mask:
case Pwr.eType_Status:
case Pwr.eType_NetStatus: {
int val = (int)args[1].value_float;
rsts = gdh.setObjectInfo( args[0].value_string, val);
break;
}
case Pwr.eType_Float32:
case Pwr.eType_Float64: {
float val = args[1].value_float;
rsts = gdh.setObjectInfo( args[0].value_string, val);
break;
}
case Pwr.eType_Boolean: {
boolean val = (args[1].value_float == 0 ? false : true);
rsts = gdh.setObjectInfo( args[0].value_string, val);
break;
}
}
break;
}
}
ret.decl = Ccm.K_DECL_INT;
if ( rsts == null)
ret.rint = 0;
else
ret.rint = rsts.getSts();
return ret;
}
}
public class CcmFuncMessageError extends CcmSysFunc { public class CcmFuncMessageError extends CcmSysFunc {
public CcmFuncMessageError( String name) { public CcmFuncMessageError( String name) {
super(name); super(name);
......
include $(pwre_dir_symbols) include $(pwre_dir_symbols)
local_java_sources := \ local_java_sources := \
CcmApplIfc.java, \
CcmFloatvar.java, \
CcmIntvar.java, \
CcmStringvar.java, \
CcmLine.java, \
CcmReturn.java, \
CcmFileReturn.java, \
CcmArg.java, \
CcmVariable.java, \
CcmFunc.java, \
CcmOperand.java, \
CcmFuncCtx.java, \
CcmFileCtx.java, \
CcmRowCtx.java, \
CcmSysFunc.java, \
Ccm.java, \
JopgCcm.java, \
Glow.java,\ Glow.java,\
PrintfFormat.java,\ PrintfFormat.java,\
GlowCFormat.java,\ GlowCFormat.java,\
......
...@@ -642,6 +642,12 @@ public class Gdh { ...@@ -642,6 +642,12 @@ public class Gdh {
*/ */
public native GdhrGetAttributeChar getAttributeChar( String attributeName); public native GdhrGetAttributeChar getAttributeChar( String attributeName);
/**
Get the flags of an attribute, given
its name and the class it belongs to.
*/
public native GdhrGetAttributeFlags getAttributeFlags( String attributeName);
/** /**
Get information of all attributes in a class. Get information of all attributes in a class.
*/ */
......
...@@ -112,6 +112,8 @@ public class GdhServer ...@@ -112,6 +112,8 @@ public class GdhServer
public final static int GET_OBJECT_INFO_INT_ARRAY = 58; public final static int GET_OBJECT_INFO_INT_ARRAY = 58;
public final static int GET_CIRCBUFF_INFO = 59; public final static int GET_CIRCBUFF_INFO = 59;
public final static int UPDATE_CIRCBUFF_INFO = 60; public final static int UPDATE_CIRCBUFF_INFO = 60;
public final static int GET_ATTRIBUTE_FLAGS = 61;
public final static int CLASSNAME_TO_ID = 62;
public final static int PORT = 4445; public final static int PORT = 4445;
...@@ -1249,6 +1251,23 @@ public class GdhServer ...@@ -1249,6 +1251,23 @@ public class GdhServer
System.out.println("getAttrRefTid: IO exception"); System.out.println("getAttrRefTid: IO exception");
} }
break; break;
case CLASSNAME_TO_ID:
try
{
String name = in.readUTF();
CdhrClassId ret = gdh.classNameToId(name);
out.writeInt(ret.getSts());
if(ret.oddSts())
{
out.writeInt(ret.classId);
}
out.flush();
}
catch(IOException e)
{
System.out.println("classNameToId: IO exception");
}
break;
case GET_CLASS_LIST: case GET_CLASS_LIST:
try try
{ {
...@@ -1404,6 +1423,24 @@ public class GdhServer ...@@ -1404,6 +1423,24 @@ public class GdhServer
System.out.println("getAttributeChar: IO exception"); System.out.println("getAttributeChar: IO exception");
} }
break; break;
case GET_ATTRIBUTE_FLAGS:
try
{
String attrName = in.readUTF();
GdhrGetAttributeFlags ret = gdh.getAttributeFlags(attrName);
out.writeInt(ret.getSts());
out.flush();
if(ret.oddSts())
{
out.writeInt(ret.flags);
out.flush();
}
}
catch(IOException e)
{
System.out.println("getAttributeFlags: IO exception");
}
break;
case CREATE_INSTANCE_FILE: case CREATE_INSTANCE_FILE:
try try
{ {
......
/*
* Proview Open Source Process Control.
* Copyright (C) 2005-2015 SSAB EMEA AB.
*
* This file is part of Proview.
*
* This program 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.
*
* This program 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 Proview. If not, see <http://www.gnu.org/licenses/>
*
* Linking Proview statically or dynamically with other modules is
* making a combined work based on Proview. Thus, the terms and
* conditions of the GNU General Public License cover the whole
* combination.
*
* In addition, as a special exception, the copyright holders of
* Proview give you permission to, from the build function in the
* Proview Configurator, combine Proview with modules generated by the
* Proview PLC Editor to a PLC program, regardless of the license
* terms of these modules. You may copy and distribute the resulting
* combined work under the terms of your choice, provided that every
* copy of the combined work is accompanied by a complete copy of
* the source code of Proview (the version used to produce the
* combined work), being distributed under the terms of the GNU
* General Public License plus this exception.
*/
package jpwr.rt;
import java.io.Serializable;
/**
Return class for functions returning attribute characteristics.
Contains a return status and attribute characteristics.
*/
public class GdhrGetAttributeFlags implements Serializable
{
public int flags;
public int sts;
public GdhrGetAttributeFlags( int flags, int sts) {
this.flags = flags;
this.sts = sts;
}
/** Check if status is even. */
public boolean evenSts() { return (sts % 2 == 0);}
/** Check if status is odd. */
public boolean oddSts() { return (sts % 2 == 1);}
/** Get the status. */
public int getSts() { return sts;}
}
...@@ -192,7 +192,7 @@ public class Pwr { ...@@ -192,7 +192,7 @@ public class Pwr {
public static final int mAdef_rtvirtual = 1 << 6; /* 64 */ public static final int mAdef_rtvirtual = 1 << 6; /* 64 */
public static final int mAdef_devbodyref = 1 << 7; /* 128 */ public static final int mAdef_devbodyref = 1 << 7; /* 128 */
public static final int mAdef_dynamic = 1 << 8; /* 256 */ public static final int mAdef_dynamic = 1 << 8; /* 256 */
public static final int mAdef_objidself = 1 << 9; /* 512 */ public static final int mAdef_publicwrite = 1 << 9; /* 512 */
public static final int mAdef_noedit = 1 << 10; /* 1024 */ public static final int mAdef_noedit = 1 << 10; /* 1024 */
public static final int mAdef_invisible = 1 << 11; /* 2048 */ public static final int mAdef_invisible = 1 << 11; /* 2048 */
public static final int mAdef_refdirect = 1 << 12; /* 4096 If an AttrRef should not give alue pointed to */ public static final int mAdef_refdirect = 1 << 12; /* 4096 If an AttrRef should not give alue pointed to */
......
...@@ -29,6 +29,7 @@ local_java_sources = \ ...@@ -29,6 +29,7 @@ local_java_sources = \
RtSecurity.java \ RtSecurity.java \
GdhrRefObjectInfo.java \ GdhrRefObjectInfo.java \
GdhrGetAttributeChar.java \ GdhrGetAttributeChar.java \
GdhrGetAttributeFlags.java \
GdhrGetXttObj.java \ GdhrGetXttObj.java \
CdhrObjAttr.java \ CdhrObjAttr.java \
PwrsParInfo.java \ PwrsParInfo.java \
......
...@@ -100,6 +100,8 @@ public class Gdh ...@@ -100,6 +100,8 @@ public class Gdh
public final static int GET_OBJECT_INFO_INT_ARRAY = 58; public final static int GET_OBJECT_INFO_INT_ARRAY = 58;
public final static int GET_CIRCBUFF_INFO = 59; public final static int GET_CIRCBUFF_INFO = 59;
public final static int UPDATE_CIRCBUFF_INFO = 60; public final static int UPDATE_CIRCBUFF_INFO = 60;
public final static int GET_ATTRIBUTE_FLAGS = 61;
public final static int CLASSNAME_TO_ID = 62;
...@@ -1326,6 +1328,27 @@ public class Gdh ...@@ -1326,6 +1328,27 @@ public class Gdh
} }
} }
public CdhrClassId classNameToId(String name)
{
try
{
out.writeInt(CLASSNAME_TO_ID);
out.writeUTF(name);
out.flush();
int sts = in.readInt();
if(sts % 2 == 0)
{
return new CdhrClassId(0, sts);
}
int classId = in.readInt();
return new CdhrClassId(classId, sts);
}
catch(IOException e)
{
return new CdhrClassId(0, __IO_EXCEPTION);
}
}
private void getDefaultPrivilege() { private void getDefaultPrivilege() {
CdhrObjid oretSec = getClassList( Pwrs.cClass_Security); CdhrObjid oretSec = getClassList( Pwrs.cClass_Security);
...@@ -1629,6 +1652,29 @@ public class Gdh ...@@ -1629,6 +1652,29 @@ public class Gdh
} }
public GdhrGetAttributeFlags getAttributeFlags(String attributeName)
{
try
{
out.writeInt(GET_ATTRIBUTE_FLAGS);
out.writeUTF(attributeName);
out.flush();
int sts = in.readInt();
if(sts % 2 == 0)
{
return new GdhrGetAttributeFlags(0, sts);
}
int flags = in.readInt();
return new GdhrGetAttributeFlags(flags, sts);
}
catch(IOException e)
{
return new GdhrGetAttributeFlags(0, __IO_EXCEPTION);
}
}
public CdhrObjAttr getClassAttribute(int classid, PwrtObjid objid_obj) public CdhrObjAttr getClassAttribute(int classid, PwrtObjid objid_obj)
{ {
try try
......
...@@ -2778,6 +2778,7 @@ tolower() <LINK> tolower() ...@@ -2778,6 +2778,7 @@ tolower() <LINK> tolower()
<h2>Database functions <h2>Database functions
GetAttribute() <LINK> getattribute() GetAttribute() <LINK> getattribute()
SetAttribute() <LINK> setattribute()
GetChild() <LINK> getchild() GetChild() <LINK> getchild()
GetParent() <LINK> getparent() GetParent() <LINK> getparent()
GetNextSibling() <LINK> getnextsibling() GetNextSibling() <LINK> getnextsibling()
...@@ -3748,6 +3749,7 @@ Database functions ...@@ -3748,6 +3749,7 @@ Database functions
<b>Function <t>Description <b>Function <t>Description
GetAttribute() <t>Get attribute value. <LINK> getattribute() GetAttribute() <t>Get attribute value. <LINK> getattribute()
SetAttribute() <t>SGet attribute value. <LINK> setattribute()
GetChild() <t>Get object child. <LINK> getchild() GetChild() <t>Get object child. <LINK> getchild()
GetParent() <t>Get object parent. <LINK> getparent() GetParent() <t>Get object parent. <LINK> getparent()
GetNextSibling()<t>Get object sibling. <LINK> getnextsibling() GetNextSibling()<t>Get object sibling. <LINK> getnextsibling()
...@@ -3786,6 +3788,40 @@ int <t>status <t>status of operation. Returned. If zero, the ...@@ -3786,6 +3788,40 @@ int <t>status <t>status of operation. Returned. If zero, the
<c> say("Could not find motor on attribute!"); <c> say("Could not find motor on attribute!");
</TOPIC> </TOPIC>
<TOPIC> setattribute() <style> function
SetAttribute()
int SetAttribute( string name, (arbitrary type)value [, int publicwrite])
<b>Description
Set the value of the specified attribute.
To set the value of a normal attribute the RtWrite privilege is required. It is
though possible to write to attributes defined as PublicWrite without this
privilege, if the publicwrite argument is added. PublicWrite attribute can be
found in the PublicAv, PublicIv and PublicDv classes.
Returns the status of the operation.
<b>Arguments
string <t>name <t>name of the attribute to write to.
<arbitrary type)<t>value <t>the value to set.
int <t>publicwrite <t>if 1, write to and attribute defined as PublicWrite
<t> <t>is allowed also without the RtWrite privilege.
<b>Example
<c> float value = 22.2;
<c> int sts;
<c> sts = SetAttribute("Roller-Motor-Reference.ActualValue", value);
<c> if ( !(sts & 1))
<c> printf( "SetAttribute error %d\n", sts);
<c> endif
</TOPIC>
<TOPIC> getchild() <style> function <TOPIC> getchild() <style> function
GetChild() GetChild()
......
...@@ -2551,6 +2551,7 @@ tolower() <LINK> tolower() ...@@ -2551,6 +2551,7 @@ tolower() <LINK> tolower()
<h2>Databas funktioner <h2>Databas funktioner
GetAttribute() <LINK> getattribute() GetAttribute() <LINK> getattribute()
SetAttribute() <LINK> setattribute()
GetChild() <LINK> getchild() GetChild() <LINK> getchild()
GetParent() <LINK> getparent() GetParent() <LINK> getparent()
GetNextSibling() <LINK> getnextsibling() GetNextSibling() <LINK> getnextsibling()
...@@ -3511,6 +3512,7 @@ Databas funktioner ...@@ -3511,6 +3512,7 @@ Databas funktioner
<b>Function <t>Description <b>Function <t>Description
GetAttribute() <t>Hämta värde för ett attribut. <LINK> getattribute() GetAttribute() <t>Hämta värde för ett attribut. <LINK> getattribute()
SetAttribute() <t>Sätt värde på ett attribut. <LINK> setattribute()
GetChild() <t>Hämta barn till ett objekt. <LINK> getchild() GetChild() <t>Hämta barn till ett objekt. <LINK> getchild()
GetParent() <t>Hämta föräder till ett objekt. <LINK> getparent() GetParent() <t>Hämta föräder till ett objekt. <LINK> getparent()
GetNextSibling()<t>Hämta syskon för ett objekt. <LINK> getnextsibling() GetNextSibling()<t>Hämta syskon för ett objekt. <LINK> getnextsibling()
...@@ -3549,6 +3551,40 @@ int <t>status <t>status f ...@@ -3549,6 +3551,40 @@ int <t>status <t>status f
<c> say("Could not find motor on attribute!"); <c> say("Could not find motor on attribute!");
</TOPIC> </TOPIC>
<TOPIC> setattribute() <style> function
SetAttribute()
int SetAttribute( string name, (arbitrary type)value [, int publicwrite])
<b>Beskrivning
Sätt värdet på angivet attribut.
För att sätta värdet på ett vanligt attribut krävs RtWrite privilegiet. Det är
dock möjligt skriva till attribute som är definierade som PublicWrite även utan
detta privilegie, om publicwrite argumentet anges. PublicWrite attribut can bl a
hittas i klasserna PublicAv, PublicIv och PublicDv.
Returnerar status av operationen.
<b>Argument
string <t>name <t>namn på attributet som ska sättas.
<godtycklig typ)<t>value <t>värde som ska sättas.
int <t>publicwrite <t>om 1, skrivning till ett attribut definierad som PublicWrite
<t> <t>är tillåtet även utan RtWrite privilegiet.
<b>Exempel
<c> float value = 22.2;
<c> int sts;
<c> sts = SetAttribute("Roller-Motor-Reference.ActualValue", value);
<c> if ( !(sts & 1))
<c> printf( "SetAttribute error %d\n", sts);
<c> endif
</TOPIC>
<TOPIC> getchild() <style> function <TOPIC> getchild() <style> function
GetChild() GetChild()
......
...@@ -1327,7 +1327,7 @@ char *CnvReadWbl::flags_to_string( int value) ...@@ -1327,7 +1327,7 @@ char *CnvReadWbl::flags_to_string( int value)
if ( value & pwr_mAdef_rtvirtual) strcat( str, "Rtvirtual|"); if ( value & pwr_mAdef_rtvirtual) strcat( str, "Rtvirtual|");
if ( value & pwr_mAdef_devbodyref) strcat( str, "Devbodyref|"); if ( value & pwr_mAdef_devbodyref) strcat( str, "Devbodyref|");
if ( value & pwr_mAdef_dynamic) strcat( str, "Dynamic|"); if ( value & pwr_mAdef_dynamic) strcat( str, "Dynamic|");
if ( value & pwr_mAdef_objidself) strcat( str, "Objidself|"); if ( value & pwr_mAdef_publicwrite) strcat( str, "PubicWrite|");
if ( value & pwr_mAdef_noedit) strcat( str, "Noedit|"); if ( value & pwr_mAdef_noedit) strcat( str, "Noedit|");
if ( value & pwr_mAdef_invisible) strcat( str, "Invisible|"); if ( value & pwr_mAdef_invisible) strcat( str, "Invisible|");
if ( value & pwr_mAdef_refdirect) strcat( str, "Refdirect|"); if ( value & pwr_mAdef_refdirect) strcat( str, "Refdirect|");
......
...@@ -713,7 +713,7 @@ union pwr_m_Adef { ...@@ -713,7 +713,7 @@ union pwr_m_Adef {
pwr_Bits( devbodyref, 1), pwr_Bits( devbodyref, 1),
pwr_Bits( dynamic , 1), pwr_Bits( dynamic , 1),
pwr_Bits( objidself , 1), pwr_Bits( publicwrite , 1),
pwr_Bits( noedit , 1), pwr_Bits( noedit , 1),
pwr_Bits( invisible , 1), pwr_Bits( invisible , 1),
pwr_Bits( refdirect , 1), pwr_Bits( refdirect , 1),
...@@ -744,7 +744,7 @@ union pwr_m_Adef { ...@@ -744,7 +744,7 @@ union pwr_m_Adef {
#define pwr_mAdef_rtvirtual pwr_Bit(6) /* 64 */ #define pwr_mAdef_rtvirtual pwr_Bit(6) /* 64 */
#define pwr_mAdef_devbodyref pwr_Bit(7) /* 128 */ #define pwr_mAdef_devbodyref pwr_Bit(7) /* 128 */
#define pwr_mAdef_dynamic pwr_Bit(8) /* 256 */ #define pwr_mAdef_dynamic pwr_Bit(8) /* 256 */
#define pwr_mAdef_objidself pwr_Bit(9) /* 512 */ #define pwr_mAdef_publicwrite pwr_Bit(9) /* 512 */
#define pwr_mAdef_noedit pwr_Bit(10) /* 1024 */ #define pwr_mAdef_noedit pwr_Bit(10) /* 1024 */
#define pwr_mAdef_invisible pwr_Bit(11) /* 2048 */ #define pwr_mAdef_invisible pwr_Bit(11) /* 2048 */
#define pwr_mAdef_refdirect pwr_Bit(12) /* 4096 If an AttrRef should not give alue pointed to */ #define pwr_mAdef_refdirect pwr_Bit(12) /* 4096 If an AttrRef should not give alue pointed to */
...@@ -772,8 +772,7 @@ union pwr_m_Adef { ...@@ -772,8 +772,7 @@ union pwr_m_Adef {
#define PWR_MASK_RTVIRTUAL pwr_mAdef_rtvirtual #define PWR_MASK_RTVIRTUAL pwr_mAdef_rtvirtual
#define PWR_MASK_DEVBODYREF pwr_mAdef_devbodyref #define PWR_MASK_DEVBODYREF pwr_mAdef_devbodyref
#define PWR_MASK_DYNAMIC pwr_mAdef_dynamic #define PWR_MASK_DYNAMIC pwr_mAdef_dynamic
#define PWR_MASK_OBJDIDSELF pwr_mAdef_objidself #define PWR_MASK_PUBLICWRITE pwr_mAdef_publicwrite
#define PWR_MASK_OBJIDSELF pwr_mAdef_objidself
#define PWR_MASK_NOEDIT pwr_mAdef_noedit #define PWR_MASK_NOEDIT pwr_mAdef_noedit
#define PWR_MASK_INVISIBLE pwr_mAdef_invisible #define PWR_MASK_INVISIBLE pwr_mAdef_invisible
#define PWR_MASK_REFDIRECT pwr_mAdef_refdirect #define PWR_MASK_REFDIRECT pwr_mAdef_refdirect
......
...@@ -665,7 +665,6 @@ SObject pwrb:Class ...@@ -665,7 +665,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 35 Object TimerObjDId $Intern 35
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -647,7 +647,6 @@ SObject pwrb:Class ...@@ -647,7 +647,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Attribute 38 Object TimerObjDId $Attribute 38
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -612,7 +612,6 @@ SObject pwrb:Class ...@@ -612,7 +612,6 @@ SObject pwrb:Class
Object TimerObjDId $Attribute 42 Object TimerObjDId $Attribute 42
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
EndBody EndBody
EndObject EndObject
......
...@@ -114,7 +114,6 @@ SObject pwrb:Class ...@@ -114,7 +114,6 @@ SObject pwrb:Class
EndObject EndObject
Object TimerObjDId $Intern 9 Object TimerObjDId $Intern 9
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -589,7 +589,6 @@ SObject pwrb:Class ...@@ -589,7 +589,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 28 Object TimerObjDId $Intern 28
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -627,7 +627,6 @@ SObject pwrb:Class ...@@ -627,7 +627,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 32 Object TimerObjDId $Intern 32
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -610,7 +610,6 @@ SObject pwrb:Class ...@@ -610,7 +610,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Attribute 35 Object TimerObjDId $Attribute 35
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -307,7 +307,6 @@ SObject pwrb:Class ...@@ -307,7 +307,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 16 Object TimerObjDId $Intern 16
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -112,7 +112,6 @@ SObject pwrb:Class ...@@ -112,7 +112,6 @@ SObject pwrb:Class
EndObject EndObject
Object TimerObjDId $Intern 9 Object TimerObjDId $Intern 9
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -706,7 +706,6 @@ SObject pwrb:Class ...@@ -706,7 +706,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 37 Object TimerObjDId $Intern 37
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -571,7 +571,6 @@ SObject pwrb:Class ...@@ -571,7 +571,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 37 Object TimerObjDId $Intern 37
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -296,7 +296,6 @@ SObject pwrb:Class ...@@ -296,7 +296,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 16 Object TimerObjDId $Intern 16
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -347,7 +347,6 @@ SObject pwrb:Class ...@@ -347,7 +347,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 19 Object TimerObjDId $Intern 19
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
!
! Proview Open Source Process Control.
! Copyright (C) 2005-2015 SSAB EMEA AB.
!
! This file is part of Proview.
!
! This program 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.
!
! This program 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 Proview. If not, see <http://www.gnu.org/licenses/>
!
! Linking Proview statically or dynamically with other modules is
! making a combined work based on Proview. Thus, the terms and
! conditions of the GNU General Public License cover the whole
! combination.
!
! In addition, as a special exception, the copyright holders of
! Proview give you permission to, from the build function in the
! Proview Configurator, combine Proview with modules generated by the
! Proview PLC Editor to a PLC program, regardless of the license
! terms of these modules. You may copy and distribute the resulting
! combined work under the terms of your choice, provided that every
! copy of the combined work is accompanied by a complete copy of
! the source code of Proview (the version used to produce the
! combined work), being distributed under the terms of the GNU
! General Public License plus this exception.
!
! pwrb_c_publicav.wb_load -- Defines the class PublicAv.
!
SObject pwrb:Class
!/**
! @Version 1.0
! @Group Signals
! @Summary Analog value with public write access.
! Analog value with public write access.
!*/
Object PublicAv $ClassDef 677
Body SysBody
Attr Editor = pwr_eEditor_AttrEd
Attr Method = pwr_eMethod_Standard
EndBody
Object RtBody $ObjBodyDef 1
Body SysBody
Attr StructName = "PublicAv"
EndBody
!/**
! Optional description.
!*/
Object Description $Attribute 1
Body SysBody
Attr TypeRef = "pwrs:Type-$String80"
EndBody
EndObject
!/**
! Analog value.
!*/
Object ActualValue $Attribute 2
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_PUBLICWRITE
EndBody
EndObject
EndObject
EndObject
EndSObject
!
! Proview Open Source Process Control.
! Copyright (C) 2005-2015 SSAB EMEA AB.
!
! This file is part of Proview.
!
! This program 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.
!
! This program 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 Proview. If not, see <http://www.gnu.org/licenses/>
!
! Linking Proview statically or dynamically with other modules is
! making a combined work based on Proview. Thus, the terms and
! conditions of the GNU General Public License cover the whole
! combination.
!
! In addition, as a special exception, the copyright holders of
! Proview give you permission to, from the build function in the
! Proview Configurator, combine Proview with modules generated by the
! Proview PLC Editor to a PLC program, regardless of the license
! terms of these modules. You may copy and distribute the resulting
! combined work under the terms of your choice, provided that every
! copy of the combined work is accompanied by a complete copy of
! the source code of Proview (the version used to produce the
! combined work), being distributed under the terms of the GNU
! General Public License plus this exception.
!
! pwrb_c_publicdv.wb_load -- Defines the class PublicDv.
!
SObject pwrb:Class
!/**
! @Version 1.0
! @Group Signals
! @Summary Digital value with public write access.
! Digital value with public write access.
!*/
Object PublicDv $ClassDef 678
Body SysBody
Attr Editor = pwr_eEditor_AttrEd
Attr Method = pwr_eMethod_Standard
EndBody
Object RtBody $ObjBodyDef 1
Body SysBody
Attr StructName = "PublicDv"
EndBody
!/**
! Optional description.
!*/
Object Description $Attribute 1
Body SysBody
Attr TypeRef = "pwrs:Type-$String80"
EndBody
EndObject
!/**
! Analog value.
!*/
Object ActualValue $Attribute 2
Body SysBody
Attr TypeRef = "pwrs:Type-$Boolean"
Attr Flags |= PWR_MASK_PUBLICWRITE
EndBody
EndObject
EndObject
EndObject
EndSObject
!
! Proview Open Source Process Control.
! Copyright (C) 2005-2015 SSAB EMEA AB.
!
! This file is part of Proview.
!
! This program 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.
!
! This program 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 Proview. If not, see <http://www.gnu.org/licenses/>
!
! Linking Proview statically or dynamically with other modules is
! making a combined work based on Proview. Thus, the terms and
! conditions of the GNU General Public License cover the whole
! combination.
!
! In addition, as a special exception, the copyright holders of
! Proview give you permission to, from the build function in the
! Proview Configurator, combine Proview with modules generated by the
! Proview PLC Editor to a PLC program, regardless of the license
! terms of these modules. You may copy and distribute the resulting
! combined work under the terms of your choice, provided that every
! copy of the combined work is accompanied by a complete copy of
! the source code of Proview (the version used to produce the
! combined work), being distributed under the terms of the GNU
! General Public License plus this exception.
!
! pwrb_c_publiciv.wb_load -- Defines the class PublicIv.
!
SObject pwrb:Class
!/**
! @Version 1.0
! @Group Signals
! @Summary Integer value with public write access.
! Integer value with public write access.
!*/
Object PublicIv $ClassDef 679
Body SysBody
Attr Editor = pwr_eEditor_AttrEd
Attr Method = pwr_eMethod_Standard
EndBody
Object RtBody $ObjBodyDef 1
Body SysBody
Attr StructName = "PublicIv"
EndBody
!/**
! Optional description.
!*/
Object Description $Attribute 1
Body SysBody
Attr TypeRef = "pwrs:Type-$String80"
EndBody
EndObject
!/**
! Integer value.
!*/
Object ActualValue $Attribute 2
Body SysBody
Attr TypeRef = "pwrs:Type-$Int32"
Attr Flags |= PWR_MASK_PUBLICWRITE
EndBody
EndObject
EndObject
EndObject
EndSObject
!
! Proview Open Source Process Control.
! Copyright (C) 2005-2015 SSAB EMEA AB.
!
! This file is part of Proview.
!
! This program 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.
!
! This program 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 Proview. If not, see <http://www.gnu.org/licenses/>
!
! Linking Proview statically or dynamically with other modules is
! making a combined work based on Proview. Thus, the terms and
! conditions of the GNU General Public License cover the whole
! combination.
!
! In addition, as a special exception, the copyright holders of
! Proview give you permission to, from the build function in the
! Proview Configurator, combine Proview with modules generated by the
! Proview PLC Editor to a PLC program, regardless of the license
! terms of these modules. You may copy and distribute the resulting
! combined work under the terms of your choice, provided that every
! copy of the combined work is accompanied by a complete copy of
! the source code of Proview (the version used to produce the
! combined work), being distributed under the terms of the GNU
! General Public License plus this exception.
!
! pwrb_c_publicsv.wb_load -- Defines the class PublicSv.
!
SObject pwrb:Class
!/**
! @Version 1.0
! @Group Signals
! @Summary String value with public write access.
! String value with public write access.
!*/
Object PublicSv $ClassDef 680
Body SysBody
Attr Editor = pwr_eEditor_AttrEd
Attr Method = pwr_eMethod_Standard
EndBody
Object RtBody $ObjBodyDef 1
Body SysBody
Attr StructName = "PublicSv"
EndBody
!/**
! Optional description.
!*/
Object Description $Attribute 1
Body SysBody
Attr TypeRef = "pwrs:Type-$String80"
EndBody
EndObject
!/**
! String value.
!*/
Object ActualValue $Attribute 2
Body SysBody
Attr TypeRef = "pwrs:Type-$String80"
Attr Flags |= PWR_MASK_PUBLICWRITE
EndBody
EndObject
EndObject
EndObject
EndSObject
...@@ -194,7 +194,6 @@ SObject pwrb:Class ...@@ -194,7 +194,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 10 Object TimerObjDId $Intern 10
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -190,7 +190,6 @@ SObject pwrb:Class ...@@ -190,7 +190,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 10 Object TimerObjDId $Intern 10
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -557,7 +557,6 @@ SObject pwrb:Class ...@@ -557,7 +557,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 28 Object TimerObjDId $Intern 28
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -187,7 +187,6 @@ SObject pwrb:Class ...@@ -187,7 +187,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 10 Object TimerObjDId $Intern 10
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -230,7 +230,6 @@ SObject pwrb:Class ...@@ -230,7 +230,6 @@ SObject pwrb:Class
!*/ !*/
Object TimerObjDId $Intern 12 Object TimerObjDId $Intern 12
Body SysBody Body SysBody
Attr Flags |= PWR_MASK_OBJDIDSELF
Attr Flags |= PWR_MASK_INVISIBLE Attr Flags |= PWR_MASK_INVISIBLE
Attr TypeRef = "pwrs:Type-$Objid" Attr TypeRef = "pwrs:Type-$Objid"
EndBody EndBody
......
...@@ -152,12 +152,12 @@ SObject pwrs:Type ...@@ -152,12 +152,12 @@ SObject pwrs:Type
EndBody EndBody
EndObject EndObject
!/** !/**
! The attribtute contains the objects own objid. ! The attribute can be written without write privileges.
!*/ !*/
Object ObjidSelf $Bit Object PublicWrite $Bit
Body SysBody Body SysBody
Attr PgmName = "objidself" Attr PgmName = "publicwrite"
Attr Text = "ObjidSelf" Attr Text = "PublicWrite"
Attr Value = 512 Attr Value = 512
EndBody EndBody
EndObject EndObject
......
...@@ -314,8 +314,7 @@ static wbl_sSym attr_flags[] = ...@@ -314,8 +314,7 @@ static wbl_sSym attr_flags[] =
,{ "PWR_MASK_RTVIRTUAL", PWR_MASK_RTVIRTUAL } ,{ "PWR_MASK_RTVIRTUAL", PWR_MASK_RTVIRTUAL }
,{ "PWR_MASK_DEVBODYREF", PWR_MASK_DEVBODYREF } ,{ "PWR_MASK_DEVBODYREF", PWR_MASK_DEVBODYREF }
,{ "PWR_MASK_DYNAMIC", PWR_MASK_DYNAMIC } ,{ "PWR_MASK_DYNAMIC", PWR_MASK_DYNAMIC }
,{ "PWR_MASK_OBJDIDSELF", PWR_MASK_OBJDIDSELF } ,{ "PWR_MASK_PUBLICWRITE", PWR_MASK_PUBLICWRITE }
,{ "PWR_MASK_OBJIDSELF", PWR_MASK_OBJIDSELF }
,{ "PWR_MASK_NOEDIT", PWR_MASK_NOEDIT } ,{ "PWR_MASK_NOEDIT", PWR_MASK_NOEDIT }
,{ "PWR_MASK_INVISIBLE", PWR_MASK_INVISIBLE } ,{ "PWR_MASK_INVISIBLE", PWR_MASK_INVISIBLE }
,{ "PWR_MASK_REFDIRECT", PWR_MASK_REFDIRECT } ,{ "PWR_MASK_REFDIRECT", PWR_MASK_REFDIRECT }
......
...@@ -362,7 +362,7 @@ dcli_tCmdTable xnav_command_table[] = { ...@@ -362,7 +362,7 @@ dcli_tCmdTable xnav_command_table[] = {
"SET", "SET",
&xnav_set_func, &xnav_set_func,
{ "dcli_arg1", "dcli_arg2", "/NAME", "/VALUE", { "dcli_arg1", "dcli_arg2", "/NAME", "/VALUE",
"/BYPASS", "/INDEX", "/SOURCE", "/OBJECT", "/CONTINUE", "/BYPASS", "/PUBLICWRITE", "/INDEX", "/SOURCE", "/OBJECT", "/CONTINUE",
"/X0", "/Y0", "/X1", "/Y1", ""} "/X0", "/Y0", "/X1", "/Y1", ""}
}, },
{ {
...@@ -779,6 +779,7 @@ static int xnav_set_func( void *client_data, ...@@ -779,6 +779,7 @@ static int xnav_set_func( void *client_data,
char value_str[400]; char value_str[400];
int sts; int sts;
int bypass; int bypass;
int publicwrite;
bypass = ODD( dcli_get_qualifier( "/BYPASS", 0, 0)); bypass = ODD( dcli_get_qualifier( "/BYPASS", 0, 0));
if ( bypass) { if ( bypass) {
...@@ -786,6 +787,8 @@ static int xnav_set_func( void *client_data, ...@@ -786,6 +787,8 @@ static int xnav_set_func( void *client_data,
return XNAV__HOLDCOMMAND; return XNAV__HOLDCOMMAND;
} }
publicwrite = ODD( dcli_get_qualifier( "/PUBLICWRITE", 0, 0));
if ( EVEN( dcli_get_qualifier( "/NAME", name_str, sizeof(name_str)))) if ( EVEN( dcli_get_qualifier( "/NAME", name_str, sizeof(name_str))))
{ {
xnav->message('E', "Enter name of parameter"); xnav->message('E', "Enter name of parameter");
...@@ -796,9 +799,10 @@ static int xnav_set_func( void *client_data, ...@@ -796,9 +799,10 @@ static int xnav_set_func( void *client_data,
xnav->message('E', "Enter value"); xnav->message('E', "Enter value");
return XNAV__HOLDCOMMAND; return XNAV__HOLDCOMMAND;
} }
sts = xnav->set_parameter( name_str, value_str, bypass); sts = xnav->set_parameter( name_str, value_str, publicwrite);
if ( EVEN(sts)) if ( sts == XNAV__NOTAUTHORIZED)
{ xnav->message('E', "Not authorized for this operation");
else if ( EVEN(sts)) {
xnav->message('E',"Unable to set parameter"); xnav->message('E',"Unable to set parameter");
return XNAV__HOLDCOMMAND; return XNAV__HOLDCOMMAND;
} }
...@@ -8060,6 +8064,228 @@ static int xnav_getattribute_func( ...@@ -8060,6 +8064,228 @@ static int xnav_getattribute_func(
return 1; return 1;
} }
static int xnav_setattribute_func(
void *filectx,
ccm_sArg *arg_list,
int arg_count,
int *return_decl,
ccm_tFloat *return_float,
ccm_tInt *return_int,
char *return_string)
{
ccm_sArg *arg_p2, *arg_p3;
int sts;
pwr_sAttrRef attrref;
pwr_tTypeId attr_type;
unsigned int attr_size, attr_offset, attr_dim;
unsigned int a_flags;
int publicwrite = 0;
XNav *xnav;
if ( !(arg_count == 3 || arg_count == 2))
return CCM__ARGMISM;
arg_p2 = arg_list->next;
arg_p3 = arg_p2->next;
if ( arg_list->value_decl != CCM_DECL_STRING)
return CCM__ARGMISM;
if ( arg_count == 3) {
if ( arg_p3->value_decl != CCM_DECL_INT)
return CCM__ARGMISM;
if ( arg_p3->value_int == 1)
publicwrite = 1;
}
xnav_get_stored_xnav( &xnav);
sts = gdh_NameToAttrref( pwr_cNObjid, arg_list->value_string, &attrref);
if (EVEN(sts)) {
*return_int = sts;
*return_decl = CCM_DECL_INT;
return 1;
}
// Check authorization
if ( publicwrite) {
sts = gdh_GetAttributeFlags( &attrref, &a_flags);
if ( EVEN(sts)) return sts;
if ( !(a_flags & pwr_mAdef_publicwrite))
sts = XNAV__NOTAUTHORIZED;
if ( !((xnav->priv & pwr_mPrv_RtRead) ||
(xnav->priv & pwr_mPrv_RtWrite) ||
(xnav->priv & pwr_mPrv_System) ||
(xnav->priv & pwr_mPrv_Maintenance) ||
(xnav->priv & pwr_mPrv_Process) ||
(xnav->priv & pwr_mPrv_Instrument) ||
(xnav->priv & pwr_mPrv_Operator1) ||
(xnav->priv & pwr_mPrv_Operator2) ||
(xnav->priv & pwr_mPrv_Operator3) ||
(xnav->priv & pwr_mPrv_Operator4) ||
(xnav->priv & pwr_mPrv_Operator5) ||
(xnav->priv & pwr_mPrv_Operator6) ||
(xnav->priv & pwr_mPrv_Operator7) ||
(xnav->priv & pwr_mPrv_Operator8) ||
(xnav->priv & pwr_mPrv_Operator9) ||
(xnav->priv & pwr_mPrv_Operator10)))
sts = XNAV__NOTAUTHORIZED;
}
else {
if ( !((xnav->priv & pwr_mPrv_RtWrite) ||
(xnav->priv & pwr_mPrv_System)))
sts = XNAV__NOTAUTHORIZED;
}
if ( EVEN(sts)) {
*return_int = sts;
*return_decl = CCM_DECL_INT;
return 1;
}
sts = gdh_GetAttributeCharAttrref( &attrref, &attr_type, &attr_size,
&attr_offset, &attr_dim);
if ( EVEN(sts)) return sts;
switch ( arg_p2->value_decl) {
case CCM_DECL_STRING: {
char buffer[512];
sts = xnav->attr_string_to_value( attr_type, arg_p2->value_string,
buffer, sizeof(buffer), attr_size);
if ( ODD(sts))
sts = gdh_SetObjectInfo( arg_list->value_string, buffer, attr_size);
break;
}
case CCM_DECL_INT: {
switch ( attr_type) {
case pwr_eType_Int8: {
pwr_tInt8 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Int16: {
pwr_tInt16 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Int32: {
pwr_tInt32 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Int64: {
pwr_tInt64 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt8: {
pwr_tUInt8 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt16: {
pwr_tUInt16 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt32: {
pwr_tUInt32 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt64: {
pwr_tUInt64 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Float32: {
pwr_tFloat32 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Float64: {
pwr_tFloat64 val = arg_p2->value_int;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Boolean: {
pwr_tBoolean val = arg_p2->value_int ? 1: 0;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
}
break;
}
case CCM_DECL_FLOAT: {
switch ( attr_type) {
case pwr_eType_Int8: {
pwr_tInt8 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Int16: {
pwr_tInt16 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Int32: {
pwr_tInt32 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Int64: {
pwr_tInt64 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt8: {
pwr_tUInt8 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt16: {
pwr_tUInt16 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt32: {
pwr_tUInt32 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_UInt64: {
pwr_tUInt64 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Float32: {
pwr_tFloat32 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Float64: {
pwr_tFloat64 val = arg_p2->value_float;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
case pwr_eType_Boolean: {
pwr_tBoolean val = arg_p2->value_float ? 1: 0;
sts = gdh_SetObjectInfo( arg_list->value_string, &val, attr_size);
break;
}
}
break;
}
}
*return_int = sts;
*return_decl = CCM_DECL_INT;
return 1;
}
static int xnav_ccm_deffilename_func( char *outfile, char *infile, void *client_data) static int xnav_ccm_deffilename_func( char *outfile, char *infile, void *client_data)
{ {
pwr_tFileName fname; pwr_tFileName fname;
...@@ -8135,6 +8361,8 @@ int XNav::readcmdfile( char *incommand, char *buffer) ...@@ -8135,6 +8361,8 @@ int XNav::readcmdfile( char *incommand, char *buffer)
if ( EVEN(sts)) return sts; if ( EVEN(sts)) return sts;
sts = ccm_register_function( "GetAttribute", xnav_getattribute_func); sts = ccm_register_function( "GetAttribute", xnav_getattribute_func);
if ( EVEN(sts)) return sts; if ( EVEN(sts)) return sts;
sts = ccm_register_function( "SetAttribute", xnav_setattribute_func);
if ( EVEN(sts)) return sts;
sts = ccm_register_function( "ConfirmDialog", xnav_confirmdialog_func); sts = ccm_register_function( "ConfirmDialog", xnav_confirmdialog_func);
if ( EVEN(sts)) return sts; if ( EVEN(sts)) return sts;
...@@ -9142,27 +9370,48 @@ static void xnav_op_help_cb( void *ctx, const char *key) ...@@ -9142,27 +9370,48 @@ static void xnav_op_help_cb( void *ctx, const char *key)
xnav->message( ' ', null_str); xnav->message( ' ', null_str);
} }
int XNav::set_parameter( char *name_str, char *value_str, int bypass) int XNav::set_parameter( char *name_str, char *value_str, int publicwrite)
{ {
pwr_sAttrRef attrref; pwr_sAttrRef attrref;
int sts; int sts;
pwr_tTypeId attr_type; pwr_tTypeId attr_type;
unsigned int attr_size, attr_offset, attr_dim; unsigned int attr_size, attr_offset, attr_dim;
char buffer[80]; char buffer[80];
unsigned int a_flags;
sts = gdh_NameToAttrref( pwr_cNObjid, name_str, &attrref);
if (EVEN(sts)) return sts;
if ( !bypass)
{
// Check authorization // Check authorization
if ( publicwrite) {
sts = gdh_GetAttributeFlags( &attrref, &a_flags);
if ( EVEN(sts)) return sts;
if ( !(a_flags & pwr_mAdef_publicwrite))
return XNAV__NOTAUTHORIZED;
if ( !((priv & pwr_mPrv_RtRead) ||
(priv & pwr_mPrv_RtWrite) ||
(priv & pwr_mPrv_System) ||
(priv & pwr_mPrv_Maintenance) ||
(priv & pwr_mPrv_Process) ||
(priv & pwr_mPrv_Instrument) ||
(priv & pwr_mPrv_Operator1) ||
(priv & pwr_mPrv_Operator2) ||
(priv & pwr_mPrv_Operator3) ||
(priv & pwr_mPrv_Operator4) ||
(priv & pwr_mPrv_Operator5) ||
(priv & pwr_mPrv_Operator6) ||
(priv & pwr_mPrv_Operator7) ||
(priv & pwr_mPrv_Operator8) ||
(priv & pwr_mPrv_Operator9) ||
(priv & pwr_mPrv_Operator10)))
return XNAV__NOTAUTHORIZED;
}
else {
if ( !((priv & pwr_mPrv_RtWrite) || if ( !((priv & pwr_mPrv_RtWrite) ||
(priv & pwr_mPrv_System))) (priv & pwr_mPrv_System)))
{ return XNAV__NOTAUTHORIZED;
message('E', "Not authorized for this operation");
return 0;
} }
}
sts = gdh_NameToAttrref( pwr_cNObjid, name_str, &attrref);
if (EVEN(sts)) return sts;
sts = gdh_GetAttributeCharAttrref( &attrref, &attr_type, &attr_size, sts = gdh_GetAttributeCharAttrref( &attrref, &attr_type, &attr_size,
&attr_offset, &attr_dim); &attr_offset, &attr_dim);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment