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


Python porcelain.add方法代碼示例

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


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

示例1: add_model

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def add_model(self, model_type: str, model_uuid: str, meta: dict,
                  template_model: Template, update_default: bool=False):
        """Add a new model to the registry. Call `upload()` to update the remote side."""
        if update_default or model_type not in self.meta:
            self.meta[model_type] = meta["default"]
        model_meta = meta["model"]
        self.models.setdefault(model_type, {})[model_uuid] = model_meta
        model_directory = os.path.join(self.cached_repo, model_type)
        os.makedirs(model_directory, exist_ok=True)
        model = os.path.join(model_directory, model_uuid + ".md")
        if os.path.exists(model):
            os.remove(model)
        links = {}
        for m_type, items in self.models.items():
            for uuid in items:
                if uuid in model_meta["dependencies"]:
                    links[uuid] = os.path.join("/", m_type, "%s.md" % uuid)
        with open(model, "w") as fout:
            fout.write(template_model.render(model_type=model_type, model_uuid=model_uuid,
                                             meta=model_meta, links=links, spdx=LICENSES))
        git.add(self.cached_repo, [model])
        self._log.info("Added %s", model) 
開發者ID:src-d,項目名稱:modelforge,代碼行數:24,代碼來源:index.py

示例2: git_add

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def git_add(args):
    if len(args) > 0:
        repo = _get_repo()
        cwd = os.getcwd()

        args = [os.path.join(os.path.relpath(cwd, repo.path), x) if not os.path.samefile(cwd, repo.path) else x for x in args]

        for file in args:

            if os.path.exists(os.path.join(repo.repo.path, file)):
                print('Adding {0}'.format(file))
                porcelain.add(repo.repo.path, [file])
            else:
                print('{} does not exist. skipping'.format(file))

    else:
        print(command_help['add']) 
開發者ID:ywangd,項目名稱:stash,代碼行數:19,代碼來源:git.py

示例3: commit_and_push

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def commit_and_push(
    version: str,
    repository: Repository,
    paths: List[Path],
) -> None:
    """
    Commit and push all changes.
    """
    local_repository = Repo('.')
    _, ignored = add(paths=[str(path) for path in paths])
    assert not ignored
    message = b'Update for release ' + version.encode('utf-8')
    commit(message=message)
    branch_name = 'master'
    push(
        repo=local_repository,
        remote_location=repository.ssh_url,
        refspecs=branch_name.encode('utf-8'),
    ) 
開發者ID:dcos,項目名稱:dcos-e2e,代碼行數:21,代碼來源:release.py

示例4: refresh_gittle

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def refresh_gittle(self):
        #untracked
        #unstaged modified
        #staged add
        #staged rm
        #staged modify
        #unmodified 
        self.g=self._get_repo()
        def refresh_thread():
             if self.g:
                self.list[0]=list(self.g.untracked_files)
                #self.view['tableview1'].reload()
                self.list[1]=porcelain.status(self.g.path).unstaged
                #self.view['tableview1'].reload()
                self.list[2]=porcelain.status(self.g.path).staged['add']
                #self.view['tableview1'].reload()
                self.list[3]=porcelain.status(self.g.path).staged['delete']
                #self.view['tableview1'].reload()
                self.list[4]=porcelain.status(self.g.path).staged['modify']
                #self.view['tableview1'].reload()
                self.list[5]=list(self.g.tracked_files-set(itertools.chain(*self.list[1:4])))

        refresh_thread() 
開發者ID:khilnani,項目名稱:pythonista-scripts,代碼行數:25,代碼來源:gitui.py

示例5: update_readme

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def update_readme(self, template_readme: Template):
        """Generate the new README file locally."""
        readme = os.path.join(self.cached_repo, "README.md")
        if os.path.exists(readme):
            os.remove(readme)
        links = {model_type: {} for model_type in self.models.keys()}
        for model_type, model_uuids in self.models.items():
            for model_uuid in model_uuids:
                links[model_type][model_uuid] = os.path.join("/", model_type, "%s.md" % model_uuid)
        with open(readme, "w") as fout:
            fout.write(template_readme.render(models=self.models, meta=self.meta, links=links))
        git.add(self.cached_repo, [readme])
        self._log.info("Updated %s", readme) 
開發者ID:src-d,項目名稱:modelforge,代碼行數:15,代碼來源:index.py

示例6: upload

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def upload(self, cmd: str, meta: dict):
        """Push the current state of the registry to Git."""
        index = os.path.join(self.cached_repo, self.INDEX_FILE)
        if os.path.exists(index):
            os.remove(index)
        self._log.info("Writing the new index.json ...")
        with open(index, "w") as _out:
            json.dump(self.contents, _out, sort_keys=True, indent=4)
        git.add(self.cached_repo, [index])
        message = self.COMMIT_MESSAGES[cmd].format(**meta)
        if self.signoff:
            global_conf_path = os.path.expanduser("~/.gitconfig")
            if os.path.exists(global_conf_path):
                with open(global_conf_path, "br") as _in:
                    conf = ConfigFile.from_file(_in)
                    try:
                        name = conf.get(b"user", b"name").decode()
                        email = conf.get(b"user", b"email").decode()
                        message += self.DCO_MESSAGE.format(name=name, email=email)
                    except KeyError:
                        self._log.warning(
                            "Did not find name or email in %s, committing without DCO",
                            global_conf_path)
            else:
                self._log.warning("Global git configuration file %s does not exist, "
                                  "committing without DCO", global_conf_path)
        else:
            self._log.info("Committing the index without DCO")
        git.commit(self.cached_repo, message=message)
        self._log.info("Pushing the updated index ...")
        # TODO: change when https://github.com/dulwich/dulwich/issues/631 gets addressed
        git.push(self.cached_repo, self.remote_url, b"master")
        if self._are_local_and_remote_heads_different():
            self._log.error("Push has failed")
            raise ValueError("Push has failed") 
開發者ID:src-d,項目名稱:modelforge,代碼行數:37,代碼來源:index.py

示例7: add_file

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def add_file(self, data, filename):
        """Add a file to the commit."""
        try:
            full_filename = os.path.join(self.repo_path, filename)

            with open(full_filename, "w") as f:
                f.write(data)

            porcelain.add(self.repo, full_filename)
        except Exception:
            # Anonymizing exceptions
            log.exception("GitHandler::add_file()")
            raise InvalidCommand("Adding file failed: Please check your log files...") 
開發者ID:OpenToAllCTF,項目名稱:OTA-Challenge-Bot,代碼行數:15,代碼來源:githandler.py

示例8: unstage

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def unstage(self,repo,paths=None):
        from dulwich import porcelain
        from dulwich.index import index_entry_from_stat
    # if tree_entry does not exist, this was an add, so remove index entry to undo
    # if index_ entry does not exist, this was a remove.. add back in
        if paths:
            for path in paths:
                #print path
                full_path = os.path.join(repo.path, path)
                index=repo.open_index()
                tree_id=repo.object_store[repo.head()]._tree
                try:
                    tree_entry=repo.object_store[tree_id]._entries[path]
                except KeyError:
                    try:
                        del(index[path])
                        index.write()
                    except KeyError:
                        console.hud_alert('file not in index...')
                    return
                try:
                    index_entry=list(index[path])
                except KeyError:
                    if os.path.exists(full_path):
                        index_entry=list(index_entry_from_stat(posix.lstat(full_path),tree_entry[1]  ,0    ))
                    else:
                        index_entry=[[0]*11,tree_entry[1],0]
                index_entry[4]=tree_entry[0] #mode
                index_entry[7]=len(repo.object_store [tree_entry[1]].data) #size
                index_entry[8]=tree_entry[1] #sha
                index_entry[0]=repo.object_store[repo.head()].commit_time #ctime
                index_entry[1]=repo.object_store[repo.head()].commit_time #mtime
                index[path]=index_entry
                index.write() 
開發者ID:khilnani,項目名稱:pythonista-scripts,代碼行數:36,代碼來源:gitui.py

示例9: has_uncommitted_changes

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def has_uncommitted_changes(self):
        if(porcelain.status(self.g.path).unstaged or
            porcelain.status(self.g.path).staged['add'] or 
            porcelain.status(self.g.path).staged['modify'] or
            porcelain.status(self.g.path).staged['delete']):
                return True 
開發者ID:khilnani,項目名稱:pythonista-scripts,代碼行數:8,代碼來源:gitui.py

示例10: merge_trees

# 需要導入模塊: from dulwich import porcelain [as 別名]
# 或者: from dulwich.porcelain import add [as 別名]
def merge_trees(store, base, mine, theirs):
    ''' takes tree ids for base, mine, and theirs.  merge trees into current working tee'''
    num_conflicts = 0
    added = []
    removed = []
    w = walk_trees(store, [base, mine, theirs], True)
    count = 0
    for b, m, t in w:

        if _is_tree(b) or _is_tree(m) or _is_tree(t):
            #todo... handle mkdir, rmdir
            continue

        # if mine == theirs match, use either
        elif m == t:
            if not b.path:
                print('  ', m.path, 'was added, but matches already')
            continue  #leave workng tree alone
        # if base==theirs, but not mine, already deleted (do nothing)
        elif b == t and not m.path:
            print('   ', b.path, ' already deleted in head')
            continue
        # if base==mine, but not theirs, delete
        elif b == m and not t.path:
            print('  -', m.path, ' was deleted in theirs.')
            os.remove(m.path)
            removed.append(m.path)
        elif not b.path and m.path and not t.path:  #add in mine
            print('  ', m.path, 'added in mine')
            continue
        elif not b.path and t.path and not m.path:  # add theirs to mine
            # add theirs
            print('  +', t.path, ': adding to head')
            with open(t.path, 'w') as f:
                f.write(store[t.sha].data)
            added.append(t.path)
        elif not m == t:  # conflict
            print('  ?', m.path, ': merging conflicts')
            result = diff3.merge(
                store[m.sha].data.splitlines(True),
                store[b.sha].data.splitlines(True) if b.sha else [''],
                store[t.sha].data.splitlines(True)
            )
            mergedfile = result['body']
            had_conflict = result['conflict']
            with open(m.path, 'w') as f:
                for line in mergedfile:
                    f.write(line)
            if had_conflict:
                num_conflicts += 1
                print(
                    '    !!! {} had a conflict that could not be resolved.\n    conflict markers added to file in working tree.\n    you need to resolve manually '
                    .format(m.path)
                )
            added.append(m.path)
    return num_conflicts, added, removed 
開發者ID:ywangd,項目名稱:stash,代碼行數:58,代碼來源:git-merge.py


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