/ Hex Artifact Content
Login

Artifact 5fc1e9a4367bdd6c5afd318a36ec0b1f702fa1e3384621501873ec6b3e94651a:


0000: 2f 2a 0a 2a 2a 20 32 30 31 38 20 4d 61 79 20 30  /*.** 2018 May 0
0010: 38 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68  8.**.** The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65  place of.** a le
0060: 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65  gal notice, here
0070: 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a   is a blessing:.
0080: 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75  **.**    May you
0090: 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74   do good and not
00a0: 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79   evil..**    May
00b0: 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76   you find forgiv
00c0: 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65  eness for yourse
00d0: 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f  lf and forgive o
00e0: 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79  thers..**    May
00f0: 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c   you share freel
0100: 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20  y, never taking 
0110: 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69  more than you gi
0120: 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ve..**.*********
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 73 71  .*/.#include "sq
0180: 6c 69 74 65 49 6e 74 2e 68 22 0a 0a 2f 2a 0a 2a  liteInt.h"../*.*
0190: 2a 20 53 45 4c 45 43 54 20 52 45 57 52 49 54 49  * SELECT REWRITI
01a0: 4e 47 0a 2a 2a 0a 2a 2a 20 20 20 41 6e 79 20 53  NG.**.**   Any S
01b0: 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 20  ELECT statement 
01c0: 74 68 61 74 20 63 6f 6e 74 61 69 6e 73 20 6f 6e  that contains on
01d0: 65 20 6f 72 20 6d 6f 72 65 20 77 69 6e 64 6f 77  e or more window
01e0: 20 66 75 6e 63 74 69 6f 6e 73 20 69 6e 0a 2a 2a   functions in.**
01f0: 20 20 20 65 69 74 68 65 72 20 74 68 65 20 73 65     either the se
0200: 6c 65 63 74 20 6c 69 73 74 20 6f 72 20 4f 52 44  lect list or ORD
0210: 45 52 20 42 59 20 63 6c 61 75 73 65 20 28 74 68  ER BY clause (th
0220: 65 20 6f 6e 6c 79 20 74 77 6f 20 70 6c 61 63 65  e only two place
0230: 73 20 77 69 6e 64 6f 77 0a 2a 2a 20 20 20 66 75  s window.**   fu
0240: 6e 63 74 69 6f 6e 73 20 6d 61 79 20 62 65 20 75  nctions may be u
0250: 73 65 64 29 20 69 73 20 74 72 61 6e 73 66 6f 72  sed) is transfor
0260: 6d 65 64 20 62 79 20 66 75 6e 63 74 69 6f 6e 20  med by function 
0270: 73 71 6c 69 74 65 33 57 69 6e 64 6f 77 52 65 77  sqlite3WindowRew
0280: 72 69 74 65 28 29 0a 2a 2a 20 20 20 69 6e 20 6f  rite().**   in o
0290: 72 64 65 72 20 74 6f 20 73 75 70 70 6f 72 74 20  rder to support 
02a0: 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e 20  window function 
02b0: 70 72 6f 63 65 73 73 69 6e 67 2e 20 46 6f 72 20  processing. For 
02c0: 65 78 61 6d 70 6c 65 2c 20 77 69 74 68 20 74 68  example, with th
02d0: 65 0a 2a 2a 20 20 20 73 63 68 65 6d 61 3a 0a 2a  e.**   schema:.*
02e0: 2a 0a 2a 2a 20 20 20 20 20 43 52 45 41 54 45 20  *.**     CREATE 
02f0: 54 41 42 4c 45 20 74 31 28 61 2c 20 62 2c 20 63  TABLE t1(a, b, c
0300: 2c 20 64 2c 20 65 2c 20 66 2c 20 67 29 3b 0a 2a  , d, e, f, g);.*
0310: 2a 0a 2a 2a 20 20 20 74 68 65 20 73 74 61 74 65  *.**   the state
0320: 6d 65 6e 74 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20  ment:.**.**     
0330: 53 45 4c 45 43 54 20 61 2b 31 2c 20 6d 61 78 28  SELECT a+1, max(
0340: 62 29 20 4f 56 45 52 20 28 50 41 52 54 49 54 49  b) OVER (PARTITI
0350: 4f 4e 20 42 59 20 63 20 4f 52 44 45 52 20 42 59  ON BY c ORDER BY
0360: 20 64 29 20 46 52 4f 4d 20 74 31 20 4f 52 44 45   d) FROM t1 ORDE
0370: 52 20 42 59 20 65 3b 0a 2a 2a 0a 2a 2a 20 20 20  R BY e;.**.**   
0380: 69 73 20 74 72 61 6e 73 66 6f 72 6d 65 64 20 74  is transformed t
0390: 6f 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 53 45 4c  o:.**.**     SEL
03a0: 45 43 54 20 61 2b 31 2c 20 6d 61 78 28 62 29 20  ECT a+1, max(b) 
03b0: 4f 56 45 52 20 28 50 41 52 54 49 54 49 4f 4e 20  OVER (PARTITION 
03c0: 42 59 20 63 20 4f 52 44 45 52 20 42 59 20 64 29  BY c ORDER BY d)
03d0: 20 46 52 4f 4d 20 28 0a 2a 2a 20 20 20 20 20 20   FROM (.**      
03e0: 20 20 20 53 45 4c 45 43 54 20 61 2c 20 65 2c 20     SELECT a, e, 
03f0: 63 2c 20 64 2c 20 62 20 46 52 4f 4d 20 74 31 20  c, d, b FROM t1 
0400: 4f 52 44 45 52 20 42 59 20 63 2c 20 64 0a 2a 2a  ORDER BY c, d.**
0410: 20 20 20 20 20 29 20 4f 52 44 45 52 20 42 59 20       ) ORDER BY 
0420: 65 3b 0a 2a 2a 0a 2a 2a 20 20 20 54 68 65 20 66  e;.**.**   The f
0430: 6c 61 74 74 65 6e 69 6e 67 20 6f 70 74 69 6d 69  lattening optimi
0440: 7a 61 74 69 6f 6e 20 69 73 20 64 69 73 61 62 6c  zation is disabl
0450: 65 64 20 77 68 65 6e 20 70 72 6f 63 65 73 73 69  ed when processi
0460: 6e 67 20 74 68 69 73 20 74 72 61 6e 73 66 6f 72  ng this transfor
0470: 6d 65 64 0a 2a 2a 20 20 20 53 45 4c 45 43 54 20  med.**   SELECT 
0480: 73 74 61 74 65 6d 65 6e 74 2e 20 54 68 69 73 20  statement. This 
0490: 61 6c 6c 6f 77 73 20 74 68 65 20 69 6d 70 6c 65  allows the imple
04a0: 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 20 74 68 65  mentation of the
04b0: 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e   window function
04c0: 0a 2a 2a 20 20 20 28 69 6e 20 74 68 69 73 20 63  .**   (in this c
04d0: 61 73 65 20 6d 61 78 28 29 29 20 74 6f 20 70 72  ase max()) to pr
04e0: 6f 63 65 73 73 20 72 6f 77 73 20 73 6f 72 74 65  ocess rows sorte
04f0: 64 20 69 6e 20 6f 72 64 65 72 20 6f 66 20 28 63  d in order of (c
0500: 2c 20 64 29 2c 20 77 68 69 63 68 0a 2a 2a 20 20  , d), which.**  
0510: 20 6d 61 6b 65 73 20 74 68 69 6e 67 73 20 65 61   makes things ea
0520: 73 69 65 72 20 66 6f 72 20 6f 62 76 69 6f 75 73  sier for obvious
0530: 20 72 65 61 73 6f 6e 73 2e 20 4d 6f 72 65 20 67   reasons. More g
0540: 65 6e 65 72 61 6c 6c 79 3a 0a 2a 2a 0a 2a 2a 20  enerally:.**.** 
0550: 20 20 20 20 2a 20 46 52 4f 4d 2c 20 57 48 45 52      * FROM, WHER
0560: 45 2c 20 47 52 4f 55 50 20 42 59 20 61 6e 64 20  E, GROUP BY and 
0570: 48 41 56 49 4e 47 20 63 6c 61 75 73 65 73 20 61  HAVING clauses a
0580: 72 65 20 61 6c 6c 20 6d 6f 76 65 64 20 74 6f 20  re all moved to 
0590: 0a 2a 2a 20 20 20 20 20 20 20 74 68 65 20 73 75  .**       the su
05a0: 62 2d 71 75 65 72 79 2e 0a 2a 2a 0a 2a 2a 20 20  b-query..**.**  
05b0: 20 20 20 2a 20 4f 52 44 45 52 20 42 59 2c 20 4c     * ORDER BY, L
05c0: 49 4d 49 54 20 61 6e 64 20 4f 46 46 53 45 54 20  IMIT and OFFSET 
05d0: 72 65 6d 61 69 6e 20 70 61 72 74 20 6f 66 20 74  remain part of t
05e0: 68 65 20 70 61 72 65 6e 74 20 71 75 65 72 79 2e  he parent query.
05f0: 0a 2a 2a 0a 2a 2a 20 20 20 20 20 2a 20 54 65 72  .**.**     * Ter
0600: 6d 69 6e 61 6c 73 20 66 72 6f 6d 20 65 61 63 68  minals from each
0610: 20 6f 66 20 74 68 65 20 65 78 70 72 65 73 73 69   of the expressi
0620: 6f 6e 20 74 72 65 65 73 20 74 68 61 74 20 6d 61  on trees that ma
0630: 6b 65 20 75 70 20 74 68 65 20 0a 2a 2a 20 20 20  ke up the .**   
0640: 20 20 20 20 73 65 6c 65 63 74 2d 6c 69 73 74 20      select-list 
0650: 61 6e 64 20 4f 52 44 45 52 20 42 59 20 65 78 70  and ORDER BY exp
0660: 72 65 73 73 69 6f 6e 73 20 69 6e 20 74 68 65 20  ressions in the 
0670: 70 61 72 65 6e 74 20 71 75 65 72 79 20 61 72 65  parent query are
0680: 0a 2a 2a 20 20 20 20 20 20 20 73 65 6c 65 63 74  .**       select
0690: 65 64 20 62 79 20 74 68 65 20 73 75 62 2d 71 75  ed by the sub-qu
06a0: 65 72 79 2e 20 46 6f 72 20 74 68 65 20 70 75 72  ery. For the pur
06b0: 70 6f 73 65 73 20 6f 66 20 74 68 65 20 74 72 61  poses of the tra
06c0: 6e 73 66 6f 72 6d 61 74 69 6f 6e 2c 0a 2a 2a 20  nsformation,.** 
06d0: 20 20 20 20 20 20 74 65 72 6d 69 6e 61 6c 73 20        terminals 
06e0: 61 72 65 20 63 6f 6c 75 6d 6e 20 72 65 66 65 72  are column refer
06f0: 65 6e 63 65 73 20 61 6e 64 20 61 67 67 72 65 67  ences and aggreg
0700: 61 74 65 20 66 75 6e 63 74 69 6f 6e 73 2e 0a 2a  ate functions..*
0710: 2a 0a 2a 2a 20 20 20 49 66 20 74 68 65 72 65 20  *.**   If there 
0720: 69 73 20 6d 6f 72 65 20 74 68 61 6e 20 6f 6e 65  is more than one
0730: 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e   window function
0740: 20 69 6e 20 74 68 65 20 53 45 4c 45 43 54 20 74   in the SELECT t
0750: 68 61 74 20 75 73 65 73 0a 2a 2a 20 20 20 74 68  hat uses.**   th
0760: 65 20 73 61 6d 65 20 77 69 6e 64 6f 77 20 64 65  e same window de
0770: 63 6c 61 72 61 74 69 6f 6e 20 28 74 68 65 20 4f  claration (the O
0780: 56 45 52 20 62 69 74 29 2c 20 74 68 65 6e 20 61  VER bit), then a
0790: 20 73 69 6e 67 6c 65 20 73 63 61 6e 20 6d 61 79   single scan may
07a0: 0a 2a 2a 20 20 20 62 65 20 75 73 65 64 20 74 6f  .**   be used to
07b0: 20 70 72 6f 63 65 73 73 20 6d 6f 72 65 20 74 68   process more th
07c0: 61 6e 20 6f 6e 65 20 77 69 6e 64 6f 77 20 66 75  an one window fu
07d0: 6e 63 74 69 6f 6e 2e 20 46 6f 72 20 65 78 61 6d  nction. For exam
07e0: 70 6c 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 53  ple:.**.**     S
07f0: 45 4c 45 43 54 20 6d 61 78 28 62 29 20 4f 56 45  ELECT max(b) OVE
0800: 52 20 28 50 41 52 54 49 54 49 4f 4e 20 42 59 20  R (PARTITION BY 
0810: 63 20 4f 52 44 45 52 20 42 59 20 64 29 2c 20 0a  c ORDER BY d), .
0820: 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20 6d 69  **            mi
0830: 6e 28 65 29 20 4f 56 45 52 20 28 50 41 52 54 49  n(e) OVER (PARTI
0840: 54 49 4f 4e 20 42 59 20 63 20 4f 52 44 45 52 20  TION BY c ORDER 
0850: 42 59 20 64 29 20 0a 2a 2a 20 20 20 20 20 46 52  BY d) .**     FR
0860: 4f 4d 20 74 31 3b 0a 2a 2a 0a 2a 2a 20 20 20 69  OM t1;.**.**   i
0870: 73 20 74 72 61 6e 73 66 6f 72 6d 65 64 20 69 6e  s transformed in
0880: 20 74 68 65 20 73 61 6d 65 20 77 61 79 20 61 73   the same way as
0890: 20 74 68 65 20 65 78 61 6d 70 6c 65 20 61 62 6f   the example abo
08a0: 76 65 2e 20 48 6f 77 65 76 65 72 3a 0a 2a 2a 0a  ve. However:.**.
08b0: 2a 2a 20 20 20 20 20 53 45 4c 45 43 54 20 6d 61  **     SELECT ma
08c0: 78 28 62 29 20 4f 56 45 52 20 28 50 41 52 54 49  x(b) OVER (PARTI
08d0: 54 49 4f 4e 20 42 59 20 63 20 4f 52 44 45 52 20  TION BY c ORDER 
08e0: 42 59 20 64 29 2c 20 0a 2a 2a 20 20 20 20 20 20  BY d), .**      
08f0: 20 20 20 20 20 20 6d 69 6e 28 65 29 20 4f 56 45        min(e) OVE
0900: 52 20 28 50 41 52 54 49 54 49 4f 4e 20 42 59 20  R (PARTITION BY 
0910: 61 20 4f 52 44 45 52 20 42 59 20 62 29 20 0a 2a  a ORDER BY b) .*
0920: 2a 20 20 20 20 20 46 52 4f 4d 20 74 31 3b 0a 2a  *     FROM t1;.*
0930: 2a 0a 2a 2a 20 20 20 4d 75 73 74 20 62 65 20 74  *.**   Must be t
0940: 72 61 6e 73 66 6f 72 6d 65 64 20 74 6f 3a 0a 2a  ransformed to:.*
0950: 2a 0a 2a 2a 20 20 20 20 20 53 45 4c 45 43 54 20  *.**     SELECT 
0960: 6d 61 78 28 62 29 20 4f 56 45 52 20 28 50 41 52  max(b) OVER (PAR
0970: 54 49 54 49 4f 4e 20 42 59 20 63 20 4f 52 44 45  TITION BY c ORDE
0980: 52 20 42 59 20 64 29 20 46 52 4f 4d 20 28 0a 2a  R BY d) FROM (.*
0990: 2a 20 20 20 20 20 20 20 20 20 53 45 4c 45 43 54  *         SELECT
09a0: 20 65 2c 20 6d 69 6e 28 65 29 20 4f 56 45 52 20   e, min(e) OVER 
09b0: 28 50 41 52 54 49 54 49 4f 4e 20 42 59 20 61 20  (PARTITION BY a 
09c0: 4f 52 44 45 52 20 42 59 20 62 29 2c 20 63 2c 20  ORDER BY b), c, 
09d0: 64 2c 20 62 20 46 52 4f 4d 0a 2a 2a 20 20 20 20  d, b FROM.**    
09e0: 20 20 20 20 20 20 20 53 45 4c 45 43 54 20 61 2c         SELECT a,
09f0: 20 65 2c 20 63 2c 20 64 2c 20 62 20 46 52 4f 4d   e, c, d, b FROM
0a00: 20 74 31 20 4f 52 44 45 52 20 42 59 20 61 2c 20   t1 ORDER BY a, 
0a10: 62 0a 2a 2a 20 20 20 20 20 20 20 20 20 29 20 4f  b.**         ) O
0a20: 52 44 45 52 20 42 59 20 63 2c 20 64 0a 2a 2a 20  RDER BY c, d.** 
0a30: 20 20 20 20 29 20 4f 52 44 45 52 20 42 59 20 65      ) ORDER BY e
0a40: 3b 0a 2a 2a 0a 2a 2a 20 20 20 73 6f 20 74 68 61  ;.**.**   so tha
0a50: 74 20 62 6f 74 68 20 6d 69 6e 28 29 20 61 6e 64  t both min() and
0a60: 20 6d 61 78 28 29 20 6d 61 79 20 70 72 6f 63 65   max() may proce
0a70: 73 73 20 72 6f 77 73 20 69 6e 20 74 68 65 20 6f  ss rows in the o
0a80: 72 64 65 72 20 64 65 66 69 6e 65 64 20 62 79 0a  rder defined by.
0a90: 2a 2a 20 20 20 74 68 65 69 72 20 72 65 73 70 65  **   their respe
0aa0: 63 74 69 76 65 20 77 69 6e 64 6f 77 20 64 65 63  ctive window dec
0ab0: 6c 61 72 61 74 69 6f 6e 73 2e 0a 2a 2a 0a 2a 2a  larations..**.**
0ac0: 20 49 4e 54 45 52 46 41 43 45 20 57 49 54 48 20   INTERFACE WITH 
0ad0: 53 45 4c 45 43 54 2e 43 0a 2a 2a 0a 2a 2a 20 20  SELECT.C.**.**  
0ae0: 20 57 68 65 6e 20 70 72 6f 63 65 73 73 69 6e 67   When processing
0af0: 20 74 68 65 20 72 65 77 72 69 74 74 65 6e 20 53   the rewritten S
0b00: 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 2c  ELECT statement,
0b10: 20 63 6f 64 65 20 69 6e 20 73 65 6c 65 63 74 2e   code in select.
0b20: 63 20 63 61 6c 6c 73 0a 2a 2a 20 20 20 73 71 6c  c calls.**   sql
0b30: 69 74 65 33 57 68 65 72 65 42 65 67 69 6e 28 29  ite3WhereBegin()
0b40: 20 74 6f 20 62 65 67 69 6e 20 69 74 65 72 61 74   to begin iterat
0b50: 69 6e 67 20 74 68 72 6f 75 67 68 20 74 68 65 20  ing through the 
0b60: 72 65 73 75 6c 74 73 20 6f 66 20 74 68 65 0a 2a  results of the.*
0b70: 2a 20 20 20 73 75 62 2d 71 75 65 72 79 2c 20 77  *   sub-query, w
0b80: 68 69 63 68 20 69 73 20 61 6c 77 61 79 73 20 69  hich is always i
0b90: 6d 70 6c 65 6d 65 6e 74 65 64 20 61 73 20 61 20  mplemented as a 
0ba0: 63 6f 2d 72 6f 75 74 69 6e 65 2e 20 49 74 20 74  co-routine. It t
0bb0: 68 65 6e 20 63 61 6c 6c 73 0a 2a 2a 20 20 20 73  hen calls.**   s
0bc0: 71 6c 69 74 65 33 57 69 6e 64 6f 77 43 6f 64 65  qlite3WindowCode
0bd0: 53 74 65 70 28 29 20 74 6f 20 70 72 6f 63 65 73  Step() to proces
0be0: 73 20 72 6f 77 73 20 61 6e 64 20 66 69 6e 69 73  s rows and finis
0bf0: 68 20 74 68 65 20 73 63 61 6e 20 62 79 20 63 61  h the scan by ca
0c00: 6c 6c 69 6e 67 0a 2a 2a 20 20 20 73 71 6c 69 74  lling.**   sqlit
0c10: 65 33 57 68 65 72 65 45 6e 64 28 29 2e 0a 2a 2a  e3WhereEnd()..**
0c20: 0a 2a 2a 20 20 20 73 71 6c 69 74 65 33 57 69 6e  .**   sqlite3Win
0c30: 64 6f 77 43 6f 64 65 53 74 65 70 28 29 20 67 65  dowCodeStep() ge
0c40: 6e 65 72 61 74 65 73 20 56 4d 20 63 6f 64 65 20  nerates VM code 
0c50: 73 6f 20 74 68 61 74 2c 20 66 6f 72 20 65 61 63  so that, for eac
0c60: 68 20 72 6f 77 20 72 65 74 75 72 6e 65 64 0a 2a  h row returned.*
0c70: 2a 20 20 20 62 79 20 74 68 65 20 73 75 62 2d 71  *   by the sub-q
0c80: 75 65 72 79 20 61 20 73 75 62 2d 72 6f 75 74 69  uery a sub-routi
0c90: 6e 65 20 28 4f 50 5f 47 6f 73 75 62 29 20 63 6f  ne (OP_Gosub) co
0ca0: 64 65 64 20 62 79 20 73 65 6c 65 63 74 2e 63 20  ded by select.c 
0cb0: 69 73 20 69 6e 76 6f 6b 65 64 2e 0a 2a 2a 20 20  is invoked..**  
0cc0: 20 57 68 65 6e 20 74 68 65 20 73 75 62 2d 72 6f   When the sub-ro
0cd0: 75 74 69 6e 65 20 69 73 20 69 6e 76 6f 6b 65 64  utine is invoked
0ce0: 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 2a 20 54 68  :.**.**     * Th
0cf0: 65 20 72 65 73 75 6c 74 73 20 6f 66 20 61 6c 6c  e results of all
0d00: 20 77 69 6e 64 6f 77 2d 66 75 6e 63 74 69 6f 6e   window-function
0d10: 73 20 66 6f 72 20 74 68 65 20 72 6f 77 20 61 72  s for the row ar
0d20: 65 20 73 74 6f 72 65 64 0a 2a 2a 20 20 20 20 20  e stored.**     
0d30: 20 20 69 6e 20 74 68 65 20 61 73 73 6f 63 69 61    in the associa
0d40: 74 65 64 20 57 69 6e 64 6f 77 2e 72 65 67 52 65  ted Window.regRe
0d50: 73 75 6c 74 20 72 65 67 69 73 74 65 72 73 2e 0a  sult registers..
0d60: 2a 2a 0a 2a 2a 20 20 20 20 20 2a 20 54 68 65 20  **.**     * The 
0d70: 72 65 71 75 69 72 65 64 20 74 65 72 6d 69 6e 61  required termina
0d80: 6c 20 76 61 6c 75 65 73 20 61 72 65 20 73 74 6f  l values are sto
0d90: 72 65 64 20 69 6e 20 74 68 65 20 63 75 72 72 65  red in the curre
0da0: 6e 74 20 72 6f 77 20 6f 66 0a 2a 2a 20 20 20 20  nt row of.**    
0db0: 20 20 20 74 65 6d 70 20 74 61 62 6c 65 20 57 69     temp table Wi
0dc0: 6e 64 6f 77 2e 69 45 70 68 43 73 72 2e 0a 2a 2a  ndow.iEphCsr..**
0dd0: 0a 2a 2a 20 20 20 49 6e 20 73 6f 6d 65 20 63 61  .**   In some ca
0de0: 73 65 73 2c 20 64 65 70 65 6e 64 69 6e 67 20 6f  ses, depending o
0df0: 6e 20 74 68 65 20 77 69 6e 64 6f 77 20 66 72 61  n the window fra
0e00: 6d 65 20 61 6e 64 20 74 68 65 20 73 70 65 63 69  me and the speci
0e10: 66 69 63 20 77 69 6e 64 6f 77 0a 2a 2a 20 20 20  fic window.**   
0e20: 66 75 6e 63 74 69 6f 6e 73 20 69 6e 76 6f 6b 65  functions invoke
0e30: 64 2c 20 73 71 6c 69 74 65 33 57 69 6e 64 6f 77  d, sqlite3Window
0e40: 43 6f 64 65 53 74 65 70 28 29 20 63 61 63 68 65  CodeStep() cache
0e50: 73 20 65 61 63 68 20 65 6e 74 69 72 65 20 70 61  s each entire pa
0e60: 72 74 69 74 69 6f 6e 0a 2a 2a 20 20 20 69 6e 20  rtition.**   in 
0e70: 61 20 74 65 6d 70 20 74 61 62 6c 65 20 62 65 66  a temp table bef
0e80: 6f 72 65 20 72 65 74 75 72 6e 69 6e 67 20 61 6e  ore returning an
0e90: 79 20 72 6f 77 73 2e 20 49 6e 20 6f 74 68 65 72  y rows. In other
0ea0: 20 63 61 73 65 73 20 69 74 20 64 6f 65 73 20 6e   cases it does n
0eb0: 6f 74 2e 0a 2a 2a 20 20 20 54 68 69 73 20 64 65  ot..**   This de
0ec0: 74 61 69 6c 20 69 73 20 65 6e 63 61 70 73 75 6c  tail is encapsul
0ed0: 61 74 65 64 20 77 69 74 68 69 6e 20 74 68 69 73  ated within this
0ee0: 20 66 69 6c 65 2c 20 74 68 65 20 63 6f 64 65 20   file, the code 
0ef0: 67 65 6e 65 72 61 74 65 64 20 62 79 0a 2a 2a 20  generated by.** 
0f00: 20 20 73 65 6c 65 63 74 2e 63 20 69 73 20 74 68    select.c is th
0f10: 65 20 73 61 6d 65 20 69 6e 20 65 69 74 68 65 72  e same in either
0f20: 20 63 61 73 65 2e 0a 2a 2a 0a 2a 2a 20 42 55 49   case..**.** BUI
0f30: 4c 54 2d 49 4e 20 57 49 4e 44 4f 57 20 46 55 4e  LT-IN WINDOW FUN
0f40: 43 54 49 4f 4e 53 0a 2a 2a 0a 2a 2a 20 20 20 54  CTIONS.**.**   T
0f50: 68 69 73 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69  his implementati
0f60: 6f 6e 20 66 65 61 74 75 72 65 73 20 74 68 65 20  on features the 
0f70: 66 6f 6c 6c 6f 77 69 6e 67 20 62 75 69 6c 74 2d  following built-
0f80: 69 6e 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69  in window functi
0f90: 6f 6e 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 72  ons:.**.**     r
0fa0: 6f 77 5f 6e 75 6d 62 65 72 28 29 0a 2a 2a 20 20  ow_number().**  
0fb0: 20 20 20 72 61 6e 6b 28 29 0a 2a 2a 20 20 20 20     rank().**    
0fc0: 20 64 65 6e 73 65 5f 72 61 6e 6b 28 29 0a 2a 2a   dense_rank().**
0fd0: 20 20 20 20 20 70 65 72 63 65 6e 74 5f 72 61 6e       percent_ran
0fe0: 6b 28 29 0a 2a 2a 20 20 20 20 20 63 75 6d 65 5f  k().**     cume_
0ff0: 64 69 73 74 28 29 0a 2a 2a 20 20 20 20 20 6e 74  dist().**     nt
1000: 69 6c 65 28 4e 29 0a 2a 2a 20 20 20 20 20 6c 65  ile(N).**     le
1010: 61 64 28 65 78 70 72 20 5b 2c 20 6f 66 66 73 65  ad(expr [, offse
1020: 74 20 5b 2c 20 64 65 66 61 75 6c 74 5d 5d 29 0a  t [, default]]).
1030: 2a 2a 20 20 20 20 20 6c 61 67 28 65 78 70 72 20  **     lag(expr 
1040: 5b 2c 20 6f 66 66 73 65 74 20 5b 2c 20 64 65 66  [, offset [, def
1050: 61 75 6c 74 5d 5d 29 0a 2a 2a 20 20 20 20 20 66  ault]]).**     f
1060: 69 72 73 74 5f 76 61 6c 75 65 28 65 78 70 72 29  irst_value(expr)
1070: 0a 2a 2a 20 20 20 20 20 6c 61 73 74 5f 76 61 6c  .**     last_val
1080: 75 65 28 65 78 70 72 29 0a 2a 2a 20 20 20 20 20  ue(expr).**     
1090: 6e 74 68 5f 76 61 6c 75 65 28 65 78 70 72 2c 20  nth_value(expr, 
10a0: 4e 29 0a 2a 2a 20 20 20 0a 2a 2a 20 20 20 54 68  N).**   .**   Th
10b0: 65 73 65 20 61 72 65 20 74 68 65 20 73 61 6d 65  ese are the same
10c0: 20 62 75 69 6c 74 2d 69 6e 20 77 69 6e 64 6f 77   built-in window
10d0: 20 66 75 6e 63 74 69 6f 6e 73 20 73 75 70 70 6f   functions suppo
10e0: 72 74 65 64 20 62 79 20 50 6f 73 74 67 72 65 73  rted by Postgres
10f0: 2e 20 0a 2a 2a 20 20 20 41 6c 74 68 6f 75 67 68  . .**   Although
1100: 20 74 68 65 20 62 65 68 61 76 69 6f 75 72 20 6f   the behaviour o
1110: 66 20 61 67 67 72 65 67 61 74 65 20 77 69 6e 64  f aggregate wind
1120: 6f 77 20 66 75 6e 63 74 69 6f 6e 73 20 28 66 75  ow functions (fu
1130: 6e 63 74 69 6f 6e 73 20 74 68 61 74 0a 2a 2a 20  nctions that.** 
1140: 20 20 63 61 6e 20 62 65 20 75 73 65 64 20 61 73    can be used as
1150: 20 65 69 74 68 65 72 20 61 67 67 72 65 67 61 74   either aggregat
1160: 65 73 20 6f 72 20 77 69 6e 64 6f 77 20 66 75 6e  es or window fun
1170: 74 69 6f 6e 73 29 20 61 6c 6c 6f 77 73 20 74 68  tions) allows th
1180: 65 6d 20 74 6f 0a 2a 2a 20 20 20 62 65 20 69 6d  em to.**   be im
1190: 70 6c 65 6d 65 6e 74 65 64 20 75 73 69 6e 67 20  plemented using 
11a0: 61 6e 20 41 50 49 2c 20 62 75 69 6c 74 2d 69 6e  an API, built-in
11b0: 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e   window function
11c0: 73 20 61 72 65 20 6d 75 63 68 20 6d 6f 72 65 0a  s are much more.
11d0: 2a 2a 20 20 20 65 73 6f 74 65 72 69 63 2e 20 41  **   esoteric. A
11e0: 64 64 69 74 69 6f 6e 61 6c 6c 79 2c 20 73 6f 6d  dditionally, som
11f0: 65 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f  e window functio
1200: 6e 73 20 28 65 2e 67 2e 20 6e 74 68 5f 76 61 6c  ns (e.g. nth_val
1210: 75 65 28 29 29 20 0a 2a 2a 20 20 20 6d 61 79 20  ue()) .**   may 
1220: 6f 6e 6c 79 20 62 65 20 69 6d 70 6c 65 6d 65 6e  only be implemen
1230: 74 65 64 20 62 79 20 63 61 63 68 69 6e 67 20 74  ted by caching t
1240: 68 65 20 65 6e 74 69 72 65 20 70 61 72 74 69 74  he entire partit
1250: 69 6f 6e 20 69 6e 20 6d 65 6d 6f 72 79 2e 0a 2a  ion in memory..*
1260: 2a 20 20 20 41 73 20 73 75 63 68 2c 20 73 6f 6d  *   As such, som
1270: 65 20 62 75 69 6c 74 2d 69 6e 20 77 69 6e 64 6f  e built-in windo
1280: 77 20 66 75 6e 63 74 69 6f 6e 73 20 75 73 65 20  w functions use 
1290: 74 68 65 20 73 61 6d 65 20 41 50 49 20 61 73 20  the same API as 
12a0: 61 67 67 72 65 67 61 74 65 0a 2a 2a 20 20 20 77  aggregate.**   w
12b0: 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e 73 20  indow functions 
12c0: 61 6e 64 20 73 6f 6d 65 20 61 72 65 20 69 6d 70  and some are imp
12d0: 6c 65 6d 65 6e 74 65 64 20 64 69 72 65 63 74 6c  lemented directl
12e0: 79 20 75 73 69 6e 67 20 56 44 42 45 20 0a 2a 2a  y using VDBE .**
12f0: 20 20 20 69 6e 73 74 72 75 63 74 69 6f 6e 73 2e     instructions.
1300: 20 41 64 64 69 74 69 6f 6e 61 6c 6c 79 2c 20 66   Additionally, f
1310: 6f 72 20 74 68 6f 73 65 20 66 75 6e 63 74 69 6f  or those functio
1320: 6e 73 20 74 68 61 74 20 75 73 65 20 74 68 65 20  ns that use the 
1330: 41 50 49 2c 20 74 68 65 0a 2a 2a 20 20 20 77 69  API, the.**   wi
1340: 6e 64 6f 77 20 66 72 61 6d 65 20 69 73 20 73 6f  ndow frame is so
1350: 6d 65 74 69 6d 65 73 20 6d 6f 64 69 66 69 65 64  metimes modified
1360: 20 62 65 66 6f 72 65 20 74 68 65 20 53 45 4c 45   before the SELE
1370: 43 54 20 73 74 61 74 65 6d 65 6e 74 20 69 73 0a  CT statement is.
1380: 2a 2a 20 20 20 72 65 77 72 69 74 74 65 6e 2e 20  **   rewritten. 
1390: 46 6f 72 20 65 78 61 6d 70 6c 65 2c 20 72 65 67  For example, reg
13a0: 61 72 64 6c 65 73 73 20 6f 66 20 74 68 65 20 73  ardless of the s
13b0: 70 65 63 69 66 69 65 64 20 77 69 6e 64 6f 77 20  pecified window 
13c0: 66 72 61 6d 65 2c 20 74 68 65 0a 2a 2a 20 20 20  frame, the.**   
13d0: 72 6f 77 5f 6e 75 6d 62 65 72 28 29 20 66 75 6e  row_number() fun
13e0: 63 74 69 6f 6e 20 61 6c 77 61 79 73 20 75 73 65  ction always use
13f0: 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 52 4f 57  s:.**.**     ROW
1400: 53 20 42 45 54 57 45 45 4e 20 55 4e 42 4f 55 4e  S BETWEEN UNBOUN
1410: 44 45 44 20 50 52 45 43 45 44 49 4e 47 20 41 4e  DED PRECEDING AN
1420: 44 20 43 55 52 52 45 4e 54 20 52 4f 57 0a 2a 2a  D CURRENT ROW.**
1430: 0a 2a 2a 20 20 20 53 65 65 20 73 71 6c 69 74 65  .**   See sqlite
1440: 33 57 69 6e 64 6f 77 55 70 64 61 74 65 28 29 20  3WindowUpdate() 
1450: 66 6f 72 20 64 65 74 61 69 6c 73 2e 0a 2a 2f 0a  for details..*/.
1460: 0a 2f 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65 6e 74  ./*.** Implement
1470: 61 74 69 6f 6e 20 6f 66 20 62 75 69 6c 74 2d 69  ation of built-i
1480: 6e 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f  n window functio
1490: 6e 20 72 6f 77 5f 6e 75 6d 62 65 72 28 29 2e 20  n row_number(). 
14a0: 41 73 73 75 6d 65 73 20 74 68 61 74 20 74 68 65  Assumes that the
14b0: 0a 2a 2a 20 77 69 6e 64 6f 77 20 66 72 61 6d 65  .** window frame
14c0: 20 68 61 73 20 62 65 65 6e 20 63 6f 65 72 63 65   has been coerce
14d0: 64 20 74 6f 3a 0a 2a 2a 0a 2a 2a 20 20 20 52 4f  d to:.**.**   RO
14e0: 57 53 20 42 45 54 57 45 45 4e 20 55 4e 42 4f 55  WS BETWEEN UNBOU
14f0: 4e 44 45 44 20 50 52 45 43 45 44 49 4e 47 20 41  NDED PRECEDING A
1500: 4e 44 20 43 55 52 52 45 4e 54 20 52 4f 57 0a 2a  ND CURRENT ROW.*
1510: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 72 6f  /.static void ro
1520: 77 5f 6e 75 6d 62 65 72 53 74 65 70 46 75 6e 63  w_numberStepFunc
1530: 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  (.  sqlite3_cont
1540: 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e  ext *pCtx, .  in
1550: 74 20 6e 41 72 67 2c 0a 20 20 73 71 6c 69 74 65  t nArg,.  sqlite
1560: 33 5f 76 61 6c 75 65 20 2a 2a 61 70 41 72 67 0a  3_value **apArg.
1570: 29 7b 0a 20 20 69 36 34 20 2a 70 20 3d 20 28 69  ){.  i64 *p = (i
1580: 36 34 2a 29 73 71 6c 69 74 65 33 5f 61 67 67 72  64*)sqlite3_aggr
1590: 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 28 70 43  egate_context(pC
15a0: 74 78 2c 20 73 69 7a 65 6f 66 28 2a 70 29 29 3b  tx, sizeof(*p));
15b0: 0a 20 20 69 66 28 20 70 20 29 20 28 2a 70 29 2b  .  if( p ) (*p)+
15c0: 2b 3b 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64  +;.}.static void
15d0: 20 72 6f 77 5f 6e 75 6d 62 65 72 49 6e 76 46 75   row_numberInvFu
15e0: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
15f0: 6e 74 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20  ntext *pCtx, .  
1600: 69 6e 74 20 6e 41 72 67 2c 0a 20 20 73 71 6c 69  int nArg,.  sqli
1610: 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 41 72  te3_value **apAr
1620: 67 0a 29 7b 0a 7d 0a 73 74 61 74 69 63 20 76 6f  g.){.}.static vo
1630: 69 64 20 72 6f 77 5f 6e 75 6d 62 65 72 56 61 6c  id row_numberVal
1640: 75 65 46 75 6e 63 28 73 71 6c 69 74 65 33 5f 63  ueFunc(sqlite3_c
1650: 6f 6e 74 65 78 74 20 2a 70 43 74 78 29 7b 0a 20  ontext *pCtx){. 
1660: 20 69 36 34 20 2a 70 20 3d 20 28 69 36 34 2a 29   i64 *p = (i64*)
1670: 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74  sqlite3_aggregat
1680: 65 5f 63 6f 6e 74 65 78 74 28 70 43 74 78 2c 20  e_context(pCtx, 
1690: 73 69 7a 65 6f 66 28 2a 70 29 29 3b 0a 20 20 73  sizeof(*p));.  s
16a0: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e  qlite3_result_in
16b0: 74 36 34 28 70 43 74 78 2c 20 28 70 20 3f 20 2a  t64(pCtx, (p ? *
16c0: 70 20 3a 20 30 29 29 3b 0a 7d 0a 0a 2f 2a 0a 2a  p : 0));.}../*.*
16d0: 2a 20 43 6f 6e 74 65 78 74 20 6f 62 6a 65 63 74  * Context object
16e0: 20 74 79 70 65 20 75 73 65 64 20 62 79 20 72 61   type used by ra
16f0: 6e 6b 28 29 2c 20 64 65 6e 73 65 5f 72 61 6e 6b  nk(), dense_rank
1700: 28 29 2c 20 70 65 72 63 65 6e 74 5f 72 61 6e 6b  (), percent_rank
1710: 28 29 20 61 6e 64 0a 2a 2a 20 63 75 6d 65 5f 64  () and.** cume_d
1720: 69 73 74 28 29 2e 0a 2a 2f 0a 73 74 72 75 63 74  ist()..*/.struct
1730: 20 43 61 6c 6c 43 6f 75 6e 74 20 7b 0a 20 20 69   CallCount {.  i
1740: 36 34 20 6e 56 61 6c 75 65 3b 0a 20 20 69 36 34  64 nValue;.  i64
1750: 20 6e 53 74 65 70 3b 0a 20 20 69 36 34 20 6e 54   nStep;.  i64 nT
1760: 6f 74 61 6c 3b 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  otal;.};../*.** 
1770: 49 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f  Implementation o
1780: 66 20 62 75 69 6c 74 2d 69 6e 20 77 69 6e 64 6f  f built-in windo
1790: 77 20 66 75 6e 63 74 69 6f 6e 20 64 65 6e 73 65  w function dense
17a0: 5f 72 61 6e 6b 28 29 2e 0a 2a 2f 0a 73 74 61 74  _rank()..*/.stat
17b0: 69 63 20 76 6f 69 64 20 64 65 6e 73 65 5f 72 61  ic void dense_ra
17c0: 6e 6b 53 74 65 70 46 75 6e 63 28 0a 20 20 73 71  nkStepFunc(.  sq
17d0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
17e0: 43 74 78 2c 20 0a 20 20 69 6e 74 20 6e 41 72 67  Ctx, .  int nArg
17f0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  ,.  sqlite3_valu
1800: 65 20 2a 2a 61 70 41 72 67 0a 29 7b 0a 20 20 73  e **apArg.){.  s
1810: 74 72 75 63 74 20 43 61 6c 6c 43 6f 75 6e 74 20  truct CallCount 
1820: 2a 70 3b 0a 20 20 70 20 3d 20 28 73 74 72 75 63  *p;.  p = (struc
1830: 74 20 43 61 6c 6c 43 6f 75 6e 74 2a 29 73 71 6c  t CallCount*)sql
1840: 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63  ite3_aggregate_c
1850: 6f 6e 74 65 78 74 28 70 43 74 78 2c 20 73 69 7a  ontext(pCtx, siz
1860: 65 6f 66 28 2a 70 29 29 3b 0a 20 20 69 66 28 20  eof(*p));.  if( 
1870: 70 20 29 20 70 2d 3e 6e 53 74 65 70 20 3d 20 31  p ) p->nStep = 1
1880: 3b 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20  ;.}.static void 
1890: 64 65 6e 73 65 5f 72 61 6e 6b 49 6e 76 46 75 6e  dense_rankInvFun
18a0: 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e  c(.  sqlite3_con
18b0: 74 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 69  text *pCtx, .  i
18c0: 6e 74 20 6e 41 72 67 2c 0a 20 20 73 71 6c 69 74  nt nArg,.  sqlit
18d0: 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 41 72 67  e3_value **apArg
18e0: 0a 29 7b 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69  .){.}.static voi
18f0: 64 20 64 65 6e 73 65 5f 72 61 6e 6b 56 61 6c 75  d dense_rankValu
1900: 65 46 75 6e 63 28 73 71 6c 69 74 65 33 5f 63 6f  eFunc(sqlite3_co
1910: 6e 74 65 78 74 20 2a 70 43 74 78 29 7b 0a 20 20  ntext *pCtx){.  
1920: 73 74 72 75 63 74 20 43 61 6c 6c 43 6f 75 6e 74  struct CallCount
1930: 20 2a 70 3b 0a 20 20 70 20 3d 20 28 73 74 72 75   *p;.  p = (stru
1940: 63 74 20 43 61 6c 6c 43 6f 75 6e 74 2a 29 73 71  ct CallCount*)sq
1950: 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f  lite3_aggregate_
1960: 63 6f 6e 74 65 78 74 28 70 43 74 78 2c 20 73 69  context(pCtx, si
1970: 7a 65 6f 66 28 2a 70 29 29 3b 0a 20 20 69 66 28  zeof(*p));.  if(
1980: 20 70 20 29 7b 0a 20 20 20 20 69 66 28 20 70 2d   p ){.    if( p-
1990: 3e 6e 53 74 65 70 20 29 7b 0a 20 20 20 20 20 20  >nStep ){.      
19a0: 70 2d 3e 6e 56 61 6c 75 65 2b 2b 3b 0a 20 20 20  p->nValue++;.   
19b0: 20 20 20 70 2d 3e 6e 53 74 65 70 20 3d 20 30 3b     p->nStep = 0;
19c0: 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74  .    }.    sqlit
19d0: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 28  e3_result_int64(
19e0: 70 43 74 78 2c 20 70 2d 3e 6e 56 61 6c 75 65 29  pCtx, p->nValue)
19f0: 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49  ;.  }.}../*.** I
1a00: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66  mplementation of
1a10: 20 62 75 69 6c 74 2d 69 6e 20 77 69 6e 64 6f 77   built-in window
1a20: 20 66 75 6e 63 74 69 6f 6e 20 72 61 6e 6b 28 29   function rank()
1a30: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  ..*/.static void
1a40: 20 72 61 6e 6b 53 74 65 70 46 75 6e 63 28 0a 20   rankStepFunc(. 
1a50: 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74   sqlite3_context
1a60: 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74 20 6e   *pCtx, .  int n
1a70: 41 72 67 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76  Arg,.  sqlite3_v
1a80: 61 6c 75 65 20 2a 2a 61 70 41 72 67 0a 29 7b 0a  alue **apArg.){.
1a90: 20 20 73 74 72 75 63 74 20 43 61 6c 6c 43 6f 75    struct CallCou
1aa0: 6e 74 20 2a 70 3b 0a 20 20 70 20 3d 20 28 73 74  nt *p;.  p = (st
1ab0: 72 75 63 74 20 43 61 6c 6c 43 6f 75 6e 74 2a 29  ruct CallCount*)
1ac0: 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74  sqlite3_aggregat
1ad0: 65 5f 63 6f 6e 74 65 78 74 28 70 43 74 78 2c 20  e_context(pCtx, 
1ae0: 73 69 7a 65 6f 66 28 2a 70 29 29 3b 0a 20 20 69  sizeof(*p));.  i
1af0: 66 28 20 70 20 29 7b 0a 20 20 20 20 70 2d 3e 6e  f( p ){.    p->n
1b00: 53 74 65 70 2b 2b 3b 0a 20 20 20 20 69 66 28 20  Step++;.    if( 
1b10: 70 2d 3e 6e 56 61 6c 75 65 3d 3d 30 20 29 7b 0a  p->nValue==0 ){.
1b20: 20 20 20 20 20 20 70 2d 3e 6e 56 61 6c 75 65 20        p->nValue 
1b30: 3d 20 70 2d 3e 6e 53 74 65 70 3b 0a 20 20 20 20  = p->nStep;.    
1b40: 7d 0a 20 20 7d 0a 7d 0a 73 74 61 74 69 63 20 76  }.  }.}.static v
1b50: 6f 69 64 20 72 61 6e 6b 49 6e 76 46 75 6e 63 28  oid rankInvFunc(
1b60: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65  .  sqlite3_conte
1b70: 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74  xt *pCtx, .  int
1b80: 20 6e 41 72 67 2c 0a 20 20 73 71 6c 69 74 65 33   nArg,.  sqlite3
1b90: 5f 76 61 6c 75 65 20 2a 2a 61 70 41 72 67 0a 29  _value **apArg.)
1ba0: 7b 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20  {.}.static void 
1bb0: 72 61 6e 6b 56 61 6c 75 65 46 75 6e 63 28 73 71  rankValueFunc(sq
1bc0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
1bd0: 43 74 78 29 7b 0a 20 20 73 74 72 75 63 74 20 43  Ctx){.  struct C
1be0: 61 6c 6c 43 6f 75 6e 74 20 2a 70 3b 0a 20 20 70  allCount *p;.  p
1bf0: 20 3d 20 28 73 74 72 75 63 74 20 43 61 6c 6c 43   = (struct CallC
1c00: 6f 75 6e 74 2a 29 73 71 6c 69 74 65 33 5f 61 67  ount*)sqlite3_ag
1c10: 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 28  gregate_context(
1c20: 70 43 74 78 2c 20 73 69 7a 65 6f 66 28 2a 70 29  pCtx, sizeof(*p)
1c30: 29 3b 0a 20 20 69 66 28 20 70 20 29 7b 0a 20 20  );.  if( p ){.  
1c40: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
1c50: 5f 69 6e 74 36 34 28 70 43 74 78 2c 20 70 2d 3e  _int64(pCtx, p->
1c60: 6e 56 61 6c 75 65 29 3b 0a 20 20 20 20 70 2d 3e  nValue);.    p->
1c70: 6e 56 61 6c 75 65 20 3d 20 30 3b 0a 20 20 7d 0a  nValue = 0;.  }.
1c80: 7d 0a 0a 2f 2a 0a 2a 2a 20 49 6d 70 6c 65 6d 65  }../*.** Impleme
1c90: 6e 74 61 74 69 6f 6e 20 6f 66 20 62 75 69 6c 74  ntation of built
1ca0: 2d 69 6e 20 77 69 6e 64 6f 77 20 66 75 6e 63 74  -in window funct
1cb0: 69 6f 6e 20 70 65 72 63 65 6e 74 5f 72 61 6e 6b  ion percent_rank
1cc0: 28 29 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  ()..*/.static vo
1cd0: 69 64 20 70 65 72 63 65 6e 74 5f 72 61 6e 6b 53  id percent_rankS
1ce0: 74 65 70 46 75 6e 63 28 0a 20 20 73 71 6c 69 74  tepFunc(.  sqlit
1cf0: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78  e3_context *pCtx
1d00: 2c 20 0a 20 20 69 6e 74 20 6e 41 72 67 2c 0a 20  , .  int nArg,. 
1d10: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a   sqlite3_value *
1d20: 2a 61 70 41 72 67 0a 29 7b 0a 20 20 73 74 72 75  *apArg.){.  stru
1d30: 63 74 20 43 61 6c 6c 43 6f 75 6e 74 20 2a 70 3b  ct CallCount *p;
1d40: 0a 20 20 61 73 73 65 72 74 28 20 6e 41 72 67 3d  .  assert( nArg=
1d50: 3d 31 20 29 3b 0a 0a 20 20 70 20 3d 20 28 73 74  =1 );..  p = (st
1d60: 72 75 63 74 20 43 61 6c 6c 43 6f 75 6e 74 2a 29  ruct CallCount*)
1d70: 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74  sqlite3_aggregat
1d80: 65 5f 63 6f 6e 74 65 78 74 28 70 43 74 78 2c 20  e_context(pCtx, 
1d90: 73 69 7a 65 6f 66 28 2a 70 29 29 3b 0a 20 20 69  sizeof(*p));.  i
1da0: 66 28 20 70 20 29 7b 0a 20 20 20 20 69 66 28 20  f( p ){.    if( 
1db0: 70 2d 3e 6e 54 6f 74 61 6c 3d 3d 30 20 29 7b 0a  p->nTotal==0 ){.
1dc0: 20 20 20 20 20 20 70 2d 3e 6e 54 6f 74 61 6c 20        p->nTotal 
1dd0: 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f  = sqlite3_value_
1de0: 69 6e 74 36 34 28 61 70 41 72 67 5b 30 5d 29 3b  int64(apArg[0]);
1df0: 0a 20 20 20 20 7d 0a 20 20 20 20 70 2d 3e 6e 53  .    }.    p->nS
1e00: 74 65 70 2b 2b 3b 0a 20 20 20 20 69 66 28 20 70  tep++;.    if( p
1e10: 2d 3e 6e 56 61 6c 75 65 3d 3d 30 20 29 7b 0a 20  ->nValue==0 ){. 
1e20: 20 20 20 20 20 70 2d 3e 6e 56 61 6c 75 65 20 3d       p->nValue =
1e30: 20 70 2d 3e 6e 53 74 65 70 3b 0a 20 20 20 20 7d   p->nStep;.    }
1e40: 0a 20 20 7d 0a 7d 0a 73 74 61 74 69 63 20 76 6f  .  }.}.static vo
1e50: 69 64 20 70 65 72 63 65 6e 74 5f 72 61 6e 6b 49  id percent_rankI
1e60: 6e 76 46 75 6e 63 28 0a 20 20 73 71 6c 69 74 65  nvFunc(.  sqlite
1e70: 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78 2c  3_context *pCtx,
1e80: 20 0a 20 20 69 6e 74 20 6e 41 72 67 2c 0a 20 20   .  int nArg,.  
1e90: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a  sqlite3_value **
1ea0: 61 70 41 72 67 0a 29 7b 0a 7d 0a 73 74 61 74 69  apArg.){.}.stati
1eb0: 63 20 76 6f 69 64 20 70 65 72 63 65 6e 74 5f 72  c void percent_r
1ec0: 61 6e 6b 56 61 6c 75 65 46 75 6e 63 28 73 71 6c  ankValueFunc(sql
1ed0: 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43  ite3_context *pC
1ee0: 74 78 29 7b 0a 20 20 73 74 72 75 63 74 20 43 61  tx){.  struct Ca
1ef0: 6c 6c 43 6f 75 6e 74 20 2a 70 3b 0a 20 20 70 20  llCount *p;.  p 
1f00: 3d 20 28 73 74 72 75 63 74 20 43 61 6c 6c 43 6f  = (struct CallCo
1f10: 75 6e 74 2a 29 73 71 6c 69 74 65 33 5f 61 67 67  unt*)sqlite3_agg
1f20: 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 28 70  regate_context(p
1f30: 43 74 78 2c 20 73 69 7a 65 6f 66 28 2a 70 29 29  Ctx, sizeof(*p))
1f40: 3b 0a 20 20 69 66 28 20 70 20 29 7b 0a 20 20 20  ;.  if( p ){.   
1f50: 20 69 66 28 20 70 2d 3e 6e 54 6f 74 61 6c 3e 31   if( p->nTotal>1
1f60: 20 29 7b 0a 20 20 20 20 20 20 64 6f 75 62 6c 65   ){.      double
1f70: 20 72 20 3d 20 28 64 6f 75 62 6c 65 29 28 70 2d   r = (double)(p-
1f80: 3e 6e 56 61 6c 75 65 2d 31 29 20 2f 20 28 64 6f  >nValue-1) / (do
1f90: 75 62 6c 65 29 28 70 2d 3e 6e 54 6f 74 61 6c 2d  uble)(p->nTotal-
1fa0: 31 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  1);.      sqlite
1fb0: 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 28  3_result_double(
1fc0: 70 43 74 78 2c 20 72 29 3b 0a 20 20 20 20 7d 65  pCtx, r);.    }e
1fd0: 6c 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  lse{.      sqlit
1fe0: 65 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65  e3_result_double
1ff0: 28 70 43 74 78 2c 20 31 30 30 2e 30 29 3b 0a 20  (pCtx, 100.0);. 
2000: 20 20 20 7d 0a 20 20 20 20 70 2d 3e 6e 56 61 6c     }.    p->nVal
2010: 75 65 20 3d 20 30 3b 0a 20 20 7d 0a 7d 0a 0a 73  ue = 0;.  }.}..s
2020: 74 61 74 69 63 20 76 6f 69 64 20 63 75 6d 65 5f  tatic void cume_
2030: 64 69 73 74 53 74 65 70 46 75 6e 63 28 0a 20 20  distStepFunc(.  
2040: 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20  sqlite3_context 
2050: 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74 20 6e 41  *pCtx, .  int nA
2060: 72 67 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61  rg,.  sqlite3_va
2070: 6c 75 65 20 2a 2a 61 70 41 72 67 0a 29 7b 0a 20  lue **apArg.){. 
2080: 20 73 74 72 75 63 74 20 43 61 6c 6c 43 6f 75 6e   struct CallCoun
2090: 74 20 2a 70 3b 0a 20 20 61 73 73 65 72 74 28 20  t *p;.  assert( 
20a0: 6e 41 72 67 3d 3d 31 20 29 3b 0a 0a 20 20 70 20  nArg==1 );..  p 
20b0: 3d 20 28 73 74 72 75 63 74 20 43 61 6c 6c 43 6f  = (struct CallCo
20c0: 75 6e 74 2a 29 73 71 6c 69 74 65 33 5f 61 67 67  unt*)sqlite3_agg
20d0: 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 28 70  regate_context(p
20e0: 43 74 78 2c 20 73 69 7a 65 6f 66 28 2a 70 29 29  Ctx, sizeof(*p))
20f0: 3b 0a 20 20 69 66 28 20 70 20 29 7b 0a 20 20 20  ;.  if( p ){.   
2100: 20 69 66 28 20 70 2d 3e 6e 54 6f 74 61 6c 3d 3d   if( p->nTotal==
2110: 30 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 6e 54  0 ){.      p->nT
2120: 6f 74 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76  otal = sqlite3_v
2130: 61 6c 75 65 5f 69 6e 74 36 34 28 61 70 41 72 67  alue_int64(apArg
2140: 5b 30 5d 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  [0]);.    }.    
2150: 70 2d 3e 6e 53 74 65 70 2b 2b 3b 0a 20 20 7d 0a  p->nStep++;.  }.
2160: 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 63 75  }.static void cu
2170: 6d 65 5f 64 69 73 74 49 6e 76 46 75 6e 63 28 0a  me_distInvFunc(.
2180: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78    sqlite3_contex
2190: 74 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74 20  t *pCtx, .  int 
21a0: 6e 41 72 67 2c 0a 20 20 73 71 6c 69 74 65 33 5f  nArg,.  sqlite3_
21b0: 76 61 6c 75 65 20 2a 2a 61 70 41 72 67 0a 29 7b  value **apArg.){
21c0: 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 63  .}.static void c
21d0: 75 6d 65 5f 64 69 73 74 56 61 6c 75 65 46 75 6e  ume_distValueFun
21e0: 63 28 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  c(sqlite3_contex
21f0: 74 20 2a 70 43 74 78 29 7b 0a 20 20 73 74 72 75  t *pCtx){.  stru
2200: 63 74 20 43 61 6c 6c 43 6f 75 6e 74 20 2a 70 3b  ct CallCount *p;
2210: 0a 20 20 70 20 3d 20 28 73 74 72 75 63 74 20 43  .  p = (struct C
2220: 61 6c 6c 43 6f 75 6e 74 2a 29 73 71 6c 69 74 65  allCount*)sqlite
2230: 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74  3_aggregate_cont
2240: 65 78 74 28 70 43 74 78 2c 20 73 69 7a 65 6f 66  ext(pCtx, sizeof
2250: 28 2a 70 29 29 3b 0a 20 20 69 66 28 20 70 20 29  (*p));.  if( p )
2260: 7b 0a 20 20 20 20 64 6f 75 62 6c 65 20 72 20 3d  {.    double r =
2270: 20 28 64 6f 75 62 6c 65 29 28 70 2d 3e 6e 53 74   (double)(p->nSt
2280: 65 70 29 20 2f 20 28 64 6f 75 62 6c 65 29 28 70  ep) / (double)(p
2290: 2d 3e 6e 54 6f 74 61 6c 29 3b 0a 20 20 20 20 73  ->nTotal);.    s
22a0: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 64 6f  qlite3_result_do
22b0: 75 62 6c 65 28 70 43 74 78 2c 20 72 29 3b 0a 20  uble(pCtx, r);. 
22c0: 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 74   }.}../*.** Cont
22d0: 65 78 74 20 6f 62 6a 65 63 74 20 66 6f 72 20 6e  ext object for n
22e0: 74 69 6c 65 28 29 20 77 69 6e 64 6f 77 20 66 75  tile() window fu
22f0: 6e 63 74 69 6f 6e 2e 0a 2a 2f 0a 73 74 72 75 63  nction..*/.struc
2300: 74 20 4e 74 69 6c 65 43 74 78 20 7b 0a 20 20 69  t NtileCtx {.  i
2310: 36 34 20 6e 54 6f 74 61 6c 3b 20 20 20 20 20 20  64 nTotal;      
2320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2330: 2a 20 54 6f 74 61 6c 20 72 6f 77 73 20 69 6e 20  * Total rows in 
2340: 70 61 72 74 69 74 69 6f 6e 20 2a 2f 0a 20 20 69  partition */.  i
2350: 36 34 20 6e 50 61 72 61 6d 3b 20 20 20 20 20 20  64 nParam;      
2360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2370: 2a 20 50 61 72 61 6d 65 74 65 72 20 70 61 73 73  * Parameter pass
2380: 65 64 20 74 6f 20 6e 74 69 6c 65 28 4e 29 20 2a  ed to ntile(N) *
2390: 2f 0a 20 20 69 36 34 20 69 52 6f 77 3b 20 20 20  /.  i64 iRow;   
23a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
23b0: 20 20 20 20 2f 2a 20 43 75 72 72 65 6e 74 20 72      /* Current r
23c0: 6f 77 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  ow */.};../*.** 
23d0: 49 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f  Implementation o
23e0: 66 20 6e 74 69 6c 65 28 29 2e 20 54 68 69 73 20  f ntile(). This 
23f0: 61 73 73 75 6d 65 73 20 74 68 61 74 20 74 68 65  assumes that the
2400: 20 77 69 6e 64 6f 77 20 66 72 61 6d 65 20 68 61   window frame ha
2410: 73 0a 2a 2a 20 62 65 65 6e 20 63 6f 65 72 63 65  s.** been coerce
2420: 64 20 74 6f 3a 0a 2a 2a 0a 2a 2a 20 20 20 52 4f  d to:.**.**   RO
2430: 57 53 20 55 4e 42 4f 55 4e 44 45 44 20 50 52 45  WS UNBOUNDED PRE
2440: 43 45 44 49 4e 47 20 41 4e 44 20 43 55 52 52 45  CEDING AND CURRE
2450: 4e 54 20 52 4f 57 0a 2a 2f 0a 73 74 61 74 69 63  NT ROW.*/.static
2460: 20 76 6f 69 64 20 6e 74 69 6c 65 53 74 65 70 46   void ntileStepF
2470: 75 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63  unc(.  sqlite3_c
2480: 6f 6e 74 65 78 74 20 2a 70 43 74 78 2c 20 0a 20  ontext *pCtx, . 
2490: 20 69 6e 74 20 6e 41 72 67 2c 0a 20 20 73 71 6c   int nArg,.  sql
24a0: 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 41  ite3_value **apA
24b0: 72 67 0a 29 7b 0a 20 20 73 74 72 75 63 74 20 4e  rg.){.  struct N
24c0: 74 69 6c 65 43 74 78 20 2a 70 3b 0a 20 20 61 73  tileCtx *p;.  as
24d0: 73 65 72 74 28 20 6e 41 72 67 3d 3d 32 20 29 3b  sert( nArg==2 );
24e0: 0a 20 20 70 20 3d 20 28 73 74 72 75 63 74 20 4e  .  p = (struct N
24f0: 74 69 6c 65 43 74 78 2a 29 73 71 6c 69 74 65 33  tileCtx*)sqlite3
2500: 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65  _aggregate_conte
2510: 78 74 28 70 43 74 78 2c 20 73 69 7a 65 6f 66 28  xt(pCtx, sizeof(
2520: 2a 70 29 29 3b 0a 20 20 69 66 28 20 70 20 29 7b  *p));.  if( p ){
2530: 0a 20 20 20 20 69 66 28 20 70 2d 3e 6e 54 6f 74  .    if( p->nTot
2540: 61 6c 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 70  al==0 ){.      p
2550: 2d 3e 6e 50 61 72 61 6d 20 3d 20 73 71 6c 69 74  ->nParam = sqlit
2560: 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28 61  e3_value_int64(a
2570: 70 41 72 67 5b 30 5d 29 3b 0a 20 20 20 20 20 20  pArg[0]);.      
2580: 70 2d 3e 6e 54 6f 74 61 6c 20 3d 20 73 71 6c 69  p->nTotal = sqli
2590: 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28  te3_value_int64(
25a0: 61 70 41 72 67 5b 31 5d 29 3b 0a 20 20 20 20 20  apArg[1]);.     
25b0: 20 69 66 28 20 70 2d 3e 6e 50 61 72 61 6d 3c 3d   if( p->nParam<=
25c0: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  0 ){.        sql
25d0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 65 72 72 6f  ite3_result_erro
25e0: 72 28 0a 20 20 20 20 20 20 20 20 20 20 20 20 70  r(.            p
25f0: 43 74 78 2c 20 22 61 72 67 75 6d 65 6e 74 20 6f  Ctx, "argument o
2600: 66 20 6e 74 69 6c 65 20 6d 75 73 74 20 62 65 20  f ntile must be 
2610: 61 20 70 6f 73 69 74 69 76 65 20 69 6e 74 65 67  a positive integ
2620: 65 72 22 2c 20 2d 31 0a 20 20 20 20 20 20 20 20  er", -1.        
2630: 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  );.      }.    }
2640: 0a 20 20 20 20 70 2d 3e 69 52 6f 77 2b 2b 3b 0a  .    p->iRow++;.
2650: 20 20 7d 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69    }.}.static voi
2660: 64 20 6e 74 69 6c 65 49 6e 76 46 75 6e 63 28 0a  d ntileInvFunc(.
2670: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78    sqlite3_contex
2680: 74 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74 20  t *pCtx, .  int 
2690: 6e 41 72 67 2c 0a 20 20 73 71 6c 69 74 65 33 5f  nArg,.  sqlite3_
26a0: 76 61 6c 75 65 20 2a 2a 61 70 41 72 67 0a 29 7b  value **apArg.){
26b0: 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 6e  .}.static void n
26c0: 74 69 6c 65 56 61 6c 75 65 46 75 6e 63 28 73 71  tileValueFunc(sq
26d0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
26e0: 43 74 78 29 7b 0a 20 20 73 74 72 75 63 74 20 4e  Ctx){.  struct N
26f0: 74 69 6c 65 43 74 78 20 2a 70 3b 0a 20 20 70 20  tileCtx *p;.  p 
2700: 3d 20 28 73 74 72 75 63 74 20 4e 74 69 6c 65 43  = (struct NtileC
2710: 74 78 2a 29 73 71 6c 69 74 65 33 5f 61 67 67 72  tx*)sqlite3_aggr
2720: 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 28 70 43  egate_context(pC
2730: 74 78 2c 20 73 69 7a 65 6f 66 28 2a 70 29 29 3b  tx, sizeof(*p));
2740: 0a 20 20 69 66 28 20 70 20 26 26 20 70 2d 3e 6e  .  if( p && p->n
2750: 50 61 72 61 6d 3e 30 20 29 7b 0a 20 20 20 20 69  Param>0 ){.    i
2760: 6e 74 20 6e 53 69 7a 65 20 3d 20 28 70 2d 3e 6e  nt nSize = (p->n
2770: 54 6f 74 61 6c 20 2f 20 70 2d 3e 6e 50 61 72 61  Total / p->nPara
2780: 6d 29 3b 0a 20 20 20 20 69 66 28 20 6e 53 69 7a  m);.    if( nSiz
2790: 65 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 73 71  e==0 ){.      sq
27a0: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74  lite3_result_int
27b0: 36 34 28 70 43 74 78 2c 20 70 2d 3e 69 52 6f 77  64(pCtx, p->iRow
27c0: 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  );.    }else{.  
27d0: 20 20 20 20 69 36 34 20 6e 4c 61 72 67 65 20 3d      i64 nLarge =
27e0: 20 70 2d 3e 6e 54 6f 74 61 6c 20 2d 20 70 2d 3e   p->nTotal - p->
27f0: 6e 50 61 72 61 6d 2a 6e 53 69 7a 65 3b 0a 20 20  nParam*nSize;.  
2800: 20 20 20 20 69 36 34 20 69 53 6d 61 6c 6c 20 3d      i64 iSmall =
2810: 20 6e 4c 61 72 67 65 2a 28 6e 53 69 7a 65 2b 31   nLarge*(nSize+1
2820: 29 3b 0a 20 20 20 20 20 20 69 36 34 20 69 52 6f  );.      i64 iRo
2830: 77 20 3d 20 70 2d 3e 69 52 6f 77 2d 31 3b 0a 0a  w = p->iRow-1;..
2840: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 28 6e        assert( (n
2850: 4c 61 72 67 65 2a 28 6e 53 69 7a 65 2b 31 29 20  Large*(nSize+1) 
2860: 2b 20 28 70 2d 3e 6e 50 61 72 61 6d 2d 6e 4c 61  + (p->nParam-nLa
2870: 72 67 65 29 2a 6e 53 69 7a 65 29 3d 3d 70 2d 3e  rge)*nSize)==p->
2880: 6e 54 6f 74 61 6c 20 29 3b 0a 0a 20 20 20 20 20  nTotal );..     
2890: 20 69 66 28 20 69 52 6f 77 3c 69 53 6d 61 6c 6c   if( iRow<iSmall
28a0: 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69   ){.        sqli
28b0: 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34  te3_result_int64
28c0: 28 70 43 74 78 2c 20 31 20 2b 20 69 52 6f 77 2f  (pCtx, 1 + iRow/
28d0: 28 6e 53 69 7a 65 2b 31 29 29 3b 0a 20 20 20 20  (nSize+1));.    
28e0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20    }else{.       
28f0: 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f   sqlite3_result_
2900: 69 6e 74 36 34 28 70 43 74 78 2c 20 31 20 2b 20  int64(pCtx, 1 + 
2910: 6e 4c 61 72 67 65 20 2b 20 28 69 52 6f 77 2d 69  nLarge + (iRow-i
2920: 53 6d 61 6c 6c 29 2f 6e 53 69 7a 65 29 3b 0a 20  Small)/nSize);. 
2930: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d       }.    }.  }
2940: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 74 65 78  .}../*.** Contex
2950: 74 20 6f 62 6a 65 63 74 20 66 6f 72 20 6c 61 73  t object for las
2960: 74 5f 76 61 6c 75 65 28 29 20 77 69 6e 64 6f 77  t_value() window
2970: 20 66 75 6e 63 74 69 6f 6e 2e 0a 2a 2f 0a 73 74   function..*/.st
2980: 72 75 63 74 20 4c 61 73 74 56 61 6c 75 65 43 74  ruct LastValueCt
2990: 78 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f 76 61  x {.  sqlite3_va
29a0: 6c 75 65 20 2a 70 56 61 6c 3b 0a 20 20 69 6e 74  lue *pVal;.  int
29b0: 20 6e 56 61 6c 3b 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a   nVal;.};../*.**
29c0: 20 49 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20   Implementation 
29d0: 6f 66 20 6c 61 73 74 5f 76 61 6c 75 65 28 29 2e  of last_value().
29e0: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
29f0: 6c 61 73 74 5f 76 61 6c 75 65 53 74 65 70 46 75  last_valueStepFu
2a00: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
2a10: 6e 74 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20  ntext *pCtx, .  
2a20: 69 6e 74 20 6e 41 72 67 2c 0a 20 20 73 71 6c 69  int nArg,.  sqli
2a30: 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 41 72  te3_value **apAr
2a40: 67 0a 29 7b 0a 20 20 73 74 72 75 63 74 20 4c 61  g.){.  struct La
2a50: 73 74 56 61 6c 75 65 43 74 78 20 2a 70 3b 0a 20  stValueCtx *p;. 
2a60: 20 70 20 3d 20 28 73 74 72 75 63 74 20 4c 61 73   p = (struct Las
2a70: 74 56 61 6c 75 65 43 74 78 20 2a 29 73 71 6c 69  tValueCtx *)sqli
2a80: 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f  te3_aggregate_co
2a90: 6e 74 65 78 74 28 70 43 74 78 2c 20 73 69 7a 65  ntext(pCtx, size
2aa0: 6f 66 28 2a 70 29 29 3b 0a 20 20 69 66 28 20 70  of(*p));.  if( p
2ab0: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f   ){.    sqlite3_
2ac0: 76 61 6c 75 65 5f 66 72 65 65 28 70 2d 3e 70 56  value_free(p->pV
2ad0: 61 6c 29 3b 0a 20 20 20 20 70 2d 3e 70 56 61 6c  al);.    p->pVal
2ae0: 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65   = sqlite3_value
2af0: 5f 64 75 70 28 61 70 41 72 67 5b 30 5d 29 3b 0a  _dup(apArg[0]);.
2b00: 20 20 20 20 70 2d 3e 6e 56 61 6c 2b 2b 3b 0a 20      p->nVal++;. 
2b10: 20 7d 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69 64   }.}.static void
2b20: 20 6c 61 73 74 5f 76 61 6c 75 65 49 6e 76 46 75   last_valueInvFu
2b30: 6e 63 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  nc(.  sqlite3_co
2b40: 6e 74 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20  ntext *pCtx, .  
2b50: 69 6e 74 20 6e 41 72 67 2c 0a 20 20 73 71 6c 69  int nArg,.  sqli
2b60: 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 41 72  te3_value **apAr
2b70: 67 0a 29 7b 0a 20 20 73 74 72 75 63 74 20 4c 61  g.){.  struct La
2b80: 73 74 56 61 6c 75 65 43 74 78 20 2a 70 3b 0a 20  stValueCtx *p;. 
2b90: 20 70 20 3d 20 28 73 74 72 75 63 74 20 4c 61 73   p = (struct Las
2ba0: 74 56 61 6c 75 65 43 74 78 20 2a 29 73 71 6c 69  tValueCtx *)sqli
2bb0: 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f  te3_aggregate_co
2bc0: 6e 74 65 78 74 28 70 43 74 78 2c 20 73 69 7a 65  ntext(pCtx, size
2bd0: 6f 66 28 2a 70 29 29 3b 0a 20 20 69 66 28 20 70  of(*p));.  if( p
2be0: 20 29 7b 0a 20 20 20 20 70 2d 3e 6e 56 61 6c 2d   ){.    p->nVal-
2bf0: 2d 3b 0a 20 20 20 20 69 66 28 20 70 2d 3e 6e 56  -;.    if( p->nV
2c00: 61 6c 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 73  al==0 ){.      s
2c10: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 66 72 65  qlite3_value_fre
2c20: 65 28 70 2d 3e 70 56 61 6c 29 3b 0a 20 20 20 20  e(p->pVal);.    
2c30: 20 20 70 2d 3e 70 56 61 6c 20 3d 20 30 3b 0a 20    p->pVal = 0;. 
2c40: 20 20 20 7d 0a 20 20 7d 0a 7d 0a 73 74 61 74 69     }.  }.}.stati
2c50: 63 20 76 6f 69 64 20 6c 61 73 74 5f 76 61 6c 75  c void last_valu
2c60: 65 56 61 6c 75 65 46 75 6e 63 28 73 71 6c 69 74  eValueFunc(sqlit
2c70: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78  e3_context *pCtx
2c80: 29 7b 0a 20 20 73 74 72 75 63 74 20 4c 61 73 74  ){.  struct Last
2c90: 56 61 6c 75 65 43 74 78 20 2a 70 3b 0a 20 20 70  ValueCtx *p;.  p
2ca0: 20 3d 20 28 73 74 72 75 63 74 20 4c 61 73 74 56   = (struct LastV
2cb0: 61 6c 75 65 43 74 78 20 2a 29 73 71 6c 69 74 65  alueCtx *)sqlite
2cc0: 33 5f 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74  3_aggregate_cont
2cd0: 65 78 74 28 70 43 74 78 2c 20 73 69 7a 65 6f 66  ext(pCtx, sizeof
2ce0: 28 2a 70 29 29 3b 0a 20 20 69 66 28 20 70 20 26  (*p));.  if( p &
2cf0: 26 20 70 2d 3e 70 56 61 6c 20 29 7b 0a 20 20 20  & p->pVal ){.   
2d00: 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f   sqlite3_result_
2d10: 76 61 6c 75 65 28 70 43 74 78 2c 20 70 2d 3e 70  value(pCtx, p->p
2d20: 56 61 6c 29 3b 0a 20 20 7d 0a 7d 0a 73 74 61 74  Val);.  }.}.stat
2d30: 69 63 20 76 6f 69 64 20 6c 61 73 74 5f 76 61 6c  ic void last_val
2d40: 75 65 46 69 6e 61 6c 69 7a 65 46 75 6e 63 28 73  ueFinalizeFunc(s
2d50: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
2d60: 70 43 74 78 29 7b 0a 20 20 73 74 72 75 63 74 20  pCtx){.  struct 
2d70: 4c 61 73 74 56 61 6c 75 65 43 74 78 20 2a 70 3b  LastValueCtx *p;
2d80: 0a 20 20 70 20 3d 20 28 73 74 72 75 63 74 20 4c  .  p = (struct L
2d90: 61 73 74 56 61 6c 75 65 43 74 78 20 2a 29 73 71  astValueCtx *)sq
2da0: 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f  lite3_aggregate_
2db0: 63 6f 6e 74 65 78 74 28 70 43 74 78 2c 20 73 69  context(pCtx, si
2dc0: 7a 65 6f 66 28 2a 70 29 29 3b 0a 20 20 69 66 28  zeof(*p));.  if(
2dd0: 20 70 20 26 26 20 70 2d 3e 70 56 61 6c 20 29 7b   p && p->pVal ){
2de0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73  .    sqlite3_res
2df0: 75 6c 74 5f 76 61 6c 75 65 28 70 43 74 78 2c 20  ult_value(pCtx, 
2e00: 70 2d 3e 70 56 61 6c 29 3b 0a 20 20 20 20 73 71  p->pVal);.    sq
2e10: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 66 72 65 65  lite3_value_free
2e20: 28 70 2d 3e 70 56 61 6c 29 3b 0a 20 20 20 20 70  (p->pVal);.    p
2e30: 2d 3e 70 56 61 6c 20 3d 20 30 3b 0a 20 20 7d 0a  ->pVal = 0;.  }.
2e40: 7d 0a 0a 2f 2a 0a 2a 2a 20 4e 6f 2d 6f 70 20 69  }../*.** No-op i
2e50: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 73 20 6f  mplementations o
2e60: 66 20 6e 74 68 5f 76 61 6c 75 65 28 29 2c 20 66  f nth_value(), f
2e70: 69 72 73 74 5f 76 61 6c 75 65 28 29 2c 20 6c 65  irst_value(), le
2e80: 61 64 28 29 20 61 6e 64 20 6c 61 67 28 29 2e 0a  ad() and lag()..
2e90: 2a 2a 20 54 68 65 73 65 20 61 72 65 20 61 6c 6c  ** These are all
2ea0: 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20 69 6e 6c   implemented inl
2eb0: 69 6e 65 20 75 73 69 6e 67 20 56 44 42 45 20 69  ine using VDBE i
2ec0: 6e 73 74 72 75 63 74 69 6f 6e 73 2e 20 0a 2a 2f  nstructions. .*/
2ed0: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 6e 74 68  .static void nth
2ee0: 5f 76 61 6c 75 65 53 74 65 70 46 75 6e 63 28 73  _valueStepFunc(s
2ef0: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
2f00: 70 43 74 78 2c 20 69 6e 74 20 6e 2c 20 73 71 6c  pCtx, int n, sql
2f10: 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 29 7b  ite3_value **a){
2f20: 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 6e 74  }.static void nt
2f30: 68 5f 76 61 6c 75 65 49 6e 76 46 75 6e 63 28 73  h_valueInvFunc(s
2f40: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
2f50: 70 43 74 78 2c 20 69 6e 74 20 6e 2c 20 73 71 6c  pCtx, int n, sql
2f60: 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 29  ite3_value **ap)
2f70: 7b 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 6e  {}.static void n
2f80: 74 68 5f 76 61 6c 75 65 56 61 6c 75 65 46 75 6e  th_valueValueFun
2f90: 63 28 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  c(sqlite3_contex
2fa0: 74 20 2a 70 43 74 78 29 7b 7d 0a 73 74 61 74 69  t *pCtx){}.stati
2fb0: 63 20 76 6f 69 64 20 66 69 72 73 74 5f 76 61 6c  c void first_val
2fc0: 75 65 53 74 65 70 46 75 6e 63 28 73 71 6c 69 74  ueStepFunc(sqlit
2fd0: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 2c 20 69  e3_context *p, i
2fe0: 6e 74 20 6e 2c 20 73 71 6c 69 74 65 33 5f 76 61  nt n, sqlite3_va
2ff0: 6c 75 65 20 2a 2a 61 70 29 7b 7d 0a 73 74 61 74  lue **ap){}.stat
3000: 69 63 20 76 6f 69 64 20 66 69 72 73 74 5f 76 61  ic void first_va
3010: 6c 75 65 49 6e 76 46 75 6e 63 28 73 71 6c 69 74  lueInvFunc(sqlit
3020: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 2c 20 69  e3_context *p, i
3030: 6e 74 20 6e 2c 20 73 71 6c 69 74 65 33 5f 76 61  nt n, sqlite3_va
3040: 6c 75 65 20 2a 2a 61 70 29 7b 7d 0a 73 74 61 74  lue **ap){}.stat
3050: 69 63 20 76 6f 69 64 20 66 69 72 73 74 5f 76 61  ic void first_va
3060: 6c 75 65 56 61 6c 75 65 46 75 6e 63 28 73 71 6c  lueValueFunc(sql
3070: 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43  ite3_context *pC
3080: 74 78 29 7b 7d 0a 73 74 61 74 69 63 20 76 6f 69  tx){}.static voi
3090: 64 20 6c 65 61 64 53 74 65 70 46 75 6e 63 28 73  d leadStepFunc(s
30a0: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
30b0: 70 43 74 78 2c 20 69 6e 74 20 6e 2c 20 73 71 6c  pCtx, int n, sql
30c0: 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70 29  ite3_value **ap)
30d0: 7b 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 6c  {}.static void l
30e0: 65 61 64 49 6e 76 46 75 6e 63 28 73 71 6c 69 74  eadInvFunc(sqlit
30f0: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78  e3_context *pCtx
3100: 2c 20 69 6e 74 20 6e 2c 20 73 71 6c 69 74 65 33  , int n, sqlite3
3110: 5f 76 61 6c 75 65 20 2a 2a 61 70 29 7b 7d 0a 73  _value **ap){}.s
3120: 74 61 74 69 63 20 76 6f 69 64 20 6c 65 61 64 56  tatic void leadV
3130: 61 6c 75 65 46 75 6e 63 28 73 71 6c 69 74 65 33  alueFunc(sqlite3
3140: 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78 29 7b  _context *pCtx){
3150: 7d 0a 73 74 61 74 69 63 20 76 6f 69 64 20 6c 61  }.static void la
3160: 67 53 74 65 70 46 75 6e 63 28 73 71 6c 69 74 65  gStepFunc(sqlite
3170: 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78 2c  3_context *pCtx,
3180: 20 69 6e 74 20 6e 2c 20 73 71 6c 69 74 65 33 5f   int n, sqlite3_
3190: 76 61 6c 75 65 20 2a 2a 61 70 29 7b 7d 0a 73 74  value **ap){}.st
31a0: 61 74 69 63 20 76 6f 69 64 20 6c 61 67 49 6e 76  atic void lagInv
31b0: 46 75 6e 63 28 73 71 6c 69 74 65 33 5f 63 6f 6e  Func(sqlite3_con
31c0: 74 65 78 74 20 2a 70 43 74 78 2c 20 69 6e 74 20  text *pCtx, int 
31d0: 6e 2c 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  n, sqlite3_value
31e0: 20 2a 2a 61 70 29 7b 7d 0a 73 74 61 74 69 63 20   **ap){}.static 
31f0: 76 6f 69 64 20 6c 61 67 56 61 6c 75 65 46 75 6e  void lagValueFun
3200: 63 28 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  c(sqlite3_contex
3210: 74 20 2a 70 43 74 78 29 7b 7d 0a 0a 23 64 65 66  t *pCtx){}..#def
3220: 69 6e 65 20 57 49 4e 44 4f 57 46 55 4e 43 28 6e  ine WINDOWFUNC(n
3230: 61 6d 65 2c 6e 41 72 67 2c 65 78 74 72 61 29 20  ame,nArg,extra) 
3240: 7b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {               
3250: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3260: 20 20 20 20 20 20 20 5c 0a 20 20 6e 41 72 67 2c         \.  nArg,
3270: 20 28 53 51 4c 49 54 45 5f 55 54 46 38 7c 53 51   (SQLITE_UTF8|SQ
3280: 4c 49 54 45 5f 46 55 4e 43 5f 57 49 4e 44 4f 57  LITE_FUNC_WINDOW
3290: 7c 65 78 74 72 61 29 2c 20 30 2c 20 30 2c 20 20  |extra), 0, 0,  
32a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
32b0: 20 20 20 20 5c 0a 20 20 6e 61 6d 65 20 23 23 20      \.  name ## 
32c0: 53 74 65 70 46 75 6e 63 2c 20 6e 61 6d 65 20 23  StepFunc, name #
32d0: 23 20 56 61 6c 75 65 46 75 6e 63 2c 20 6e 61 6d  # ValueFunc, nam
32e0: 65 20 23 23 20 56 61 6c 75 65 46 75 6e 63 2c 20  e ## ValueFunc, 
32f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3300: 20 5c 0a 20 20 6e 61 6d 65 20 23 23 20 49 6e 76   \.  name ## Inv
3310: 46 75 6e 63 2c 20 23 6e 61 6d 65 20 20 20 20 20  Func, #name     
3320: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3330: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3340: 20 20 20 20 20 20 20 20 20 20 5c 0a 7d 0a 0a 23            \.}..#
3350: 64 65 66 69 6e 65 20 57 49 4e 44 4f 57 46 55 4e  define WINDOWFUN
3360: 43 46 28 6e 61 6d 65 2c 6e 41 72 67 2c 65 78 74  CF(name,nArg,ext
3370: 72 61 29 20 7b 20 20 20 20 20 20 20 20 20 20 20  ra) {           
3380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3390: 20 20 20 20 20 20 20 20 20 20 5c 0a 20 20 6e 41            \.  nA
33a0: 72 67 2c 20 28 53 51 4c 49 54 45 5f 55 54 46 38  rg, (SQLITE_UTF8
33b0: 7c 53 51 4c 49 54 45 5f 46 55 4e 43 5f 57 49 4e  |SQLITE_FUNC_WIN
33c0: 44 4f 57 7c 65 78 74 72 61 29 2c 20 30 2c 20 30  DOW|extra), 0, 0
33d0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
33e0: 20 20 20 20 20 20 20 5c 0a 20 20 6e 61 6d 65 20         \.  name 
33f0: 23 23 20 53 74 65 70 46 75 6e 63 2c 20 6e 61 6d  ## StepFunc, nam
3400: 65 20 23 23 20 46 69 6e 61 6c 69 7a 65 46 75 6e  e ## FinalizeFun
3410: 63 2c 20 6e 61 6d 65 20 23 23 20 56 61 6c 75 65  c, name ## Value
3420: 46 75 6e 63 2c 20 20 20 20 20 20 20 20 20 20 20  Func,           
3430: 20 20 20 20 5c 0a 20 20 6e 61 6d 65 20 23 23 20      \.  name ## 
3440: 49 6e 76 46 75 6e 63 2c 20 23 6e 61 6d 65 20 20  InvFunc, #name  
3450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3460: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3470: 20 20 20 20 20 20 20 20 20 20 20 20 20 5c 0a 7d               \.}
3480: 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73 74 65 72  ../*.** Register
3490: 20 74 68 6f 73 65 20 62 75 69 6c 74 2d 69 6e 20   those built-in 
34a0: 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e 73  window functions
34b0: 20 74 68 61 74 20 61 72 65 20 6e 6f 74 20 61 6c   that are not al
34c0: 73 6f 20 61 67 67 72 65 67 61 74 65 73 2e 0a 2a  so aggregates..*
34d0: 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 57 69  /.void sqlite3Wi
34e0: 6e 64 6f 77 46 75 6e 63 74 69 6f 6e 73 28 76 6f  ndowFunctions(vo
34f0: 69 64 29 7b 0a 20 20 73 74 61 74 69 63 20 46 75  id){.  static Fu
3500: 6e 63 44 65 66 20 61 57 69 6e 64 6f 77 46 75 6e  ncDef aWindowFun
3510: 63 73 5b 5d 20 3d 20 7b 0a 20 20 20 20 57 49 4e  cs[] = {.    WIN
3520: 44 4f 57 46 55 4e 43 28 72 6f 77 5f 6e 75 6d 62  DOWFUNC(row_numb
3530: 65 72 2c 20 30 2c 20 30 29 2c 0a 20 20 20 20 57  er, 0, 0),.    W
3540: 49 4e 44 4f 57 46 55 4e 43 28 64 65 6e 73 65 5f  INDOWFUNC(dense_
3550: 72 61 6e 6b 2c 20 30 2c 20 30 29 2c 0a 20 20 20  rank, 0, 0),.   
3560: 20 57 49 4e 44 4f 57 46 55 4e 43 28 72 61 6e 6b   WINDOWFUNC(rank
3570: 2c 20 30 2c 20 30 29 2c 0a 20 20 20 20 57 49 4e  , 0, 0),.    WIN
3580: 44 4f 57 46 55 4e 43 28 70 65 72 63 65 6e 74 5f  DOWFUNC(percent_
3590: 72 61 6e 6b 2c 20 30 2c 20 53 51 4c 49 54 45 5f  rank, 0, SQLITE_
35a0: 46 55 4e 43 5f 57 49 4e 44 4f 57 5f 53 49 5a 45  FUNC_WINDOW_SIZE
35b0: 29 2c 0a 20 20 20 20 57 49 4e 44 4f 57 46 55 4e  ),.    WINDOWFUN
35c0: 43 28 63 75 6d 65 5f 64 69 73 74 2c 20 30 2c 20  C(cume_dist, 0, 
35d0: 53 51 4c 49 54 45 5f 46 55 4e 43 5f 57 49 4e 44  SQLITE_FUNC_WIND
35e0: 4f 57 5f 53 49 5a 45 29 2c 0a 20 20 20 20 57 49  OW_SIZE),.    WI
35f0: 4e 44 4f 57 46 55 4e 43 28 6e 74 69 6c 65 2c 20  NDOWFUNC(ntile, 
3600: 31 2c 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f 57  1, SQLITE_FUNC_W
3610: 49 4e 44 4f 57 5f 53 49 5a 45 29 2c 0a 20 20 20  INDOW_SIZE),.   
3620: 20 57 49 4e 44 4f 57 46 55 4e 43 46 28 6c 61 73   WINDOWFUNCF(las
3630: 74 5f 76 61 6c 75 65 2c 20 31 2c 20 30 29 2c 0a  t_value, 1, 0),.
3640: 20 20 20 20 57 49 4e 44 4f 57 46 55 4e 43 28 6e      WINDOWFUNC(n
3650: 74 68 5f 76 61 6c 75 65 2c 20 32 2c 20 30 29 2c  th_value, 2, 0),
3660: 0a 20 20 20 20 57 49 4e 44 4f 57 46 55 4e 43 28  .    WINDOWFUNC(
3670: 66 69 72 73 74 5f 76 61 6c 75 65 2c 20 31 2c 20  first_value, 1, 
3680: 30 29 2c 0a 20 20 20 20 57 49 4e 44 4f 57 46 55  0),.    WINDOWFU
3690: 4e 43 28 6c 65 61 64 2c 20 31 2c 20 30 29 2c 20  NC(lead, 1, 0), 
36a0: 57 49 4e 44 4f 57 46 55 4e 43 28 6c 65 61 64 2c  WINDOWFUNC(lead,
36b0: 20 32 2c 20 30 29 2c 20 57 49 4e 44 4f 57 46 55   2, 0), WINDOWFU
36c0: 4e 43 28 6c 65 61 64 2c 20 33 2c 20 30 29 2c 0a  NC(lead, 3, 0),.
36d0: 20 20 20 20 57 49 4e 44 4f 57 46 55 4e 43 28 6c      WINDOWFUNC(l
36e0: 61 67 2c 20 31 2c 20 30 29 2c 20 20 57 49 4e 44  ag, 1, 0),  WIND
36f0: 4f 57 46 55 4e 43 28 6c 61 67 2c 20 32 2c 20 30  OWFUNC(lag, 2, 0
3700: 29 2c 20 20 57 49 4e 44 4f 57 46 55 4e 43 28 6c  ),  WINDOWFUNC(l
3710: 61 67 2c 20 33 2c 20 30 29 2c 0a 20 20 7d 3b 0a  ag, 3, 0),.  };.
3720: 20 20 73 71 6c 69 74 65 33 49 6e 73 65 72 74 42    sqlite3InsertB
3730: 75 69 6c 74 69 6e 46 75 6e 63 73 28 61 57 69 6e  uiltinFuncs(aWin
3740: 64 6f 77 46 75 6e 63 73 2c 20 41 72 72 61 79 53  dowFuncs, ArrayS
3750: 69 7a 65 28 61 57 69 6e 64 6f 77 46 75 6e 63 73  ize(aWindowFuncs
3760: 29 29 3b 0a 7d 0a 0a 76 6f 69 64 20 73 71 6c 69  ));.}..void sqli
3770: 74 65 33 57 69 6e 64 6f 77 55 70 64 61 74 65 28  te3WindowUpdate(
3780: 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65  .  Parse *pParse
3790: 2c 20 0a 20 20 57 69 6e 64 6f 77 20 2a 70 4c 69  , .  Window *pLi
37a0: 73 74 2c 20 0a 20 20 57 69 6e 64 6f 77 20 2a 70  st, .  Window *p
37b0: 57 69 6e 2c 20 0a 20 20 46 75 6e 63 44 65 66 20  Win, .  FuncDef 
37c0: 2a 70 46 75 6e 63 0a 29 7b 0a 20 20 69 66 28 20  *pFunc.){.  if( 
37d0: 70 57 69 6e 2d 3e 7a 4e 61 6d 65 20 29 7b 0a 20  pWin->zName ){. 
37e0: 20 20 20 57 69 6e 64 6f 77 20 2a 70 3b 0a 20 20     Window *p;.  
37f0: 20 20 66 6f 72 28 70 3d 70 4c 69 73 74 3b 20 70    for(p=pList; p
3800: 3b 20 70 3d 70 2d 3e 70 4e 65 78 74 57 69 6e 29  ; p=p->pNextWin)
3810: 7b 0a 20 20 20 20 20 20 69 66 28 20 73 71 6c 69  {.      if( sqli
3820: 74 65 33 53 74 72 49 43 6d 70 28 70 2d 3e 7a 4e  te3StrICmp(p->zN
3830: 61 6d 65 2c 20 70 57 69 6e 2d 3e 7a 4e 61 6d 65  ame, pWin->zName
3840: 29 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20 20  )==0 ) break;.  
3850: 20 20 7d 0a 20 20 20 20 69 66 28 20 70 3d 3d 30    }.    if( p==0
3860: 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ){.      sqlite
3870: 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72 73 65  3ErrorMsg(pParse
3880: 2c 20 22 6e 6f 20 73 75 63 68 20 77 69 6e 64 6f  , "no such windo
3890: 77 3a 20 25 73 22 2c 20 70 57 69 6e 2d 3e 7a 4e  w: %s", pWin->zN
38a0: 61 6d 65 29 3b 0a 20 20 20 20 20 20 72 65 74 75  ame);.      retu
38b0: 72 6e 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70 57  rn;.    }.    pW
38c0: 69 6e 2d 3e 70 50 61 72 74 69 74 69 6f 6e 20 3d  in->pPartition =
38d0: 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73 74   sqlite3ExprList
38e0: 44 75 70 28 70 50 61 72 73 65 2d 3e 64 62 2c 20  Dup(pParse->db, 
38f0: 70 2d 3e 70 50 61 72 74 69 74 69 6f 6e 2c 20 30  p->pPartition, 0
3900: 29 3b 0a 20 20 20 20 70 57 69 6e 2d 3e 70 4f 72  );.    pWin->pOr
3910: 64 65 72 42 79 20 3d 20 73 71 6c 69 74 65 33 45  derBy = sqlite3E
3920: 78 70 72 4c 69 73 74 44 75 70 28 70 50 61 72 73  xprListDup(pPars
3930: 65 2d 3e 64 62 2c 20 70 2d 3e 70 4f 72 64 65 72  e->db, p->pOrder
3940: 42 79 2c 20 30 29 3b 0a 20 20 20 20 70 57 69 6e  By, 0);.    pWin
3950: 2d 3e 70 53 74 61 72 74 20 3d 20 73 71 6c 69 74  ->pStart = sqlit
3960: 65 33 45 78 70 72 44 75 70 28 70 50 61 72 73 65  e3ExprDup(pParse
3970: 2d 3e 64 62 2c 20 70 2d 3e 70 53 74 61 72 74 2c  ->db, p->pStart,
3980: 20 30 29 3b 0a 20 20 20 20 70 57 69 6e 2d 3e 70   0);.    pWin->p
3990: 45 6e 64 20 3d 20 73 71 6c 69 74 65 33 45 78 70  End = sqlite3Exp
39a0: 72 44 75 70 28 70 50 61 72 73 65 2d 3e 64 62 2c  rDup(pParse->db,
39b0: 20 70 2d 3e 70 45 6e 64 2c 20 30 29 3b 0a 20 20   p->pEnd, 0);.  
39c0: 20 20 70 57 69 6e 2d 3e 65 53 74 61 72 74 20 3d    pWin->eStart =
39d0: 20 70 2d 3e 65 53 74 61 72 74 3b 0a 20 20 20 20   p->eStart;.    
39e0: 70 57 69 6e 2d 3e 65 45 6e 64 20 3d 20 70 2d 3e  pWin->eEnd = p->
39f0: 65 45 6e 64 3b 0a 20 20 7d 0a 20 20 69 66 28 20  eEnd;.  }.  if( 
3a00: 70 46 75 6e 63 2d 3e 66 75 6e 63 46 6c 61 67 73  pFunc->funcFlags
3a10: 20 26 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f 57   & SQLITE_FUNC_W
3a20: 49 4e 44 4f 57 20 29 7b 0a 20 20 20 20 73 71 6c  INDOW ){.    sql
3a30: 69 74 65 33 20 2a 64 62 20 3d 20 70 50 61 72 73  ite3 *db = pPars
3a40: 65 2d 3e 64 62 3b 0a 20 20 20 20 69 66 28 20 70  e->db;.    if( p
3a50: 57 69 6e 2d 3e 70 46 69 6c 74 65 72 20 29 7b 0a  Win->pFilter ){.
3a60: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72        sqlite3Err
3a70: 6f 72 4d 73 67 28 70 50 61 72 73 65 2c 20 0a 20  orMsg(pParse, . 
3a80: 20 20 20 20 20 20 20 20 20 22 46 49 4c 54 45 52           "FILTER
3a90: 20 63 6c 61 75 73 65 20 6d 61 79 20 6f 6e 6c 79   clause may only
3aa0: 20 62 65 20 75 73 65 64 20 77 69 74 68 20 61 67   be used with ag
3ab0: 67 72 65 67 61 74 65 20 77 69 6e 64 6f 77 20 66  gregate window f
3ac0: 75 6e 63 74 69 6f 6e 73 22 0a 20 20 20 20 20 20  unctions".      
3ad0: 29 3b 0a 20 20 20 20 7d 65 6c 73 65 0a 20 20 20  );.    }else.   
3ae0: 20 69 66 28 20 70 46 75 6e 63 2d 3e 78 53 46 75   if( pFunc->xSFu
3af0: 6e 63 3d 3d 72 6f 77 5f 6e 75 6d 62 65 72 53 74  nc==row_numberSt
3b00: 65 70 46 75 6e 63 20 7c 7c 20 70 46 75 6e 63 2d  epFunc || pFunc-
3b10: 3e 78 53 46 75 6e 63 3d 3d 6e 74 69 6c 65 53 74  >xSFunc==ntileSt
3b20: 65 70 46 75 6e 63 20 29 7b 0a 20 20 20 20 20 20  epFunc ){.      
3b30: 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74  sqlite3ExprDelet
3b40: 65 28 64 62 2c 20 70 57 69 6e 2d 3e 70 53 74 61  e(db, pWin->pSta
3b50: 72 74 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  rt);.      sqlit
3b60: 65 33 45 78 70 72 44 65 6c 65 74 65 28 64 62 2c  e3ExprDelete(db,
3b70: 20 70 57 69 6e 2d 3e 70 45 6e 64 29 3b 0a 20 20   pWin->pEnd);.  
3b80: 20 20 20 20 70 57 69 6e 2d 3e 70 53 74 61 72 74      pWin->pStart
3b90: 20 3d 20 70 57 69 6e 2d 3e 70 45 6e 64 20 3d 20   = pWin->pEnd = 
3ba0: 30 3b 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e 65  0;.      pWin->e
3bb0: 54 79 70 65 20 3d 20 54 4b 5f 52 4f 57 53 3b 0a  Type = TK_ROWS;.
3bc0: 20 20 20 20 20 20 70 57 69 6e 2d 3e 65 53 74 61        pWin->eSta
3bd0: 72 74 20 3d 20 54 4b 5f 55 4e 42 4f 55 4e 44 45  rt = TK_UNBOUNDE
3be0: 44 3b 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e 65  D;.      pWin->e
3bf0: 45 6e 64 20 3d 20 54 4b 5f 43 55 52 52 45 4e 54  End = TK_CURRENT
3c00: 3b 0a 20 20 20 20 7d 65 6c 73 65 0a 0a 20 20 20  ;.    }else..   
3c10: 20 69 66 28 20 70 46 75 6e 63 2d 3e 78 53 46 75   if( pFunc->xSFu
3c20: 6e 63 3d 3d 64 65 6e 73 65 5f 72 61 6e 6b 53 74  nc==dense_rankSt
3c30: 65 70 46 75 6e 63 20 7c 7c 20 70 46 75 6e 63 2d  epFunc || pFunc-
3c40: 3e 78 53 46 75 6e 63 3d 3d 72 61 6e 6b 53 74 65  >xSFunc==rankSte
3c50: 70 46 75 6e 63 0a 20 20 20 20 20 7c 7c 20 70 46  pFunc.     || pF
3c60: 75 6e 63 2d 3e 78 53 46 75 6e 63 3d 3d 70 65 72  unc->xSFunc==per
3c70: 63 65 6e 74 5f 72 61 6e 6b 53 74 65 70 46 75 6e  cent_rankStepFun
3c80: 63 20 7c 7c 20 70 46 75 6e 63 2d 3e 78 53 46 75  c || pFunc->xSFu
3c90: 6e 63 3d 3d 63 75 6d 65 5f 64 69 73 74 53 74 65  nc==cume_distSte
3ca0: 70 46 75 6e 63 0a 20 20 20 20 29 7b 0a 20 20 20  pFunc.    ){.   
3cb0: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65     sqlite3ExprDe
3cc0: 6c 65 74 65 28 64 62 2c 20 70 57 69 6e 2d 3e 70  lete(db, pWin->p
3cd0: 53 74 61 72 74 29 3b 0a 20 20 20 20 20 20 73 71  Start);.      sq
3ce0: 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65 28  lite3ExprDelete(
3cf0: 64 62 2c 20 70 57 69 6e 2d 3e 70 45 6e 64 29 3b  db, pWin->pEnd);
3d00: 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e 70 53 74  .      pWin->pSt
3d10: 61 72 74 20 3d 20 70 57 69 6e 2d 3e 70 45 6e 64  art = pWin->pEnd
3d20: 20 3d 20 30 3b 0a 20 20 20 20 20 20 70 57 69 6e   = 0;.      pWin
3d30: 2d 3e 65 54 79 70 65 20 3d 20 54 4b 5f 52 41 4e  ->eType = TK_RAN
3d40: 47 45 3b 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e  GE;.      pWin->
3d50: 65 53 74 61 72 74 20 3d 20 54 4b 5f 55 4e 42 4f  eStart = TK_UNBO
3d60: 55 4e 44 45 44 3b 0a 20 20 20 20 20 20 70 57 69  UNDED;.      pWi
3d70: 6e 2d 3e 65 45 6e 64 20 3d 20 54 4b 5f 43 55 52  n->eEnd = TK_CUR
3d80: 52 45 4e 54 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  RENT;.    }.  }.
3d90: 20 20 70 57 69 6e 2d 3e 70 46 75 6e 63 20 3d 20    pWin->pFunc = 
3da0: 70 46 75 6e 63 3b 0a 7d 0a 0a 74 79 70 65 64 65  pFunc;.}..typede
3db0: 66 20 73 74 72 75 63 74 20 57 69 6e 64 6f 77 52  f struct WindowR
3dc0: 65 77 72 69 74 65 20 57 69 6e 64 6f 77 52 65 77  ewrite WindowRew
3dd0: 72 69 74 65 3b 0a 73 74 72 75 63 74 20 57 69 6e  rite;.struct Win
3de0: 64 6f 77 52 65 77 72 69 74 65 20 7b 0a 20 20 57  dowRewrite {.  W
3df0: 69 6e 64 6f 77 20 2a 70 57 69 6e 3b 0a 20 20 45  indow *pWin;.  E
3e00: 78 70 72 4c 69 73 74 20 2a 70 53 75 62 3b 0a 7d  xprList *pSub;.}
3e10: 3b 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 73 65  ;..static int se
3e20: 6c 65 63 74 57 69 6e 64 6f 77 52 65 77 72 69 74  lectWindowRewrit
3e30: 65 53 65 6c 65 63 74 43 62 28 57 61 6c 6b 65 72  eSelectCb(Walker
3e40: 20 2a 70 57 61 6c 6b 65 72 2c 20 53 65 6c 65 63   *pWalker, Selec
3e50: 74 20 2a 70 53 65 6c 65 63 74 29 7b 0a 20 20 72  t *pSelect){.  r
3e60: 65 74 75 72 6e 20 57 52 43 5f 50 72 75 6e 65 3b  eturn WRC_Prune;
3e70: 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 73  .}..static int s
3e80: 65 6c 65 63 74 57 69 6e 64 6f 77 52 65 77 72 69  electWindowRewri
3e90: 74 65 45 78 70 72 43 62 28 57 61 6c 6b 65 72 20  teExprCb(Walker 
3ea0: 2a 70 57 61 6c 6b 65 72 2c 20 45 78 70 72 20 2a  *pWalker, Expr *
3eb0: 70 45 78 70 72 29 7b 0a 20 20 73 74 72 75 63 74  pExpr){.  struct
3ec0: 20 57 69 6e 64 6f 77 52 65 77 72 69 74 65 20 2a   WindowRewrite *
3ed0: 70 20 3d 20 70 57 61 6c 6b 65 72 2d 3e 75 2e 70  p = pWalker->u.p
3ee0: 52 65 77 72 69 74 65 3b 0a 20 20 50 61 72 73 65  Rewrite;.  Parse
3ef0: 20 2a 70 50 61 72 73 65 20 3d 20 70 57 61 6c 6b   *pParse = pWalk
3f00: 65 72 2d 3e 70 50 61 72 73 65 3b 0a 0a 20 20 73  er->pParse;..  s
3f10: 77 69 74 63 68 28 20 70 45 78 70 72 2d 3e 6f 70  witch( pExpr->op
3f20: 20 29 7b 0a 0a 20 20 20 20 63 61 73 65 20 54 4b   ){..    case TK
3f30: 5f 46 55 4e 43 54 49 4f 4e 3a 0a 20 20 20 20 20  _FUNCTION:.     
3f40: 20 69 66 28 20 70 45 78 70 72 2d 3e 70 57 69 6e   if( pExpr->pWin
3f50: 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 62  ==0 ){.        b
3f60: 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 65 6c 73  reak;.      }els
3f70: 65 7b 0a 20 20 20 20 20 20 20 20 57 69 6e 64 6f  e{.        Windo
3f80: 77 20 2a 70 57 69 6e 3b 0a 20 20 20 20 20 20 20  w *pWin;.       
3f90: 20 66 6f 72 28 70 57 69 6e 3d 70 2d 3e 70 57 69   for(pWin=p->pWi
3fa0: 6e 3b 20 70 57 69 6e 3b 20 70 57 69 6e 3d 70 57  n; pWin; pWin=pW
3fb0: 69 6e 2d 3e 70 4e 65 78 74 57 69 6e 29 7b 0a 20  in->pNextWin){. 
3fc0: 20 20 20 20 20 20 20 20 20 69 66 28 20 70 45 78           if( pEx
3fd0: 70 72 2d 3e 70 57 69 6e 3d 3d 70 57 69 6e 20 29  pr->pWin==pWin )
3fe0: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 61 73  {.            as
3ff0: 73 65 72 74 28 20 70 57 69 6e 2d 3e 70 4f 77 6e  sert( pWin->pOwn
4000: 65 72 3d 3d 70 45 78 70 72 20 29 3b 0a 20 20 20  er==pExpr );.   
4010: 20 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20           return 
4020: 57 52 43 5f 50 72 75 6e 65 3b 0a 20 20 20 20 20  WRC_Prune;.     
4030: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d       }.        }
4040: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 2f  .      }.      /
4050: 2a 20 46 61 6c 6c 20 74 68 72 6f 75 67 68 2e 20  * Fall through. 
4060: 20 2a 2f 0a 0a 20 20 20 20 63 61 73 65 20 54 4b   */..    case TK
4070: 5f 41 47 47 5f 46 55 4e 43 54 49 4f 4e 3a 0a 20  _AGG_FUNCTION:. 
4080: 20 20 20 63 61 73 65 20 54 4b 5f 43 4f 4c 55 4d     case TK_COLUM
4090: 4e 3a 20 7b 0a 20 20 20 20 20 20 45 78 70 72 20  N: {.      Expr 
40a0: 2a 70 44 75 70 20 3d 20 73 71 6c 69 74 65 33 45  *pDup = sqlite3E
40b0: 78 70 72 44 75 70 28 70 50 61 72 73 65 2d 3e 64  xprDup(pParse->d
40c0: 62 2c 20 70 45 78 70 72 2c 20 30 29 3b 0a 20 20  b, pExpr, 0);.  
40d0: 20 20 20 20 70 2d 3e 70 53 75 62 20 3d 20 73 71      p->pSub = sq
40e0: 6c 69 74 65 33 45 78 70 72 4c 69 73 74 41 70 70  lite3ExprListApp
40f0: 65 6e 64 28 70 50 61 72 73 65 2c 20 70 2d 3e 70  end(pParse, p->p
4100: 53 75 62 2c 20 70 44 75 70 29 3b 0a 20 20 20 20  Sub, pDup);.    
4110: 20 20 69 66 28 20 70 2d 3e 70 53 75 62 20 29 7b    if( p->pSub ){
4120: 0a 20 20 20 20 20 20 20 20 61 73 73 65 72 74 28  .        assert(
4130: 20 45 78 70 72 48 61 73 50 72 6f 70 65 72 74 79   ExprHasProperty
4140: 28 70 45 78 70 72 2c 20 45 50 5f 53 74 61 74 69  (pExpr, EP_Stati
4150: 63 29 3d 3d 30 20 29 3b 0a 20 20 20 20 20 20 20  c)==0 );.       
4160: 20 45 78 70 72 53 65 74 50 72 6f 70 65 72 74 79   ExprSetProperty
4170: 28 70 45 78 70 72 2c 20 45 50 5f 53 74 61 74 69  (pExpr, EP_Stati
4180: 63 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  c);.        sqli
4190: 74 65 33 45 78 70 72 44 65 6c 65 74 65 28 70 50  te3ExprDelete(pP
41a0: 61 72 73 65 2d 3e 64 62 2c 20 70 45 78 70 72 29  arse->db, pExpr)
41b0: 3b 0a 20 20 20 20 20 20 20 20 45 78 70 72 43 6c  ;.        ExprCl
41c0: 65 61 72 50 72 6f 70 65 72 74 79 28 70 45 78 70  earProperty(pExp
41d0: 72 2c 20 45 50 5f 53 74 61 74 69 63 29 3b 0a 20  r, EP_Static);. 
41e0: 20 20 20 20 20 20 20 6d 65 6d 73 65 74 28 70 45         memset(pE
41f0: 78 70 72 2c 20 30 2c 20 73 69 7a 65 6f 66 28 45  xpr, 0, sizeof(E
4200: 78 70 72 29 29 3b 0a 0a 20 20 20 20 20 20 20 20  xpr));..        
4210: 70 45 78 70 72 2d 3e 6f 70 20 3d 20 54 4b 5f 43  pExpr->op = TK_C
4220: 4f 4c 55 4d 4e 3b 0a 20 20 20 20 20 20 20 20 70  OLUMN;.        p
4230: 45 78 70 72 2d 3e 69 43 6f 6c 75 6d 6e 20 3d 20  Expr->iColumn = 
4240: 70 2d 3e 70 53 75 62 2d 3e 6e 45 78 70 72 2d 31  p->pSub->nExpr-1
4250: 3b 0a 20 20 20 20 20 20 20 20 70 45 78 70 72 2d  ;.        pExpr-
4260: 3e 69 54 61 62 6c 65 20 3d 20 70 2d 3e 70 57 69  >iTable = p->pWi
4270: 6e 2d 3e 69 45 70 68 43 73 72 3b 0a 20 20 20 20  n->iEphCsr;.    
4280: 20 20 7d 0a 0a 20 20 20 20 20 20 62 72 65 61 6b    }..      break
4290: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 64 65 66  ;.    }..    def
42a0: 61 75 6c 74 3a 20 2f 2a 20 6e 6f 2d 6f 70 20 2a  ault: /* no-op *
42b0: 2f 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  /.      break;. 
42c0: 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20 57 52 43   }..  return WRC
42d0: 5f 43 6f 6e 74 69 6e 75 65 3b 0a 7d 0a 0a 73 74  _Continue;.}..st
42e0: 61 74 69 63 20 69 6e 74 20 73 65 6c 65 63 74 57  atic int selectW
42f0: 69 6e 64 6f 77 52 65 77 72 69 74 65 45 4c 69 73  indowRewriteELis
4300: 74 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72  t(.  Parse *pPar
4310: 73 65 2c 20 0a 20 20 57 69 6e 64 6f 77 20 2a 70  se, .  Window *p
4320: 57 69 6e 2c 0a 20 20 45 78 70 72 4c 69 73 74 20  Win,.  ExprList 
4330: 2a 70 45 4c 69 73 74 2c 20 20 20 20 20 20 20 20  *pEList,        
4340: 20 20 20 20 20 20 20 2f 2a 20 52 65 77 72 69 74         /* Rewrit
4350: 65 20 65 78 70 72 65 73 73 69 6f 6e 73 20 69 6e  e expressions in
4360: 20 74 68 69 73 20 6c 69 73 74 20 2a 2f 0a 20 20   this list */.  
4370: 45 78 70 72 4c 69 73 74 20 2a 2a 70 70 53 75 62  ExprList **ppSub
4380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4390: 2f 2a 20 49 4e 2f 4f 55 54 3a 20 53 75 62 2d 73  /* IN/OUT: Sub-s
43a0: 65 6c 65 63 74 20 65 78 70 72 65 73 73 69 6f 6e  elect expression
43b0: 2d 6c 69 73 74 20 2a 2f 0a 29 7b 0a 20 20 57 61  -list */.){.  Wa
43c0: 6c 6b 65 72 20 73 57 61 6c 6b 65 72 3b 0a 20 20  lker sWalker;.  
43d0: 57 69 6e 64 6f 77 52 65 77 72 69 74 65 20 73 52  WindowRewrite sR
43e0: 65 77 72 69 74 65 3b 0a 20 20 69 6e 74 20 72 63  ewrite;.  int rc
43f0: 3b 0a 0a 20 20 6d 65 6d 73 65 74 28 26 73 57 61  ;..  memset(&sWa
4400: 6c 6b 65 72 2c 20 30 2c 20 73 69 7a 65 6f 66 28  lker, 0, sizeof(
4410: 57 61 6c 6b 65 72 29 29 3b 0a 20 20 6d 65 6d 73  Walker));.  mems
4420: 65 74 28 26 73 52 65 77 72 69 74 65 2c 20 30 2c  et(&sRewrite, 0,
4430: 20 73 69 7a 65 6f 66 28 57 69 6e 64 6f 77 52 65   sizeof(WindowRe
4440: 77 72 69 74 65 29 29 3b 0a 0a 20 20 73 52 65 77  write));..  sRew
4450: 72 69 74 65 2e 70 53 75 62 20 3d 20 2a 70 70 53  rite.pSub = *ppS
4460: 75 62 3b 0a 20 20 73 52 65 77 72 69 74 65 2e 70  ub;.  sRewrite.p
4470: 57 69 6e 20 3d 20 70 57 69 6e 3b 0a 0a 20 20 73  Win = pWin;..  s
4480: 57 61 6c 6b 65 72 2e 70 50 61 72 73 65 20 3d 20  Walker.pParse = 
4490: 70 50 61 72 73 65 3b 0a 20 20 73 57 61 6c 6b 65  pParse;.  sWalke
44a0: 72 2e 78 45 78 70 72 43 61 6c 6c 62 61 63 6b 20  r.xExprCallback 
44b0: 3d 20 73 65 6c 65 63 74 57 69 6e 64 6f 77 52 65  = selectWindowRe
44c0: 77 72 69 74 65 45 78 70 72 43 62 3b 0a 20 20 73  writeExprCb;.  s
44d0: 57 61 6c 6b 65 72 2e 78 53 65 6c 65 63 74 43 61  Walker.xSelectCa
44e0: 6c 6c 62 61 63 6b 20 3d 20 73 65 6c 65 63 74 57  llback = selectW
44f0: 69 6e 64 6f 77 52 65 77 72 69 74 65 53 65 6c 65  indowRewriteSele
4500: 63 74 43 62 3b 0a 20 20 73 57 61 6c 6b 65 72 2e  ctCb;.  sWalker.
4510: 75 2e 70 52 65 77 72 69 74 65 20 3d 20 26 73 52  u.pRewrite = &sR
4520: 65 77 72 69 74 65 3b 0a 0a 20 20 72 63 20 3d 20  ewrite;..  rc = 
4530: 73 71 6c 69 74 65 33 57 61 6c 6b 45 78 70 72 4c  sqlite3WalkExprL
4540: 69 73 74 28 26 73 57 61 6c 6b 65 72 2c 20 70 45  ist(&sWalker, pE
4550: 4c 69 73 74 29 3b 0a 0a 20 20 2a 70 70 53 75 62  List);..  *ppSub
4560: 20 3d 20 73 52 65 77 72 69 74 65 2e 70 53 75 62   = sRewrite.pSub
4570: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
4580: 0a 0a 73 74 61 74 69 63 20 45 78 70 72 4c 69 73  ..static ExprLis
4590: 74 20 2a 65 78 70 72 4c 69 73 74 41 70 70 65 6e  t *exprListAppen
45a0: 64 4c 69 73 74 28 0a 20 20 50 61 72 73 65 20 2a  dList(.  Parse *
45b0: 70 50 61 72 73 65 2c 20 20 20 20 20 20 20 20 20  pParse,         
45c0: 20 2f 2a 20 50 61 72 73 69 6e 67 20 63 6f 6e 74   /* Parsing cont
45d0: 65 78 74 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73  ext */.  ExprLis
45e0: 74 20 2a 70 4c 69 73 74 2c 20 20 20 20 20 20 20  t *pList,       
45f0: 20 2f 2a 20 4c 69 73 74 20 74 6f 20 77 68 69 63   /* List to whic
4600: 68 20 74 6f 20 61 70 70 65 6e 64 2e 20 4d 69 67  h to append. Mig
4610: 68 74 20 62 65 20 4e 55 4c 4c 20 2a 2f 0a 20 20  ht be NULL */.  
4620: 45 78 70 72 4c 69 73 74 20 2a 70 41 70 70 65 6e  ExprList *pAppen
4630: 64 20 20 20 20 20 20 20 2f 2a 20 4c 69 73 74 20  d       /* List 
4640: 6f 66 20 76 61 6c 75 65 73 20 74 6f 20 61 70 70  of values to app
4650: 65 6e 64 2e 20 4d 69 67 68 74 20 62 65 20 4e 55  end. Might be NU
4660: 4c 4c 20 2a 2f 0a 29 7b 0a 20 20 69 66 28 20 70  LL */.){.  if( p
4670: 41 70 70 65 6e 64 20 29 7b 0a 20 20 20 20 69 6e  Append ){.    in
4680: 74 20 69 3b 0a 20 20 20 20 69 6e 74 20 6e 49 6e  t i;.    int nIn
4690: 69 74 20 3d 20 70 4c 69 73 74 20 3f 20 70 4c 69  it = pList ? pLi
46a0: 73 74 2d 3e 6e 45 78 70 72 20 3a 20 30 3b 0a 20  st->nExpr : 0;. 
46b0: 20 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 41     for(i=0; i<pA
46c0: 70 70 65 6e 64 2d 3e 6e 45 78 70 72 3b 20 69 2b  ppend->nExpr; i+
46d0: 2b 29 7b 0a 20 20 20 20 20 20 45 78 70 72 20 2a  +){.      Expr *
46e0: 70 44 75 70 20 3d 20 73 71 6c 69 74 65 33 45 78  pDup = sqlite3Ex
46f0: 70 72 44 75 70 28 70 50 61 72 73 65 2d 3e 64 62  prDup(pParse->db
4700: 2c 20 70 41 70 70 65 6e 64 2d 3e 61 5b 69 5d 2e  , pAppend->a[i].
4710: 70 45 78 70 72 2c 20 30 29 3b 0a 20 20 20 20 20  pExpr, 0);.     
4720: 20 70 4c 69 73 74 20 3d 20 73 71 6c 69 74 65 33   pList = sqlite3
4730: 45 78 70 72 4c 69 73 74 41 70 70 65 6e 64 28 70  ExprListAppend(p
4740: 50 61 72 73 65 2c 20 70 4c 69 73 74 2c 20 70 44  Parse, pList, pD
4750: 75 70 29 3b 0a 20 20 20 20 20 20 69 66 28 20 70  up);.      if( p
4760: 4c 69 73 74 20 29 20 70 4c 69 73 74 2d 3e 61 5b  List ) pList->a[
4770: 6e 49 6e 69 74 2b 69 5d 2e 73 6f 72 74 4f 72 64  nInit+i].sortOrd
4780: 65 72 20 3d 20 70 41 70 70 65 6e 64 2d 3e 61 5b  er = pAppend->a[
4790: 69 5d 2e 73 6f 72 74 4f 72 64 65 72 3b 0a 20 20  i].sortOrder;.  
47a0: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
47b0: 20 70 4c 69 73 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a   pList;.}../*.**
47c0: 20 49 66 20 74 68 65 20 53 45 4c 45 43 54 20 73   If the SELECT s
47d0: 74 61 74 65 6d 65 6e 74 20 70 61 73 73 65 64 20  tatement passed 
47e0: 61 73 20 74 68 65 20 73 65 63 6f 6e 64 20 61 72  as the second ar
47f0: 67 75 6d 65 6e 74 20 64 6f 65 73 20 6e 6f 74 20  gument does not 
4800: 69 6e 76 6f 6b 65 0a 2a 2a 20 61 6e 79 20 53 51  invoke.** any SQ
4810: 4c 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f  L window functio
4820: 6e 73 2c 20 74 68 69 73 20 66 75 6e 63 74 69 6f  ns, this functio
4830: 6e 20 69 73 20 61 20 6e 6f 2d 6f 70 2e 20 4f 74  n is a no-op. Ot
4840: 68 65 72 77 69 73 65 2c 20 69 74 20 0a 2a 2a 20  herwise, it .** 
4850: 72 65 77 72 69 74 65 73 20 74 68 65 20 53 45 4c  rewrites the SEL
4860: 45 43 54 20 73 74 61 74 65 6d 65 6e 74 20 73 6f  ECT statement so
4870: 20 74 68 61 74 20 77 69 6e 64 6f 77 20 66 75 6e   that window fun
4880: 63 74 69 6f 6e 20 78 53 74 65 70 20 66 75 6e 63  ction xStep func
4890: 74 69 6f 6e 73 0a 2a 2a 20 61 72 65 20 69 6e 76  tions.** are inv
48a0: 6f 6b 65 64 20 69 6e 20 74 68 65 20 63 6f 72 72  oked in the corr
48b0: 65 63 74 20 6f 72 64 65 72 2e 20 54 68 65 20 73  ect order. The s
48c0: 69 6d 70 6c 65 73 74 20 76 65 72 73 69 6f 6e 20  implest version 
48d0: 6f 66 20 74 68 65 20 0a 2a 2a 20 74 72 61 6e 73  of the .** trans
48e0: 66 6f 72 6d 61 74 69 6f 6e 20 69 73 3a 0a 2a 2a  formation is:.**
48f0: 0a 2a 2a 20 20 20 53 45 4c 45 43 54 20 77 69 6e  .**   SELECT win
4900: 28 61 72 67 73 2e 2e 2e 29 20 4f 56 45 52 20 28  (args...) OVER (
4910: 3c 6c 69 73 74 31 3e 29 20 46 52 4f 4d 20 3c 73  <list1>) FROM <s
4920: 72 63 3e 20 4f 52 44 45 52 20 42 59 20 3c 6c 69  rc> ORDER BY <li
4930: 73 74 32 3e 0a 2a 2a 0a 2a 2a 20 74 6f 0a 2a 2a  st2>.**.** to.**
4940: 0a 2a 2a 20 20 20 53 45 4c 45 43 54 20 77 69 6e  .**   SELECT win
4950: 28 61 72 67 73 2e 2e 2e 29 20 46 52 4f 4d 20 28  (args...) FROM (
4960: 0a 2a 2a 20 20 20 20 20 53 45 4c 45 43 54 20 61  .**     SELECT a
4970: 72 67 73 2e 2e 2e 20 46 52 4f 4d 20 3c 73 72 63  rgs... FROM <src
4980: 3e 20 4f 52 44 45 52 20 42 59 20 3c 6c 69 73 74  > ORDER BY <list
4990: 31 3e 0a 2a 2a 20 20 20 29 20 4f 52 44 45 52 20  1>.**   ) ORDER 
49a0: 42 59 20 3c 6c 69 73 74 32 3e 0a 2a 2a 0a 2a 2a  BY <list2>.**.**
49b0: 20 77 68 65 72 65 20 3c 73 72 63 3e 20 6d 61 79   where <src> may
49c0: 20 63 6f 6e 74 61 69 6e 20 57 48 45 52 45 2c 20   contain WHERE, 
49d0: 47 52 4f 55 50 20 42 59 20 61 6e 64 20 48 41 56  GROUP BY and HAV
49e0: 49 4e 47 20 63 6c 61 75 73 65 73 2c 20 61 6e 64  ING clauses, and
49f0: 20 3c 6c 69 73 74 31 3e 0a 2a 2a 20 69 73 20 74   <list1>.** is t
4a00: 68 65 20 63 6f 6e 63 61 74 65 6e 61 74 69 6f 6e  he concatenation
4a10: 20 6f 66 20 74 68 65 20 50 41 52 54 49 54 49 4f   of the PARTITIO
4a20: 4e 20 42 59 20 61 6e 64 20 4f 52 44 45 52 20 42  N BY and ORDER B
4a30: 59 20 63 6c 61 75 73 65 73 20 69 6e 20 74 68 65  Y clauses in the
4a40: 0a 2a 2a 20 4f 56 45 52 20 63 6c 61 75 73 65 2e  .** OVER clause.
4a50: 0a 2a 2a 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  .**.*/.int sqlit
4a60: 65 33 57 69 6e 64 6f 77 52 65 77 72 69 74 65 28  e3WindowRewrite(
4a70: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 53  Parse *pParse, S
4a80: 65 6c 65 63 74 20 2a 70 29 7b 0a 20 20 69 6e 74  elect *p){.  int
4a90: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b   rc = SQLITE_OK;
4aa0: 0a 20 20 69 66 28 20 70 2d 3e 70 57 69 6e 20 29  .  if( p->pWin )
4ab0: 7b 0a 20 20 20 20 56 64 62 65 20 2a 76 20 3d 20  {.    Vdbe *v = 
4ac0: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
4ad0: 50 61 72 73 65 29 3b 0a 20 20 20 20 69 6e 74 20  Parse);.    int 
4ae0: 69 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 20 2a  i;.    sqlite3 *
4af0: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
4b00: 0a 20 20 20 20 53 65 6c 65 63 74 20 2a 70 53 75  .    Select *pSu
4b10: 62 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  b = 0;          
4b20: 20 20 20 2f 2a 20 54 68 65 20 73 75 62 71 75 65     /* The subque
4b30: 72 79 20 2a 2f 0a 20 20 20 20 53 72 63 4c 69 73  ry */.    SrcLis
4b40: 74 20 2a 70 53 72 63 20 3d 20 70 2d 3e 70 53 72  t *pSrc = p->pSr
4b50: 63 3b 0a 20 20 20 20 45 78 70 72 20 2a 70 57 68  c;.    Expr *pWh
4b60: 65 72 65 20 3d 20 70 2d 3e 70 57 68 65 72 65 3b  ere = p->pWhere;
4b70: 0a 20 20 20 20 45 78 70 72 4c 69 73 74 20 2a 70  .    ExprList *p
4b80: 47 72 6f 75 70 42 79 20 3d 20 70 2d 3e 70 47 72  GroupBy = p->pGr
4b90: 6f 75 70 42 79 3b 0a 20 20 20 20 45 78 70 72 20  oupBy;.    Expr 
4ba0: 2a 70 48 61 76 69 6e 67 20 3d 20 70 2d 3e 70 48  *pHaving = p->pH
4bb0: 61 76 69 6e 67 3b 0a 20 20 20 20 45 78 70 72 4c  aving;.    ExprL
4bc0: 69 73 74 20 2a 70 53 6f 72 74 20 3d 20 30 3b 0a  ist *pSort = 0;.
4bd0: 0a 20 20 20 20 45 78 70 72 4c 69 73 74 20 2a 70  .    ExprList *p
4be0: 53 75 62 6c 69 73 74 20 3d 20 30 3b 20 20 20 20  Sublist = 0;    
4bf0: 20 20 20 2f 2a 20 45 78 70 72 65 73 73 69 6f 6e     /* Expression
4c00: 20 6c 69 73 74 20 66 6f 72 20 73 75 62 2d 71 75   list for sub-qu
4c10: 65 72 79 20 2a 2f 0a 20 20 20 20 57 69 6e 64 6f  ery */.    Windo
4c20: 77 20 2a 70 4d 57 69 6e 20 3d 20 70 2d 3e 70 57  w *pMWin = p->pW
4c30: 69 6e 3b 20 20 20 20 20 20 2f 2a 20 4d 61 73 74  in;      /* Mast
4c40: 65 72 20 77 69 6e 64 6f 77 20 6f 62 6a 65 63 74  er window object
4c50: 20 2a 2f 0a 20 20 20 20 57 69 6e 64 6f 77 20 2a   */.    Window *
4c60: 70 57 69 6e 3b 20 20 20 20 20 20 20 20 20 20 20  pWin;           
4c70: 20 20 20 20 20 20 2f 2a 20 57 69 6e 64 6f 77 20        /* Window 
4c80: 6f 62 6a 65 63 74 20 69 74 65 72 61 74 6f 72 20  object iterator 
4c90: 2a 2f 0a 0a 20 20 20 20 70 2d 3e 70 53 72 63 20  */..    p->pSrc 
4ca0: 3d 20 30 3b 0a 20 20 20 20 70 2d 3e 70 57 68 65  = 0;.    p->pWhe
4cb0: 72 65 20 3d 20 30 3b 0a 20 20 20 20 70 2d 3e 70  re = 0;.    p->p
4cc0: 47 72 6f 75 70 42 79 20 3d 20 30 3b 0a 20 20 20  GroupBy = 0;.   
4cd0: 20 70 2d 3e 70 48 61 76 69 6e 67 20 3d 20 30 3b   p->pHaving = 0;
4ce0: 0a 0a 20 20 20 20 2f 2a 20 41 73 73 69 67 6e 20  ..    /* Assign 
4cf0: 61 20 63 75 72 73 6f 72 20 6e 75 6d 62 65 72 20  a cursor number 
4d00: 66 6f 72 20 74 68 65 20 65 70 68 65 6d 65 72 61  for the ephemera
4d10: 6c 20 74 61 62 6c 65 20 75 73 65 64 20 74 6f 20  l table used to 
4d20: 62 75 66 66 65 72 20 72 6f 77 73 2e 0a 20 20 20  buffer rows..   
4d30: 20 2a 2a 20 54 68 65 20 4f 70 65 6e 45 70 68 65   ** The OpenEphe
4d40: 6d 65 72 61 6c 20 69 6e 73 74 72 75 63 74 69 6f  meral instructio
4d50: 6e 20 69 73 20 63 6f 64 65 64 20 6c 61 74 65 72  n is coded later
4d60: 2c 20 61 66 74 65 72 20 69 74 20 69 73 20 6b 6e  , after it is kn
4d70: 6f 77 6e 20 68 6f 77 0a 20 20 20 20 2a 2a 20 6d  own how.    ** m
4d80: 61 6e 79 20 63 6f 6c 75 6d 6e 73 20 74 68 65 20  any columns the 
4d90: 74 61 62 6c 65 20 77 69 6c 6c 20 68 61 76 65 2e  table will have.
4da0: 20 20 2a 2f 0a 20 20 20 20 70 4d 57 69 6e 2d 3e    */.    pMWin->
4db0: 69 45 70 68 43 73 72 20 3d 20 70 50 61 72 73 65  iEphCsr = pParse
4dc0: 2d 3e 6e 54 61 62 2b 2b 3b 0a 0a 20 20 20 20 72  ->nTab++;..    r
4dd0: 63 20 3d 20 73 65 6c 65 63 74 57 69 6e 64 6f 77  c = selectWindow
4de0: 52 65 77 72 69 74 65 45 4c 69 73 74 28 70 50 61  RewriteEList(pPa
4df0: 72 73 65 2c 20 70 4d 57 69 6e 2c 20 70 2d 3e 70  rse, pMWin, p->p
4e00: 45 4c 69 73 74 2c 20 26 70 53 75 62 6c 69 73 74  EList, &pSublist
4e10: 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29 20  );.    if( rc ) 
4e20: 72 65 74 75 72 6e 20 72 63 3b 0a 20 20 20 20 72  return rc;.    r
4e30: 63 20 3d 20 73 65 6c 65 63 74 57 69 6e 64 6f 77  c = selectWindow
4e40: 52 65 77 72 69 74 65 45 4c 69 73 74 28 70 50 61  RewriteEList(pPa
4e50: 72 73 65 2c 20 70 4d 57 69 6e 2c 20 70 2d 3e 70  rse, pMWin, p->p
4e60: 4f 72 64 65 72 42 79 2c 20 26 70 53 75 62 6c 69  OrderBy, &pSubli
4e70: 73 74 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20  st);.    if( rc 
4e80: 29 20 72 65 74 75 72 6e 20 72 63 3b 0a 20 20 20  ) return rc;.   
4e90: 20 70 4d 57 69 6e 2d 3e 6e 42 75 66 66 65 72 43   pMWin->nBufferC
4ea0: 6f 6c 20 3d 20 28 70 53 75 62 6c 69 73 74 20 3f  ol = (pSublist ?
4eb0: 20 70 53 75 62 6c 69 73 74 2d 3e 6e 45 78 70 72   pSublist->nExpr
4ec0: 20 3a 20 30 29 3b 0a 0a 20 20 20 20 2f 2a 20 43   : 0);..    /* C
4ed0: 72 65 61 74 65 20 74 68 65 20 4f 52 44 45 52 20  reate the ORDER 
4ee0: 42 59 20 63 6c 61 75 73 65 20 66 6f 72 20 74 68  BY clause for th
4ef0: 65 20 73 75 62 2d 73 65 6c 65 63 74 2e 20 54 68  e sub-select. Th
4f00: 69 73 20 69 73 20 74 68 65 20 63 6f 6e 63 61 74  is is the concat
4f10: 65 6e 61 74 69 6f 6e 0a 20 20 20 20 2a 2a 20 6f  enation.    ** o
4f20: 66 20 74 68 65 20 77 69 6e 64 6f 77 20 50 41 52  f the window PAR
4f30: 54 49 54 49 4f 4e 20 61 6e 64 20 4f 52 44 45 52  TITION and ORDER
4f40: 20 42 59 20 63 6c 61 75 73 65 73 2e 20 41 70 70   BY clauses. App
4f50: 65 6e 64 20 74 68 65 20 73 61 6d 65 20 0a 20 20  end the same .  
4f60: 20 20 2a 2a 20 65 78 70 72 65 73 73 69 6f 6e 73    ** expressions
4f70: 20 74 6f 20 74 68 65 20 73 75 62 2d 73 65 6c 65   to the sub-sele
4f80: 63 74 20 65 78 70 72 65 73 73 69 6f 6e 20 6c 69  ct expression li
4f90: 73 74 2e 20 54 68 65 79 20 61 72 65 20 72 65 71  st. They are req
4fa0: 75 69 72 65 64 20 74 6f 0a 20 20 20 20 2a 2a 20  uired to.    ** 
4fb0: 66 69 67 75 72 65 20 6f 75 74 20 77 68 65 72 65  figure out where
4fc0: 20 62 6f 75 6e 64 61 72 69 65 73 20 66 6f 72 20   boundaries for 
4fd0: 70 61 72 74 69 74 69 6f 6e 73 20 61 6e 64 20 73  partitions and s
4fe0: 65 74 73 20 6f 66 20 70 65 65 72 20 72 6f 77 73  ets of peer rows
4ff0: 2e 20 20 2a 2f 0a 20 20 20 20 70 53 6f 72 74 20  .  */.    pSort 
5000: 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73  = sqlite3ExprLis
5010: 74 44 75 70 28 64 62 2c 20 70 4d 57 69 6e 2d 3e  tDup(db, pMWin->
5020: 70 50 61 72 74 69 74 69 6f 6e 2c 20 30 29 3b 0a  pPartition, 0);.
5030: 20 20 20 20 69 66 28 20 70 4d 57 69 6e 2d 3e 70      if( pMWin->p
5040: 4f 72 64 65 72 42 79 20 29 7b 0a 20 20 20 20 20  OrderBy ){.     
5050: 20 70 53 6f 72 74 20 3d 20 65 78 70 72 4c 69 73   pSort = exprLis
5060: 74 41 70 70 65 6e 64 4c 69 73 74 28 70 50 61 72  tAppendList(pPar
5070: 73 65 2c 20 70 53 6f 72 74 2c 20 70 4d 57 69 6e  se, pSort, pMWin
5080: 2d 3e 70 4f 72 64 65 72 42 79 29 3b 0a 20 20 20  ->pOrderBy);.   
5090: 20 7d 0a 20 20 20 20 70 53 75 62 6c 69 73 74 20   }.    pSublist 
50a0: 3d 20 65 78 70 72 4c 69 73 74 41 70 70 65 6e 64  = exprListAppend
50b0: 4c 69 73 74 28 70 50 61 72 73 65 2c 20 70 53 75  List(pParse, pSu
50c0: 62 6c 69 73 74 2c 20 70 53 6f 72 74 29 3b 0a 0a  blist, pSort);..
50d0: 20 20 20 20 2f 2a 20 41 70 70 65 6e 64 20 74 68      /* Append th
50e0: 65 20 61 72 67 75 6d 65 6e 74 73 20 70 61 73 73  e arguments pass
50f0: 65 64 20 74 6f 20 65 61 63 68 20 77 69 6e 64 6f  ed to each windo
5100: 77 20 66 75 6e 63 74 69 6f 6e 20 74 6f 20 74 68  w function to th
5110: 65 0a 20 20 20 20 2a 2a 20 73 75 62 2d 73 65 6c  e.    ** sub-sel
5120: 65 63 74 20 65 78 70 72 65 73 73 69 6f 6e 20 6c  ect expression l
5130: 69 73 74 2e 20 41 6c 73 6f 20 61 6c 6c 6f 63 61  ist. Also alloca
5140: 74 65 20 74 77 6f 20 72 65 67 69 73 74 65 72 73  te two registers
5150: 20 66 6f 72 20 65 61 63 68 0a 20 20 20 20 2a 2a   for each.    **
5160: 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e   window function
5170: 20 2d 20 6f 6e 65 20 66 6f 72 20 74 68 65 20 61   - one for the a
5180: 63 63 75 6d 75 6c 61 74 6f 72 2c 20 61 6e 6f 74  ccumulator, anot
5190: 68 65 72 20 66 6f 72 20 69 6e 74 65 72 69 6d 0a  her for interim.
51a0: 20 20 20 20 2a 2a 20 72 65 73 75 6c 74 73 2e 20      ** results. 
51b0: 20 2a 2f 0a 20 20 20 20 66 6f 72 28 70 57 69 6e   */.    for(pWin
51c0: 3d 70 4d 57 69 6e 3b 20 70 57 69 6e 3b 20 70 57  =pMWin; pWin; pW
51d0: 69 6e 3d 70 57 69 6e 2d 3e 70 4e 65 78 74 57 69  in=pWin->pNextWi
51e0: 6e 29 7b 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e  n){.      pWin->
51f0: 69 41 72 67 43 6f 6c 20 3d 20 28 70 53 75 62 6c  iArgCol = (pSubl
5200: 69 73 74 20 3f 20 70 53 75 62 6c 69 73 74 2d 3e  ist ? pSublist->
5210: 6e 45 78 70 72 20 3a 20 30 29 3b 0a 20 20 20 20  nExpr : 0);.    
5220: 20 20 70 53 75 62 6c 69 73 74 20 3d 20 65 78 70    pSublist = exp
5230: 72 4c 69 73 74 41 70 70 65 6e 64 4c 69 73 74 28  rListAppendList(
5240: 70 50 61 72 73 65 2c 20 70 53 75 62 6c 69 73 74  pParse, pSublist
5250: 2c 20 70 57 69 6e 2d 3e 70 4f 77 6e 65 72 2d 3e  , pWin->pOwner->
5260: 78 2e 70 4c 69 73 74 29 3b 0a 20 20 20 20 20 20  x.pList);.      
5270: 69 66 28 20 70 57 69 6e 2d 3e 70 46 69 6c 74 65  if( pWin->pFilte
5280: 72 20 29 7b 0a 20 20 20 20 20 20 20 20 45 78 70  r ){.        Exp
5290: 72 20 2a 70 46 69 6c 74 65 72 20 3d 20 73 71 6c  r *pFilter = sql
52a0: 69 74 65 33 45 78 70 72 44 75 70 28 64 62 2c 20  ite3ExprDup(db, 
52b0: 70 57 69 6e 2d 3e 70 46 69 6c 74 65 72 2c 20 30  pWin->pFilter, 0
52c0: 29 3b 0a 20 20 20 20 20 20 20 20 70 53 75 62 6c  );.        pSubl
52d0: 69 73 74 20 3d 20 73 71 6c 69 74 65 33 45 78 70  ist = sqlite3Exp
52e0: 72 4c 69 73 74 41 70 70 65 6e 64 28 70 50 61 72  rListAppend(pPar
52f0: 73 65 2c 20 70 53 75 62 6c 69 73 74 2c 20 70 46  se, pSublist, pF
5300: 69 6c 74 65 72 29 3b 0a 20 20 20 20 20 20 7d 0a  ilter);.      }.
5310: 20 20 20 20 20 20 70 57 69 6e 2d 3e 72 65 67 41        pWin->regA
5320: 63 63 75 6d 20 3d 20 2b 2b 70 50 61 72 73 65 2d  ccum = ++pParse-
5330: 3e 6e 4d 65 6d 3b 0a 20 20 20 20 20 20 70 57 69  >nMem;.      pWi
5340: 6e 2d 3e 72 65 67 52 65 73 75 6c 74 20 3d 20 2b  n->regResult = +
5350: 2b 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 3b 0a 20  +pParse->nMem;. 
5360: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
5370: 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 4e 75 6c  AddOp2(v, OP_Nul
5380: 6c 2c 20 30 2c 20 70 57 69 6e 2d 3e 72 65 67 41  l, 0, pWin->regA
5390: 63 63 75 6d 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  ccum);.    }..  
53a0: 20 20 70 53 75 62 20 3d 20 73 71 6c 69 74 65 33    pSub = sqlite3
53b0: 53 65 6c 65 63 74 4e 65 77 28 0a 20 20 20 20 20  SelectNew(.     
53c0: 20 20 20 70 50 61 72 73 65 2c 20 70 53 75 62 6c     pParse, pSubl
53d0: 69 73 74 2c 20 70 53 72 63 2c 20 70 57 68 65 72  ist, pSrc, pWher
53e0: 65 2c 20 70 47 72 6f 75 70 42 79 2c 20 70 48 61  e, pGroupBy, pHa
53f0: 76 69 6e 67 2c 20 70 53 6f 72 74 2c 20 30 2c 20  ving, pSort, 0, 
5400: 30 0a 20 20 20 20 29 3b 0a 20 20 20 20 70 2d 3e  0.    );.    p->
5410: 70 53 72 63 20 3d 20 73 71 6c 69 74 65 33 53 72  pSrc = sqlite3Sr
5420: 63 4c 69 73 74 41 70 70 65 6e 64 28 64 62 2c 20  cListAppend(db, 
5430: 30 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 69 66  0, 0, 0);.    if
5440: 28 20 70 2d 3e 70 53 72 63 20 29 7b 0a 20 20 20  ( p->pSrc ){.   
5450: 20 20 20 69 6e 74 20 69 54 61 62 3b 0a 20 20 20     int iTab;.   
5460: 20 20 20 45 78 70 72 4c 69 73 74 20 2a 70 4c 69     ExprList *pLi
5470: 73 74 20 3d 20 30 3b 0a 20 20 20 20 20 20 70 2d  st = 0;.      p-
5480: 3e 70 53 72 63 2d 3e 61 5b 30 5d 2e 70 53 65 6c  >pSrc->a[0].pSel
5490: 65 63 74 20 3d 20 70 53 75 62 3b 0a 20 20 20 20  ect = pSub;.    
54a0: 20 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74    sqlite3SrcList
54b0: 41 73 73 69 67 6e 43 75 72 73 6f 72 73 28 70 50  AssignCursors(pP
54c0: 61 72 73 65 2c 20 70 2d 3e 70 53 72 63 29 3b 0a  arse, p->pSrc);.
54d0: 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 65        if( sqlite
54e0: 33 45 78 70 61 6e 64 53 75 62 71 75 65 72 79 28  3ExpandSubquery(
54f0: 70 50 61 72 73 65 2c 20 26 70 2d 3e 70 53 72 63  pParse, &p->pSrc
5500: 2d 3e 61 5b 30 5d 29 20 29 7b 0a 20 20 20 20 20  ->a[0]) ){.     
5510: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e     rc = SQLITE_N
5520: 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 7d 65 6c 73  OMEM;.      }els
5530: 65 7b 0a 20 20 20 20 20 20 20 20 70 53 75 62 2d  e{.        pSub-
5540: 3e 73 65 6c 46 6c 61 67 73 20 7c 3d 20 53 46 5f  >selFlags |= SF_
5550: 45 78 70 61 6e 64 65 64 3b 0a 20 20 20 20 20 20  Expanded;.      
5560: 20 20 70 2d 3e 73 65 6c 46 6c 61 67 73 20 26 3d    p->selFlags &=
5570: 20 7e 53 46 5f 41 67 67 72 65 67 61 74 65 3b 0a   ~SF_Aggregate;.
5580: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 53          sqlite3S
5590: 65 6c 65 63 74 50 72 65 70 28 70 50 61 72 73 65  electPrep(pParse
55a0: 2c 20 70 53 75 62 2c 20 30 29 3b 0a 20 20 20 20  , pSub, 0);.    
55b0: 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 73    }.    }..    s
55c0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
55d0: 28 76 2c 20 4f 50 5f 4f 70 65 6e 45 70 68 65 6d  (v, OP_OpenEphem
55e0: 65 72 61 6c 2c 20 70 4d 57 69 6e 2d 3e 69 45 70  eral, pMWin->iEp
55f0: 68 43 73 72 2c 20 70 53 75 62 6c 69 73 74 2d 3e  hCsr, pSublist->
5600: 6e 45 78 70 72 29 3b 0a 20 20 7d 0a 0a 20 20 72  nExpr);.  }..  r
5610: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 76 6f 69  eturn rc;.}..voi
5620: 64 20 73 71 6c 69 74 65 33 57 69 6e 64 6f 77 44  d sqlite3WindowD
5630: 65 6c 65 74 65 28 73 71 6c 69 74 65 33 20 2a 64  elete(sqlite3 *d
5640: 62 2c 20 57 69 6e 64 6f 77 20 2a 70 29 7b 0a 20  b, Window *p){. 
5650: 20 69 66 28 20 70 20 29 7b 0a 20 20 20 20 73 71   if( p ){.    sq
5660: 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65 28  lite3ExprDelete(
5670: 64 62 2c 20 70 2d 3e 70 46 69 6c 74 65 72 29 3b  db, p->pFilter);
5680: 0a 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72  .    sqlite3Expr
5690: 4c 69 73 74 44 65 6c 65 74 65 28 64 62 2c 20 70  ListDelete(db, p
56a0: 2d 3e 70 50 61 72 74 69 74 69 6f 6e 29 3b 0a 20  ->pPartition);. 
56b0: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69     sqlite3ExprLi
56c0: 73 74 44 65 6c 65 74 65 28 64 62 2c 20 70 2d 3e  stDelete(db, p->
56d0: 70 4f 72 64 65 72 42 79 29 3b 0a 20 20 20 20 73  pOrderBy);.    s
56e0: 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74 65  qlite3ExprDelete
56f0: 28 64 62 2c 20 70 2d 3e 70 45 6e 64 29 3b 0a 20  (db, p->pEnd);. 
5700: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 44 65     sqlite3ExprDe
5710: 6c 65 74 65 28 64 62 2c 20 70 2d 3e 70 53 74 61  lete(db, p->pSta
5720: 72 74 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  rt);.    sqlite3
5730: 44 62 46 72 65 65 28 64 62 2c 20 70 2d 3e 7a 4e  DbFree(db, p->zN
5740: 61 6d 65 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  ame);.    sqlite
5750: 33 44 62 46 72 65 65 28 64 62 2c 20 70 29 3b 0a  3DbFree(db, p);.
5760: 20 20 7d 0a 7d 0a 0a 76 6f 69 64 20 73 71 6c 69    }.}..void sqli
5770: 74 65 33 57 69 6e 64 6f 77 4c 69 73 74 44 65 6c  te3WindowListDel
5780: 65 74 65 28 73 71 6c 69 74 65 33 20 2a 64 62 2c  ete(sqlite3 *db,
5790: 20 57 69 6e 64 6f 77 20 2a 70 29 7b 0a 20 20 77   Window *p){.  w
57a0: 68 69 6c 65 28 20 70 20 29 7b 0a 20 20 20 20 57  hile( p ){.    W
57b0: 69 6e 64 6f 77 20 2a 70 4e 65 78 74 20 3d 20 70  indow *pNext = p
57c0: 2d 3e 70 4e 65 78 74 57 69 6e 3b 0a 20 20 20 20  ->pNextWin;.    
57d0: 73 71 6c 69 74 65 33 57 69 6e 64 6f 77 44 65 6c  sqlite3WindowDel
57e0: 65 74 65 28 64 62 2c 20 70 29 3b 0a 20 20 20 20  ete(db, p);.    
57f0: 70 20 3d 20 70 4e 65 78 74 3b 0a 20 20 7d 0a 7d  p = pNext;.  }.}
5800: 0a 0a 57 69 6e 64 6f 77 20 2a 73 71 6c 69 74 65  ..Window *sqlite
5810: 33 57 69 6e 64 6f 77 41 6c 6c 6f 63 28 0a 20 20  3WindowAlloc(.  
5820: 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20 0a  Parse *pParse, .
5830: 20 20 69 6e 74 20 65 54 79 70 65 2c 0a 20 20 69    int eType,.  i
5840: 6e 74 20 65 53 74 61 72 74 2c 20 45 78 70 72 20  nt eStart, Expr 
5850: 2a 70 53 74 61 72 74 2c 0a 20 20 69 6e 74 20 65  *pStart,.  int e
5860: 45 6e 64 2c 20 45 78 70 72 20 2a 70 45 6e 64 0a  End, Expr *pEnd.
5870: 29 7b 0a 20 20 57 69 6e 64 6f 77 20 2a 70 57 69  ){.  Window *pWi
5880: 6e 20 3d 20 28 57 69 6e 64 6f 77 2a 29 73 71 6c  n = (Window*)sql
5890: 69 74 65 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f  ite3DbMallocZero
58a0: 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 73 69 7a  (pParse->db, siz
58b0: 65 6f 66 28 57 69 6e 64 6f 77 29 29 3b 0a 0a 20  eof(Window));.. 
58c0: 20 69 66 28 20 70 57 69 6e 20 29 7b 0a 20 20 20   if( pWin ){.   
58d0: 20 70 57 69 6e 2d 3e 65 54 79 70 65 20 3d 20 65   pWin->eType = e
58e0: 54 79 70 65 3b 0a 20 20 20 20 70 57 69 6e 2d 3e  Type;.    pWin->
58f0: 65 53 74 61 72 74 20 3d 20 65 53 74 61 72 74 3b  eStart = eStart;
5900: 0a 20 20 20 20 70 57 69 6e 2d 3e 65 45 6e 64 20  .    pWin->eEnd 
5910: 3d 20 65 45 6e 64 3b 0a 20 20 20 20 70 57 69 6e  = eEnd;.    pWin
5920: 2d 3e 70 45 6e 64 20 3d 20 70 45 6e 64 3b 0a 20  ->pEnd = pEnd;. 
5930: 20 20 20 70 57 69 6e 2d 3e 70 53 74 61 72 74 20     pWin->pStart 
5940: 3d 20 70 53 74 61 72 74 3b 0a 20 20 7d 65 6c 73  = pStart;.  }els
5950: 65 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45 78  e{.    sqlite3Ex
5960: 70 72 44 65 6c 65 74 65 28 70 50 61 72 73 65 2d  prDelete(pParse-
5970: 3e 64 62 2c 20 70 45 6e 64 29 3b 0a 20 20 20 20  >db, pEnd);.    
5980: 73 71 6c 69 74 65 33 45 78 70 72 44 65 6c 65 74  sqlite3ExprDelet
5990: 65 28 70 50 61 72 73 65 2d 3e 64 62 2c 20 70 53  e(pParse->db, pS
59a0: 74 61 72 74 29 3b 0a 20 20 7d 0a 0a 20 20 72 65  tart);.  }..  re
59b0: 74 75 72 6e 20 70 57 69 6e 3b 0a 7d 0a 0a 76 6f  turn pWin;.}..vo
59c0: 69 64 20 73 71 6c 69 74 65 33 57 69 6e 64 6f 77  id sqlite3Window
59d0: 41 74 74 61 63 68 28 50 61 72 73 65 20 2a 70 50  Attach(Parse *pP
59e0: 61 72 73 65 2c 20 45 78 70 72 20 2a 70 2c 20 57  arse, Expr *p, W
59f0: 69 6e 64 6f 77 20 2a 70 57 69 6e 29 7b 0a 20 20  indow *pWin){.  
5a00: 69 66 28 20 70 20 29 7b 0a 20 20 20 20 70 2d 3e  if( p ){.    p->
5a10: 70 57 69 6e 20 3d 20 70 57 69 6e 3b 0a 20 20 20  pWin = pWin;.   
5a20: 20 69 66 28 20 70 57 69 6e 20 29 20 70 57 69 6e   if( pWin ) pWin
5a30: 2d 3e 70 4f 77 6e 65 72 20 3d 20 70 3b 0a 20 20  ->pOwner = p;.  
5a40: 7d 65 6c 73 65 7b 0a 20 20 20 20 73 71 6c 69 74  }else{.    sqlit
5a50: 65 33 57 69 6e 64 6f 77 44 65 6c 65 74 65 28 70  e3WindowDelete(p
5a60: 50 61 72 73 65 2d 3e 64 62 2c 20 70 57 69 6e 29  Parse->db, pWin)
5a70: 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52  ;.  }.}../*.** R
5a80: 65 74 75 72 6e 20 30 20 69 66 20 74 68 65 20 74  eturn 0 if the t
5a90: 77 6f 20 77 69 6e 64 6f 77 20 6f 62 6a 65 63 74  wo window object
5aa0: 73 20 61 72 65 20 69 64 65 6e 74 69 63 61 6c 2c  s are identical,
5ab0: 20 6f 72 20 6e 6f 6e 2d 7a 65 72 6f 20 6f 74 68   or non-zero oth
5ac0: 65 72 77 69 73 65 2e 0a 2a 2f 0a 69 6e 74 20 73  erwise..*/.int s
5ad0: 71 6c 69 74 65 33 57 69 6e 64 6f 77 43 6f 6d 70  qlite3WindowComp
5ae0: 61 72 65 28 50 61 72 73 65 20 2a 70 50 61 72 73  are(Parse *pPars
5af0: 65 2c 20 57 69 6e 64 6f 77 20 2a 70 31 2c 20 57  e, Window *p1, W
5b00: 69 6e 64 6f 77 20 2a 70 32 29 7b 0a 20 20 69 66  indow *p2){.  if
5b10: 28 20 70 31 2d 3e 65 54 79 70 65 21 3d 70 32 2d  ( p1->eType!=p2-
5b20: 3e 65 54 79 70 65 20 29 20 72 65 74 75 72 6e 20  >eType ) return 
5b30: 31 3b 0a 20 20 69 66 28 20 70 31 2d 3e 65 53 74  1;.  if( p1->eSt
5b40: 61 72 74 21 3d 70 32 2d 3e 65 53 74 61 72 74 20  art!=p2->eStart 
5b50: 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 69 66  ) return 1;.  if
5b60: 28 20 70 31 2d 3e 65 45 6e 64 21 3d 70 32 2d 3e  ( p1->eEnd!=p2->
5b70: 65 45 6e 64 20 29 20 72 65 74 75 72 6e 20 31 3b  eEnd ) return 1;
5b80: 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 45 78  .  if( sqlite3Ex
5b90: 70 72 43 6f 6d 70 61 72 65 28 70 50 61 72 73 65  prCompare(pParse
5ba0: 2c 20 70 31 2d 3e 70 53 74 61 72 74 2c 20 70 32  , p1->pStart, p2
5bb0: 2d 3e 70 53 74 61 72 74 2c 20 2d 31 29 20 29 20  ->pStart, -1) ) 
5bc0: 72 65 74 75 72 6e 20 31 3b 0a 20 20 69 66 28 20  return 1;.  if( 
5bd0: 73 71 6c 69 74 65 33 45 78 70 72 43 6f 6d 70 61  sqlite3ExprCompa
5be0: 72 65 28 70 50 61 72 73 65 2c 20 70 31 2d 3e 70  re(pParse, p1->p
5bf0: 45 6e 64 2c 20 70 32 2d 3e 70 45 6e 64 2c 20 2d  End, p2->pEnd, -
5c00: 31 29 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20  1) ) return 1;. 
5c10: 20 69 66 28 20 73 71 6c 69 74 65 33 45 78 70 72   if( sqlite3Expr
5c20: 4c 69 73 74 43 6f 6d 70 61 72 65 28 70 31 2d 3e  ListCompare(p1->
5c30: 70 50 61 72 74 69 74 69 6f 6e 2c 20 70 32 2d 3e  pPartition, p2->
5c40: 70 50 61 72 74 69 74 69 6f 6e 2c 20 2d 31 29 20  pPartition, -1) 
5c50: 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 69 66  ) return 1;.  if
5c60: 28 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69 73  ( sqlite3ExprLis
5c70: 74 43 6f 6d 70 61 72 65 28 70 31 2d 3e 70 4f 72  tCompare(p1->pOr
5c80: 64 65 72 42 79 2c 20 70 32 2d 3e 70 4f 72 64 65  derBy, p2->pOrde
5c90: 72 42 79 2c 20 2d 31 29 20 29 20 72 65 74 75 72  rBy, -1) ) retur
5ca0: 6e 20 31 3b 0a 20 20 72 65 74 75 72 6e 20 30 3b  n 1;.  return 0;
5cb0: 0a 7d 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .}..static void 
5cc0: 77 69 6e 64 6f 77 41 67 67 49 6e 69 74 28 50 61  windowAggInit(Pa
5cd0: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 57 69 6e  rse *pParse, Win
5ce0: 64 6f 77 20 2a 70 4d 57 69 6e 29 7b 0a 20 20 57  dow *pMWin){.  W
5cf0: 69 6e 64 6f 77 20 2a 70 57 69 6e 3b 0a 20 20 66  indow *pWin;.  f
5d00: 6f 72 28 70 57 69 6e 3d 70 4d 57 69 6e 3b 20 70  or(pWin=pMWin; p
5d10: 57 69 6e 3b 20 70 57 69 6e 3d 70 57 69 6e 2d 3e  Win; pWin=pWin->
5d20: 70 4e 65 78 74 57 69 6e 29 7b 0a 20 20 20 20 56  pNextWin){.    V
5d30: 64 62 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 33  dbe *v = sqlite3
5d40: 47 65 74 56 64 62 65 28 70 50 61 72 73 65 29 3b  GetVdbe(pParse);
5d50: 0a 20 20 20 20 46 75 6e 63 44 65 66 20 2a 70 20  .    FuncDef *p 
5d60: 3d 20 70 57 69 6e 2d 3e 70 46 75 6e 63 3b 0a 20  = pWin->pFunc;. 
5d70: 20 20 20 69 66 28 20 28 70 2d 3e 66 75 6e 63 46     if( (p->funcF
5d80: 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 46 55  lags & SQLITE_FU
5d90: 4e 43 5f 4d 49 4e 4d 41 58 29 20 26 26 20 70 57  NC_MINMAX) && pW
5da0: 69 6e 2d 3e 65 53 74 61 72 74 21 3d 54 4b 5f 55  in->eStart!=TK_U
5db0: 4e 42 4f 55 4e 44 45 44 20 29 7b 0a 20 20 20 20  NBOUNDED ){.    
5dc0: 20 20 45 78 70 72 4c 69 73 74 20 2a 70 4c 69 73    ExprList *pLis
5dd0: 74 20 3d 20 70 57 69 6e 2d 3e 70 4f 77 6e 65 72  t = pWin->pOwner
5de0: 2d 3e 78 2e 70 4c 69 73 74 3b 0a 20 20 20 20 20  ->x.pList;.     
5df0: 20 4b 65 79 49 6e 66 6f 20 2a 70 4b 65 79 49 6e   KeyInfo *pKeyIn
5e00: 66 6f 20 3d 20 73 71 6c 69 74 65 33 4b 65 79 49  fo = sqlite3KeyI
5e10: 6e 66 6f 46 72 6f 6d 45 78 70 72 4c 69 73 74 28  nfoFromExprList(
5e20: 70 50 61 72 73 65 2c 20 70 4c 69 73 74 2c 20 30  pParse, pList, 0
5e30: 2c 20 30 29 3b 0a 20 20 20 20 20 20 70 57 69 6e  , 0);.      pWin
5e40: 2d 3e 63 73 72 41 70 70 20 3d 20 70 50 61 72 73  ->csrApp = pPars
5e50: 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20 20 20 20 20  e->nTab++;.     
5e60: 20 70 57 69 6e 2d 3e 72 65 67 41 70 70 20 3d 20   pWin->regApp = 
5e70: 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 2b 31 3b 0a  pParse->nMem+1;.
5e80: 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d        pParse->nM
5e90: 65 6d 20 2b 3d 20 33 3b 0a 20 20 20 20 20 20 69  em += 3;.      i
5ea0: 66 28 20 70 4b 65 79 49 6e 66 6f 20 26 26 20 70  f( pKeyInfo && p
5eb0: 57 69 6e 2d 3e 70 46 75 6e 63 2d 3e 7a 4e 61 6d  Win->pFunc->zNam
5ec0: 65 5b 31 5d 3d 3d 27 69 27 20 29 7b 0a 20 20 20  e[1]=='i' ){.   
5ed0: 20 20 20 20 20 61 73 73 65 72 74 28 20 70 4b 65       assert( pKe
5ee0: 79 49 6e 66 6f 2d 3e 61 53 6f 72 74 4f 72 64 65  yInfo->aSortOrde
5ef0: 72 5b 30 5d 3d 3d 30 20 29 3b 0a 20 20 20 20 20  r[0]==0 );.     
5f00: 20 20 20 70 4b 65 79 49 6e 66 6f 2d 3e 61 53 6f     pKeyInfo->aSo
5f10: 72 74 4f 72 64 65 72 5b 30 5d 20 3d 20 31 3b 0a  rtOrder[0] = 1;.
5f20: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73 71        }.      sq
5f30: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
5f40: 76 2c 20 4f 50 5f 4f 70 65 6e 45 70 68 65 6d 65  v, OP_OpenEpheme
5f50: 72 61 6c 2c 20 70 57 69 6e 2d 3e 63 73 72 41 70  ral, pWin->csrAp
5f60: 70 2c 20 32 29 3b 0a 20 20 20 20 20 20 73 71 6c  p, 2);.      sql
5f70: 69 74 65 33 56 64 62 65 41 70 70 65 6e 64 50 34  ite3VdbeAppendP4
5f80: 28 76 2c 20 70 4b 65 79 49 6e 66 6f 2c 20 50 34  (v, pKeyInfo, P4
5f90: 5f 4b 45 59 49 4e 46 4f 29 3b 0a 20 20 20 20 20  _KEYINFO);.     
5fa0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
5fb0: 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72  p2(v, OP_Integer
5fc0: 2c 20 30 2c 20 70 57 69 6e 2d 3e 72 65 67 41 70  , 0, pWin->regAp
5fd0: 70 2b 31 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  p+1);.    }.    
5fe0: 65 6c 73 65 20 69 66 28 20 70 2d 3e 78 53 46 75  else if( p->xSFu
5ff0: 6e 63 3d 3d 6e 74 68 5f 76 61 6c 75 65 53 74 65  nc==nth_valueSte
6000: 70 46 75 6e 63 20 7c 7c 20 70 2d 3e 78 53 46 75  pFunc || p->xSFu
6010: 6e 63 3d 3d 66 69 72 73 74 5f 76 61 6c 75 65 53  nc==first_valueS
6020: 74 65 70 46 75 6e 63 20 29 7b 0a 20 20 20 20 20  tepFunc ){.     
6030: 20 2f 2a 20 41 6c 6c 6f 63 61 74 65 20 74 77 6f   /* Allocate two
6040: 20 72 65 67 69 73 74 65 72 73 20 61 74 20 70 57   registers at pW
6050: 69 6e 2d 3e 72 65 67 41 70 70 2e 20 54 68 65 73  in->regApp. Thes
6060: 65 20 77 69 6c 6c 20 62 65 20 75 73 65 64 20 74  e will be used t
6070: 6f 0a 20 20 20 20 20 20 2a 2a 20 73 74 6f 72 65  o.      ** store
6080: 20 74 68 65 20 73 74 61 72 74 20 61 6e 64 20 65   the start and e
6090: 6e 64 20 69 6e 64 65 78 20 6f 66 20 74 68 65 20  nd index of the 
60a0: 63 75 72 72 65 6e 74 20 66 72 61 6d 65 2e 20 20  current frame.  
60b0: 2a 2f 0a 20 20 20 20 20 20 61 73 73 65 72 74 28  */.      assert(
60c0: 20 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 20   pMWin->iEphCsr 
60d0: 29 3b 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e 72  );.      pWin->r
60e0: 65 67 41 70 70 20 3d 20 70 50 61 72 73 65 2d 3e  egApp = pParse->
60f0: 6e 4d 65 6d 2b 31 3b 0a 20 20 20 20 20 20 70 57  nMem+1;.      pW
6100: 69 6e 2d 3e 63 73 72 41 70 70 20 3d 20 70 50 61  in->csrApp = pPa
6110: 72 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20 20 20  rse->nTab++;.   
6120: 20 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20     pParse->nMem 
6130: 2b 3d 20 32 3b 0a 20 20 20 20 20 20 73 71 6c 69  += 2;.      sqli
6140: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
6150: 20 4f 50 5f 4f 70 65 6e 44 75 70 2c 20 70 57 69   OP_OpenDup, pWi
6160: 6e 2d 3e 63 73 72 41 70 70 2c 20 70 4d 57 69 6e  n->csrApp, pMWin
6170: 2d 3e 69 45 70 68 43 73 72 29 3b 0a 20 20 20 20  ->iEphCsr);.    
6180: 7d 0a 20 20 20 20 65 6c 73 65 20 69 66 28 20 70  }.    else if( p
6190: 2d 3e 78 53 46 75 6e 63 3d 3d 6c 65 61 64 53 74  ->xSFunc==leadSt
61a0: 65 70 46 75 6e 63 20 7c 7c 20 70 2d 3e 78 53 46  epFunc || p->xSF
61b0: 75 6e 63 3d 3d 6c 61 67 53 74 65 70 46 75 6e 63  unc==lagStepFunc
61c0: 20 29 7b 0a 20 20 20 20 20 20 61 73 73 65 72 74   ){.      assert
61d0: 28 20 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72  ( pMWin->iEphCsr
61e0: 20 29 3b 0a 20 20 20 20 20 20 70 57 69 6e 2d 3e   );.      pWin->
61f0: 63 73 72 41 70 70 20 3d 20 70 50 61 72 73 65 2d  csrApp = pParse-
6200: 3e 6e 54 61 62 2b 2b 3b 0a 20 20 20 20 20 20 73  >nTab++;.      s
6210: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
6220: 28 76 2c 20 4f 50 5f 4f 70 65 6e 44 75 70 2c 20  (v, OP_OpenDup, 
6230: 70 57 69 6e 2d 3e 63 73 72 41 70 70 2c 20 70 4d  pWin->csrApp, pM
6240: 57 69 6e 2d 3e 69 45 70 68 43 73 72 29 3b 0a 20  Win->iEphCsr);. 
6250: 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 76 6f 69 64     }.  }.}..void
6260: 20 73 71 6c 69 74 65 33 57 69 6e 64 6f 77 43 6f   sqlite3WindowCo
6270: 64 65 49 6e 69 74 28 50 61 72 73 65 20 2a 70 50  deInit(Parse *pP
6280: 61 72 73 65 2c 20 57 69 6e 64 6f 77 20 2a 70 57  arse, Window *pW
6290: 69 6e 29 7b 0a 20 20 56 64 62 65 20 2a 76 20 3d  in){.  Vdbe *v =
62a0: 20 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28   sqlite3GetVdbe(
62b0: 70 50 61 72 73 65 29 3b 0a 20 20 69 6e 74 20 6e  pParse);.  int n
62c0: 50 61 72 74 20 3d 20 28 70 57 69 6e 2d 3e 70 50  Part = (pWin->pP
62d0: 61 72 74 69 74 69 6f 6e 20 3f 20 70 57 69 6e 2d  artition ? pWin-
62e0: 3e 70 50 61 72 74 69 74 69 6f 6e 2d 3e 6e 45 78  >pPartition->nEx
62f0: 70 72 20 3a 20 30 29 3b 0a 20 20 6e 50 61 72 74  pr : 0);.  nPart
6300: 20 2b 3d 20 28 70 57 69 6e 2d 3e 70 4f 72 64 65   += (pWin->pOrde
6310: 72 42 79 20 3f 20 70 57 69 6e 2d 3e 70 4f 72 64  rBy ? pWin->pOrd
6320: 65 72 42 79 2d 3e 6e 45 78 70 72 20 3a 20 30 29  erBy->nExpr : 0)
6330: 3b 0a 20 20 69 66 28 20 6e 50 61 72 74 20 29 7b  ;.  if( nPart ){
6340: 0a 20 20 20 20 70 57 69 6e 2d 3e 72 65 67 50 61  .    pWin->regPa
6350: 72 74 20 3d 20 70 50 61 72 73 65 2d 3e 6e 4d 65  rt = pParse->nMe
6360: 6d 2b 31 3b 0a 20 20 20 20 70 50 61 72 73 65 2d  m+1;.    pParse-
6370: 3e 6e 4d 65 6d 20 2b 3d 20 6e 50 61 72 74 3b 0a  >nMem += nPart;.
6380: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
6390: 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4e 75 6c 6c  ddOp3(v, OP_Null
63a0: 2c 20 30 2c 20 70 57 69 6e 2d 3e 72 65 67 50 61  , 0, pWin->regPa
63b0: 72 74 2c 20 70 57 69 6e 2d 3e 72 65 67 50 61 72  rt, pWin->regPar
63c0: 74 2b 6e 50 61 72 74 2d 31 29 3b 0a 20 20 7d 0a  t+nPart-1);.  }.
63d0: 20 20 77 69 6e 64 6f 77 41 67 67 49 6e 69 74 28    windowAggInit(
63e0: 70 50 61 72 73 65 2c 20 70 57 69 6e 29 3b 0a 7d  pParse, pWin);.}
63f0: 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20 77 69  ..static void wi
6400: 6e 64 6f 77 43 68 65 63 6b 46 72 61 6d 65 56 61  ndowCheckFrameVa
6410: 6c 75 65 28 50 61 72 73 65 20 2a 70 50 61 72 73  lue(Parse *pPars
6420: 65 2c 20 69 6e 74 20 72 65 67 2c 20 69 6e 74 20  e, int reg, int 
6430: 62 45 6e 64 29 7b 0a 20 20 73 74 61 74 69 63 20  bEnd){.  static 
6440: 63 6f 6e 73 74 20 63 68 61 72 20 2a 61 7a 45 72  const char *azEr
6450: 72 5b 5d 20 3d 20 7b 0a 20 20 20 20 22 66 72 61  r[] = {.    "fra
6460: 6d 65 20 73 74 61 72 74 69 6e 67 20 6f 66 66 73  me starting offs
6470: 65 74 20 6d 75 73 74 20 62 65 20 61 20 6e 6f 6e  et must be a non
6480: 2d 6e 65 67 61 74 69 76 65 20 69 6e 74 65 67 65  -negative intege
6490: 72 22 2c 0a 20 20 20 20 22 66 72 61 6d 65 20 65  r",.    "frame e
64a0: 6e 64 69 6e 67 20 6f 66 66 73 65 74 20 6d 75 73  nding offset mus
64b0: 74 20 62 65 20 61 20 6e 6f 6e 2d 6e 65 67 61 74  t be a non-negat
64c0: 69 76 65 20 69 6e 74 65 67 65 72 22 0a 20 20 7d  ive integer".  }
64d0: 3b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71  ;.  Vdbe *v = sq
64e0: 6c 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61  lite3GetVdbe(pPa
64f0: 72 73 65 29 3b 0a 20 20 69 6e 74 20 72 65 67 5a  rse);.  int regZ
6500: 65 72 6f 20 3d 20 2b 2b 70 50 61 72 73 65 2d 3e  ero = ++pParse->
6510: 6e 4d 65 6d 3b 0a 0a 20 20 73 71 6c 69 74 65 33  nMem;..  sqlite3
6520: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
6530: 5f 49 6e 74 65 67 65 72 2c 20 30 2c 20 72 65 67  _Integer, 0, reg
6540: 5a 65 72 6f 29 3b 0a 20 20 73 71 6c 69 74 65 33  Zero);.  sqlite3
6550: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
6560: 5f 4d 75 73 74 42 65 49 6e 74 2c 20 72 65 67 2c  _MustBeInt, reg,
6570: 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72 72   sqlite3VdbeCurr
6580: 65 6e 74 41 64 64 72 28 76 29 2b 32 29 3b 0a 20  entAddr(v)+2);. 
6590: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
65a0: 70 33 28 76 2c 20 4f 50 5f 47 65 2c 20 72 65 67  p3(v, OP_Ge, reg
65b0: 5a 65 72 6f 2c 20 73 71 6c 69 74 65 33 56 64 62  Zero, sqlite3Vdb
65c0: 65 43 75 72 72 65 6e 74 41 64 64 72 28 76 29 2b  eCurrentAddr(v)+
65d0: 32 2c 20 72 65 67 29 3b 0a 20 20 73 71 6c 69 74  2, reg);.  sqlit
65e0: 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20  e3VdbeAddOp2(v, 
65f0: 4f 50 5f 48 61 6c 74 2c 20 53 51 4c 49 54 45 5f  OP_Halt, SQLITE_
6600: 45 52 52 4f 52 2c 20 4f 45 5f 41 62 6f 72 74 29  ERROR, OE_Abort)
6610: 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41  ;.  sqlite3VdbeA
6620: 70 70 65 6e 64 50 34 28 76 2c 20 28 76 6f 69 64  ppendP4(v, (void
6630: 2a 29 61 7a 45 72 72 5b 62 45 6e 64 5d 2c 20 50  *)azErr[bEnd], P
6640: 34 5f 53 54 41 54 49 43 29 3b 0a 7d 0a 0a 73 74  4_STATIC);.}..st
6650: 61 74 69 63 20 69 6e 74 20 77 69 6e 64 6f 77 41  atic int windowA
6660: 72 67 43 6f 75 6e 74 28 57 69 6e 64 6f 77 20 2a  rgCount(Window *
6670: 70 57 69 6e 29 7b 0a 20 20 45 78 70 72 4c 69 73  pWin){.  ExprLis
6680: 74 20 2a 70 4c 69 73 74 20 3d 20 70 57 69 6e 2d  t *pList = pWin-
6690: 3e 70 4f 77 6e 65 72 2d 3e 78 2e 70 4c 69 73 74  >pOwner->x.pList
66a0: 3b 0a 20 20 72 65 74 75 72 6e 20 28 70 4c 69 73  ;.  return (pLis
66b0: 74 20 3f 20 70 4c 69 73 74 2d 3e 6e 45 78 70 72  t ? pList->nExpr
66c0: 20 3a 20 30 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20   : 0);.}../*.** 
66d0: 47 65 6e 65 72 61 74 65 20 56 4d 20 63 6f 64 65  Generate VM code
66e0: 20 74 6f 20 69 6e 76 6f 6b 65 20 65 69 74 68 65   to invoke eithe
66f0: 72 20 78 53 74 65 70 28 29 20 28 69 66 20 62 49  r xStep() (if bI
6700: 6e 76 65 72 73 65 20 69 73 20 30 29 20 6f 72 20  nverse is 0) or 
6710: 0a 2a 2a 20 78 49 6e 76 65 72 73 65 20 28 69 66  .** xInverse (if
6720: 20 62 49 6e 76 65 72 73 65 20 69 73 20 6e 6f 6e   bInverse is non
6730: 2d 7a 65 72 6f 29 20 66 6f 72 20 65 61 63 68 20  -zero) for each 
6740: 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e 20  window function 
6750: 69 6e 20 74 68 65 20 0a 2a 2a 20 6c 69 6e 6b 65  in the .** linke
6760: 64 20 6c 69 73 74 20 73 74 61 72 74 69 6e 67 20  d list starting 
6770: 61 74 20 70 4d 57 69 6e 2e 0a 2a 2f 0a 73 74 61  at pMWin..*/.sta
6780: 74 69 63 20 76 6f 69 64 20 77 69 6e 64 6f 77 41  tic void windowA
6790: 67 67 53 74 65 70 28 0a 20 20 50 61 72 73 65 20  ggStep(.  Parse 
67a0: 2a 70 50 61 72 73 65 2c 20 0a 20 20 57 69 6e 64  *pParse, .  Wind
67b0: 6f 77 20 2a 70 4d 57 69 6e 2c 20 0a 20 20 69 6e  ow *pMWin, .  in
67c0: 74 20 63 73 72 2c 0a 20 20 69 6e 74 20 62 49 6e  t csr,.  int bIn
67d0: 76 65 72 73 65 2c 20 0a 20 20 69 6e 74 20 72 65  verse, .  int re
67e0: 67 2c 0a 20 20 69 6e 74 20 72 65 67 50 61 72 74  g,.  int regPart
67f0: 53 69 7a 65 20 20 20 20 20 20 20 20 20 20 20 20  Size            
6800: 20 20 20 20 20 2f 2a 20 52 65 67 69 73 74 65 72       /* Register
6810: 20 63 6f 6e 74 61 69 6e 69 6e 67 20 73 69 7a 65   containing size
6820: 20 6f 66 20 70 61 72 74 69 74 69 6f 6e 20 2a 2f   of partition */
6830: 0a 29 7b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20  .){.  Vdbe *v = 
6840: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
6850: 50 61 72 73 65 29 3b 0a 20 20 57 69 6e 64 6f 77  Parse);.  Window
6860: 20 2a 70 57 69 6e 3b 0a 20 20 66 6f 72 28 70 57   *pWin;.  for(pW
6870: 69 6e 3d 70 4d 57 69 6e 3b 20 70 57 69 6e 3b 20  in=pMWin; pWin; 
6880: 70 57 69 6e 3d 70 57 69 6e 2d 3e 70 4e 65 78 74  pWin=pWin->pNext
6890: 57 69 6e 29 7b 0a 20 20 20 20 69 6e 74 20 66 6c  Win){.    int fl
68a0: 61 67 73 20 3d 20 70 57 69 6e 2d 3e 70 46 75 6e  ags = pWin->pFun
68b0: 63 2d 3e 66 75 6e 63 46 6c 61 67 73 3b 0a 20 20  c->funcFlags;.  
68c0: 20 20 69 6e 74 20 72 65 67 41 72 67 3b 0a 20 20    int regArg;.  
68d0: 20 20 69 6e 74 20 6e 41 72 67 20 3d 20 77 69 6e    int nArg = win
68e0: 64 6f 77 41 72 67 43 6f 75 6e 74 28 70 57 69 6e  dowArgCount(pWin
68f0: 29 3b 0a 0a 20 20 20 20 69 66 28 20 63 73 72 3e  );..    if( csr>
6900: 3d 30 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20  =0 ){.      int 
6910: 69 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30  i;.      for(i=0
6920: 3b 20 69 3c 6e 41 72 67 3b 20 69 2b 2b 29 7b 0a  ; i<nArg; i++){.
6930: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56          sqlite3V
6940: 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f  dbeAddOp3(v, OP_
6950: 43 6f 6c 75 6d 6e 2c 20 63 73 72 2c 20 70 57 69  Column, csr, pWi
6960: 6e 2d 3e 69 41 72 67 43 6f 6c 2b 69 2c 20 72 65  n->iArgCol+i, re
6970: 67 2b 69 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  g+i);.      }.  
6980: 20 20 20 20 72 65 67 41 72 67 20 3d 20 72 65 67      regArg = reg
6990: 3b 0a 20 20 20 20 20 20 69 66 28 20 66 6c 61 67  ;.      if( flag
69a0: 73 20 26 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f  s & SQLITE_FUNC_
69b0: 57 49 4e 44 4f 57 5f 53 49 5a 45 20 29 7b 0a 20  WINDOW_SIZE ){. 
69c0: 20 20 20 20 20 20 20 69 66 28 20 6e 41 72 67 3d         if( nArg=
69d0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
69e0: 72 65 67 41 72 67 20 3d 20 72 65 67 50 61 72 74  regArg = regPart
69f0: 53 69 7a 65 3b 0a 20 20 20 20 20 20 20 20 7d 65  Size;.        }e
6a00: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 73  lse{.          s
6a10: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
6a20: 28 76 2c 20 4f 50 5f 53 43 6f 70 79 2c 20 72 65  (v, OP_SCopy, re
6a30: 67 50 61 72 74 53 69 7a 65 2c 20 72 65 67 2b 6e  gPartSize, reg+n
6a40: 41 72 67 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  Arg);.        }.
6a50: 20 20 20 20 20 20 20 20 6e 41 72 67 2b 2b 3b 0a          nArg++;.
6a60: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 65 6c 73        }.    }els
6a70: 65 7b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28  e{.      assert(
6a80: 20 21 28 66 6c 61 67 73 20 26 20 53 51 4c 49 54   !(flags & SQLIT
6a90: 45 5f 46 55 4e 43 5f 57 49 4e 44 4f 57 5f 53 49  E_FUNC_WINDOW_SI
6aa0: 5a 45 29 20 29 3b 0a 20 20 20 20 20 20 72 65 67  ZE) );.      reg
6ab0: 41 72 67 20 3d 20 72 65 67 20 2b 20 70 57 69 6e  Arg = reg + pWin
6ac0: 2d 3e 69 41 72 67 43 6f 6c 3b 0a 20 20 20 20 7d  ->iArgCol;.    }
6ad0: 0a 0a 20 20 20 20 69 66 28 20 28 70 57 69 6e 2d  ..    if( (pWin-
6ae0: 3e 70 46 75 6e 63 2d 3e 66 75 6e 63 46 6c 61 67  >pFunc->funcFlag
6af0: 73 20 26 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f  s & SQLITE_FUNC_
6b00: 4d 49 4e 4d 41 58 29 20 0a 20 20 20 20 20 20 26  MINMAX) .      &
6b10: 26 20 70 57 69 6e 2d 3e 65 53 74 61 72 74 21 3d  & pWin->eStart!=
6b20: 54 4b 5f 55 4e 42 4f 55 4e 44 45 44 20 0a 20 20  TK_UNBOUNDED .  
6b30: 20 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20 62    ){.      if( b
6b40: 49 6e 76 65 72 73 65 3d 3d 30 20 29 7b 0a 20 20  Inverse==0 ){.  
6b50: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
6b60: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 41 64  eAddOp2(v, OP_Ad
6b70: 64 49 6d 6d 2c 20 70 57 69 6e 2d 3e 72 65 67 41  dImm, pWin->regA
6b80: 70 70 2b 31 2c 20 31 29 3b 0a 20 20 20 20 20 20  pp+1, 1);.      
6b90: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
6ba0: 4f 70 32 28 76 2c 20 4f 50 5f 53 43 6f 70 79 2c  Op2(v, OP_SCopy,
6bb0: 20 72 65 67 41 72 67 2c 20 70 57 69 6e 2d 3e 72   regArg, pWin->r
6bc0: 65 67 41 70 70 29 3b 0a 20 20 20 20 20 20 20 20  egApp);.        
6bd0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
6be0: 33 28 76 2c 20 4f 50 5f 4d 61 6b 65 52 65 63 6f  3(v, OP_MakeReco
6bf0: 72 64 2c 20 70 57 69 6e 2d 3e 72 65 67 41 70 70  rd, pWin->regApp
6c00: 2c 20 32 2c 20 70 57 69 6e 2d 3e 72 65 67 41 70  , 2, pWin->regAp
6c10: 70 2b 32 29 3b 0a 20 20 20 20 20 20 20 20 73 71  p+2);.        sq
6c20: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
6c30: 76 2c 20 4f 50 5f 49 64 78 49 6e 73 65 72 74 2c  v, OP_IdxInsert,
6c40: 20 70 57 69 6e 2d 3e 63 73 72 41 70 70 2c 20 70   pWin->csrApp, p
6c50: 57 69 6e 2d 3e 72 65 67 41 70 70 2b 32 29 3b 0a  Win->regApp+2);.
6c60: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
6c70: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
6c80: 41 64 64 4f 70 34 49 6e 74 28 76 2c 20 4f 50 5f  AddOp4Int(v, OP_
6c90: 53 65 65 6b 47 45 2c 20 70 57 69 6e 2d 3e 63 73  SeekGE, pWin->cs
6ca0: 72 41 70 70 2c 20 30 2c 20 72 65 67 41 72 67 2c  rApp, 0, regArg,
6cb0: 20 31 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c   1);.        sql
6cc0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 31 28 76  ite3VdbeAddOp1(v
6cd0: 2c 20 4f 50 5f 44 65 6c 65 74 65 2c 20 70 57 69  , OP_Delete, pWi
6ce0: 6e 2d 3e 63 73 72 41 70 70 29 3b 0a 20 20 20 20  n->csrApp);.    
6cf0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4a      sqlite3VdbeJ
6d00: 75 6d 70 48 65 72 65 28 76 2c 20 73 71 6c 69 74  umpHere(v, sqlit
6d10: 65 33 56 64 62 65 43 75 72 72 65 6e 74 41 64 64  e3VdbeCurrentAdd
6d20: 72 28 76 29 2d 32 29 3b 0a 20 20 20 20 20 20 7d  r(v)-2);.      }
6d30: 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 70  .    }else if( p
6d40: 57 69 6e 2d 3e 72 65 67 41 70 70 20 29 7b 0a 20  Win->regApp ){. 
6d50: 20 20 20 20 20 61 73 73 65 72 74 28 20 70 57 69       assert( pWi
6d60: 6e 2d 3e 70 46 75 6e 63 2d 3e 78 53 46 75 6e 63  n->pFunc->xSFunc
6d70: 3d 3d 6e 74 68 5f 76 61 6c 75 65 53 74 65 70 46  ==nth_valueStepF
6d80: 75 6e 63 20 0a 20 20 20 20 20 20 20 20 20 20 20  unc .           
6d90: 7c 7c 20 70 57 69 6e 2d 3e 70 46 75 6e 63 2d 3e  || pWin->pFunc->
6da0: 78 53 46 75 6e 63 3d 3d 66 69 72 73 74 5f 76 61  xSFunc==first_va
6db0: 6c 75 65 53 74 65 70 46 75 6e 63 20 0a 20 20 20  lueStepFunc .   
6dc0: 20 20 20 29 3b 0a 20 20 20 20 20 20 61 73 73 65     );.      asse
6dd0: 72 74 28 20 62 49 6e 76 65 72 73 65 3d 3d 30 20  rt( bInverse==0 
6de0: 7c 7c 20 62 49 6e 76 65 72 73 65 3d 3d 31 20 29  || bInverse==1 )
6df0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
6e00: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
6e10: 41 64 64 49 6d 6d 2c 20 70 57 69 6e 2d 3e 72 65  AddImm, pWin->re
6e20: 67 41 70 70 2b 31 2d 62 49 6e 76 65 72 73 65 2c  gApp+1-bInverse,
6e30: 20 31 29 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69   1);.    }else i
6e40: 66 28 20 70 57 69 6e 2d 3e 70 46 75 6e 63 2d 3e  f( pWin->pFunc->
6e50: 78 53 46 75 6e 63 3d 3d 6c 65 61 64 53 74 65 70  xSFunc==leadStep
6e60: 46 75 6e 63 20 0a 20 20 20 20 20 20 20 20 20 20  Func .          
6e70: 20 7c 7c 20 70 57 69 6e 2d 3e 70 46 75 6e 63 2d   || pWin->pFunc-
6e80: 3e 78 53 46 75 6e 63 3d 3d 6c 61 67 53 74 65 70  >xSFunc==lagStep
6e90: 46 75 6e 63 20 0a 20 20 20 20 29 7b 0a 20 20 20  Func .    ){.   
6ea0: 20 20 20 2f 2a 20 6e 6f 2d 6f 70 20 2a 2f 0a 20     /* no-op */. 
6eb0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
6ec0: 69 6e 74 20 61 64 64 72 49 66 20 3d 20 30 3b 0a  int addrIf = 0;.
6ed0: 20 20 20 20 20 20 69 66 28 20 70 57 69 6e 2d 3e        if( pWin->
6ee0: 70 46 69 6c 74 65 72 20 29 7b 0a 20 20 20 20 20  pFilter ){.     
6ef0: 20 20 20 69 6e 74 20 72 65 67 54 6d 70 3b 0a 20     int regTmp;. 
6f00: 20 20 20 20 20 20 20 61 73 73 65 72 74 28 20 6e         assert( n
6f10: 41 72 67 3d 3d 70 57 69 6e 2d 3e 70 4f 77 6e 65  Arg==pWin->pOwne
6f20: 72 2d 3e 78 2e 70 4c 69 73 74 2d 3e 6e 45 78 70  r->x.pList->nExp
6f30: 72 20 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28  r );.        if(
6f40: 20 63 73 72 3e 30 20 29 7b 0a 20 20 20 20 20 20   csr>0 ){.      
6f50: 20 20 20 20 72 65 67 54 6d 70 20 3d 20 73 71 6c      regTmp = sql
6f60: 69 74 65 33 47 65 74 54 65 6d 70 52 65 67 28 70  ite3GetTempReg(p
6f70: 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20 20 20  Parse);.        
6f80: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
6f90: 4f 70 33 28 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e  Op3(v, OP_Column
6fa0: 2c 20 63 73 72 2c 20 70 57 69 6e 2d 3e 69 41 72  , csr, pWin->iAr
6fb0: 67 43 6f 6c 2b 6e 41 72 67 2c 72 65 67 54 6d 70  gCol+nArg,regTmp
6fc0: 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65  );.        }else
6fd0: 7b 0a 20 20 20 20 20 20 20 20 20 20 72 65 67 54  {.          regT
6fe0: 6d 70 20 3d 20 72 65 67 41 72 67 20 2b 20 6e 41  mp = regArg + nA
6ff0: 72 67 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  rg;.        }.  
7000: 20 20 20 20 20 20 61 64 64 72 49 66 20 3d 20 73        addrIf = s
7010: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33  qlite3VdbeAddOp3
7020: 28 76 2c 20 4f 50 5f 49 66 4e 6f 74 2c 20 72 65  (v, OP_IfNot, re
7030: 67 54 6d 70 2c 20 30 2c 20 31 29 3b 0a 20 20 20  gTmp, 0, 1);.   
7040: 20 20 20 20 20 69 66 28 20 63 73 72 3e 30 20 29       if( csr>0 )
7050: 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  {.          sqli
7060: 74 65 33 52 65 6c 65 61 73 65 54 65 6d 70 52 65  te3ReleaseTempRe
7070: 67 28 70 50 61 72 73 65 2c 20 72 65 67 54 6d 70  g(pParse, regTmp
7080: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
7090: 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20 70     }.      if( p
70a0: 57 69 6e 2d 3e 70 46 75 6e 63 2d 3e 66 75 6e 63  Win->pFunc->func
70b0: 46 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 46  Flags & SQLITE_F
70c0: 55 4e 43 5f 4e 45 45 44 43 4f 4c 4c 20 29 7b 0a  UNC_NEEDCOLL ){.
70d0: 20 20 20 20 20 20 20 20 43 6f 6c 6c 53 65 71 20          CollSeq 
70e0: 2a 70 43 6f 6c 6c 3b 0a 20 20 20 20 20 20 20 20  *pColl;.        
70f0: 70 43 6f 6c 6c 20 3d 20 73 71 6c 69 74 65 33 45  pColl = sqlite3E
7100: 78 70 72 4e 4e 43 6f 6c 6c 53 65 71 28 70 50 61  xprNNCollSeq(pPa
7110: 72 73 65 2c 20 70 57 69 6e 2d 3e 70 4f 77 6e 65  rse, pWin->pOwne
7120: 72 2d 3e 78 2e 70 4c 69 73 74 2d 3e 61 5b 30 5d  r->x.pList->a[0]
7130: 2e 70 45 78 70 72 29 3b 0a 20 20 20 20 20 20 20  .pExpr);.       
7140: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
7150: 70 34 28 76 2c 20 4f 50 5f 43 6f 6c 6c 53 65 71  p4(v, OP_CollSeq
7160: 2c 20 30 2c 30 2c 30 2c 20 28 63 6f 6e 73 74 20  , 0,0,0, (const 
7170: 63 68 61 72 2a 29 70 43 6f 6c 6c 2c 20 50 34 5f  char*)pColl, P4_
7180: 43 4f 4c 4c 53 45 51 29 3b 0a 20 20 20 20 20 20  COLLSEQ);.      
7190: 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  }.      sqlite3V
71a0: 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f  dbeAddOp3(v, OP_
71b0: 41 67 67 53 74 65 70 30 2c 20 62 49 6e 76 65 72  AggStep0, bInver
71c0: 73 65 2c 20 72 65 67 41 72 67 2c 20 70 57 69 6e  se, regArg, pWin
71d0: 2d 3e 72 65 67 41 63 63 75 6d 29 3b 0a 20 20 20  ->regAccum);.   
71e0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 70     sqlite3VdbeAp
71f0: 70 65 6e 64 50 34 28 76 2c 20 70 57 69 6e 2d 3e  pendP4(v, pWin->
7200: 70 46 75 6e 63 2c 20 50 34 5f 46 55 4e 43 44 45  pFunc, P4_FUNCDE
7210: 46 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  F);.      sqlite
7220: 33 56 64 62 65 43 68 61 6e 67 65 50 35 28 76 2c  3VdbeChangeP5(v,
7230: 20 28 75 38 29 6e 41 72 67 29 3b 0a 20 20 20 20   (u8)nArg);.    
7240: 20 20 69 66 28 20 61 64 64 72 49 66 20 29 20 73    if( addrIf ) s
7250: 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65  qlite3VdbeJumpHe
7260: 72 65 28 76 2c 20 61 64 64 72 49 66 29 3b 0a 20  re(v, addrIf);. 
7270: 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 73 74 61 74     }.  }.}..stat
7280: 69 63 20 76 6f 69 64 20 77 69 6e 64 6f 77 41 67  ic void windowAg
7290: 67 46 69 6e 61 6c 28 50 61 72 73 65 20 2a 70 50  gFinal(Parse *pP
72a0: 61 72 73 65 2c 20 57 69 6e 64 6f 77 20 2a 70 4d  arse, Window *pM
72b0: 57 69 6e 2c 20 69 6e 74 20 62 46 69 6e 61 6c 29  Win, int bFinal)
72c0: 7b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71  {.  Vdbe *v = sq
72d0: 6c 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61  lite3GetVdbe(pPa
72e0: 72 73 65 29 3b 0a 20 20 57 69 6e 64 6f 77 20 2a  rse);.  Window *
72f0: 70 57 69 6e 3b 0a 0a 20 20 66 6f 72 28 70 57 69  pWin;..  for(pWi
7300: 6e 3d 70 4d 57 69 6e 3b 20 70 57 69 6e 3b 20 70  n=pMWin; pWin; p
7310: 57 69 6e 3d 70 57 69 6e 2d 3e 70 4e 65 78 74 57  Win=pWin->pNextW
7320: 69 6e 29 7b 0a 20 20 20 20 69 66 28 20 28 70 57  in){.    if( (pW
7330: 69 6e 2d 3e 70 46 75 6e 63 2d 3e 66 75 6e 63 46  in->pFunc->funcF
7340: 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 46 55  lags & SQLITE_FU
7350: 4e 43 5f 4d 49 4e 4d 41 58 29 20 0a 20 20 20 20  NC_MINMAX) .    
7360: 20 26 26 20 70 57 69 6e 2d 3e 65 53 74 61 72 74   && pWin->eStart
7370: 21 3d 54 4b 5f 55 4e 42 4f 55 4e 44 45 44 20 0a  !=TK_UNBOUNDED .
7380: 20 20 20 20 29 7b 0a 20 20 20 20 20 20 73 71 6c      ){.      sql
7390: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
73a0: 2c 20 4f 50 5f 4e 75 6c 6c 2c 20 30 2c 20 70 57  , OP_Null, 0, pW
73b0: 69 6e 2d 3e 72 65 67 52 65 73 75 6c 74 29 3b 0a  in->regResult);.
73c0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
73d0: 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f 4c 61  eAddOp1(v, OP_La
73e0: 73 74 2c 20 70 57 69 6e 2d 3e 63 73 72 41 70 70  st, pWin->csrApp
73f0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
7400: 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50  VdbeAddOp3(v, OP
7410: 5f 43 6f 6c 75 6d 6e 2c 20 70 57 69 6e 2d 3e 63  _Column, pWin->c
7420: 73 72 41 70 70 2c 20 30 2c 20 70 57 69 6e 2d 3e  srApp, 0, pWin->
7430: 72 65 67 52 65 73 75 6c 74 29 3b 0a 20 20 20 20  regResult);.    
7440: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d    sqlite3VdbeJum
7450: 70 48 65 72 65 28 76 2c 20 73 71 6c 69 74 65 33  pHere(v, sqlite3
7460: 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72 28  VdbeCurrentAddr(
7470: 76 29 2d 32 29 3b 0a 20 20 20 20 20 20 69 66 28  v)-2);.      if(
7480: 20 62 46 69 6e 61 6c 20 29 7b 0a 20 20 20 20 20   bFinal ){.     
7490: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
74a0: 64 4f 70 31 28 76 2c 20 4f 50 5f 52 65 73 65 74  dOp1(v, OP_Reset
74b0: 53 6f 72 74 65 72 2c 20 70 57 69 6e 2d 3e 63 73  Sorter, pWin->cs
74c0: 72 41 70 70 29 3b 0a 20 20 20 20 20 20 7d 0a 20  rApp);.      }. 
74d0: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 70 57 69     }else if( pWi
74e0: 6e 2d 3e 72 65 67 41 70 70 20 29 7b 0a 20 20 20  n->regApp ){.   
74f0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 66   }else{.      if
7500: 28 20 62 46 69 6e 61 6c 3d 3d 30 20 29 7b 0a 20  ( bFinal==0 ){. 
7510: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64         sqlite3Vd
7520: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 4e  beAddOp2(v, OP_N
7530: 75 6c 6c 2c 20 30 2c 20 70 57 69 6e 2d 3e 72 65  ull, 0, pWin->re
7540: 67 52 65 73 75 6c 74 29 3b 0a 20 20 20 20 20 20  gResult);.      
7550: 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  }.      sqlite3V
7560: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
7570: 41 67 67 46 69 6e 61 6c 2c 20 70 57 69 6e 2d 3e  AggFinal, pWin->
7580: 72 65 67 41 63 63 75 6d 2c 20 77 69 6e 64 6f 77  regAccum, window
7590: 41 72 67 43 6f 75 6e 74 28 70 57 69 6e 29 29 3b  ArgCount(pWin));
75a0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
75b0: 62 65 41 70 70 65 6e 64 50 34 28 76 2c 20 70 57  beAppendP4(v, pW
75c0: 69 6e 2d 3e 70 46 75 6e 63 2c 20 50 34 5f 46 55  in->pFunc, P4_FU
75d0: 4e 43 44 45 46 29 3b 0a 20 20 20 20 20 20 69 66  NCDEF);.      if
75e0: 28 20 62 46 69 6e 61 6c 20 29 7b 0a 20 20 20 20  ( bFinal ){.    
75f0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
7600: 64 64 4f 70 32 28 76 2c 20 4f 50 5f 43 6f 70 79  ddOp2(v, OP_Copy
7610: 2c 20 70 57 69 6e 2d 3e 72 65 67 41 63 63 75 6d  , pWin->regAccum
7620: 2c 20 70 57 69 6e 2d 3e 72 65 67 52 65 73 75 6c  , pWin->regResul
7630: 74 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  t);.        sqli
7640: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
7650: 20 4f 50 5f 4e 75 6c 6c 2c 20 30 2c 20 70 57 69   OP_Null, 0, pWi
7660: 6e 2d 3e 72 65 67 41 63 63 75 6d 29 3b 0a 20 20  n->regAccum);.  
7670: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
7680: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68     sqlite3VdbeCh
7690: 61 6e 67 65 50 33 28 76 2c 20 2d 31 2c 20 70 57  angeP3(v, -1, pW
76a0: 69 6e 2d 3e 72 65 67 52 65 73 75 6c 74 29 3b 0a  in->regResult);.
76b0: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
76c0: 7d 0a 7d 0a 0a 73 74 61 74 69 63 20 76 6f 69 64  }.}..static void
76d0: 20 77 69 6e 64 6f 77 50 61 72 74 69 74 69 6f 6e   windowPartition
76e0: 43 61 63 68 65 28 0a 20 20 50 61 72 73 65 20 2a  Cache(.  Parse *
76f0: 70 50 61 72 73 65 2c 0a 20 20 53 65 6c 65 63 74  pParse,.  Select
7700: 20 2a 70 2c 0a 20 20 57 68 65 72 65 49 6e 66 6f   *p,.  WhereInfo
7710: 20 2a 70 57 49 6e 66 6f 2c 0a 20 20 69 6e 74 20   *pWInfo,.  int 
7720: 72 65 67 46 6c 75 73 68 50 61 72 74 2c 0a 20 20  regFlushPart,.  
7730: 69 6e 74 20 6c 62 6c 46 6c 75 73 68 50 61 72 74  int lblFlushPart
7740: 2c 0a 20 20 69 6e 74 20 2a 70 52 65 67 53 69 7a  ,.  int *pRegSiz
7750: 65 0a 29 7b 0a 20 20 57 69 6e 64 6f 77 20 2a 70  e.){.  Window *p
7760: 4d 57 69 6e 20 3d 20 70 2d 3e 70 57 69 6e 3b 0a  MWin = p->pWin;.
7770: 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71 6c 69    Vdbe *v = sqli
7780: 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73  te3GetVdbe(pPars
7790: 65 29 3b 0a 20 20 57 69 6e 64 6f 77 20 2a 70 57  e);.  Window *pW
77a0: 69 6e 3b 0a 20 20 69 6e 74 20 69 53 75 62 43 73  in;.  int iSubCs
77b0: 72 20 3d 20 70 2d 3e 70 53 72 63 2d 3e 61 5b 30  r = p->pSrc->a[0
77c0: 5d 2e 69 43 75 72 73 6f 72 3b 0a 20 20 69 6e 74  ].iCursor;.  int
77d0: 20 6e 53 75 62 20 3d 20 70 2d 3e 70 53 72 63 2d   nSub = p->pSrc-
77e0: 3e 61 5b 30 5d 2e 70 54 61 62 2d 3e 6e 43 6f 6c  >a[0].pTab->nCol
77f0: 3b 0a 20 20 69 6e 74 20 6b 3b 0a 0a 20 20 69 6e  ;.  int k;..  in
7800: 74 20 72 65 67 20 3d 20 70 50 61 72 73 65 2d 3e  t reg = pParse->
7810: 6e 4d 65 6d 2b 31 3b 0a 20 20 69 6e 74 20 72 65  nMem+1;.  int re
7820: 67 52 65 63 6f 72 64 20 3d 20 72 65 67 2b 6e 53  gRecord = reg+nS
7830: 75 62 3b 0a 20 20 69 6e 74 20 72 65 67 52 6f 77  ub;.  int regRow
7840: 69 64 20 3d 20 72 65 67 52 65 63 6f 72 64 2b 31  id = regRecord+1
7850: 3b 0a 0a 20 20 2a 70 52 65 67 53 69 7a 65 20 3d  ;..  *pRegSize =
7860: 20 72 65 67 52 6f 77 69 64 3b 0a 20 20 70 50 61   regRowid;.  pPa
7870: 72 73 65 2d 3e 6e 4d 65 6d 20 2b 3d 20 6e 53 75  rse->nMem += nSu
7880: 62 20 2b 20 32 3b 0a 0a 20 20 2f 2a 20 4d 61 72  b + 2;..  /* Mar
7890: 74 69 61 6c 20 74 68 65 20 72 6f 77 20 72 65 74  tial the row ret
78a0: 75 72 6e 65 64 20 62 79 20 74 68 65 20 73 75 62  urned by the sub
78b0: 2d 73 65 6c 65 63 74 20 69 6e 74 6f 20 61 6e 20  -select into an 
78c0: 61 72 72 61 79 20 6f 66 20 0a 20 20 2a 2a 20 72  array of .  ** r
78d0: 65 67 69 73 74 65 72 73 2e 20 2a 2f 0a 20 20 66  egisters. */.  f
78e0: 6f 72 28 6b 3d 30 3b 20 6b 3c 6e 53 75 62 3b 20  or(k=0; k<nSub; 
78f0: 6b 2b 2b 29 7b 0a 20 20 20 20 73 71 6c 69 74 65  k++){.    sqlite
7900: 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f  3VdbeAddOp3(v, O
7910: 50 5f 43 6f 6c 75 6d 6e 2c 20 69 53 75 62 43 73  P_Column, iSubCs
7920: 72 2c 20 6b 2c 20 72 65 67 2b 6b 29 3b 0a 20 20  r, k, reg+k);.  
7930: 7d 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41  }.  sqlite3VdbeA
7940: 64 64 4f 70 33 28 76 2c 20 4f 50 5f 4d 61 6b 65  ddOp3(v, OP_Make
7950: 52 65 63 6f 72 64 2c 20 72 65 67 2c 20 6e 53 75  Record, reg, nSu
7960: 62 2c 20 72 65 67 52 65 63 6f 72 64 29 3b 0a 0a  b, regRecord);..
7970: 20 20 2f 2a 20 43 68 65 63 6b 20 69 66 20 74 68    /* Check if th
7980: 69 73 20 69 73 20 74 68 65 20 73 74 61 72 74 20  is is the start 
7990: 6f 66 20 61 20 6e 65 77 20 70 61 72 74 69 74 69  of a new partiti
79a0: 6f 6e 2e 20 49 66 20 73 6f 2c 20 63 61 6c 6c 20  on. If so, call 
79b0: 74 68 65 0a 20 20 2a 2a 20 66 6c 75 73 68 5f 70  the.  ** flush_p
79c0: 61 72 74 69 74 69 6f 6e 20 73 75 62 2d 72 6f 75  artition sub-rou
79d0: 74 69 6e 65 2e 20 20 2a 2f 0a 20 20 69 66 28 20  tine.  */.  if( 
79e0: 70 4d 57 69 6e 2d 3e 70 50 61 72 74 69 74 69 6f  pMWin->pPartitio
79f0: 6e 20 29 7b 0a 20 20 20 20 69 6e 74 20 61 64 64  n ){.    int add
7a00: 72 3b 0a 20 20 20 20 45 78 70 72 4c 69 73 74 20  r;.    ExprList 
7a10: 2a 70 50 61 72 74 20 3d 20 70 4d 57 69 6e 2d 3e  *pPart = pMWin->
7a20: 70 50 61 72 74 69 74 69 6f 6e 3b 0a 20 20 20 20  pPartition;.    
7a30: 69 6e 74 20 6e 50 61 72 74 20 3d 20 28 70 50 61  int nPart = (pPa
7a40: 72 74 20 3f 20 70 50 61 72 74 2d 3e 6e 45 78 70  rt ? pPart->nExp
7a50: 72 20 3a 20 30 29 3b 0a 20 20 20 20 69 6e 74 20  r : 0);.    int 
7a60: 72 65 67 4e 65 77 50 61 72 74 20 3d 20 72 65 67  regNewPart = reg
7a70: 20 2b 20 70 4d 57 69 6e 2d 3e 6e 42 75 66 66 65   + pMWin->nBuffe
7a80: 72 43 6f 6c 3b 0a 20 20 20 20 4b 65 79 49 6e 66  rCol;.    KeyInf
7a90: 6f 20 2a 70 4b 65 79 49 6e 66 6f 20 3d 20 73 71  o *pKeyInfo = sq
7aa0: 6c 69 74 65 33 4b 65 79 49 6e 66 6f 46 72 6f 6d  lite3KeyInfoFrom
7ab0: 45 78 70 72 4c 69 73 74 28 70 50 61 72 73 65 2c  ExprList(pParse,
7ac0: 20 70 50 61 72 74 2c 20 30 2c 20 30 29 3b 0a 0a   pPart, 0, 0);..
7ad0: 20 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74      addr = sqlit
7ae0: 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20  e3VdbeAddOp3(v, 
7af0: 4f 50 5f 43 6f 6d 70 61 72 65 2c 20 72 65 67 4e  OP_Compare, regN
7b00: 65 77 50 61 72 74 2c 20 70 4d 57 69 6e 2d 3e 72  ewPart, pMWin->r
7b10: 65 67 50 61 72 74 2c 6e 50 61 72 74 29 3b 0a 20  egPart,nPart);. 
7b20: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 70     sqlite3VdbeAp
7b30: 70 65 6e 64 50 34 28 76 2c 20 28 76 6f 69 64 2a  pendP4(v, (void*
7b40: 29 70 4b 65 79 49 6e 66 6f 2c 20 50 34 5f 4b 45  )pKeyInfo, P4_KE
7b50: 59 49 4e 46 4f 29 3b 0a 20 20 20 20 73 71 6c 69  YINFO);.    sqli
7b60: 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c  te3VdbeAddOp3(v,
7b70: 20 4f 50 5f 4a 75 6d 70 2c 20 61 64 64 72 2b 32   OP_Jump, addr+2
7b80: 2c 20 61 64 64 72 2b 34 2c 20 61 64 64 72 2b 32  , addr+4, addr+2
7b90: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  );.    sqlite3Vd
7ba0: 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 43  beAddOp3(v, OP_C
7bb0: 6f 70 79 2c 20 72 65 67 4e 65 77 50 61 72 74 2c  opy, regNewPart,
7bc0: 20 70 4d 57 69 6e 2d 3e 72 65 67 50 61 72 74 2c   pMWin->regPart,
7bd0: 20 6e 50 61 72 74 2d 31 29 3b 0a 20 20 20 20 73   nPart-1);.    s
7be0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
7bf0: 28 76 2c 20 4f 50 5f 47 6f 73 75 62 2c 20 72 65  (v, OP_Gosub, re
7c00: 67 46 6c 75 73 68 50 61 72 74 2c 20 6c 62 6c 46  gFlushPart, lblF
7c10: 6c 75 73 68 50 61 72 74 29 3b 0a 20 20 7d 0a 0a  lushPart);.  }..
7c20: 20 20 2f 2a 20 42 75 66 66 65 72 20 74 68 65 20    /* Buffer the 
7c30: 63 75 72 72 65 6e 74 20 72 6f 77 20 69 6e 20 74  current row in t
7c40: 68 65 20 65 70 68 65 6d 65 72 61 6c 20 74 61 62  he ephemeral tab
7c50: 6c 65 2e 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  le. */.  sqlite3
7c60: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
7c70: 5f 4e 65 77 52 6f 77 69 64 2c 20 70 4d 57 69 6e  _NewRowid, pMWin
7c80: 2d 3e 69 45 70 68 43 73 72 2c 20 72 65 67 52 6f  ->iEphCsr, regRo
7c90: 77 69 64 29 3b 0a 20 20 73 71 6c 69 74 65 33 56  wid);.  sqlite3V
7ca0: 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f  dbeAddOp3(v, OP_
7cb0: 49 6e 73 65 72 74 2c 20 70 4d 57 69 6e 2d 3e 69  Insert, pMWin->i
7cc0: 45 70 68 43 73 72 2c 20 72 65 67 52 65 63 6f 72  EphCsr, regRecor
7cd0: 64 2c 20 72 65 67 52 6f 77 69 64 29 3b 0a 0a 20  d, regRowid);.. 
7ce0: 20 2f 2a 20 45 6e 64 20 6f 66 20 74 68 65 20 69   /* End of the i
7cf0: 6e 70 75 74 20 6c 6f 6f 70 20 2a 2f 0a 20 20 73  nput loop */.  s
7d00: 71 6c 69 74 65 33 57 68 65 72 65 45 6e 64 28 70  qlite3WhereEnd(p
7d10: 57 49 6e 66 6f 29 3b 0a 0a 20 20 2f 2a 20 49 6e  WInfo);..  /* In
7d20: 76 6f 6b 65 20 22 66 6c 75 73 68 5f 70 61 72 74  voke "flush_part
7d30: 69 74 69 6f 6e 22 20 74 6f 20 64 65 61 6c 20 77  ition" to deal w
7d40: 69 74 68 20 74 68 65 20 66 69 6e 61 6c 20 28 6f  ith the final (o
7d50: 72 20 6f 6e 6c 79 29 20 70 61 72 74 69 74 69 6f  r only) partitio
7d60: 6e 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 56 64  n */.  sqlite3Vd
7d70: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 47  beAddOp2(v, OP_G
7d80: 6f 73 75 62 2c 20 72 65 67 46 6c 75 73 68 50 61  osub, regFlushPa
7d90: 72 74 2c 20 6c 62 6c 46 6c 75 73 68 50 61 72 74  rt, lblFlushPart
7da0: 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 76 6f 69  );.}..static voi
7db0: 64 20 77 69 6e 64 6f 77 52 65 74 75 72 6e 4f 6e  d windowReturnOn
7dc0: 65 52 6f 77 28 0a 20 20 50 61 72 73 65 20 2a 70  eRow(.  Parse *p
7dd0: 50 61 72 73 65 2c 0a 20 20 57 69 6e 64 6f 77 20  Parse,.  Window 
7de0: 2a 70 4d 57 69 6e 2c 0a 20 20 69 6e 74 20 72 65  *pMWin,.  int re
7df0: 67 47 6f 73 75 62 2c 0a 20 20 69 6e 74 20 61 64  gGosub,.  int ad
7e00: 64 72 47 6f 73 75 62 0a 29 7b 0a 20 20 56 64 62  drGosub.){.  Vdb
7e10: 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 33 47 65  e *v = sqlite3Ge
7e20: 74 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a 20  tVdbe(pParse);. 
7e30: 20 57 69 6e 64 6f 77 20 2a 70 57 69 6e 3b 0a 20   Window *pWin;. 
7e40: 20 66 6f 72 28 70 57 69 6e 3d 70 4d 57 69 6e 3b   for(pWin=pMWin;
7e50: 20 70 57 69 6e 3b 20 70 57 69 6e 3d 70 57 69 6e   pWin; pWin=pWin
7e60: 2d 3e 70 4e 65 78 74 57 69 6e 29 7b 0a 20 20 20  ->pNextWin){.   
7e70: 20 46 75 6e 63 44 65 66 20 2a 70 46 75 6e 63 20   FuncDef *pFunc 
7e80: 3d 20 70 57 69 6e 2d 3e 70 46 75 6e 63 3b 0a 20  = pWin->pFunc;. 
7e90: 20 20 20 69 66 28 20 70 46 75 6e 63 2d 3e 78 53     if( pFunc->xS
7ea0: 46 75 6e 63 3d 3d 6e 74 68 5f 76 61 6c 75 65 53  Func==nth_valueS
7eb0: 74 65 70 46 75 6e 63 20 0a 20 20 20 20 20 7c 7c  tepFunc .     ||
7ec0: 20 70 46 75 6e 63 2d 3e 78 53 46 75 6e 63 3d 3d   pFunc->xSFunc==
7ed0: 66 69 72 73 74 5f 76 61 6c 75 65 53 74 65 70 46  first_valueStepF
7ee0: 75 6e 63 20 0a 20 20 20 20 29 7b 0a 20 20 20 20  unc .    ){.    
7ef0: 20 20 69 6e 74 20 63 73 72 20 3d 20 70 57 69 6e    int csr = pWin
7f00: 2d 3e 63 73 72 41 70 70 3b 0a 20 20 20 20 20 20  ->csrApp;.      
7f10: 69 6e 74 20 6c 62 6c 20 3d 20 73 71 6c 69 74 65  int lbl = sqlite
7f20: 33 56 64 62 65 4d 61 6b 65 4c 61 62 65 6c 28 76  3VdbeMakeLabel(v
7f30: 29 3b 0a 20 20 20 20 20 20 69 6e 74 20 74 6d 70  );.      int tmp
7f40: 52 65 67 20 3d 20 73 71 6c 69 74 65 33 47 65 74  Reg = sqlite3Get
7f50: 54 65 6d 70 52 65 67 28 70 50 61 72 73 65 29 3b  TempReg(pParse);
7f60: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
7f70: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 4e  beAddOp2(v, OP_N
7f80: 75 6c 6c 2c 20 30 2c 20 70 57 69 6e 2d 3e 72 65  ull, 0, pWin->re
7f90: 67 52 65 73 75 6c 74 29 3b 0a 0a 20 20 20 20 20  gResult);..     
7fa0: 20 69 66 28 20 70 46 75 6e 63 2d 3e 78 53 46 75   if( pFunc->xSFu
7fb0: 6e 63 3d 3d 6e 74 68 5f 76 61 6c 75 65 53 74 65  nc==nth_valueSte
7fc0: 70 46 75 6e 63 20 29 7b 0a 20 20 20 20 20 20 20  pFunc ){.       
7fd0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
7fe0: 70 33 28 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e 2c  p3(v, OP_Column,
7ff0: 20 70 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c 20   pWin->iEphCsr, 
8000: 70 57 69 6e 2d 3e 69 41 72 67 43 6f 6c 2b 31 2c  pWin->iArgCol+1,
8010: 20 74 6d 70 52 65 67 29 3b 0a 20 20 20 20 20 20   tmpReg);.      
8020: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 73  }else{.        s
8030: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
8040: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
8050: 31 2c 20 74 6d 70 52 65 67 29 3b 0a 20 20 20 20  1, tmpReg);.    
8060: 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65    }.      sqlite
8070: 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f  3VdbeAddOp3(v, O
8080: 50 5f 41 64 64 2c 20 74 6d 70 52 65 67 2c 20 70  P_Add, tmpReg, p
8090: 57 69 6e 2d 3e 72 65 67 41 70 70 2c 20 74 6d 70  Win->regApp, tmp
80a0: 52 65 67 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  Reg);.      sqli
80b0: 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c  te3VdbeAddOp3(v,
80c0: 20 4f 50 5f 47 74 2c 20 70 57 69 6e 2d 3e 72 65   OP_Gt, pWin->re
80d0: 67 41 70 70 2b 31 2c 20 6c 62 6c 2c 20 74 6d 70  gApp+1, lbl, tmp
80e0: 52 65 67 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  Reg);.      sqli
80f0: 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c  te3VdbeAddOp3(v,
8100: 20 4f 50 5f 53 65 65 6b 52 6f 77 69 64 2c 20 63   OP_SeekRowid, c
8110: 73 72 2c 20 6c 62 6c 2c 20 74 6d 70 52 65 67 29  sr, lbl, tmpReg)
8120: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
8130: 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f  dbeAddOp3(v, OP_
8140: 43 6f 6c 75 6d 6e 2c 20 63 73 72 2c 20 70 57 69  Column, csr, pWi
8150: 6e 2d 3e 69 41 72 67 43 6f 6c 2c 20 70 57 69 6e  n->iArgCol, pWin
8160: 2d 3e 72 65 67 52 65 73 75 6c 74 29 3b 0a 20 20  ->regResult);.  
8170: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 52      sqlite3VdbeR
8180: 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76 2c 20 6c  esolveLabel(v, l
8190: 62 6c 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  bl);.      sqlit
81a0: 65 33 52 65 6c 65 61 73 65 54 65 6d 70 52 65 67  e3ReleaseTempReg
81b0: 28 70 50 61 72 73 65 2c 20 74 6d 70 52 65 67 29  (pParse, tmpReg)
81c0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 65 6c 73 65  ;.    }.    else
81d0: 20 69 66 28 20 70 46 75 6e 63 2d 3e 78 53 46 75   if( pFunc->xSFu
81e0: 6e 63 3d 3d 6c 65 61 64 53 74 65 70 46 75 6e 63  nc==leadStepFunc
81f0: 20 7c 7c 20 70 46 75 6e 63 2d 3e 78 53 46 75 6e   || pFunc->xSFun
8200: 63 3d 3d 6c 61 67 53 74 65 70 46 75 6e 63 20 29  c==lagStepFunc )
8210: 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 41 72 67  {.      int nArg
8220: 20 3d 20 70 57 69 6e 2d 3e 70 4f 77 6e 65 72 2d   = pWin->pOwner-
8230: 3e 78 2e 70 4c 69 73 74 2d 3e 6e 45 78 70 72 3b  >x.pList->nExpr;
8240: 0a 20 20 20 20 20 20 69 6e 74 20 69 45 70 68 20  .      int iEph 
8250: 3d 20 70 57 69 6e 2d 3e 69 45 70 68 43 73 72 3b  = pWin->iEphCsr;
8260: 0a 20 20 20 20 20 20 69 6e 74 20 63 73 72 20 3d  .      int csr =
8270: 20 70 57 69 6e 2d 3e 63 73 72 41 70 70 3b 0a 20   pWin->csrApp;. 
8280: 20 20 20 20 20 69 6e 74 20 6c 62 6c 20 3d 20 73       int lbl = s
8290: 71 6c 69 74 65 33 56 64 62 65 4d 61 6b 65 4c 61  qlite3VdbeMakeLa
82a0: 62 65 6c 28 76 29 3b 0a 20 20 20 20 20 20 69 6e  bel(v);.      in
82b0: 74 20 74 6d 70 52 65 67 20 3d 20 73 71 6c 69 74  t tmpReg = sqlit
82c0: 65 33 47 65 74 54 65 6d 70 52 65 67 28 70 50 61  e3GetTempReg(pPa
82d0: 72 73 65 29 3b 0a 0a 20 20 20 20 20 20 69 66 28  rse);..      if(
82e0: 20 6e 41 72 67 3c 33 20 29 7b 0a 20 20 20 20 20   nArg<3 ){.     
82f0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64     sqlite3VdbeAd
8300: 64 4f 70 32 28 76 2c 20 4f 50 5f 4e 75 6c 6c 2c  dOp2(v, OP_Null,
8310: 20 30 2c 20 70 57 69 6e 2d 3e 72 65 67 52 65 73   0, pWin->regRes
8320: 75 6c 74 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73  ult);.      }els
8330: 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  e{.        sqlit
8340: 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20  e3VdbeAddOp3(v, 
8350: 4f 50 5f 43 6f 6c 75 6d 6e 2c 20 69 45 70 68 2c  OP_Column, iEph,
8360: 20 70 57 69 6e 2d 3e 69 41 72 67 43 6f 6c 2b 32   pWin->iArgCol+2
8370: 2c 20 70 57 69 6e 2d 3e 72 65 67 52 65 73 75 6c  , pWin->regResul
8380: 74 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  t);.      }.    
8390: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
83a0: 4f 70 32 28 76 2c 20 4f 50 5f 52 6f 77 69 64 2c  Op2(v, OP_Rowid,
83b0: 20 69 45 70 68 2c 20 74 6d 70 52 65 67 29 3b 0a   iEph, tmpReg);.
83c0: 20 20 20 20 20 20 69 66 28 20 6e 41 72 67 3c 32        if( nArg<2
83d0: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20   ){.        int 
83e0: 76 61 6c 20 3d 20 28 70 46 75 6e 63 2d 3e 78 53  val = (pFunc->xS
83f0: 46 75 6e 63 3d 3d 6c 65 61 64 53 74 65 70 46 75  Func==leadStepFu
8400: 6e 63 20 3f 20 31 20 3a 20 2d 31 29 3b 0a 20 20  nc ? 1 : -1);.  
8410: 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62        sqlite3Vdb
8420: 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 41 64  eAddOp2(v, OP_Ad
8430: 64 49 6d 6d 2c 20 74 6d 70 52 65 67 2c 20 76 61  dImm, tmpReg, va
8440: 6c 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b  l);.      }else{
8450: 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6f 70 20  .        int op 
8460: 3d 20 28 70 46 75 6e 63 2d 3e 78 53 46 75 6e 63  = (pFunc->xSFunc
8470: 3d 3d 6c 65 61 64 53 74 65 70 46 75 6e 63 20 3f  ==leadStepFunc ?
8480: 20 4f 50 5f 41 64 64 20 3a 20 4f 50 5f 53 75 62   OP_Add : OP_Sub
8490: 74 72 61 63 74 29 3b 0a 20 20 20 20 20 20 20 20  tract);.        
84a0: 69 6e 74 20 74 6d 70 52 65 67 32 20 3d 20 73 71  int tmpReg2 = sq
84b0: 6c 69 74 65 33 47 65 74 54 65 6d 70 52 65 67 28  lite3GetTempReg(
84c0: 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20 20  pParse);.       
84d0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
84e0: 70 33 28 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e 2c  p3(v, OP_Column,
84f0: 20 69 45 70 68 2c 20 70 57 69 6e 2d 3e 69 41 72   iEph, pWin->iAr
8500: 67 43 6f 6c 2b 31 2c 20 74 6d 70 52 65 67 32 29  gCol+1, tmpReg2)
8510: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
8520: 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 6f  3VdbeAddOp3(v, o
8530: 70 2c 20 74 6d 70 52 65 67 32 2c 20 74 6d 70 52  p, tmpReg2, tmpR
8540: 65 67 2c 20 74 6d 70 52 65 67 29 3b 0a 20 20 20  eg, tmpReg);.   
8550: 20 20 20 20 20 73 71 6c 69 74 65 33 52 65 6c 65       sqlite3Rele
8560: 61 73 65 54 65 6d 70 52 65 67 28 70 50 61 72 73  aseTempReg(pPars
8570: 65 2c 20 74 6d 70 52 65 67 32 29 3b 0a 20 20 20  e, tmpReg2);.   
8580: 20 20 20 7d 0a 0a 20 20 20 20 20 20 73 71 6c 69     }..      sqli
8590: 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c  te3VdbeAddOp3(v,
85a0: 20 4f 50 5f 53 65 65 6b 52 6f 77 69 64 2c 20 63   OP_SeekRowid, c
85b0: 73 72 2c 20 6c 62 6c 2c 20 74 6d 70 52 65 67 29  sr, lbl, tmpReg)
85c0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56  ;.      sqlite3V
85d0: 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f  dbeAddOp3(v, OP_
85e0: 43 6f 6c 75 6d 6e 2c 20 63 73 72 2c 20 70 57 69  Column, csr, pWi
85f0: 6e 2d 3e 69 41 72 67 43 6f 6c 2c 20 70 57 69 6e  n->iArgCol, pWin
8600: 2d 3e 72 65 67 52 65 73 75 6c 74 29 3b 0a 20 20  ->regResult);.  
8610: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 52      sqlite3VdbeR
8620: 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76 2c 20 6c  esolveLabel(v, l
8630: 62 6c 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  bl);.      sqlit
8640: 65 33 52 65 6c 65 61 73 65 54 65 6d 70 52 65 67  e3ReleaseTempReg
8650: 28 70 50 61 72 73 65 2c 20 74 6d 70 52 65 67 29  (pParse, tmpReg)
8660: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 73 71  ;.    }.  }.  sq
8670: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
8680: 76 2c 20 4f 50 5f 47 6f 73 75 62 2c 20 72 65 67  v, OP_Gosub, reg
8690: 47 6f 73 75 62 2c 20 61 64 64 72 47 6f 73 75 62  Gosub, addrGosub
86a0: 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 76 6f 69  );.}..static voi
86b0: 64 20 77 69 6e 64 6f 77 52 65 74 75 72 6e 52 6f  d windowReturnRo
86c0: 77 73 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61  ws(.  Parse *pPa
86d0: 72 73 65 2c 0a 20 20 57 69 6e 64 6f 77 20 2a 70  rse,.  Window *p
86e0: 4d 57 69 6e 2c 0a 20 20 69 6e 74 20 72 65 67 43  MWin,.  int regC
86f0: 74 72 2c 0a 20 20 69 6e 74 20 62 46 69 6e 61 6c  tr,.  int bFinal
8700: 2c 0a 20 20 69 6e 74 20 72 65 67 47 6f 73 75 62  ,.  int regGosub
8710: 2c 0a 20 20 69 6e 74 20 61 64 64 72 47 6f 73 75  ,.  int addrGosu
8720: 62 2c 0a 20 20 69 6e 74 20 72 65 67 49 6e 76 41  b,.  int regInvA
8730: 72 67 2c 0a 20 20 69 6e 74 20 72 65 67 49 6e 76  rg,.  int regInv
8740: 53 69 7a 65 0a 29 7b 0a 20 20 69 6e 74 20 61 64  Size.){.  int ad
8750: 64 72 3b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20  dr;.  Vdbe *v = 
8760: 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70  sqlite3GetVdbe(p
8770: 50 61 72 73 65 29 3b 0a 20 20 77 69 6e 64 6f 77  Parse);.  window
8780: 41 67 67 46 69 6e 61 6c 28 70 50 61 72 73 65 2c  AggFinal(pParse,
8790: 20 70 4d 57 69 6e 2c 20 30 29 3b 0a 20 20 61 64   pMWin, 0);.  ad
87a0: 64 72 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65  dr = sqlite3Vdbe
87b0: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 49 66 50  AddOp3(v, OP_IfP
87c0: 6f 73 2c 20 72 65 67 43 74 72 2c 20 73 71 6c 69  os, regCtr, sqli
87d0: 74 65 33 56 64 62 65 43 75 72 72 65 6e 74 41 64  te3VdbeCurrentAd
87e0: 64 72 28 76 29 2b 32 20 2c 31 29 3b 0a 20 20 73  dr(v)+2 ,1);.  s
87f0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
8800: 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20  (v, OP_Goto, 0, 
8810: 30 29 3b 0a 20 20 77 69 6e 64 6f 77 52 65 74 75  0);.  windowRetu
8820: 72 6e 4f 6e 65 52 6f 77 28 70 50 61 72 73 65 2c  rnOneRow(pParse,
8830: 20 70 4d 57 69 6e 2c 20 72 65 67 47 6f 73 75 62   pMWin, regGosub
8840: 2c 20 61 64 64 72 47 6f 73 75 62 29 3b 0a 20 20  , addrGosub);.  
8850: 69 66 28 20 72 65 67 49 6e 76 41 72 67 20 29 7b  if( regInvArg ){
8860: 0a 20 20 20 20 77 69 6e 64 6f 77 41 67 67 53 74  .    windowAggSt
8870: 65 70 28 70 50 61 72 73 65 2c 20 70 4d 57 69 6e  ep(pParse, pMWin
8880: 2c 20 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72  , pMWin->iEphCsr
8890: 2c 20 31 2c 20 72 65 67 49 6e 76 41 72 67 2c 20  , 1, regInvArg, 
88a0: 72 65 67 49 6e 76 53 69 7a 65 29 3b 0a 20 20 7d  regInvSize);.  }
88b0: 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64  .  sqlite3VdbeAd
88c0: 64 4f 70 32 28 76 2c 20 4f 50 5f 4e 65 78 74 2c  dOp2(v, OP_Next,
88d0: 20 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c   pMWin->iEphCsr,
88e0: 20 61 64 64 72 29 3b 0a 20 20 73 71 6c 69 74 65   addr);.  sqlite
88f0: 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28 76 2c  3VdbeJumpHere(v,
8900: 20 61 64 64 72 2b 31 29 3b 20 20 20 2f 2a 20 54   addr+1);   /* T
8910: 68 65 20 4f 50 5f 47 6f 74 6f 20 2a 2f 0a 7d 0a  he OP_Goto */.}.
8920: 0a 73 74 61 74 69 63 20 69 6e 74 20 77 69 6e 64  .static int wind
8930: 6f 77 49 6e 69 74 41 63 63 75 6d 28 50 61 72 73  owInitAccum(Pars
8940: 65 20 2a 70 50 61 72 73 65 2c 20 57 69 6e 64 6f  e *pParse, Windo
8950: 77 20 2a 70 4d 57 69 6e 29 7b 0a 20 20 56 64 62  w *pMWin){.  Vdb
8960: 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 33 47 65  e *v = sqlite3Ge
8970: 74 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a 20  tVdbe(pParse);. 
8980: 20 69 6e 74 20 72 65 67 41 72 67 3b 0a 20 20 69   int regArg;.  i
8990: 6e 74 20 6e 41 72 67 20 3d 20 30 3b 0a 20 20 57  nt nArg = 0;.  W
89a0: 69 6e 64 6f 77 20 2a 70 57 69 6e 3b 0a 20 20 66  indow *pWin;.  f
89b0: 6f 72 28 70 57 69 6e 3d 70 4d 57 69 6e 3b 20 70  or(pWin=pMWin; p
89c0: 57 69 6e 3b 20 70 57 69 6e 3d 70 57 69 6e 2d 3e  Win; pWin=pWin->
89d0: 70 4e 65 78 74 57 69 6e 29 7b 0a 20 20 20 20 73  pNextWin){.    s
89e0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
89f0: 28 76 2c 20 4f 50 5f 4e 75 6c 6c 2c 20 30 2c 20  (v, OP_Null, 0, 
8a00: 70 57 69 6e 2d 3e 72 65 67 41 63 63 75 6d 29 3b  pWin->regAccum);
8a10: 0a 20 20 20 20 6e 41 72 67 20 3d 20 4d 41 58 28  .    nArg = MAX(
8a20: 6e 41 72 67 2c 20 77 69 6e 64 6f 77 41 72 67 43  nArg, windowArgC
8a30: 6f 75 6e 74 28 70 57 69 6e 29 29 3b 0a 20 20 20  ount(pWin));.   
8a40: 20 69 66 28 20 70 57 69 6e 2d 3e 70 46 75 6e 63   if( pWin->pFunc
8a50: 2d 3e 78 53 46 75 6e 63 3d 3d 6e 74 68 5f 76 61  ->xSFunc==nth_va
8a60: 6c 75 65 53 74 65 70 46 75 6e 63 0a 20 20 20 20  lueStepFunc.    
8a70: 20 7c 7c 20 70 57 69 6e 2d 3e 70 46 75 6e 63 2d   || pWin->pFunc-
8a80: 3e 78 53 46 75 6e 63 3d 3d 66 69 72 73 74 5f 76  >xSFunc==first_v
8a90: 61 6c 75 65 53 74 65 70 46 75 6e 63 20 0a 20 20  alueStepFunc .  
8aa0: 20 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74    ){.      sqlit
8ab0: 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20  e3VdbeAddOp2(v, 
8ac0: 4f 50 5f 49 6e 74 65 67 65 72 2c 20 30 2c 20 70  OP_Integer, 0, p
8ad0: 57 69 6e 2d 3e 72 65 67 41 70 70 29 3b 0a 20 20  Win->regApp);.  
8ae0: 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41      sqlite3VdbeA
8af0: 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49 6e 74 65  ddOp2(v, OP_Inte
8b00: 67 65 72 2c 20 30 2c 20 70 57 69 6e 2d 3e 72 65  ger, 0, pWin->re
8b10: 67 41 70 70 2b 31 29 3b 0a 20 20 20 20 7d 0a 20  gApp+1);.    }. 
8b20: 20 7d 0a 20 20 72 65 67 41 72 67 20 3d 20 70 50   }.  regArg = pP
8b30: 61 72 73 65 2d 3e 6e 4d 65 6d 2b 31 3b 0a 20 20  arse->nMem+1;.  
8b40: 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20 2b 3d 20  pParse->nMem += 
8b50: 6e 41 72 67 3b 0a 20 20 72 65 74 75 72 6e 20 72  nArg;.  return r
8b60: 65 67 41 72 67 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a  egArg;.}.../*.**
8b70: 20 52 4f 57 53 20 42 45 54 57 45 45 4e 20 3c 65   ROWS BETWEEN <e
8b80: 78 70 72 31 3e 20 50 52 45 43 45 44 49 4e 47 20  xpr1> PRECEDING 
8b90: 41 4e 44 20 3c 65 78 70 72 32 3e 20 46 4f 4c 4c  AND <expr2> FOLL
8ba0: 4f 57 49 4e 47 0a 2a 2a 20 2d 2d 2d 2d 2d 2d 2d  OWING.** -------
8bb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
8bc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
8bd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 2a 2a  -------------.**
8be0: 0a 2a 2a 20 50 73 65 75 64 6f 2d 63 6f 64 65 20  .** Pseudo-code 
8bf0: 66 6f 72 20 74 68 65 20 69 6d 70 6c 65 6d 65 6e  for the implemen
8c00: 74 61 74 69 6f 6e 20 6f 66 20 74 68 69 73 20 77  tation of this w
8c10: 69 6e 64 6f 77 20 66 72 61 6d 65 20 74 79 70 65  indow frame type
8c20: 20 69 73 20 61 73 0a 2a 2a 20 66 6f 6c 6c 6f 77   is as.** follow
8c30: 73 2e 20 73 71 6c 69 74 65 33 57 68 65 72 65 42  s. sqlite3WhereB
8c40: 65 67 69 6e 28 29 20 68 61 73 20 61 6c 72 65 61  egin() has alrea
8c50: 64 79 20 62 65 65 6e 20 63 61 6c 6c 65 64 20 74  dy been called t
8c60: 6f 20 67 65 6e 65 72 61 74 65 20 74 68 65 0a 2a  o generate the.*
8c70: 2a 20 74 6f 70 20 6f 66 20 74 68 65 20 6d 61 69  * top of the mai
8c80: 6e 20 6c 6f 6f 70 20 77 68 65 6e 20 74 68 69 73  n loop when this
8c90: 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61 6c   function is cal
8ca0: 6c 65 64 2e 0a 2a 2a 0a 2a 2a 20 45 61 63 68 20  led..**.** Each 
8cb0: 74 69 6d 65 20 74 68 65 20 73 75 62 2d 72 6f 75  time the sub-rou
8cc0: 74 69 6e 65 20 61 74 20 61 64 64 72 47 6f 73 75  tine at addrGosu
8cd0: 62 20 69 73 20 69 6e 76 6f 6b 65 64 2c 20 61 20  b is invoked, a 
8ce0: 73 69 6e 67 6c 65 20 6f 75 74 70 75 74 0a 2a 2a  single output.**
8cf0: 20 72 6f 77 20 69 73 20 67 65 6e 65 72 61 74 65   row is generate
8d00: 64 20 62 61 73 65 64 20 6f 6e 20 74 68 65 20 63  d based on the c
8d10: 75 72 72 65 6e 74 20 72 6f 77 20 69 6e 64 69 63  urrent row indic
8d20: 61 74 65 64 20 62 79 20 57 69 6e 64 6f 77 2e 69  ated by Window.i
8d30: 45 70 68 43 73 72 2e 0a 2a 2a 0a 2a 2a 20 20 20  EphCsr..**.**   
8d40: 20 20 2e 2e 2e 0a 2a 2a 20 20 20 20 20 20 20 69    ....**       i
8d50: 66 28 20 6e 65 77 20 70 61 72 74 69 74 69 6f 6e  f( new partition
8d60: 20 29 7b 0a 2a 2a 20 20 20 20 20 20 20 20 20 47   ){.**         G
8d70: 6f 73 75 62 20 66 6c 75 73 68 5f 70 61 72 74 69  osub flush_parti
8d80: 74 69 6f 6e 0a 2a 2a 20 20 20 20 20 20 20 7d 0a  tion.**       }.
8d90: 2a 2a 20 20 20 20 20 20 20 49 6e 73 65 72 74 20  **       Insert 
8da0: 28 72 65 63 6f 72 64 20 69 6e 20 65 70 68 2d 74  (record in eph-t
8db0: 61 62 6c 65 29 0a 2a 2a 20 20 20 20 20 73 71 6c  able).**     sql
8dc0: 69 74 65 33 57 68 65 72 65 45 6e 64 28 29 0a 2a  ite3WhereEnd().*
8dd0: 2a 20 20 20 20 20 47 6f 73 75 62 20 66 6c 75 73  *     Gosub flus
8de0: 68 5f 70 61 72 74 69 74 69 6f 6e 0a 2a 2a 20 20  h_partition.**  
8df0: 0a 2a 2a 20 20 20 66 6c 75 73 68 5f 70 61 72 74  .**   flush_part
8e00: 69 74 69 6f 6e 3a 0a 2a 2a 20 20 20 20 20 4f 6e  ition:.**     On
8e10: 63 65 20 7b 0a 2a 2a 20 20 20 20 20 20 20 4f 70  ce {.**       Op
8e20: 65 6e 44 75 70 20 28 69 45 70 68 43 73 72 20 2d  enDup (iEphCsr -
8e30: 3e 20 63 73 72 53 74 61 72 74 29 0a 2a 2a 20 20  > csrStart).**  
8e40: 20 20 20 20 20 4f 70 65 6e 44 75 70 20 28 69 45       OpenDup (iE
8e50: 70 68 43 73 72 20 2d 3e 20 63 73 72 45 6e 64 29  phCsr -> csrEnd)
8e60: 0a 2a 2a 20 20 20 20 20 7d 0a 2a 2a 20 20 20 20  .**     }.**    
8e70: 20 72 65 67 53 74 61 72 74 20 3d 20 3c 65 78 70   regStart = <exp
8e80: 72 31 3e 20 20 20 20 20 20 20 20 20 20 20 20 20  r1>             
8e90: 20 20 20 2f 2f 20 50 52 45 43 45 44 49 4e 47 20     // PRECEDING 
8ea0: 65 78 70 72 65 73 73 69 6f 6e 0a 2a 2a 20 20 20  expression.**   
8eb0: 20 20 72 65 67 45 6e 64 20 3d 20 3c 65 78 70 72    regEnd = <expr
8ec0: 32 3e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  2>              
8ed0: 20 20 20 20 2f 2f 20 46 4f 4c 4c 4f 57 49 4e 47      // FOLLOWING
8ee0: 20 65 78 70 72 65 73 73 69 6f 6e 0a 2a 2a 20 20   expression.**  
8ef0: 20 20 20 69 66 28 20 72 65 67 53 74 61 72 74 3c     if( regStart<
8f00: 30 20 7c 7c 20 72 65 67 45 6e 64 3c 30 20 29 7b  0 || regEnd<0 ){
8f10: 20 65 72 72 6f 72 21 20 7d 0a 2a 2a 20 20 20 20   error! }.**    
8f20: 20 52 65 77 69 6e 64 20 28 63 73 72 2c 63 73 72   Rewind (csr,csr
8f30: 53 74 61 72 74 2c 63 73 72 45 6e 64 29 20 20 20  Start,csrEnd)   
8f40: 20 20 20 2f 2f 20 69 66 20 45 4f 46 20 67 6f 74     // if EOF got
8f50: 6f 20 66 6c 75 73 68 5f 70 61 72 74 69 74 69 6f  o flush_partitio
8f60: 6e 5f 64 6f 6e 65 0a 2a 2a 20 20 20 20 20 20 20  n_done.**       
8f70: 4e 65 78 74 28 63 73 72 45 6e 64 29 20 20 20 20  Next(csrEnd)    
8f80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8f90: 2f 2f 20 69 66 20 45 4f 46 20 73 6b 69 70 20 41  // if EOF skip A
8fa0: 67 67 73 74 65 70 0a 2a 2a 20 20 20 20 20 20 20  ggstep.**       
8fb0: 41 67 67 73 74 65 70 20 28 63 73 72 45 6e 64 29  Aggstep (csrEnd)
8fc0: 0a 2a 2a 20 20 20 20 20 20 20 69 66 28 20 28 72  .**       if( (r
8fd0: 65 67 45 6e 64 2d 2d 29 3c 3d 30 20 29 7b 0a 2a  egEnd--)<=0 ){.*
8fe0: 2a 20 20 20 20 20 20 20 20 20 41 67 67 46 69 6e  *         AggFin
8ff0: 61 6c 20 28 78 56 61 6c 75 65 29 0a 2a 2a 20 20  al (xValue).**  
9000: 20 20 20 20 20 20 20 47 6f 73 75 62 20 61 64 64         Gosub add
9010: 72 47 6f 73 75 62 0a 2a 2a 20 20 20 20 20 20 20  rGosub.**       
9020: 20 20 4e 65 78 74 28 63 73 72 29 20 20 20 20 20    Next(csr)     
9030: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 69 66             // if
9040: 20 45 4f 46 20 67 6f 74 6f 20 66 6c 75 73 68 5f   EOF goto flush_
9050: 70 61 72 74 69 74 69 6f 6e 5f 64 6f 6e 65 0a 2a  partition_done.*
9060: 2a 20 20 20 20 20 20 20 20 20 69 66 28 20 28 72  *         if( (r
9070: 65 67 53 74 61 72 74 2d 2d 29 3c 3d 30 20 29 7b  egStart--)<=0 ){
9080: 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20 41 67  .**           Ag
9090: 67 53 74 65 70 20 28 63 73 72 53 74 61 72 74 2c  gStep (csrStart,
90a0: 20 78 49 6e 76 65 72 73 65 29 0a 2a 2a 20 20 20   xInverse).**   
90b0: 20 20 20 20 20 20 20 20 4e 65 78 74 28 63 73 72          Next(csr
90c0: 53 74 61 72 74 29 0a 2a 2a 20 20 20 20 20 20 20  Start).**       
90d0: 20 20 7d 0a 2a 2a 20 20 20 20 20 20 20 7d 0a 2a    }.**       }.*
90e0: 2a 20 20 20 66 6c 75 73 68 5f 70 61 72 74 69 74  *   flush_partit
90f0: 69 6f 6e 5f 64 6f 6e 65 3a 0a 2a 2a 20 20 20 20  ion_done:.**    
9100: 20 52 65 73 65 74 53 6f 72 74 65 72 20 28 63 73   ResetSorter (cs
9110: 72 29 0a 2a 2a 20 20 20 20 20 52 65 74 75 72 6e  r).**     Return
9120: 0a 2a 2a 0a 2a 2a 20 52 4f 57 53 20 42 45 54 57  .**.** ROWS BETW
9130: 45 45 4e 20 3c 65 78 70 72 3e 20 50 52 45 43 45  EEN <expr> PRECE
9140: 44 49 4e 47 20 20 20 20 41 4e 44 20 43 55 52 52  DING    AND CURR
9150: 45 4e 54 20 52 4f 57 0a 2a 2a 20 52 4f 57 53 20  ENT ROW.** ROWS 
9160: 42 45 54 57 45 45 4e 20 43 55 52 52 45 4e 54 20  BETWEEN CURRENT 
9170: 52 4f 57 20 20 20 20 20 20 20 20 20 41 4e 44 20  ROW         AND 
9180: 3c 65 78 70 72 3e 20 46 4f 4c 4c 4f 57 49 4e 47  <expr> FOLLOWING
9190: 0a 2a 2a 20 52 4f 57 53 20 42 45 54 57 45 45 4e  .** ROWS BETWEEN
91a0: 20 55 4e 42 4f 55 4e 44 45 44 20 50 52 45 43 45   UNBOUNDED PRECE
91b0: 44 49 4e 47 20 41 4e 44 20 3c 65 78 70 72 3e 20  DING AND <expr> 
91c0: 46 4f 4c 4c 4f 57 49 4e 47 0a 2a 2a 0a 2a 2a 20  FOLLOWING.**.** 
91d0: 20 20 54 68 65 73 65 20 61 72 65 20 73 69 6d 69    These are simi
91e0: 6c 61 72 20 74 6f 20 74 68 65 20 61 62 6f 76 65  lar to the above
91f0: 2e 20 46 6f 72 20 22 43 55 52 52 45 4e 54 20 52  . For "CURRENT R
9200: 4f 57 22 2c 20 69 6e 74 69 61 6c 69 7a 65 20 74  OW", intialize t
9210: 68 65 0a 2a 2a 20 20 20 72 65 67 69 73 74 65 72  he.**   register
9220: 20 74 6f 20 30 2e 20 46 6f 72 20 22 55 4e 42 4f   to 0. For "UNBO
9230: 55 4e 44 45 44 20 50 52 45 43 45 44 49 4e 47 22  UNDED PRECEDING"
9240: 20 74 6f 20 69 6e 66 69 6e 69 74 79 2e 0a 2a 2a   to infinity..**
9250: 0a 2a 2a 20 52 4f 57 53 20 42 45 54 57 45 45 4e  .** ROWS BETWEEN
9260: 20 3c 65 78 70 72 3e 20 50 52 45 43 45 44 49 4e   <expr> PRECEDIN
9270: 47 20 20 20 20 41 4e 44 20 55 4e 42 4f 55 4e 44  G    AND UNBOUND
9280: 45 44 20 46 4f 4c 4c 4f 57 49 4e 47 0a 2a 2a 20  ED FOLLOWING.** 
9290: 52 4f 57 53 20 42 45 54 57 45 45 4e 20 43 55 52  ROWS BETWEEN CUR
92a0: 52 45 4e 54 20 52 4f 57 20 20 20 20 20 20 20 20  RENT ROW        
92b0: 20 41 4e 44 20 55 4e 42 4f 55 4e 44 45 44 20 46   AND UNBOUNDED F
92c0: 4f 4c 4c 4f 57 49 4e 47 0a 2a 2a 0a 2a 2a 20 20  OLLOWING.**.**  
92d0: 20 20 20 52 65 77 69 6e 64 20 28 63 73 72 2c 63     Rewind (csr,c
92e0: 73 72 53 74 61 72 74 2c 63 73 72 45 6e 64 29 20  srStart,csrEnd) 
92f0: 20 20 20 2f 2f 20 69 66 20 45 4f 46 20 67 6f 74     // if EOF got
9300: 6f 20 66 6c 75 73 68 5f 70 61 72 74 69 74 69 6f  o flush_partitio
9310: 6e 5f 64 6f 6e 65 0a 2a 2a 20 20 20 20 20 77 68  n_done.**     wh
9320: 69 6c 65 28 20 31 20 29 7b 0a 2a 2a 20 20 20 20  ile( 1 ){.**    
9330: 20 20 20 4e 65 78 74 28 63 73 72 45 6e 64 29 20     Next(csrEnd) 
9340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9350: 20 2f 2f 20 45 78 69 74 20 77 68 69 6c 65 28 31   // Exit while(1
9360: 29 20 61 74 20 45 4f 46 0a 2a 2a 20 20 20 20 20  ) at EOF.**     
9370: 20 20 41 67 67 73 74 65 70 20 28 63 73 72 45 6e    Aggstep (csrEn
9380: 64 29 0a 2a 2a 20 20 20 20 20 7d 0a 2a 2a 20 20  d).**     }.**  
9390: 20 20 20 77 68 69 6c 65 28 20 31 20 29 7b 0a 2a     while( 1 ){.*
93a0: 2a 20 20 20 20 20 20 20 41 67 67 46 69 6e 61 6c  *       AggFinal
93b0: 20 28 78 56 61 6c 75 65 29 0a 2a 2a 20 20 20 20   (xValue).**    
93c0: 20 20 20 47 6f 73 75 62 20 61 64 64 72 47 6f 73     Gosub addrGos
93d0: 75 62 0a 2a 2a 20 20 20 20 20 20 20 4e 65 78 74  ub.**       Next
93e0: 28 63 73 72 29 20 20 20 20 20 20 20 20 20 20 20  (csr)           
93f0: 20 20 20 20 20 20 20 20 20 20 2f 2f 20 69 66 20            // if 
9400: 45 4f 46 20 67 6f 74 6f 20 66 6c 75 73 68 5f 70  EOF goto flush_p
9410: 61 72 74 69 74 69 6f 6e 5f 64 6f 6e 65 0a 2a 2a  artition_done.**
9420: 20 20 20 20 20 20 20 69 66 28 20 28 72 65 67 53         if( (regS
9430: 74 61 72 74 2d 2d 29 3c 3d 30 20 29 7b 0a 2a 2a  tart--)<=0 ){.**
9440: 20 20 20 20 20 20 20 20 20 41 67 67 53 74 65 70           AggStep
9450: 20 28 63 73 72 53 74 61 72 74 2c 20 78 49 6e 76   (csrStart, xInv
9460: 65 72 73 65 29 0a 2a 2a 20 20 20 20 20 20 20 20  erse).**        
9470: 20 4e 65 78 74 28 63 73 72 53 74 61 72 74 29 0a   Next(csrStart).
9480: 2a 2a 20 20 20 20 20 20 20 7d 0a 2a 2a 20 20 20  **       }.**   
9490: 20 20 7d 0a 2a 2a 0a 2a 2a 20 20 20 46 6f 72 20    }.**.**   For 
94a0: 74 68 65 20 22 43 55 52 52 45 4e 54 20 52 4f 57  the "CURRENT ROW
94b0: 20 41 4e 44 20 55 4e 42 4f 55 4e 44 45 44 20 46   AND UNBOUNDED F
94c0: 4f 4c 4c 4f 57 49 4e 47 22 20 63 61 73 65 2c 20  OLLOWING" case, 
94d0: 74 68 65 20 66 69 6e 61 6c 20 69 66 28 29 20 0a  the final if() .
94e0: 2a 2a 20 20 20 63 6f 6e 64 69 74 69 6f 6e 20 69  **   condition i
94f0: 73 20 61 6c 77 61 79 73 20 74 72 75 65 20 28 61  s always true (a
9500: 73 20 69 66 20 72 65 67 53 74 61 72 74 20 77 65  s if regStart we
9510: 72 65 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 74  re initialized t
9520: 6f 20 30 29 2e 0a 2a 2a 0a 2a 2a 20 52 41 4e 47  o 0)..**.** RANG
9530: 45 20 42 45 54 57 45 45 4e 20 43 55 52 52 45 4e  E BETWEEN CURREN
9540: 54 20 52 4f 57 20 41 4e 44 20 55 4e 42 4f 55 4e  T ROW AND UNBOUN
9550: 44 45 44 20 46 4f 4c 4c 4f 57 49 4e 47 0a 2a 2a  DED FOLLOWING.**
9560: 20 0a 2a 2a 20 20 20 54 68 69 73 20 69 73 20 74   .**   This is t
9570: 68 65 20 6f 6e 6c 79 20 52 41 4e 47 45 20 63 61  he only RANGE ca
9580: 73 65 20 68 61 6e 64 6c 65 64 20 62 79 20 74 68  se handled by th
9590: 69 73 20 72 6f 75 74 69 6e 65 2e 20 49 74 20 6d  is routine. It m
95a0: 6f 64 69 66 69 65 73 20 74 68 65 0a 2a 2a 20 20  odifies the.**  
95b0: 20 73 65 63 6f 6e 64 20 77 68 69 6c 65 28 20 31   second while( 1
95c0: 20 29 20 6c 6f 6f 70 20 69 6e 20 22 52 4f 57 53   ) loop in "ROWS
95d0: 20 42 45 54 57 45 45 4e 20 43 55 52 52 45 4e 54   BETWEEN CURRENT
95e0: 20 2e 2e 2e 20 55 4e 42 4f 55 4e 44 45 44 2e 2e   ... UNBOUNDED..
95f0: 2e 22 20 74 6f 0a 2a 2a 20 20 20 62 65 3a 0a 2a  ." to.**   be:.*
9600: 2a 0a 2a 2a 20 20 20 20 20 77 68 69 6c 65 28 20  *.**     while( 
9610: 31 20 29 7b 0a 2a 2a 20 20 20 20 20 20 20 41 67  1 ){.**       Ag
9620: 67 46 69 6e 61 6c 20 28 78 56 61 6c 75 65 29 0a  gFinal (xValue).
9630: 2a 2a 20 20 20 20 20 20 20 77 68 69 6c 65 28 20  **       while( 
9640: 31 20 29 7b 0a 2a 2a 20 20 20 20 20 20 20 20 20  1 ){.**         
9650: 72 65 67 50 65 65 72 2b 2b 0a 2a 2a 20 20 20 20  regPeer++.**    
9660: 20 20 20 20 20 47 6f 73 75 62 20 61 64 64 72 47       Gosub addrG
9670: 6f 73 75 62 0a 2a 2a 20 20 20 20 20 20 20 20 20  osub.**         
9680: 4e 65 78 74 28 63 73 72 29 20 20 20 20 20 20 20  Next(csr)       
9690: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f                //
96a0: 20 69 66 20 45 4f 46 20 67 6f 74 6f 20 66 6c 75   if EOF goto flu
96b0: 73 68 5f 70 61 72 74 69 74 69 6f 6e 5f 64 6f 6e  sh_partition_don
96c0: 65 0a 2a 2a 20 20 20 20 20 20 20 20 20 69 66 28  e.**         if(
96d0: 20 6e 65 77 20 70 65 65 72 20 29 20 62 72 65 61   new peer ) brea
96e0: 6b 3b 0a 2a 2a 20 20 20 20 20 20 20 7d 0a 2a 2a  k;.**       }.**
96f0: 20 20 20 20 20 20 20 77 68 69 6c 65 28 20 28 72         while( (r
9700: 65 67 50 65 65 72 2d 2d 29 3e 30 20 29 7b 0a 2a  egPeer--)>0 ){.*
9710: 2a 20 20 20 20 20 20 20 20 20 41 67 67 53 74 65  *         AggSte
9720: 70 20 28 63 73 72 53 74 61 72 74 2c 20 78 49 6e  p (csrStart, xIn
9730: 76 65 72 73 65 29 0a 2a 2a 20 20 20 20 20 20 20  verse).**       
9740: 20 20 4e 65 78 74 28 63 73 72 53 74 61 72 74 29    Next(csrStart)
9750: 0a 2a 2a 20 20 20 20 20 20 20 7d 0a 2a 2a 20 20  .**       }.**  
9760: 20 20 20 7d 0a 2a 2a 0a 2a 2a 20 52 4f 57 53 20     }.**.** ROWS 
9770: 42 45 54 57 45 45 4e 20 3c 65 78 70 72 3e 20 46  BETWEEN <expr> F
9780: 4f 4c 4c 4f 57 49 4e 47 20 20 20 20 41 4e 44 20  OLLOWING    AND 
9790: 3c 65 78 70 72 3e 20 46 4f 4c 4c 4f 57 49 4e 47  <expr> FOLLOWING
97a0: 0a 2a 2a 0a 2a 2a 20 20 20 72 65 67 45 6e 64 20  .**.**   regEnd 
97b0: 3d 20 72 65 67 45 6e 64 20 2d 20 72 65 67 53 74  = regEnd - regSt
97c0: 61 72 74 0a 2a 2a 20 20 20 52 65 77 69 6e 64 20  art.**   Rewind 
97d0: 28 63 73 72 2c 63 73 72 53 74 61 72 74 2c 63 73  (csr,csrStart,cs
97e0: 72 45 6e 64 29 20 20 20 2f 2f 20 69 66 20 45 4f  rEnd)   // if EO
97f0: 46 20 67 6f 74 6f 20 66 6c 75 73 68 5f 70 61 72  F goto flush_par
9800: 74 69 74 69 6f 6e 5f 64 6f 6e 65 0a 2a 2a 20 20  tition_done.**  
9810: 20 20 20 41 67 67 73 74 65 70 20 28 63 73 72 45     Aggstep (csrE
9820: 6e 64 29 0a 2a 2a 20 20 20 20 20 4e 65 78 74 28  nd).**     Next(
9830: 63 73 72 45 6e 64 29 20 20 20 20 20 20 20 20 20  csrEnd)         
9840: 20 20 20 20 20 20 20 20 2f 2f 20 69 66 20 45 4f          // if EO
9850: 46 20 66 61 6c 6c 2d 74 68 72 6f 75 67 68 0a 2a  F fall-through.*
9860: 2a 20 20 20 20 20 69 66 28 20 28 72 65 67 45 6e  *     if( (regEn
9870: 64 2d 2d 29 3c 3d 30 20 29 7b 0a 2a 2a 20 20 20  d--)<=0 ){.**   
9880: 20 20 20 20 69 66 28 20 28 72 65 67 53 74 61 72      if( (regStar
9890: 74 2d 2d 29 3c 3d 30 20 29 7b 0a 2a 2a 20 20 20  t--)<=0 ){.**   
98a0: 20 20 20 20 20 20 41 67 67 46 69 6e 61 6c 20 28        AggFinal (
98b0: 78 56 61 6c 75 65 29 0a 2a 2a 20 20 20 20 20 20  xValue).**      
98c0: 20 20 20 47 6f 73 75 62 20 61 64 64 72 47 6f 73     Gosub addrGos
98d0: 75 62 0a 2a 2a 20 20 20 20 20 20 20 20 20 4e 65  ub.**         Ne
98e0: 78 74 28 63 73 72 29 20 20 20 20 20 20 20 20 20  xt(csr)         
98f0: 20 20 20 20 20 2f 2f 20 69 66 20 45 4f 46 20 67       // if EOF g
9900: 6f 74 6f 20 66 6c 75 73 68 5f 70 61 72 74 69 74  oto flush_partit
9910: 69 6f 6e 5f 64 6f 6e 65 0a 2a 2a 20 20 20 20 20  ion_done.**     
9920: 20 20 7d 0a 2a 2a 20 20 20 20 20 20 20 41 67 67    }.**       Agg
9930: 53 74 65 70 20 28 63 73 72 53 74 61 72 74 2c 20  Step (csrStart, 
9940: 78 49 6e 76 65 72 73 65 29 0a 2a 2a 20 20 20 20  xInverse).**    
9950: 20 20 20 4e 65 78 74 20 28 63 73 72 53 74 61 72     Next (csrStar
9960: 74 29 0a 2a 2a 20 20 20 20 20 7d 0a 2a 2a 0a 2a  t).**     }.**.*
9970: 2a 20 52 4f 57 53 20 42 45 54 57 45 45 4e 20 3c  * ROWS BETWEEN <
9980: 65 78 70 72 3e 20 50 52 45 43 45 44 49 4e 47 20  expr> PRECEDING 
9990: 20 20 20 41 4e 44 20 3c 65 78 70 72 3e 20 50 52     AND <expr> PR
99a0: 45 43 45 44 49 4e 47 0a 2a 2a 0a 2a 2a 20 20 20  ECEDING.**.**   
99b0: 52 65 70 6c 61 63 65 20 74 68 65 20 62 69 74 20  Replace the bit 
99c0: 61 66 74 65 72 20 22 52 65 77 69 6e 64 22 20 69  after "Rewind" i
99d0: 6e 20 74 68 65 20 61 62 6f 76 65 20 77 69 74 68  n the above with
99e0: 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 69 66 28 20  :.**.**     if( 
99f0: 28 72 65 67 45 6e 64 2d 2d 29 3c 3d 30 20 29 7b  (regEnd--)<=0 ){
9a00: 0a 2a 2a 20 20 20 20 20 20 20 41 67 67 53 74 65  .**       AggSte
9a10: 70 20 28 63 73 72 45 6e 64 29 0a 2a 2a 20 20 20  p (csrEnd).**   
9a20: 20 20 20 20 4e 65 78 74 20 28 63 73 72 45 6e 64      Next (csrEnd
9a30: 29 0a 2a 2a 20 20 20 20 20 7d 0a 2a 2a 20 20 20  ).**     }.**   
9a40: 20 20 41 67 67 46 69 6e 61 6c 20 28 78 56 61 6c    AggFinal (xVal
9a50: 75 65 29 0a 2a 2a 20 20 20 20 20 47 6f 73 75 62  ue).**     Gosub
9a60: 20 61 64 64 72 47 6f 73 75 62 0a 2a 2a 20 20 20   addrGosub.**   
9a70: 20 20 4e 65 78 74 28 63 73 72 29 20 20 20 20 20    Next(csr)     
9a80: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20               // 
9a90: 69 66 20 45 4f 46 20 67 6f 74 6f 20 66 6c 75 73  if EOF goto flus
9aa0: 68 5f 70 61 72 74 69 74 69 6f 6e 5f 64 6f 6e 65  h_partition_done
9ab0: 0a 2a 2a 20 20 20 20 20 69 66 28 20 28 72 65 67  .**     if( (reg
9ac0: 53 74 61 72 74 2d 2d 29 3c 3d 30 20 29 7b 0a 2a  Start--)<=0 ){.*
9ad0: 2a 20 20 20 20 20 20 20 41 67 67 53 74 65 70 20  *       AggStep 
9ae0: 28 63 73 72 32 2c 20 78 49 6e 76 65 72 73 65 29  (csr2, xInverse)
9af0: 0a 2a 2a 20 20 20 20 20 20 20 4e 65 78 74 20 28  .**       Next (
9b00: 63 73 72 32 29 0a 2a 2a 20 20 20 20 20 7d 0a 2a  csr2).**     }.*
9b10: 2a 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  *.*/.static void
9b20: 20 77 69 6e 64 6f 77 43 6f 64 65 52 6f 77 45 78   windowCodeRowEx
9b30: 70 72 53 74 65 70 28 0a 20 20 50 61 72 73 65 20  prStep(.  Parse 
9b40: 2a 70 50 61 72 73 65 2c 20 0a 20 20 53 65 6c 65  *pParse, .  Sele
9b50: 63 74 20 2a 70 2c 0a 20 20 57 68 65 72 65 49 6e  ct *p,.  WhereIn
9b60: 66 6f 20 2a 70 57 49 6e 66 6f 2c 0a 20 20 69 6e  fo *pWInfo,.  in
9b70: 74 20 72 65 67 47 6f 73 75 62 2c 20 0a 20 20 69  t regGosub, .  i
9b80: 6e 74 20 61 64 64 72 47 6f 73 75 62 0a 29 7b 0a  nt addrGosub.){.
9b90: 20 20 57 69 6e 64 6f 77 20 2a 70 4d 57 69 6e 20    Window *pMWin 
9ba0: 3d 20 70 2d 3e 70 57 69 6e 3b 0a 20 20 56 64 62  = p->pWin;.  Vdb
9bb0: 65 20 2a 76 20 3d 20 73 71 6c 69 74 65 33 47 65  e *v = sqlite3Ge
9bc0: 74 56 64 62 65 28 70 50 61 72 73 65 29 3b 0a 20  tVdbe(pParse);. 
9bd0: 20 57 69 6e 64 6f 77 20 2a 70 57 69 6e 3b 0a 20   Window *pWin;. 
9be0: 20 69 6e 74 20 6b 3b 0a 20 20 69 6e 74 20 6e 53   int k;.  int nS
9bf0: 75 62 20 3d 20 70 2d 3e 70 53 72 63 2d 3e 61 5b  ub = p->pSrc->a[
9c00: 30 5d 2e 70 54 61 62 2d 3e 6e 43 6f 6c 3b 0a 20  0].pTab->nCol;. 
9c10: 20 69 6e 74 20 72 65 67 46 6c 75 73 68 50 61 72   int regFlushPar
9c20: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t;              
9c30: 20 2f 2a 20 52 65 67 69 73 74 65 72 20 66 6f 72   /* Register for
9c40: 20 22 47 6f 73 75 62 20 66 6c 75 73 68 5f 70 61   "Gosub flush_pa
9c50: 72 74 69 74 69 6f 6e 22 20 2a 2f 0a 20 20 69 6e  rtition" */.  in
9c60: 74 20 6c 62 6c 46 6c 75 73 68 50 61 72 74 3b 20  t lblFlushPart; 
9c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
9c80: 20 4c 61 62 65 6c 20 66 6f 72 20 22 47 6f 73 75   Label for "Gosu
9c90: 62 20 66 6c 75 73 68 5f 70 61 72 74 69 74 69 6f  b flush_partitio
9ca0: 6e 22 20 2a 2f 0a 20 20 69 6e 74 20 6c 62 6c 46  n" */.  int lblF
9cb0: 6c 75 73 68 44 6f 6e 65 3b 20 20 20 20 20 20 20  lushDone;       
9cc0: 20 20 20 20 20 20 20 20 2f 2a 20 4c 61 62 65 6c          /* Label
9cd0: 20 66 6f 72 20 22 47 6f 73 75 62 20 66 6c 75 73   for "Gosub flus
9ce0: 68 5f 70 61 72 74 69 74 69 6f 6e 5f 64 6f 6e 65  h_partition_done
9cf0: 22 20 2a 2f 0a 0a 20 20 69 6e 74 20 72 65 67 41  " */..  int regA
9d00: 72 67 3b 0a 20 20 69 6e 74 20 6e 41 72 67 3b 0a  rg;.  int nArg;.
9d10: 20 20 69 6e 74 20 61 64 64 72 3b 0a 20 20 69 6e    int addr;.  in
9d20: 74 20 63 73 72 53 74 61 72 74 20 3d 20 70 50 61  t csrStart = pPa
9d30: 72 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20 20 69  rse->nTab++;.  i
9d40: 6e 74 20 63 73 72 45 6e 64 20 3d 20 70 50 61 72  nt csrEnd = pPar
9d50: 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20 20 69 6e  se->nTab++;.  in
9d60: 74 20 72 65 67 53 74 61 72 74 3b 20 20 20 20 20  t regStart;     
9d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
9d80: 2a 20 56 61 6c 75 65 20 6f 66 20 3c 65 78 70 72  * Value of <expr
9d90: 3e 20 50 52 45 43 45 44 49 4e 47 20 2a 2f 0a 20  > PRECEDING */. 
9da0: 20 69 6e 74 20 72 65 67 45 6e 64 3b 20 20 20 20   int regEnd;    
9db0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9dc0: 20 20 2f 2a 20 56 61 6c 75 65 20 6f 66 20 3c 65    /* Value of <e
9dd0: 78 70 72 3e 20 46 4f 4c 4c 4f 57 49 4e 47 20 2a  xpr> FOLLOWING *
9de0: 2f 0a 20 20 69 6e 74 20 61 64 64 72 4e 65 78 74  /.  int addrNext
9df0: 3b 0a 20 20 69 6e 74 20 61 64 64 72 47 6f 74 6f  ;.  int addrGoto
9e00: 3b 0a 20 20 69 6e 74 20 61 64 64 72 54 6f 70 3b  ;.  int addrTop;
9e10: 0a 20 20 69 6e 74 20 61 64 64 72 49 66 50 6f 73  .  int addrIfPos
9e20: 31 3b 0a 20 20 69 6e 74 20 61 64 64 72 49 66 50  1;.  int addrIfP
9e30: 6f 73 32 3b 0a 0a 20 20 69 6e 74 20 72 65 67 50  os2;..  int regP
9e40: 65 65 72 20 3d 20 30 3b 20 20 20 20 20 20 20 20  eer = 0;        
9e50: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62           /* Numb
9e60: 65 72 20 6f 66 20 70 65 65 72 73 20 69 6e 20 63  er of peers in c
9e70: 75 72 72 65 6e 74 20 67 72 6f 75 70 20 2a 2f 0a  urrent group */.
9e80: 20 20 69 6e 74 20 72 65 67 50 65 65 72 56 61 6c    int regPeerVal
9e90: 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20 20   = 0;           
9ea0: 20 20 20 2f 2a 20 41 72 72 61 79 20 6f 66 20 76     /* Array of v
9eb0: 61 6c 75 65 73 20 69 64 65 6e 74 69 66 79 69 6e  alues identifyin
9ec0: 67 20 70 65 65 72 20 67 72 6f 75 70 20 2a 2f 0a  g peer group */.
9ed0: 20 20 69 6e 74 20 69 50 65 65 72 20 3d 20 30 3b    int iPeer = 0;
9ee0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9ef0: 20 20 20 2f 2a 20 43 6f 6c 75 6d 6e 20 6f 66 66     /* Column off
9f00: 73 65 74 20 69 6e 20 65 70 68 2d 74 61 62 6c 65  set in eph-table
9f10: 20 6f 66 20 70 65 65 72 20 76 61 6c 73 20 2a 2f   of peer vals */
9f20: 0a 20 20 69 6e 74 20 6e 50 65 65 72 56 61 6c 3b  .  int nPeerVal;
9f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
9f40: 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66      /* Number of
9f50: 20 70 65 65 72 20 76 61 6c 75 65 73 20 2a 2f 0a   peer values */.
9f60: 20 20 69 6e 74 20 62 52 61 6e 67 65 20 3d 20 30    int bRange = 0
9f70: 3b 0a 20 20 69 6e 74 20 72 65 67 53 69 7a 65 20  ;.  int regSize 
9f80: 3d 20 30 3b 0a 0a 20 20 61 73 73 65 72 74 28 20  = 0;..  assert( 
9f90: 70 4d 57 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54  pMWin->eStart==T
9fa0: 4b 5f 50 52 45 43 45 44 49 4e 47 20 0a 20 20 20  K_PRECEDING .   
9fb0: 20 20 20 20 7c 7c 20 70 4d 57 69 6e 2d 3e 65 53      || pMWin->eS
9fc0: 74 61 72 74 3d 3d 54 4b 5f 43 55 52 52 45 4e 54  tart==TK_CURRENT
9fd0: 20 0a 20 20 20 20 20 20 20 7c 7c 20 70 4d 57 69   .       || pMWi
9fe0: 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 46 4f  n->eStart==TK_FO
9ff0: 4c 4c 4f 57 49 4e 47 20 0a 20 20 20 20 20 20 20  LLOWING .       
a000: 7c 7c 20 70 4d 57 69 6e 2d 3e 65 53 74 61 72 74  || pMWin->eStart
a010: 3d 3d 54 4b 5f 55 4e 42 4f 55 4e 44 45 44 20 0a  ==TK_UNBOUNDED .
a020: 20 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 70    );.  assert( p
a030: 4d 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 46  MWin->eEnd==TK_F
a040: 4f 4c 4c 4f 57 49 4e 47 20 0a 20 20 20 20 20 20  OLLOWING .      
a050: 20 7c 7c 20 70 4d 57 69 6e 2d 3e 65 45 6e 64 3d   || pMWin->eEnd=
a060: 3d 54 4b 5f 43 55 52 52 45 4e 54 20 0a 20 20 20  =TK_CURRENT .   
a070: 20 20 20 20 7c 7c 20 70 4d 57 69 6e 2d 3e 65 45      || pMWin->eE
a080: 6e 64 3d 3d 54 4b 5f 55 4e 42 4f 55 4e 44 45 44  nd==TK_UNBOUNDED
a090: 20 0a 20 20 20 20 20 20 20 7c 7c 20 70 4d 57 69   .       || pMWi
a0a0: 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 50 52 45 43  n->eEnd==TK_PREC
a0b0: 45 44 49 4e 47 20 0a 20 20 29 3b 0a 0a 20 20 69  EDING .  );..  i
a0c0: 66 28 20 70 4d 57 69 6e 2d 3e 65 54 79 70 65 3d  f( pMWin->eType=
a0d0: 3d 54 4b 5f 52 41 4e 47 45 20 0a 20 20 20 26 26  =TK_RANGE .   &&
a0e0: 20 70 4d 57 69 6e 2d 3e 65 53 74 61 72 74 3d 3d   pMWin->eStart==
a0f0: 54 4b 5f 43 55 52 52 45 4e 54 20 0a 20 20 20 26  TK_CURRENT .   &
a100: 26 20 70 4d 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54  & pMWin->eEnd==T
a110: 4b 5f 55 4e 42 4f 55 4e 44 45 44 0a 20 20 29 7b  K_UNBOUNDED.  ){
a120: 0a 20 20 20 20 62 52 61 6e 67 65 20 3d 20 31 3b  .    bRange = 1;
a130: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 41 6c 6c 6f 63  .  }..  /* Alloc
a140: 61 74 65 20 72 65 67 69 73 74 65 72 20 61 6e 64  ate register and
a150: 20 6c 61 62 65 6c 20 66 6f 72 20 74 68 65 20 22   label for the "
a160: 66 6c 75 73 68 5f 70 61 72 74 69 74 69 6f 6e 22  flush_partition"
a170: 20 73 75 62 2d 72 6f 75 74 69 6e 65 2e 20 2a 2f   sub-routine. */
a180: 0a 20 20 72 65 67 46 6c 75 73 68 50 61 72 74 20  .  regFlushPart 
a190: 3d 20 2b 2b 70 50 61 72 73 65 2d 3e 6e 4d 65 6d  = ++pParse->nMem
a1a0: 3b 0a 20 20 6c 62 6c 46 6c 75 73 68 50 61 72 74  ;.  lblFlushPart
a1b0: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 4d 61   = sqlite3VdbeMa
a1c0: 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20 20 6c 62  keLabel(v);.  lb
a1d0: 6c 46 6c 75 73 68 44 6f 6e 65 20 3d 20 73 71 6c  lFlushDone = sql
a1e0: 69 74 65 33 56 64 62 65 4d 61 6b 65 4c 61 62 65  ite3VdbeMakeLabe
a1f0: 6c 28 76 29 3b 0a 0a 20 20 72 65 67 53 74 61 72  l(v);..  regStar
a200: 74 20 3d 20 2b 2b 70 50 61 72 73 65 2d 3e 6e 4d  t = ++pParse->nM
a210: 65 6d 3b 0a 20 20 72 65 67 45 6e 64 20 3d 20 2b  em;.  regEnd = +
a220: 2b 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 3b 0a 0a  +pParse->nMem;..
a230: 20 20 77 69 6e 64 6f 77 50 61 72 74 69 74 69 6f    windowPartitio
a240: 6e 43 61 63 68 65 28 70 50 61 72 73 65 2c 20 70  nCache(pParse, p
a250: 2c 20 70 57 49 6e 66 6f 2c 20 72 65 67 46 6c 75  , pWInfo, regFlu
a260: 73 68 50 61 72 74 2c 20 6c 62 6c 46 6c 75 73 68  shPart, lblFlush
a270: 50 61 72 74 2c 20 26 72 65 67 53 69 7a 65 29 3b  Part, &regSize);
a280: 0a 0a 20 20 61 64 64 72 47 6f 74 6f 20 3d 20 73  ..  addrGoto = s
a290: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 30  qlite3VdbeAddOp0
a2a0: 28 76 2c 20 4f 50 5f 47 6f 74 6f 29 3b 0a 0a 20  (v, OP_Goto);.. 
a2b0: 20 2f 2a 20 53 74 61 72 74 20 6f 66 20 22 66 6c   /* Start of "fl
a2c0: 75 73 68 5f 70 61 72 74 69 74 69 6f 6e 22 20 2a  ush_partition" *
a2d0: 2f 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 52  /.  sqlite3VdbeR
a2e0: 65 73 6f 6c 76 65 4c 61 62 65 6c 28 76 2c 20 6c  esolveLabel(v, l
a2f0: 62 6c 46 6c 75 73 68 50 61 72 74 29 3b 0a 20 20  blFlushPart);.  
a300: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
a310: 32 28 76 2c 20 4f 50 5f 4f 6e 63 65 2c 20 30 2c  2(v, OP_Once, 0,
a320: 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72 72   sqlite3VdbeCurr
a330: 65 6e 74 41 64 64 72 28 76 29 2b 33 29 3b 0a 20  entAddr(v)+3);. 
a340: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
a350: 70 32 28 76 2c 20 4f 50 5f 4f 70 65 6e 44 75 70  p2(v, OP_OpenDup
a360: 2c 20 63 73 72 53 74 61 72 74 2c 20 70 4d 57 69  , csrStart, pMWi
a370: 6e 2d 3e 69 45 70 68 43 73 72 29 3b 0a 20 20 73  n->iEphCsr);.  s
a380: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
a390: 28 76 2c 20 4f 50 5f 4f 70 65 6e 44 75 70 2c 20  (v, OP_OpenDup, 
a3a0: 63 73 72 45 6e 64 2c 20 70 4d 57 69 6e 2d 3e 69  csrEnd, pMWin->i
a3b0: 45 70 68 43 73 72 29 3b 0a 0a 20 20 2f 2a 20 49  EphCsr);..  /* I
a3c0: 66 20 65 69 74 68 65 72 20 72 65 67 53 74 61 72  f either regStar
a3d0: 74 20 6f 72 20 72 65 67 45 6e 64 20 61 72 65 20  t or regEnd are 
a3e0: 6e 6f 74 20 6e 6f 6e 2d 6e 65 67 61 74 69 76 65  not non-negative
a3f0: 20 69 6e 74 65 67 65 72 73 2c 20 74 68 72 6f 77   integers, throw
a400: 20 0a 20 20 2a 2a 20 61 6e 20 65 78 63 65 70 74   .  ** an except
a410: 69 6f 6e 2e 20 20 2a 2f 0a 20 20 69 66 28 20 70  ion.  */.  if( p
a420: 4d 57 69 6e 2d 3e 70 53 74 61 72 74 20 29 7b 0a  MWin->pStart ){.
a430: 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 43      sqlite3ExprC
a440: 6f 64 65 28 70 50 61 72 73 65 2c 20 70 4d 57 69  ode(pParse, pMWi
a450: 6e 2d 3e 70 53 74 61 72 74 2c 20 72 65 67 53 74  n->pStart, regSt
a460: 61 72 74 29 3b 0a 20 20 20 20 77 69 6e 64 6f 77  art);.    window
a470: 43 68 65 63 6b 46 72 61 6d 65 56 61 6c 75 65 28  CheckFrameValue(
a480: 70 50 61 72 73 65 2c 20 72 65 67 53 74 61 72 74  pParse, regStart
a490: 2c 20 30 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20  , 0);.  }.  if( 
a4a0: 70 4d 57 69 6e 2d 3e 70 45 6e 64 20 29 7b 0a 20  pMWin->pEnd ){. 
a4b0: 20 20 20 73 71 6c 69 74 65 33 45 78 70 72 43 6f     sqlite3ExprCo
a4c0: 64 65 28 70 50 61 72 73 65 2c 20 70 4d 57 69 6e  de(pParse, pMWin
a4d0: 2d 3e 70 45 6e 64 2c 20 72 65 67 45 6e 64 29 3b  ->pEnd, regEnd);
a4e0: 0a 20 20 20 20 77 69 6e 64 6f 77 43 68 65 63 6b  .    windowCheck
a4f0: 46 72 61 6d 65 56 61 6c 75 65 28 70 50 61 72 73  FrameValue(pPars
a500: 65 2c 20 72 65 67 45 6e 64 2c 20 31 29 3b 0a 20  e, regEnd, 1);. 
a510: 20 7d 0a 0a 20 20 2f 2a 20 49 66 20 74 68 69 73   }..  /* If this
a520: 20 69 73 20 22 52 4f 57 53 20 3c 65 78 70 72 31   is "ROWS <expr1
a530: 3e 20 46 4f 4c 4c 4f 57 49 4e 47 20 41 4e 44 20  > FOLLOWING AND 
a540: 52 4f 57 53 20 3c 65 78 70 72 32 3e 20 46 4f 4c  ROWS <expr2> FOL
a550: 4c 4f 57 49 4e 47 22 2c 20 64 6f 3a 0a 20 20 2a  LOWING", do:.  *
a560: 2a 0a 20 20 2a 2a 20 20 20 69 66 28 20 72 65 67  *.  **   if( reg
a570: 45 6e 64 3c 72 65 67 53 74 61 72 74 20 29 7b 0a  End<regStart ){.
a580: 20 20 2a 2a 20 20 20 20 20 2f 2f 20 54 68 65 20    **     // The 
a590: 66 72 61 6d 65 20 61 6c 77 61 79 73 20 63 6f 6e  frame always con
a5a0: 73 69 73 74 73 20 6f 66 20 30 20 72 6f 77 73 0a  sists of 0 rows.
a5b0: 20 20 2a 2a 20 20 20 20 20 72 65 67 53 74 61 72    **     regStar
a5c0: 74 20 3d 20 72 65 67 53 69 7a 65 3b 0a 20 20 2a  t = regSize;.  *
a5d0: 2a 20 20 20 7d 0a 20 20 2a 2a 20 20 20 72 65 67  *   }.  **   reg
a5e0: 45 6e 64 20 3d 20 72 65 67 45 6e 64 20 2d 20 72  End = regEnd - r
a5f0: 65 67 53 74 61 72 74 3b 0a 20 20 2a 2f 0a 20 20  egStart;.  */.  
a600: 69 66 28 20 70 4d 57 69 6e 2d 3e 70 45 6e 64 20  if( pMWin->pEnd 
a610: 26 26 20 70 4d 57 69 6e 2d 3e 70 53 74 61 72 74  && pMWin->pStart
a620: 20 26 26 20 70 4d 57 69 6e 2d 3e 65 53 74 61 72   && pMWin->eStar
a630: 74 3d 3d 54 4b 5f 46 4f 4c 4c 4f 57 49 4e 47 20  t==TK_FOLLOWING 
a640: 29 7b 0a 20 20 20 20 61 73 73 65 72 74 28 20 70  ){.    assert( p
a650: 4d 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 46  MWin->eEnd==TK_F
a660: 4f 4c 4c 4f 57 49 4e 47 20 29 3b 0a 20 20 20 20  OLLOWING );.    
a670: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
a680: 33 28 76 2c 20 4f 50 5f 47 65 2c 20 72 65 67 53  3(v, OP_Ge, regS
a690: 74 61 72 74 2c 20 73 71 6c 69 74 65 33 56 64 62  tart, sqlite3Vdb
a6a0: 65 43 75 72 72 65 6e 74 41 64 64 72 28 76 29 2b  eCurrentAddr(v)+
a6b0: 32 2c 20 72 65 67 45 6e 64 29 3b 0a 20 20 20 20  2, regEnd);.    
a6c0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
a6d0: 32 28 76 2c 20 4f 50 5f 43 6f 70 79 2c 20 72 65  2(v, OP_Copy, re
a6e0: 67 53 69 7a 65 2c 20 72 65 67 53 74 61 72 74 29  gSize, regStart)
a6f0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  ;.    sqlite3Vdb
a700: 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 53 75  eAddOp3(v, OP_Su
a710: 62 74 72 61 63 74 2c 20 72 65 67 53 74 61 72 74  btract, regStart
a720: 2c 20 72 65 67 45 6e 64 2c 20 72 65 67 45 6e 64  , regEnd, regEnd
a730: 29 3b 0a 20 20 7d 0a 0a 20 20 69 66 28 20 70 4d  );.  }..  if( pM
a740: 57 69 6e 2d 3e 70 45 6e 64 20 26 26 20 70 4d 57  Win->pEnd && pMW
a750: 69 6e 2d 3e 70 53 74 61 72 74 20 26 26 20 70 4d  in->pStart && pM
a760: 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 50 52  Win->eEnd==TK_PR
a770: 45 43 45 44 49 4e 47 20 29 7b 0a 20 20 20 20 61  ECEDING ){.    a
a780: 73 73 65 72 74 28 20 70 4d 57 69 6e 2d 3e 65 53  ssert( pMWin->eS
a790: 74 61 72 74 3d 3d 54 4b 5f 50 52 45 43 45 44 49  tart==TK_PRECEDI
a7a0: 4e 47 20 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  NG );.    sqlite
a7b0: 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f  3VdbeAddOp3(v, O
a7c0: 50 5f 4c 65 2c 20 72 65 67 53 74 61 72 74 2c 20  P_Le, regStart, 
a7d0: 73 71 6c 69 74 65 33 56 64 62 65 43 75 72 72 65  sqlite3VdbeCurre
a7e0: 6e 74 41 64 64 72 28 76 29 2b 33 2c 20 72 65 67  ntAddr(v)+3, reg
a7f0: 45 6e 64 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  End);.    sqlite
a800: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
a810: 50 5f 43 6f 70 79 2c 20 72 65 67 53 69 7a 65 2c  P_Copy, regSize,
a820: 20 72 65 67 53 74 61 72 74 29 3b 0a 20 20 20 20   regStart);.    
a830: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
a840: 32 28 76 2c 20 4f 50 5f 43 6f 70 79 2c 20 72 65  2(v, OP_Copy, re
a850: 67 53 69 7a 65 2c 20 72 65 67 45 6e 64 29 3b 0a  gSize, regEnd);.
a860: 20 20 7d 0a 0a 20 20 2f 2a 20 49 6e 69 74 69 61    }..  /* Initia
a870: 6c 69 7a 65 20 74 68 65 20 61 63 63 75 6d 75 6c  lize the accumul
a880: 61 74 6f 72 20 72 65 67 69 73 74 65 72 20 66 6f  ator register fo
a890: 72 20 65 61 63 68 20 77 69 6e 64 6f 77 20 66 75  r each window fu
a8a0: 6e 63 74 69 6f 6e 20 74 6f 20 4e 55 4c 4c 20 2a  nction to NULL *
a8b0: 2f 0a 20 20 72 65 67 41 72 67 20 3d 20 77 69 6e  /.  regArg = win
a8c0: 64 6f 77 49 6e 69 74 41 63 63 75 6d 28 70 50 61  dowInitAccum(pPa
a8d0: 72 73 65 2c 20 70 4d 57 69 6e 29 3b 0a 0a 20 20  rse, pMWin);..  
a8e0: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
a8f0: 32 28 76 2c 20 4f 50 5f 52 65 77 69 6e 64 2c 20  2(v, OP_Rewind, 
a900: 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c 20  pMWin->iEphCsr, 
a910: 6c 62 6c 46 6c 75 73 68 44 6f 6e 65 29 3b 0a 20  lblFlushDone);. 
a920: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
a930: 70 32 28 76 2c 20 4f 50 5f 52 65 77 69 6e 64 2c  p2(v, OP_Rewind,
a940: 20 63 73 72 53 74 61 72 74 2c 20 6c 62 6c 46 6c   csrStart, lblFl
a950: 75 73 68 44 6f 6e 65 29 3b 0a 20 20 73 71 6c 69  ushDone);.  sqli
a960: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 35 28  te3VdbeChangeP5(
a970: 76 2c 20 31 29 3b 0a 20 20 73 71 6c 69 74 65 33  v, 1);.  sqlite3
a980: 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50  VdbeAddOp2(v, OP
a990: 5f 52 65 77 69 6e 64 2c 20 63 73 72 45 6e 64 2c  _Rewind, csrEnd,
a9a0: 20 6c 62 6c 46 6c 75 73 68 44 6f 6e 65 29 3b 0a   lblFlushDone);.
a9b0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61    sqlite3VdbeCha
a9c0: 6e 67 65 50 35 28 76 2c 20 31 29 3b 0a 0a 20 20  ngeP5(v, 1);..  
a9d0: 2f 2a 20 49 6e 76 6f 6b 65 20 41 67 67 53 74 65  /* Invoke AggSte
a9e0: 70 20 66 75 6e 63 74 69 6f 6e 20 66 6f 72 20 65  p function for e
a9f0: 61 63 68 20 77 69 6e 64 6f 77 20 66 75 6e 63 74  ach window funct
aa00: 69 6f 6e 20 75 73 69 6e 67 20 74 68 65 20 72 6f  ion using the ro
aa10: 77 20 74 68 61 74 0a 20 20 2a 2a 20 63 73 72 45  w that.  ** csrE
aa20: 6e 64 20 63 75 72 72 65 6e 74 6c 79 20 70 6f 69  nd currently poi
aa30: 6e 74 73 20 74 6f 2e 20 4f 72 2c 20 69 66 20 63  nts to. Or, if c
aa40: 73 72 45 6e 64 20 69 73 20 61 6c 72 65 61 64 79  srEnd is already
aa50: 20 61 74 20 45 4f 46 2c 0a 20 20 2a 2a 20 64 6f   at EOF,.  ** do
aa60: 20 6e 6f 74 68 69 6e 67 2e 20 20 2a 2f 0a 20 20   nothing.  */.  
aa70: 61 64 64 72 54 6f 70 20 3d 20 73 71 6c 69 74 65  addrTop = sqlite
aa80: 33 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72  3VdbeCurrentAddr
aa90: 28 76 29 3b 0a 20 20 69 66 28 20 70 4d 57 69 6e  (v);.  if( pMWin
aaa0: 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 50 52 45 43 45  ->eEnd==TK_PRECE
aab0: 44 49 4e 47 20 29 7b 0a 20 20 20 20 61 64 64 72  DING ){.    addr
aac0: 49 66 50 6f 73 31 20 3d 20 73 71 6c 69 74 65 33  IfPos1 = sqlite3
aad0: 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50  VdbeAddOp3(v, OP
aae0: 5f 49 66 50 6f 73 2c 20 72 65 67 45 6e 64 2c 20  _IfPos, regEnd, 
aaf0: 30 20 2c 20 31 29 3b 0a 20 20 7d 0a 20 20 73 71  0 , 1);.  }.  sq
ab00: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
ab10: 76 2c 20 4f 50 5f 4e 65 78 74 2c 20 63 73 72 45  v, OP_Next, csrE
ab20: 6e 64 2c 20 73 71 6c 69 74 65 33 56 64 62 65 43  nd, sqlite3VdbeC
ab30: 75 72 72 65 6e 74 41 64 64 72 28 76 29 2b 32 29  urrentAddr(v)+2)
ab40: 3b 0a 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74  ;.  addr = sqlit
ab50: 65 33 56 64 62 65 41 64 64 4f 70 30 28 76 2c 20  e3VdbeAddOp0(v, 
ab60: 4f 50 5f 47 6f 74 6f 29 3b 0a 20 20 77 69 6e 64  OP_Goto);.  wind
ab70: 6f 77 41 67 67 53 74 65 70 28 70 50 61 72 73 65  owAggStep(pParse
ab80: 2c 20 70 4d 57 69 6e 2c 20 63 73 72 45 6e 64 2c  , pMWin, csrEnd,
ab90: 20 30 2c 20 72 65 67 41 72 67 2c 20 72 65 67 53   0, regArg, regS
aba0: 69 7a 65 29 3b 0a 20 20 69 66 28 20 70 4d 57 69  ize);.  if( pMWi
abb0: 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 55 4e 42 4f  n->eEnd==TK_UNBO
abc0: 55 4e 44 45 44 20 29 7b 0a 20 20 20 20 73 71 6c  UNDED ){.    sql
abd0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
abe0: 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20 61 64  , OP_Goto, 0, ad
abf0: 64 72 54 6f 70 29 3b 0a 20 20 20 20 73 71 6c 69  drTop);.    sqli
ac00: 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28  te3VdbeJumpHere(
ac10: 76 2c 20 61 64 64 72 29 3b 0a 20 20 20 20 61 64  v, addr);.    ad
ac20: 64 72 54 6f 70 20 3d 20 73 71 6c 69 74 65 33 56  drTop = sqlite3V
ac30: 64 62 65 43 75 72 72 65 6e 74 41 64 64 72 28 76  dbeCurrentAddr(v
ac40: 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  );.  }else{.    
ac50: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
ac60: 65 72 65 28 76 2c 20 61 64 64 72 29 3b 0a 20 20  ere(v, addr);.  
ac70: 20 20 69 66 28 20 70 4d 57 69 6e 2d 3e 65 45 6e    if( pMWin->eEn
ac80: 64 3d 3d 54 4b 5f 50 52 45 43 45 44 49 4e 47 20  d==TK_PRECEDING 
ac90: 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ){.      sqlite3
aca0: 56 64 62 65 4a 75 6d 70 48 65 72 65 28 76 2c 20  VdbeJumpHere(v, 
acb0: 61 64 64 72 49 66 50 6f 73 31 29 3b 0a 20 20 20  addrIfPos1);.   
acc0: 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28 20 70 4d   }.  }..  if( pM
acd0: 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 46 4f  Win->eEnd==TK_FO
ace0: 4c 4c 4f 57 49 4e 47 20 29 7b 0a 20 20 20 20 61  LLOWING ){.    a
acf0: 64 64 72 49 66 50 6f 73 31 20 3d 20 73 71 6c 69  ddrIfPos1 = sqli
ad00: 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c  te3VdbeAddOp3(v,
ad10: 20 4f 50 5f 49 66 50 6f 73 2c 20 72 65 67 45 6e   OP_IfPos, regEn
ad20: 64 2c 20 30 20 2c 20 31 29 3b 0a 20 20 7d 0a 20  d, 0 , 1);.  }. 
ad30: 20 69 66 28 20 70 4d 57 69 6e 2d 3e 65 53 74 61   if( pMWin->eSta
ad40: 72 74 3d 3d 54 4b 5f 46 4f 4c 4c 4f 57 49 4e 47  rt==TK_FOLLOWING
ad50: 20 29 7b 0a 20 20 20 20 61 64 64 72 49 66 50 6f   ){.    addrIfPo
ad60: 73 32 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65  s2 = sqlite3Vdbe
ad70: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 49 66 50  AddOp3(v, OP_IfP
ad80: 6f 73 2c 20 72 65 67 53 74 61 72 74 2c 20 30 20  os, regStart, 0 
ad90: 2c 20 31 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20  , 1);.  }.  if( 
ada0: 62 52 61 6e 67 65 20 29 7b 0a 20 20 20 20 61 73  bRange ){.    as
adb0: 73 65 72 74 28 20 70 4d 57 69 6e 2d 3e 65 53 74  sert( pMWin->eSt
adc0: 61 72 74 3d 3d 54 4b 5f 43 55 52 52 45 4e 54 20  art==TK_CURRENT 
add0: 26 26 20 70 4d 57 69 6e 2d 3e 70 4f 72 64 65 72  && pMWin->pOrder
ade0: 42 79 20 29 3b 0a 20 20 20 20 72 65 67 50 65 65  By );.    regPee
adf0: 72 20 3d 20 2b 2b 70 50 61 72 73 65 2d 3e 6e 4d  r = ++pParse->nM
ae00: 65 6d 3b 0a 20 20 20 20 72 65 67 50 65 65 72 56  em;.    regPeerV
ae10: 61 6c 20 3d 20 70 50 61 72 73 65 2d 3e 6e 4d 65  al = pParse->nMe
ae20: 6d 2b 31 3b 0a 20 20 20 20 69 50 65 65 72 20 3d  m+1;.    iPeer =
ae30: 20 70 4d 57 69 6e 2d 3e 6e 42 75 66 66 65 72 43   pMWin->nBufferC
ae40: 6f 6c 20 2b 20 28 70 4d 57 69 6e 2d 3e 70 50 61  ol + (pMWin->pPa
ae50: 72 74 69 74 69 6f 6e 3f 70 4d 57 69 6e 2d 3e 70  rtition?pMWin->p
ae60: 50 61 72 74 69 74 69 6f 6e 2d 3e 6e 45 78 70 72  Partition->nExpr
ae70: 3a 30 29 3b 0a 20 20 20 20 6e 50 65 65 72 56 61  :0);.    nPeerVa
ae80: 6c 20 3d 20 70 4d 57 69 6e 2d 3e 70 4f 72 64 65  l = pMWin->pOrde
ae90: 72 42 79 2d 3e 6e 45 78 70 72 3b 0a 20 20 20 20  rBy->nExpr;.    
aea0: 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20 2b 3d 20  pParse->nMem += 
aeb0: 28 32 20 2a 20 6e 50 65 65 72 56 61 6c 29 3b 0a  (2 * nPeerVal);.
aec0: 20 20 20 20 66 6f 72 28 6b 3d 30 3b 20 6b 3c 6e      for(k=0; k<n
aed0: 50 65 65 72 56 61 6c 3b 20 6b 2b 2b 29 7b 0a 20  PeerVal; k++){. 
aee0: 20 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65       sqlite3Vdbe
aef0: 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 43 6f 6c  AddOp3(v, OP_Col
af00: 75 6d 6e 2c 20 70 4d 57 69 6e 2d 3e 69 45 70 68  umn, pMWin->iEph
af10: 43 73 72 2c 20 69 50 65 65 72 2b 6b 2c 20 72 65  Csr, iPeer+k, re
af20: 67 50 65 65 72 56 61 6c 2b 6b 29 3b 0a 20 20 20  gPeerVal+k);.   
af30: 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64   }.    sqlite3Vd
af40: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 49  beAddOp2(v, OP_I
af50: 6e 74 65 67 65 72 2c 20 30 2c 20 72 65 67 50 65  nteger, 0, regPe
af60: 65 72 29 3b 0a 20 20 7d 0a 0a 20 20 77 69 6e 64  er);.  }..  wind
af70: 6f 77 41 67 67 46 69 6e 61 6c 28 70 50 61 72 73  owAggFinal(pPars
af80: 65 2c 20 70 4d 57 69 6e 2c 20 30 29 3b 0a 20 20  e, pMWin, 0);.  
af90: 69 66 28 20 62 52 61 6e 67 65 20 29 7b 0a 20 20  if( bRange ){.  
afa0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
afb0: 4f 70 32 28 76 2c 20 4f 50 5f 41 64 64 49 6d 6d  Op2(v, OP_AddImm
afc0: 2c 20 72 65 67 50 65 65 72 2c 20 31 29 3b 0a 20  , regPeer, 1);. 
afd0: 20 7d 0a 20 20 77 69 6e 64 6f 77 52 65 74 75 72   }.  windowRetur
afe0: 6e 4f 6e 65 52 6f 77 28 70 50 61 72 73 65 2c 20  nOneRow(pParse, 
aff0: 70 4d 57 69 6e 2c 20 72 65 67 47 6f 73 75 62 2c  pMWin, regGosub,
b000: 20 61 64 64 72 47 6f 73 75 62 29 3b 0a 20 20 73   addrGosub);.  s
b010: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
b020: 28 76 2c 20 4f 50 5f 4e 65 78 74 2c 20 70 4d 57  (v, OP_Next, pMW
b030: 69 6e 2d 3e 69 45 70 68 43 73 72 2c 20 73 71 6c  in->iEphCsr, sql
b040: 69 74 65 33 56 64 62 65 43 75 72 72 65 6e 74 41  ite3VdbeCurrentA
b050: 64 64 72 28 76 29 2b 32 29 3b 0a 20 20 73 71 6c  ddr(v)+2);.  sql
b060: 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76  ite3VdbeAddOp2(v
b070: 2c 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20 6c 62  , OP_Goto, 0, lb
b080: 6c 46 6c 75 73 68 44 6f 6e 65 29 3b 0a 20 20 69  lFlushDone);.  i
b090: 66 28 20 62 52 61 6e 67 65 20 29 7b 0a 20 20 20  f( bRange ){.   
b0a0: 20 4b 65 79 49 6e 66 6f 20 2a 70 4b 65 79 49 6e   KeyInfo *pKeyIn
b0b0: 66 6f 20 3d 20 73 71 6c 69 74 65 33 4b 65 79 49  fo = sqlite3KeyI
b0c0: 6e 66 6f 46 72 6f 6d 45 78 70 72 4c 69 73 74 28  nfoFromExprList(
b0d0: 70 50 61 72 73 65 2c 20 70 4d 57 69 6e 2d 3e 70  pParse, pMWin->p
b0e0: 4f 72 64 65 72 42 79 2c 30 2c 30 29 3b 0a 20 20  OrderBy,0,0);.  
b0f0: 20 20 69 6e 74 20 61 64 64 72 4a 75 6d 70 20 3d    int addrJump =
b100: 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72 72   sqlite3VdbeCurr
b110: 65 6e 74 41 64 64 72 28 76 29 2d 34 3b 0a 20 20  entAddr(v)-4;.  
b120: 20 20 66 6f 72 28 6b 3d 30 3b 20 6b 3c 6e 50 65    for(k=0; k<nPe
b130: 65 72 56 61 6c 3b 20 6b 2b 2b 29 7b 0a 20 20 20  erVal; k++){.   
b140: 20 20 20 69 6e 74 20 69 4f 75 74 20 3d 20 72 65     int iOut = re
b150: 67 50 65 65 72 56 61 6c 20 2b 20 6e 50 65 65 72  gPeerVal + nPeer
b160: 56 61 6c 20 2b 20 6b 3b 0a 20 20 20 20 20 20 73  Val + k;.      s
b170: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33  qlite3VdbeAddOp3
b180: 28 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e 2c 20 70  (v, OP_Column, p
b190: 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c 20 69  MWin->iEphCsr, i
b1a0: 50 65 65 72 2b 6b 2c 20 69 4f 75 74 29 3b 0a 20  Peer+k, iOut);. 
b1b0: 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33     }.    sqlite3
b1c0: 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50  VdbeAddOp3(v, OP
b1d0: 5f 43 6f 6d 70 61 72 65 2c 20 72 65 67 50 65 65  _Compare, regPee
b1e0: 72 56 61 6c 2c 20 72 65 67 50 65 65 72 56 61 6c  rVal, regPeerVal
b1f0: 2b 6e 50 65 65 72 56 61 6c 2c 20 6e 50 65 65 72  +nPeerVal, nPeer
b200: 56 61 6c 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  Val);.    sqlite
b210: 33 56 64 62 65 41 70 70 65 6e 64 50 34 28 76 2c  3VdbeAppendP4(v,
b220: 20 28 76 6f 69 64 2a 29 70 4b 65 79 49 6e 66 6f   (void*)pKeyInfo
b230: 2c 20 50 34 5f 4b 45 59 49 4e 46 4f 29 3b 0a 20  , P4_KEYINFO);. 
b240: 20 20 20 61 64 64 72 20 3d 20 73 71 6c 69 74 65     addr = sqlite
b250: 33 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72  3VdbeCurrentAddr
b260: 28 76 29 2b 31 3b 0a 20 20 20 20 73 71 6c 69 74  (v)+1;.    sqlit
b270: 65 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20  e3VdbeAddOp3(v, 
b280: 4f 50 5f 4a 75 6d 70 2c 20 61 64 64 72 2c 20 61  OP_Jump, addr, a
b290: 64 64 72 4a 75 6d 70 2c 20 61 64 64 72 29 3b 0a  ddrJump, addr);.
b2a0: 20 20 7d 0a 20 20 69 66 28 20 70 4d 57 69 6e 2d    }.  if( pMWin-
b2b0: 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 46 4f 4c 4c  >eStart==TK_FOLL
b2c0: 4f 57 49 4e 47 20 29 7b 0a 20 20 20 20 73 71 6c  OWING ){.    sql
b2d0: 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65  ite3VdbeJumpHere
b2e0: 28 76 2c 20 61 64 64 72 49 66 50 6f 73 32 29 3b  (v, addrIfPos2);
b2f0: 0a 20 20 7d 0a 0a 20 20 69 66 28 20 70 4d 57 69  .  }..  if( pMWi
b300: 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 43 55  n->eStart==TK_CU
b310: 52 52 45 4e 54 20 0a 20 20 20 7c 7c 20 70 4d 57  RRENT .   || pMW
b320: 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 50  in->eStart==TK_P
b330: 52 45 43 45 44 49 4e 47 20 0a 20 20 20 7c 7c 20  RECEDING .   || 
b340: 70 4d 57 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54  pMWin->eStart==T
b350: 4b 5f 46 4f 4c 4c 4f 57 49 4e 47 20 0a 20 20 29  K_FOLLOWING .  )
b360: 7b 0a 20 20 20 20 69 6e 74 20 61 64 64 72 4a 75  {.    int addrJu
b370: 6d 70 48 65 72 65 20 3d 20 30 3b 0a 20 20 20 20  mpHere = 0;.    
b380: 69 66 28 20 70 4d 57 69 6e 2d 3e 65 53 74 61 72  if( pMWin->eStar
b390: 74 3d 3d 54 4b 5f 50 52 45 43 45 44 49 4e 47 20  t==TK_PRECEDING 
b3a0: 29 7b 0a 20 20 20 20 20 20 61 64 64 72 4a 75 6d  ){.      addrJum
b3b0: 70 48 65 72 65 20 3d 20 73 71 6c 69 74 65 33 56  pHere = sqlite3V
b3c0: 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f  dbeAddOp3(v, OP_
b3d0: 49 66 50 6f 73 2c 20 72 65 67 53 74 61 72 74 2c  IfPos, regStart,
b3e0: 20 30 20 2c 20 31 29 3b 0a 20 20 20 20 7d 0a 20   0 , 1);.    }. 
b3f0: 20 20 20 69 66 28 20 62 52 61 6e 67 65 20 29 7b     if( bRange ){
b400: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 56 64  .      sqlite3Vd
b410: 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50 5f 49  beAddOp3(v, OP_I
b420: 66 50 6f 73 2c 20 72 65 67 50 65 65 72 2c 20 73  fPos, regPeer, s
b430: 71 6c 69 74 65 33 56 64 62 65 43 75 72 72 65 6e  qlite3VdbeCurren
b440: 74 41 64 64 72 28 76 29 2b 32 2c 20 31 29 3b 0a  tAddr(v)+2, 1);.
b450: 20 20 20 20 20 20 61 64 64 72 4a 75 6d 70 48 65        addrJumpHe
b460: 72 65 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65  re = sqlite3Vdbe
b470: 41 64 64 4f 70 30 28 76 2c 20 4f 50 5f 47 6f 74  AddOp0(v, OP_Got
b480: 6f 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71  o);.    }.    sq
b490: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32 28  lite3VdbeAddOp2(
b4a0: 76 2c 20 4f 50 5f 4e 65 78 74 2c 20 63 73 72 53  v, OP_Next, csrS
b4b0: 74 61 72 74 2c 20 73 71 6c 69 74 65 33 56 64 62  tart, sqlite3Vdb
b4c0: 65 43 75 72 72 65 6e 74 41 64 64 72 28 76 29 2b  eCurrentAddr(v)+
b4d0: 31 29 3b 0a 20 20 20 20 77 69 6e 64 6f 77 41 67  1);.    windowAg
b4e0: 67 53 74 65 70 28 70 50 61 72 73 65 2c 20 70 4d  gStep(pParse, pM
b4f0: 57 69 6e 2c 20 63 73 72 53 74 61 72 74 2c 20 31  Win, csrStart, 1
b500: 2c 20 72 65 67 41 72 67 2c 20 72 65 67 53 69 7a  , regArg, regSiz
b510: 65 29 3b 0a 20 20 20 20 69 66 28 20 62 52 61 6e  e);.    if( bRan
b520: 67 65 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69  ge ){.      sqli
b530: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c  te3VdbeAddOp2(v,
b540: 20 4f 50 5f 47 6f 74 6f 2c 20 30 2c 20 61 64 64   OP_Goto, 0, add
b550: 72 4a 75 6d 70 48 65 72 65 2d 31 29 3b 0a 20 20  rJumpHere-1);.  
b560: 20 20 7d 0a 20 20 20 20 69 66 28 20 61 64 64 72    }.    if( addr
b570: 4a 75 6d 70 48 65 72 65 20 29 7b 0a 20 20 20 20  JumpHere ){.    
b580: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d    sqlite3VdbeJum
b590: 70 48 65 72 65 28 76 2c 20 61 64 64 72 4a 75 6d  pHere(v, addrJum
b5a0: 70 48 65 72 65 29 3b 0a 20 20 20 20 7d 0a 20 20  pHere);.    }.  
b5b0: 7d 0a 20 20 69 66 28 20 70 4d 57 69 6e 2d 3e 65  }.  if( pMWin->e
b5c0: 45 6e 64 3d 3d 54 4b 5f 46 4f 4c 4c 4f 57 49 4e  End==TK_FOLLOWIN
b5d0: 47 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  G ){.    sqlite3
b5e0: 56 64 62 65 4a 75 6d 70 48 65 72 65 28 76 2c 20  VdbeJumpHere(v, 
b5f0: 61 64 64 72 49 66 50 6f 73 31 29 3b 0a 20 20 7d  addrIfPos1);.  }
b600: 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64  .  sqlite3VdbeAd
b610: 64 4f 70 32 28 76 2c 20 4f 50 5f 47 6f 74 6f 2c  dOp2(v, OP_Goto,
b620: 20 30 2c 20 61 64 64 72 54 6f 70 29 3b 0a 0a 20   0, addrTop);.. 
b630: 20 2f 2a 20 66 6c 75 73 68 5f 70 61 72 74 69 74   /* flush_partit
b640: 69 6f 6e 5f 64 6f 6e 65 3a 20 2a 2f 0a 20 20 73  ion_done: */.  s
b650: 71 6c 69 74 65 33 56 64 62 65 52 65 73 6f 6c 76  qlite3VdbeResolv
b660: 65 4c 61 62 65 6c 28 76 2c 20 6c 62 6c 46 6c 75  eLabel(v, lblFlu
b670: 73 68 44 6f 6e 65 29 3b 0a 20 20 73 71 6c 69 74  shDone);.  sqlit
b680: 65 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20  e3VdbeAddOp1(v, 
b690: 4f 50 5f 52 65 73 65 74 53 6f 72 74 65 72 2c 20  OP_ResetSorter, 
b6a0: 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 29 3b  pMWin->iEphCsr);
b6b0: 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64  .  sqlite3VdbeAd
b6c0: 64 4f 70 31 28 76 2c 20 4f 50 5f 52 65 74 75 72  dOp1(v, OP_Retur
b6d0: 6e 2c 20 72 65 67 46 6c 75 73 68 50 61 72 74 29  n, regFlushPart)
b6e0: 3b 0a 0a 20 20 2f 2a 20 4a 75 6d 70 20 74 6f 20  ;..  /* Jump to 
b6f0: 68 65 72 65 20 74 6f 20 73 6b 69 70 20 6f 76 65  here to skip ove
b700: 72 20 66 6c 75 73 68 5f 70 61 72 74 69 74 69 6f  r flush_partitio
b710: 6e 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 56 64  n */.  sqlite3Vd
b720: 62 65 4a 75 6d 70 48 65 72 65 28 76 2c 20 61 64  beJumpHere(v, ad
b730: 64 72 47 6f 74 6f 29 3b 0a 7d 0a 0a 2f 2a 0a 2a  drGoto);.}../*.*
b740: 2a 20 52 41 4e 47 45 20 42 45 54 57 45 45 4e 20  * RANGE BETWEEN 
b750: 55 4e 42 4f 55 4e 44 45 44 20 50 52 45 43 45 44  UNBOUNDED PRECED
b760: 49 4e 47 20 41 4e 44 20 43 55 52 52 45 4e 54 20  ING AND CURRENT 
b770: 52 4f 57 0a 2a 2a 0a 2a 2a 20 20 20 66 6c 75 73  ROW.**.**   flus
b780: 68 5f 70 61 72 74 69 74 69 6f 6e 3a 0a 2a 2a 20  h_partition:.** 
b790: 20 20 20 20 4f 6e 63 65 20 7b 0a 2a 2a 20 20 20      Once {.**   
b7a0: 20 20 20 20 4f 70 65 6e 44 75 70 20 28 69 45 70      OpenDup (iEp
b7b0: 68 43 73 72 20 2d 3e 20 63 73 72 4c 65 61 64 29  hCsr -> csrLead)
b7c0: 0a 2a 2a 20 20 20 20 20 7d 0a 2a 2a 20 20 20 20  .**     }.**    
b7d0: 20 49 6e 74 65 67 65 72 20 63 74 72 20 30 0a 2a   Integer ctr 0.*
b7e0: 2a 20 20 20 20 20 66 6f 72 65 61 63 68 20 72 6f  *     foreach ro
b7f0: 77 20 28 63 73 72 4c 65 61 64 29 7b 0a 2a 2a 20  w (csrLead){.** 
b800: 20 20 20 20 20 20 69 66 28 20 6e 65 77 20 70 65        if( new pe
b810: 65 72 20 29 7b 0a 2a 2a 20 20 20 20 20 20 20 20  er ){.**        
b820: 20 41 67 67 46 69 6e 61 6c 20 28 78 56 61 6c 75   AggFinal (xValu
b830: 65 29 0a 2a 2a 20 20 20 20 20 20 20 20 20 66 6f  e).**         fo
b840: 72 28 69 3d 30 3b 20 69 3c 63 74 72 3b 20 69 2b  r(i=0; i<ctr; i+
b850: 2b 29 7b 0a 2a 2a 20 20 20 20 20 20 20 20 20 20  +){.**          
b860: 20 47 6f 73 75 62 20 61 64 64 72 47 6f 73 75 62   Gosub addrGosub
b870: 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20 4e 65  .**           Ne
b880: 78 74 20 69 45 70 68 43 73 72 0a 2a 2a 20 20 20  xt iEphCsr.**   
b890: 20 20 20 20 20 20 7d 0a 2a 2a 20 20 20 20 20 20        }.**      
b8a0: 20 20 20 49 6e 74 65 67 65 72 20 63 74 72 20 30     Integer ctr 0
b8b0: 0a 2a 2a 20 20 20 20 20 20 20 7d 0a 2a 2a 20 20  .**       }.**  
b8c0: 20 20 20 20 20 41 67 67 53 74 65 70 20 28 63 73       AggStep (cs
b8d0: 72 4c 65 61 64 29 0a 2a 2a 20 20 20 20 20 20 20  rLead).**       
b8e0: 49 6e 63 72 20 63 74 72 0a 2a 2a 20 20 20 20 20  Incr ctr.**     
b8f0: 7d 0a 2a 2a 0a 2a 2a 20 20 20 20 20 41 67 67 46  }.**.**     AggF
b900: 69 6e 61 6c 20 28 78 46 69 6e 61 6c 69 7a 65 29  inal (xFinalize)
b910: 0a 2a 2a 20 20 20 20 20 66 6f 72 28 69 3d 30 3b  .**     for(i=0;
b920: 20 69 3c 63 74 72 3b 20 69 2b 2b 29 7b 0a 2a 2a   i<ctr; i++){.**
b930: 20 20 20 20 20 20 20 47 6f 73 75 62 20 61 64 64         Gosub add
b940: 72 47 6f 73 75 62 0a 2a 2a 20 20 20 20 20 20 20  rGosub.**       
b950: 4e 65 78 74 20 69 45 70 68 43 73 72 0a 2a 2a 20  Next iEphCsr.** 
b960: 20 20 20 20 7d 0a 2a 2a 0a 2a 2a 20 20 20 20 20      }.**.**     
b970: 52 65 73 65 74 53 6f 72 74 65 72 20 28 63 73 72  ResetSorter (csr
b980: 29 0a 2a 2a 20 20 20 20 20 52 65 74 75 72 6e 0a  ).**     Return.
b990: 2a 2a 0a 2a 2a 20 52 4f 57 53 20 42 45 54 57 45  **.** ROWS BETWE
b9a0: 45 4e 20 55 4e 42 4f 55 4e 44 45 44 20 50 52 45  EN UNBOUNDED PRE
b9b0: 43 45 44 49 4e 47 20 41 4e 44 20 43 55 52 52 45  CEDING AND CURRE
b9c0: 4e 54 20 52 4f 57 0a 2a 2a 20 52 41 4e 47 45 20  NT ROW.** RANGE 
b9d0: 42 45 54 57 45 45 4e 20 55 4e 42 4f 55 4e 44 45  BETWEEN UNBOUNDE
b9e0: 44 20 50 52 45 43 45 44 49 4e 47 20 41 4e 44 20  D PRECEDING AND 
b9f0: 55 4e 42 4f 55 4e 44 45 44 20 46 4f 4c 4c 4f 57  UNBOUNDED FOLLOW
ba00: 49 4e 47 0a 2a 2a 20 52 41 4e 47 45 20 42 45 54  ING.** RANGE BET
ba10: 57 45 45 4e 20 43 55 52 52 45 4e 54 20 52 4f 57  WEEN CURRENT ROW
ba20: 20 41 4e 44 20 43 55 52 52 45 4e 54 20 52 4f 57   AND CURRENT ROW
ba30: 20 0a 2a 2a 0a 2a 2a 20 20 20 54 4f 44 4f 2e 0a   .**.**   TODO..
ba40: 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 77  */.static void w
ba50: 69 6e 64 6f 77 43 6f 64 65 43 61 63 68 65 53 74  indowCodeCacheSt
ba60: 65 70 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61  ep(.  Parse *pPa
ba70: 72 73 65 2c 20 0a 20 20 53 65 6c 65 63 74 20 2a  rse, .  Select *
ba80: 70 2c 0a 20 20 57 68 65 72 65 49 6e 66 6f 20 2a  p,.  WhereInfo *
ba90: 70 57 49 6e 66 6f 2c 0a 20 20 69 6e 74 20 72 65  pWInfo,.  int re
baa0: 67 47 6f 73 75 62 2c 20 0a 20 20 69 6e 74 20 61  gGosub, .  int a
bab0: 64 64 72 47 6f 73 75 62 0a 29 7b 0a 20 20 57 69  ddrGosub.){.  Wi
bac0: 6e 64 6f 77 20 2a 70 4d 57 69 6e 20 3d 20 70 2d  ndow *pMWin = p-
bad0: 3e 70 57 69 6e 3b 0a 20 20 56 64 62 65 20 2a 76  >pWin;.  Vdbe *v
bae0: 20 3d 20 73 71 6c 69 74 65 33 47 65 74 56 64 62   = sqlite3GetVdb
baf0: 65 28 70 50 61 72 73 65 29 3b 0a 20 20 57 69 6e  e(pParse);.  Win
bb00: 64 6f 77 20 2a 70 57 69 6e 3b 0a 20 20 69 6e 74  dow *pWin;.  int
bb10: 20 6b 3b 0a 20 20 69 6e 74 20 61 64 64 72 3b 0a   k;.  int addr;.
bb20: 20 20 45 78 70 72 4c 69 73 74 20 2a 70 50 61 72    ExprList *pPar
bb30: 74 20 3d 20 70 4d 57 69 6e 2d 3e 70 50 61 72 74  t = pMWin->pPart
bb40: 69 74 69 6f 6e 3b 0a 20 20 45 78 70 72 4c 69 73  ition;.  ExprLis
bb50: 74 20 2a 70 4f 72 64 65 72 42 79 20 3d 20 70 4d  t *pOrderBy = pM
bb60: 57 69 6e 2d 3e 70 4f 72 64 65 72 42 79 3b 0a 20  Win->pOrderBy;. 
bb70: 20 69 6e 74 20 6e 50 65 65 72 20 3d 20 70 4f 72   int nPeer = pOr
bb80: 64 65 72 42 79 2d 3e 6e 45 78 70 72 3b 0a 20 20  derBy->nExpr;.  
bb90: 69 6e 74 20 72 65 67 4e 65 77 50 65 65 72 3b 0a  int regNewPeer;.
bba0: 0a 20 20 69 6e 74 20 61 64 64 72 47 6f 74 6f 3b  .  int addrGoto;
bbb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bbc0: 20 20 20 2f 2a 20 41 64 64 72 65 73 73 20 6f 66     /* Address of
bbd0: 20 47 6f 74 6f 20 75 73 65 64 20 74 6f 20 6a 75   Goto used to ju
bbe0: 6d 70 20 66 6c 75 73 68 5f 70 61 72 2e 2e 20 2a  mp flush_par.. *
bbf0: 2f 0a 20 20 69 6e 74 20 61 64 64 72 52 65 77 69  /.  int addrRewi
bc00: 6e 64 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  nd;             
bc10: 20 20 20 20 2f 2a 20 41 64 64 72 65 73 73 20 6f      /* Address o
bc20: 66 20 52 65 77 69 6e 64 20 74 68 61 74 20 73 74  f Rewind that st
bc30: 61 72 74 73 20 6c 6f 6f 70 20 2a 2f 0a 20 20 69  arts loop */.  i
bc40: 6e 74 20 72 65 67 46 6c 75 73 68 50 61 72 74 3b  nt regFlushPart;
bc50: 0a 20 20 69 6e 74 20 6c 62 6c 46 6c 75 73 68 50  .  int lblFlushP
bc60: 61 72 74 3b 0a 20 20 69 6e 74 20 63 73 72 4c 65  art;.  int csrLe
bc70: 61 64 3b 0a 20 20 69 6e 74 20 72 65 67 43 74 72  ad;.  int regCtr
bc80: 3b 0a 20 20 69 6e 74 20 72 65 67 41 72 67 3b 20  ;.  int regArg; 
bc90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
bca0: 20 20 20 20 2f 2a 20 52 65 67 69 73 74 65 72 20      /* Register 
bcb0: 61 72 72 61 79 20 74 6f 20 6d 61 72 74 69 61 6c  array to martial
bcc0: 20 66 75 6e 63 74 69 6f 6e 20 61 72 67 73 20 2a   function args *
bcd0: 2f 0a 20 20 69 6e 74 20 72 65 67 53 69 7a 65 3b  /.  int regSize;
bce0: 0a 20 20 69 6e 74 20 6e 41 72 67 3b 0a 0a 20 20  .  int nArg;..  
bcf0: 61 73 73 65 72 74 28 20 28 70 4d 57 69 6e 2d 3e  assert( (pMWin->
bd00: 65 53 74 61 72 74 3d 3d 54 4b 5f 55 4e 42 4f 55  eStart==TK_UNBOU
bd10: 4e 44 45 44 20 26 26 20 70 4d 57 69 6e 2d 3e 65  NDED && pMWin->e
bd20: 45 6e 64 3d 3d 54 4b 5f 43 55 52 52 45 4e 54 29  End==TK_CURRENT)
bd30: 20 0a 20 20 20 20 20 20 20 7c 7c 20 28 70 4d 57   .       || (pMW
bd40: 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 55  in->eStart==TK_U
bd50: 4e 42 4f 55 4e 44 45 44 20 26 26 20 70 4d 57 69  NBOUNDED && pMWi
bd60: 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 55 4e 42 4f  n->eEnd==TK_UNBO
bd70: 55 4e 44 45 44 29 20 0a 20 20 20 20 20 20 20 7c  UNDED) .       |
bd80: 7c 20 28 70 4d 57 69 6e 2d 3e 65 53 74 61 72 74  | (pMWin->eStart
bd90: 3d 3d 54 4b 5f 43 55 52 52 45 4e 54 20 26 26 20  ==TK_CURRENT && 
bda0: 70 4d 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f  pMWin->eEnd==TK_
bdb0: 43 55 52 52 45 4e 54 29 20 0a 20 20 29 3b 0a 0a  CURRENT) .  );..
bdc0: 20 20 72 65 67 4e 65 77 50 65 65 72 20 3d 20 70    regNewPeer = p
bdd0: 50 61 72 73 65 2d 3e 6e 4d 65 6d 2b 31 3b 0a 20  Parse->nMem+1;. 
bde0: 20 70 50 61 72 73 65 2d 3e 6e 4d 65 6d 20 2b 3d   pParse->nMem +=
bdf0: 20 6e 50 65 65 72 3b 0a 0a 20 20 2f 2a 20 41 6c   nPeer;..  /* Al
be00: 6c 6f 63 61 74 65 20 72 65 67 69 73 74 65 72 20  locate register 
be10: 61 6e 64 20 6c 61 62 65 6c 20 66 6f 72 20 74 68  and label for th
be20: 65 20 22 66 6c 75 73 68 5f 70 61 72 74 69 74 69  e "flush_partiti
be30: 6f 6e 22 20 73 75 62 2d 72 6f 75 74 69 6e 65 2e  on" sub-routine.
be40: 20 2a 2f 0a 20 20 72 65 67 46 6c 75 73 68 50 61   */.  regFlushPa
be50: 72 74 20 3d 20 2b 2b 70 50 61 72 73 65 2d 3e 6e  rt = ++pParse->n
be60: 4d 65 6d 3b 0a 20 20 6c 62 6c 46 6c 75 73 68 50  Mem;.  lblFlushP
be70: 61 72 74 20 3d 20 73 71 6c 69 74 65 33 56 64 62  art = sqlite3Vdb
be80: 65 4d 61 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 0a  eMakeLabel(v);..
be90: 20 20 63 73 72 4c 65 61 64 20 3d 20 70 50 61 72    csrLead = pPar
bea0: 73 65 2d 3e 6e 54 61 62 2b 2b 3b 0a 20 20 72 65  se->nTab++;.  re
beb0: 67 43 74 72 20 3d 20 2b 2b 70 50 61 72 73 65 2d  gCtr = ++pParse-
bec0: 3e 6e 4d 65 6d 3b 0a 0a 20 20 77 69 6e 64 6f 77  >nMem;..  window
bed0: 50 61 72 74 69 74 69 6f 6e 43 61 63 68 65 28 70  PartitionCache(p
bee0: 50 61 72 73 65 2c 20 70 2c 20 70 57 49 6e 66 6f  Parse, p, pWInfo
bef0: 2c 20 72 65 67 46 6c 75 73 68 50 61 72 74 2c 20  , regFlushPart, 
bf00: 6c 62 6c 46 6c 75 73 68 50 61 72 74 2c 20 26 72  lblFlushPart, &r
bf10: 65 67 53 69 7a 65 29 3b 0a 20 20 61 64 64 72 47  egSize);.  addrG
bf20: 6f 74 6f 20 3d 20 73 71 6c 69 74 65 33 56 64 62  oto = sqlite3Vdb
bf30: 65 41 64 64 4f 70 30 28 76 2c 20 4f 50 5f 47 6f  eAddOp0(v, OP_Go
bf40: 74 6f 29 3b 0a 0a 20 20 2f 2a 20 53 74 61 72 74  to);..  /* Start
bf50: 20 6f 66 20 22 66 6c 75 73 68 5f 70 61 72 74 69   of "flush_parti
bf60: 74 69 6f 6e 22 20 2a 2f 0a 20 20 73 71 6c 69 74  tion" */.  sqlit
bf70: 65 33 56 64 62 65 52 65 73 6f 6c 76 65 4c 61 62  e3VdbeResolveLab
bf80: 65 6c 28 76 2c 20 6c 62 6c 46 6c 75 73 68 50 61  el(v, lblFlushPa
bf90: 72 74 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64  rt);.  sqlite3Vd
bfa0: 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f 4f  beAddOp2(v, OP_O
bfb0: 6e 63 65 2c 20 30 2c 20 73 71 6c 69 74 65 33 56  nce, 0, sqlite3V
bfc0: 64 62 65 43 75 72 72 65 6e 74 41 64 64 72 28 76  dbeCurrentAddr(v
bfd0: 29 2b 32 29 3b 0a 20 20 73 71 6c 69 74 65 33 56  )+2);.  sqlite3V
bfe0: 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f 50 5f  dbeAddOp2(v, OP_
bff0: 4f 70 65 6e 44 75 70 2c 20 63 73 72 4c 65 61 64  OpenDup, csrLead
c000: 2c 20 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72  , pMWin->iEphCsr
c010: 29 3b 0a 0a 20 20 2f 2a 20 49 6e 69 74 69 61 6c  );..  /* Initial
c020: 69 7a 65 20 74 68 65 20 61 63 63 75 6d 75 6c 61  ize the accumula
c030: 74 6f 72 20 72 65 67 69 73 74 65 72 20 66 6f 72  tor register for
c040: 20 65 61 63 68 20 77 69 6e 64 6f 77 20 66 75 6e   each window fun
c050: 63 74 69 6f 6e 20 74 6f 20 4e 55 4c 4c 20 2a 2f  ction to NULL */
c060: 0a 20 20 72 65 67 41 72 67 20 3d 20 77 69 6e 64  .  regArg = wind
c070: 6f 77 49 6e 69 74 41 63 63 75 6d 28 70 50 61 72  owInitAccum(pPar
c080: 73 65 2c 20 70 4d 57 69 6e 29 3b 0a 0a 20 20 73  se, pMWin);..  s
c090: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
c0a0: 28 76 2c 20 4f 50 5f 49 6e 74 65 67 65 72 2c 20  (v, OP_Integer, 
c0b0: 30 2c 20 72 65 67 43 74 72 29 3b 0a 20 20 61 64  0, regCtr);.  ad
c0c0: 64 72 52 65 77 69 6e 64 20 3d 20 73 71 6c 69 74  drRewind = sqlit
c0d0: 65 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20  e3VdbeAddOp1(v, 
c0e0: 4f 50 5f 52 65 77 69 6e 64 2c 20 63 73 72 4c 65  OP_Rewind, csrLe
c0f0: 61 64 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64  ad);.  sqlite3Vd
c100: 62 65 41 64 64 4f 70 31 28 76 2c 20 4f 50 5f 52  beAddOp1(v, OP_R
c110: 65 77 69 6e 64 2c 20 70 4d 57 69 6e 2d 3e 69 45  ewind, pMWin->iE
c120: 70 68 43 73 72 29 3b 0a 0a 20 20 69 66 28 20 70  phCsr);..  if( p
c130: 4f 72 64 65 72 42 79 20 26 26 20 70 4d 57 69 6e  OrderBy && pMWin
c140: 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 43 55 52 52 45  ->eEnd==TK_CURRE
c150: 4e 54 20 29 7b 0a 20 20 20 20 69 6e 74 20 62 43  NT ){.    int bC
c160: 75 72 72 65 6e 74 20 3d 20 28 70 4d 57 69 6e 2d  urrent = (pMWin-
c170: 3e 65 45 6e 64 3d 3d 54 4b 5f 43 55 52 52 45 4e  >eEnd==TK_CURREN
c180: 54 20 26 26 20 70 4d 57 69 6e 2d 3e 65 53 74 61  T && pMWin->eSta
c190: 72 74 3d 3d 54 4b 5f 43 55 52 52 45 4e 54 29 3b  rt==TK_CURRENT);
c1a0: 0a 20 20 20 20 69 6e 74 20 61 64 64 72 4a 75 6d  .    int addrJum
c1b0: 70 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  p = 0;          
c1c0: 20 20 20 2f 2a 20 41 64 64 72 65 73 73 20 6f 66     /* Address of
c1d0: 20 4f 50 5f 4a 75 6d 70 20 62 65 6c 6f 77 20 2a   OP_Jump below *
c1e0: 2f 0a 20 20 20 20 69 66 28 20 70 4d 57 69 6e 2d  /.    if( pMWin-
c1f0: 3e 65 54 79 70 65 3d 3d 54 4b 5f 52 41 4e 47 45  >eType==TK_RANGE
c200: 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 4f   ){.      int iO
c210: 66 66 20 3d 20 70 4d 57 69 6e 2d 3e 6e 42 75 66  ff = pMWin->nBuf
c220: 66 65 72 43 6f 6c 20 2b 20 28 70 50 61 72 74 20  ferCol + (pPart 
c230: 3f 20 70 50 61 72 74 2d 3e 6e 45 78 70 72 20 3a  ? pPart->nExpr :
c240: 20 30 29 3b 0a 20 20 20 20 20 20 69 6e 74 20 72   0);.      int r
c250: 65 67 50 65 65 72 20 3d 20 70 4d 57 69 6e 2d 3e  egPeer = pMWin->
c260: 72 65 67 50 61 72 74 20 2b 20 28 70 50 61 72 74  regPart + (pPart
c270: 20 3f 20 70 50 61 72 74 2d 3e 6e 45 78 70 72 20   ? pPart->nExpr 
c280: 3a 20 30 29 3b 0a 20 20 20 20 20 20 4b 65 79 49  : 0);.      KeyI
c290: 6e 66 6f 20 2a 70 4b 65 79 49 6e 66 6f 20 3d 20  nfo *pKeyInfo = 
c2a0: 73 71 6c 69 74 65 33 4b 65 79 49 6e 66 6f 46 72  sqlite3KeyInfoFr
c2b0: 6f 6d 45 78 70 72 4c 69 73 74 28 70 50 61 72 73  omExprList(pPars
c2c0: 65 2c 20 70 4f 72 64 65 72 42 79 2c 20 30 2c 20  e, pOrderBy, 0, 
c2d0: 30 29 3b 0a 20 20 20 20 20 20 66 6f 72 28 6b 3d  0);.      for(k=
c2e0: 30 3b 20 6b 3c 6e 50 65 65 72 3b 20 6b 2b 2b 29  0; k<nPeer; k++)
c2f0: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
c300: 33 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f  3VdbeAddOp3(v, O
c310: 50 5f 43 6f 6c 75 6d 6e 2c 20 63 73 72 4c 65 61  P_Column, csrLea
c320: 64 2c 20 69 4f 66 66 2b 6b 2c 20 72 65 67 4e 65  d, iOff+k, regNe
c330: 77 50 65 65 72 2b 6b 29 3b 0a 20 20 20 20 20 20  wPeer+k);.      
c340: 7d 0a 20 20 20 20 20 20 61 64 64 72 20 3d 20 73  }.      addr = s
c350: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33  qlite3VdbeAddOp3
c360: 28 76 2c 20 4f 50 5f 43 6f 6d 70 61 72 65 2c 20  (v, OP_Compare, 
c370: 72 65 67 4e 65 77 50 65 65 72 2c 20 72 65 67 50  regNewPeer, regP
c380: 65 65 72 2c 20 6e 50 65 65 72 29 3b 0a 20 20 20  eer, nPeer);.   
c390: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 70     sqlite3VdbeAp
c3a0: 70 65 6e 64 50 34 28 76 2c 20 28 76 6f 69 64 2a  pendP4(v, (void*
c3b0: 29 70 4b 65 79 49 6e 66 6f 2c 20 50 34 5f 4b 45  )pKeyInfo, P4_KE
c3c0: 59 49 4e 46 4f 29 3b 0a 20 20 20 20 20 20 61 64  YINFO);.      ad
c3d0: 64 72 4a 75 6d 70 20 3d 20 73 71 6c 69 74 65 33  drJump = sqlite3
c3e0: 56 64 62 65 41 64 64 4f 70 33 28 76 2c 20 4f 50  VdbeAddOp3(v, OP
c3f0: 5f 4a 75 6d 70 2c 20 61 64 64 72 2b 32 2c 20 30  _Jump, addr+2, 0
c400: 2c 20 61 64 64 72 2b 32 29 3b 0a 20 20 20 20 20  , addr+2);.     
c410: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
c420: 70 33 28 76 2c 20 4f 50 5f 43 6f 70 79 2c 20 72  p3(v, OP_Copy, r
c430: 65 67 4e 65 77 50 65 65 72 2c 20 72 65 67 50 65  egNewPeer, regPe
c440: 65 72 2c 20 6e 50 65 65 72 2d 31 29 3b 0a 20 20  er, nPeer-1);.  
c450: 20 20 7d 0a 0a 20 20 20 20 77 69 6e 64 6f 77 52    }..    windowR
c460: 65 74 75 72 6e 52 6f 77 73 28 70 50 61 72 73 65  eturnRows(pParse
c470: 2c 20 70 4d 57 69 6e 2c 20 72 65 67 43 74 72 2c  , pMWin, regCtr,
c480: 20 30 2c 20 72 65 67 47 6f 73 75 62 2c 20 61 64   0, regGosub, ad
c490: 64 72 47 6f 73 75 62 2c 20 0a 20 20 20 20 20 20  drGosub, .      
c4a0: 20 20 28 62 43 75 72 72 65 6e 74 20 3f 20 72 65    (bCurrent ? re
c4b0: 67 41 72 67 20 3a 20 30 29 2c 20 28 62 43 75 72  gArg : 0), (bCur
c4c0: 72 65 6e 74 20 3f 20 72 65 67 53 69 7a 65 20 3a  rent ? regSize :
c4d0: 20 30 29 0a 20 20 20 20 29 3b 0a 20 20 20 20 69   0).    );.    i
c4e0: 66 28 20 61 64 64 72 4a 75 6d 70 20 29 20 73 71  f( addrJump ) sq
c4f0: 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72  lite3VdbeJumpHer
c500: 65 28 76 2c 20 61 64 64 72 4a 75 6d 70 29 3b 0a  e(v, addrJump);.
c510: 20 20 7d 0a 0a 20 20 77 69 6e 64 6f 77 41 67 67    }..  windowAgg
c520: 53 74 65 70 28 70 50 61 72 73 65 2c 20 70 4d 57  Step(pParse, pMW
c530: 69 6e 2c 20 63 73 72 4c 65 61 64 2c 20 30 2c 20  in, csrLead, 0, 
c540: 72 65 67 41 72 67 2c 20 72 65 67 53 69 7a 65 29  regArg, regSize)
c550: 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41  ;.  sqlite3VdbeA
c560: 64 64 4f 70 32 28 76 2c 20 4f 50 5f 41 64 64 49  ddOp2(v, OP_AddI
c570: 6d 6d 2c 20 72 65 67 43 74 72 2c 20 31 29 3b 0a  mm, regCtr, 1);.
c580: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
c590: 4f 70 32 28 76 2c 20 4f 50 5f 4e 65 78 74 2c 20  Op2(v, OP_Next, 
c5a0: 63 73 72 4c 65 61 64 2c 20 61 64 64 72 52 65 77  csrLead, addrRew
c5b0: 69 6e 64 2b 32 29 3b 0a 0a 20 20 77 69 6e 64 6f  ind+2);..  windo
c5c0: 77 52 65 74 75 72 6e 52 6f 77 73 28 70 50 61 72  wReturnRows(pPar
c5d0: 73 65 2c 20 70 4d 57 69 6e 2c 20 72 65 67 43 74  se, pMWin, regCt
c5e0: 72 2c 20 31 2c 20 72 65 67 47 6f 73 75 62 2c 20  r, 1, regGosub, 
c5f0: 61 64 64 72 47 6f 73 75 62 2c 20 30 2c 20 30 29  addrGosub, 0, 0)
c600: 3b 0a 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65  ;..  sqlite3Vdbe
c610: 4a 75 6d 70 48 65 72 65 28 76 2c 20 61 64 64 72  JumpHere(v, addr
c620: 52 65 77 69 6e 64 29 3b 0a 20 20 73 71 6c 69 74  Rewind);.  sqlit
c630: 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28 76  e3VdbeJumpHere(v
c640: 2c 20 61 64 64 72 52 65 77 69 6e 64 2b 31 29 3b  , addrRewind+1);
c650: 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64  .  sqlite3VdbeAd
c660: 64 4f 70 31 28 76 2c 20 4f 50 5f 52 65 73 65 74  dOp1(v, OP_Reset
c670: 53 6f 72 74 65 72 2c 20 70 4d 57 69 6e 2d 3e 69  Sorter, pMWin->i
c680: 45 70 68 43 73 72 29 3b 0a 20 20 73 71 6c 69 74  EphCsr);.  sqlit
c690: 65 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20  e3VdbeAddOp1(v, 
c6a0: 4f 50 5f 52 65 74 75 72 6e 2c 20 72 65 67 46 6c  OP_Return, regFl
c6b0: 75 73 68 50 61 72 74 29 3b 0a 0a 20 20 2f 2a 20  ushPart);..  /* 
c6c0: 4a 75 6d 70 20 74 6f 20 68 65 72 65 20 74 6f 20  Jump to here to 
c6d0: 73 6b 69 70 20 6f 76 65 72 20 66 6c 75 73 68 5f  skip over flush_
c6e0: 70 61 72 74 69 74 69 6f 6e 20 2a 2f 0a 20 20 73  partition */.  s
c6f0: 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65  qlite3VdbeJumpHe
c700: 72 65 28 76 2c 20 61 64 64 72 47 6f 74 6f 29 3b  re(v, addrGoto);
c710: 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 52 41 4e 47 45  .}.../*.** RANGE
c720: 20 42 45 54 57 45 45 4e 20 55 4e 42 4f 55 4e 44   BETWEEN UNBOUND
c730: 45 44 20 50 52 45 43 45 44 49 4e 47 20 41 4e 44  ED PRECEDING AND
c740: 20 43 55 52 52 45 4e 54 20 52 4f 57 0a 2a 2a 0a   CURRENT ROW.**.
c750: 2a 2a 20 20 20 2e 2e 2e 0a 2a 2a 20 20 20 20 20  **   ....**     
c760: 69 66 28 20 6e 65 77 20 70 61 72 74 69 74 69 6f  if( new partitio
c770: 6e 20 29 7b 0a 2a 2a 20 20 20 20 20 20 20 41 67  n ){.**       Ag
c780: 67 46 69 6e 61 6c 20 28 78 46 69 6e 61 6c 69 7a  gFinal (xFinaliz
c790: 65 29 0a 2a 2a 20 20 20 20 20 20 20 47 6f 73 75  e).**       Gosu
c7a0: 62 20 61 64 64 72 47 6f 73 75 62 0a 2a 2a 20 20  b addrGosub.**  
c7b0: 20 20 20 20 20 52 65 73 65 74 53 6f 72 74 65 72       ResetSorter
c7c0: 20 65 70 68 2d 74 61 62 6c 65 0a 2a 2a 20 20 20   eph-table.**   
c7d0: 20 20 7d 0a 2a 2a 20 20 20 20 20 65 6c 73 65 20    }.**     else 
c7e0: 69 66 28 20 6e 65 77 20 70 65 65 72 20 29 7b 0a  if( new peer ){.
c7f0: 2a 2a 20 20 20 20 20 20 20 41 67 67 46 69 6e 61  **       AggFina
c800: 6c 20 28 78 56 61 6c 75 65 29 0a 2a 2a 20 20 20  l (xValue).**   
c810: 20 20 20 20 47 6f 73 75 62 20 61 64 64 72 47 6f      Gosub addrGo
c820: 73 75 62 0a 2a 2a 20 20 20 20 20 20 20 52 65 73  sub.**       Res
c830: 65 74 53 6f 72 74 65 72 20 65 70 68 2d 74 61 62  etSorter eph-tab
c840: 6c 65 0a 2a 2a 20 20 20 20 20 7d 0a 2a 2a 20 20  le.**     }.**  
c850: 20 20 20 41 67 67 53 74 65 70 0a 2a 2a 20 20 20     AggStep.**   
c860: 20 20 49 6e 73 65 72 74 20 28 72 65 63 6f 72 64    Insert (record
c870: 20 69 6e 74 6f 20 65 70 68 2d 74 61 62 6c 65 29   into eph-table)
c880: 0a 2a 2a 20 20 20 73 71 6c 69 74 65 33 57 68 65  .**   sqlite3Whe
c890: 72 65 45 6e 64 28 29 0a 2a 2a 20 20 20 41 67 67  reEnd().**   Agg
c8a0: 46 69 6e 61 6c 20 28 78 46 69 6e 61 6c 69 7a 65  Final (xFinalize
c8b0: 29 0a 2a 2a 20 20 20 47 6f 73 75 62 20 61 64 64  ).**   Gosub add
c8c0: 72 47 6f 73 75 62 0a 2a 2a 0a 2a 2a 20 52 41 4e  rGosub.**.** RAN
c8d0: 47 45 20 42 45 54 57 45 45 4e 20 55 4e 42 4f 55  GE BETWEEN UNBOU
c8e0: 4e 44 45 44 20 50 52 45 43 45 44 49 4e 47 20 41  NDED PRECEDING A
c8f0: 4e 44 20 55 4e 42 4f 55 4e 44 45 44 20 46 4f 4c  ND UNBOUNDED FOL
c900: 4c 4f 57 49 4e 47 0a 2a 2a 0a 2a 2a 20 20 20 41  LOWING.**.**   A
c910: 73 20 61 62 6f 76 65 2c 20 65 78 63 65 70 74 20  s above, except 
c920: 74 61 6b 65 20 6e 6f 20 61 63 74 69 6f 6e 20 66  take no action f
c930: 6f 72 20 61 20 22 6e 65 77 20 70 65 65 72 22 2e  or a "new peer".
c940: 20 49 6e 76 6f 6b 65 0a 2a 2a 20 20 20 74 68 65   Invoke.**   the
c950: 20 73 75 62 2d 72 6f 75 74 69 6e 65 20 6f 6e 63   sub-routine onc
c960: 65 20 6f 6e 6c 79 20 66 6f 72 20 65 61 63 68 20  e only for each 
c970: 70 61 72 74 69 74 69 6f 6e 2e 0a 2a 2a 0a 2a 2a  partition..**.**
c980: 20 52 41 4e 47 45 20 42 45 54 57 45 45 4e 20 43   RANGE BETWEEN C
c990: 55 52 52 45 4e 54 20 52 4f 57 20 41 4e 44 20 43  URRENT ROW AND C
c9a0: 55 52 52 45 4e 54 20 52 4f 57 0a 2a 2a 0a 2a 2a  URRENT ROW.**.**
c9b0: 20 20 20 41 73 20 61 62 6f 76 65 2c 20 65 78 63     As above, exc
c9c0: 65 70 74 20 74 68 61 74 20 74 68 65 20 22 6e 65  ept that the "ne
c9d0: 77 20 70 65 65 72 22 20 63 6f 6e 64 69 74 69 6f  w peer" conditio
c9e0: 6e 20 69 73 20 68 61 6e 64 6c 65 64 20 69 6e 20  n is handled in 
c9f0: 74 68 65 0a 2a 2a 20 20 20 73 61 6d 65 20 77 61  the.**   same wa
ca00: 79 20 61 73 20 22 6e 65 77 20 70 61 72 74 69 74  y as "new partit
ca10: 69 6f 6e 22 20 28 73 6f 20 74 68 65 72 65 20 69  ion" (so there i
ca20: 73 20 6e 6f 20 22 65 6c 73 65 20 69 66 22 20 62  s no "else if" b
ca30: 6c 6f 63 6b 29 2e 0a 2a 2a 0a 2a 2a 20 52 4f 57  lock)..**.** ROW
ca40: 53 20 42 45 54 57 45 45 4e 20 55 4e 42 4f 55 4e  S BETWEEN UNBOUN
ca50: 44 45 44 20 50 52 45 43 45 44 49 4e 47 20 41 4e  DED PRECEDING AN
ca60: 44 20 43 55 52 52 45 4e 54 20 52 4f 57 0a 2a 2a  D CURRENT ROW.**
ca70: 20 0a 2a 2a 20 20 20 41 73 20 61 62 6f 76 65 2c   .**   As above,
ca80: 20 65 78 63 65 70 74 20 61 73 73 75 6d 65 20 65   except assume e
ca90: 76 65 72 79 20 72 6f 77 20 69 73 20 61 20 22 6e  very row is a "n
caa0: 65 77 20 70 65 65 72 22 2e 0a 2a 2f 0a 73 74 61  ew peer"..*/.sta
cab0: 74 69 63 20 76 6f 69 64 20 77 69 6e 64 6f 77 43  tic void windowC
cac0: 6f 64 65 44 65 66 61 75 6c 74 53 74 65 70 28 0a  odeDefaultStep(.
cad0: 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c    Parse *pParse,
cae0: 20 0a 20 20 53 65 6c 65 63 74 20 2a 70 2c 0a 20   .  Select *p,. 
caf0: 20 57 68 65 72 65 49 6e 66 6f 20 2a 70 57 49 6e   WhereInfo *pWIn
cb00: 66 6f 2c 0a 20 20 69 6e 74 20 72 65 67 47 6f 73  fo,.  int regGos
cb10: 75 62 2c 20 0a 20 20 69 6e 74 20 61 64 64 72 47  ub, .  int addrG
cb20: 6f 73 75 62 0a 29 7b 0a 20 20 57 69 6e 64 6f 77  osub.){.  Window
cb30: 20 2a 70 4d 57 69 6e 20 3d 20 70 2d 3e 70 57 69   *pMWin = p->pWi
cb40: 6e 3b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73  n;.  Vdbe *v = s
cb50: 71 6c 69 74 65 33 47 65 74 56 64 62 65 28 70 50  qlite3GetVdbe(pP
cb60: 61 72 73 65 29 3b 0a 20 20 57 69 6e 64 6f 77 20  arse);.  Window 
cb70: 2a 70 57 69 6e 3b 0a 20 20 69 6e 74 20 6b 3b 0a  *pWin;.  int k;.
cb80: 20 20 69 6e 74 20 69 53 75 62 43 73 72 20 3d 20    int iSubCsr = 
cb90: 70 2d 3e 70 53 72 63 2d 3e 61 5b 30 5d 2e 69 43  p->pSrc->a[0].iC
cba0: 75 72 73 6f 72 3b 0a 20 20 69 6e 74 20 6e 53 75  ursor;.  int nSu
cbb0: 62 20 3d 20 70 2d 3e 70 53 72 63 2d 3e 61 5b 30  b = p->pSrc->a[0
cbc0: 5d 2e 70 54 61 62 2d 3e 6e 43 6f 6c 3b 0a 20 20  ].pTab->nCol;.  
cbd0: 69 6e 74 20 72 65 67 20 3d 20 70 50 61 72 73 65  int reg = pParse
cbe0: 2d 3e 6e 4d 65 6d 2b 31 3b 0a 20 20 69 6e 74 20  ->nMem+1;.  int 
cbf0: 72 65 67 52 65 63 6f 72 64 20 3d 20 72 65 67 2b  regRecord = reg+
cc00: 6e 53 75 62 3b 0a 20 20 69 6e 74 20 72 65 67 52  nSub;.  int regR
cc10: 6f 77 69 64 20 3d 20 72 65 67 52 65 63 6f 72 64  owid = regRecord
cc20: 2b 31 3b 0a 20 20 69 6e 74 20 61 64 64 72 3b 0a  +1;.  int addr;.
cc30: 20 20 45 78 70 72 4c 69 73 74 20 2a 70 50 61 72    ExprList *pPar
cc40: 74 20 3d 20 70 4d 57 69 6e 2d 3e 70 50 61 72 74  t = pMWin->pPart
cc50: 69 74 69 6f 6e 3b 0a 20 20 45 78 70 72 4c 69 73  ition;.  ExprLis
cc60: 74 20 2a 70 4f 72 64 65 72 42 79 20 3d 20 70 4d  t *pOrderBy = pM
cc70: 57 69 6e 2d 3e 70 4f 72 64 65 72 42 79 3b 0a 0a  Win->pOrderBy;..
cc80: 20 20 61 73 73 65 72 74 28 20 70 4d 57 69 6e 2d    assert( pMWin-
cc90: 3e 65 54 79 70 65 3d 3d 54 4b 5f 52 41 4e 47 45  >eType==TK_RANGE
cca0: 20 0a 20 20 20 20 20 20 7c 7c 20 28 70 4d 57 69   .      || (pMWi
ccb0: 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 55 4e  n->eStart==TK_UN
ccc0: 42 4f 55 4e 44 45 44 20 26 26 20 70 4d 57 69 6e  BOUNDED && pMWin
ccd0: 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 43 55 52 52 45  ->eEnd==TK_CURRE
cce0: 4e 54 29 0a 20 20 29 3b 0a 0a 20 20 61 73 73 65  NT).  );..  asse
ccf0: 72 74 28 20 28 70 4d 57 69 6e 2d 3e 65 53 74 61  rt( (pMWin->eSta
cd00: 72 74 3d 3d 54 4b 5f 55 4e 42 4f 55 4e 44 45 44  rt==TK_UNBOUNDED
cd10: 20 26 26 20 70 4d 57 69 6e 2d 3e 65 45 6e 64 3d   && pMWin->eEnd=
cd20: 3d 54 4b 5f 43 55 52 52 45 4e 54 29 0a 20 20 20  =TK_CURRENT).   
cd30: 20 20 20 20 7c 7c 20 28 70 4d 57 69 6e 2d 3e 65      || (pMWin->e
cd40: 53 74 61 72 74 3d 3d 54 4b 5f 55 4e 42 4f 55 4e  Start==TK_UNBOUN
cd50: 44 45 44 20 26 26 20 70 4d 57 69 6e 2d 3e 65 45  DED && pMWin->eE
cd60: 6e 64 3d 3d 54 4b 5f 55 4e 42 4f 55 4e 44 45 44  nd==TK_UNBOUNDED
cd70: 29 0a 20 20 20 20 20 20 20 7c 7c 20 28 70 4d 57  ).       || (pMW
cd80: 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 43  in->eStart==TK_C
cd90: 55 52 52 45 4e 54 20 26 26 20 70 4d 57 69 6e 2d  URRENT && pMWin-
cda0: 3e 65 45 6e 64 3d 3d 54 4b 5f 43 55 52 52 45 4e  >eEnd==TK_CURREN
cdb0: 54 29 0a 20 20 20 20 20 20 20 7c 7c 20 28 70 4d  T).       || (pM
cdc0: 57 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f  Win->eStart==TK_
cdd0: 43 55 52 52 45 4e 54 20 26 26 20 70 4d 57 69 6e  CURRENT && pMWin
cde0: 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 55 4e 42 4f 55  ->eEnd==TK_UNBOU
cdf0: 4e 44 45 44 20 26 26 20 21 70 4f 72 64 65 72 42  NDED && !pOrderB
ce00: 79 29 0a 20 20 29 3b 0a 0a 20 20 69 66 28 20 70  y).  );..  if( p
ce10: 4d 57 69 6e 2d 3e 65 45 6e 64 3d 3d 54 4b 5f 55  MWin->eEnd==TK_U
ce20: 4e 42 4f 55 4e 44 45 44 20 29 7b 0a 20 20 20 20  NBOUNDED ){.    
ce30: 70 4f 72 64 65 72 42 79 20 3d 20 30 3b 0a 20 20  pOrderBy = 0;.  
ce40: 7d 0a 0a 20 20 70 50 61 72 73 65 2d 3e 6e 4d 65  }..  pParse->nMe
ce50: 6d 20 2b 3d 20 6e 53 75 62 20 2b 20 32 3b 0a 0a  m += nSub + 2;..
ce60: 20 20 2f 2a 20 4d 61 72 74 69 61 6c 20 74 68 65    /* Martial the
ce70: 20 72 6f 77 20 72 65 74 75 72 6e 65 64 20 62 79   row returned by
ce80: 20 74 68 65 20 73 75 62 2d 73 65 6c 65 63 74 20   the sub-select 
ce90: 69 6e 74 6f 20 61 6e 20 61 72 72 61 79 20 6f 66  into an array of
cea0: 20 0a 20 20 2a 2a 20 72 65 67 69 73 74 65 72 73   .  ** registers
ceb0: 2e 20 2a 2f 0a 20 20 66 6f 72 28 6b 3d 30 3b 20  . */.  for(k=0; 
cec0: 6b 3c 6e 53 75 62 3b 20 6b 2b 2b 29 7b 0a 20 20  k<nSub; k++){.  
ced0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
cee0: 4f 70 33 28 76 2c 20 4f 50 5f 43 6f 6c 75 6d 6e  Op3(v, OP_Column
cef0: 2c 20 69 53 75 62 43 73 72 2c 20 6b 2c 20 72 65  , iSubCsr, k, re
cf00: 67 2b 6b 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20  g+k);.  }..  /* 
cf10: 43 68 65 63 6b 20 69 66 20 74 68 69 73 20 69 73  Check if this is
cf20: 20 74 68 65 20 73 74 61 72 74 20 6f 66 20 61 20   the start of a 
cf30: 6e 65 77 20 70 61 72 74 69 74 69 6f 6e 20 6f 72  new partition or
cf40: 20 70 65 65 72 20 67 72 6f 75 70 2e 20 2a 2f 0a   peer group. */.
cf50: 20 20 69 66 28 20 70 50 61 72 74 20 7c 7c 20 70    if( pPart || p
cf60: 4f 72 64 65 72 42 79 20 29 7b 0a 20 20 20 20 69  OrderBy ){.    i
cf70: 6e 74 20 6e 50 61 72 74 20 3d 20 28 70 50 61 72  nt nPart = (pPar
cf80: 74 20 3f 20 70 50 61 72 74 2d 3e 6e 45 78 70 72  t ? pPart->nExpr
cf90: 20 3a 20 30 29 3b 0a 20 20 20 20 69 6e 74 20 61   : 0);.    int a
cfa0: 64 64 72 47 6f 74 6f 20 3d 20 30 3b 0a 20 20 20  ddrGoto = 0;.   
cfb0: 20 69 6e 74 20 61 64 64 72 4a 75 6d 70 20 3d 20   int addrJump = 
cfc0: 30 3b 0a 20 20 20 20 69 6e 74 20 6e 50 65 65 72  0;.    int nPeer
cfd0: 20 3d 20 28 70 4f 72 64 65 72 42 79 20 3f 20 70   = (pOrderBy ? p
cfe0: 4f 72 64 65 72 42 79 2d 3e 6e 45 78 70 72 20 3a  OrderBy->nExpr :
cff0: 20 30 29 3b 0a 0a 20 20 20 20 69 66 28 20 70 50   0);..    if( pP
d000: 61 72 74 20 29 7b 0a 20 20 20 20 20 20 69 6e 74  art ){.      int
d010: 20 72 65 67 4e 65 77 50 61 72 74 20 3d 20 72 65   regNewPart = re
d020: 67 20 2b 20 70 4d 57 69 6e 2d 3e 6e 42 75 66 66  g + pMWin->nBuff
d030: 65 72 43 6f 6c 3b 0a 20 20 20 20 20 20 4b 65 79  erCol;.      Key
d040: 49 6e 66 6f 20 2a 70 4b 65 79 49 6e 66 6f 20 3d  Info *pKeyInfo =
d050: 20 73 71 6c 69 74 65 33 4b 65 79 49 6e 66 6f 46   sqlite3KeyInfoF
d060: 72 6f 6d 45 78 70 72 4c 69 73 74 28 70 50 61 72  romExprList(pPar
d070: 73 65 2c 20 70 50 61 72 74 2c 20 30 2c 20 30 29  se, pPart, 0, 0)
d080: 3b 0a 20 20 20 20 20 20 61 64 64 72 20 3d 20 73  ;.      addr = s
d090: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33  qlite3VdbeAddOp3
d0a0: 28 76 2c 20 4f 50 5f 43 6f 6d 70 61 72 65 2c 20  (v, OP_Compare, 
d0b0: 72 65 67 4e 65 77 50 61 72 74 2c 20 70 4d 57 69  regNewPart, pMWi
d0c0: 6e 2d 3e 72 65 67 50 61 72 74 2c 6e 50 61 72 74  n->regPart,nPart
d0d0: 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  );.      sqlite3
d0e0: 56 64 62 65 41 70 70 65 6e 64 50 34 28 76 2c 20  VdbeAppendP4(v, 
d0f0: 28 76 6f 69 64 2a 29 70 4b 65 79 49 6e 66 6f 2c  (void*)pKeyInfo,
d100: 20 50 34 5f 4b 45 59 49 4e 46 4f 29 3b 0a 20 20   P4_KEYINFO);.  
d110: 20 20 20 20 61 64 64 72 4a 75 6d 70 20 3d 20 73      addrJump = s
d120: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33  qlite3VdbeAddOp3
d130: 28 76 2c 20 4f 50 5f 4a 75 6d 70 2c 20 61 64 64  (v, OP_Jump, add
d140: 72 2b 32 2c 20 30 2c 20 61 64 64 72 2b 32 29 3b  r+2, 0, addr+2);
d150: 0a 20 20 20 20 20 20 77 69 6e 64 6f 77 41 67 67  .      windowAgg
d160: 46 69 6e 61 6c 28 70 50 61 72 73 65 2c 20 70 4d  Final(pParse, pM
d170: 57 69 6e 2c 20 31 29 3b 0a 20 20 20 20 20 20 69  Win, 1);.      i
d180: 66 28 20 70 4f 72 64 65 72 42 79 20 29 7b 0a 20  f( pOrderBy ){. 
d190: 20 20 20 20 20 20 20 61 64 64 72 47 6f 74 6f 20         addrGoto 
d1a0: 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64  = sqlite3VdbeAdd
d1b0: 4f 70 30 28 76 2c 20 4f 50 5f 47 6f 74 6f 29 3b  Op0(v, OP_Goto);
d1c0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a  .      }.    }..
d1d0: 20 20 20 20 69 66 28 20 70 4f 72 64 65 72 42 79      if( pOrderBy
d1e0: 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 72 65   ){.      int re
d1f0: 67 4e 65 77 50 65 65 72 20 3d 20 72 65 67 20 2b  gNewPeer = reg +
d200: 20 70 4d 57 69 6e 2d 3e 6e 42 75 66 66 65 72 43   pMWin->nBufferC
d210: 6f 6c 20 2b 20 6e 50 61 72 74 3b 0a 20 20 20 20  ol + nPart;.    
d220: 20 20 69 6e 74 20 72 65 67 50 65 65 72 20 3d 20    int regPeer = 
d230: 70 4d 57 69 6e 2d 3e 72 65 67 50 61 72 74 20 2b  pMWin->regPart +
d240: 20 6e 50 61 72 74 3b 0a 0a 20 20 20 20 20 20 69   nPart;..      i
d250: 66 28 20 61 64 64 72 4a 75 6d 70 20 29 20 73 71  f( addrJump ) sq
d260: 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72  lite3VdbeJumpHer
d270: 65 28 76 2c 20 61 64 64 72 4a 75 6d 70 29 3b 0a  e(v, addrJump);.
d280: 20 20 20 20 20 20 69 66 28 20 70 4d 57 69 6e 2d        if( pMWin-
d290: 3e 65 54 79 70 65 3d 3d 54 4b 5f 52 41 4e 47 45  >eType==TK_RANGE
d2a0: 20 29 7b 0a 20 20 20 20 20 20 20 20 4b 65 79 49   ){.        KeyI
d2b0: 6e 66 6f 20 2a 70 4b 65 79 49 6e 66 6f 20 3d 20  nfo *pKeyInfo = 
d2c0: 73 71 6c 69 74 65 33 4b 65 79 49 6e 66 6f 46 72  sqlite3KeyInfoFr
d2d0: 6f 6d 45 78 70 72 4c 69 73 74 28 70 50 61 72 73  omExprList(pPars
d2e0: 65 2c 20 70 4f 72 64 65 72 42 79 2c 20 30 2c 20  e, pOrderBy, 0, 
d2f0: 30 29 3b 0a 20 20 20 20 20 20 20 20 61 64 64 72  0);.        addr
d300: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 41 64   = sqlite3VdbeAd
d310: 64 4f 70 33 28 76 2c 20 4f 50 5f 43 6f 6d 70 61  dOp3(v, OP_Compa
d320: 72 65 2c 20 72 65 67 4e 65 77 50 65 65 72 2c 20  re, regNewPeer, 
d330: 72 65 67 50 65 65 72 2c 20 6e 50 65 65 72 29 3b  regPeer, nPeer);
d340: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
d350: 56 64 62 65 41 70 70 65 6e 64 50 34 28 76 2c 20  VdbeAppendP4(v, 
d360: 28 76 6f 69 64 2a 29 70 4b 65 79 49 6e 66 6f 2c  (void*)pKeyInfo,
d370: 20 50 34 5f 4b 45 59 49 4e 46 4f 29 3b 0a 20 20   P4_KEYINFO);.  
d380: 20 20 20 20 20 20 61 64 64 72 4a 75 6d 70 20 3d        addrJump =
d390: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
d3a0: 70 33 28 76 2c 20 4f 50 5f 4a 75 6d 70 2c 20 61  p3(v, OP_Jump, a
d3b0: 64 64 72 2b 32 2c 20 30 2c 20 61 64 64 72 2b 32  ddr+2, 0, addr+2
d3c0: 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a  );.      }else{.
d3d0: 20 20 20 20 20 20 20 20 61 64 64 72 4a 75 6d 70          addrJump
d3e0: 20 3d 20 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20   = 0;.      }.  
d3f0: 20 20 20 20 77 69 6e 64 6f 77 41 67 67 46 69 6e      windowAggFin
d400: 61 6c 28 70 50 61 72 73 65 2c 20 70 4d 57 69 6e  al(pParse, pMWin
d410: 2c 20 70 4d 57 69 6e 2d 3e 65 53 74 61 72 74 3d  , pMWin->eStart=
d420: 3d 54 4b 5f 43 55 52 52 45 4e 54 29 3b 0a 20 20  =TK_CURRENT);.  
d430: 20 20 20 20 69 66 28 20 61 64 64 72 47 6f 74 6f      if( addrGoto
d440: 20 29 20 73 71 6c 69 74 65 33 56 64 62 65 4a 75   ) sqlite3VdbeJu
d450: 6d 70 48 65 72 65 28 76 2c 20 61 64 64 72 47 6f  mpHere(v, addrGo
d460: 74 6f 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  to);.    }..    
d470: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
d480: 32 28 76 2c 20 4f 50 5f 52 65 77 69 6e 64 2c 20  2(v, OP_Rewind, 
d490: 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c 73  pMWin->iEphCsr,s
d4a0: 71 6c 69 74 65 33 56 64 62 65 43 75 72 72 65 6e  qlite3VdbeCurren
d4b0: 74 41 64 64 72 28 76 29 2b 33 29 3b 0a 20 20 20  tAddr(v)+3);.   
d4c0: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
d4d0: 70 32 28 76 2c 20 4f 50 5f 47 6f 73 75 62 2c 20  p2(v, OP_Gosub, 
d4e0: 72 65 67 47 6f 73 75 62 2c 20 61 64 64 72 47 6f  regGosub, addrGo
d4f0: 73 75 62 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  sub);.    sqlite
d500: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
d510: 50 5f 4e 65 78 74 2c 20 70 4d 57 69 6e 2d 3e 69  P_Next, pMWin->i
d520: 45 70 68 43 73 72 2c 20 73 71 6c 69 74 65 33 56  EphCsr, sqlite3V
d530: 64 62 65 43 75 72 72 65 6e 74 41 64 64 72 28 76  dbeCurrentAddr(v
d540: 29 2d 31 29 3b 0a 0a 20 20 20 20 73 71 6c 69 74  )-1);..    sqlit
d550: 65 33 56 64 62 65 41 64 64 4f 70 31 28 76 2c 20  e3VdbeAddOp1(v, 
d560: 4f 50 5f 52 65 73 65 74 53 6f 72 74 65 72 2c 20  OP_ResetSorter, 
d570: 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 29 3b  pMWin->iEphCsr);
d580: 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62 65  .    sqlite3Vdbe
d590: 41 64 64 4f 70 33 28 0a 20 20 20 20 20 20 20 20  AddOp3(.        
d5a0: 76 2c 20 4f 50 5f 43 6f 70 79 2c 20 72 65 67 2b  v, OP_Copy, reg+
d5b0: 70 4d 57 69 6e 2d 3e 6e 42 75 66 66 65 72 43 6f  pMWin->nBufferCo
d5c0: 6c 2c 20 70 4d 57 69 6e 2d 3e 72 65 67 50 61 72  l, pMWin->regPar
d5d0: 74 2c 20 6e 50 61 72 74 2b 6e 50 65 65 72 2d 31  t, nPart+nPeer-1
d5e0: 0a 20 20 20 20 29 3b 0a 0a 20 20 20 20 69 66 28  .    );..    if(
d5f0: 20 61 64 64 72 4a 75 6d 70 20 29 20 73 71 6c 69   addrJump ) sqli
d600: 74 65 33 56 64 62 65 4a 75 6d 70 48 65 72 65 28  te3VdbeJumpHere(
d610: 76 2c 20 61 64 64 72 4a 75 6d 70 29 3b 0a 20 20  v, addrJump);.  
d620: 7d 0a 0a 20 20 2f 2a 20 49 6e 76 6f 6b 65 20 73  }..  /* Invoke s
d630: 74 65 70 20 66 75 6e 63 74 69 6f 6e 20 66 6f 72  tep function for
d640: 20 77 69 6e 64 6f 77 20 66 75 6e 63 74 69 6f 6e   window function
d650: 73 20 2a 2f 0a 20 20 77 69 6e 64 6f 77 41 67 67  s */.  windowAgg
d660: 53 74 65 70 28 70 50 61 72 73 65 2c 20 70 4d 57  Step(pParse, pMW
d670: 69 6e 2c 20 2d 31 2c 20 30 2c 20 72 65 67 2c 20  in, -1, 0, reg, 
d680: 30 29 3b 0a 0a 20 20 2f 2a 20 42 75 66 66 65 72  0);..  /* Buffer
d690: 20 74 68 65 20 63 75 72 72 65 6e 74 20 72 6f 77   the current row
d6a0: 20 69 6e 20 74 68 65 20 65 70 68 65 6d 65 72 61   in the ephemera
d6b0: 6c 20 74 61 62 6c 65 2e 20 2a 2f 0a 20 20 69 66  l table. */.  if
d6c0: 28 20 70 4d 57 69 6e 2d 3e 6e 42 75 66 66 65 72  ( pMWin->nBuffer
d6d0: 43 6f 6c 3e 30 20 29 7b 0a 20 20 20 20 73 71 6c  Col>0 ){.    sql
d6e0: 69 74 65 33 56 64 62 65 41 64 64 4f 70 33 28 76  ite3VdbeAddOp3(v
d6f0: 2c 20 4f 50 5f 4d 61 6b 65 52 65 63 6f 72 64 2c  , OP_MakeRecord,
d700: 20 72 65 67 2c 20 70 4d 57 69 6e 2d 3e 6e 42 75   reg, pMWin->nBu
d710: 66 66 65 72 43 6f 6c 2c 20 72 65 67 52 65 63 6f  fferCol, regReco
d720: 72 64 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  rd);.  }else{.  
d730: 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64    sqlite3VdbeAdd
d740: 4f 70 32 28 76 2c 20 4f 50 5f 42 6c 6f 62 2c 20  Op2(v, OP_Blob, 
d750: 30 2c 20 72 65 67 52 65 63 6f 72 64 29 3b 0a 20  0, regRecord);. 
d760: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 41 70     sqlite3VdbeAp
d770: 70 65 6e 64 50 34 28 76 2c 20 28 76 6f 69 64 2a  pendP4(v, (void*
d780: 29 22 22 2c 20 30 29 3b 0a 20 20 7d 0a 20 20 73  )"", 0);.  }.  s
d790: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
d7a0: 28 76 2c 20 4f 50 5f 4e 65 77 52 6f 77 69 64 2c  (v, OP_NewRowid,
d7b0: 20 70 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c   pMWin->iEphCsr,
d7c0: 20 72 65 67 52 6f 77 69 64 29 3b 0a 20 20 73 71   regRowid);.  sq
d7d0: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 33 28  lite3VdbeAddOp3(
d7e0: 76 2c 20 4f 50 5f 49 6e 73 65 72 74 2c 20 70 4d  v, OP_Insert, pM
d7f0: 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c 20 72 65  Win->iEphCsr, re
d800: 67 52 65 63 6f 72 64 2c 20 72 65 67 52 6f 77 69  gRecord, regRowi
d810: 64 29 3b 0a 0a 20 20 2f 2a 20 45 6e 64 20 74 68  d);..  /* End th
d820: 65 20 64 61 74 61 62 61 73 65 20 73 63 61 6e 20  e database scan 
d830: 6c 6f 6f 70 2e 20 2a 2f 0a 20 20 73 71 6c 69 74  loop. */.  sqlit
d840: 65 33 57 68 65 72 65 45 6e 64 28 70 57 49 6e 66  e3WhereEnd(pWInf
d850: 6f 29 3b 0a 0a 20 20 77 69 6e 64 6f 77 41 67 67  o);..  windowAgg
d860: 46 69 6e 61 6c 28 70 50 61 72 73 65 2c 20 70 4d  Final(pParse, pM
d870: 57 69 6e 2c 20 31 29 3b 0a 20 20 73 71 6c 69 74  Win, 1);.  sqlit
d880: 65 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20  e3VdbeAddOp2(v, 
d890: 4f 50 5f 52 65 77 69 6e 64 2c 20 70 4d 57 69 6e  OP_Rewind, pMWin
d8a0: 2d 3e 69 45 70 68 43 73 72 2c 73 71 6c 69 74 65  ->iEphCsr,sqlite
d8b0: 33 56 64 62 65 43 75 72 72 65 6e 74 41 64 64 72  3VdbeCurrentAddr
d8c0: 28 76 29 2b 33 29 3b 0a 20 20 73 71 6c 69 74 65  (v)+3);.  sqlite
d8d0: 33 56 64 62 65 41 64 64 4f 70 32 28 76 2c 20 4f  3VdbeAddOp2(v, O
d8e0: 50 5f 47 6f 73 75 62 2c 20 72 65 67 47 6f 73 75  P_Gosub, regGosu
d8f0: 62 2c 20 61 64 64 72 47 6f 73 75 62 29 3b 0a 20  b, addrGosub);. 
d900: 20 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f   sqlite3VdbeAddO
d910: 70 32 28 76 2c 20 4f 50 5f 4e 65 78 74 2c 20 70  p2(v, OP_Next, p
d920: 4d 57 69 6e 2d 3e 69 45 70 68 43 73 72 2c 20 73  MWin->iEphCsr, s
d930: 71 6c 69 74 65 33 56 64 62 65 43 75 72 72 65 6e  qlite3VdbeCurren
d940: 74 41 64 64 72 28 76 29 2d 31 29 3b 0a 7d 0a 0a  tAddr(v)-1);.}..
d950: 57 69 6e 64 6f 77 20 2a 73 71 6c 69 74 65 33 57  Window *sqlite3W
d960: 69 6e 64 6f 77 44 75 70 28 73 71 6c 69 74 65 33  indowDup(sqlite3
d970: 20 2a 64 62 2c 20 45 78 70 72 20 2a 70 4f 77 6e   *db, Expr *pOwn
d980: 65 72 2c 20 57 69 6e 64 6f 77 20 2a 70 29 7b 0a  er, Window *p){.
d990: 20 20 57 69 6e 64 6f 77 20 2a 70 4e 65 77 20 3d    Window *pNew =
d9a0: 20 30 3b 0a 20 20 69 66 28 20 70 20 29 7b 0a 20   0;.  if( p ){. 
d9b0: 20 20 20 70 4e 65 77 20 3d 20 73 71 6c 69 74 65     pNew = sqlite
d9c0: 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64 62  3DbMallocZero(db
d9d0: 2c 20 73 69 7a 65 6f 66 28 57 69 6e 64 6f 77 29  , sizeof(Window)
d9e0: 29 3b 0a 20 20 20 20 69 66 28 20 70 4e 65 77 20  );.    if( pNew 
d9f0: 29 7b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e 70  ){.      pNew->p
da00: 46 69 6c 74 65 72 20 3d 20 73 71 6c 69 74 65 33  Filter = sqlite3
da10: 45 78 70 72 44 75 70 28 64 62 2c 20 70 2d 3e 70  ExprDup(db, p->p
da20: 46 69 6c 74 65 72 2c 20 30 29 3b 0a 20 20 20 20  Filter, 0);.    
da30: 20 20 70 4e 65 77 2d 3e 70 50 61 72 74 69 74 69    pNew->pPartiti
da40: 6f 6e 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  on = sqlite3Expr
da50: 4c 69 73 74 44 75 70 28 64 62 2c 20 70 2d 3e 70  ListDup(db, p->p
da60: 50 61 72 74 69 74 69 6f 6e 2c 20 30 29 3b 0a 20  Partition, 0);. 
da70: 20 20 20 20 20 70 4e 65 77 2d 3e 70 4f 72 64 65       pNew->pOrde
da80: 72 42 79 20 3d 20 73 71 6c 69 74 65 33 45 78 70  rBy = sqlite3Exp
da90: 72 4c 69 73 74 44 75 70 28 64 62 2c 20 70 2d 3e  rListDup(db, p->
daa0: 70 4f 72 64 65 72 42 79 2c 20 30 29 3b 0a 20 20  pOrderBy, 0);.  
dab0: 20 20 20 20 70 4e 65 77 2d 3e 65 54 79 70 65 20      pNew->eType 
dac0: 3d 20 70 2d 3e 65 54 79 70 65 3b 0a 20 20 20 20  = p->eType;.    
dad0: 20 20 70 4e 65 77 2d 3e 65 45 6e 64 20 3d 20 70    pNew->eEnd = p
dae0: 2d 3e 65 45 6e 64 3b 0a 20 20 20 20 20 20 70 4e  ->eEnd;.      pN
daf0: 65 77 2d 3e 65 53 74 61 72 74 20 3d 20 70 2d 3e  ew->eStart = p->
db00: 65 53 74 61 72 74 3b 0a 20 20 20 20 20 20 70 4e  eStart;.      pN
db10: 65 77 2d 3e 70 53 74 61 72 74 20 3d 20 73 71 6c  ew->pStart = sql
db20: 69 74 65 33 45 78 70 72 44 75 70 28 64 62 2c 20  ite3ExprDup(db, 
db30: 70 4e 65 77 2d 3e 70 53 74 61 72 74 2c 20 30 29  pNew->pStart, 0)
db40: 3b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e 70 45  ;.      pNew->pE
db50: 6e 64 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72  nd = sqlite3Expr
db60: 44 75 70 28 64 62 2c 20 70 4e 65 77 2d 3e 70 45  Dup(db, pNew->pE
db70: 6e 64 2c 20 30 29 3b 0a 20 20 20 20 20 20 70 4e  nd, 0);.      pN
db80: 65 77 2d 3e 70 4f 77 6e 65 72 20 3d 20 70 4f 77  ew->pOwner = pOw
db90: 6e 65 72 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  ner;.    }.  }. 
dba0: 20 72 65 74 75 72 6e 20 70 4e 65 77 3b 0a 7d 0a   return pNew;.}.
dbb0: 0a 2f 2a 0a 2a 2a 20 73 71 6c 69 74 65 33 57 68  ./*.** sqlite3Wh
dbc0: 65 72 65 42 65 67 69 6e 28 29 20 68 61 73 20 61  ereBegin() has a
dbd0: 6c 72 65 61 64 79 20 62 65 65 6e 20 63 61 6c 6c  lready been call
dbe0: 65 64 20 66 6f 72 20 74 68 65 20 53 45 4c 45 43  ed for the SELEC
dbf0: 54 20 73 74 61 74 65 6d 65 6e 74 20 0a 2a 2a 20  T statement .** 
dc00: 70 61 73 73 65 64 20 61 73 20 74 68 65 20 73 65  passed as the se
dc10: 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 20 77 68  cond argument wh
dc20: 65 6e 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e  en this function
dc30: 20 69 73 20 69 6e 76 6f 6b 65 64 2e 20 49 74 20   is invoked. It 
dc40: 67 65 6e 65 72 61 74 65 73 0a 2a 2a 20 63 6f 64  generates.** cod
dc50: 65 20 74 6f 20 70 6f 70 75 6c 61 74 65 20 74 68  e to populate th
dc60: 65 20 57 69 6e 64 6f 77 2e 72 65 67 52 65 73 75  e Window.regResu
dc70: 6c 74 20 72 65 67 69 73 74 65 72 20 66 6f 72 20  lt register for 
dc80: 65 61 63 68 20 77 69 6e 64 6f 77 20 66 75 6e 63  each window func
dc90: 74 69 6f 6e 20 61 6e 64 0a 2a 2a 20 69 6e 76 6f  tion and.** invo
dca0: 6b 65 20 74 68 65 20 73 75 62 2d 72 6f 75 74 69  ke the sub-routi
dcb0: 6e 65 20 61 74 20 69 6e 73 74 72 75 63 74 69 6f  ne at instructio
dcc0: 6e 20 61 64 64 72 47 6f 73 75 62 20 6f 6e 63 65  n addrGosub once
dcd0: 20 66 6f 72 20 65 61 63 68 20 72 6f 77 2e 0a 2a   for each row..*
dce0: 2a 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20  * This function 
dcf0: 63 61 6c 6c 73 20 73 71 6c 69 74 65 33 57 68 65  calls sqlite3Whe
dd00: 72 65 45 6e 64 28 29 20 62 65 66 6f 72 65 20 72  reEnd() before r
dd10: 65 74 75 72 6e 69 6e 67 2e 20 0a 2a 2f 0a 76 6f  eturning. .*/.vo
dd20: 69 64 20 73 71 6c 69 74 65 33 57 69 6e 64 6f 77  id sqlite3Window
dd30: 43 6f 64 65 53 74 65 70 28 0a 20 20 50 61 72 73  CodeStep(.  Pars
dd40: 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20 20 20  e *pParse,      
dd50: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 50              /* P
dd60: 61 72 73 65 20 63 6f 6e 74 65 78 74 20 2a 2f 0a  arse context */.
dd70: 20 20 53 65 6c 65 63 74 20 2a 70 2c 20 20 20 20    Select *p,    
dd80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
dd90: 20 20 2f 2a 20 52 65 77 72 69 74 74 65 6e 20 53    /* Rewritten S
dda0: 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 20  ELECT statement 
ddb0: 2a 2f 0a 20 20 57 68 65 72 65 49 6e 66 6f 20 2a  */.  WhereInfo *
ddc0: 70 57 49 6e 66 6f 2c 20 20 20 20 20 20 20 20 20  pWInfo,         
ddd0: 20 20 20 20 20 2f 2a 20 43 6f 6e 74 65 78 74 20       /* Context 
dde0: 72 65 74 75 72 6e 65 64 20 62 79 20 73 71 6c 69  returned by sqli
ddf0: 74 65 33 57 68 65 72 65 42 65 67 69 6e 28 29 20  te3WhereBegin() 
de00: 2a 2f 0a 20 20 69 6e 74 20 72 65 67 47 6f 73 75  */.  int regGosu
de10: 62 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b,              
de20: 20 20 20 20 20 2f 2a 20 52 65 67 69 73 74 65 72       /* Register
de30: 20 66 6f 72 20 4f 50 5f 47 6f 73 75 62 20 2a 2f   for OP_Gosub */
de40: 0a 20 20 69 6e 74 20 61 64 64 72 47 6f 73 75 62  .  int addrGosub
de50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
de60: 20 20 20 2f 2a 20 4f 50 5f 47 6f 73 75 62 20 68     /* OP_Gosub h
de70: 65 72 65 20 74 6f 20 72 65 74 75 72 6e 20 65 61  ere to return ea
de80: 63 68 20 72 6f 77 20 2a 2f 0a 29 7b 0a 20 20 57  ch row */.){.  W
de90: 69 6e 64 6f 77 20 2a 70 4d 57 69 6e 20 3d 20 70  indow *pMWin = p
dea0: 2d 3e 70 57 69 6e 3b 0a 20 20 57 69 6e 64 6f 77  ->pWin;.  Window
deb0: 20 2a 70 57 69 6e 3b 0a 0a 20 20 2f 2a 20 43 61   *pWin;..  /* Ca
dec0: 6c 6c 20 77 69 6e 64 6f 77 43 6f 64 65 52 6f 77  ll windowCodeRow
ded0: 45 78 70 72 53 74 65 70 28 29 20 66 6f 72 20 61  ExprStep() for a
dee0: 6c 6c 20 77 69 6e 64 6f 77 20 6d 6f 64 65 73 20  ll window modes 
def0: 2a 65 78 63 65 70 74 2a 3a 0a 20 20 2a 2a 0a 20  *except*:.  **. 
df00: 20 2a 2a 20 20 20 52 41 4e 47 45 20 42 45 54 57   **   RANGE BETW
df10: 45 45 4e 20 55 4e 42 4f 55 4e 44 45 44 20 50 52  EEN UNBOUNDED PR
df20: 45 43 45 44 49 4e 47 20 41 4e 44 20 43 55 52 52  ECEDING AND CURR
df30: 45 4e 54 20 52 4f 57 0a 20 20 2a 2a 20 20 20 52  ENT ROW.  **   R
df40: 41 4e 47 45 20 42 45 54 57 45 45 4e 20 55 4e 42  ANGE BETWEEN UNB
df50: 4f 55 4e 44 45 44 20 50 52 45 43 45 44 49 4e 47  OUNDED PRECEDING
df60: 20 41 4e 44 20 55 4e 42 4f 55 4e 44 45 44 20 46   AND UNBOUNDED F
df70: 4f 4c 4c 4f 57 49 4e 47 0a 20 20 2a 2a 20 20 20  OLLOWING.  **   
df80: 52 41 4e 47 45 20 42 45 54 57 45 45 4e 20 43 55  RANGE BETWEEN CU
df90: 52 52 45 4e 54 20 52 4f 57 20 41 4e 44 20 43 55  RRENT ROW AND CU
dfa0: 52 52 45 4e 54 20 52 4f 57 0a 20 20 2a 2a 20 20  RRENT ROW.  **  
dfb0: 20 52 4f 57 53 20 20 42 45 54 57 45 45 4e 20 55   ROWS  BETWEEN U
dfc0: 4e 42 4f 55 4e 44 45 44 20 50 52 45 43 45 44 49  NBOUNDED PRECEDI
dfd0: 4e 47 20 41 4e 44 20 43 55 52 52 45 4e 54 20 52  NG AND CURRENT R
dfe0: 4f 57 0a 20 20 2a 2f 0a 20 20 69 66 28 20 28 70  OW.  */.  if( (p
dff0: 4d 57 69 6e 2d 3e 65 54 79 70 65 3d 3d 54 4b 5f  MWin->eType==TK_
e000: 52 4f 57 53 20 0a 20 20 20 26 26 20 28 70 4d 57  ROWS .   && (pMW
e010: 69 6e 2d 3e 65 53 74 61 72 74 21 3d 54 4b 5f 55  in->eStart!=TK_U
e020: 4e 42 4f 55 4e 44 45 44 7c 7c 70 4d 57 69 6e 2d  NBOUNDED||pMWin-
e030: 3e 65 45 6e 64 21 3d 54 4b 5f 43 55 52 52 45 4e  >eEnd!=TK_CURREN
e040: 54 7c 7c 21 70 4d 57 69 6e 2d 3e 70 4f 72 64 65  T||!pMWin->pOrde
e050: 72 42 79 29 29 0a 20 20 20 7c 7c 20 28 70 4d 57  rBy)).   || (pMW
e060: 69 6e 2d 3e 65 53 74 61 72 74 3d 3d 54 4b 5f 43  in->eStart==TK_C
e070: 55 52 52 45 4e 54 26 26 70 4d 57 69 6e 2d 3e 65  URRENT&&pMWin->e
e080: 45 6e 64 3d 3d 54 4b 5f 55 4e 42 4f 55 4e 44 45  End==TK_UNBOUNDE
e090: 44 26 26 70 4d 57 69 6e 2d 3e 70 4f 72 64 65 72  D&&pMWin->pOrder
e0a0: 42 79 29 0a 20 20 29 7b 0a 20 20 20 20 77 69 6e  By).  ){.    win
e0b0: 64 6f 77 43 6f 64 65 52 6f 77 45 78 70 72 53 74  dowCodeRowExprSt
e0c0: 65 70 28 70 50 61 72 73 65 2c 20 70 2c 20 70 57  ep(pParse, p, pW
e0d0: 49 6e 66 6f 2c 20 72 65 67 47 6f 73 75 62 2c 20  Info, regGosub, 
e0e0: 61 64 64 72 47 6f 73 75 62 29 3b 0a 20 20 20 20  addrGosub);.    
e0f0: 72 65 74 75 72 6e 3b 0a 20 20 7d 0a 0a 20 20 2f  return;.  }..  /
e100: 2a 20 43 61 6c 6c 20 77 69 6e 64 6f 77 43 6f 64  * Call windowCod
e110: 65 43 61 63 68 65 53 74 65 70 28 29 20 69 66 20  eCacheStep() if 
e120: 74 68 65 72 65 20 69 73 20 61 20 77 69 6e 64 6f  there is a windo
e130: 77 20 66 75 6e 63 74 69 6f 6e 20 74 68 61 74 20  w function that 
e140: 72 65 71 75 69 72 65 73 0a 20 20 2a 2a 20 74 68  requires.  ** th
e150: 61 74 20 74 68 65 20 65 6e 74 69 72 65 20 70 61  at the entire pa
e160: 72 74 69 74 69 6f 6e 20 62 65 20 63 61 63 68 65  rtition be cache
e170: 64 20 69 6e 20 61 20 74 65 6d 70 20 74 61 62 6c  d in a temp tabl
e180: 65 20 62 65 66 6f 72 65 20 61 6e 79 20 72 6f 77  e before any row
e190: 73 0a 20 20 2a 2a 20 61 72 65 20 72 65 74 75 72  s.  ** are retur
e1a0: 6e 65 64 2e 20 20 2a 2f 0a 20 20 66 6f 72 28 70  ned.  */.  for(p
e1b0: 57 69 6e 3d 70 4d 57 69 6e 3b 20 70 57 69 6e 3b  Win=pMWin; pWin;
e1c0: 20 70 57 69 6e 3d 70 57 69 6e 2d 3e 70 4e 65 78   pWin=pWin->pNex
e1d0: 74 57 69 6e 29 7b 0a 20 20 20 20 46 75 6e 63 44  tWin){.    FuncD
e1e0: 65 66 20 2a 70 46 75 6e 63 20 3d 20 70 57 69 6e  ef *pFunc = pWin
e1f0: 2d 3e 70 46 75 6e 63 3b 0a 20 20 20 20 69 66 28  ->pFunc;.    if(
e200: 20 28 70 46 75 6e 63 2d 3e 66 75 6e 63 46 6c 61   (pFunc->funcFla
e210: 67 73 20 26 20 53 51 4c 49 54 45 5f 46 55 4e 43  gs & SQLITE_FUNC
e220: 5f 57 49 4e 44 4f 57 5f 53 49 5a 45 29 0a 20 20  _WINDOW_SIZE).  
e230: 20 20 20 7c 7c 20 28 70 46 75 6e 63 2d 3e 78 53     || (pFunc->xS
e240: 46 75 6e 63 3d 3d 6e 74 68 5f 76 61 6c 75 65 53  Func==nth_valueS
e250: 74 65 70 46 75 6e 63 29 0a 20 20 20 20 20 7c 7c  tepFunc).     ||
e260: 20 28 70 46 75 6e 63 2d 3e 78 53 46 75 6e 63 3d   (pFunc->xSFunc=
e270: 3d 66 69 72 73 74 5f 76 61 6c 75 65 53 74 65 70  =first_valueStep
e280: 46 75 6e 63 29 0a 20 20 20 20 20 7c 7c 20 28 70  Func).     || (p
e290: 46 75 6e 63 2d 3e 78 53 46 75 6e 63 3d 3d 6c 65  Func->xSFunc==le
e2a0: 61 64 53 74 65 70 46 75 6e 63 29 0a 20 20 20 20  adStepFunc).    
e2b0: 20 7c 7c 20 28 70 46 75 6e 63 2d 3e 78 53 46 75   || (pFunc->xSFu
e2c0: 6e 63 3d 3d 6c 61 67 53 74 65 70 46 75 6e 63 29  nc==lagStepFunc)
e2d0: 0a 20 20 20 20 29 7b 0a 20 20 20 20 20 20 77 69  .    ){.      wi
e2e0: 6e 64 6f 77 43 6f 64 65 43 61 63 68 65 53 74 65  ndowCodeCacheSte
e2f0: 70 28 70 50 61 72 73 65 2c 20 70 2c 20 70 57 49  p(pParse, p, pWI
e300: 6e 66 6f 2c 20 72 65 67 47 6f 73 75 62 2c 20 61  nfo, regGosub, a
e310: 64 64 72 47 6f 73 75 62 29 3b 0a 20 20 20 20 20  ddrGosub);.     
e320: 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 7d 0a 20   return;.    }. 
e330: 20 7d 0a 0a 20 20 2f 2a 20 4f 74 68 65 72 77 69   }..  /* Otherwi
e340: 73 65 2c 20 63 61 6c 6c 20 77 69 6e 64 6f 77 43  se, call windowC
e350: 6f 64 65 44 65 66 61 75 6c 74 53 74 65 70 28 29  odeDefaultStep()
e360: 2e 20 20 2a 2f 0a 20 20 77 69 6e 64 6f 77 43 6f  .  */.  windowCo
e370: 64 65 44 65 66 61 75 6c 74 53 74 65 70 28 70 50  deDefaultStep(pP
e380: 61 72 73 65 2c 20 70 2c 20 70 57 49 6e 66 6f 2c  arse, p, pWInfo,
e390: 20 72 65 67 47 6f 73 75 62 2c 20 61 64 64 72 47   regGosub, addrG
e3a0: 6f 73 75 62 29 3b 0a 7d 0a 0a                    osub);.}..