开源 企业版 高校版 私有云 模力方舟 AI 队友
代码拉取完成,页面将自动刷新
捐赠
捐赠前请先登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
1 Star 0 Fork 0

tqyin/cloudstack

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
已有帐号? 立即登录
文件
master
分支 (258)
标签 (146)
master
4.11
4.11.0.0-RC20180115T1603
4.10
4.9
add_XS_71_72
CLOUDSTACK-10012
GA-4.9.3.0
new-location
cloudearlyinit
4.10.0.0-RC20170703T1006
GA-4.10.0.0
4.10.0.0-RC20170626T1011
4.10.0.0-RC20170620T1023
4.10.0.0-RC20170609T1354
4.10.0.0-RC20170607T1407
4.10.0.0-RC20170509T1030
4.10.0.0-RC20170301T0634
4.8
GA-4.9.2.0
4.9.3.0
4.10.0.0
4.9.2.0
4.9.1.0
4.5.2.2
4.9.0.1
4.8.1.1
4.8.1
4.9.0
4.8.0.1
4.7.1.1
4.6.2.1
4.5.2.1
4.8.0
4.7.1
4.7.0
4.6.2
4.6.1
4.6.0
4.5.2
master
分支 (258)
标签 (146)
master
4.11
4.11.0.0-RC20180115T1603
4.10
4.9
add_XS_71_72
CLOUDSTACK-10012
GA-4.9.3.0
new-location
cloudearlyinit
4.10.0.0-RC20170703T1006
GA-4.10.0.0
4.10.0.0-RC20170626T1011
4.10.0.0-RC20170620T1023
4.10.0.0-RC20170609T1354
4.10.0.0-RC20170607T1407
4.10.0.0-RC20170509T1030
4.10.0.0-RC20170301T0634
4.8
GA-4.9.2.0
4.9.3.0
4.10.0.0
4.9.2.0
4.9.1.0
4.5.2.2
4.9.0.1
4.8.1.1
4.8.1
4.9.0
4.8.0.1
4.7.1.1
4.6.2.1
4.5.2.1
4.8.0
4.7.1
4.7.0
4.6.2
4.6.1
4.6.0
4.5.2
克隆/下载
克隆/下载
提示
下载代码请复制以下命令到终端执行
为确保你提交的代码身份被 Gitee 正确识别,请执行以下命令完成配置
初次使用 SSH 协议进行代码克隆、推送等操作时,需按下述提示完成 SSH 配置
1 生成 RSA 密钥
2 获取 RSA 公钥内容,并配置到 SSH公钥
在 Gitee 上使用 SVN,请访问 使用指南
使用 HTTPS 协议时,命令行会出现如下账号密码验证步骤。基于安全考虑,Gitee 建议 配置并使用私人令牌 替代登录密码进行克隆、推送等操作
Username for 'https://gitee.com': userName
Password for 'https://userName@gitee.com': # 私人令牌
master
分支 (258)
标签 (146)
master
4.11
4.11.0.0-RC20180115T1603
4.10
4.9
add_XS_71_72
CLOUDSTACK-10012
GA-4.9.3.0
new-location
cloudearlyinit
4.10.0.0-RC20170703T1006
GA-4.10.0.0
4.10.0.0-RC20170626T1011
4.10.0.0-RC20170620T1023
4.10.0.0-RC20170609T1354
4.10.0.0-RC20170607T1407
4.10.0.0-RC20170509T1030
4.10.0.0-RC20170301T0634
4.8
GA-4.9.2.0
4.9.3.0
4.10.0.0
4.9.2.0
4.9.1.0
4.5.2.2
4.9.0.1
4.8.1.1
4.8.1
4.9.0
4.8.0.1
4.7.1.1
4.6.2.1
4.5.2.1
4.8.0
4.7.1
4.7.0
4.6.2
4.6.1
4.6.0
4.5.2
cloudstack
/
python
/
lib
/
cloudutils
/
configFileOps.py
cloudstack
/
python
/
lib
/
cloudutils
/
configFileOps.py
configFileOps.py 6.32 KB
一键复制 编辑 原始数据 按行查看 历史
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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.
import re
import tempfile
import shutil
from utilities import bash
class configFileOps:
class entry:
def __init__(self, name, value, op, separator):
self.name = name
self.value = value
self.state = "new"
self.op = op
self.separator = separator
def setState(self, state):
self.state = state
def getState(self):
return self.state
def __init__(self, fileName, cfg=None):
self.fileName = fileName
self.entries = []
self.backups = []
if cfg is not None:
cfg.cfoHandlers.append(self)
def addEntry(self, name, value, separator="="):
e = self.entry(name, value, "add", separator)
self.entries.append(e)
def rmEntry(self, name, value, separator="="):
entry = self.entry(name, value, "rm", separator)
self.entries.append(entry)
def getEntry(self, name, separator="="):
try:
ctx = file(self.fileName).read(-1)
match = re.search("^" + name + ".*", ctx, re.MULTILINE)
if match is None:
return ""
line = match.group(0).split(separator, 1)
return line[1]
except:
return ""
def save(self):
fp = open(self.fileName, "r")
newLines = []
for line in fp.readlines():
matched = False
for entry in self.entries:
if entry.op == "add":
if entry.separator == "=":
matchString = "^\ *" + entry.name + ".*"
elif entry.separator == " ":
matchString = "^\ *" + entry.name + "\ *" + entry.value
else:
if entry.separator == "=":
matchString = "^\ *" + entry.name + "\ *=\ *" + entry.value
else:
matchString = "^\ *" + entry.name + "\ *" + entry.value
match = re.match(matchString, line)
if match is not None:
if entry.op == "add" and entry.separator == "=":
newline = "\n" + entry.name + "=" + entry.value + "\n"
entry.setState("set")
newLines.append(newline)
self.backups.append([line, newline])
matched = True
break
elif entry.op == "rm":
entry.setState("set")
self.backups.append([line, None])
matched = True
break
if not matched:
newLines.append(line)
for entry in self.entries:
if entry.getState() != "set":
if entry.op == "add":
newline = entry.name + entry.separator + entry.value + "\n"
newLines.append(newline)
self.backups.append([None, newline])
entry.setState("set")
fp.close()
file(self.fileName, "w").writelines(newLines)
def replace_line(self, startswith,stanza,always_add=False):
lines = [ s.strip() for s in file(self.fileName).readlines() ]
newlines = []
replaced = False
for line in lines:
if re.search(startswith, line):
if stanza is not None:
newlines.append(stanza)
self.backups.append([line, stanza])
replaced = True
else: newlines.append(line)
if not replaced and always_add:
newlines.append(stanza)
self.backups.append([None, stanza])
newlines = [ s + '\n' for s in newlines ]
file(self.fileName,"w").writelines(newlines)
def replace_or_add_line(self, startswith,stanza):
return self.replace_line(startswith,stanza,always_add=True)
def add_lines(self, lines, addToBackup=True):
fp = file(self.fileName).read(-1)
sh = re.escape(lines)
match = re.search(sh, fp, re.MULTILINE)
if match is not None:
return
fp += lines
file(self.fileName, "w").write(fp)
self.backups.append([None, lines])
def replace_lines(self, src, dst, addToBackup=True):
fp = file(self.fileName).read(-1)
sh = re.escape(src)
if dst is None:
dst = ""
repl,nums = re.subn(sh, dst, fp)
if nums <=0:
return
file(self.fileName, "w").write(repl)
if addToBackup:
self.backups.append([src, dst])
def append_lines(self, match_lines, append_lines):
fp = file(self.fileName).read(-1)
sh = re.escape(match_lines)
match = re.search(sh, fp, re.MULTILINE)
if match is None:
return
sh = re.escape(append_lines)
if re.search(sh, fp, re.MULTILINE) is not None:
return
newlines = []
for line in file(self.fileName).readlines():
if re.search(match_lines, line) is not None:
newlines.append(line + append_lines)
self.backups.append([line, line + append_lines])
else:
newlines.append(line)
file(self.fileName, "w").writelines(newlines)
def backup(self):
for oldLine, newLine in self.backups:
if newLine is None:
self.add_lines(oldLine, False)
else:
self.replace_lines(newLine, oldLine, False)
Loading...
举报
举报成功
我们将于2个工作日内通过站内信反馈结果给你!
请认真填写举报原因,尽可能描述详细。
请选择举报类型
取消
发送
误判申诉

此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。

如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。

取消
提交

简介

Mirror of Apache Cloudstack
暂无标签
Apache-2.0
使用 Apache-2.0 开源许可协议
, Apache-2.0
使用 Apache-2.0 开源许可协议
取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
编辑仓库简介
简介内容
主页
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/zedhs/cloudstack.git
git@gitee.com:zedhs/cloudstack.git
zedhs
cloudstack
cloudstack
master
点此查找更多帮助

搜索帮助

评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册

AltStyle によって変換されたページ (->オリジナル) /