Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
S
StarUML Evológica Plugin
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
3
Merge Requests
3
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
evologica
StarUML Evológica Plugin
Commits
450b8c5e
Commit
450b8c5e
authored
Sep 23, 2020
by
Jucelino Fonseca
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Ajustes
parent
b74604ab
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
117 additions
and
68 deletions
+117
-68
ituExplorerV2.dfm
EvoUMLPlugin/src/ituExplorerV2.dfm
+17
-5
ituExplorerV2.pas
EvoUMLPlugin/src/ituExplorerV2.pas
+100
-63
No files found.
EvoUMLPlugin/src/ituExplorerV2.dfm
View file @
450b8c5e
...
...
@@ -11754,7 +11754,7 @@ object ExplorerV2: TExplorerV2
OnDragDrop = memOQLQuery2DragDrop
OnDragOver = memOQLQuery2DragOver
BorderStyle = bsNone
Gutter.Width =
42
Gutter.Width =
29
Gutter.MouseActions = <>
RightGutter.Width = 0
RightGutter.MouseActions = <>
...
...
@@ -12210,6 +12210,7 @@ object ExplorerV2: TExplorerV2
MouseLinkColor.Foreground = clBlue
LineHighlightColor.Background = clNone
LineHighlightColor.Foreground = clNone
OnChange = SynEditOQLChange
inline SynLeftGutterPartList1: TSynGutterPartList
object SynGutterMarks1: TSynGutterMarks
Width = 30
...
...
@@ -12252,15 +12253,15 @@ object ExplorerV2: TExplorerV2
end
object tsSQL: TTabSheet
Caption = 'SQL Translation'
ClientHeight = 51
1
ClientWidth =
620
ClientHeight = 51
2
ClientWidth =
467
Font.Color = clWindowText
ParentFont = False
inline SynEditSQL: TSynEdit
Left = 0
Height = 51
1
Height = 51
2
Top = 0
Width =
620
Width =
467
Align = alClient
Font.Height = -16
Font.Name = 'Courier New'
...
...
@@ -14276,4 +14277,15 @@ object ExplorerV2: TExplorerV2
0000000000000000000000000000
}
end
object SynAutoComplete1: TSynAutoComplete
AutoCompleteList.Strings = (
'Teste'
)
EndOfTokenChr = '()[].'
ShortCut = 8224
ExecCommandID = ecSynAutoCompletionExecute
Editor = SynEditOQL
Left = 574
Top = 379
end
end
EvoUMLPlugin/src/ituExplorerV2.pas
View file @
450b8c5e
...
...
@@ -41,6 +41,7 @@ type
sbStatusBar
:
TStatusBar
;
spResultXML
:
TSplitter
;
spResultObject
:
TSplitter
;
SynAutoComplete1
:
TSynAutoComplete
;
SynCompletion1
:
TSynCompletion
;
SynEditOQL
:
TSynEdit
;
SynEditSQL
:
TSynEdit
;
...
...
@@ -86,6 +87,7 @@ type
procedure
FormShow
(
Sender
:
TObject
);
procedure
actResultsPanelExecute
(
Sender
:
TObject
);
procedure
rbSequencialClick
(
Sender
:
TObject
);
procedure
SynEditOQLChange
(
Sender
:
TObject
);
procedure
tvModelExplorerGetSelectedIndex
(
Sender
:
TObject
;
Node
:
TTreeNode
);
procedure
tvModelExplorerItemExpanding
(
Sender
:
TObject
;
Node
:
TTreeNode
;
var
AllowExpansion
:
Boolean
);
procedure
XMLQueryExecute
(
Sender
:
TObject
);
...
...
@@ -119,7 +121,8 @@ type
function
GetNumeroDeStringOID
(
piString
:
string
)
:
string
;
procedure
CopiaTextoObjeto
(
piObjeto
:
TTreeNode
);
function
BuscaParcialClasse
(
piCLasse
:
string
;
piFiltrar
:
boolean
):
boolean
;
function
BuscarParcialNodeClasse
(
piClassTicket
:
acClassTicket
;
piFiltrar
:
boolean
):
boolean
;
function
BuscarParcialChildClass
(
piClassTicket
:
acClassTicket
;
piFiltrar
:
boolean
):
boolean
;
function
FindParcialNodeClass
(
piClassTicketPai
:
acClassTicket
;
piFiltrar
:
boolean
):
acClassTicket
;
protected
procedure
CreateParams
(
var
Params
:
TCreateParams
);
override
;
function
Connect
:
acPersistenceSession
;
...
...
@@ -425,6 +428,11 @@ begin
end
;
procedure
TExplorerV2
.
SynEditOQLChange
(
Sender
:
TObject
);
begin
end
;
procedure
TExplorerV2
.
tvModelExplorerGetSelectedIndex
(
Sender
:
TObject
;
Node
:
TTreeNode
);
...
...
@@ -538,12 +546,14 @@ begin
end
;
function
TExplorerV2
.
BuscarParcial
NodeClasse
(
piClassTicket
:
acClassTicket
;
function
TExplorerV2
.
BuscarParcial
ChildClass
(
piClassTicket
:
acClassTicket
;
piFiltrar
:
boolean
):
boolean
;
var
lEnumeratorChild
:
acEnumerator
;
lClassTicketChild
:
acClassTicket
;
begin
result
:=
false
;
result
:=
BuscaParcialClasse
(
piClassTicket
.
PersistentObjectClassName
,
piFiltrar
);
if
not
result
then
begin
lEnumeratorChild
:=
piClassTicket
.
DirectDescendants
.
GetEnumerator
;
try
while
not
lEnumeratorChild
.
EOL
do
...
...
@@ -554,7 +564,7 @@ begin
result
:=
true
;
break
;
end
else
if
BuscarParcialNodeClasse
(
lClassTicketChild
,
piFiltrar
)
then
else
if
BuscarParcialChildClass
(
lClassTicketChild
,
piFiltrar
)
then
begin
result
:=
true
;
break
;
...
...
@@ -565,6 +575,45 @@ begin
finally
lEnumeratorChild
.
Free
;
end
;
end
;
end
;
function
TExplorerV2
.
FindParcialNodeClass
(
piClassTicketPai
:
acClassTicket
;
piFiltrar
:
boolean
):
acClassTicket
;
var
lEnumeratorChild
:
acEnumerator
;
lClassTicketChild
:
acClassTicket
;
begin
result
:=
nil
;
if
BuscaParcialClasse
(
piClassTicketPai
.
PersistentObjectClassName
,
piFiltrar
)
then
begin
result
:=
piClassTicketPai
;
end
else
begin
lEnumeratorChild
:=
piClassTicketPai
.
DirectDescendants
.
GetEnumerator
;
try
while
not
lEnumeratorChild
.
EOL
do
begin
lClassTicketChild
:=
acClassTicket
(
lEnumeratorChild
.
Current
);
if
BuscaParcialClasse
(
lClassTicketChild
.
PersistentObjectClassName
,
piFiltrar
)
then
begin
result
:=
lClassTicketChild
;
end
else
begin
result
:=
FindParcialNodeClass
(
lClassTicketChild
,
piFiltrar
);
end
;
if
Assigned
(
result
)
then
begin
break
;
end
;
lEnumeratorChild
.
MoveNext
;
end
;
finally
lEnumeratorChild
.
Free
;
end
;
end
;
end
;
...
...
@@ -743,39 +792,20 @@ begin
lFiltroIgualFilho
:=
false
;
if
not
Assigned
(
lClassTicket
.
ParentClassTicket
)
then
begin
if
BuscaParcialClasse
(
lClassTicket
.
PersistentObjectClassName
,
lFiltro
)
then
begin
lAchei
:=
true
;
end
else
if
lClassTicket
.
HasDescendants
then
lClassTicketChild
:=
FindParcialNodeClass
(
lClassTicket
,
lFiltro
);
if
Assigned
(
lClassTicketChild
)
then
begin
if
BuscarParcialNodeClasse
(
lClassTicket
,
lFiltro
)
then
if
lClassTicket
<>
lClassTicketChild
then
begin
if
not
Assigned
(
Node
.
Owner
.
FindNodeWithData
(
lClassTicket
))
then
begin
lAchei
:=
true
;
lFiltroIgualFilho
:=
true
;
end
;
end
;
{lEnumeratorChild := lClassTicket.DirectDescendants.GetEnumerator;
try
while not lEnumeratorChild.EOL do
begin
lClassTicketChild := acClassTicket(lEnumeratorChild.Current);
if BuscaParcialClasse(lClassTicketChild.PersistentObjectClassName,lFiltro) then
begin
if not Assigned(Node.Owner.FindNodeWithData(lClassTicket)) then
end
else
begin
lAchei
:=
true
;
lFiltroIgualFilho := true;
end;
end;
lEnumeratorChild.MoveNext;
end;
finally
lEnumeratorChild.Free;
end; }
end
;
end
;
if
lAchei
then
begin
...
...
@@ -787,6 +817,8 @@ begin
targetNode
.
Expanded
:=
true
;
end
;
end
;
end
;
end
;
lEnumerator
.
MoveNext
;
end
;
finally
...
...
@@ -865,8 +897,6 @@ begin
if
lClassTicket
.
HasDescendants
then
begin
//Carrega os filhos
lEnumerator
:=
lClassTicket
.
DirectDescendants
.
GetEnumerator
;
try
if
Assigned
(
lClassTicket
.
PatriarcClassTicket
)
then
begin
lFiltroIgualPai
:=
BuscaParcialClasse
(
lClassTicket
.
PatriarcClassTicket
.
PersistentObjectClassName
,
lFiltro
);
...
...
@@ -875,16 +905,23 @@ begin
begin
lFiltroIgualPai
:=
BuscaParcialClasse
(
lClassTicket
.
PersistentObjectClassName
,
lFiltro
);
end
;
lEnumerator
:=
lClassTicket
.
DirectDescendants
.
GetEnumerator
;
try
while
not
lEnumerator
.
EOL
do
begin
lClassTicketChild
:=
acClassTicket
(
lEnumerator
.
Current
);
lFiltroIgualFilho
:=
Busca
ParcialClasse
(
lClassTicketChild
.
PersistentObjectClassName
,
lFiltro
);
lFiltroIgualFilho
:=
Busca
rParcialChildClass
(
lClassTicketChild
,
lFiltro
);
lbIncluir
:=
lFiltroIgualPai
or
lFiltroIgualFilho
;
if
lbIncluir
then
begin
targetNode
:=
Node
.
Owner
.
AddChildObject
(
Node
,
lClassTicketChild
.
PersistentObjectClassName
,
lClassTicketChild
);
targetNode
.
ImageIndex
:=
6
;
targetNode
.
HasChildren
:=
True
;
if
lFiltroIgualFilho
then
begin
targetNode
.
Expanded
:=
true
;
end
;
end
;
lEnumerator
.
MoveNext
;
end
;
...
...
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