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
6616c3b0
Commit
6616c3b0
authored
Mar 05, 2018
by
Claes Sjofors
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wb revisions, Git set as default, and 'Enable revisions' added in settings
parent
b9d0d49d
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
281 additions
and
70 deletions
+281
-70
src/exp/inc/src/pwr_names.h
src/exp/inc/src/pwr_names.h
+2
-1
src/msg/wb/src/wb_rev_msg.msg
src/msg/wb/src/wb_rev_msg.msg
+2
-0
wb/exp/com/src/os_linux/wb_revision.sh
wb/exp/com/src/os_linux/wb_revision.sh
+0
-1
wb/lib/wb/gtk/wb_wtt_gtk.cpp
wb/lib/wb/gtk/wb_wtt_gtk.cpp
+14
-8
wb/lib/wb/gtk/wb_wtt_gtk.h
wb/lib/wb/gtk/wb_wtt_gtk.h
+1
-0
wb/lib/wb/src/wb_revision.cpp
wb/lib/wb/src/wb_revision.cpp
+172
-48
wb/lib/wb/src/wb_revision.h
wb/lib/wb/src/wb_revision.h
+15
-2
wb/lib/wb/src/wb_wnav.cpp
wb/lib/wb/src/wb_wnav.cpp
+12
-2
wb/lib/wb/src/wb_wnav.h
wb/lib/wb/src/wb_wnav.h
+4
-3
wb/lib/wb/src/wb_wnav_command.cpp
wb/lib/wb/src/wb_wnav_command.cpp
+34
-1
wb/lib/wb/src/wb_wrev.cpp
wb/lib/wb/src/wb_wrev.cpp
+12
-2
wb/lib/wb/src/wb_wtt.cpp
wb/lib/wb/src/wb_wtt.cpp
+12
-2
wb/lib/wb/src/wb_wtt.h
wb/lib/wb/src/wb_wtt.h
+1
-0
No files found.
src/exp/inc/src/pwr_names.h
View file @
6616c3b0
...
...
@@ -55,6 +55,7 @@
# define pwr_cNameDistribute "$pwrp_root/src/db/pwrp_cnf_distribute.dat"
# define pwr_cNameSysObject "$pwrp_root/src/db/pwrp_cnf_sysobject.dat"
# define pwr_cNameFilePath "$pwrp_root/src/db/pwrp_cnf_dirlist.dat"
# define pwr_cNameRevision "$pwrp_root/src/db/pwrp_cnf_revision.dat"
# define pwr_cNameLocalWb "$pwrp_root/src/db/wb.wb_load"
# define pwr_cNameGblVolumeList "$pwra_db/pwr_volumelist.dat"
# define pwr_cNameCmnVolumeList "pwr_volumelist.dat"
...
...
@@ -71,4 +72,4 @@
# define pwr_cNameRedcom "%sld_redcom_%s_%04d.dat"
#endif
#endif
\ No newline at end of file
#endif
src/msg/wb/src/wb_rev_msg.msg
View file @
6616c3b0
...
...
@@ -48,3 +48,5 @@ noselect <No revision is selected> /error
createpos <Unable to create a new revision from current> /error
nosuchrev <No such revision> /error
nobranch <No branch is checked out> /info
nochange <No change since last revision> /error
nogit <Git not found> /error
\ No newline at end of file
wb/exp/com/src/os_linux/wb_revision.sh
View file @
6616c3b0
...
...
@@ -54,7 +54,6 @@ pwrc_dblist_read()
pwrc_status
=
$pwrc__success
#set -o xtrace
echo
"arg1:
\"
$1
\"
arg2:
\"
$2
\"
arg3:
\"
$3
\"
"
if
[
-n
"
${
db_array
[*]
}
"
]
;
then
unset
db_array
...
...
wb/lib/wb/gtk/wb_wtt_gtk.cpp
View file @
6616c3b0
...
...
@@ -1905,6 +1905,7 @@ void WttGtk::boot_ok_cb(GtkWidget *w, gpointer data)
GtkTreeIter
iter
;
GtkTreeModel
*
store
;
char
*
text
;
int
node_type
;
if
(
!
wtt
->
focused_wnav
)
wtt
->
set_focus_default
();
...
...
@@ -1929,9 +1930,10 @@ void WttGtk::boot_ok_cb(GtkWidget *w, gpointer data)
strcpy
(
nodeconfigname
,
volumelist_ptr
->
p1
);
if
(
strcmp
(
nodeconfigname
,
text
)
==
0
)
{
node_type
=
atoi
(
volumelist_ptr
->
p6
);
wb_build
build
(
*
(
wb_session
*
)
wtt
->
ldhses
,
wtt
->
focused_wnav
);
build
.
opt
=
wtt
->
focused_wnav
->
gbl
.
build
;
build
.
node
(
nodeconfigname
,
build
.
node
(
nodeconfigname
,
node_type
,
wtt
->
boot_volumelist
,
wtt
->
boot_volumecount
);
if
(
build
.
evenSts
())
{
gtk_widget_destroy
(
((
WttGtk
*
)
wtt
)
->
boot_dia
);
...
...
@@ -1970,6 +1972,7 @@ void WttGtk::update_options_form()
{
// Hierarchies
gtk_toggle_button_set_active
(
GTK_TOGGLE_BUTTON
(
enable_comment_w
),
enable_comment
?
TRUE
:
FALSE
);
gtk_toggle_button_set_active
(
GTK_TOGGLE_BUTTON
(
enable_revisions_w
),
enable_revisions
?
TRUE
:
FALSE
);
gtk_toggle_button_set_active
(
GTK_TOGGLE_BUTTON
(
show_plant_w
),
wnav_mapped
?
TRUE
:
FALSE
);
gtk_toggle_button_set_active
(
GTK_TOGGLE_BUTTON
(
show_node_w
),
wnavnode_mapped
?
TRUE
:
FALSE
);
...
...
@@ -2000,6 +2003,7 @@ void WttGtk::update_options_form()
void
WttGtk
::
set_options
()
{
enable_comment
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
enable_comment_w
));
enable_revisions
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
enable_revisions_w
));
show_class
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
show_class_w
));
show_alias
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
show_alias_w
));
show_descrip
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
show_descrip_w
));
...
...
@@ -2013,14 +2017,13 @@ void WttGtk::set_options()
build_crossref_sim
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
build_crossrefsim_w
));
build_crossref_graph
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
build_crossrefgraph_w
));
build_manual
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
build_manual_w
));
build_nocopy
=
(
int
)
gtk_toggle_button_get_active
(
GTK_TOGGLE_BUTTON
(
build_nocopy_w
));
wnav
->
set_options
(
enable_comment
,
show_class
,
show_alias
,
wnav
->
set_options
(
enable_comment
,
enable_revisions
,
show_class
,
show_alias
,
show_descrip
,
show_objref
,
show_objxref
,
show_attrref
,
show_attrxref
,
build_force
,
build_debug
,
build_crossref
,
build_crossref_sim
,
build_crossref_graph
,
build_manual
,
build_nocopy
);
wnavnode
->
set_options
(
enable_comment
,
show_class
,
show_alias
,
wnavnode
->
set_options
(
enable_comment
,
enable_revisions
,
show_class
,
show_alias
,
show_descrip
,
show_objref
,
show_objxref
,
show_attrref
,
show_attrxref
,
build_force
,
build_debug
,
build_crossref
,
build_crossref_sim
,
build_crossref_graph
,
...
...
@@ -2115,10 +2118,11 @@ WttGtk::WttGtk(
pwr_tFileName
fname
;
wb_rev_info
rev_info
;
char
version
[
80
];
pwr_tStatus
revsts
;
wb_revision
::
info
(
&
rev_info
);
if
(
!
rev_info
.
in_master
)
revsts
=
wb_revision
::
info
(
&
rev_info
);
if
(
ODD
(
revsts
)
&&
!
rev_info
.
in_master
)
strcpy
(
version
,
rev_info
.
name
);
else
strcpy
(
version
,
""
);
...
...
@@ -3087,7 +3091,7 @@ WttGtk::WttGtk(
g_object_set
(
cmd_input
,
"visible"
,
FALSE
,
NULL
);
gtk_paned_set_position
(
GTK_PANED
(
wnav_paned
),
window_width
/
2
);
wnav
->
get_options
(
&
enable_comment
,
&
show_class
,
&
show_alias
,
wnav
->
get_options
(
&
enable_comment
,
&
enable_revisions
,
&
show_class
,
&
show_alias
,
&
show_descrip
,
&
show_objref
,
&
show_objxref
,
&
show_attrref
,
&
show_attrxref
,
&
build_force
,
&
build_debug
,
&
build_crossref
,
&
build_crossref_sim
,
&
build_crossref_graph
,
...
...
@@ -3122,7 +3126,7 @@ WttGtk::WttGtk(
menu_setup
();
update_title
();
if
(
!
rev_info
.
in_end_of_branch
)
{
if
(
ODD
(
revsts
)
&&
!
rev_info
.
in_end_of_branch
)
{
wnav
->
wow
->
DisplayError
(
"Revision"
,
"Revision is not at end o branch.
\n
No changes can be made."
);
CoLogin
::
reduce_privilege
(
pwr_mPrv_DevConfig
|
pwr_mPrv_DevPlc
|
pwr_mPrv_DevClass
);
}
...
...
@@ -3192,12 +3196,14 @@ void WttGtk::create_options_dialog()
GtkWidget
*
hier_label
=
gtk_label_new
(
"Hierarchy"
);
enable_comment_w
=
gtk_check_button_new_with_label
(
"Enable Comment"
);
enable_revisions_w
=
gtk_check_button_new_with_label
(
"Enable Revisions"
);
show_plant_w
=
gtk_check_button_new_with_label
(
"Plant Configuration"
);
show_node_w
=
gtk_check_button_new_with_label
(
"Node Configuration"
);
GtkWidget
*
hier_vbox
=
gtk_vbox_new
(
FALSE
,
0
);
gtk_box_pack_start
(
GTK_BOX
(
hier_vbox
),
hier_label
,
FALSE
,
FALSE
,
15
);
gtk_box_pack_start
(
GTK_BOX
(
hier_vbox
),
enable_comment_w
,
FALSE
,
FALSE
,
7
);
gtk_box_pack_start
(
GTK_BOX
(
hier_vbox
),
enable_revisions_w
,
FALSE
,
FALSE
,
7
);
gtk_box_pack_start
(
GTK_BOX
(
hier_vbox
),
show_plant_w
,
FALSE
,
FALSE
,
7
);
gtk_box_pack_start
(
GTK_BOX
(
hier_vbox
),
show_node_w
,
FALSE
,
FALSE
,
7
);
...
...
wb/lib/wb/gtk/wb_wtt_gtk.h
View file @
6616c3b0
...
...
@@ -102,6 +102,7 @@ class WttGtk : public Wtt {
GtkWidget
*
build_crossrefgraph_w
;
GtkWidget
*
build_manual_w
;
GtkWidget
*
build_nocopy_w
;
GtkWidget
*
enable_revisions_w
;
GtkWidget
*
menu_save_w
;
GtkWidget
*
menu_revert_w
;
GtkWidget
*
menu_cut_w
;
...
...
wb/lib/wb/src/wb_revision.cpp
View file @
6616c3b0
...
...
@@ -37,6 +37,7 @@
#include <vector>
#include "pwr.h"
#include "pwr_names.h"
#include "co_time.h"
#include "co_dcli.h"
#include "wb_revision.h"
...
...
@@ -49,50 +50,37 @@
wb_revision
::
wb_revision
(
void
*
parent_ctx
,
wb_session
*
ses
)
:
m_parent_ctx
(
parent_ctx
),
m_session
(
ses
),
m_manager
(
0
),
m_manager_enum
(
pwr_eVersionManagerEnum_None
),
m_read
(
false
),
m_current_idx
(
-
1
),
m_current_main_idx
(
-
1
),
m_current_sub_idx
(
-
1
),
m_command_cb
(
0
)
m_parent_ctx
(
parent_ctx
),
m_session
(
ses
),
m_manager
(
0
),
m_manager_enum
(
pwr_eVersionManagerEnum_Git
),
m_read
(
false
),
m_current_idx
(
-
1
),
m_current_main_idx
(
-
1
),
m_current_sub_idx
(
-
1
),
m_next_idx
(
0
),
m_command_cb
(
0
)
{
char
current
[
80
];
read_file
();
switch
(
m_manager_enum
)
{
case
pwr_eVersionManagerEnum_Git
:
m_manager
=
new
wb_version_manager_git
();
if
(
EVEN
(
m_manager
->
sts
()))
{
delete
m_manager
;
m_manager
=
0
;
}
break
;
default:
;
}
if
(
m_manager
)
{
char
current_name
[
80
];
m_sts
=
m_manager
->
check
(
m_vect
);
bool
found
=
false
;
m_sts
=
m_manager
->
get_current
(
current
);
if
(
ODD
(
m_sts
))
{
for
(
unsigned
int
i
=
0
;
i
<
m_vect
.
size
();
i
++
)
{
if
(
cdh_NoCaseStrcmp
(
current
,
m_vect
[
i
].
name
)
==
0
)
{
m_current_idx
=
m_vect
[
i
].
idx
;
m_current_main_idx
=
i
;
m_current_sub_idx
=
-
1
;
m_vect
[
i
].
current
=
true
;
found
=
true
;
break
;
}
for
(
unsigned
int
j
=
0
;
j
<
m_vect
[
i
].
vect
.
size
();
j
++
)
{
if
(
cdh_NoCaseStrcmp
(
current
,
m_vect
[
i
].
vect
[
j
].
name
)
==
0
)
{
m_current_idx
=
m_vect
[
i
].
vect
[
j
].
idx
;
m_current_main_idx
=
i
;
m_current_sub_idx
=
j
;
m_vect
[
i
].
vect
[
j
].
current
=
true
;
m_vect
[
i
].
current_branch
=
true
;
found
=
true
;
break
;
}
}
if
(
found
)
break
;
}
}
m_sts
=
m_manager
->
get_current
(
current_name
);
if
(
ODD
(
m_sts
))
set_current
(
current_name
);
else
set_current
(
m_current_idx
);
}
else
{
set_current
(
m_current_idx
);
}
}
...
...
@@ -105,11 +93,75 @@ wb_revision::wb_revision():
switch
(
m_manager_enum
)
{
case
pwr_eVersionManagerEnum_Git
:
m_manager
=
new
wb_version_manager_git
();
if
(
EVEN
(
m_manager
->
sts
()))
{
delete
m_manager
;
m_manager
=
0
;
}
break
;
default:
;
}
}
bool
wb_revision
::
set_current
(
int
idx
)
{
bool
found
=
false
;
for
(
unsigned
int
i
=
0
;
i
<
m_vect
.
size
();
i
++
)
{
if
(
m_vect
[
i
].
idx
==
idx
)
{
m_current_main_idx
=
i
;
m_current_sub_idx
=
-
1
;
m_vect
[
i
].
current
=
true
;
m_current_idx
=
idx
;
found
=
true
;
break
;
}
for
(
unsigned
int
j
=
0
;
j
<
m_vect
[
i
].
vect
.
size
();
j
++
)
{
if
(
m_vect
[
i
].
vect
[
j
].
idx
==
idx
)
{
m_current_main_idx
=
i
;
m_current_sub_idx
=
j
;
m_vect
[
i
].
vect
[
j
].
current
=
true
;
m_vect
[
i
].
current_branch
=
true
;
m_current_idx
=
idx
;
found
=
true
;
break
;
}
}
if
(
found
)
break
;
}
return
found
;
}
bool
wb_revision
::
set_current
(
char
*
name
)
{
bool
found
=
false
;
for
(
unsigned
int
i
=
0
;
i
<
m_vect
.
size
();
i
++
)
{
if
(
cdh_NoCaseStrcmp
(
name
,
m_vect
[
i
].
name
)
==
0
)
{
m_current_idx
=
m_vect
[
i
].
idx
;
m_current_main_idx
=
i
;
m_current_sub_idx
=
-
1
;
m_vect
[
i
].
current
=
true
;
found
=
true
;
break
;
}
for
(
unsigned
int
j
=
0
;
j
<
m_vect
[
i
].
vect
.
size
();
j
++
)
{
if
(
cdh_NoCaseStrcmp
(
name
,
m_vect
[
i
].
vect
[
j
].
name
)
==
0
)
{
m_current_idx
=
m_vect
[
i
].
vect
[
j
].
idx
;
m_current_main_idx
=
i
;
m_current_sub_idx
=
j
;
m_vect
[
i
].
vect
[
j
].
current
=
true
;
m_vect
[
i
].
current_branch
=
true
;
found
=
true
;
break
;
}
}
if
(
found
)
break
;
}
return
found
;
}
char
*
wb_revision
::
branch_name
(
char
*
name
)
{
static
char
bname
[
80
];
...
...
@@ -141,6 +193,8 @@ pwr_tStatus wb_revision::create_check()
pwr_tStatus
wb_revision
::
create
(
int
all
,
char
*
name
,
char
*
descr
)
{
if
(
m_manager
&&
!
m_manager
->
modified
())
return
REV__NOCHANGE
;
if
(
all
)
{
// Get current volume
...
...
@@ -216,7 +270,8 @@ pwr_tStatus wb_revision::create( int all, char *name, char *descr)
// Add to revision file
add
(
name
,
descr
,
(
char
*
)
pwrv_cPwrVersionStr
,
0
,
in_main
,
main_idx
);
write_file
();
set_current
(
m_next_idx
-
1
);
write_file
();
wb_log
::
log
(
wlog_eCategory_NewRevision
,
name
,
descr
);
}
...
...
@@ -513,11 +568,10 @@ void wb_revision::read_file()
{
pwr_tFileName
fname
;
char
line
[
200
];
char
item_array
[
6
][
80
];
char
item_array
[
7
][
80
];
int
sts
;
int
idx
=
0
;
dcli_translate_filename
(
fname
,
"$pwrp_db/pwrp_cnf_revision.dat"
);
dcli_translate_filename
(
fname
,
pwr_cNameRevision
);
ifstream
fp
(
fname
,
ios
::
in
);
if
(
!
fp
)
{
m_read
=
true
;
...
...
@@ -539,24 +593,40 @@ void wb_revision::read_file()
m_manager_enum
=
pwr_eVersionManagerEnum_None
;
continue
;
}
if
(
nr
!=
5
)
{
if
(
nr
==
3
&&
strcmp
(
item_array
[
0
],
"#!"
)
==
0
&&
strcmp
(
item_array
[
1
],
"Current"
)
==
0
)
{
int
current
;
int
num
;
num
=
sscanf
(
item_array
[
2
],
"%d"
,
&
current
);
if
(
num
==
1
)
m_current_idx
=
current
;
else
m_current_idx
=
-
1
;
continue
;
}
if
(
nr
!=
6
)
{
m_sts
=
0
;
return
;
}
sts
=
sscanf
(
item_array
[
0
],
"%d"
,
&
item
.
level
);
sts
=
sscanf
(
item_array
[
0
],
"%d"
,
&
item
.
idx
);
if
(
sts
!=
1
)
printf
(
"** Syntax error in configuration file
\n
"
);
sts
=
sscanf
(
item_array
[
1
],
"%d"
,
&
item
.
level
);
if
(
sts
!=
1
)
printf
(
"** Syntax error in configuration file
\n
"
);
strncpy
(
item
.
name
,
item_array
[
1
],
sizeof
(
item
.
name
));
strncpy
(
item
.
description
,
item_array
[
2
],
sizeof
(
item
.
description
));
strncpy
(
item
.
version
,
item_array
[
3
],
sizeof
(
item
.
version
));
time_AsciiToA
(
item_array
[
4
],
&
item
.
date
);
item
.
idx
=
idx
++
;
strncpy
(
item
.
name
,
item_array
[
2
],
sizeof
(
item
.
name
));
strncpy
(
item
.
description
,
item_array
[
3
],
sizeof
(
item
.
description
));
strncpy
(
item
.
version
,
item_array
[
4
],
sizeof
(
item
.
version
));
time_AsciiToA
(
item_array
[
5
],
&
item
.
date
);
if
(
item
.
level
==
0
)
m_vect
.
push_back
(
item
);
else
if
(
m_vect
.
size
()
>
0
)
m_vect
[
m_vect
.
size
()
-
1
].
vect
.
push_back
(
item
);
if
(
m_next_idx
<
item
.
idx
+
1
)
m_next_idx
=
item
.
idx
+
1
;
}
fp
.
close
();
...
...
@@ -569,7 +639,7 @@ void wb_revision::read_file_meta()
char
line
[
200
];
char
item_array
[
6
][
80
];
dcli_translate_filename
(
fname
,
"$pwrp_db/pwrp_cnf_revision.dat"
);
dcli_translate_filename
(
fname
,
pwr_cNameRevision
);
ifstream
fp
(
fname
,
ios
::
in
);
if
(
!
fp
)
{
m_read
=
true
;
...
...
@@ -591,6 +661,17 @@ void wb_revision::read_file_meta()
m_manager_enum
=
pwr_eVersionManagerEnum_None
;
continue
;
}
if
(
nr
==
3
&&
strcmp
(
item_array
[
0
],
"#!"
)
==
0
&&
strcmp
(
item_array
[
1
],
"Current"
)
==
0
)
{
int
current
;
int
num
;
num
=
sscanf
(
item_array
[
2
],
"%d"
,
&
current
);
if
(
num
==
1
)
m_current_idx
=
current
;
else
m_current_idx
=
-
1
;
continue
;
}
if
(
strcmp
(
item_array
[
0
],
"#!"
)
!=
0
)
break
;
}
...
...
@@ -605,7 +686,7 @@ void wb_revision::write_file()
if
(
!
m_read
)
return
;
dcli_translate_filename
(
fname
,
"$pwrp_db/pwrp_cnf_revision.dat"
);
dcli_translate_filename
(
fname
,
pwr_cNameRevision
);
ofstream
fp
(
fname
,
ios
::
out
);
if
(
!
fp
)
{
m_sts
=
0
;
...
...
@@ -613,14 +694,15 @@ void wb_revision::write_file()
}
fp
<<
"#! RevisionManager "
<<
m_manager_enum
<<
endl
;
fp
<<
"#! Current "
<<
m_current_idx
<<
endl
;
for
(
unsigned
int
i
=
0
;
i
<
m_vect
.
size
();
i
++
)
{
time_AtoAscii
(
&
m_vect
[
i
].
date
,
time_eFormat_DateAndTime
,
timestr
,
sizeof
(
timestr
));
fp
<<
m_vect
[
i
].
level
<<
" "
<<
m_vect
[
i
].
name
<<
" "
<<
"
\"
"
<<
m_vect
[
i
].
description
<<
"
\"
"
<<
m_vect
[
i
].
version
<<
"
\"
"
<<
timestr
<<
"
\"
"
<<
endl
;
fp
<<
m_vect
[
i
].
idx
<<
" "
<<
m_vect
[
i
].
level
<<
" "
<<
m_vect
[
i
].
name
<<
" "
<<
"
\"
"
<<
m_vect
[
i
].
description
<<
"
\"
"
<<
m_vect
[
i
].
version
<<
"
\"
"
<<
timestr
<<
"
\"
"
<<
endl
;
for
(
unsigned
int
j
=
0
;
j
<
m_vect
[
i
].
vect
.
size
();
j
++
)
{
time_AtoAscii
(
&
m_vect
[
i
].
vect
[
j
].
date
,
time_eFormat_DateAndTime
,
timestr
,
sizeof
(
timestr
));
fp
<<
m_vect
[
i
].
vect
[
j
].
level
<<
" "
<<
m_vect
[
i
].
vect
[
j
].
name
<<
" "
<<
"
\"
"
<<
m_vect
[
i
].
vect
[
j
].
description
<<
"
\"
"
<<
m_vect
[
i
].
vect
[
j
].
version
<<
"
\"
"
<<
timestr
<<
"
\"
"
<<
endl
;
fp
<<
m_vect
[
i
].
vect
[
j
].
idx
<<
" "
<<
m_vect
[
i
].
vect
[
j
].
level
<<
" "
<<
m_vect
[
i
].
vect
[
j
].
name
<<
" "
<<
"
\"
"
<<
m_vect
[
i
].
vect
[
j
].
description
<<
"
\"
"
<<
m_vect
[
i
].
vect
[
j
].
version
<<
"
\"
"
<<
timestr
<<
"
\"
"
<<
endl
;
}
}
fp
.
close
();
...
...
@@ -634,7 +716,7 @@ int wb_revision::add( char *name, char *description, char *version, pwr_tTime *d
if
(
!
m_read
)
read_file
();
// Check the name is unique
// Check th
at th
e name is unique
for
(
unsigned
int
i
=
0
;
i
<
m_vect
.
size
();
i
++
)
{
if
(
cdh_NoCaseStrcmp
(
name
,
m_vect
[
i
].
name
)
==
0
)
{
return
0
;
...
...
@@ -648,6 +730,7 @@ int wb_revision::add( char *name, char *description, char *version, pwr_tTime *d
item
.
date
=
*
date
;
else
time_GetTime
(
&
item
.
date
);
item
.
idx
=
m_next_idx
++
;
if
(
in_main
)
{
item
.
level
=
0
;
...
...
@@ -719,11 +802,21 @@ void wb_revision::get_info( wb_rev_info *info)
}
}
void
wb_revision
::
info
(
wb_rev_info
*
info
)
pwr_tStatus
wb_revision
::
info
(
wb_rev_info
*
info
)
{
pwr_tFileName
fname
;
pwr_tStatus
sts
;
pwr_tTime
time
;
dcli_translate_filename
(
fname
,
pwr_cNameRevision
);
sts
=
dcli_file_time
(
fname
,
&
time
);
if
(
EVEN
(
sts
))
return
sts
;
wb_revision
*
rev
=
new
wb_revision
(
0
,
0
);
rev
->
get_info
(
info
);
delete
rev
;
return
REV__SUCCESS
;
}
//
...
...
@@ -777,6 +870,23 @@ int wb_revision::check_add_file( char *filename)
return
0
;
}
bool
wb_version_manager_git
::
m_found
=
false
;
bool
wb_version_manager_git
::
m_found_tested
=
false
;
bool
wb_version_manager_git
::
git_found
()
{
if
(
!
m_found_tested
)
{
int
sts
;
sts
=
system
(
"git --version > /dev/null 2> /dev/null"
);
m_found
=
sts
==
0
?
true
:
false
;
m_found_tested
=
true
;
if
(
!
m_found
)
m_sts
=
REV__NOGIT
;
}
return
m_found
;
}
void
wb_version_manager_git
::
init
()
{
pwr_tFileName
fname
;
...
...
@@ -784,6 +894,9 @@ void wb_version_manager_git::init()
pwr_tTime
t
;
bool
new_git
=
false
;
if
(
!
git_found
())
return
;
dcli_translate_filename
(
m_git_dir
,
"$pwrp_root/src/.git"
);
dcli_translate_filename
(
m_work_tree
,
"$pwrp_root/src"
);
if
(
EVEN
(
dcli_file_time
(
m_git_dir
,
&
t
)))
{
...
...
@@ -841,7 +954,7 @@ db/rt_eventlog_info.txt" << endl;
snprintf
(
cmd
,
sizeof
(
cmd
),
"git --git-dir=%s --work-tree=%s commit -m
\"
Initial commit
\"
-a"
,
m_git_dir
,
m_work_tree
);
system
(
cmd
);
}
m_sts
=
REV__SUCCESS
;
}
int
wb_version_manager_git
::
store_revision
(
char
*
name
,
char
*
descr
,
bool
new_branch
)
...
...
@@ -948,6 +1061,9 @@ int wb_version_manager_git::check( vector<wb_rev_item>& v)
pwr_tFileName
fname
=
"$pwrp_tmp/git_tags.dat"
;
char
line
[
80
];
if
(
!
git_found
())
return
REV__NOGIT
;
dcli_translate_filename
(
fname
,
fname
);
// Get current tag
...
...
@@ -1012,3 +1128,11 @@ int wb_version_manager_git::check_add( char *filename)
return
1
;
}
bool
wb_version_manager_git
::
modified
()
{
int
sts
;
sts
=
system
(
"git diff --exit-code"
);
return
sts
!=
0
;
}
wb/lib/wb/src/wb_revision.h
View file @
6616c3b0
...
...
@@ -76,9 +76,12 @@ class wb_version_manager
{
private:
pwr_eVersionManagerEnum
m_manager
;
protected:
pwr_tStatus
m_sts
;
public:
wb_version_manager
(
pwr_eVersionManagerEnum
manager
)
:
m_manager
(
manager
)
{}
wb_version_manager
(
pwr_eVersionManagerEnum
manager
)
:
m_manager
(
manager
),
m_sts
(
0
)
{}
pwr_tStatus
sts
()
{
return
m_sts
;}
virtual
~
wb_version_manager
()
{}
virtual
void
init
()
{}
virtual
int
store_revision
(
char
*
name
,
char
*
descr
,
bool
new_branch
)
{
return
0
;}
...
...
@@ -86,10 +89,16 @@ class wb_version_manager
virtual
int
get_current
(
char
*
name
)
{
return
0
;}
virtual
int
check
(
vector
<
wb_rev_item
>&
v
)
{
return
0
;}
virtual
int
check_add
(
char
*
filename
)
{
return
0
;}
virtual
bool
modified
()
{
return
true
;}
};
class
wb_version_manager_git
:
public
wb_version_manager
{
static
bool
m_found
;
static
bool
m_found_tested
;
bool
git_found
();
public:
wb_version_manager_git
()
:
wb_version_manager
(
pwr_eVersionManagerEnum_None
)
{
init
();}
~
wb_version_manager_git
()
{}
...
...
@@ -101,6 +110,7 @@ class wb_version_manager_git : public wb_version_manager
int
get_current
(
char
*
name
);
int
check
(
vector
<
wb_rev_item
>&
v
);
int
check_add
(
char
*
filename
);
bool
modified
();
};
class
wb_revision
:
public
wb_status
...
...
@@ -115,6 +125,7 @@ class wb_revision : public wb_status
int
m_current_idx
;
int
m_current_main_idx
;
int
m_current_sub_idx
;
int
m_next_idx
;
int
(
*
m_command_cb
)(
void
*
ctx
,
char
*
cmd
);
public:
...
...
@@ -129,6 +140,8 @@ class wb_revision : public wb_status
pwr_tStatus
restore
(
char
*
name
);
pwr_tStatus
build_all
();
pwr_tStatus
remove
(
char
*
name
);
bool
set_current
(
char
*
name
);
bool
set_current
(
int
idx
);
void
read_file
();
void
read_file_meta
();
void
write_file
();
...
...
@@ -146,7 +159,7 @@ class wb_revision : public wb_status
void
next_name
(
char
*
name
);
static
char
*
branch_name
(
char
*
name
);
static
void
info
(
wb_rev_info
*
info
);
static
pwr_tStatus
info
(
wb_rev_info
*
info
);
static
int
check_add_file
(
char
*
filename
);
};
...
...
wb/lib/wb/src/wb_wnav.cpp
View file @
6616c3b0
...
...
@@ -2271,6 +2271,9 @@ int WNav::setup()
new
WItemLocal
(
this
,
"EnableComment"
,
"setup_comment"
,
pwr_eType_Int32
,
sizeof
(
gbl
.
enable_comment
),
0
,
1
,
(
void
*
)
&
gbl
.
enable_comment
,
NULL
,
flow_eDest_IntoLast
);
new
WItemLocal
(
this
,
"EnableRevisions"
,
"setup_revisions"
,
pwr_eType_Int32
,
sizeof
(
gbl
.
enable_revisions
),
0
,
1
,
(
void
*
)
&
gbl
.
enable_revisions
,
NULL
,
flow_eDest_IntoLast
);
new
WItemLocal
(
this
,
"AdvancedUser"
,
"setup_advanceduser"
,
pwr_eType_Int32
,
sizeof
(
gbl
.
advanced_user
),
0
,
1
,
(
void
*
)
&
gbl
.
advanced_user
,
NULL
,
flow_eDest_IntoLast
);
...
...
@@ -2351,12 +2354,13 @@ int WNavGbl::symbolfile_exec( void *wnav)
return
WNAV__SUCCESS
;
}
void
WNav
::
set_options
(
int
ena_comment
,
int
sh_class
,
int
sh_alias
,
int
sh_descrip
,
void
WNav
::
set_options
(
int
ena_comment
,
int
ena_revisions
,
int
sh_class
,
int
sh_alias
,
int
sh_descrip
,
int
sh_objref
,
int
sh_objxref
,
int
sh_attrref
,
int
sh_attrxref
,
int
bu_force
,
int
bu_debug
,
int
bu_crossref
,
int
bu_crossrefsim
,
int
bu_crossrefgraph
,
int
bu_manual
,
int
bu_nocopy
)
{
gbl
.
enable_comment
=
ena_comment
;
gbl
.
enable_revisions
=
ena_revisions
;
gbl
.
show_class
=
sh_class
;
gbl
.
show_alias
=
sh_alias
;
gbl
.
show_descrip
=
sh_descrip
;
...
...
@@ -2374,12 +2378,13 @@ void WNav::set_options( int ena_comment, int sh_class, int sh_alias, int sh_desc
ldh_refresh
(
pwr_cNObjid
);
}
void
WNav
::
get_options
(
int
*
ena_comment
,
int
*
sh_class
,
int
*
sh_alias
,
int
*
sh_descrip
,
void
WNav
::
get_options
(
int
*
ena_comment
,
int
*
ena_revisions
,
int
*
sh_class
,
int
*
sh_alias
,
int
*
sh_descrip
,
int
*
sh_objref
,
int
*
sh_objxref
,
int
*
sh_attrref
,
int
*
sh_attrxref
,
int
*
bu_force
,
int
*
bu_debug
,
int
*
bu_crossref
,
int
*
bu_crossrefsim
,
int
*
bu_crossrefgraph
,
int
*
bu_manual
,
int
*
bu_nocopy
)
{
*
ena_comment
=
gbl
.
enable_comment
;
*
ena_revisions
=
gbl
.
enable_revisions
;
*
sh_class
=
gbl
.
show_class
;
*
sh_alias
=
gbl
.
show_alias
;
*
sh_descrip
=
gbl
.
show_descrip
;
...
...
@@ -2486,6 +2491,11 @@ int WNav::save_settnings( ofstream& fp)
else
fp
<<
" set nobuildnocopy /local"
<<
endl
;
if
(
gbl
.
enable_revisions
)
fp
<<
" set enablerevisions /local"
<<
endl
;
else
fp
<<
" set noenablerevisions /local"
<<
endl
;
if
(
window_type
==
wnav_eWindowType_W1
)
fp
<<
"endif"
<<
endl
;
else
if
(
window_type
==
wnav_eWindowType_W2
)
...
...
wb/lib/wb/src/wb_wnav.h
View file @
6616c3b0
...
...
@@ -202,7 +202,7 @@ class WNavGbl {
priv
(
0
),
verify
(
0
),
advanced_user
(
1
),
all_toplevel
(
0
),
bypass
(
0
),
show_class
(
1
),
show_alias
(
0
),
show_descrip
(
1
),
show_attrref
(
0
),
show_attrxref
(
0
),
show_objref
(
0
),
show_objxref
(
0
),
show_truedb
(
0
),
enable_comment
(
0
)
enable_comment
(
0
)
,
enable_revisions
(
0
)
{
strcpy
(
version
,
wnav_cVersion
);
strcpy
(
platform
,
""
);
strcpy
(
os
,
""
);
strcpy
(
hw
,
""
);
...
...
@@ -231,6 +231,7 @@ class WNavGbl {
int
show_objxref
;
int
show_truedb
;
int
enable_comment
;
int
enable_revisions
;
wb_build_opt
build
;
int
load_config
(
void
*
wnav
);
...
...
@@ -412,11 +413,11 @@ class WNav : public WUtility{
void
ldh_refresh
(
pwr_tObjid
new_open
);
void
refresh
();
void
collapse
();
void
set_options
(
int
ena_comment
,
int
sh_class
,
int
sh_alias
,
int
sh_descrip
,
void
set_options
(
int
ena_comment
,
int
ena_revisions
,
int
sh_class
,
int
sh_alias
,
int
sh_descrip
,
int
sh_objref
,
int
sh_objxref
,
int
sh_attrref
,
int
sh_attrxref
,
int
bu_force
,
int
bu_debug
,
int
bu_crossref
,
int
bu_crossrefsim
,
int
bu_crossrefgraph
,
int
bu_manual
,
int
bu_nocopy
);
void
get_options
(
int
*
ena_comment
,
int
*
sh_class
,
int
*
sh_alias
,
int
*
sh_descrip
,
void
get_options
(
int
*
ena_comment
,
int
*
ena_revisions
,
int
*
sh_class
,
int
*
sh_alias
,
int
*
sh_descrip
,
int
*
sh_objref
,
int
*
sh_objxref
,
int
*
sh_attrref
,
int
*
sh_attrxref
,
int
*
bu_force
,
int
*
bu_debug
,
int
*
bu_crossref
,
int
*
bu_crossrefsim
,
int
*
bu_crossrefgraph
,
int
*
bu_manual
,
int
*
bu_nocopy
);
...
...
wb/lib/wb/src/wb_wnav_command.cpp
View file @
6616c3b0
...
...
@@ -1398,6 +1398,20 @@ static int wnav_set_func( void *client_data,
else
wnav
->
gbl
.
enable_comment
=
0
;
}
else
if
(
cdh_NoCaseStrncmp
(
arg1_str
,
"ENABLEREVISIONS"
,
strlen
(
arg1_str
))
==
0
)
{
if
(
EVEN
(
dcli_get_qualifier
(
"/LOCAL"
,
0
,
0
)))
(
wnav
->
gbl_command_cb
)(
wnav
->
parent_ctx
,
"SET ENABLEREVISIONS"
);
else
wnav
->
gbl
.
enable_revisions
=
1
;
}
else
if
(
cdh_NoCaseStrncmp
(
arg1_str
,
"NOENABLEREVISIONS"
,
strlen
(
arg1_str
))
==
0
)
{
if
(
EVEN
(
dcli_get_qualifier
(
"/LOCAL"
,
0
,
0
)))
(
wnav
->
gbl_command_cb
)(
wnav
->
parent_ctx
,
"SET NOENABLEREVISIONS"
);
else
wnav
->
gbl
.
enable_revisions
=
0
;
}
else
if
(
cdh_NoCaseStrncmp
(
arg1_str
,
"VERIFY"
,
strlen
(
arg1_str
))
==
0
)
{
if
(
wnav
->
window_type
==
wnav_eWindowType_No
)
...
...
@@ -5272,6 +5286,9 @@ static int wnav_build_func( void *client_data,
char
namestr
[
80
];
void
*
volumelist
;
int
volumecount
;
lfu_t_volumelist
*
vp
;
int
found
;
int
node_type
;
if
(
EVEN
(
dcli_get_qualifier
(
"/NAME"
,
namestr
,
sizeof
(
namestr
))))
{
if
(
EVEN
(
dcli_get_qualifier
(
"dcli_arg2"
,
namestr
,
sizeof
(
namestr
))))
{
...
...
@@ -5288,13 +5305,29 @@ static int wnav_build_func( void *client_data,
return
sts
;
}
found
=
0
;
vp
=
(
lfu_t_volumelist
*
)
volumelist
;
for
(
int
i
=
0
;
i
<
volumecount
;
i
++
)
{
if
(
cdh_NoCaseStrcmp
(
vp
[
i
].
p1
,
namestr
)
==
0
)
{
found
=
1
;
node_type
=
atoi
(
vp
[
i
].
p6
);
break
;
}
}
if
(
!
found
)
{
wnav
->
message
(
'E'
,
"No such node"
);
return
WNAV__SYNTAX
;
}
wb_build
build
(
*
(
wb_session
*
)
wnav
->
ldhses
,
wnav
);
build
.
opt
.
force
=
ODD
(
dcli_get_qualifier
(
"/FORCE"
,
0
,
0
));
build
.
opt
.
debug
=
ODD
(
dcli_get_qualifier
(
"/DEBUG"
,
0
,
0
));
build
.
opt
.
crossref
=
ODD
(
dcli_get_qualifier
(
"/CROSSREFERENCE"
,
0
,
0
));
build
.
opt
.
manual
=
ODD
(
dcli_get_qualifier
(
"/MANUAL"
,
0
,
0
));
build
.
node
(
namestr
,
volumelist
,
volumecount
);
build
.
node
(
vp
->
p1
,
node_type
,
volumelist
,
volumecount
);
wnav
->
message
(
' '
,
wnav_get_message
(
build
.
sts
()));
command_sts
=
build
.
sts
();
...
...
wb/lib/wb/src/wb_wrev.cpp
View file @
6616c3b0
...
...
@@ -85,6 +85,16 @@ void WRev::store_ok_cb( WRev *wrev, char *text1, char *text2)
{
pwr_tStatus
sts
;
if
(
strcmp
(
text1
,
""
)
==
0
)
{
wrev
->
wow
->
DisplayError
(
"Syntax Error"
,
"Revision name is missing"
);
return
;
}
if
(
strcmp
(
text2
,
""
)
==
0
)
{
wrev
->
wow
->
DisplayError
(
"Syntax Error"
,
"Description is missing"
);
return
;
}
wrev
->
set_clock_cursor
();
sts
=
wrev
->
wrevnav
->
rev
->
create
(
1
,
text1
,
text2
);
...
...
@@ -104,7 +114,7 @@ void WRev::activate_store()
// Check if new revision is allowed
sts
=
wrevnav
->
rev
->
create_check
();
if
(
EVEN
(
sts
))
{
wow
->
DisplayError
(
"New Revision Error"
,
"New rev
k
sion can't be created
\n
Current revision is not at end of branch"
);
wow
->
DisplayError
(
"New Revision Error"
,
"New rev
i
sion can't be created
\n
Current revision is not at end of branch"
);
return
;
}
...
...
@@ -277,4 +287,4 @@ WRev::~WRev()
WRev
::
WRev
(
void
*
wa_parent_ctx
,
ldh_tSession
wa_ldhses
)
:
parent_ctx
(
wa_parent_ctx
),
ldhses
(
wa_ldhses
),
close_cb
(
0
),
command_cb
(
0
),
dialog_count
(
0
)
{
}
\ No newline at end of file
}
wb/lib/wb/src/wb_wtt.cpp
View file @
6616c3b0
...
...
@@ -1004,7 +1004,15 @@ void Wtt::activate_revert()
void
Wtt
::
activate_revisions
()
{
wnavnode
->
command
(
(
char
*
)
"open revisions"
);
if
(
!
focused_wnav
)
set_focus_default
();
if
(
!
focused_wnav
->
gbl
.
enable_revisions
)
{
focused_wnav
->
wow
->
DisplayError
(
"Revisions"
,
"Revision is not enabled.
\n
Enable revisions in Tools/Settings."
);
return
;
}
focused_wnav
->
command
(
(
char
*
)
"open revisions"
);
}
void
Wtt
::
activate_syntax
()
...
...
@@ -2012,6 +2020,7 @@ void Wtt::activate_buildnode()
{
pwr_tStatus
sts
;
lfu_t_volumelist
*
vp
,
*
volp
;
int
node_type
;
message
(
' '
,
""
);
...
...
@@ -2052,9 +2061,10 @@ void Wtt::activate_buildnode()
if
(
!
focused_wnav
)
set_focus_default
();
build
->
opt
=
focused_wnav
->
gbl
.
build
;
node_type
=
atoi
(
vp
->
p6
);
set_clock_cursor
();
build
->
node
(
volp
->
p1
,
boot_volumelist
,
boot_volumecount
);
build
->
node
(
volp
->
p1
,
node_type
,
boot_volumelist
,
boot_volumecount
);
reset_cursor
();
if
(
build
->
evenSts
())
{
char
msg
[
80
];
...
...
wb/lib/wb/src/wb_wtt.h
View file @
6616c3b0
...
...
@@ -190,6 +190,7 @@ class Wtt : public WUtility {
int
build_crossref_graph
;
int
build_manual
;
int
build_nocopy
;
int
enable_revisions
;
int
wnav_mapped
;
int
wnavnode_mapped
;
WUted
*
utedctx
;
...
...
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