Skip to main content

Disable specific ZCML directives in other package's configuration

Project description

Documentation

Introduction

This package allows you to disable specific bits of ZCML configuration that may occur in other packages. For instance, let’s consider a simple ZCML directive that prints strings and a silly one that prints lolcat messages:

>>> zcml("""
... <print msg="Hello World!" />
... <lolcat who="I" canhas="cheezburger" />
... """)
Hello World!
I can has cheezburger?

Now let’s say this directive were used a bunch of times, but we wanted to prevent one or two of its occurrences. To do that we simply repeat the directive inside the unconfigure grouping directive. This grouping directive will look at all the previous directives and filter out the ones we want to exclude:

>>> zcml("""
... <configure>
...   <print msg="Hello World!" />
...   <lolcat who="I" canhas="cheezburger" />
...   <print msg="Goodbye World!" />
...   <print msg="LOL!" />
...
...   <include package="z3c.unconfigure" file="meta.zcml" />
...   <unconfigure>
...     <lolcat who="I" canhas="cheezburger" />
...     <print msg="LOL!" />
...   </unconfigure>
... </configure>
... """)
Hello World!
Goodbye World!

If you’re trying to unconfigure something that hasn’t been configured in the first place, nothing will happen:

>>> zcml("""
... <configure>
...   <include package="z3c.unconfigure" file="meta.zcml" />
...   <unconfigure>
...     <lolcat who="I" canhas="cheezburger" />
...   </unconfigure>
... </configure>
... """)

Where to place “unconfiguration”

What’s a good place to add the unconfigure directives, you may ask. Certainly, the example from above is not very realistic because both the original directives and the filters are in one file. What typically happens is that you have some third party package that has much configuration of which you’d like to disable just one or two directives. Like this file, for instance:

>>> cat('lolcat.zcml')
<configure>
  <print msg="Hello World!" />
  <print msg="Important configuration here." />
  <lolcat who="I" canhas="cheezburger" />
  <print msg="Goodbye World!" />
  <print msg="LOL!" />
  <print msg="This is the last directive" />
</configure>

What you can do now is write a separate ZCML file in your package. A good name for it would be overrides.zcml (which is the naming convention for ZCML files containing overriding directives, a technique not unlike to what unconfigure does). For example, let’s say we wanted to undo some silly configuration in the above third party file:

>>> cat('overrides.zcml')
<configure>
  <include package="z3c.unconfigure" file="meta.zcml" />
  <unconfigure>
    <lolcat who="I" canhas="cheezburger" />
    <print msg="LOL!" />
  </unconfigure>
</configure>

What you would do now is include first that third party package’s configuration and then load your overrides (which is typically done using includeOverrides, either explicitly by you or for you by site.zcml):

>>> zcml("""
... <configure>
...   <include file="lolcat.zcml" />
...   <includeOverrides file="overrides.zcml" />
... </configure>
... """)
Hello World!
Important configuration here.
Goodbye World!
This is the last directive

In this case, simply including the file with the <include /> directive would’ve sufficed as well. What matters is that the “unconfiguration” happens after the original configuration, and override files are a good place to ensure this.

It can also be conveniend to unconfigure an entire zcml file. This can be done without using z3c.unconfigure, if you use the <exclude /> directive before you include that file:

>>> zcml("""
... <configure>
...   <exclude file="lolcat.zcml" />
...   <print msg="The new hello" />
...   <include file="lolcat.zcml" />
...   <include package="z3c.unconfigure" file="meta.zcml" />
...   <print msg="The final goodbye" />
... </configure>
... """)
The new hello
The final goodbye

Or you can try to use an include statement inside an unconfigure block:

>>> zcml("""
... <configure>
...   <print msg="The new hello" />
...   <include file="lolcat.zcml" />
...   <include package="z3c.unconfigure" file="meta.zcml" />
...   <unconfigure>
...     <include file="lolcat.zcml" />
...   </unconfigure>
...   <print msg="The final goodbye" />
... </configure>
... """)
The new hello
The final goodbye

Changes

2.1 (2024-10-16)

  • Add support for Python 3.12, 3.13.

  • Drop support for Python 3.7.

2.0 (2023-02-10)

  • Drop support for Python < 3.7.

  • Add support for Python 3.7, 3.8, 3.9, 3.10, 3.11.

1.1 (2012-10-26)

  • Added support for zope.configuration 3.8.0, which changed the internal data structures from tuples to dicts.

  • Dropped support for zope.configuration 3.7.x and older.

  • Unconfiguring an entire zcml file (include statement inside an unconfigure block) now works.

1.0.1 (2008-08-07)

  • Added a meta.zcml file so that the <unconfigure> directive can actually be registered from ZCML.

1.0 (2008-08-07)

First public release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

z3c.unconfigure-2.1.tar.gz (12.6 kB view details)

Uploaded Source

Built Distribution

z3c.unconfigure-2.1-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file z3c.unconfigure-2.1.tar.gz.

File metadata

  • Download URL: z3c.unconfigure-2.1.tar.gz
  • Upload date:
  • Size: 12.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.10

File hashes

Hashes for z3c.unconfigure-2.1.tar.gz
Algorithm Hash digest
SHA256 f43cf5cdb062e5ddf756c619221f0134c3cedc3019fe9c679c8c0578ebe9e386
MD5 02b69ed7c6a0a63366da2d7da18980f3
BLAKE2b-256 7143db64e9cc1f3109ead9f33aefe9183b3945c39c804beeaa458da8d7dbcdd7

See more details on using hashes here.

File details

Details for the file z3c.unconfigure-2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for z3c.unconfigure-2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 fc0dd7ea7b9afada9dfbc16be323e04b20539211ae8ecf50c9fc8e05db4332c0
MD5 7a8be2512c1d05760bd910039492e8f6
BLAKE2b-256 ac72dd692d44567832dc878362c8e40926083f0fafd3aa3dd45092a706c2106b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page