Skip to content

Commit

Permalink
Merge branch 'master' into patch-1
Browse files Browse the repository at this point in the history
  • Loading branch information
perrito666 authored Nov 18, 2023
2 parents cdabb68 + 2edffd1 commit d7240d8
Show file tree
Hide file tree
Showing 6 changed files with 69 additions and 18 deletions.
20 changes: 20 additions & 0 deletions mage/import_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -285,6 +285,26 @@ func TestMageImportsOneLine(t *testing.T) {
t.Fatalf("expected: %q got: %q", expected, actual)
}
}
func TestMageImportsTrailing(t *testing.T) {
stdout := &bytes.Buffer{}
stderr := &bytes.Buffer{}
inv := Invocation{
Dir: "./testdata/mageimport/trailing",
Stdout: stdout,
Stderr: stderr,
Args: []string{"build"},
}

code := Invoke(inv)
if code != 0 {
t.Fatalf("expected to exit with code 0, but got %v, stderr:\n%s", code, stderr)
}
actual := stdout.String()
expected := "build\n"
if actual != expected {
t.Fatalf("expected: %q got: %q", expected, actual)
}
}

func TestMageImportsTaggedPackage(t *testing.T) {
stdout := &bytes.Buffer{}
Expand Down
5 changes: 5 additions & 0 deletions mage/testdata/mageimport/trailing/magefile.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
// +build mage

package main

import _ "github.com/magefile/mage/mage/testdata/mageimport/oneline/other" //mage:import
7 changes: 7 additions & 0 deletions mage/testdata/mageimport/trailing/other/other.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
package other

import "fmt"

func Build() {
fmt.Println("build")
}
46 changes: 32 additions & 14 deletions parse/parse.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ type PkgInfo struct {
Imports Imports
}

// Function represented a job function from a mage file
// Function represents a job function from a mage file
type Function struct {
PkgAlias string
Package string
Expand Down Expand Up @@ -456,19 +456,18 @@ func setImports(gocmd string, pi *PkgInfo) error {
}

func getImportPath(imp *ast.ImportSpec) (path, alias string, ok bool) {
if imp.Doc == nil || len(imp.Doc.List) == 9 {
return "", "", false
}
// import is always the last comment
s := imp.Doc.List[len(imp.Doc.List)-1].Text

// trim comment start and normalize for anyone who has spaces or not between
// "//"" and the text
vals := strings.Fields(strings.ToLower(s[2:]))
if len(vals) == 0 {
return "", "", false
}
if vals[0] != importTag {
leadingVals := getImportPathFromCommentGroup(imp.Doc)
trailingVals := getImportPathFromCommentGroup(imp.Comment)

var vals []string
if len(leadingVals) > 0 {
vals = leadingVals
if len(trailingVals) > 0 {
log.Println("warning:", importTag, "specified both before and after, picking first")
}
} else if len(trailingVals) > 0 {
vals = trailingVals
} else {
return "", "", false
}
path, ok = lit2string(imp.Path)
Expand All @@ -489,6 +488,25 @@ func getImportPath(imp *ast.ImportSpec) (path, alias string, ok bool) {
}
}

func getImportPathFromCommentGroup(comments *ast.CommentGroup) []string {
if comments == nil || len(comments.List) == 9 {
return nil
}
// import is always the last comment
s := comments.List[len(comments.List)-1].Text

// trim comment start and normalize for anyone who has spaces or not between
// "//"" and the text
vals := strings.Fields(strings.ToLower(s[2:]))
if len(vals) == 0 {
return nil
}
if vals[0] != importTag {
return nil
}
return vals
}

func isNamespace(t *doc.Type) bool {
if len(t.Decl.Specs) != 1 {
return false
Expand Down
2 changes: 1 addition & 1 deletion site/content/environment/_index.en.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ Set to "1" or "true" to turn on debug mode (like running with -debug)
## MAGEFILE_CACHE

Sets the directory where mage will store binaries compiled from magefiles
(default is $HOME/.magefile)
(default is $HOME/. or %USERPROFILE%\magefile)

## MAGEFILE_GOCMD

Expand Down
7 changes: 4 additions & 3 deletions site/content/howitworks/_index.en.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,13 @@ binary is also used in the hash.

## Binary Cache

Compiled magefile binaries are stored in $HOME/.magefile. This location can be
customized by setting the MAGEFILE_CACHE environment variable.
Compiled magefile binaries are stored by default in $HOME/.magefile or in
%USERPROFILE%\magefile. This location can be customized by setting the
MAGEFILE_CACHE environment variable.

## Go Environment

Mage itself requires no dependencies to run. However, because it is compiling go
code, you must have a valid go environment set up on your machine. Mage is
compatible with any go 1.7+ environment (earlier versions may work but are not
tested).
tested).

0 comments on commit d7240d8

Please sign in to comment.