[hibernate-commits] Hibernate SVN: r19905 - validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules.

hibernate-commits at lists.jboss.org hibernate-commits at lists.jboss.org
Tue Jul 6 15:35:14 EDT 2010


Author: stliu
Date: 2010-07-06 15:35:13 -0400 (Tue, 06 Jul 2010)
New Revision: 19905

Modified:
   validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/gettingstarted.po
   validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/preface.po
Log:
HV-351 first chapter

Modified: validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/gettingstarted.po
===================================================================
--- validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/gettingstarted.po	2010-07-06 15:18:26 UTC (rev 19904)
+++ validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/gettingstarted.po	2010-07-06 19:35:13 UTC (rev 19905)
@@ -6,8 +6,8 @@
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
 "POT-Creation-Date: 2010-07-06 14:46+0000\n"
-"PO-Revision-Date: 2010-07-06 14:46+0000\n"
-"Last-Translator: Automatically generated\n"
+"PO-Revision-Date: 2010-07-07 03:33+0830\n"
+"Last-Translator: Strong Liu <stliu at hibernate.org>\n"
 "Language-Team: none\n"
 "MIME-Version: 1.0\n"
 "Content-Type: text/plain; charset=UTF-8\n"
@@ -17,43 +17,37 @@
 #: gettingstarted.xml:25
 #, no-c-format
 msgid "Getting started"
-msgstr ""
+msgstr "开始入门"
 
 #. Tag: para
 #: gettingstarted.xml:27
 #, no-c-format
-msgid ""
-"This chapter will show you how to get started with Hibernate Validator, the "
-"reference implementation (RI) of Bean Validation. For the following "
-"quickstart you need:"
-msgstr ""
+msgid "This chapter will show you how to get started with Hibernate Validator, the reference implementation (RI) of Bean Validation. For the following quickstart you need:"
+msgstr "本章将会告诉你如何使用Hibernate Validator, 在开始之前,你需要准备好下面的环境:"
 
 #. Tag: para
 #: gettingstarted.xml:33
 #, no-c-format
 msgid "A JDK &gt;= 5"
-msgstr ""
+msgstr "A JDK &gt;= 5"
 
 #. Tag: ulink
 #: gettingstarted.xml:37
 #, no-c-format
 msgid "Apache Maven"
-msgstr ""
+msgstr "Apache Maven"
 
 #. Tag: para
 #: gettingstarted.xml:41
 #, no-c-format
 msgid "An Internet connection (Maven has to download all required libraries)"
-msgstr ""
+msgstr "网络连接 ( Maven需要通过互联网下载所需的类库)"
 
 #. Tag: para
 #: gettingstarted.xml:46
 #, no-c-format
 msgid ""
-"A properly configured remote repository. Add the following to your "
-"<filename>settings.xml</filename>: <example> <title>Configuring the JBoss "
-"Maven repository in <filename>settings.xml</filename></title> "
-"<programlisting>&lt;repositories&gt;\n"
+"A properly configured remote repository. Add the following to your <filename>settings.xml</filename>: <example> <title>Configuring the JBoss Maven repository in <filename>settings.xml</filename></title> <programlisting>&lt;repositories&gt;\n"
 "    &lt;repository&gt;\n"
 "        &lt;id&gt;jboss&lt;/id&gt;\n"
 "        &lt;url&gt;http://repository.jboss.com/maven2&lt;/url&gt;\n"
@@ -64,21 +58,26 @@
 "            &lt;enabled&gt;false&lt;/enabled&gt;\n"
 "        &lt;/snapshots&gt;\n"
 "    &lt;/repository&gt;\n"
-"&lt;/repositories&gt;</programlisting> </example>More information about "
-"<filename>settings.xml</filename> can be found in the <ulink url=\"http://"
-"maven.apache.org/ref/2.0.8/maven-settings/settings.html\">Maven Local "
-"Settings Model</ulink>."
+"&lt;/repositories&gt;</programlisting> </example>More information about <filename>settings.xml</filename> can be found in the <ulink url=\"http://maven.apache.org/ref/2.0.8/maven-settings/settings.html\">Maven Local Settings Model</ulink>."
 msgstr ""
+"配置远端maven仓库. 添加下面的内容到你的<filename>settings.xml</filename>中:<example> <title>Configuring the JBoss Maven repository in <filename>settings.xml</filename></title> <programlisting>&lt;repositories&gt;\n"
+"    &lt;repository&gt;\n"
+"        &lt;id&gt;jboss&lt;/id&gt;\n"
+"        &lt;url&gt;http://repository.jboss.com/maven2&lt;/url&gt;\n"
+"        &lt;releases&gt;\n"
+"            &lt;enabled&gt;true&lt;/enabled&gt;\n"
+"        &lt;/releases&gt;\n"
+"        &lt;snapshots&gt;\n"
+"            &lt;enabled&gt;false&lt;/enabled&gt;\n"
+"        &lt;/snapshots&gt;\n"
+"    &lt;/repository&gt;\n"
+"&lt;/repositories&gt;</programlisting> </example>更多关于<filename>settings.xml</filename> 的信息请参考<ulink url=\"http://maven.apache.org/ref/2.0.8/maven-settings/settings.html\">Maven Local Settings Model</ulink>."
 
 #. Tag: para
 #: gettingstarted.xml:60
 #, no-c-format
 msgid ""
-"Hibernate Validator uses JAXB for XML parsing. JAXB is part of the Java "
-"Class Library since Java 6 which means that if you run Hibernate Validator "
-"with Java 5 you will have to add additional JAXB dependencies. Using maven "
-"you have to add the following dependencies:<programlisting>&lt;"
-"dependency&gt;\n"
+"Hibernate Validator uses JAXB for XML parsing. JAXB is part of the Java Class Library since Java 6 which means that if you run Hibernate Validator with Java 5 you will have to add additional JAXB dependencies. Using maven you have to add the following dependencies:<programlisting>&lt;dependency&gt;\n"
 "    &lt;groupId&gt;javax.xml.bind&lt;/groupId&gt;\n"
 "    &lt;artifactId&gt;jaxb-api&lt;/artifactId&gt;\n"
 "    &lt;version&gt;2.2&lt;/version&gt;\n"
@@ -88,89 +87,89 @@
 "    &lt;artifactId&gt;jaxb-impl&lt;/artifactId&gt;\n"
 "    &lt;version&gt;2.1.12&lt;/version&gt;\n"
 "&lt;/dependency&gt;\n"
-"</programlisting> if you are using the SourceForge package you find the "
-"necessary libraries in the <filename>lib/jdk5</filename> directory. In case "
-"you are not using the XML configuration you can also disable it explicitly "
-"by calling <methodname>Configuration.ignoreXmlConfiguration()</methodname> "
-"during <classname>ValidationFactory</classname> creation. In this case the "
-"JAXB dependencies are not needed."
+"</programlisting> if you are using the SourceForge package you find the necessary libraries in the <filename>lib/jdk5</filename> directory. In case you are not using the XML configuration you can also disable it explicitly by calling <methodname>Configuration.ignoreXmlConfiguration()</methodname> during <classname>ValidationFactory</classname> creation. In this case the JAXB dependencies are not needed."
 msgstr ""
+"Hibernate Validator 使用JAXB 来解析XML. JAXB 已经被集成进Java 6了, 所以,如果你要在Java 5上使用Hibernate Validator的话, 那么,还需要添加额外的JAXB的依赖. 如果你使用Maven的话,你可以把下面的内容添加到pom当中:<programlisting>&lt;dependency&gt;\n"
+"    &lt;groupId&gt;javax.xml.bind&lt;/groupId&gt;\n"
+"    &lt;artifactId&gt;jaxb-api&lt;/artifactId&gt;\n"
+"    &lt;version&gt;2.2&lt;/version&gt;\n"
+"&lt;/dependency&gt;\n"
+"&lt;dependency&gt;\n"
+"    &lt;groupId&gt;com.sun.xml.bind&lt;/groupId&gt;\n"
+"    &lt;artifactId&gt;jaxb-impl&lt;/artifactId&gt;\n"
+"    &lt;version&gt;2.1.12&lt;/version&gt;\n"
+"&lt;/dependency&gt;\n"
+"</programlisting>"
 
 #. Tag: title
 #: gettingstarted.xml:73
 #, no-c-format
 msgid "Setting up a new Maven project"
-msgstr ""
+msgstr "第一个Maven项目"
 
 #. Tag: para
 #: gettingstarted.xml:75
 #, no-c-format
-msgid ""
-"Start by creating new Maven project using the Maven archetype plugin as "
-"follows:"
-msgstr ""
+msgid "Start by creating new Maven project using the Maven archetype plugin as follows:"
+msgstr "使用Maven archetype插件来创建一个新的Maven 项目"
 
 #. Tag: title
 #: gettingstarted.xml:79
 #, no-c-format
-msgid ""
-"Using Maven's archetype plugin to create a sample project using Hibernate "
-"Validator"
-msgstr ""
+msgid "Using Maven's archetype plugin to create a sample project using Hibernate Validator"
+msgstr "使用Maven archetype 插件来创建一个简单的基于Hibernate Validator的项目"
 
 #. Tag: programlisting
 #: gettingstarted.xml:82
 #, no-c-format
 msgid ""
 "mvn archetype:create -DarchetypeGroupId=org.hibernate \\\n"
-"                     -DarchetypeArtifactId=hibernate-validator-quickstart-"
-"archetype \\\n"
+"                     -DarchetypeArtifactId=hibernate-validator-quickstart-archetype \\\n"
 "                     -DarchetypeVersion=&version; \\\n"
 "                     -DgroupId=com.mycompany \n"
 "                     -DartifactId=hv-quickstart"
 msgstr ""
+"mvn archetype:create -DarchetypeGroupId=org.hibernate \\\n"
+"                     -DarchetypeArtifactId=hibernate-validator-quickstart-archetype \\\n"
+"                     -DarchetypeVersion=&version; \\\n"
+"                     -DgroupId=com.mycompany \n"
+"                     -DartifactId=hv-quickstart"
 
 #. Tag: para
 #: gettingstarted.xml:85
 #, no-c-format
-msgid ""
-"Maven will create your project in the directory hv-quickstart. Change into "
-"this directory and run:"
-msgstr ""
+msgid "Maven will create your project in the directory hv-quickstart. Change into this directory and run:"
+msgstr "Maven 将会把你的项目创建在hv-quickstart目录中. 进入这个目录并且执行:"
 
 #. Tag: programlisting
 #: gettingstarted.xml:88
 #, no-c-format
 msgid "mvn test"
-msgstr ""
+msgstr "mvn test"
 
 #. Tag: para
 #: gettingstarted.xml:88
 #, no-c-format
-msgid ""
-"Maven will compile the example code and run the implemented unit tests. "
-"Let's have a look at the actual code."
-msgstr ""
+msgid "Maven will compile the example code and run the implemented unit tests. Let's have a look at the actual code."
+msgstr "这样, Maven会编译示例代码并且运行单元测试, 接下来,让我们看看生成的代码."
 
 #. Tag: title
 #: gettingstarted.xml:94
 #, no-c-format
 msgid "Applying constraints"
-msgstr ""
+msgstr "添加约束"
 
 #. Tag: para
 #: gettingstarted.xml:96
 #, no-c-format
-msgid ""
-"Open the project in the IDE of your choice and have a look at the class "
-"<classname>Car</classname>:"
-msgstr ""
+msgid "Open the project in the IDE of your choice and have a look at the class <classname>Car</classname>:"
+msgstr "在你喜欢的IDE中打开这个项目中的<classname>Car</classname>类:"
 
 #. Tag: title
 #: gettingstarted.xml:100
 #, no-c-format
 msgid "Class Car annotated with constraints"
-msgstr ""
+msgstr "带约束性标注(annotated with constraints)的Car 类"
 
 #. Tag: programlisting
 #: gettingstarted.xml:102
@@ -203,57 +202,74 @@
 "    //getters and setters ...\n"
 "}"
 msgstr ""
+"package com.mycompany;\n"
+"\n"
+"import javax.validation.constraints.Min;\n"
+"import javax.validation.constraints.NotNull;\n"
+"import javax.validation.constraints.Size;\n"
+"\n"
+"public class Car {\n"
+"\n"
+"    @NotNull\n"
+"    private String manufacturer;\n"
+"\n"
+"    @NotNull\n"
+"    @Size(min = 2, max = 14)\n"
+"    private String licensePlate;\n"
+"\n"
+"    @Min(2)\n"
+"    private int seatCount;\n"
+"    \n"
+"    public Car(String manufacturer, String licencePlate, int seatCount) {\n"
+"        this.manufacturer = manufacturer;\n"
+"        this.licensePlate = licencePlate;\n"
+"        this.seatCount = seatCount;\n"
+"    }\n"
+"\n"
+"    //getters and setters ...\n"
+"}"
 
 #. Tag: para
 #: gettingstarted.xml:105
 #, no-c-format
-msgid ""
-"<classname>@NotNull</classname>, <classname>@Size</classname> and "
-"<classname>@Min</classname> are so-called constraint annotations, that we "
-"use to declare constraints, which shall be applied to the fields of a "
-"<classname>Car</classname> instance:"
-msgstr ""
+msgid "<classname>@NotNull</classname>, <classname>@Size</classname> and <classname>@Min</classname> are so-called constraint annotations, that we use to declare constraints, which shall be applied to the fields of a <classname>Car</classname> instance:"
+msgstr "<classname>@NotNull</classname>, <classname>@Size</classname> and <classname>@Min</classname>就是上面所属的约束性标注( constraint annotations), 我们就是使用它们来声明约束, 例如在<classname>Car</classname>的字段中我们可以看到:"
 
 #. Tag: para
 #: gettingstarted.xml:112
 #, no-c-format
 msgid "<property>manufacturer</property> shall never be null"
-msgstr ""
+msgstr "<property>manufacturer</property>永远不能为null"
 
 #. Tag: para
 #: gettingstarted.xml:116
 #, no-c-format
-msgid ""
-"<property>licensePlate</property> shall never be null and must be between 2 "
-"and 14 characters long"
-msgstr ""
+msgid "<property>licensePlate</property> shall never be null and must be between 2 and 14 characters long"
+msgstr "<property>licensePlate</property>永远不能为null,并且它的值字符串的长度要在2到14之间"
 
 #. Tag: para
 #: gettingstarted.xml:121
 #, no-c-format
 msgid "<property>seatCount</property> shall be at least 2."
-msgstr ""
+msgstr "<property>seatCount</property>的值要不能小于2"
 
 #. Tag: title
 #: gettingstarted.xml:127
 #, no-c-format
 msgid "Validating constraints"
-msgstr ""
+msgstr "校验约束"
 
 #. Tag: para
 #: gettingstarted.xml:129
 #, no-c-format
-msgid ""
-"To perform a validation of these constraints, we use a <classname>Validator</"
-"classname> instance. Let's have a look at the <classname>CarTest</classname> "
-"class:"
-msgstr ""
+msgid "To perform a validation of these constraints, we use a <classname>Validator</classname> instance. Let's have a look at the <classname>CarTest</classname> class:"
+msgstr "我们需要使用<classname>Validator</classname>来对上面的那些约束进行校验. 让我们来看看<classname>CarTest</classname>这个类:"
 
 #. Tag: title
 #: gettingstarted.xml:134
 #, no-c-format
 msgid "Class CarTest showing validation examples"
-msgstr ""
+msgstr "在CarTest中使用校验"
 
 #. Tag: programlisting
 #: gettingstarted.xml:136
@@ -279,8 +295,7 @@
 "\n"
 "    @BeforeClass\n"
 "    public static void setUp() {\n"
-"        ValidatorFactory factory = Validation.buildDefaultValidatorFactory"
-"();\n"
+"        ValidatorFactory factory = Validation.buildDefaultValidatorFactory();\n"
 "        validator = factory.getValidator();\n"
 "    }\n"
 "\n"
@@ -292,8 +307,7 @@
 "            validator.validate(car);\n"
 "\n"
 "        assertEquals(1, constraintViolations.size());\n"
-"        assertEquals(\"may not be null\", constraintViolations.iterator()."
-"next().getMessage());\n"
+"        assertEquals(\"may not be null\", constraintViolations.iterator().next().getMessage());\n"
 "    }\n"
 "\n"
 "    @Test\n"
@@ -304,8 +318,7 @@
 "            validator.validate(car);\n"
 "\n"
 "        assertEquals(1, constraintViolations.size());\n"
-"        assertEquals(\"size must be between 2 and 14\", constraintViolations."
-"iterator().next().getMessage());\n"
+"        assertEquals(\"size must be between 2 and 14\", constraintViolations.iterator().next().getMessage());\n"
 "    }\n"
 "    \n"
 "    @Test\n"
@@ -316,8 +329,7 @@
 "            validator.validate(car);\n"
 "\n"
 "        assertEquals(1, constraintViolations.size());\n"
-"        assertEquals(\"must be greater than or equal to 2\", "
-"constraintViolations.iterator().next().getMessage());\n"
+"        assertEquals(\"must be greater than or equal to 2\", constraintViolations.iterator().next().getMessage());\n"
 "    }\n"
 "\n"
 "    @Test\n"
@@ -331,85 +343,125 @@
 "    }\n"
 "}"
 msgstr ""
+"package com.mycompany;\n"
+"\n"
+"import static org.junit.Assert.*;\n"
+"\n"
+"import java.util.Set;\n"
+"\n"
+"import javax.validation.ConstraintViolation;\n"
+"import javax.validation.Validation;\n"
+"import javax.validation.Validator;\n"
+"import javax.validation.ValidatorFactory;\n"
+"\n"
+"import org.junit.BeforeClass;\n"
+"import org.junit.Test;\n"
+"\n"
+"public class CarTest {\n"
+"\n"
+"    private static Validator validator;\n"
+"\n"
+"    @BeforeClass\n"
+"    public static void setUp() {\n"
+"        ValidatorFactory factory = Validation.buildDefaultValidatorFactory();\n"
+"        validator = factory.getValidator();\n"
+"    }\n"
+"\n"
+"    @Test\n"
+"    public void manufacturerIsNull() {\n"
+"        Car car = new Car(null, \"DD-AB-123\", 4);\n"
+"\n"
+"        Set&lt;ConstraintViolation&lt;Car&gt;&gt; constraintViolations =\n"
+"            validator.validate(car);\n"
+"\n"
+"        assertEquals(1, constraintViolations.size());\n"
+"        assertEquals(\"may not be null\", constraintViolations.iterator().next().getMessage());\n"
+"    }\n"
+"\n"
+"    @Test\n"
+"    public void licensePlateTooShort() {\n"
+"        Car car = new Car(\"Morris\", \"D\", 4);\n"
+"\n"
+"        Set&lt;ConstraintViolation&lt;Car&gt;&gt; constraintViolations = \n"
+"            validator.validate(car);\n"
+"\n"
+"        assertEquals(1, constraintViolations.size());\n"
+"        assertEquals(\"size must be between 2 and 14\", constraintViolations.iterator().next().getMessage());\n"
+"    }\n"
+"    \n"
+"    @Test\n"
+"    public void seatCountTooLow() {\n"
+"        Car car = new Car(\"Morris\", \"DD-AB-123\", 1);\n"
+"\n"
+"        Set&lt;ConstraintViolation&lt;Car&gt;&gt; constraintViolations =\n"
+"            validator.validate(car);\n"
+"\n"
+"        assertEquals(1, constraintViolations.size());\n"
+"        assertEquals(\"must be greater than or equal to 2\", constraintViolations.iterator().next().getMessage());\n"
+"    }\n"
+"\n"
+"    @Test\n"
+"    public void carIsValid() {\n"
+"        Car car = new Car(\"Morris\", \"DD-AB-123\", 2);\n"
+"\n"
+"        Set&lt;ConstraintViolation&lt;Car&gt;&gt; constraintViolations =\n"
+"            validator.validate(car);\n"
+"\n"
+"        assertEquals(0, constraintViolations.size());\n"
+"    }\n"
+"}"
 
 #. Tag: para
 #: gettingstarted.xml:139
 #, no-c-format
-msgid ""
-"In the <methodname>setUp()</methodname> method we get a "
-"<classname>Validator</classname> instance from the "
-"<classname>ValidatorFactory</classname>. A <classname>Validator</classname> "
-"instance is thread-safe and may be reused multiple times. For this reason we "
-"store it as field of our test class. We can use the <classname>Validator</"
-"classname> now to validate the different car instances in the test methods."
-msgstr ""
+msgid "In the <methodname>setUp()</methodname> method we get a <classname>Validator</classname> instance from the <classname>ValidatorFactory</classname>. A <classname>Validator</classname> instance is thread-safe and may be reused multiple times. For this reason we store it as field of our test class. We can use the <classname>Validator</classname> now to validate the different car instances in the test methods."
+msgstr "在<methodname>setUp()</methodname>方法中,我们通过<classname>ValidatorFactory</classname>得到了一个<classname>Validator</classname>的实例. <classname>Validator</classname>是线程安全的,并且可以重复使用, 所以我们把它保存成一个类变量. 现在我们可以在test方法中使用这个validator的实例来校验不同的car实例了."
 
 #. Tag: para
 #: gettingstarted.xml:147
 #, no-c-format
-msgid ""
-"The <methodname>validate()</methodname> method returns a set of "
-"<classname>ConstraintViolation</classname> instances, which we can iterate "
-"in order to see which validation errors occurred. The first three test "
-"methods show some expected constraint violations:"
-msgstr ""
+msgid "The <methodname>validate()</methodname> method returns a set of <classname>ConstraintViolation</classname> instances, which we can iterate in order to see which validation errors occurred. The first three test methods show some expected constraint violations:"
+msgstr "<methodname>validate()</methodname>方法会返回一个set的<classname>ConstraintViolation</classname>的实例的集合, 我们可以通过遍历它来查看有哪些验证错误. 前面三个测试用例显示了一些预期的校验约束:"
 
 #. Tag: para
 #: gettingstarted.xml:154
 #, no-c-format
-msgid ""
-"The <classname>@NotNull</classname> constraint on manufacturer is violated "
-"in <methodname>manufacturerIsNull()</methodname>"
-msgstr ""
+msgid "The <classname>@NotNull</classname> constraint on manufacturer is violated in <methodname>manufacturerIsNull()</methodname>"
+msgstr "在<methodname>manufacturerIsNull()</methodname>中可以看到manufacturer违反了<classname>@NotNull</classname>约束"
 
 #. Tag: para
 #: gettingstarted.xml:159
 #, no-c-format
-msgid ""
-"The <classname>@Size</classname> constraint on licensePlate is violated in "
-"<methodname>licensePlateTooShort()</methodname>"
-msgstr ""
+msgid "The <classname>@Size</classname> constraint on licensePlate is violated in <methodname>licensePlateTooShort()</methodname>"
+msgstr "<methodname>licensePlateTooShort()</methodname>中的licensePlate违反了<classname>@Size</classname>约束"
 
 #. Tag: para
 #: gettingstarted.xml:164
 #, no-c-format
-msgid ""
-"The <classname>@Min</classname> constraint on seatCount is violated in "
-"<methodname>seatCountTooLow()</methodname>"
-msgstr ""
+msgid "The <classname>@Min</classname> constraint on seatCount is violated in <methodname>seatCountTooLow()</methodname>"
+msgstr "而<methodname>seatCountTooLow()</methodname>中则导致seatCount违反了<classname>@Min</classname>约束"
 
 #. Tag: para
 #: gettingstarted.xml:169
 #, no-c-format
-msgid ""
-"If the object validates successfully, <methodname>validate()</methodname> "
-"returns an empty set."
-msgstr ""
+msgid "If the object validates successfully, <methodname>validate()</methodname> returns an empty set."
+msgstr " 如果一个对象没有校验出问题的话,那么<methodname>validate()</methodname> 会返回一个空的set对象."
 
 #. Tag: para
 #: gettingstarted.xml:172
 #, no-c-format
-msgid ""
-"Note that we only use classes from the package <package>javax.validation</"
-"package> from the Bean Validation API. As we don't reference any classes of "
-"the RI directly, it would be no problem to switch to another implementation "
-"of the API, should that need arise."
-msgstr ""
+msgid "Note that we only use classes from the package <package>javax.validation</package> from the Bean Validation API. As we don't reference any classes of the RI directly, it would be no problem to switch to another implementation of the API, should that need arise."
+msgstr "注意,我们只使用了Bean Validation API中的package <package>javax.validation</package>中的类, 并没有直接调用参考实现中的任何类,所以, 没有任何问题如果切换到其他的实现."
 
 #. Tag: title
 #: gettingstarted.xml:180
 #, no-c-format
 msgid "Where to go next?"
-msgstr ""
+msgstr "更进一步"
 
 #. Tag: para
 #: gettingstarted.xml:182
 #, no-c-format
-msgid ""
-"That concludes our 5 minute tour through the world of Hibernate Validator. "
-"Continue exploring the code examples or look at further examples referenced "
-"in <xref linkend=\"chapter-further-reading\"/>. To deepen your understanding "
-"of Hibernate Validator just continue reading <xref linkend=\"validator-"
-"usingvalidator\"/>. In case your application has specific validation "
-"requirements have a look at <xref linkend=\"validator-customconstraints\"/>."
-msgstr ""
+msgid "That concludes our 5 minute tour through the world of Hibernate Validator. Continue exploring the code examples or look at further examples referenced in <xref linkend=\"chapter-further-reading\"/>. To deepen your understanding of Hibernate Validator just continue reading <xref linkend=\"validator-usingvalidator\"/>. In case your application has specific validation requirements have a look at <xref linkend=\"validator-customconstraints\"/>."
+msgstr "在本章中, 您了解了一个基于Hibernate Validator的简单例子. 更多的示例请参考 <xref linkend=\"chapter-further-reading\"/>. 如果想进一步了解Hibenate Validator, 请继续阅读<xref linkend=\"validator-usingvalidator\"/>.  如果您的应用程序有特殊的校验需求,请参考 <xref linkend=\"validator-customconstraints\"/>."
+

Modified: validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/preface.po
===================================================================
--- validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/preface.po	2010-07-06 15:18:26 UTC (rev 19904)
+++ validator/trunk/hibernate-validator/src/main/docbook/zh-CN/modules/preface.po	2010-07-06 19:35:13 UTC (rev 19905)
@@ -6,8 +6,8 @@
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
 "POT-Creation-Date: 2010-07-06 14:46+0000\n"
-"PO-Revision-Date: 2010-07-06 14:46+0000\n"
-"Last-Translator: Automatically generated\n"
+"PO-Revision-Date: 2010-07-06 23:46+0830\n"
+"Last-Translator: Strong Liu <stliu at hibernate.org>\n"
 "Language-Team: none\n"
 "MIME-Version: 1.0\n"
 "Content-Type: text/plain; charset=UTF-8\n"
@@ -17,36 +17,23 @@
 #: preface.xml:25
 #, no-c-format
 msgid "Preface"
-msgstr ""
+msgstr "序言"
 
 #. Tag: para
 #: preface.xml:27
 #, no-c-format
-msgid ""
-"Validating data is a common task that occurs throughout any application, "
-"from the presentation layer to the persistence layer. Often the same "
-"validation logic is implemented in each layer, proving time consuming and "
-"error-prone. To avoid duplication of these validations in each layer, "
-"developers often bundle validation logic directly into the domain model, "
-"cluttering domain classes with validation code which is really metadata "
-"about the class itself."
-msgstr ""
+msgid "Validating data is a common task that occurs throughout any application, from the presentation layer to the persistence layer. Often the same validation logic is implemented in each layer, proving time consuming and error-prone. To avoid duplication of these validations in each layer, developers often bundle validation logic directly into the domain model, cluttering domain classes with validation code which is really metadata about the class itself."
+msgstr "数据校验是任何一个应用程序都会用到的功能,无论是显示层还是持久层. 通常,相同的校验逻辑会分散在各个层中, 这样,不仅浪费了时间还会导致错误的发生(译注: 重复代码). 为了避免重复, 开发人员经常会把这些校验逻辑直接写在领域模型里面, 但是这样又把领域模型代码和校验代码混杂在了一起, 而这些校验逻辑更应该是描述领域模型的元数据."
 
 #. Tag: para
 #: preface.xml:46
 #, no-c-format
-msgid ""
-"JSR 303 - Bean Validation - defines a metadata model and API for entity "
-"validation. The default metadata source is annotations, with the ability to "
-"override and extend the meta-data through the use of XML. The API is not "
-"tied to a specific application tier or programming model. It is specifically "
-"not tied to either the web tier or the persistence tier, and is available "
-"for both server-side application programming, as well as rich client Swing "
-"application developers."
-msgstr ""
+msgid "JSR 303 - Bean Validation - defines a metadata model and API for entity validation. The default metadata source is annotations, with the ability to override and extend the meta-data through the use of XML. The API is not tied to a specific application tier or programming model. It is specifically not tied to either the web tier or the persistence tier, and is available for both server-side application programming, as well as rich client Swing application developers."
+msgstr "JSR 303 - Bean Validation - 为实体验证定义了元数据模型和API. 默认的元数据模型是通过Annotations来描述的,但是也可以使用XML来重载或者扩展. Bean Validation API 并不局限于应用程序的某一层或者哪种编程模型, 例如,如图所示, Bean Validation 可以被用在任何一层, 或者是像类似Swing的富客户端程序中."
 
 #. Tag: para
 #: preface.xml:65
 #, no-c-format
 msgid "Hibernate Validator is the reference implementation of this JSR."
-msgstr ""
+msgstr "Hibernate Validator 是这个JSR的参考实现."
+



More information about the hibernate-commits mailing list