Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
b7c1f949
Commit
b7c1f949
authored
Jun 05, 2013
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed bug about setting default path aliases.
parent
7e111e92
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
31 additions
and
34 deletions
+31
-34
Application.php
framework/yii/base/Application.php
+28
-34
Module.php
framework/yii/base/Module.php
+3
-0
No files found.
framework/yii/base/Application.php
View file @
b7c1f949
...
@@ -67,10 +67,20 @@ class Application extends Module
...
@@ -67,10 +67,20 @@ class Application extends Module
* Constructor.
* Constructor.
* @param array $config name-value pairs that will be used to initialize the object properties.
* @param array $config name-value pairs that will be used to initialize the object properties.
* Note that the configuration must contain both [[id]] and [[basePath]].
* Note that the configuration must contain both [[id]] and [[basePath]].
* @throws InvalidConfigException if either [[id]] or [[basePath]] configuration is missing.
*/
*/
public
function
__construct
(
$config
=
array
())
public
function
__construct
(
$config
=
array
())
{
{
Yii
::
$app
=
$this
;
Yii
::
$app
=
$this
;
if
(
!
isset
(
$config
[
'id'
]))
{
throw
new
InvalidConfigException
(
'The "id" configuration is required.'
);
}
if
(
isset
(
$config
[
'basePath'
]))
{
$this
->
setBasePath
(
$config
[
'basePath'
]);
unset
(
$config
[
'basePath'
]);
}
else
{
throw
new
InvalidConfigException
(
'The "basePath" configuration is required.'
);
}
$this
->
preInit
(
$config
);
$this
->
preInit
(
$config
);
...
@@ -83,37 +93,24 @@ class Application extends Module
...
@@ -83,37 +93,24 @@ class Application extends Module
/**
/**
* Pre-initializes the application.
* Pre-initializes the application.
* This method is called at the beginning of the application constructor.
* This method is called at the beginning of the application constructor.
* When this method is called, none of the application properties are initialized yet.
* The default implementation will initialize a few important properties
* that may be referenced during the initialization of the rest of the properties.
* @param array $config the application configuration
* @param array $config the application configuration
* @throws InvalidConfigException if either [[id]] or [[basePath]] configuration is missing.
*/
*/
public
function
preInit
(
$config
)
public
function
preInit
(
&
$config
)
{
{
if
(
!
isset
(
$config
[
'id'
]))
{
if
(
isset
(
$config
[
'vendorPath'
]))
{
throw
new
InvalidConfigException
(
'The "id" configuration is required.'
);
$this
->
setVendorPath
(
$config
[
'vendorPath'
]);
}
if
(
!
isset
(
$config
[
'basePath'
]))
{
throw
new
InvalidConfigException
(
'The "basePath" configuration is required.'
);
}
$this
->
setBasePath
(
$config
[
'basePath'
]);
Yii
::
setAlias
(
'@app'
,
$this
->
getBasePath
());
unset
(
$config
[
'basePath'
]);
if
(
isset
(
$config
[
'vendor'
]))
{
$this
->
setVendorPath
(
$config
[
'vendor'
]);
unset
(
$config
[
'vendorPath'
]);
unset
(
$config
[
'vendorPath'
]);
}
else
{
// set "@vendor"
$this
->
getVendorPath
();
}
}
Yii
::
setAlias
(
'@vendor'
,
$this
->
getVendorPath
());
if
(
isset
(
$config
[
'runtimePath'
]))
{
$this
->
setRuntimePath
(
$config
[
'runtimePath'
]);
if
(
isset
(
$config
[
'runtime'
]))
{
unset
(
$config
[
'runtimePath'
]);
$this
->
setRuntimePath
(
$config
[
'runtime'
]);
}
else
{
unset
(
$config
[
'runtime'
]);
// set "@runtime"
$this
->
getRuntimePath
();
}
}
Yii
::
setAlias
(
'@runtime'
,
$this
->
getRuntimePath
());
if
(
isset
(
$config
[
'timeZone'
]))
{
if
(
isset
(
$config
[
'timeZone'
]))
{
$this
->
setTimeZone
(
$config
[
'timeZone'
]);
$this
->
setTimeZone
(
$config
[
'timeZone'
]);
unset
(
$config
[
'timeZone'
]);
unset
(
$config
[
'timeZone'
]);
...
@@ -202,7 +199,8 @@ class Application extends Module
...
@@ -202,7 +199,8 @@ class Application extends Module
/**
/**
* Returns the directory that stores runtime files.
* Returns the directory that stores runtime files.
* @return string the directory that stores runtime files. Defaults to 'protected/runtime'.
* @return string the directory that stores runtime files.
* Defaults to the "runtime" subdirectory under [[basePath]].
*/
*/
public
function
getRuntimePath
()
public
function
getRuntimePath
()
{
{
...
@@ -215,16 +213,11 @@ class Application extends Module
...
@@ -215,16 +213,11 @@ class Application extends Module
/**
/**
* Sets the directory that stores runtime files.
* Sets the directory that stores runtime files.
* @param string $path the directory that stores runtime files.
* @param string $path the directory that stores runtime files.
* @throws InvalidConfigException if the directory does not exist or is not writable
*/
*/
public
function
setRuntimePath
(
$path
)
public
function
setRuntimePath
(
$path
)
{
{
$path
=
Yii
::
getAlias
(
$path
);
$this
->
_runtimePath
=
Yii
::
getAlias
(
$path
);
if
(
is_dir
(
$path
)
&&
is_writable
(
$path
))
{
Yii
::
setAlias
(
'@runtime'
,
$this
->
_runtimePath
);
$this
->
_runtimePath
=
$path
;
}
else
{
throw
new
InvalidConfigException
(
"Runtime path must be a directory writable by the Web server process:
$path
"
);
}
}
}
private
$_vendorPath
;
private
$_vendorPath
;
...
@@ -232,7 +225,7 @@ class Application extends Module
...
@@ -232,7 +225,7 @@ class Application extends Module
/**
/**
* Returns the directory that stores vendor files.
* Returns the directory that stores vendor files.
* @return string the directory that stores vendor files.
* @return string the directory that stores vendor files.
* Defaults to
'vendor' directory under applications
[[basePath]].
* Defaults to
"vendor" directory under
[[basePath]].
*/
*/
public
function
getVendorPath
()
public
function
getVendorPath
()
{
{
...
@@ -249,6 +242,7 @@ class Application extends Module
...
@@ -249,6 +242,7 @@ class Application extends Module
public
function
setVendorPath
(
$path
)
public
function
setVendorPath
(
$path
)
{
{
$this
->
_vendorPath
=
Yii
::
getAlias
(
$path
);
$this
->
_vendorPath
=
Yii
::
getAlias
(
$path
);
Yii
::
setAlias
(
'@vendor'
,
$this
->
_vendorPath
);
}
}
/**
/**
...
...
framework/yii/base/Module.php
View file @
b7c1f949
...
@@ -236,6 +236,9 @@ abstract class Module extends Component
...
@@ -236,6 +236,9 @@ abstract class Module extends Component
$p
=
realpath
(
$path
);
$p
=
realpath
(
$path
);
if
(
$p
!==
false
&&
is_dir
(
$p
))
{
if
(
$p
!==
false
&&
is_dir
(
$p
))
{
$this
->
_basePath
=
$p
;
$this
->
_basePath
=
$p
;
if
(
$this
instanceof
Application
)
{
Yii
::
setAlias
(
'@app'
,
$p
);
}
}
else
{
}
else
{
throw
new
InvalidParamException
(
"The directory does not exist:
$path
"
);
throw
new
InvalidParamException
(
"The directory does not exist:
$path
"
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment