| <html devsite> |
| <head> |
| <meta name="project_path" value="/_project.yaml"> |
| <meta name="book_path" value="/versions/6.1.0/_book.yaml"> |
| </head> |
| <body> |
| |
| <h1 class="page-title" id="modules.TemplateVariableInfo">TemplateVariableInfo</h1> |
| |
| <!-- {% raw %} --> |
| |
| Encapsulates template variables, that is, variables that can be referenced by strings like <code>$(VARIABLE)</code> in BUILD files and expanded by <code>ctx.expand_make_variables</code> and implicitly in certain attributes of built-in rules.</p><p><code>TemplateVariableInfo</code> can be created by calling its eponymous constructor with a string-to-string dict as an argument that specifies the variables provided.</p><p>Example: <code>platform_common.TemplateVariableInfo({'FOO': 'bar'})</code></p> |
| |
| <h2>Members</h2> |
| <ul> |
| <li> |
| <a href="#to_json">to_json</a> |
| </li> |
| <li> |
| <a href="#to_proto">to_proto</a> |
| </li> |
| <li> |
| <a href="#variables">variables</a> |
| </li> |
| </ul> |
| |
| <h2 id="to_json">to_json</h2> |
| <p><pre class="rule-signature"><a class="anchor" href="string.html">string</a> TemplateVariableInfo.to_json()</pre></p> |
| |
| <b>Deprecated</b>. This API is deprecated and will be removed soon. Please do not depend on it. It is <i>disabled</i> with <code>---incompatible_struct_has_no_methods</code>. Use this flag to verify your code is compatible with its imminent removal. <br>Creates a JSON string from the struct parameter. This method only works if all struct elements (recursively) are strings, ints, booleans, other structs, a list of these types or a dictionary with string keys and values of these types. Quotes and new lines in strings are escaped. Examples:<br><pre class=language-python>struct(key=123).to_json() |
| # {"key":123} |
| |
| struct(key=True).to_json() |
| # {"key":true} |
| |
| struct(key=[1, 2, 3]).to_json() |
| # {"key":[1,2,3]} |
| |
| struct(key='text').to_json() |
| # {"key":"text"} |
| |
| struct(key=struct(inner_key='text')).to_json() |
| # {"key":{"inner_key":"text"}} |
| |
| struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_json() |
| # {"key":[{"inner_key":1},{"inner_key":2}]} |
| |
| struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_json() |
| # {"key":{"inner_key":{"inner_inner_key":"text"}}} |
| </pre>.<p>Deprecated: instead, use json.encode(x) or json.encode_indent(x), which work for values other than structs and do not pollute the struct field namespace. |
| |
| |
| <h2 id="to_proto">to_proto</h2> |
| <p><pre class="rule-signature"><a class="anchor" href="string.html">string</a> TemplateVariableInfo.to_proto()</pre></p> |
| |
| <b>Deprecated</b>. This API is deprecated and will be removed soon. Please do not depend on it. It is <i>disabled</i> with <code>---incompatible_struct_has_no_methods</code>. Use this flag to verify your code is compatible with its imminent removal. <br>Creates a text message from the struct parameter. This method only works if all struct elements (recursively) are strings, ints, booleans, other structs or dicts or lists of these types. Quotes and new lines in strings are escaped. Struct keys are iterated in the sorted order. Examples:<br><pre class=language-python>struct(key=123).to_proto() |
| # key: 123 |
| |
| struct(key=True).to_proto() |
| # key: true |
| |
| struct(key=[1, 2, 3]).to_proto() |
| # key: 1 |
| # key: 2 |
| # key: 3 |
| |
| struct(key='text').to_proto() |
| # key: "text" |
| |
| struct(key=struct(inner_key='text')).to_proto() |
| # key { |
| # inner_key: "text" |
| # } |
| |
| struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_proto() |
| # key { |
| # inner_key: 1 |
| # } |
| # key { |
| # inner_key: 2 |
| # } |
| |
| struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_proto() |
| # key { |
| # inner_key { |
| # inner_inner_key: "text" |
| # } |
| # } |
| |
| struct(foo={4: 3, 2: 1}).to_proto() |
| # foo: { |
| # key: 4 |
| # value: 3 |
| # } |
| # foo: { |
| # key: 2 |
| # value: 1 |
| # } |
| </pre><p>Deprecated: use proto.encode_text(x) instead. |
| |
| |
| <h2 id="variables">variables</h2> |
| <p><pre class="rule-signature"><a class="anchor" href="dict.html">dict</a> TemplateVariableInfo.variables</pre></p> |
| |
| Returns the make variables defined by this target as a dictionary with string keys and string values |
| |
| |
| |
| </body> |
| </html> |
| |
| <!-- {% endraw %} --> |