Christopher Armstrong wrote:
logger.msg("scheduled-compaction-failed")
I'm confused. You don't want to use English, but... why not change
your hyphens to spaces and call it a day? Also, why did it fail?
Here's a fuller example, modified to fit the API I'm using:
from twisted.python.log import Logger
log = Logger()
try:
scheduleCompaction(...)
except Exception as e:
log.error("Scheduled compaction failed: {why}", why=e,
id=2C09A260-184C-44F9-B11F-E12B26B26C9C)
Some things to note about this:
- `log = Logger()` does some magic so that log.namespace is the name
of your module "spacecombat.server.db". So, your "system" identifier is
perhaps covered by that, with no typing.
- I have a format string instead of a fixed string. An observer
emitting text can emit something informative. I know you think that
text logs aren't useful, but a lot of us do. And you can use observers
that ignore this format. Maybe there's an argument for making the
format optional...
- Formatting isn't done here, so... cheap if you don't use it in any
observers.
- I added a GUID id argument since you seem keen, I think on a unique
key to identify the code point at which the message is logged. It's not
used in the format, but an observer storing things in a DB could use
that to take you straight to the relevant code, or identify multiple
instances of that message, etc. if the format string isn't how you want
to do that.
-wsv
_______________________________________________
Twisted-Python mailing list
Twisted-Python@twistedmatrix.com
http://twistedmatrix.com/cgi-bin/mailman/listinfo/twisted-python