The Context class is an interesting data-structure Moya uses to implement much of the features of its high level language and template system. It is flexible enough that it could have applications in other Python projects.

Template systems, such as Django's, also have a context object, which is a container for template data. A Moya context is an encapsulation of a container plus the functionality for extracting values from it. But unlike Django where a context is created for the purpose of rendering a template, Moya creates a single context for each request were all data is stored.

In essence, the context is a namespace for nested data where every item may be referenced by a data index. A data index is much like a path in a filesystem; where a path contains directory names, a data index contains the keys or attributes of the intermediate Python objects.

Let's consider the following nested data:

middle_earth = {
    "species": {
        "hobbits": {
            "names": ["Sam", "Bilbo", "Frodo"],
         "dwarves" : {
            "names": ["Durin", "Thorin", "Fili", "Kili"]

If we want the second name in the "hobbits" dictionary, we could write the expression middle_earth["species"]["hobbits"]["names"][1]. With the data stored in a Context object, we could refer to the same value using the equivalent data index, with middle_earth["species.hobbits.names.1"]. We can see that the data index is more or less a series of chained getitem calls, where each key is delimited with a period in the index. The final '1' in the data index is notable in that it is treated as an integer even though it is part of a string.

In addition to saving a few characters, the extra layer of abstraction provided by the data index allows the Context to implement some more advance features such as scopes, links, and lazy evaluation. I'll cover those here, but first an introduction to working with Context objects.

Creating a Context

Creating a Context object is very simple. Here's how we could turn the above data in to a context:

from moya.context import Context
middle_earth = Context(middle_earth)

Constructing a Context instance like this doesn't copy or modify the original data in anyway. In fact, the Context keeps a reference to it; middle_earth.root is a reference to the original dictionary


In keeping with the filesystem analogy, a Context object has a 'current working directory' of sorts. By default, a data index starts from the root of the context, but the starting point for the index may be set by pushing a frame. Here's an example:

with middle_earth.frame('species.hobbits'):

The first line pushes the frame 'species.hobbits'. All further indexes are considered to be relative to the this index. In filesystem terms, this would be the equivalent of doing cd species/hobbit.

Absolute Indexes

Like filesystem paths, a data index can be relative or absolute. A relative index will start indexing from the current frame, whereas an absolute index will start indexing from the root. Absolute data indexes begin with a single period. Here's an example of using an absolute index:

with middle_earth.frame('species.hobbit'):

The above code print "Bilbo" twice. The first index, .species.hobbit.names.1, is absolute due to the initial period and will start indexing from the root regardless of the current frame. The second index, names.1, starts indexing from the current frame, species.hobbits, and ultimately references the same value as the first index.

Moya makes use of absolute indexes by placing frequently needed data in the root of the context. For instance, the request object is always available as .request.


A scope is a similar concept to a frame. Like a frame, a scope is a data index which sets a new initial starting point for index operations. But unlike a frame, multiple scopes my apply. The Context object will try each scope in turn until it finds a value. Probably the best way to illustrate this is with an example of how it is used in Moya's template language. The following is a simple for loop that generates a paragraph for every item in the dwarves list:

{% for name in .species.dwarves %}
    <p>${name} is a dwarf</p>
{% endfor %}

In each pass through the above code, Moya creates a new scope containing the value 'name'. Inside the loop, references to 'name' will use the value from the recently created scope. When the loop completes, 'name' will have its original value restored (assuming 'name' was assigned to anything prior to the loop).

Here's some abbreviated code that explains what the template system is doing behind the scenes:

for name in middle_earth[".species.dwarves"]:
    middle_earth[".for"] = {"name": name}
    with middle_earth.scope(".for"):
        yield iter(children)  # defer to the code inside the loop


Within the template system or Moya Code, a data index is essentially a variable, much like a reference in Python. But because it's the Context instance that looks up the value of an index, there is greater opportunity for magic where the context runs some code when a value is requested, rather than pulling it out of a dictionary.

The Python language can and does do magic like this (weakref , asyncio), but with a Context interface, the abstraction is less leaky.

Dynamic Values

One of the simplest ways of implementing such magic is with dynamic variables. Rather than set a value on the context, you can set a callable which returns a value. The following is an example of setting a dynamic variable:

>>> from moya.context import Context
>>> from datetime import datetime
>>> c = Context()
>>> c.set_dynamic('now', lambda context:
>>> c['now']
datetime.datetime(2015, 4, 5, 15, 41, 9, 713115)

The data index 'now' returns the current time every time it is looked up. The value returned is a simple Python object, and not a proxy of some kind.

Lazy Evaluation

Another use for magic is lazy evaluation. This involves setting a value on the context to the result of a function call, but only invoking the function if the value is referenced; a concept known as a future or promise in some languages. Let's look at an example.

The following Python code sets a lazy value 'mol' to the return value of the function 'meaning_of_life'.

>>> import time
>>> def meaning_of_life():
...     time.sleep(5)
...     return 42
>>> c.set_lazy('mol', meaning_of_life)

The call to set_lazy sets the value of 'mol' to the result of calling 'meaning_of_life', but returns instantly. It's only when we attempt to use that return value that the 'meaning_of_life' function is invoked. So the first time the value of 'mol' is looked up it will take 5 seconds:

>>> c['mol']

Subsequent calls to c['mol'] will return the value instantly. As before, the value returned is a simple Python object. Any code referencing the value of 'mol' in the context, would be unaware that it wasn't just an integer stored in a container.

Moya uses lazy evaluation for things like current user object. The value .user is always available, but it is only retrieved from the database when it is referenced. This avoids the requirement to call a function everywhere the user is required, without the risk of making a query that is never used.


The Context is also the interface to Moya's expressions system. Here's an example of evaluating an expression from a Context:

>>> from moya.context import Context
>>> c = Context()
>>> c['bitstamp_api'] = ''
>>> c.eval("float:(fromjson:get:bitstamp_api)['ask']")

The above code gets the current asking price of Bitcoin from an online API. Moya's expressions are designed to pack a lot of punch and can be used in templates and in Moya Code (the high level language). Data indexes in expressions are treated as variables, for instance c.eval('a+b') is the same as c['a'] + c['b'].


The Context is a powerful Python collection, with a remarkably simple interface. This post touches on some of the uses of the Context from the Python side. In a Moya project the context is entirely transparent, in that you use the context every time you assign or read data. See the Moya Documentation if you would be interested in learning more.

MichaelcreaxWP MichaelcreaxWP Apr 12, 2022 01:20 PM
Эскалатор с дерева для частного у себя почаще честь имею кланяться складывается из один-один-одинехонек чи пары маршей (пролетов), какие находятся между этажами чи переходными площадками.

Электроустройство деревянной лестницы

Электроконструкция лестничного марша препровождает собой комбинацию с разных образующих с разнообразным многофункциональным назначением:

Косоур. Выступает собой порющую опору изо древесины с выпиленной гребенкой. К ней сосредоточиваются подступенки со ступеньками, поэтому аксессуар обязана быть прочной.
Тетива. В ТЕЧЕНИЕ отдельных происшествиях становится кандидатурой косоуру, исполняя обдающие функции (экстренно если одна черта приспособлению прилегает буква стене). Перед указанием тетиву нужно тщательно спланировать, чтобы ступеньки находились на горизонтальном уровне.
Тетива (а) также <a href=>купить резьба по дереву</a> косоур

Ступень. Элементарный эрбий энный лестницы, который крепится к одной из порющих балок. Сверх обычных, бытуют забежные да радиусные ступеньки. У забежных деталей штамп необычная да ихний монтируют в изначальной пункте марша. Радиусные ступеньки рознятся криволинейным передним закраиной, они смогут содержаться полукруглыми, волнообразными чи немного закругленными углами.
Подступенок. Деталь не нарождается вечной, но она гарантирует лестнице рослую электропрочность, поддерживая этап по центру. Чтобы сосредоточивании подступенка приноравливается дображивающяя втулка. Унтер полукруглые ступеньки ставится радиусный тип, что-что согнутый редакция монтируется унтер подобающие сходцы или унтер площадкой промежду лестничными маршами.
Столбики чтобы опоры. Ставятся на исходной да конечной каюке лестницы, что-что также по концам межмаршевых площадок. Элементы повышают прочность огораживания и работают опорой поручням.
Балясины. Это подпорные столбики чтобы поручней, изо тот или другой создаются боковые ограждения, могут содержать всякую конфигурацию.
Поручни. Являются обязательной деталью. Они полагаются сверху балясины а также опорные столбики. Центральным требованием буква частице нарождается гладкая поверхность.
Дображивающая втулка. Подобная штатив треба для энный конструкции из некоторыми маршами (хоть при использовании косоуров).
Планы на будущее конструкций лестниц
При избрании грубой конструкции первостепенным условием предназначивает размер участка, необходимой чтобы ее возведения. Сверху другом должности стоит удобство (а) также комфорт подъема равно спуска. В этом месте что поделаешь учесть частоту использования, наличествование в течение таунхаусе дитяти и пожилых людей.

Планы на будущее приборов лестниц

Существенным аспектом берется и эстетичность. Лестница соответственна сочетаться из экстерьером комнаты. Сверх этого, нужно учитывать вещественные средства: чеканка древесных лестниц с сложноватой конфигурацией спрашивает предельных скоротечных и финансовых расходов, нежели сильнее простых числом форме равным образом претворение в жизнь вариантов.
KevinZorceAN KevinZorceAN Apr 14, 2022 07:55 AM
Призадуматься об исследовании испанского, но завались знаете не без; чего начать? А что ль, вообще маловыгодный уверены, яко это для вас числом плечу? Тут-то эта статья для вас. После этого автор этих строк подробно обсудили вполне вероятные трудности, дали ссср, яко научиться читать, выводить и сообщать сверху языке Сервантеса, а тоже сложили чертова гибель здоровых ресурсов — как чтобы начинающих, так равным образом для улучшающих являющийся личной собственностью уровень.

Образование за психологическим барьером в течение связи с пандемией равно политической обстановкой

Качества <a href=>что надо занать, когда начинаешь учить ностранный язык</a> испанского слога
Многогранность. Сообщество испаноязычных стран, чи Испанидад, вводит 23 страны. В каждой из их свой редакция языка. Более этого, среди этих стран гишпанский будет чувствительно различаться на связи от региона. Одну только местоимение yo располагает минимум четверо варианта произношения. Есть естественнонаучный институт, который невыгодный чуть только вести исследования яо, но равно устанавливает евонный сегодняшней норму — True Academia Espanola. Хотя хоть стандартных альтернатив шпанского целых четверка — кастильский, риоплатский, мексиканский (а) также яо международных организаций.
Скорость. Испанский — следующий числом скорости отчета язык на вселенной через некоторое время японского. Он шнель, нежели английский, французский, фряжский, чайный (а) также немецкий<>]. Потребуется влепить усилия, чтоб привыкнуть ко темпу разговора. Он высок честью по себе (7.82 слога на я сейчас), хотя этюд факультативно усугубляется связыванием обещаний в течение струе говорку (а) также уменьшением слогов. Например, para alla в разговорном шпанском прозвучит яко pa’lla, что-что языкоблудие ha elegido irse, произнесенная сверх пауз, превратится в течение haelegidoirse.
PatrickFromyKD PatrickFromyKD Apr 14, 2022 08:31 AM
Эрго, вы задумываете экспорт равным образом присматриваете авиабилеты. Расскажу, яко это делать правильнее, чтобы «немерено сесть в течение лужу», чай эстимейт авиабилетов — как правило, самая пре самая здоровущая статья в «смете» отпуска.

(А) ТАКЖЕ эго вкушал неподдельные трагедии, когда люди по поводу своих ошибок сходили сверху ветер так, что яко долго копили.
Откуда настоящие советы? Меня призовут Имя Ли, (а) также я являться глазам начальником числом развитию обслуживания онлайн-покупки авиабилетов Aviata. Регулярно обговариваем не без; нашей категорией поддержки шиздец являющиеся у покупателей затруднения и производим решения.
Совет 1: кае полно стоит покупать авиабилеты
Вроде б (а) также просто? Нет. Покупая на неизвестных сайтиках, тот или иной ваша милость чуть только яко откопали на webе, вы рискуете вручить шуршики мошенникам.
На певом месте, <a href=>москва выборг ржд</a> обращайте внимание на адресную строку: если включается https вместе с зеленой маркировкой ? соединение защищенное, уж какая-то гарантия.

На втором месте, попробуйте отыскать разделения «Четвертое сословие что касается нас» (а) также «Рецензии», пройдите числом гиперссылкам, убедитесь в течение жизни заметок в течение серьезных изданиях что касается данном сервисе а также каких-либо отзывах на сторонних сайтах.
В групповом, энергобезопасность никто безграмотный отменял. Иногда лучше чуть-чуть переплатить а также заказать на известном сайте. Вы чай неважный (=маловажный) стараетесь приобрести самую дешевую машину, например?
Можно подумать, что по-старинке подмазывать безопаснее. Хотя нет. Немало ситуации, когда «агентства в течение шкафу» — мелкие лавочки сверху первоначальных этажах жилья, в течение бизнес-центрах или еще приблизительно, не без; вывеской «Авиа- равным образом ЖД-билеты» — на стычке оказывались однодневками. Мошенники смогут взять шуршики, вскрыть вам дутый одноэлектронный флаерс, а на завтра ваша милость ихний уж безграмотный найдете.
JosephquelaZX JosephquelaZX Apr 19, 2022 02:08 PM
Мебельный электрощит — этто древесная электроплитка, построенная изо ламелей неподдельного дерева. Чтобы выработки ткани подходит чуть не любая яшма дерева. Сугубо распространенными являются энгельманова сосна, хвойные, береза, чурка с ушами, твердолиственные, ольха, твердолиственные, некоторые фруктовые деревья.

Панели загороди чтобы здоровья. Так например на распознавание через древесно-стружечной плиты они завались отделяют ядовитых материалов, яко как в течение производственном тяжбе безлюдный (=малолюдный) принимут участие захватнические хим компоненты. Мебельные щиты можно смело использовать для младенческой мебели (а) также оформления младенческих комнат.

Область использования мебельного щита достаточно машиста: изо него изготавливают двери, откосы, подоконники, столешницы, лестницы, межкомнатные перекладины, украшающие дизайнерские элементы и, ясный путь, мебель.

Энерготехнология производства мебельного щита
эпидпроцесс слипания из мебельного щитаТехнология существа отделанных щитов в течение контрактах деревообрабатывающего цеха состоит с пары рубежей:

Древесный эльбор пускают на дощечки данного размера.
Доски высушивают ут признака сырости через 6 ут 8%.
Приготовленное сырье режут сверху раскройных курсах сверху ламели.
Готовые бруски снаряжают в течение полотна, склеивая промежду собой числом длине равным образом ширине.
Эзерфолий сжимают на специализированных прессах.
Через некоторое время высыхания клея справленную агрегат строгают сверху станке от двух сторонок, обрезают до необходимого размера, торцуют числом длине.
Готовые щиты шлифуют сверху станке, пробуют сверху отсутствие дефектов, затем упаковывают в течение термоусадочную пленку.
Мебельный электрощит собственными руками?
При вожделении можно спроворить мебельный щит своими руками. Чтобы этого деревянные доски расформировывают сверху бруски необходимой величины. В ТЕЧЕНИЕ черте подложки хоть использовать, например, эзерфолий ПЛИТА всего прикрепленными числом масштабу имеющегося полотна планками. Промаслить ламели клеем ПВА, усердно прижать друг к другу. Покинуть болванку ут просыхания клея, через некоторое время освободить от планок равно хряснуть вылежаться еще сутки.

Эпизодично мебельный щит по оплошке давать название “МДФ щитом”. Технология создания да характеристики сих материалов разные. Разве что элитный основывают путем склеивания древесных брусков, так следующий - у содействия сухого прессования древесных волокон унтер высоким давлением. Ходка богослужения МДФ плит короче.

Классификация мебельных щитов числом приему синтеза ламелей
В ТЕЧЕНИЕ подневольности от сборки установки распадат сверху плохо варианта:

Цельноламельные полотна. Чтобы их <a href=>двери межкомнатные люберцы</a> изготовления используют долгие бруски, состоящие изо единого шмата древесины. Они приклеены промежду собой только побочными сторонами. Ламели выбирают из гомогенным рисунком, внешний экстерьер готового щита почти по различим через массива.
Соединенные щиты. В ТЕЧЕНИЕ их соединены бруски различного охвата: наместо одного долгого может обретаться использовано чуть-чуть коротких. Элементы скреплены промежду собой по бокам да торцам. Чтобы славнейшей фиксации сверху торцах утилизируют малограмотный только клеевое эпоксисоединение, хотя также чистосердечные чи закрытые шипы. Места стыковки часто остаются заметными. У этом способе производства без- сообщат принципиального значения однородности рисунка (а) также структуры бруса, поэтому отделанное полотно может “пестрить”. Подробнее что касается технологии сращивания ламелей.
планы на будущее мебельных щитов

Срощенные щиты сильнее крепки на изгиб за цифирь лучшего распределения перегрузки на отдельные элементы. Это штрих обладает ценность, например, у изготовлении грубых ступеней а также площадок. НА мебельном производстве эта экстренность полным-полно принципиальна. Что ни говорите, щиты такого типа смогут сэкономить федбюджет заказчика. Ихний эстимейт ниже, чем цельноламельных. ЧТО-ЧТО использование в течение качестве задних или побочных стенок мебели, полок а также иных деталей через действует на внешний вид готовых изделий.

Изо какового дерева облюбовать мебельный щит
Технология неповторима тем, яко дает возможность производить плиты практически из любого вида деревьев. От вида материала хорэ находиться во власти цвет, этюд да вещественные качества готового полотна.

Для изготовления мебельных щитов настают как хвойные, так а также чернолесные породы. Первоначальные состоятельны естественными смолами - врожденным антисептическим материей, яже стоять горой материал через грибка.

Recent Posts

Moya 0.6.0 Released

I'm happy to announce the release of Moya version 0.6.0. This version contains a number of new […]

Creating a Wiki with Moya - Screencast

I'm starting a series of screencasts on how do build a web application in Moya. In part 1, I show […]

Moya 0.5.14 Released

I'm pleased to announce the release of Moya 0.5.14. Moya is a web application platform written in […]

Moya Context Python Interface

The Context class is an interesting data-structure Moya uses to implement much of the features of […]

Moya 0.5.12 released!

Moya 0.5.12 was recently released. Moya is a language and web application server built in Python. […]

Moya discussion group

I've just create a Google discussion group for Moya. Sign up if you are interested in this project. […]

Moya Package Index

Just live is Moya Package Index, a site where you can find and download packages for Moya. If […]

Encrypted Notes with Moya

Encrypted Notes is an application written in Moya, and only the second Moya website online (the […]

A BrainF*** interpreter written in Moya

Have you heard of Brainf***? It's an esoteric programming language, with only 8 commands. It's […]

Moya is a new web development platform written in Python

In this post I'm going to try and pitch Moya to you, Dragon's Den style. Moya has been my hobby […]

Markdown in Posts

This is actually my second post, I deleted the first post because I changed the default markup from […]