Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/vikstrous/mvpkg

A tool for moving Go packages within a Go module
https://github.com/vikstrous/mvpkg

Last synced: 4 days ago
JSON representation

A tool for moving Go packages within a Go module

Awesome Lists containing this project

README

        

# mvpkg

[![CircleCI](https://circleci.com/gh/vikstrous/mvpkg.svg?style=svg)](https://circleci.com/gh/vikstrous/mvpkg)
[![codecov](https://codecov.io/gh/vikstrous/mvpkg/branch/master/graph/badge.svg)](https://codecov.io/gh/vikstrous/mvpkg)
[![GolangCI](https://golangci.com/badges/github.com/vikstrous/mvpkg.svg)](https://golangci.com/r/github.com/vikstrous/mvpkg)

mvpkg is a refactoring tool for Go codebases that allows you to move a package
or a set of packages from one path to another within the same go module. It's
written for go modules and with performance in mind, so let me know if it's not
fast enough for you.

This tool was built because [gomvpkg](https://github.com/golang/tools/blob/e1da425f72fd3793b579f4e74d908ba96eb16c8a/cmd/gomvpkg/main.go) doesn't work with go modules.

## Installation:

```
go get github.com/vikstrous/mvpkg
```

## Usage:

```
Usage: mvpkg

mvpkg takes two positional arguments: a source and destination path
It works only withing a single go module and only with go module support enabled.
The source and destination paths must be relative to the root of the go module

-build-flags value
build tags to use while parsing source packages, can be specified morethan once
ex: -build-flags='-tags=foo bar'
-dry-run
print planned actions without executing them
-recursive
recursively move all packages nested under the source package
-v verbose, print status while running
```