File: ScrollOrigin.h

package info (click to toggle)
firefox 141.0.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,550,616 kB
  • sloc: cpp: 7,426,508; javascript: 6,367,238; ansic: 3,707,354; python: 1,368,984; xml: 623,983; asm: 426,916; java: 184,324; sh: 64,488; makefile: 19,203; objc: 13,059; perl: 12,955; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,071; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (70 lines) | stat: -rw-r--r-- 3,041 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/* 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/. */

#ifndef mozilla_ScrollOrigin_h_
#define mozilla_ScrollOrigin_h_

#include "mozilla/DefineEnum.h"

namespace mozilla {

// A scroll origin is a bit of a combination of "what part of the code caused
// this scroll" and "what special properties does this scroll have, in the
// context of what caused it". See specific comments below.
MOZ_DEFINE_ENUM_CLASS_WITH_BASE_AND_TOSTRING(
    ScrollOrigin, uint8_t,
    (
        // This is used as an initial value for the "LastScrollOrigin" property
        // on scrollable frames. It is not intended to be an actual scroll
        // origin, but a sentinel value that indicates that there was no "last
        // scroll". It is used similarly for the "LastSmoothScrollOrigin"
        // property, to indicate no smooth scroll is in progress.
        None,

        // This is a default value that we use when we don't know of a more
        // specific value that we can use.
        NotSpecified,
        // The scroll came from APZ code.
        Apz,
        // The scroll came from an attempt at restoring a scroll position saved
        // in the bfcache or history.
        Restore,
        // The scroll came from a "relative" scroll method like ScrollBy, where
        // the scroll destination is indicated by a delta from the current
        // position instead of an absolute value.
        Relative,
        // The scroll came from an attempt by the main thread to re-clamp the
        // scroll position after a reflow.
        Clamp,

        // The following scroll origins also are associated with prefs of the
        // form
        //   general.smoothScroll.<origin>(.*)
        // e.g. general.smoothScroll.lines indicates whether or not a scroll
        // with origin Lines will be animated smoothly, and e.g. subprefs like
        // general.smoothScroll.lines.durationMinMS control some of the
        // animation timing behavior.

        // The scroll came from some sort of input that's not one of the above
        // or below values. Generally this means it came from a content-exposed
        // API, like window.scrollTo, but may also be from other sources that
        // don't need any particular special handling.
        Other,
        // The scroll was originated by pixel-scrolling input device (e.g.
        // precision mouse wheel).
        Pixels,
        // The scroll was originated by a line-scrolling input device (e.g.
        // up/down keyboard buttons).
        Lines,
        // The scroll was originated by a page-scrolling input device (e.g.
        // pgup/ pgdn keyboard buttons).
        Pages,
        // The scroll was originated by a mousewheel that scrolls by lines.
        MouseWheel,
        // The scroll was originated by moving the scrollbars.
        Scrollbars));

}  // namespace mozilla

#endif  // mozilla_ScrollOrigin_h_