当前位置: 首页> 文旅> 旅游 > 鞍山58同城租房网_软件开发是怎么开发的啊_seo概念_东莞seo搜索

鞍山58同城租房网_软件开发是怎么开发的啊_seo概念_东莞seo搜索

时间:2025/7/10 9:32:05来源:https://blog.csdn.net/nobigdeal00/article/details/144798730 浏览次数:0次
鞍山58同城租房网_软件开发是怎么开发的啊_seo概念_东莞seo搜索

背景

接之前wiki 15、【OS】【Nuttx】OS裁剪,运行指定程序,周期打印当前任务
准备合并MR的时候,发现合并请求创建不了
在这里插入图片描述
原因为该项目没有main分支,nuttx-apps的主分支名为master,而gitlab创建的项目中,主分支名为main,开源项目有不少主分支名为master,而非main

目标

重新更新go封装,自动识别远程仓库默认分支名

解决方案

回顾之前go代码
7、【ubuntu】【git】【go】优化merge request,用go对git mr进行配置
10、【ubuntu】【go】【git】优化merge request:使用分叉方法对项目进行隔离
发现target branch进行了硬编码,默认写成了main
在这里插入图片描述
封装个自动获取远程仓库默认分支名的代码出来

func getDefaultBranch(client *gitlab.Client, projectPath string) string {// 使用 GetProject 方法获取项目默认分支名project, _, err := client.Projects.GetProject(projectPath, nil)if err != nil {log.Fatalf("Failed to get project information: %v", err)}return project.DefaultBranch
}

目标分支名调用该接口,取消分叉项目保护的分支为目标分支名

	// 获取当前分支mrInfo.sourceBranch = execCommand("git br --show-current")// Merge Request的相关信息mrInfo.targetBranch = getDefaultBranch(client, projectPath)fmt.Printf("merge request from %s to %s\n", mrInfo.sourceBranch, mrInfo.targetBranch)// 获取当前认证的用户user := getCurrentUser(client)fmt.Printf("current user is %s\n", user)// 为项目创建新Groupgroup := getGroup(client, user)// 分叉项目fmt.Printf("project id is %d\n", mrInfo.projectID)forkedProject := getForkProject(mrInfo.projectID, group, client)mrInfo.forkedProjectID = forkedProject.IDfmt.Printf("forkedProject id is %d, url is %s\n", forkedProject.ID, forkedProject.SSHURLToRepo)// 取消分叉项目分支保护unprotectedBranch(forkedProject.ID, mrInfo.targetBranch, client)// 配置fork远程仓库forkRemoteConfig(forkedProject)

按wiki 5、【ubuntu】【git】【go】用go对git做层wrapper
构建,对git进行替换

最终效果

MR创建成功,目标分支也改成了远程仓库名master
在这里插入图片描述

关键字:鞍山58同城租房网_软件开发是怎么开发的啊_seo概念_东莞seo搜索

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: