-
Notifications
You must be signed in to change notification settings - Fork 52
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add helper methods to create mappings #38
Merged
+165
−4
Merged
Changes from 1 commit
Commits
Show all changes
6 commits
Select commit
Hold shift + click to select a range
ff21308
Add helper methods to create mappings
muuki88 b84c01a
Fix file path in examples
muuki88 42ed5a8
Move helpers to PathMapper.scala
muuki88 012496a
Adding additional tests for corner cases
muuki88 7d8883a
add test case
muuki88 2b184f0
Fix docs for directory method
muuki88 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -85,6 +85,60 @@ object Path extends Mapper { | |
val sep: Char = java.io.File.separatorChar | ||
|
||
def toURLs(files: Seq[File]): Array[URL] = files.map(_.toURI.toURL).toArray | ||
|
||
/** | ||
* return a Seq of mappings which effect is to add a whole directory in the generated package | ||
* | ||
* @example In order to create mappings for a static directory "extra" add | ||
* {{{ | ||
* mappings in Universal ++= directory(baseDirectory.value / "extra") | ||
* }}} | ||
* | ||
* The resulting mappings sequence will look something like this | ||
* | ||
* {{{ | ||
* File(extras/file1) -> "extras/file1" | ||
* File(extras/file2) -> "extras/"file2" | ||
* ... | ||
* }}} | ||
* | ||
* | ||
* @param baseDirectory The directory that should be turned into a mappings sequence. | ||
* @return mappings The `baseDirectory` and all of its contents | ||
*/ | ||
def directory(baseDirectory: File): Seq[(File, String)] = | ||
Option(baseDirectory.getParentFile) | ||
.map(parent => PathFinder(baseDirectory).allPaths pair relativeTo(parent)) | ||
.getOrElse(PathFinder(baseDirectory).allPaths pair basic) | ||
|
||
/** | ||
* return a Seq of mappings excluding the directory itself. | ||
* | ||
* @example In order to create mappings for a static directory "extra" add | ||
* {{{ | ||
* mappings in Universal ++= contentOf(baseDirectory.value / "extra") | ||
* }}} | ||
* | ||
* The resulting mappings sequence will look something like this | ||
* | ||
* {{{ | ||
* File(extras/file1) -> "file1" | ||
* File(extras/file2) -> "file2" | ||
* ... | ||
* }}} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This example seems to be wrong. I'm getting: scala> for ((file, path) <- Path contentOf (file("base") / "extra")) println(s"""$file -> "$path"""")
base/extra/file1 -> "file1"
base/extra/file2 -> "file2" |
||
* | ||
* @example Add a static directory "extra" and re-map the destination to a different path | ||
* {{{ | ||
* mappings in Universal ++= contentOf(baseDirectory.value / "extra").map { | ||
* case (src, destination => src -> s"new/path/$destination" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. this example doesn't compile (missing |
||
* } | ||
* }}} | ||
* | ||
* @param baseDirectory The directory that should be turned into a mappings sequence. | ||
* @return mappings - The `basicDirectory`'s contents exlcuding `basicDirectory` itself | ||
*/ | ||
def contentOf(baseDirectory: File): Seq[(File, String)] = | ||
(PathFinder(baseDirectory).allPaths --- PathFinder(baseDirectory)) pair relativeTo(baseDirectory) | ||
} | ||
|
||
object PathFinder { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
package sbt.io | ||
|
||
import java.nio.file.{ Files, Path => NioPath } | ||
|
||
import org.scalatest._ | ||
import sbt.io.syntax._ | ||
|
||
class PathSpec extends fixture.FlatSpec with Matchers { | ||
|
||
type FixtureParam = NioPath | ||
|
||
"directory" should "create mappings including the baseDirectory" in { tempDirectory => | ||
|
||
val nestedFile1 = Files.createFile(tempDirectory resolve "file1").toFile | ||
val nestedFile2 = Files.createFile(tempDirectory resolve "file2").toFile | ||
val nestedDir = Files.createDirectory(tempDirectory resolve "dir1") | ||
val nestedDirFile = Files.createDirectory(nestedDir resolve "dir1-file1").toFile | ||
|
||
val mappings = Path.directory(tempDirectory.toFile) | ||
|
||
mappings should contain theSameElementsAs List[(File, String)]( | ||
tempDirectory.toFile -> s"${tempDirectory.getFileName}", | ||
nestedFile1 -> s"${tempDirectory.getFileName}/file1", | ||
nestedFile2 -> s"${tempDirectory.getFileName}/file2", | ||
nestedDir.toFile -> s"${tempDirectory.getFileName}/dir1", | ||
nestedDirFile -> s"${tempDirectory.getFileName}/dir1/dir1-file1" | ||
) | ||
} | ||
|
||
"contentOf" should "create mappings excluding the baseDirectory" in { tempDirectory => | ||
|
||
val nestedFile1 = Files.createFile(tempDirectory resolve "file1").toFile | ||
val nestedFile2 = Files.createFile(tempDirectory resolve "file2").toFile | ||
val nestedDir = Files.createDirectory(tempDirectory resolve "dir1") | ||
val nestedDirFile = Files.createDirectory(nestedDir resolve "dir1-file1").toFile | ||
|
||
val mappings = Path.contentOf(tempDirectory.toFile) | ||
|
||
mappings should contain theSameElementsAs List[(File, String)]( | ||
nestedFile1 -> s"file1", | ||
nestedFile2 -> s"file2", | ||
nestedDir.toFile -> s"dir1", | ||
nestedDirFile -> s"dir1/dir1-file1" | ||
) | ||
} | ||
|
||
override protected def withFixture(test: OneArgTest): Outcome = { | ||
val tmpDir = Files.createTempDirectory("path-mappings") | ||
try { | ||
withFixture(test.toNoArgTest(tmpDir)) | ||
} finally { | ||
// cleanup an delete the temp directory | ||
IO.delete(tmpDir.toFile) | ||
} | ||
} | ||
} |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This example seems to be wrong. I'm getting: