當前位置: 首頁>>代碼示例>>Python>>正文


Python Params._askFor方法代碼示例

本文整理匯總了Python中params.Params._askFor方法的典型用法代碼示例。如果您正苦於以下問題:Python Params._askFor方法的具體用法?Python Params._askFor怎麽用?Python Params._askFor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在params.Params的用法示例。


在下文中一共展示了Params._askFor方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Run

# 需要導入模塊: from params import Params [as 別名]
# 或者: from params.Params import _askFor [as 別名]
class Run():
    debug = False
    dryrun = False
    params = None
    answers_data = {GLOBAL_CONF: {}}
    tmpdir = None
    answers_file = None
    provider = DEFAULT_PROVIDER
    installed = False
    plugins = []
    update = False
    app_path = None
    target_path = None
    app_id = None
    app = None
    answers_output = None
    kwargs = None

    def __init__(self, answers, APP, dryrun = False, debug = False, **kwargs):

        self.debug = debug
        self.dryrun = dryrun
        self.kwargs = kwargs
        if "answers_output" in kwargs:
            self.answers_output = kwargs["answers_output"]

        if APP and os.path.exists(APP):
            self.app_path = APP
        else:
            raise Exception("App path %s does not exist." % APP)

        self.params = Params(target_path=self.app_path)
        if "ask" in kwargs:
            self.params.ask = kwargs["ask"]

        self.utils = Utils(self.params)

        self.answers_file = answers
        self.plugin = Plugin()
        self.plugin.load_plugins()

    def _dispatchGraph(self):
        if not "graph" in self.params.mainfile_data:
            raise Exception("Graph not specified in %s" % MAIN_FILE)

        for component, graph_item in self.params.mainfile_data["graph"].iteritems():
            if self.utils.isExternal(graph_item):
                component_run = Run(self.answers_file, self.utils.getExternalAppDir(component), self.dryrun, self.debug, **self.kwargs)
                ret = component_run.run()
                if self.answers_output:
                    self.params.loadAnswers(ret)
            else:
                self._processComponent(component, graph_item)

    def _applyTemplate(self, data, component):
        template = Template(data)
        config = self.params.getValues(component)
        logger.debug("Config: %s " % config)

        output = None
        while not output:
            try:
                logger.debug(config)
                output = template.substitute(config)
            except KeyError as ex:
                name = ex.args[0]
                logger.debug("Artifact contains unknown parameter %s, asking for it" % name)
                config[name] = self.params._askFor(name, {"description": "Missing parameter '%s', provide the value or fix your %s" % (name, MAIN_FILE)})
                if not len(config[name]):
                    raise Exception("Artifact contains unknown parameter %s" % name)
                self.params.loadAnswers({component: {name: config[name]}})

        return output

    def _processComponent(self, component, graph_item):
        logger.debug("Processing component %s" % component)
        
        data = None
        artifacts = self.utils.getArtifacts(component)
        artifact_provider_list = []
        if not self.params.provider in artifacts:
            raise Exception("Data for provider \"%s\" are not part of this app" % self.params.provider)
        
        dst_dir = os.path.join(self.utils.tmpdir, component)
        for artifact in artifacts[self.params.provider]:
            artifact_path = self.utils.sanitizePath(artifact)
            with open(os.path.join(self.app_path, artifact_path), "r") as fp:
                data = fp.read()

            logger.debug("Templating artifact %s/%s" % (self.app_path, artifact_path))
            data = self._applyTemplate(data, component)
        
            artifact_dst = os.path.join(dst_dir, artifact_path)
            
            if not os.path.isdir(os.path.dirname(artifact_dst)):
                os.makedirs(os.path.dirname(artifact_dst))
            with open(artifact_dst, "w") as fp:
                logger.debug("Writing artifact to %s" % artifact_dst)
                fp.write(data)

#.........這裏部分代碼省略.........
開發者ID:whitel,項目名稱:atomic-app-with-runner,代碼行數:103,代碼來源:run.py

示例2: Create

# 需要導入模塊: from params import Params [as 別名]
# 或者: from params.Params import _askFor [as 別名]

#.........這裏部分代碼省略.........
                        elif isinstance(element["contents"], collections.Mapping):
                            fp.write(anymarkup.serialize(self._generateContents(element["contents"]), format='yaml'))
#                        elif element["contentType"] == "application/json":
#                            if element["name"] == "Atomicfile":
#                                element["contents"] = self._updateAtomicfile(element["contents"])

#                            fp.write(json.dumps(element["contents"]))

    def _pickOne(self, what, info, options):
        options_text = ""
        for i, option in enumerate(options):
            options_text += "%s. %s\n" % (i+1, option)

        required = False

        if "required" in info:
            required = info["required"]

        value = raw_input("%s (%s)\n Options:\n%s\nYour choice (default: 1): " % (what, info["description"], options_text))
        if len(value) == 0:
            value = 1
        elif int(value) == 0 and not required:
            return None

        return options[int(value)-1]

    def _getName(self, element, content, path = None):
        name = None
        if not "name" in content:
            name = element
        elif not content["name"]:
            name = self._generateValue(path)
            if not name:
                name = self.params._askFor(element, content)
        elif type(content["name"]) is list:
            name = self._pickOne(element, content, content["name"])
        else:
            name = content["name"]

        logger.debug(name)

        return name

    def _generateContents(self, contents, path="root"):
        result = {}
        for element, content in contents.iteritems():

            local_path = "%s.%s" % (path, element)
            name = self._getName(element, content, local_path)

            print("Filling %s" % name)
            if not content["required"]:
                skip = self.params._askFor("Element %s not required, do you want to skip it?" % name, {"description": "Type y or n", "default": "Y"})
                if isTrue(skip):
                    continue
            #logger.debug("Key: %s, value %s" % (element, content["value"]))

            if content["type"] == "object":
                result[name] = self._generateContents(content["value"], local_path)
            elif content["type"] == "list":

                tmp_results = []
                while True:
                    value = self.params._askFor(content["value"].keys()[0], content["value"][content["value"].keys()[0]])
                    if len(value) == 0:
                        break
開發者ID:tlitovsk,項目名稱:atomicapp,代碼行數:70,代碼來源:create.py


注:本文中的params.Params._askFor方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。