[FreeType] Incorrect application of glyph positioning in the Y direction
[WebKit-https.git] / Source / WebCore / platform / mac / ScrollAnimatorMac.h
index b06cdee..ff733c1 100644 (file)
@@ -1,5 +1,6 @@
+
 /*
 /*
- * Copyright (C) 2010, 2011 Apple Inc. All rights reserved.
+ * Copyright (C) 2010, 2011, 2014-2015 Apple Inc. All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
@@ -23,8 +24,7 @@
  * THE POSSIBILITY OF SUCH DAMAGE.
  */
 
  * THE POSSIBILITY OF SUCH DAMAGE.
  */
 
-#ifndef ScrollAnimatorMac_h
-#define ScrollAnimatorMac_h
+#pragma once
 
 #if ENABLE(SMOOTH_SCROLLING)
 
 
 #if ENABLE(SMOOTH_SCROLLING)
 
 #include "FloatPoint.h"
 #include "FloatSize.h"
 #include "ScrollAnimator.h"
 #include "FloatPoint.h"
 #include "FloatSize.h"
 #include "ScrollAnimator.h"
-#include "ScrollElasticityController.h"
 #include "Timer.h"
 #include <wtf/RetainPtr.h>
 
 OBJC_CLASS WebScrollAnimationHelperDelegate;
 #include "Timer.h"
 #include <wtf/RetainPtr.h>
 
 OBJC_CLASS WebScrollAnimationHelperDelegate;
-OBJC_CLASS WebScrollbarPainterControllerDelegate;
-OBJC_CLASS WebScrollbarPainterDelegate;
-
-typedef id ScrollbarPainterController;
+OBJC_CLASS WebScrollerImpPairDelegate;
+OBJC_CLASS WebScrollerImpDelegate;
 
 
-#if !ENABLE(RUBBER_BANDING)
-class ScrollElasticityControllerClient { };
-#endif
+typedef id ScrollerImpPair;
 
 namespace WebCore {
 
 class Scrollbar;
 
 
 namespace WebCore {
 
 class Scrollbar;
 
-class ScrollAnimatorMac : public ScrollAnimator, private ScrollElasticityControllerClient {
+class ScrollAnimatorMac : public ScrollAnimator {
 
 public:
 
 public:
-    ScrollAnimatorMac(ScrollableArea*);
+    ScrollAnimatorMac(ScrollableArea&);
     virtual ~ScrollAnimatorMac();
 
     virtual ~ScrollAnimatorMac();
 
-    void immediateScrollToPointForScrollAnimation(const FloatPoint& newPosition);
+    void immediateScrollToPositionForScrollAnimation(const FloatPoint& newPosition);
     bool haveScrolledSincePageLoad() const { return m_haveScrolledSincePageLoad; }
 
     void updateScrollerStyle();
     bool haveScrolledSincePageLoad() const { return m_haveScrolledSincePageLoad; }
 
     void updateScrollerStyle();
@@ -67,64 +62,68 @@ public:
 
     void setVisibleScrollerThumbRect(const IntRect&);
 
 
     void setVisibleScrollerThumbRect(const IntRect&);
 
-    virtual bool scrollbarsCanBeActive() const override final;
+    bool scrollbarsCanBeActive() const final;
 
 private:
     RetainPtr<id> m_scrollAnimationHelper;
     RetainPtr<WebScrollAnimationHelperDelegate> m_scrollAnimationHelperDelegate;
 
 
 private:
     RetainPtr<id> m_scrollAnimationHelper;
     RetainPtr<WebScrollAnimationHelperDelegate> m_scrollAnimationHelperDelegate;
 
-    RetainPtr<ScrollbarPainterController> m_scrollbarPainterController;
-    RetainPtr<WebScrollbarPainterControllerDelegate> m_scrollbarPainterControllerDelegate;
-    RetainPtr<WebScrollbarPainterDelegate> m_horizontalScrollbarPainterDelegate;
-    RetainPtr<WebScrollbarPainterDelegate> m_verticalScrollbarPainterDelegate;
+    RetainPtr<ScrollerImpPair> m_scrollerImpPair;
+    RetainPtr<WebScrollerImpPairDelegate> m_scrollerImpPairDelegate;
+    RetainPtr<WebScrollerImpDelegate> m_horizontalScrollerImpDelegate;
+    RetainPtr<WebScrollerImpDelegate> m_verticalScrollerImpDelegate;
 
 
-    void initialScrollbarPaintTimerFired(Timer&);
+    void initialScrollbarPaintTimerFired();
     Timer m_initialScrollbarPaintTimer;
 
     Timer m_initialScrollbarPaintTimer;
 
-    void sendContentAreaScrolledTimerFired(Timer&);
+    void sendContentAreaScrolledTimerFired();
     Timer m_sendContentAreaScrolledTimer;
     FloatSize m_contentAreaScrolledTimerScrollDelta;
 
     Timer m_sendContentAreaScrolledTimer;
     FloatSize m_contentAreaScrolledTimerScrollDelta;
 
-    virtual bool scroll(ScrollbarOrientation, ScrollGranularity, float step, float multiplier);
-    virtual void scrollToOffsetWithoutAnimation(const FloatPoint&);
+    bool scroll(ScrollbarOrientation, ScrollGranularity, float step, float multiplier) override;
+    void scrollToOffsetWithoutAnimation(const FloatPoint&, ScrollClamping) override;
 
 #if ENABLE(RUBBER_BANDING)
 
 #if ENABLE(RUBBER_BANDING)
-    virtual bool handleWheelEvent(const PlatformWheelEvent&) override;
+    bool shouldForwardWheelEventsToParent(const PlatformWheelEvent&);
+    bool handleWheelEvent(const PlatformWheelEvent&) override;
 #endif
 
 #endif
 
-    virtual void handleWheelEventPhase(PlatformWheelEventPhase) override;
+    void handleWheelEventPhase(PlatformWheelEventPhase) override;
 
 
-    virtual void cancelAnimations();
+    void cancelAnimations() override;
     
     
-    virtual void notifyPositionChanged(const FloatSize& delta);
-    virtual void contentAreaWillPaint() const;
-    virtual void mouseEnteredContentArea() const;
-    virtual void mouseExitedContentArea() const;
-    virtual void mouseMovedInContentArea() const;
-    virtual void mouseEnteredScrollbar(Scrollbar*) const;
-    virtual void mouseExitedScrollbar(Scrollbar*) const;
-    virtual void willStartLiveResize();
-    virtual void contentsResized() const;
-    virtual void willEndLiveResize();
-    virtual void contentAreaDidShow() const;
-    virtual void contentAreaDidHide() const;
+    void notifyPositionChanged(const FloatSize& delta) override;
+    void contentAreaWillPaint() const override;
+    void mouseEnteredContentArea() override;
+    void mouseExitedContentArea() override;
+    void mouseMovedInContentArea() override;
+    void mouseEnteredScrollbar(Scrollbar*) const override;
+    void mouseExitedScrollbar(Scrollbar*) const override;
+    void mouseIsDownInScrollbar(Scrollbar*, bool) const override;
+    void willStartLiveResize() override;
+    void contentsResized() const override;
+    void willEndLiveResize() override;
+    void contentAreaDidShow() override;
+    void contentAreaDidHide() override;
     void didBeginScrollGesture() const;
     void didEndScrollGesture() const;
     void mayBeginScrollGesture() const;
 
     void didBeginScrollGesture() const;
     void didEndScrollGesture() const;
     void mayBeginScrollGesture() const;
 
-    virtual void lockOverlayScrollbarStateToHidden(bool shouldLockState) override final;
+    void lockOverlayScrollbarStateToHidden(bool shouldLockState) final;
 
 
-    virtual void didAddVerticalScrollbar(Scrollbar*);
-    virtual void willRemoveVerticalScrollbar(Scrollbar*);
-    virtual void didAddHorizontalScrollbar(Scrollbar*);
-    virtual void willRemoveHorizontalScrollbar(Scrollbar*);
+    void didAddVerticalScrollbar(Scrollbar*) override;
+    void willRemoveVerticalScrollbar(Scrollbar*) override;
+    void didAddHorizontalScrollbar(Scrollbar*) override;
+    void willRemoveHorizontalScrollbar(Scrollbar*) override;
 
 
-    virtual void verticalScrollbarLayerDidChange();
-    virtual void horizontalScrollbarLayerDidChange();
+    void invalidateScrollbarPartLayers(Scrollbar*) override;
 
 
-    virtual bool shouldScrollbarParticipateInHitTesting(Scrollbar*);
+    void verticalScrollbarLayerDidChange() override;
+    void horizontalScrollbarLayerDidChange() override;
 
 
-    virtual void notifyContentAreaScrolled(const FloatSize& delta) override;
+    bool shouldScrollbarParticipateInHitTesting(Scrollbar*) override;
+
+    void notifyContentAreaScrolled(const FloatSize& delta) override;
 
     // sendContentAreaScrolledSoon() will do the same work that sendContentAreaScrolled() does except
     // it does it after a zero-delay timer fires. This will prevent us from updating overlay scrollbar 
 
     // sendContentAreaScrolledSoon() will do the same work that sendContentAreaScrolled() does except
     // it does it after a zero-delay timer fires. This will prevent us from updating overlay scrollbar 
@@ -134,33 +133,25 @@ private:
 
     FloatPoint adjustScrollPositionIfNecessary(const FloatPoint&) const;
 
 
     FloatPoint adjustScrollPositionIfNecessary(const FloatPoint&) const;
 
-    void immediateScrollTo(const FloatPoint&);
+    void immediateScrollToPosition(const FloatPoint&, ScrollClamping = ScrollClamping::Clamped);
 
 
-    virtual bool isRubberBandInProgress() const override;
+    bool isRubberBandInProgress() const override;
+    bool isScrollSnapInProgress() const override;
 
 #if ENABLE(RUBBER_BANDING)
 
 #if ENABLE(RUBBER_BANDING)
-    /// ScrollElasticityControllerClient member functions.
-    virtual IntSize stretchAmount() override;
-    virtual bool allowsHorizontalStretching(const PlatformWheelEvent&) override;
-    virtual bool allowsVerticalStretching(const PlatformWheelEvent&) override;
-    virtual bool pinnedInDirection(const FloatSize&) override;
-    virtual bool canScrollHorizontally() override;
-    virtual bool canScrollVertically() override;
-    virtual bool shouldRubberBandInDirection(ScrollDirection) override;
-    virtual WebCore::IntPoint absoluteScrollPosition() override;
-    virtual void immediateScrollByWithoutContentEdgeConstraints(const FloatSize&) override;
-    virtual void immediateScrollBy(const FloatSize&) override;
-    virtual void startSnapRubberbandTimer() override;
-    virtual void stopSnapRubberbandTimer() override;
-    virtual void adjustScrollPositionToBoundsIfNecessary() override;
-
-    bool pinnedInDirection(float deltaX, float deltaY);
-    void snapRubberBandTimerFired(Timer&);
+    /// ScrollControllerClient member functions.
+    IntSize stretchAmount() override;
+    bool allowsHorizontalStretching(const PlatformWheelEvent&) override;
+    bool allowsVerticalStretching(const PlatformWheelEvent&) override;
+    bool pinnedInDirection(const FloatSize&) override;
+    bool canScrollHorizontally() override;
+    bool canScrollVertically() override;
+    bool shouldRubberBandInDirection(ScrollDirection) override;
+    void immediateScrollByWithoutContentEdgeConstraints(const FloatSize&) override;
+    void immediateScrollBy(const FloatSize&) override;
+    void adjustScrollPositionToBoundsIfNecessary() override;
 
     bool isAlreadyPinnedInDirectionOfGesture(const PlatformWheelEvent&, ScrollEventAxis);
 
     bool isAlreadyPinnedInDirectionOfGesture(const PlatformWheelEvent&, ScrollEventAxis);
-
-    ScrollElasticityController m_scrollElasticityController;
-    Timer m_snapRubberBandTimer;
 #endif
 
     bool m_haveScrolledSincePageLoad;
 #endif
 
     bool m_haveScrolledSincePageLoad;
@@ -172,4 +163,3 @@ private:
 
 #endif // ENABLE(SMOOTH_SCROLLING)
 
 
 #endif // ENABLE(SMOOTH_SCROLLING)
 
-#endif // ScrollAnimatorMac_h