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
532e423f
Commit
532e423f
authored
Aug 25, 2008
by
claes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bit type added to DigLowColor, DigWarning and DigError
parent
76f36274
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
248 additions
and
70 deletions
+248
-70
xtt/lib/ge/src/ge_dyn.cpp
xtt/lib/ge/src/ge_dyn.cpp
+238
-65
xtt/lib/ge/src/ge_dyn.h
xtt/lib/ge/src/ge_dyn.h
+10
-5
No files found.
xtt/lib/ge/src/ge_dyn.cpp
View file @
532e423f
/*
/*
* Proview $Id: ge_dyn.cpp,v 1.6
4 2008-06-09 14:33:12
claes Exp $
* Proview $Id: ge_dyn.cpp,v 1.6
5 2008-08-25 11:17:44
claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB.
* Copyright (C) 2005 SSAB Oxelsund AB.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -1738,6 +1738,20 @@ int GeDigLowColor::connect( grow_tObject object, glow_sTraceData *trace_data)
...
@@ -1738,6 +1738,20 @@ int GeDigLowColor::connect( grow_tObject object, glow_sTraceData *trace_data)
if
(
strcmp
(
parsed_name
,
""
)
==
0
)
if
(
strcmp
(
parsed_name
,
""
)
==
0
)
return
1
;
return
1
;
a_typeid
=
attr_type
;
if
(
attr_type
==
graph_eType_Bit
)
{
// Get bit number from parsed name
char
*
s
;
int
bitnum
;
if
(
(
s
=
strchr
(
parsed_name
,
'['
)))
{
sscanf
(
s
+
1
,
"%d"
,
&
bitnum
);
*
s
=
0
;
if
(
bitnum
>=
0
&&
bitnum
<
32
)
bitmask
=
1
<<
bitnum
;
}
}
switch
(
db
)
{
switch
(
db
)
{
case
graph_eDatabase_Local
:
case
graph_eDatabase_Local
:
p
=
(
pwr_tBoolean
*
)
dyn
->
graph
->
localdb_ref_or_create
(
parsed_name
,
attr_type
);
p
=
(
pwr_tBoolean
*
)
dyn
->
graph
->
localdb_ref_or_create
(
parsed_name
,
attr_type
);
...
@@ -1767,6 +1781,10 @@ int GeDigLowColor::scan( grow_tObject object)
...
@@ -1767,6 +1781,10 @@ int GeDigLowColor::scan( grow_tObject object)
if
(
!
p
||
dyn
->
ignore_color
)
if
(
!
p
||
dyn
->
ignore_color
)
return
1
;
return
1
;
switch
(
a_typeid
)
{
case
pwr_eType_Boolean
:
case
pwr_eType_Int32
:
case
pwr_eType_UInt32
:
{
if
(
!
first_scan
)
{
if
(
!
first_scan
)
{
if
(
old_value
==
*
p
&&
!
dyn
->
reset_color
)
if
(
old_value
==
*
p
&&
!
dyn
->
reset_color
)
// No change since last time
// No change since last time
...
@@ -1795,6 +1813,43 @@ int GeDigLowColor::scan( grow_tObject object)
...
@@ -1795,6 +1813,43 @@ int GeDigLowColor::scan( grow_tObject object)
grow_ResetObjectFillColor
(
object
);
grow_ResetObjectFillColor
(
object
);
}
}
old_value
=
*
p
;
old_value
=
*
p
;
break
;
}
case
graph_eType_Bit
:
{
pwr_tBoolean
val
=
((
*
p
&
bitmask
)
!=
0
);
if
(
!
first_scan
)
{
if
(
old_value
==
val
&&
!
dyn
->
reset_color
)
// No change since last time
return
1
;
}
else
first_scan
=
false
;
if
(
dyn
->
total_dyn_type
&
ge_mDynType_Tone
)
{
if
(
(
!
inverted
&&
!
val
)
||
(
inverted
&&
val
))
{
if
(
color
>=
(
glow_eDrawType
)
glow_eDrawTone__
)
grow_SetObjectFillColor
(
object
,
color
);
else
grow_SetObjectColorTone
(
object
,
(
glow_eDrawTone
)
color
);
dyn
->
ignore_color
=
true
;
}
else
{
if
(
color
>=
(
glow_eDrawType
)
glow_eDrawTone__
)
grow_ResetObjectFillColor
(
object
);
grow_ResetObjectColorTone
(
object
);
}
}
else
{
if
(
(
!
inverted
&&
!
val
)
||
(
inverted
&&
val
))
grow_SetObjectFillColor
(
object
,
color
);
else
grow_ResetObjectFillColor
(
object
);
}
old_value
=
val
;
break
;
}
}
return
1
;
return
1
;
}
}
...
@@ -2220,6 +2275,20 @@ int GeDigWarning::connect( grow_tObject object, glow_sTraceData *trace_data)
...
@@ -2220,6 +2275,20 @@ int GeDigWarning::connect( grow_tObject object, glow_sTraceData *trace_data)
if
(
strcmp
(
parsed_name
,
""
)
==
0
)
if
(
strcmp
(
parsed_name
,
""
)
==
0
)
return
1
;
return
1
;
a_typeid
=
attr_type
;
if
(
attr_type
==
graph_eType_Bit
)
{
// Get bit number from parsed name
char
*
s
;
int
bitnum
;
if
(
(
s
=
strchr
(
parsed_name
,
'['
)))
{
sscanf
(
s
+
1
,
"%d"
,
&
bitnum
);
*
s
=
0
;
if
(
bitnum
>=
0
&&
bitnum
<
32
)
bitmask
=
1
<<
bitnum
;
}
}
sts
=
dyn
->
graph
->
ref_object_info
(
dyn
->
cycle
,
parsed_name
,
(
void
**
)
&
p
,
&
subid
,
size
);
sts
=
dyn
->
graph
->
ref_object_info
(
dyn
->
cycle
,
parsed_name
,
(
void
**
)
&
p
,
&
subid
,
size
);
if
(
EVEN
(
sts
))
return
sts
;
if
(
EVEN
(
sts
))
return
sts
;
...
@@ -2241,6 +2310,10 @@ int GeDigWarning::scan( grow_tObject object)
...
@@ -2241,6 +2310,10 @@ int GeDigWarning::scan( grow_tObject object)
if
(
!
p
||
dyn
->
ignore_color
)
if
(
!
p
||
dyn
->
ignore_color
)
return
1
;
return
1
;
switch
(
a_typeid
)
{
case
pwr_eType_Boolean
:
case
pwr_eType_Int32
:
case
pwr_eType_UInt32
:
{
if
(
!
first_scan
)
{
if
(
!
first_scan
)
{
if
(
old_value
==
*
p
&&
!
dyn
->
reset_color
)
{
if
(
old_value
==
*
p
&&
!
dyn
->
reset_color
)
{
// No change since last time
// No change since last time
...
@@ -2273,6 +2346,47 @@ int GeDigWarning::scan( grow_tObject object)
...
@@ -2273,6 +2346,47 @@ int GeDigWarning::scan( grow_tObject object)
}
}
}
}
old_value
=
*
p
;
old_value
=
*
p
;
break
;
}
case
graph_eType_Bit
:
{
pwr_tBoolean
val
=
((
*
p
&
bitmask
)
!=
0
);
if
(
!
first_scan
)
{
if
(
old_value
==
val
&&
!
dyn
->
reset_color
)
{
// No change since last time
if
(
(
!
inverted
&&
val
)
||
(
inverted
&&
!
val
))
dyn
->
ignore_color
=
true
;
return
1
;
}
}
else
first_scan
=
false
;
if
(
dyn
->
total_dyn_type
&
ge_mDynType_Tone
)
{
if
(
(
!
inverted
&&
val
)
||
(
inverted
&&
!
val
))
{
grow_SetObjectColorTone
(
object
,
glow_eDrawTone_Yellow
);
dyn
->
ignore_color
=
true
;
}
else
{
grow_ResetObjectColorTone
(
object
);
dyn
->
reset_color
=
true
;
}
}
else
{
if
(
(
!
inverted
&&
val
)
||
(
inverted
&&
!
val
))
{
grow_SetObjectFillColor
(
object
,
glow_eDrawType_ColorYellow
);
dyn
->
ignore_color
=
true
;
}
else
{
grow_ResetObjectFillColor
(
object
);
dyn
->
reset_color
=
true
;
}
}
old_value
=
val
;
break
;
}
}
return
1
;
return
1
;
}
}
...
@@ -2360,6 +2474,20 @@ int GeDigError::connect( grow_tObject object, glow_sTraceData *trace_data)
...
@@ -2360,6 +2474,20 @@ int GeDigError::connect( grow_tObject object, glow_sTraceData *trace_data)
if
(
strcmp
(
parsed_name
,
""
)
==
0
)
if
(
strcmp
(
parsed_name
,
""
)
==
0
)
return
1
;
return
1
;
a_typeid
=
attr_type
;
if
(
attr_type
==
graph_eType_Bit
)
{
// Get bit number from parsed name
char
*
s
;
int
bitnum
;
if
(
(
s
=
strchr
(
parsed_name
,
'['
)))
{
sscanf
(
s
+
1
,
"%d"
,
&
bitnum
);
*
s
=
0
;
if
(
bitnum
>=
0
&&
bitnum
<
32
)
bitmask
=
1
<<
bitnum
;
}
}
sts
=
dyn
->
graph
->
ref_object_info
(
dyn
->
cycle
,
parsed_name
,
(
void
**
)
&
p
,
&
subid
,
size
);
sts
=
dyn
->
graph
->
ref_object_info
(
dyn
->
cycle
,
parsed_name
,
(
void
**
)
&
p
,
&
subid
,
size
);
if
(
EVEN
(
sts
))
return
sts
;
if
(
EVEN
(
sts
))
return
sts
;
...
@@ -2381,6 +2509,10 @@ int GeDigError::scan( grow_tObject object)
...
@@ -2381,6 +2509,10 @@ int GeDigError::scan( grow_tObject object)
if
(
!
p
||
dyn
->
ignore_color
)
if
(
!
p
||
dyn
->
ignore_color
)
return
1
;
return
1
;
switch
(
a_typeid
)
{
case
pwr_eType_Boolean
:
case
pwr_eType_Int32
:
case
pwr_eType_UInt32
:
{
if
(
!
first_scan
)
{
if
(
!
first_scan
)
{
if
(
old_value
==
*
p
&&
!
dyn
->
reset_color
)
{
if
(
old_value
==
*
p
&&
!
dyn
->
reset_color
)
{
// No change since last time
// No change since last time
...
@@ -2413,6 +2545,47 @@ int GeDigError::scan( grow_tObject object)
...
@@ -2413,6 +2545,47 @@ int GeDigError::scan( grow_tObject object)
}
}
}
}
old_value
=
*
p
;
old_value
=
*
p
;
break
;
}
case
graph_eType_Bit
:
{
pwr_tBoolean
val
=
((
*
p
&
bitmask
)
!=
0
);
if
(
!
first_scan
)
{
if
(
old_value
==
val
&&
!
dyn
->
reset_color
)
{
// No change since last time
if
(
(
!
inverted
&&
val
)
||
(
inverted
&&
!
val
))
dyn
->
ignore_color
=
true
;
return
1
;
}
}
else
first_scan
=
false
;
if
(
dyn
->
total_dyn_type
&
ge_mDynType_Tone
)
{
if
(
(
!
inverted
&&
val
)
||
(
inverted
&&
!
val
))
{
grow_SetObjectColorTone
(
object
,
glow_eDrawTone_Red
);
dyn
->
ignore_color
=
true
;
}
else
{
grow_ResetObjectColorTone
(
object
);
dyn
->
reset_color
=
true
;
}
}
else
{
if
(
(
!
inverted
&&
val
)
||
(
inverted
&&
!
val
))
{
grow_SetObjectFillColor
(
object
,
glow_eDrawType_ColorRed
);
dyn
->
ignore_color
=
true
;
}
else
{
grow_ResetObjectFillColor
(
object
);
dyn
->
reset_color
=
true
;
}
}
old_value
=
val
;
break
;
}
}
return
1
;
return
1
;
}
}
...
...
xtt/lib/ge/src/ge_dyn.h
View file @
532e423f
/*
/*
* Proview $Id: ge_dyn.h,v 1.3
6 2008-04-14 07:02:30
claes Exp $
* Proview $Id: ge_dyn.h,v 1.3
7 2008-08-25 11:17:48
claes Exp $
* Copyright (C) 2005 SSAB Oxelsund AB.
* Copyright (C) 2005 SSAB Oxelsund AB.
*
*
* This program is free software; you can redistribute it and/or
* This program is free software; you can redistribute it and/or
...
@@ -870,11 +870,12 @@ class GeDigLowColor : public GeDynElem {
...
@@ -870,11 +870,12 @@ class GeDigLowColor : public GeDynElem {
int
inverted
;
int
inverted
;
bool
first_scan
;
bool
first_scan
;
pwr_tBoolean
old_value
;
pwr_tBoolean
old_value
;
int
a_typeid
;
unsigned
int
bitmask
;
GeDigLowColor
(
GeDyn
*
e_dyn
)
:
GeDigLowColor
(
GeDyn
*
e_dyn
)
:
GeDynElem
(
e_dyn
,
ge_mDynType_DigLowColor
,
(
ge_mActionType
)
0
,
ge_eDynPrio_DigLowColor
),
GeDynElem
(
e_dyn
,
ge_mDynType_DigLowColor
,
(
ge_mActionType
)
0
,
ge_eDynPrio_DigLowColor
),
color
(
glow_eDrawType_Inherit
)
color
(
glow_eDrawType_Inherit
)
,
bitmask
(
0
)
{
strcpy
(
attribute
,
""
);}
{
strcpy
(
attribute
,
""
);}
GeDigLowColor
(
const
GeDigLowColor
&
x
)
:
GeDigLowColor
(
const
GeDigLowColor
&
x
)
:
GeDynElem
(
x
.
dyn
,
x
.
dyn_type
,
x
.
action_type
,
x
.
prio
),
color
(
x
.
color
)
GeDynElem
(
x
.
dyn
,
x
.
dyn_type
,
x
.
action_type
,
x
.
prio
),
color
(
x
.
color
)
...
@@ -939,9 +940,11 @@ class GeDigWarning : public GeDynElem {
...
@@ -939,9 +940,11 @@ class GeDigWarning : public GeDynElem {
int
inverted
;
int
inverted
;
bool
first_scan
;
bool
first_scan
;
pwr_tBoolean
old_value
;
pwr_tBoolean
old_value
;
int
a_typeid
;
unsigned
int
bitmask
;
GeDigWarning
(
GeDyn
*
e_dyn
)
:
GeDigWarning
(
GeDyn
*
e_dyn
)
:
GeDynElem
(
e_dyn
,
ge_mDynType_DigWarning
,
(
ge_mActionType
)
0
,
ge_eDynPrio_DigWarning
)
GeDynElem
(
e_dyn
,
ge_mDynType_DigWarning
,
(
ge_mActionType
)
0
,
ge_eDynPrio_DigWarning
)
,
bitmask
(
0
)
{
strcpy
(
attribute
,
""
);}
{
strcpy
(
attribute
,
""
);}
GeDigWarning
(
const
GeDigWarning
&
x
)
:
GeDigWarning
(
const
GeDigWarning
&
x
)
:
GeDynElem
(
x
.
dyn
,
x
.
dyn_type
,
x
.
action_type
,
x
.
prio
)
GeDynElem
(
x
.
dyn
,
x
.
dyn_type
,
x
.
action_type
,
x
.
prio
)
...
@@ -970,9 +973,11 @@ class GeDigError : public GeDynElem {
...
@@ -970,9 +973,11 @@ class GeDigError : public GeDynElem {
int
inverted
;
int
inverted
;
bool
first_scan
;
bool
first_scan
;
pwr_tBoolean
old_value
;
pwr_tBoolean
old_value
;
int
a_typeid
;
unsigned
int
bitmask
;
GeDigError
(
GeDyn
*
e_dyn
)
:
GeDigError
(
GeDyn
*
e_dyn
)
:
GeDynElem
(
e_dyn
,
ge_mDynType_DigError
,
(
ge_mActionType
)
0
,
ge_eDynPrio_DigError
)
GeDynElem
(
e_dyn
,
ge_mDynType_DigError
,
(
ge_mActionType
)
0
,
ge_eDynPrio_DigError
)
,
bitmask
(
0
)
{
strcpy
(
attribute
,
""
);}
{
strcpy
(
attribute
,
""
);}
GeDigError
(
const
GeDigError
&
x
)
:
GeDigError
(
const
GeDigError
&
x
)
:
GeDynElem
(
x
.
dyn
,
x
.
dyn_type
,
x
.
action_type
,
x
.
prio
)
GeDynElem
(
x
.
dyn
,
x
.
dyn_type
,
x
.
action_type
,
x
.
prio
)
...
...
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