Skip to content

Commit

Permalink
Make basedir property (including its default "." value) is a relative…
Browse files Browse the repository at this point in the history
… path to the project's root.
  • Loading branch information
mpdude authored and mrook committed Mar 3, 2017
1 parent 41b2f54 commit dfdb0bc
Show file tree
Hide file tree
Showing 6 changed files with 83 additions and 5 deletions.
2 changes: 1 addition & 1 deletion classes/phing/parser/ProjectHandler.php
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@ public function init($tag, $attrs)
if ($f->isAbsolute()) {
$project->setBasedir($baseDir);
} else {
$project->setBaseDir($project->resolveFile($baseDir, new PhingFile(getcwd())));
$project->setBaseDir($project->resolveFile($baseDir, $buildFileParent));
}
}
}
Expand Down
10 changes: 6 additions & 4 deletions docs/docbook5/en/source/chapters/gettingstarted.xml
Original file line number Diff line number Diff line change
Expand Up @@ -154,10 +154,12 @@
</row>
<row>
<entry><literal>basedir</literal></entry>
<entry>The base directory of the project, use &quot;.&quot; do denote
the current directory. <emphasis role="bold">Note:</emphasis> if
none is specified, the parent directory of the build file is
used!</entry>
<entry>The base directory of the project. This attribute controls the value of the
<literal>${project.basedir}</literal> property which can be used to reference
files with paths relative to the project root folder. Can be a path relative to
the position of the buildfile itself. If omitted, &quot;.&quot; will be used,
which means that the build file should be located in the project's root folder.
</entry>
<entry>No</entry>
</row>
<row>
Expand Down
49 changes: 49 additions & 0 deletions test/classes/phing/regression/309/Ticket309RegressionTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
<?php

/*
* $Id$
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL. For more information please see
* <http://phing.info>.
*/

require_once 'phing/BuildFileTest.php';

class Ticket309RegressionTest extends BuildFileTest
{
/**
* The project.basedir property denotes the project root directory.
* This root directory can be set by the "basedir" attribute on the
* <project> tag. It denotes the path to the project root, relative to
* the buildfile.
*
* The default is ".", meaning that the build.xml file is locate in the
* project root.
*
* This test uses several buildfiles that reference the /etc/regression/309
* directory as their project root in various ways.
*/
public function testPhingCallTask()
{
$testBasedir = PHING_TEST_BASE . "/etc/regression/309";

foreach (array('basedir-dot.xml', 'basedir-default.xml', 'sub/basedir-dotdot.xml') as $buildfile) {
$this->configureProject("$testBasedir/$buildfile");
$this->executeTarget("main");
$this->assertInLogs("project.basedir: $testBasedir");
}
}
}
9 changes: 9 additions & 0 deletions test/etc/regression/309/basedir-default.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<?xml version="1.0"?>
<project name="test" default="main">

<target name="main">
<echo>project.basedir: ${project.basedir}</echo>
<echo>application.startdir: ${application.startdir}</echo>
</target>

</project>
9 changes: 9 additions & 0 deletions test/etc/regression/309/basedir-dot.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<?xml version="1.0"?>
<project name="test" default="main" basedir=".">

<target name="main">
<echo>project.basedir: ${project.basedir}</echo>
<echo>application.startdir: ${application.startdir}</echo>
</target>

</project>
9 changes: 9 additions & 0 deletions test/etc/regression/309/sub/basedir-dotdot.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<?xml version="1.0"?>
<project name="test" default="main" basedir="..">

<target name="main">
<echo>project.basedir: ${project.basedir}</echo>
<echo>application.startdir: ${application.startdir}</echo>
</target>

</project>

0 comments on commit dfdb0bc

Please sign in to comment.