##// END OF EJS Templates
fix: do not render email if we arent sending email with notification
fix: do not render email if we arent sending email with notification

File last commit:

r5091:9ce86a18 default
r5542:d9b3c623 default
Show More
inmemory.py
77 lines | 2.7 KiB | text/x-python | PythonLexer
copyrights: updated for 2023
r5088 # Copyright (C) 2014-2023 RhodeCode GmbH
project: added all source files and assets
r1 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
"""
SVN inmemory module
"""
from rhodecode.lib.datelib import date_astimestamp
vcs-lib: bulk of changes for python3 support
r5074 from rhodecode.lib.str_utils import safe_str, safe_bytes
project: added all source files and assets
r1 from rhodecode.lib.vcs.backends import base
class SubversionInMemoryCommit(base.BaseInMemoryCommit):
commits: updated logic of in-memory-commits, fixed tests and re-architectured a bit how commit_ids are calculated and updated....
r3743 def commit(self, message, author, parents=None, branch=None, date=None, **kwargs):
project: added all source files and assets
r1 if branch not in (None, self.repository.DEFAULT_BRANCH_NAME):
raise NotImplementedError("Branches are not yet supported")
self.check_integrity(parents)
message = safe_str(message)
author = safe_str(author)
updated = []
for node in self.added:
node_data = {
vcs-lib: bulk of changes for python3 support
r5074 'path': safe_bytes(node.path),
'content': node.content,
project: added all source files and assets
r1 'mode': node.mode,
}
if node.is_binary:
node_data['properties'] = {
'svn:mime-type': 'application/octet-stream'
}
updated.append(node_data)
for node in self.changed:
updated.append({
vcs-lib: bulk of changes for python3 support
r5074 'path': safe_bytes(node.path),
'content': node.content,
project: added all source files and assets
r1 'mode': node.mode,
})
removed = []
for node in self.removed:
removed.append({
vcs-lib: bulk of changes for python3 support
r5074 'path': safe_bytes(node.path),
project: added all source files and assets
r1 })
timestamp = date_astimestamp(date) if date else None
svn_rev = self.repository._remote.commit(
message=message, author=author, timestamp=timestamp,
updated=updated, removed=removed)
# TODO: Find a nicer way. If commit_ids is not yet evaluated, then
# we should not add the commit_id, if it is already evaluated, it
# will not be evaluated again.
commit_id = str(svn_rev)
commits: updated logic of in-memory-commits, fixed tests and re-architectured a bit how commit_ids are calculated and updated....
r3743 self.repository.append_commit_id(commit_id)
project: added all source files and assets
r1 tip = self.repository.get_commit()
self.reset()
return tip