Skip to content
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

Translate appcontext #43

Merged
merged 6 commits into from
Jan 23, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
### docs/

- [x] advanced_foreword [@rosekc](https://github.com/rosekc) rosekc
- [ ] appcontext [@rosekc](https://github.com/rosekc) rosekc
- [x] appcontext [@rosekc](https://github.com/rosekc) rosekc
- [ ] async-await [@rosekc](https://github.com/your_username) rosekc
- [ ] becomingbig [@yuxiaoy1](https://github.com/yuxiaoy1) Frank Yu
- [x] blueprints [@frostming](https://github.com/frostming) Frost Ming
Expand Down
72 changes: 62 additions & 10 deletions docs/locales/zh_CN/LC_MESSAGES/appcontext.po
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# SOME DESCRIPTIVE TITLE.
# Copyright (C) 2010 Pallets
# This file is distributed under the same license as the Flask package.
# FIRST AUTHOR <EMAIL@ADDRESS>, 2021.
# rosekc <rose-kc@hotmail.com>, 2021.
#
#, fuzzy
msgid ""
Expand All @@ -10,7 +10,7 @@ msgstr ""
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2021-05-25 19:31+0800\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Last-Translator: rosekc <rose-kc@hotmail.com>\n"
"Language-Team: zh_CN <withlihui@gmail.com>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=utf-8\n"
Expand All @@ -19,7 +19,7 @@ msgstr ""

#: ../../appcontext.rst:4
msgid "The Application Context"
msgstr ""
msgstr "应用上下文"

#: ../../appcontext.rst:6
msgid ""
Expand All @@ -28,17 +28,22 @@ msgid ""
"application around to each function, the :data:`current_app` and "
":data:`g` proxies are accessed instead."
msgstr ""
"应用上下文在请求、命令行命令以及其他活动期间保持对应用层面数据的追踪。相"
"比起将应用上下文传递到每个函数当中,Flask 使用了 :data:`current_app` 和 :"
"data:`g` 这两个代理对象来访问应用上下文。"

#: ../../appcontext.rst:11
msgid ""
"This is similar to the :doc:`/reqcontext`, which keeps track of request-"
"level data during a request. A corresponding application context is "
"pushed when a request context is pushed."
msgstr ""
"这与在请求当中跟踪请求层面数据的 :doc:`/reqcontext` 类似。在一个请"
"求上下文被推入线程局部栈时,对应的应用上下文也被推入。"

#: ../../appcontext.rst:16
msgid "Purpose of the Context"
msgstr ""
msgstr "上下文的目的"

#: ../../appcontext.rst:18
msgid ""
Expand All @@ -50,30 +55,41 @@ msgid ""
"writing reusable :doc:`blueprints </blueprints>` or :doc:`extensions "
"</extensions>` there won't be an ``app`` instance to import at all."
msgstr ""
":class:`Flask` 应用对象所拥有的属性(attributes),如 :attr:`~Flask.config`,"
"在视图函数与 :doc:`CLI 命令 </cli>` 中会用到。然而,在项目的模块里导入"
"(import) ``app`` 可能会带来循环导入的问题。当使用 :doc:`应用工厂模式 </"
"patterns/appfactories>` 、编写可重用的 :doc:`蓝图 </blueprints>` 或者 :"
"doc:`扩展 </extensions>`,``app`` 实例将完全无法被导入。"

#: ../../appcontext.rst:27
msgid ""
"Flask solves this issue with the *application context*. Rather than "
"referring to an ``app`` directly, you use the :data:`current_app` proxy, "
"which points to the application handling the current activity."
msgstr ""
"Flask 使用 *应用上下文* 来解决这个问题。在这种情况下,使用指向当前活动的"
"应用对象的代理 :data:`current_app` ,而不是直接引用 ``app``。"

#: ../../appcontext.rst:31
msgid ""
"Flask automatically *pushes* an application context when handling a "
"request. View functions, error handlers, and other functions that run "
"during a request will have access to :data:`current_app`."
msgstr ""
"Flask 在处理请求时候会自动 *推入* 一个应用上下文。视图函数、错误处理器、还"
"有其他在请求中运行的函数将可以访问 :data:`current_app`。"

#: ../../appcontext.rst:35
msgid ""
"Flask will also automatically push an app context when running CLI "
"commands registered with :attr:`Flask.cli` using ``@app.cli.command()``."
msgstr ""
"运行使用 ``@app.cli.command()`` 注册到 :attr:`Flask.cli` 的命令行命令,Flask "
"也会自动推入应用上下文。"

#: ../../appcontext.rst:40
msgid "Lifetime of the Context"
msgstr ""
msgstr "上下文的生命周期"

#: ../../appcontext.rst:42
msgid ""
Expand All @@ -83,22 +99,29 @@ msgid ""
" it pops the request context then the application context. Typically, an "
"application context will have the same lifetime as a request."
msgstr ""
"应用上下文会在必要的时候创建以及销毁。当 Flask 应用准备处理一个请求时,将"
"推入一个应用上下文以及 :doc:`请求上下文 </reqcontext>`。当请求结束的时候,弹出"
"应用上下文以及请求上下文。通常来说,一个应用上下文与请求上下文拥有一致"
"的生命周期。"

#: ../../appcontext.rst:49
msgid ""
"See :doc:`/reqcontext` for more information about how the contexts work "
"and the full life cycle of a request."
msgstr ""
"关于上下文的工作原理以及请求的完整生命周期的更多信息,参见 :doc:`/reqcontext`。"

#: ../../appcontext.rst:54
msgid "Manually Push a Context"
msgstr ""
msgstr "手动推入一个上下文"

#: ../../appcontext.rst:56
msgid ""
"If you try to access :data:`current_app`, or anything that uses it, "
"outside an application context, you'll get this error message:"
msgstr ""
"若在应用上下文之外的地方尝试访问 :data:`current_app` ,或在任何"
"使用此对象的情况下,会收到这样的错误信息:"

#: ../../appcontext.rst:67
msgid ""
Expand All @@ -108,17 +131,22 @@ msgid ""
"``with`` block, and everything that runs in the block will have access to"
" :data:`current_app`. ::"
msgstr ""
"如果在配置应用的时候(如初始化扩展)看到这样的错误信息,可以手动推入一个上下"
"文以访问 ``app``。在 ``with`` 语句中使用 :meth:`~Flask."
"app_context` 上下文管理器对象,所有在块内的运行的代码将可以访问 :data:`current_app`:"

#: ../../appcontext.rst:81
msgid ""
"If you see that error somewhere else in your code not related to "
"configuring the application, it most likely indicates that you should "
"move that code into a view function or CLI command."
msgstr ""
"如果你在配置应用以外场景遇到这个错误,绝大多数情况下意味着这些代码应该转移到"
"视图函数以及命令行命令下。"
FesonX marked this conversation as resolved.
Show resolved Hide resolved

#: ../../appcontext.rst:87
msgid "Storing Data"
msgstr ""
msgstr "存储数据"

#: ../../appcontext.rst:89
msgid ""
Expand All @@ -127,6 +155,9 @@ msgid ""
"purpose. It is a simple namespace object that has the same lifetime as an"
" application context."
msgstr ""
"在请求中或者命令行命令里,应用上下文是存储通用数据的好地方。"
"Flask 为此提供了 :data:`g 对象<g>` 。这是一个简单的命名空间对象,"
"与应用上下文有同样的生命周期。"

#: ../../appcontext.rst:95
msgid ""
Expand All @@ -136,45 +167,57 @@ msgid ""
"requests. Use the :data:`session` or a database to store data across "
"requests."
msgstr ""
"``g`` 表示 “global”(全局)的意思,这也意味着数据 *在上下文中* 是属于全局的。"
"在上下文结束的时候, ``g`` 对象中的数据会丢失,因此这不是请求之间存放数据的好地方。"
"这时候可以使用 :data:`session` 或者数据库来存放跨请求的数据。"

#: ../../appcontext.rst:101
msgid "A common use for :data:`g` is to manage resources during a request."
msgstr ""
msgstr "一种使用 :data:`g` 的常见场景是管理一个请求中的资源。"

#: ../../appcontext.rst:103
msgid ""
"``get_X()`` creates resource ``X`` if it does not exist, caching it as "
"``g.X``."
msgstr ""
"``get_X()`` 在资源 ``X`` 不存在的时候创建了资源 ``X``,将其缓存到 ``g.X``。"

#: ../../appcontext.rst:105
msgid ""
"``teardown_X()`` closes or otherwise deallocates the resource if it "
"exists. It is registered as a :meth:`~Flask.teardown_appcontext` handler."
msgstr ""
"``teardown_X()`` 在资源存在的时候关闭或者释放它。函数被注册为 :meth:`~Flask."
"teardown_appcontext` 钩子函数。"

#: ../../appcontext.rst:109
msgid "For example, you can manage a database connection using this pattern::"
msgstr ""
msgstr "例如,可以使用以下方式来处理数据库连接:"

#: ../../appcontext.rst:126
msgid ""
"During a request, every call to ``get_db()`` will return the same "
"connection, and it will be closed automatically at the end of the "
"request."
msgstr ""
"在请求当中,所有调用 ``get_db()`` 的地方均会返回一样的连接,而这个连接会在请"
"求结束的时候自动关闭。"

#: ../../appcontext.rst:130
msgid ""
"You can use :class:`~werkzeug.local.LocalProxy` to make a new context "
"local from ``get_db()``::"
msgstr ""
"通过 :class:`~werkzeug.local.LocalProxy` 可以从 ``get_db()`` 创建一个新的上下"
"文本地变量:"

#: ../../appcontext.rst:136
msgid ""
"Accessing ``db`` will call ``get_db`` internally, in the same way that "
":data:`current_app` works."
msgstr ""
"访问 ``db`` 会内部调用 ``get_db``,就像访问 :data:`current_app` 的调用机制一"
"样。"

#: ../../appcontext.rst:141
msgid ""
Expand All @@ -184,21 +227,30 @@ msgid ""
":data:`_app_ctx_stack.top <_app_ctx_stack>`. For more information see "
":doc:`/extensiondev`."
msgstr ""
"在编写扩展的过程当中,:data:`g` 应该为用户代码保留。扩展的内部数据应该存储在上下文"
"对象的属性当中,除此以外还要保证使用一个足够独特的属性名称。当前的上下文"
"可以通过 :data:`_app_ctx_stack.top <_app_ctx_stack>` 获取。"
"更多信息参见 :doc:`/extensiondev`。"

#: ../../appcontext.rst:149
msgid "Events and Signals"
msgstr ""
msgstr "事件与信号"

#: ../../appcontext.rst:151
msgid ""
"The application will call functions registered with "
":meth:`~Flask.teardown_appcontext` when the application context is "
"popped."
msgstr ""
"在应用上下文被弹出的时候,应用会调用注册在 :meth:`~Flask."
"teardown_appcontext` 的函数。"

#: ../../appcontext.rst:155
msgid ""
"If :data:`~signals.signals_available` is true, the following signals are "
"sent: :data:`appcontext_pushed`, :data:`appcontext_tearing_down`, and "
":data:`appcontext_popped`."
msgstr ""
"如果 :data:`~signals.signals_available` 为真,下列信号将被发送::data:"
"`appcontext_pushed`、:data:`appcontext_tearing_down`、以及 :data:"
"`appcontext_popped`."