update 04-schema.md

This commit is contained in:
成武 2014-01-05 23:52:50 +08:00
parent 66dddc4d59
commit 322381a166
1 changed files with 15 additions and 24 deletions

View File

@ -6,18 +6,18 @@
我们有一个 [JSON schema](http://json-schema.org) 格式化文档,它也可以被用来验证你的 `composer.json` 文件。事实上,它已经被 `validate` 命令所使用。 你可以在这里找到它: [`res/composer-schema.json`](https://github.com/composer/composer/blob/master/res/composer-schema.json). 我们有一个 [JSON schema](http://json-schema.org) 格式化文档,它也可以被用来验证你的 `composer.json` 文件。事实上,它已经被 `validate` 命令所使用。 你可以在这里找到它: [`res/composer-schema.json`](https://github.com/composer/composer/blob/master/res/composer-schema.json).
## Root Package ## Root
root package 是指由 `composer.json` 定义的在你项目根目录的包。这是 `composer.json` 定义你项目所需的主要条件。(简单的说,你自己的项目就是一个 root package “root 包”是指由 `composer.json` 定义的在你项目根目录的包。这是 `composer.json` 定义你项目所需的主要条件。(简单的说,你自己的项目就是一个 root
某些字段仅适用于 root package 上下文。 `config` 字段就是其中一个例子。只有 root package 可以定义 configuration。在依赖包中定义的 `config` 字段将被忽略,这使得 `config` 字段只有 root package 可用(`root-only`)。 某些字段仅适用于“root 包”上下文。 `config` 字段就是其中一个例子。只有“root 包”可以定义。在依赖包中定义的 `config` 字段将被忽略,这使得 `config` 字段只有“root 包”可用(`root-only`)。
如果你克隆了其中的一个依赖包,直接在其上开始工作,那么它就变成了 root package。与作为他人的依赖包时使用相同的 `composer.json` 文件,但上下文发生了变化。 如果你克隆了其中的一个依赖包,直接在其上开始工作,那么它就变成了“root 包”。与作为他人的依赖包时使用相同的 `composer.json` 文件,但上下文发生了变化。
> **注意:** 一个资源包是不是 root package,取决于它的上下文。 > **注意:** 一个资源包是不是“root 包”,取决于它的上下文。
> 例如:如果你的项目依赖 `monolog` 库,那么你的项目就是 root package > 例如:如果你的项目依赖 `monolog` 库,那么你的项目就是“root 包”
> 但是,如果你从 GitHub 上克隆了 `monolog` 为它修复 bug > 但是,如果你从 GitHub 上克隆了 `monolog` 为它修复 bug
> 那么此时 `monolog` 就是 root package > 那么此时 `monolog` 就是“root 包”
## 属性 ## 属性
@ -211,10 +211,9 @@ composer 原生支持以下4种类型
### Package links ### Package links
All of the following take an object which maps package names to 下面提到的所有对象,都应该是 包名 到 [版本](01-basic-usage.md#包版本) 的映射对象。
[version constraints](01-basic-usage.md#package-versions).
Example: 例如:
{ {
"require": { "require": {
@ -222,15 +221,11 @@ Example:
} }
} }
All links are optional fields. 所有的这些都是可选的。
`require` and `require-dev` additionally support stability flags (root-only). `require``require-dev` 还支持稳定性标签(@仅针对“root 包”)。这允许你在 [minimum-stability](#minimum-stability) 设定的范围外做进一步的限制或扩展。例如:如果你想允许依赖一个不稳定的包,你可以在一个包的版本约束后使用它,或者是一个空的版本约束内使用它。
These allow you to further restrict or expand the stability of a package beyond
the scope of the [minimum-stability](#minimum-stability) setting. You can apply
them to a constraint, or just apply them to an empty constraint if you want to
allow unstable packages of a dependency for example.
Example: 例子:
{ {
"require": { "require": {
@ -239,10 +234,9 @@ Example:
} }
} }
If one of your dependencies has a dependency on an unstable package you need to 如果你的依赖之一,有对另一个不稳定包的依赖,你最好在 require 中显示的定义它,并带上足够详细的稳定性标识。
explicitly require it as well, along with its sufficient stability flag.
Example: 例子:
{ {
"require": { "require": {
@ -251,10 +245,7 @@ Example:
} }
} }
`require` and `require-dev` additionally support explicit references (i.e. `require``require-dev` 还支持对 dev开发版本的明确引用版本控制系统中的提交编号 commit以确保它们被锁定到一个给定的状态即使你运行了更新命令。你只需要明确一个开发版本号并带上诸如 `#<ref>` 的标识。
commit) for dev versions to make sure they are locked to a given state, even
when you run update. These only work if you explicitly require a dev version
and append the reference with `#<ref>`.
Example: Example: