Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
proview
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Esteban Blanc
proview
Commits
df1bef6b
Commit
df1bef6b
authored
Mar 14, 2007
by
claes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
*** empty log message ***
parent
8a3659c6
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
166 additions
and
6 deletions
+166
-6
opc/exe/opc_server/src/opc_server.cpp
opc/exe/opc_server/src/opc_server.cpp
+106
-1
opc/lib/opc/src/opc_utl.cpp
opc/lib/opc/src/opc_utl.cpp
+54
-2
opc/lib/opc/src/opc_utl.h
opc/lib/opc/src/opc_utl.h
+6
-3
No files found.
opc/exe/opc_server/src/opc_server.cpp
View file @
df1bef6b
/*
* Proview $Id: opc_server.cpp,v 1.
5 2007-03-13 15:48:41
claes Exp $
* Proview $Id: opc_server.cpp,v 1.
6 2007-03-14 08:02:16
claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB.
*
* This program is free software; you can redistribute it and/or
...
...
@@ -151,6 +151,111 @@ SOAP_FMAC5 int SOAP_FMAC6 __ns1__Read(struct soap*,
_ns1__Read
*
ns1__Read
,
_ns1__ReadResponse
*
ns1__ReadResponse
)
{
int
ii
;
class
ns1__ReadRequestItem
*
item
;
pwr_sAttrRef
ar
;
pwr_tStatus
sts
;
pwr_tOName
itemname
;
pwr_tOName
itempath
;
pwr_tOName
path
;
int
reqType
=
-
1
;
pwr_tTypeId
tid
;
unsigned
int
elem
;
char
buf
[
40
];
unsigned
int
options
=
0
;
if
(
!
ns1__Read
->
ItemList
)
return
0
;
if
(
ns1__Read
->
ItemList
->
Items
.
empty
())
return
0
;
memset
(
path
,
0
,
sizeof
(
path
));
opc_requestoptions_to_mask
(
ns1__Read
->
Options
,
&
options
);
if
(
ns1__Read
->
ItemList
->
ItemPath
&&
!
ns1__Read
->
ItemList
->
ItemPath
->
empty
())
strncpy
(
path
,
ns1__Read
->
ItemList
->
ItemPath
->
c_str
(),
sizeof
(
path
));
for
(
ii
=
0
;
ii
<
(
int
)
ns1__Read
->
ItemList
->
Items
.
size
();
ii
++
)
{
ns1__ItemValue
*
iv
=
new
ns1__ItemValue
();
if
(
!
ns1__ReadResponse
->
RItemList
)
ns1__ReadResponse
->
RItemList
=
new
ns1__ReplyItemList
();
item
=
ns1__Read
->
ItemList
->
Items
[
ii
];
if
(
item
->
ItemPath
&&
!
item
->
ItemPath
->
empty
())
strncpy
(
itempath
,
item
->
ItemPath
->
c_str
(),
sizeof
(
itemname
));
else
strncpy
(
itempath
,
path
,
sizeof
(
itemname
));
strncpy
(
itemname
,
itempath
,
sizeof
(
itemname
));
strncat
(
itemname
,
item
->
ItemName
->
c_str
(),
sizeof
(
itemname
));
if
(
options
&
opc_mRequestOption_ReturnItemPath
)
iv
->
ItemPath
=
new
std
::
string
(
itempath
);
if
(
options
&
opc_mRequestOption_ReturnItemName
)
iv
->
ItemName
=
new
std
::
string
(
itemname
);
if
(
options
&
opc_mRequestOption_ReturnDiagnosticInfo
)
iv
->
DiagnosticInfo
=
new
std
::
string
(
""
);
// ToDo !!
sts
=
gdh_NameToAttrref
(
pwr_cNObjid
,
itemname
,
&
ar
);
if
(
EVEN
(
sts
))
{
opcsrv_returnerror
(
ns1__ReadResponse
->
Errors
,
&
iv
->
ResultID
,
opc_eResultCode_E_INVALIDITEMNAME
,
options
);
continue
;
}
if
(
!
item
->
ReqType
||
item
->
ReqType
->
empty
())
{
if
(
!
ns1__Read
->
ItemList
->
ReqType
||
ns1__Read
->
ItemList
->
ReqType
->
empty
())
{
reqType
=
-
1
;
}
else
{
opc_string_to_opctype
(
ns1__Read
->
ItemList
->
ReqType
->
c_str
(),
&
reqType
);
}
}
else
{
opc_string_to_opctype
(
item
->
ReqType
->
c_str
(),
&
reqType
);
}
gdh_GetAttributeCharAttrref
(
&
ar
,
&
tid
,
NULL
,
NULL
,
&
elem
);
if
(
cdh_tidIsCid
(
tid
)
||
elem
>
1
)
{
opcsrv_returnerror
(
ns1__ReadResponse
->
Errors
,
&
iv
->
ResultID
,
opc_eResultCode_E_BADTYPE
,
options
);
ns1__ReadResponse
->
RItemList
->
Items
.
push_back
(
iv
);
continue
;
}
sts
=
gdh_GetObjectInfoAttrref
(
&
ar
,
buf
,
40
);
if
(
ODD
(
sts
))
{
if
(
reqType
<
0
)
opc_pwrtype_to_opctype
(
tid
,
&
reqType
);
if
(
opc_convert_pwrtype_to_opctype
(
buf
,
40
,
reqType
,
tid
))
{
char
*
str
;
opc_opctype_to_value
(
buf
,
40
,
reqType
);
str
=
(
char
*
)
malloc
(
strlen
(
buf
));
strncpy
(
str
,
buf
,
40
);
iv
->
Value
=
str
;
sprintf
(
iv
->
ValueType
,
"xsd:%s"
,
opc_opctype_to_string
(
reqType
));
if
(
options
&
opc_mRequestOption_ReturnItemTime
)
{
// ToDo !!!
}
ns1__ReadResponse
->
RItemList
->
Items
.
push_back
(
iv
);
}
else
{
opcsrv_returnerror
(
ns1__ReadResponse
->
Errors
,
&
iv
->
ResultID
,
opc_eResultCode_E_BADTYPE
,
options
);
continue
;
}
}
else
{
opcsrv_returnerror
(
ns1__ReadResponse
->
Errors
,
&
iv
->
ResultID
,
opc_eResultCode_E_BADTYPE
,
options
);
continue
;
}
}
return
0
;
}
...
...
opc/lib/opc/src/opc_utl.cpp
View file @
df1bef6b
/*
* Proview $Id: opc_utl.cpp,v 1.
7 2007-03-13 15:48:41
claes Exp $
* Proview $Id: opc_utl.cpp,v 1.
8 2007-03-14 08:02:54
claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB.
*
* This program is free software; you can redistribute it and/or
...
...
@@ -119,6 +119,7 @@ void opcsrv_returnerror(std::vector<ns1__OPCError *>& errors, std::string **rc,
opc_resultcode_to_string
(
err_code
,
str
);
if
(
rc
)
*
rc
=
new
std
::
string
(
str
);
...
...
@@ -616,7 +617,7 @@ bool opc_convert_pwrtype_to_opctype(void *bufp, int size, int opc_type, int pwr_
//
// Return the corresponding opc type for a opc type string
//
bool
opc_string_to_opctype
(
char
*
str
,
int
*
type
)
bool
opc_string_to_opctype
(
c
onst
c
har
*
str
,
int
*
type
)
{
int
ii
;
...
...
@@ -639,6 +640,57 @@ char *opc_opctype_to_string(int type)
}
bool
opc_pwrtype_to_opctype
(
int
pwrtype
,
int
*
opctype
)
{
switch
(
pwrtype
)
{
case
pwr_eType_String
:
case
pwr_eType_Objid
:
case
pwr_eType_AttrRef
:
*
opctype
=
opc_eDataType_string
;
break
;
case
pwr_eType_Boolean
:
*
opctype
=
opc_eDataType_boolean
;
break
;
case
pwr_eType_Float32
:
*
opctype
=
opc_eDataType_float
;
break
;
case
pwr_eType_Float64
:
*
opctype
=
opc_eDataType_double
;
break
;
case
pwr_eType_Enum
:
case
pwr_eType_Mask
:
case
pwr_eType_Status
:
case
pwr_eType_NetStatus
:
case
pwr_eType_Int32
:
*
opctype
=
opc_eDataType_int
;
break
;
case
pwr_eType_Int16
:
*
opctype
=
opc_eDataType_short
;
break
;
case
pwr_eType_Int8
:
*
opctype
=
opc_eDataType_byte
;
break
;
case
pwr_eType_UInt32
:
*
opctype
=
opc_eDataType_unsignedInt
;
break
;
case
pwr_eType_UInt16
:
*
opctype
=
opc_eDataType_unsignedShort
;
break
;
case
pwr_eType_UInt8
:
*
opctype
=
opc_eDataType_unsignedByte
;
break
;
case
pwr_eType_Time
:
*
opctype
=
opc_eDataType_dateTime
;
break
;
case
pwr_eType_DeltaTime
:
*
opctype
=
opc_eDataType_duration
;
break
;
default:
*
opctype
=
opc_eDataType_
;
return
false
;
}
return
true
;
}
bool
opc_type_to_pwrtype
(
int
type
,
int
*
pwrtype
)
{
switch
(
type
)
{
...
...
opc/lib/opc/src/opc_utl.h
View file @
df1bef6b
/*
* Proview $Id: opc_utl.h,v 1.
6 2007-03-13 15:48:41
claes Exp $
* Proview $Id: opc_utl.h,v 1.
7 2007-03-14 08:02:54
claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB.
*
* This program is free software; you can redistribute it and/or
...
...
@@ -74,7 +74,8 @@ typedef enum {
opc_eDataType_date
,
opc_eDataType_duration
,
opc_eDataType_QName
,
opc_eDataType_anyType
opc_eDataType_anyType
,
opc_eDataType_
}
opc_eDataType
;
const
int
opc_cResultCodesSize
=
20
;
...
...
@@ -111,8 +112,10 @@ pwr_tStatus time_AtoOPCAscii (pwr_tTime *tp, char *buf, int bufsize);
bool
opc_resultcode_to_string
(
int
type
,
char
*
str
);
bool
opc_resultcode_to_text
(
int
type
,
char
*
str
);
bool
opc_opctype_to_value
(
void
*
bufp
,
int
size
,
int
opc_type
);
bool
opc_string_to_opctype
(
char
*
str
,
int
*
type
);
bool
opc_convert_pwrtype_to_opctype
(
void
*
bufp
,
int
size
,
int
opc_type
,
int
pwr_type
);
bool
opc_string_to_opctype
(
const
char
*
str
,
int
*
type
);
char
*
opc_opctype_to_string
(
int
type
);
bool
opc_pwrtype_to_opctype
(
int
pwrtype
,
int
*
opctype
);
bool
opc_type_to_pwrtype
(
int
type
,
int
*
pwrtype
);
bool
opc_pwrtype_to_string
(
int
type
,
char
**
str
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment