Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(81)

Side by Side Diff: src/core/SkXfermode.cpp

Issue 811903004: Do more cleanup from xp changes (Closed) Base URL: https://skia.googlesource.com/skia.git@removeReadDst
Patch Set: Remove virtual call Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « include/core/SkXfermode.h ('k') | src/gpu/SkGr.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 1
2 /* 2 /*
3 * Copyright 2006 The Android Open Source Project 3 * Copyright 2006 The Android Open Source Project
4 * 4 *
5 * Use of this source code is governed by a BSD-style license that can be 5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file. 6 * found in the LICENSE file.
7 */ 7 */
8 8
9 #include "SkXfermode.h" 9 #include "SkXfermode.h"
10 #include "SkXfermode_opts_SSE2.h" 10 #include "SkXfermode_opts_SSE2.h"
(...skipping 669 matching lines...) Expand 10 before | Expand all | Expand 10 after
680 } 680 }
681 681
682 bool SkXfermode::asXPFactory(GrXPFactory**) const { 682 bool SkXfermode::asXPFactory(GrXPFactory**) const {
683 return false; 683 return false;
684 } 684 }
685 685
686 686
687 #if SK_SUPPORT_GPU 687 #if SK_SUPPORT_GPU
688 #include "effects/GrPorterDuffXferProcessor.h" 688 #include "effects/GrPorterDuffXferProcessor.h"
689 689
690 bool SkXfermode::AsFragmentProcessorOrXPFactory(SkXfermode* xfermode, 690 bool SkXfermode::AsXPFactory(SkXfermode* xfermode, GrXPFactory** xpf) {
691 GrFragmentProcessor** fp,
692 GrXPFactory** xpf) {
693 Coeff src, dst;
694 Mode mode;
695 if (NULL == xfermode) { 691 if (NULL == xfermode) {
696 *xpf = GrPorterDuffXPFactory::Create(kSrcOver_Mode); 692 if (xpf) {
697 return true; 693 *xpf = GrPorterDuffXPFactory::Create(kSrcOver_Mode);
698 } else if (xfermode->asMode(&mode) && mode <= kLastCoeffMode) { 694 }
699 *xpf = GrPorterDuffXPFactory::Create(mode);
700 return true;
701 } else if (xfermode->asCoeff(&src, &dst)) {
702 *xpf = GrPorterDuffXPFactory::Create(src, dst);
703 return true;
704 } else if (xfermode->asXPFactory(xpf)) {
705 return true; 695 return true;
706 } else { 696 } else {
707 return xfermode->asFragmentProcessor(fp, NULL); 697 return xfermode->asXPFactory(xpf);
708 } 698 }
709 } 699 }
710 #else 700 #else
711 bool SkXfermode::AsFragmentProcessorOrXPFactory(SkXfermode* xfermode, 701 bool SkXfermode::AsXPFactory(SkXfermode* xfermode, GrXPFactory** xpf) {
712 GrFragmentProcessor** fp,
713 GrXPFactory** xpf) {
714 return false; 702 return false;
715 } 703 }
716 #endif 704 #endif
717 705
718 SkPMColor SkXfermode::xferColor(SkPMColor src, SkPMColor dst) const{ 706 SkPMColor SkXfermode::xferColor(SkPMColor src, SkPMColor dst) const{
719 // no-op. subclasses should override this 707 // no-op. subclasses should override this
720 return dst; 708 return dst;
721 } 709 }
722 710
723 void SkXfermode::xfer32(SkPMColor* SK_RESTRICT dst, 711 void SkXfermode::xfer32(SkPMColor* SK_RESTRICT dst,
(...skipping 203 matching lines...) Expand 10 before | Expand all | Expand 10 after
927 if (fp) { 915 if (fp) {
928 *fp = GrCustomXfermode::CreateFP(fMode, background); 916 *fp = GrCustomXfermode::CreateFP(fMode, background);
929 SkASSERT(*fp); 917 SkASSERT(*fp);
930 } 918 }
931 return true; 919 return true;
932 } 920 }
933 return false; 921 return false;
934 } 922 }
935 923
936 bool SkProcCoeffXfermode::asXPFactory(GrXPFactory** xp) const { 924 bool SkProcCoeffXfermode::asXPFactory(GrXPFactory** xp) const {
925 if (CANNOT_USE_COEFF != fSrcCoeff) {
926 if (xp) {
927 *xp = GrPorterDuffXPFactory::Create(fMode);
928 SkASSERT(*xp);
929 }
930 return true;
931 }
932
937 if (GrCustomXfermode::IsSupportedMode(fMode)) { 933 if (GrCustomXfermode::IsSupportedMode(fMode)) {
938 if (xp) { 934 if (xp) {
939 *xp = GrCustomXfermode::CreateXPFactory(fMode); 935 *xp = GrCustomXfermode::CreateXPFactory(fMode);
940 SkASSERT(*xp); 936 SkASSERT(*xp);
941 } 937 }
942 return true; 938 return true;
943 } 939 }
944 return false; 940 return false;
945 } 941 }
946 #endif 942 #endif
(...skipping 551 matching lines...) Expand 10 before | Expand all | Expand 10 after
1498 } else { 1494 } else {
1499 proc16 = rec.fProc16_General; 1495 proc16 = rec.fProc16_General;
1500 } 1496 }
1501 } 1497 }
1502 return proc16; 1498 return proc16;
1503 } 1499 }
1504 1500
1505 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkXfermode) 1501 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkXfermode)
1506 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkProcCoeffXfermode) 1502 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkProcCoeffXfermode)
1507 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END 1503 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END
OLDNEW
« no previous file with comments | « include/core/SkXfermode.h ('k') | src/gpu/SkGr.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698