Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F103074662
DiffusionSymbolQuery.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Thu, Feb 27, 02:08
Size
6 KB
Mime Type
text/x-php
Expires
Sat, Mar 1, 02:08 (2 d)
Engine
blob
Format
Raw Data
Handle
24490424
Attached To
rPH Phabricator
DiffusionSymbolQuery.php
View Options
<?php
/*
* Copyright 2012 Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* Query symbol information (class and function names and location), returning
* a list of matching @{class:PhabricatorRepositorySymbol} objects and possibly
* attached data.
*
* @task config Configuring the Query
* @task exec Executing the Query
* @task internal Internals
*
* @group diffusion
*/
final
class
DiffusionSymbolQuery
extends
PhabricatorOffsetPagedQuery
{
private
$namePrefix
;
private
$name
;
private
$projectIDs
;
private
$language
;
private
$type
;
private
$needPaths
;
private
$needArcanistProject
;
private
$needRepositories
;
/* -( Configuring the Query )---------------------------------------------- */
/**
* @task config
*/
public
function
setName
(
$name
)
{
$this
->
name
=
$name
;
return
$this
;
}
/**
* @task config
*/
public
function
setNamePrefix
(
$name_prefix
)
{
$this
->
namePrefix
=
$name_prefix
;
return
$this
;
}
/**
* @task config
*/
public
function
setProjectIDs
(
array
$project_ids
)
{
$this
->
projectIDs
=
$project_ids
;
return
$this
;
}
/**
* @task config
*/
public
function
setLanguage
(
$language
)
{
$this
->
language
=
$language
;
return
$this
;
}
/**
* @task config
*/
public
function
setType
(
$type
)
{
$this
->
type
=
$type
;
return
$this
;
}
/**
* @task config
*/
public
function
needPaths
(
$need_paths
)
{
$this
->
needPaths
=
$need_paths
;
return
$this
;
}
/**
* @task config
*/
public
function
needArcanistProjects
(
$need_arcanist_projects
)
{
$this
->
needArcanistProjects
=
$need_arcanist_projects
;
return
$this
;
}
/**
* @task config
*/
public
function
needRepositories
(
$need_repositories
)
{
$this
->
needRepositories
=
$need_repositories
;
return
$this
;
}
/* -( Executing the Query )------------------------------------------------ */
/**
* @task exec
*/
public
function
execute
()
{
if
(
$this
->
name
&&
$this
->
namePrefix
)
{
throw
new
Exception
(
"You can not set both a name and a name prefix!"
);
}
else
if
(!
$this
->
name
&&
!
$this
->
namePrefix
)
{
throw
new
Exception
(
"You must set a name or a name prefix!"
);
}
$symbol
=
new
PhabricatorRepositorySymbol
();
$conn_r
=
$symbol
->
establishConnection
(
'r'
);
$data
=
queryfx_all
(
$conn_r
,
'SELECT * FROM %T %Q %Q %Q'
,
$symbol
->
getTableName
(),
$this
->
buildWhereClause
(
$conn_r
),
$this
->
buildOrderClause
(
$conn_r
),
$this
->
buildLimitClause
(
$conn_r
));
$symbols
=
$symbol
->
loadAllFromArray
(
$data
);
if
(
$symbols
)
{
if
(
$this
->
needPaths
)
{
$this
->
loadPaths
(
$symbols
);
}
if
(
$this
->
needArcanistProjects
||
$this
->
needRepositories
)
{
$this
->
loadArcanistProjects
(
$symbols
);
}
if
(
$this
->
needRepositories
)
{
$this
->
loadRepositories
(
$symbols
);
}
}
return
$symbols
;
}
/* -( Internals )---------------------------------------------------------- */
/**
* @task internal
*/
private
function
buildOrderClause
(
$conn_r
)
{
return
qsprintf
(
$conn_r
,
'ORDER BY symbolName ASC'
);
}
/**
* @task internal
*/
private
function
buildWhereClause
(
$conn_r
)
{
$where
=
array
();
if
(
$this
->
name
)
{
$where
[]
=
qsprintf
(
$conn_r
,
'symbolName = %s'
,
$this
->
name
);
}
if
(
$this
->
namePrefix
)
{
$where
[]
=
qsprintf
(
$conn_r
,
'symbolName LIKE %>'
,
$this
->
namePrefix
);
}
if
(
$this
->
projectIDs
)
{
$where
[]
=
qsprintf
(
$conn_r
,
'arcanistProjectID IN (%Ld)'
,
$this
->
projectIDs
);
}
if
(
$this
->
language
)
{
$where
[]
=
qsprintf
(
$conn_r
,
'symbolLanguage = %s'
,
$this
->
language
);
}
return
$this
->
formatWhereClause
(
$where
);
}
/**
* @task internal
*/
private
function
loadPaths
(
array
$symbols
)
{
assert_instances_of
(
$symbols
,
'PhabricatorRepositorySymbol'
);
$path_map
=
queryfx_all
(
id
(
new
PhabricatorRepository
())->
establishConnection
(
'r'
),
'SELECT * FROM %T WHERE id IN (%Ld)'
,
PhabricatorRepository
::
TABLE_PATH
,
mpull
(
$symbols
,
'getPathID'
));
$path_map
=
ipull
(
$path_map
,
'path'
,
'id'
);
foreach
(
$symbols
as
$symbol
)
{
$symbol
->
attachPath
(
idx
(
$path_map
,
$symbol
->
getPathID
()));
}
}
/**
* @task internal
*/
private
function
loadArcanistProjects
(
array
$symbols
)
{
assert_instances_of
(
$symbols
,
'PhabricatorRepositorySymbol'
);
$projects
=
id
(
new
PhabricatorRepositoryArcanistProject
())->
loadAllWhere
(
'id IN (%Ld)'
,
mpull
(
$symbols
,
'getArcanistProjectID'
));
foreach
(
$symbols
as
$symbol
)
{
$project
=
idx
(
$projects
,
$symbol
->
getArcanistProjectID
());
$symbol
->
attachArcanistProject
(
$project
);
}
}
/**
* @task internal
*/
private
function
loadRepositories
(
array
$symbols
)
{
assert_instances_of
(
$symbols
,
'PhabricatorRepositorySymbol'
);
$projects
=
mpull
(
$symbols
,
'getArcanistProject'
);
$projects
=
array_filter
(
$projects
);
$repo_ids
=
mpull
(
$projects
,
'getRepositoryID'
);
$repo_ids
=
array_filter
(
$repo_ids
);
if
(
$repo_ids
)
{
$repos
=
id
(
new
PhabricatorRepository
())->
loadAllWhere
(
'id IN (%Ld)'
,
$repo_ids
);
}
else
{
$repos
=
array
();
}
foreach
(
$symbols
as
$symbol
)
{
$proj
=
$symbol
->
getArcanistProject
();
if
(
$proj
)
{
$symbol
->
attachRepository
(
idx
(
$repos
,
$proj
->
getRepositoryID
()));
}
else
{
$symbol
->
attachRepository
(
null
);
}
}
}
}
Event Timeline
Log In to Comment