mirror of
https://github.com/servo/servo.git
synced 2025-08-05 13:40:08 +01:00
Add config to do desktop notifications by running an abitrary command.
This commit is contained in:
parent
dc93a72997
commit
16d8c35be4
2 changed files with 35 additions and 14 deletions
|
@ -92,17 +92,32 @@ def notify_darwin(title, text):
|
||||||
raise Exception("Optional Python module 'pyobjc' is not installed.")
|
raise Exception("Optional Python module 'pyobjc' is not installed.")
|
||||||
|
|
||||||
|
|
||||||
def notify_build_done(elapsed, success=True):
|
def notify_with_command(command):
|
||||||
|
def notify(title, text):
|
||||||
|
if call([command, title, text]) != 0:
|
||||||
|
raise Exception("Could not run '%s'." % command)
|
||||||
|
return notify
|
||||||
|
|
||||||
|
|
||||||
|
def notify_build_done(config, elapsed, success=True):
|
||||||
"""Generate desktop notification when build is complete and the
|
"""Generate desktop notification when build is complete and the
|
||||||
elapsed build time was longer than 30 seconds."""
|
elapsed build time was longer than 30 seconds."""
|
||||||
if elapsed > 30:
|
if elapsed > 30:
|
||||||
notify("Servo build", "%s in %s" % ("Completed" if success else "FAILED", format_duration(elapsed)))
|
notify(config, "Servo build",
|
||||||
|
"%s in %s" % ("Completed" if success else "FAILED", format_duration(elapsed)))
|
||||||
|
|
||||||
|
|
||||||
def notify(title, text):
|
def notify(config, title, text):
|
||||||
"""Generate a desktop notification using appropriate means on
|
"""Generate a desktop notification using appropriate means on
|
||||||
supported platforms Linux, Windows, and Mac OS. On unsupported
|
supported platforms Linux, Windows, and Mac OS. On unsupported
|
||||||
platforms, this function acts as a no-op."""
|
platforms, this function acts as a no-op.
|
||||||
|
|
||||||
|
If notify-command is set in the [tools] section of the configuration,
|
||||||
|
that is used instead."""
|
||||||
|
notify_command = config["tools"].get("notify-command")
|
||||||
|
if notify_command:
|
||||||
|
func = notify_with_command(notify_command)
|
||||||
|
else:
|
||||||
platforms = {
|
platforms = {
|
||||||
"linux": notify_linux,
|
"linux": notify_linux,
|
||||||
"linux2": notify_linux,
|
"linux2": notify_linux,
|
||||||
|
@ -324,7 +339,7 @@ class MachCommands(CommandBase):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
# Generate Desktop Notification if elapsed-time > some threshold value
|
# Generate Desktop Notification if elapsed-time > some threshold value
|
||||||
notify_build_done(elapsed, status == 0)
|
notify_build_done(self.config, elapsed, status == 0)
|
||||||
|
|
||||||
print("Build %s in %s" % ("Completed" if status == 0 else "FAILED", format_duration(elapsed)))
|
print("Build %s in %s" % ("Completed" if status == 0 else "FAILED", format_duration(elapsed)))
|
||||||
return status
|
return status
|
||||||
|
@ -375,7 +390,7 @@ class MachCommands(CommandBase):
|
||||||
elapsed = time() - build_start
|
elapsed = time() - build_start
|
||||||
|
|
||||||
# Generate Desktop Notification if elapsed-time > some threshold value
|
# Generate Desktop Notification if elapsed-time > some threshold value
|
||||||
notify_build_done(elapsed)
|
notify_build_done(self.config, elapsed)
|
||||||
|
|
||||||
print("CEF build completed in %s" % format_duration(elapsed))
|
print("CEF build completed in %s" % format_duration(elapsed))
|
||||||
|
|
||||||
|
@ -430,7 +445,7 @@ class MachCommands(CommandBase):
|
||||||
elapsed = time() - build_start
|
elapsed = time() - build_start
|
||||||
|
|
||||||
# Generate Desktop Notification if elapsed-time > some threshold value
|
# Generate Desktop Notification if elapsed-time > some threshold value
|
||||||
notify_build_done(elapsed)
|
notify_build_done(self.config, elapsed)
|
||||||
|
|
||||||
print("GeckoLib build completed in %s" % format_duration(elapsed))
|
print("GeckoLib build completed in %s" % format_duration(elapsed))
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,12 @@ system-cargo = false
|
||||||
# Defaults to true
|
# Defaults to true
|
||||||
rustc-with-gold = true
|
rustc-with-gold = true
|
||||||
|
|
||||||
|
# If uncommented, this command is used instead of the platform’s default
|
||||||
|
# to notify at the end of a compilation that took a long time.
|
||||||
|
# This is the name or path of an executable called with two arguments:
|
||||||
|
# the summary and content of the notification.
|
||||||
|
#notify-command = "notify-send"
|
||||||
|
|
||||||
[build]
|
[build]
|
||||||
# Set "mode = dev" or use `mach build --dev` to build the project with warning.
|
# Set "mode = dev" or use `mach build --dev` to build the project with warning.
|
||||||
# or Set "mode = release" or use `mach build --release` for optimized build.
|
# or Set "mode = release" or use `mach build --release` for optimized build.
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue