dom/fm/nsIFMRadio.idl
author Lucas Rocha <lucasr@mozilla.com>
Mon, 12 Nov 2012 15:58:40 +0000
changeset 112995 edc00669b8e13aada1969ab0d37ff26246bb1b43
parent 107524 75923725b2fc72927458f6281a78ebaab8f6bc71
child 115612 3dd00821b68021a452f832711d139945bcac0018
permissions -rw-r--r--
Bug 808296 - Update top sites thumbnails from adapter, not from gridview (r=mfinkle)

/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsIDOMEventTarget.idl"

[scriptable, uuid(c142387a-5488-454b-8b5a-91f0dbee833b)]
interface nsIFMRadioSettings : nsISupports
{
    /* Upper limit in KHz */
    attribute long upperLimit;
    /* Lower limit in KHz */
    attribute long lowerLimit;
    /* Channel width in KHz */
    attribute long channelWidth;
};

/**
 * This is an interface to expose the FM radio hardware related functions;
 * it's kind of the FM radio hardware wrapper interface.
 *
 * Because the WebFM API (navigator.mozFMRadio) is implemented as a JS component,
 * it can't access our C++ hardware interface directly; instead it must go
 * through this interface.
 * Do not confuse this interface with the WebFM DOM interface (nsIDOMFMRadio).
 *
 * If the WebFM API is re-written in c++ some day, this interface will be useless.
 */
[scriptable, builtinclass, uuid(26288adc-d2c1-4fbc-86b5-ecd8173fbf90)]
interface nsIFMRadio : nsIDOMEventTarget {
    const long SEEK_DIRECTION_UP   = 0;
    const long SEEK_DIRECTION_DOWN = 1;

    /**
     * Indicates if the FM radio hardware is enabled.
     */
    readonly attribute boolean enabled;

    /**
     * Current frequency in KHz
     */
    readonly attribute long frequency;

    /**
     * Indicates if the antenna is plugged in and available.
     */
    readonly attribute boolean isAntennaAvailable;

    /**
     * Enable the FM radio hardware with the given settings.
     */
    void enable(in nsIFMRadioSettings settings);

    /**
     * Disable the FM radio hardware.
     */
    void disable();

    /**
     * Seek the next available channel (up or down).
     *
     * @param direction
     *   The value should be one of SEEK_DIRECTION_DOWN and SEEK_DIRECTION_UP
     */
    void seek(in long direction);

    /**
     * Cancel the seek action.
     */
    void cancelSeek();

    /**
     * Get the current settings.
     */
    nsIFMRadioSettings getSettings();

    /**
     * Set the frequency in KHz
     */
    void setFrequency(in long frequency);

    /**
     * Fired when the antenna state is changed.
     */
    [implicit_jscontext] attribute jsval onantennastatechange;

    /**
     * Fired when a seek action completes.
     */
    [implicit_jscontext] attribute jsval onseekcomplete;

    /**
     * Fired when the FM radio hardware is enabled.
     */
    [implicit_jscontext] attribute jsval onenabled;

    /**
     * Fired when the FM radio hardware is disabled.
     */
    [implicit_jscontext] attribute jsval ondisabled;
};