Files
gtav-src/tools_ng/lib/util/perforce/p4_splitverify.py
T
2025-09-29 00:52:08 +02:00

97 lines
3.2 KiB
Python
Executable File

#!/usr/bin/python
#
#
"""A P4Python script that splits the verify process over the root directories of each depot
$Id$
#*******************************************************************************
# Copyright (c) 2009, Perforce Software, Inc. All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL PERFORCE SOFTWARE, INC. BE LIABLE FOR ANY
# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#*******************************************************************************
"""
from __future__ import with_statement
import P4
import sys
import datetime
import time
p4 = P4.P4()
# assumes that the P4 enviroment is set correctly via environment variables or P4CONFIG
# otherwise, set the P4 environment here
p4.port = "rsgedip4d1:1666"
p4.user = "svcrsgediperforce"
def formatTD(td):
days = td.seconds // (60*60*24)
hours = td.seconds // 3600
minutes = (td.seconds % 3600) // 60
seconds = td.seconds % 60
return '%s days, %sh %sm %ss' % (days, hours, minutes, seconds)
def main( file ):
try:
p4.connect()
time_start = datetime.datetime.now()
print >> file, time_start.strftime( "[%H:%M:%S - %d/%m/%Y]" ) + ": P4 Verify Start"
dirs = p4.run_dirs("//*/*")
result = []
for d in dirs:
pattern = d['dir'] + "/..."
if ( 0 != cmp( pattern, "//depot/audio/..." ) ):
print >> file, datetime.datetime.now().strftime( "[%H:%M:%S - %d/%m/%Y]" ) + ": Verifying %s" % pattern
result += ( p4.run_verify("-q", pattern))
if len(result) > 0:
print >> file, "Verify reported errors:"
for r in result:
print >> file, r
time_end = datetime.datetime.now()
print >> file, time_end.strftime( "[%H:%M:%S - %d/%m/%Y]" ) + ": P4 Verify End"
delta = (time_end-time_start)
print >> file, "Verify took: " + formatTD(delta)
p4.disconnect()
except P4.P4Exception, err:
print >> file, err
if __name__ == "__main__":
if len( sys.argv ) > 1:
filename = sys.argv[1]
with open( filename, "w" ) as hFile:
main(hFile)
else:
main(sys.stdout)
print "verify complete"