1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 15:21:03 +01:00

Fix some straggling qsprintf() warnings in repository import

Summary:
Ref T13217. See <https://discourse.phabricator-community.org/t/unsafe-raw-string-warnings-while-importing-git-commits/2191>.

Hunt down and fix two more `qsprintf()` things.

I just converted the "performance optimization" into a normal, safe call since we're dealing with far less SVN stuff nowadays and the actual issue has been lost in the mists of time. If it resurfaces, we can take another look.

Test Plan: Imported some commits, no longer saw these warnings in the daemon logs.

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T13217

Differential Revision: https://secure.phabricator.com/D19869
This commit is contained in:
epriestley 2018-12-12 05:20:36 -08:00
parent 0e067213fb
commit d8e2bb9f0f
2 changed files with 12 additions and 15 deletions

View file

@ -43,12 +43,13 @@ final class DiffusionPathChangeQuery extends Phobject {
$conn_r = $repository->establishConnection('r'); $conn_r = $repository->establishConnection('r');
$limit = '';
if ($this->limit) { if ($this->limit) {
$limit = qsprintf( $limit = qsprintf(
$conn_r, $conn_r,
'LIMIT %d', 'LIMIT %d',
$this->limit + 1); $this->limit + 1);
} else {
$limit = qsprintf($conn_r, '');
} }
$raw_changes = queryfx_all( $raw_changes = queryfx_all(

View file

@ -114,40 +114,36 @@ abstract class PhabricatorRepositoryCommitChangeParserWorker
PhabricatorRepositoryCommit $commit, PhabricatorRepositoryCommit $commit,
array $changes) { array $changes) {
$conn = $repository->establishConnection('w');
$repository_id = (int)$repository->getID(); $repository_id = (int)$repository->getID();
$commit_id = (int)$commit->getID(); $commit_id = (int)$commit->getID();
// NOTE: This SQL is being built manually instead of with qsprintf()
// because some SVN changes affect an enormous number of paths (millions)
// and this showed up as significantly slow on a profile at some point.
$changes_sql = array(); $changes_sql = array();
foreach ($changes as $change) { foreach ($changes as $change) {
$values = array( $changes_sql[] = qsprintf(
$conn,
'(%d, %d, %d, %nd, %nd, %d, %d, %d, %d)',
$repository_id, $repository_id,
(int)$change->getPathID(), (int)$change->getPathID(),
$commit_id, $commit_id,
nonempty((int)$change->getTargetPathID(), 'null'), nonempty((int)$change->getTargetPathID(), null),
nonempty((int)$change->getTargetCommitID(), 'null'), nonempty((int)$change->getTargetCommitID(), null),
(int)$change->getChangeType(), (int)$change->getChangeType(),
(int)$change->getFileType(), (int)$change->getFileType(),
(int)$change->getIsDirect(), (int)$change->getIsDirect(),
(int)$change->getCommitSequence(), (int)$change->getCommitSequence());
);
$changes_sql[] = '('.implode(', ', $values).')';
} }
$conn_w = $repository->establishConnection('w');
queryfx( queryfx(
$conn_w, $conn,
'DELETE FROM %T WHERE commitID = %d', 'DELETE FROM %T WHERE commitID = %d',
PhabricatorRepository::TABLE_PATHCHANGE, PhabricatorRepository::TABLE_PATHCHANGE,
$commit_id); $commit_id);
foreach (PhabricatorLiskDAO::chunkSQL($changes_sql) as $chunk) { foreach (PhabricatorLiskDAO::chunkSQL($changes_sql) as $chunk) {
queryfx( queryfx(
$conn_w, $conn,
'INSERT INTO %T 'INSERT INTO %T
(repositoryID, pathID, commitID, targetPathID, targetCommitID, (repositoryID, pathID, commitID, targetPathID, targetCommitID,
changeType, fileType, isDirect, commitSequence) changeType, fileType, isDirect, commitSequence)