/ Hex Artifact Content
Login

Artifact cae81f6c65c4977bc2cbd27d43bfee478710853c:


0000: 2f 2a 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74  /*.**.** The aut
0010: 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f  hor disclaims co
0020: 70 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20  pyright to this 
0030: 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e  source code.  In
0040: 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c   place of.** a l
0050: 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72  egal notice, her
0060: 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a  e is a blessing:
0070: 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f  .**.**    May yo
0080: 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f  u do good and no
0090: 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61  t evil..**    Ma
00a0: 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69  y you find forgi
00b0: 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73  veness for yours
00c0: 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20  elf and forgive 
00d0: 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61  others..**    Ma
00e0: 79 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65  y you share free
00f0: 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67  ly, never taking
0100: 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67   more than you g
0110: 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a  ive..**.********
0120: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
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 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63  *.** This file c
0170: 6f 6e 74 61 69 6e 73 20 74 68 65 20 69 6d 70 6c  ontains the impl
0180: 65 6d 65 6e 74 61 74 69 6f 6e 20 66 6f 72 20 54  ementation for T
0190: 52 49 47 47 45 52 73 0a 2a 2f 0a 23 69 6e 63 6c  RIGGERs.*/.#incl
01a0: 75 64 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68  ude "sqliteInt.h
01b0: 22 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  "..#ifndef SQLIT
01c0: 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 0a 2f  E_OMIT_TRIGGER./
01d0: 2a 0a 2a 2a 20 44 65 6c 65 74 65 20 61 20 6c 69  *.** Delete a li
01e0: 6e 6b 65 64 20 6c 69 73 74 20 6f 66 20 54 72 69  nked list of Tri
01f0: 67 67 65 72 53 74 65 70 20 73 74 72 75 63 74 75  ggerStep structu
0200: 72 65 73 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  res..*/.void sql
0210: 69 74 65 33 44 65 6c 65 74 65 54 72 69 67 67 65  ite3DeleteTrigge
0220: 72 53 74 65 70 28 73 71 6c 69 74 65 33 20 2a 64  rStep(sqlite3 *d
0230: 62 2c 20 54 72 69 67 67 65 72 53 74 65 70 20 2a  b, TriggerStep *
0240: 70 54 72 69 67 67 65 72 53 74 65 70 29 7b 0a 20  pTriggerStep){. 
0250: 20 77 68 69 6c 65 28 20 70 54 72 69 67 67 65 72   while( pTrigger
0260: 53 74 65 70 20 29 7b 0a 20 20 20 20 54 72 69 67  Step ){.    Trig
0270: 67 65 72 53 74 65 70 20 2a 20 70 54 6d 70 20 3d  gerStep * pTmp =
0280: 20 70 54 72 69 67 67 65 72 53 74 65 70 3b 0a 20   pTriggerStep;. 
0290: 20 20 20 70 54 72 69 67 67 65 72 53 74 65 70 20     pTriggerStep 
02a0: 3d 20 70 54 72 69 67 67 65 72 53 74 65 70 2d 3e  = pTriggerStep->
02b0: 70 4e 65 78 74 3b 0a 0a 20 20 20 20 73 71 6c 69  pNext;..    sqli
02c0: 74 65 33 45 78 70 72 44 65 6c 65 74 65 28 64 62  te3ExprDelete(db
02d0: 2c 20 70 54 6d 70 2d 3e 70 57 68 65 72 65 29 3b  , pTmp->pWhere);
02e0: 0a 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72  .    sqlite3Expr
02f0: 4c 69 73 74 44 65 6c 65 74 65 28 64 62 2c 20 70  ListDelete(db, p
0300: 54 6d 70 2d 3e 70 45 78 70 72 4c 69 73 74 29 3b  Tmp->pExprList);
0310: 0a 20 20 20 20 73 71 6c 69 74 65 33 53 65 6c 65  .    sqlite3Sele
0320: 63 74 44 65 6c 65 74 65 28 64 62 2c 20 70 54 6d  ctDelete(db, pTm
0330: 70 2d 3e 70 53 65 6c 65 63 74 29 3b 0a 20 20 20  p->pSelect);.   
0340: 20 73 71 6c 69 74 65 33 49 64 4c 69 73 74 44 65   sqlite3IdListDe
0350: 6c 65 74 65 28 64 62 2c 20 70 54 6d 70 2d 3e 70  lete(db, pTmp->p
0360: 49 64 4c 69 73 74 29 3b 0a 0a 20 20 20 20 73 71  IdList);..    sq
0370: 6c 69 74 65 33 44 62 46 72 65 65 28 64 62 2c 20  lite3DbFree(db, 
0380: 70 54 6d 70 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a  pTmp);.  }.}../*
0390: 0a 2a 2a 20 47 69 76 65 6e 20 74 61 62 6c 65 20  .** Given table 
03a0: 70 54 61 62 2c 20 72 65 74 75 72 6e 20 61 20 6c  pTab, return a l
03b0: 69 73 74 20 6f 66 20 61 6c 6c 20 74 68 65 20 74  ist of all the t
03c0: 72 69 67 67 65 72 73 20 61 74 74 61 63 68 65 64  riggers attached
03d0: 20 74 6f 20 0a 2a 2a 20 74 68 65 20 74 61 62 6c   to .** the tabl
03e0: 65 2e 20 54 68 65 20 6c 69 73 74 20 69 73 20 63  e. The list is c
03f0: 6f 6e 6e 65 63 74 65 64 20 62 79 20 54 72 69 67  onnected by Trig
0400: 67 65 72 2e 70 4e 65 78 74 20 70 6f 69 6e 74 65  ger.pNext pointe
0410: 72 73 2e 0a 2a 2a 0a 2a 2a 20 41 6c 6c 20 6f 66  rs..**.** All of
0420: 20 74 68 65 20 74 72 69 67 67 65 72 73 20 6f 6e   the triggers on
0430: 20 70 54 61 62 20 74 68 61 74 20 61 72 65 20 69   pTab that are i
0440: 6e 20 74 68 65 20 73 61 6d 65 20 64 61 74 61 62  n the same datab
0450: 61 73 65 20 61 73 20 70 54 61 62 0a 2a 2a 20 61  ase as pTab.** a
0460: 72 65 20 61 6c 72 65 61 64 79 20 61 74 74 61 63  re already attac
0470: 68 65 64 20 74 6f 20 70 54 61 62 2d 3e 70 54 72  hed to pTab->pTr
0480: 69 67 67 65 72 2e 20 20 42 75 74 20 74 68 65 72  igger.  But ther
0490: 65 20 6d 69 67 68 74 20 62 65 20 61 64 64 69 74  e might be addit
04a0: 69 6f 6e 61 6c 0a 2a 2a 20 74 72 69 67 67 65 72  ional.** trigger
04b0: 73 20 6f 6e 20 70 54 61 62 20 69 6e 20 74 68 65  s on pTab in the
04c0: 20 54 45 4d 50 20 73 63 68 65 6d 61 2e 20 20 54   TEMP schema.  T
04d0: 68 69 73 20 72 6f 75 74 69 6e 65 20 70 72 65 70  his routine prep
04e0: 65 6e 64 73 20 61 6c 6c 0a 2a 2a 20 54 45 4d 50  ends all.** TEMP
04f0: 20 74 72 69 67 67 65 72 73 20 6f 6e 20 70 54 61   triggers on pTa
0500: 62 20 74 6f 20 74 68 65 20 62 65 67 69 6e 6e 69  b to the beginni
0510: 6e 67 20 6f 66 20 74 68 65 20 70 54 61 62 2d 3e  ng of the pTab->
0520: 70 54 72 69 67 67 65 72 20 6c 69 73 74 0a 2a 2a  pTrigger list.**
0530: 20 61 6e 64 20 72 65 74 75 72 6e 73 20 74 68 65   and returns the
0540: 20 63 6f 6d 62 69 6e 65 64 20 6c 69 73 74 2e 0a   combined list..
0550: 2a 2a 0a 2a 2a 20 54 6f 20 73 74 61 74 65 20 69  **.** To state i
0560: 74 20 61 6e 6f 74 68 65 72 20 77 61 79 3a 20 20  t another way:  
0570: 54 68 69 73 20 72 6f 75 74 69 6e 65 20 72 65 74  This routine ret
0580: 75 72 6e 73 20 61 20 6c 69 73 74 20 6f 66 20 61  urns a list of a
0590: 6c 6c 20 74 72 69 67 67 65 72 73 0a 2a 2a 20 74  ll triggers.** t
05a0: 68 61 74 20 66 69 72 65 20 6f 66 66 20 6f 66 20  hat fire off of 
05b0: 70 54 61 62 2e 20 20 54 68 65 20 6c 69 73 74 20  pTab.  The list 
05c0: 77 69 6c 6c 20 69 6e 63 6c 75 64 65 20 61 6e 79  will include any
05d0: 20 54 45 4d 50 20 74 72 69 67 67 65 72 73 20 6f   TEMP triggers o
05e0: 6e 0a 2a 2a 20 70 54 61 62 20 61 73 20 77 65 6c  n.** pTab as wel
05f0: 6c 20 61 73 20 74 68 65 20 74 72 69 67 67 65 72  l as the trigger
0600: 73 20 6c 69 73 65 64 20 69 6e 20 70 54 61 62 2d  s lised in pTab-
0610: 3e 70 54 72 69 67 67 65 72 2e 0a 2a 2f 0a 54 72  >pTrigger..*/.Tr
0620: 69 67 67 65 72 20 2a 73 71 6c 69 74 65 33 54 72  igger *sqlite3Tr
0630: 69 67 67 65 72 4c 69 73 74 28 50 61 72 73 65 20  iggerList(Parse 
0640: 2a 70 50 61 72 73 65 2c 20 54 61 62 6c 65 20 2a  *pParse, Table *
0650: 70 54 61 62 29 7b 0a 20 20 53 63 68 65 6d 61 20  pTab){.  Schema 
0660: 2a 20 63 6f 6e 73 74 20 70 54 6d 70 53 63 68 65  * const pTmpSche
0670: 6d 61 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 2d  ma = pParse->db-
0680: 3e 61 44 62 5b 31 5d 2e 70 53 63 68 65 6d 61 3b  >aDb[1].pSchema;
0690: 0a 20 20 54 72 69 67 67 65 72 20 2a 70 4c 69 73  .  Trigger *pLis
06a0: 74 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  t = 0;          
06b0: 20 20 20 20 20 20 20 20 2f 2a 20 4c 69 73 74 20          /* List 
06c0: 6f 66 20 74 72 69 67 67 65 72 73 20 74 6f 20 72  of triggers to r
06d0: 65 74 75 72 6e 20 2a 2f 0a 0a 20 20 69 66 28 20  eturn */..  if( 
06e0: 70 50 61 72 73 65 2d 3e 64 69 73 61 62 6c 65 54  pParse->disableT
06f0: 72 69 67 67 65 72 73 20 29 7b 0a 20 20 20 20 72  riggers ){.    r
0700: 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 0a 20 20  eturn 0;.  }..  
0710: 69 66 28 20 70 54 6d 70 53 63 68 65 6d 61 21 3d  if( pTmpSchema!=
0720: 70 54 61 62 2d 3e 70 53 63 68 65 6d 61 20 29 7b  pTab->pSchema ){
0730: 0a 20 20 20 20 48 61 73 68 45 6c 65 6d 20 2a 70  .    HashElem *p
0740: 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 73 71  ;.    assert( sq
0750: 6c 69 74 65 33 53 63 68 65 6d 61 4d 75 74 65 78  lite3SchemaMutex
0760: 48 65 6c 64 28 70 50 61 72 73 65 2d 3e 64 62 2c  Held(pParse->db,
0770: 20 30 2c 20 70 54 6d 70 53 63 68 65 6d 61 29 20   0, pTmpSchema) 
0780: 29 3b 0a 20 20 20 20 66 6f 72 28 70 3d 73 71 6c  );.    for(p=sql
0790: 69 74 65 48 61 73 68 46 69 72 73 74 28 26 70 54  iteHashFirst(&pT
07a0: 6d 70 53 63 68 65 6d 61 2d 3e 74 72 69 67 48 61  mpSchema->trigHa
07b0: 73 68 29 3b 20 70 3b 20 70 3d 73 71 6c 69 74 65  sh); p; p=sqlite
07c0: 48 61 73 68 4e 65 78 74 28 70 29 29 7b 0a 20 20  HashNext(p)){.  
07d0: 20 20 20 20 54 72 69 67 67 65 72 20 2a 70 54 72      Trigger *pTr
07e0: 69 67 20 3d 20 28 54 72 69 67 67 65 72 20 2a 29  ig = (Trigger *)
07f0: 73 71 6c 69 74 65 48 61 73 68 44 61 74 61 28 70  sqliteHashData(p
0800: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 70 54 72  );.      if( pTr
0810: 69 67 2d 3e 70 54 61 62 53 63 68 65 6d 61 3d 3d  ig->pTabSchema==
0820: 70 54 61 62 2d 3e 70 53 63 68 65 6d 61 0a 20 20  pTab->pSchema.  
0830: 20 20 20 20 20 26 26 20 30 3d 3d 73 71 6c 69 74       && 0==sqlit
0840: 65 33 53 74 72 49 43 6d 70 28 70 54 72 69 67 2d  e3StrICmp(pTrig-
0850: 3e 74 61 62 6c 65 2c 20 70 54 61 62 2d 3e 7a 4e  >table, pTab->zN
0860: 61 6d 65 29 20 0a 20 20 20 20 20 20 29 7b 0a 20  ame) .      ){. 
0870: 20 20 20 20 20 20 20 70 54 72 69 67 2d 3e 70 4e         pTrig->pN
0880: 65 78 74 20 3d 20 28 70 4c 69 73 74 20 3f 20 70  ext = (pList ? p
0890: 4c 69 73 74 20 3a 20 70 54 61 62 2d 3e 70 54 72  List : pTab->pTr
08a0: 69 67 67 65 72 29 3b 0a 20 20 20 20 20 20 20 20  igger);.        
08b0: 70 4c 69 73 74 20 3d 20 70 54 72 69 67 3b 0a 20  pList = pTrig;. 
08c0: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d       }.    }.  }
08d0: 0a 0a 20 20 72 65 74 75 72 6e 20 28 70 4c 69 73  ..  return (pLis
08e0: 74 20 3f 20 70 4c 69 73 74 20 3a 20 70 54 61 62  t ? pList : pTab
08f0: 2d 3e 70 54 72 69 67 67 65 72 29 3b 0a 7d 0a 0a  ->pTrigger);.}..
0900: 2f 2a 0a 2a 2a 20 54 68 69 73 20 69 73 20 63 61  /*.** This is ca
0910: 6c 6c 65 64 20 62 79 20 74 68 65 20 70 61 72 73  lled by the pars
0920: 65 72 20 77 68 65 6e 20 69 74 20 73 65 65 73 20  er when it sees 
0930: 61 20 43 52 45 41 54 45 20 54 52 49 47 47 45 52  a CREATE TRIGGER
0940: 20 73 74 61 74 65 6d 65 6e 74 0a 2a 2a 20 75 70   statement.** up
0950: 20 74 6f 20 74 68 65 20 70 6f 69 6e 74 20 6f 66   to the point of
0960: 20 74 68 65 20 42 45 47 49 4e 20 62 65 66 6f 72   the BEGIN befor
0970: 65 20 74 68 65 20 74 72 69 67 67 65 72 20 61 63  e the trigger ac
0980: 74 69 6f 6e 73 2e 20 20 41 20 54 72 69 67 67 65  tions.  A Trigge
0990: 72 0a 2a 2a 20 73 74 72 75 63 74 75 72 65 20 69  r.** structure i
09a0: 73 20 67 65 6e 65 72 61 74 65 64 20 62 61 73 65  s generated base
09b0: 64 20 6f 6e 20 74 68 65 20 69 6e 66 6f 72 6d 61  d on the informa
09c0: 74 69 6f 6e 20 61 76 61 69 6c 61 62 6c 65 20 61  tion available a
09d0: 6e 64 20 73 74 6f 72 65 64 0a 2a 2a 20 69 6e 20  nd stored.** in 
09e0: 70 50 61 72 73 65 2d 3e 70 4e 65 77 54 72 69 67  pParse->pNewTrig
09f0: 67 65 72 2e 20 20 41 66 74 65 72 20 74 68 65 20  ger.  After the 
0a00: 74 72 69 67 67 65 72 20 61 63 74 69 6f 6e 73 20  trigger actions 
0a10: 68 61 76 65 20 62 65 65 6e 20 70 61 72 73 65 64  have been parsed
0a20: 2c 20 74 68 65 0a 2a 2a 20 73 71 6c 69 74 65 33  , the.** sqlite3
0a30: 46 69 6e 69 73 68 54 72 69 67 67 65 72 28 29 20  FinishTrigger() 
0a40: 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61 6c 6c  function is call
0a50: 65 64 20 74 6f 20 63 6f 6d 70 6c 65 74 65 20 74  ed to complete t
0a60: 68 65 20 74 72 69 67 67 65 72 0a 2a 2a 20 63 6f  he trigger.** co
0a70: 6e 73 74 72 75 63 74 69 6f 6e 20 70 72 6f 63 65  nstruction proce
0a80: 73 73 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69  ss..*/.void sqli
0a90: 74 65 33 42 65 67 69 6e 54 72 69 67 67 65 72 28  te3BeginTrigger(
0aa0: 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65  .  Parse *pParse
0ab0: 2c 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61  ,      /* The pa
0ac0: 72 73 65 20 63 6f 6e 74 65 78 74 20 6f 66 20 74  rse context of t
0ad0: 68 65 20 43 52 45 41 54 45 20 54 52 49 47 47 45  he CREATE TRIGGE
0ae0: 52 20 73 74 61 74 65 6d 65 6e 74 20 2a 2f 0a 20  R statement */. 
0af0: 20 54 6f 6b 65 6e 20 2a 70 4e 61 6d 65 31 2c 20   Token *pName1, 
0b00: 20 20 20 20 20 2f 2a 20 54 68 65 20 6e 61 6d 65       /* The name
0b10: 20 6f 66 20 74 68 65 20 74 72 69 67 67 65 72 20   of the trigger 
0b20: 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70 4e 61 6d  */.  Token *pNam
0b30: 65 32 2c 20 20 20 20 20 20 2f 2a 20 54 68 65 20  e2,      /* The 
0b40: 6e 61 6d 65 20 6f 66 20 74 68 65 20 74 72 69 67  name of the trig
0b50: 67 65 72 20 2a 2f 0a 20 20 69 6e 74 20 74 72 5f  ger */.  int tr_
0b60: 74 6d 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20  tm,          /* 
0b70: 4f 6e 65 20 6f 66 20 54 4b 5f 42 45 46 4f 52 45  One of TK_BEFORE
0b80: 2c 20 54 4b 5f 41 46 54 45 52 2c 20 54 4b 5f 49  , TK_AFTER, TK_I
0b90: 4e 53 54 45 41 44 20 2a 2f 0a 20 20 69 6e 74 20  NSTEAD */.  int 
0ba0: 6f 70 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  op,             
0bb0: 2f 2a 20 4f 6e 65 20 6f 66 20 54 4b 5f 49 4e 53  /* One of TK_INS
0bc0: 45 52 54 2c 20 54 4b 5f 55 50 44 41 54 45 2c 20  ERT, TK_UPDATE, 
0bd0: 54 4b 5f 44 45 4c 45 54 45 20 2a 2f 0a 20 20 49  TK_DELETE */.  I
0be0: 64 4c 69 73 74 20 2a 70 43 6f 6c 75 6d 6e 73 2c  dList *pColumns,
0bf0: 20 20 20 2f 2a 20 63 6f 6c 75 6d 6e 20 6c 69 73     /* column lis
0c00: 74 20 69 66 20 74 68 69 73 20 69 73 20 61 6e 20  t if this is an 
0c10: 55 50 44 41 54 45 20 4f 46 20 74 72 69 67 67 65  UPDATE OF trigge
0c20: 72 20 2a 2f 0a 20 20 53 72 63 4c 69 73 74 20 2a  r */.  SrcList *
0c30: 70 54 61 62 6c 65 4e 61 6d 65 2c 2f 2a 20 54 68  pTableName,/* Th
0c40: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 74 61  e name of the ta
0c50: 62 6c 65 2f 76 69 65 77 20 74 68 65 20 74 72 69  ble/view the tri
0c60: 67 67 65 72 20 61 70 70 6c 69 65 73 20 74 6f 20  gger applies to 
0c70: 2a 2f 0a 20 20 45 78 70 72 20 2a 70 57 68 65 6e  */.  Expr *pWhen
0c80: 2c 20 20 20 20 20 20 20 20 2f 2a 20 57 48 45 4e  ,        /* WHEN
0c90: 20 63 6c 61 75 73 65 20 2a 2f 0a 20 20 69 6e 74   clause */.  int
0ca0: 20 69 73 54 65 6d 70 2c 20 20 20 20 20 20 20 20   isTemp,        
0cb0: 20 2f 2a 20 54 72 75 65 20 69 66 20 74 68 65 20   /* True if the 
0cc0: 54 45 4d 50 4f 52 41 52 59 20 6b 65 79 77 6f 72  TEMPORARY keywor
0cd0: 64 20 69 73 20 70 72 65 73 65 6e 74 20 2a 2f 0a  d is present */.
0ce0: 20 20 69 6e 74 20 6e 6f 45 72 72 20 20 20 20 20    int noErr     
0cf0: 20 20 20 20 20 20 2f 2a 20 53 75 70 70 72 65 73        /* Suppres
0d00: 73 20 65 72 72 6f 72 73 20 69 66 20 74 68 65 20  s errors if the 
0d10: 74 72 69 67 67 65 72 20 61 6c 72 65 61 64 79 20  trigger already 
0d20: 65 78 69 73 74 73 20 2a 2f 0a 29 7b 0a 20 20 54  exists */.){.  T
0d30: 72 69 67 67 65 72 20 2a 70 54 72 69 67 67 65 72  rigger *pTrigger
0d40: 20 3d 20 30 3b 20 20 2f 2a 20 54 68 65 20 6e 65   = 0;  /* The ne
0d50: 77 20 74 72 69 67 67 65 72 20 2a 2f 0a 20 20 54  w trigger */.  T
0d60: 61 62 6c 65 20 2a 70 54 61 62 3b 20 20 20 20 20  able *pTab;     
0d70: 20 20 20 20 20 20 20 2f 2a 20 54 61 62 6c 65 20         /* Table 
0d80: 74 68 61 74 20 74 68 65 20 74 72 69 67 67 65 72  that the trigger
0d90: 20 66 69 72 65 73 20 6f 66 66 20 6f 66 20 2a 2f   fires off of */
0da0: 0a 20 20 63 68 61 72 20 2a 7a 4e 61 6d 65 20 3d  .  char *zName =
0db0: 20 30 3b 20 20 20 20 20 20 20 20 2f 2a 20 4e 61   0;        /* Na
0dc0: 6d 65 20 6f 66 20 74 68 65 20 74 72 69 67 67 65  me of the trigge
0dd0: 72 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 20 2a  r */.  sqlite3 *
0de0: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
0df0: 20 20 2f 2a 20 54 68 65 20 64 61 74 61 62 61 73    /* The databas
0e00: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a  e connection */.
0e10: 20 20 69 6e 74 20 69 44 62 3b 20 20 20 20 20 20    int iDb;      
0e20: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65            /* The
0e30: 20 64 61 74 61 62 61 73 65 20 74 6f 20 73 74 6f   database to sto
0e40: 72 65 20 74 68 65 20 74 72 69 67 67 65 72 20 69  re the trigger i
0e50: 6e 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70 4e  n */.  Token *pN
0e60: 61 6d 65 3b 20 20 20 20 20 20 20 20 20 20 20 2f  ame;           /
0e70: 2a 20 54 68 65 20 75 6e 71 75 61 6c 69 66 69 65  * The unqualifie
0e80: 64 20 64 62 20 6e 61 6d 65 20 2a 2f 0a 20 20 44  d db name */.  D
0e90: 62 46 69 78 65 72 20 73 46 69 78 3b 20 20 20 20  bFixer sFix;    
0ea0: 20 20 20 20 20 20 20 2f 2a 20 53 74 61 74 65 20         /* State 
0eb0: 76 65 63 74 6f 72 20 66 6f 72 20 74 68 65 20 44  vector for the D
0ec0: 42 20 66 69 78 65 72 20 2a 2f 0a 0a 20 20 61 73  B fixer */..  as
0ed0: 73 65 72 74 28 20 70 4e 61 6d 65 31 21 3d 30 20  sert( pName1!=0 
0ee0: 29 3b 20 20 20 2f 2a 20 70 4e 61 6d 65 31 2d 3e  );   /* pName1->
0ef0: 7a 20 6d 69 67 68 74 20 62 65 20 4e 55 4c 4c 2c  z might be NULL,
0f00: 20 62 75 74 20 6e 6f 74 20 70 4e 61 6d 65 31 20   but not pName1 
0f10: 69 74 73 65 6c 66 20 2a 2f 0a 20 20 61 73 73 65  itself */.  asse
0f20: 72 74 28 20 70 4e 61 6d 65 32 21 3d 30 20 29 3b  rt( pName2!=0 );
0f30: 0a 20 20 61 73 73 65 72 74 28 20 6f 70 3d 3d 54  .  assert( op==T
0f40: 4b 5f 49 4e 53 45 52 54 20 7c 7c 20 6f 70 3d 3d  K_INSERT || op==
0f50: 54 4b 5f 55 50 44 41 54 45 20 7c 7c 20 6f 70 3d  TK_UPDATE || op=
0f60: 3d 54 4b 5f 44 45 4c 45 54 45 20 29 3b 0a 20 20  =TK_DELETE );.  
0f70: 61 73 73 65 72 74 28 20 6f 70 3e 30 20 26 26 20  assert( op>0 && 
0f80: 6f 70 3c 30 78 66 66 20 29 3b 0a 20 20 69 66 28  op<0xff );.  if(
0f90: 20 69 73 54 65 6d 70 20 29 7b 0a 20 20 20 20 2f   isTemp ){.    /
0fa0: 2a 20 49 66 20 54 45 4d 50 20 77 61 73 20 73 70  * If TEMP was sp
0fb0: 65 63 69 66 69 65 64 2c 20 74 68 65 6e 20 74 68  ecified, then th
0fc0: 65 20 74 72 69 67 67 65 72 20 6e 61 6d 65 20 6d  e trigger name m
0fd0: 61 79 20 6e 6f 74 20 62 65 20 71 75 61 6c 69 66  ay not be qualif
0fe0: 69 65 64 2e 20 2a 2f 0a 20 20 20 20 69 66 28 20  ied. */.    if( 
0ff0: 70 4e 61 6d 65 32 2d 3e 6e 3e 30 20 29 7b 0a 20  pName2->n>0 ){. 
1000: 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f       sqlite3Erro
1010: 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 74 65  rMsg(pParse, "te
1020: 6d 70 6f 72 61 72 79 20 74 72 69 67 67 65 72 20  mporary trigger 
1030: 6d 61 79 20 6e 6f 74 20 68 61 76 65 20 71 75 61  may not have qua
1040: 6c 69 66 69 65 64 20 6e 61 6d 65 22 29 3b 0a 20  lified name");. 
1050: 20 20 20 20 20 67 6f 74 6f 20 74 72 69 67 67 65       goto trigge
1060: 72 5f 63 6c 65 61 6e 75 70 3b 0a 20 20 20 20 7d  r_cleanup;.    }
1070: 0a 20 20 20 20 69 44 62 20 3d 20 31 3b 0a 20 20  .    iDb = 1;.  
1080: 20 20 70 4e 61 6d 65 20 3d 20 70 4e 61 6d 65 31    pName = pName1
1090: 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 2f  ;.  }else{.    /
10a0: 2a 20 46 69 67 75 72 65 20 6f 75 74 20 74 68 65  * Figure out the
10b0: 20 64 62 20 74 68 61 74 20 74 68 65 20 74 72 69   db that the tri
10c0: 67 67 65 72 20 77 69 6c 6c 20 62 65 20 63 72 65  gger will be cre
10d0: 61 74 65 64 20 69 6e 20 2a 2f 0a 20 20 20 20 69  ated in */.    i
10e0: 44 62 20 3d 20 73 71 6c 69 74 65 33 54 77 6f 50  Db = sqlite3TwoP
10f0: 61 72 74 4e 61 6d 65 28 70 50 61 72 73 65 2c 20  artName(pParse, 
1100: 70 4e 61 6d 65 31 2c 20 70 4e 61 6d 65 32 2c 20  pName1, pName2, 
1110: 26 70 4e 61 6d 65 29 3b 0a 20 20 20 20 69 66 28  &pName);.    if(
1120: 20 69 44 62 3c 30 20 29 7b 0a 20 20 20 20 20 20   iDb<0 ){.      
1130: 67 6f 74 6f 20 74 72 69 67 67 65 72 5f 63 6c 65  goto trigger_cle
1140: 61 6e 75 70 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  anup;.    }.  }.
1150: 20 20 69 66 28 20 21 70 54 61 62 6c 65 4e 61 6d    if( !pTableNam
1160: 65 20 7c 7c 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46  e || db->mallocF
1170: 61 69 6c 65 64 20 29 7b 0a 20 20 20 20 67 6f 74  ailed ){.    got
1180: 6f 20 74 72 69 67 67 65 72 5f 63 6c 65 61 6e 75  o trigger_cleanu
1190: 70 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 41 20 6c  p;.  }..  /* A l
11a0: 6f 6e 67 2d 73 74 61 6e 64 69 6e 67 20 70 61 72  ong-standing par
11b0: 73 65 72 20 62 75 67 20 69 73 20 74 68 61 74 20  ser bug is that 
11c0: 74 68 69 73 20 73 79 6e 74 61 78 20 77 61 73 20  this syntax was 
11d0: 61 6c 6c 6f 77 65 64 3a 0a 20 20 2a 2a 0a 20 20  allowed:.  **.  
11e0: 2a 2a 20 20 20 20 43 52 45 41 54 45 20 54 52 49  **    CREATE TRI
11f0: 47 47 45 52 20 61 74 74 61 63 68 65 64 2e 64 65  GGER attached.de
1200: 6d 6f 20 41 46 54 45 52 20 49 4e 53 45 52 54 20  mo AFTER INSERT 
1210: 4f 4e 20 61 74 74 61 63 68 65 64 2e 74 61 62 20  ON attached.tab 
1220: 2e 2e 2e 2e 0a 20 20 2a 2a 20 20 20 20 20 20 20  .....  **       
1230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1240: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1250: 20 20 20 20 20 20 20 20 20 20 5e 5e 5e 5e 5e 5e            ^^^^^^
1260: 5e 5e 0a 20 20 2a 2a 0a 20 20 2a 2a 20 54 6f 20  ^^.  **.  ** To 
1270: 6d 61 69 6e 74 61 69 6e 20 62 61 63 6b 77 61 72  maintain backwar
1280: 64 73 20 63 6f 6d 70 61 74 69 62 69 6c 69 74 79  ds compatibility
1290: 2c 20 69 67 6e 6f 72 65 20 74 68 65 20 64 61 74  , ignore the dat
12a0: 61 62 61 73 65 0a 20 20 2a 2a 20 6e 61 6d 65 20  abase.  ** name 
12b0: 6f 6e 20 70 54 61 62 6c 65 4e 61 6d 65 20 69 66  on pTableName if
12c0: 20 77 65 20 61 72 65 20 72 65 70 61 72 73 69 6e   we are reparsin
12d0: 67 20 6f 75 74 20 6f 66 20 53 51 4c 49 54 45 5f  g out of SQLITE_
12e0: 4d 41 53 54 45 52 2e 0a 20 20 2a 2f 0a 20 20 69  MASTER..  */.  i
12f0: 66 28 20 64 62 2d 3e 69 6e 69 74 2e 62 75 73 79  f( db->init.busy
1300: 20 26 26 20 69 44 62 21 3d 31 20 29 7b 0a 20 20   && iDb!=1 ){.  
1310: 20 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28    sqlite3DbFree(
1320: 64 62 2c 20 70 54 61 62 6c 65 4e 61 6d 65 2d 3e  db, pTableName->
1330: 61 5b 30 5d 2e 7a 44 61 74 61 62 61 73 65 29 3b  a[0].zDatabase);
1340: 0a 20 20 20 20 70 54 61 62 6c 65 4e 61 6d 65 2d  .    pTableName-
1350: 3e 61 5b 30 5d 2e 7a 44 61 74 61 62 61 73 65 20  >a[0].zDatabase 
1360: 3d 20 30 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 49  = 0;.  }..  /* I
1370: 66 20 74 68 65 20 74 72 69 67 67 65 72 20 6e 61  f the trigger na
1380: 6d 65 20 77 61 73 20 75 6e 71 75 61 6c 69 66 69  me was unqualifi
1390: 65 64 2c 20 61 6e 64 20 74 68 65 20 74 61 62 6c  ed, and the tabl
13a0: 65 20 69 73 20 61 20 74 65 6d 70 20 74 61 62 6c  e is a temp tabl
13b0: 65 2c 0a 20 20 2a 2a 20 74 68 65 6e 20 73 65 74  e,.  ** then set
13c0: 20 69 44 62 20 74 6f 20 31 20 74 6f 20 63 72 65   iDb to 1 to cre
13d0: 61 74 65 20 74 68 65 20 74 72 69 67 67 65 72 20  ate the trigger 
13e0: 69 6e 20 74 68 65 20 74 65 6d 70 6f 72 61 72 79  in the temporary
13f0: 20 64 61 74 61 62 61 73 65 2e 0a 20 20 2a 2a 20   database..  ** 
1400: 49 66 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73  If sqlite3SrcLis
1410: 74 4c 6f 6f 6b 75 70 28 29 20 72 65 74 75 72 6e  tLookup() return
1420: 73 20 30 2c 20 69 6e 64 69 63 61 74 69 6e 67 20  s 0, indicating 
1430: 74 68 65 20 74 61 62 6c 65 20 64 6f 65 73 20 6e  the table does n
1440: 6f 74 0a 20 20 2a 2a 20 65 78 69 73 74 2c 20 74  ot.  ** exist, t
1450: 68 65 20 65 72 72 6f 72 20 69 73 20 63 61 75 67  he error is caug
1460: 68 74 20 62 79 20 74 68 65 20 62 6c 6f 63 6b 20  ht by the block 
1470: 62 65 6c 6f 77 2e 0a 20 20 2a 2f 0a 20 20 70 54  below..  */.  pT
1480: 61 62 20 3d 20 73 71 6c 69 74 65 33 53 72 63 4c  ab = sqlite3SrcL
1490: 69 73 74 4c 6f 6f 6b 75 70 28 70 50 61 72 73 65  istLookup(pParse
14a0: 2c 20 70 54 61 62 6c 65 4e 61 6d 65 29 3b 0a 20  , pTableName);. 
14b0: 20 69 66 28 20 64 62 2d 3e 69 6e 69 74 2e 62 75   if( db->init.bu
14c0: 73 79 3d 3d 30 20 26 26 20 70 4e 61 6d 65 32 2d  sy==0 && pName2-
14d0: 3e 6e 3d 3d 30 20 26 26 20 70 54 61 62 0a 20 20  >n==0 && pTab.  
14e0: 20 20 20 20 20 20 26 26 20 70 54 61 62 2d 3e 70        && pTab->p
14f0: 53 63 68 65 6d 61 3d 3d 64 62 2d 3e 61 44 62 5b  Schema==db->aDb[
1500: 31 5d 2e 70 53 63 68 65 6d 61 20 29 7b 0a 20 20  1].pSchema ){.  
1510: 20 20 69 44 62 20 3d 20 31 3b 0a 20 20 7d 0a 0a    iDb = 1;.  }..
1520: 20 20 2f 2a 20 45 6e 73 75 72 65 20 74 68 65 20    /* Ensure the 
1530: 74 61 62 6c 65 20 6e 61 6d 65 20 6d 61 74 63 68  table name match
1540: 65 73 20 64 61 74 61 62 61 73 65 20 6e 61 6d 65  es database name
1550: 20 61 6e 64 20 74 68 61 74 20 74 68 65 20 74 61   and that the ta
1560: 62 6c 65 20 65 78 69 73 74 73 20 2a 2f 0a 20 20  ble exists */.  
1570: 69 66 28 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61  if( db->mallocFa
1580: 69 6c 65 64 20 29 20 67 6f 74 6f 20 74 72 69 67  iled ) goto trig
1590: 67 65 72 5f 63 6c 65 61 6e 75 70 3b 0a 20 20 61  ger_cleanup;.  a
15a0: 73 73 65 72 74 28 20 70 54 61 62 6c 65 4e 61 6d  ssert( pTableNam
15b0: 65 2d 3e 6e 53 72 63 3d 3d 31 20 29 3b 0a 20 20  e->nSrc==1 );.  
15c0: 73 71 6c 69 74 65 33 46 69 78 49 6e 69 74 28 26  sqlite3FixInit(&
15d0: 73 46 69 78 2c 20 70 50 61 72 73 65 2c 20 69 44  sFix, pParse, iD
15e0: 62 2c 20 22 74 72 69 67 67 65 72 22 2c 20 70 4e  b, "trigger", pN
15f0: 61 6d 65 29 3b 0a 20 20 69 66 28 20 73 71 6c 69  ame);.  if( sqli
1600: 74 65 33 46 69 78 53 72 63 4c 69 73 74 28 26 73  te3FixSrcList(&s
1610: 46 69 78 2c 20 70 54 61 62 6c 65 4e 61 6d 65 29  Fix, pTableName)
1620: 20 29 7b 0a 20 20 20 20 67 6f 74 6f 20 74 72 69   ){.    goto tri
1630: 67 67 65 72 5f 63 6c 65 61 6e 75 70 3b 0a 20 20  gger_cleanup;.  
1640: 7d 0a 20 20 70 54 61 62 20 3d 20 73 71 6c 69 74  }.  pTab = sqlit
1650: 65 33 53 72 63 4c 69 73 74 4c 6f 6f 6b 75 70 28  e3SrcListLookup(
1660: 70 50 61 72 73 65 2c 20 70 54 61 62 6c 65 4e 61  pParse, pTableNa
1670: 6d 65 29 3b 0a 20 20 69 66 28 20 21 70 54 61 62  me);.  if( !pTab
1680: 20 29 7b 0a 20 20 20 20 2f 2a 20 54 68 65 20 74   ){.    /* The t
1690: 61 62 6c 65 20 64 6f 65 73 20 6e 6f 74 20 65 78  able does not ex
16a0: 69 73 74 2e 20 2a 2f 0a 20 20 20 20 69 66 28 20  ist. */.    if( 
16b0: 64 62 2d 3e 69 6e 69 74 2e 69 44 62 3d 3d 31 20  db->init.iDb==1 
16c0: 29 7b 0a 20 20 20 20 20 20 2f 2a 20 54 69 63 6b  ){.      /* Tick
16d0: 65 74 20 23 33 38 31 30 2e 0a 20 20 20 20 20 20  et #3810..      
16e0: 2a 2a 20 4e 6f 72 6d 61 6c 6c 79 2c 20 77 68 65  ** Normally, whe
16f0: 6e 65 76 65 72 20 61 20 74 61 62 6c 65 20 69 73  never a table is
1700: 20 64 72 6f 70 70 65 64 2c 20 61 6c 6c 20 61 73   dropped, all as
1710: 73 6f 63 69 61 74 65 64 20 74 72 69 67 67 65 72  sociated trigger
1720: 73 20 61 72 65 0a 20 20 20 20 20 20 2a 2a 20 64  s are.      ** d
1730: 72 6f 70 70 65 64 20 74 6f 6f 2e 20 20 42 75 74  ropped too.  But
1740: 20 69 66 20 61 20 54 45 4d 50 20 74 72 69 67 67   if a TEMP trigg
1750: 65 72 20 69 73 20 63 72 65 61 74 65 64 20 6f 6e  er is created on
1760: 20 61 20 6e 6f 6e 2d 54 45 4d 50 20 74 61 62 6c   a non-TEMP tabl
1770: 65 0a 20 20 20 20 20 20 2a 2a 20 61 6e 64 20 74  e.      ** and t
1780: 68 65 20 74 61 62 6c 65 20 69 73 20 64 72 6f 70  he table is drop
1790: 70 65 64 20 62 79 20 61 20 64 69 66 66 65 72 65  ped by a differe
17a0: 6e 74 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e  nt database conn
17b0: 65 63 74 69 6f 6e 2c 20 74 68 65 0a 20 20 20 20  ection, the.    
17c0: 20 20 2a 2a 20 74 72 69 67 67 65 72 20 69 73 20    ** trigger is 
17d0: 6e 6f 74 20 76 69 73 69 62 6c 65 20 74 6f 20 74  not visible to t
17e0: 68 65 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e  he database conn
17f0: 65 63 74 69 6f 6e 20 74 68 61 74 20 64 6f 65 73  ection that does
1800: 20 74 68 65 0a 20 20 20 20 20 20 2a 2a 20 64 72   the.      ** dr
1810: 6f 70 20 73 6f 20 74 68 65 20 74 72 69 67 67 65  op so the trigge
1820: 72 20 63 61 6e 6e 6f 74 20 62 65 20 64 72 6f 70  r cannot be drop
1830: 70 65 64 2e 20 20 54 68 69 73 20 72 65 73 75 6c  ped.  This resul
1840: 74 73 20 69 6e 20 61 6e 0a 20 20 20 20 20 20 2a  ts in an.      *
1850: 2a 20 22 6f 72 70 68 61 6e 65 64 20 74 72 69 67  * "orphaned trig
1860: 67 65 72 22 20 2d 20 61 20 74 72 69 67 67 65 72  ger" - a trigger
1870: 20 77 68 6f 73 65 20 61 73 73 6f 63 69 61 74 65   whose associate
1880: 64 20 74 61 62 6c 65 20 69 73 20 6d 69 73 73 69  d table is missi
1890: 6e 67 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20  ng..      */.   
18a0: 20 20 20 64 62 2d 3e 69 6e 69 74 2e 6f 72 70 68     db->init.orph
18b0: 61 6e 54 72 69 67 67 65 72 20 3d 20 31 3b 0a 20  anTrigger = 1;. 
18c0: 20 20 20 7d 0a 20 20 20 20 67 6f 74 6f 20 74 72     }.    goto tr
18d0: 69 67 67 65 72 5f 63 6c 65 61 6e 75 70 3b 0a 20  igger_cleanup;. 
18e0: 20 7d 0a 20 20 69 66 28 20 49 73 56 69 72 74 75   }.  if( IsVirtu
18f0: 61 6c 28 70 54 61 62 29 20 29 7b 0a 20 20 20 20  al(pTab) ){.    
1900: 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28  sqlite3ErrorMsg(
1910: 70 50 61 72 73 65 2c 20 22 63 61 6e 6e 6f 74 20  pParse, "cannot 
1920: 63 72 65 61 74 65 20 74 72 69 67 67 65 72 73 20  create triggers 
1930: 6f 6e 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65  on virtual table
1940: 73 22 29 3b 0a 20 20 20 20 67 6f 74 6f 20 74 72  s");.    goto tr
1950: 69 67 67 65 72 5f 63 6c 65 61 6e 75 70 3b 0a 20  igger_cleanup;. 
1960: 20 7d 0a 0a 20 20 2f 2a 20 43 68 65 63 6b 20 74   }..  /* Check t
1970: 68 61 74 20 74 68 65 20 74 72 69 67 67 65 72 20  hat the trigger 
1980: 6e 61 6d 65 20 69 73 20 6e 6f 74 20 72 65 73 65  name is not rese
1990: 72 76 65 64 20 61 6e 64 20 74 68 61 74 20 6e 6f  rved and that no
19a0: 20 74 72 69 67 67 65 72 20 6f 66 20 74 68 65 0a   trigger of the.
19b0: 20 20 2a 2a 20 73 70 65 63 69 66 69 65 64 20 6e    ** specified n
19c0: 61 6d 65 20 65 78 69 73 74 73 20 2a 2f 0a 20 20  ame exists */.  
19d0: 7a 4e 61 6d 65 20 3d 20 73 71 6c 69 74 65 33 4e  zName = sqlite3N
19e0: 61 6d 65 46 72 6f 6d 54 6f 6b 65 6e 28 64 62 2c  ameFromToken(db,
19f0: 20 70 4e 61 6d 65 29 3b 0a 20 20 69 66 28 20 21   pName);.  if( !
1a00: 7a 4e 61 6d 65 20 7c 7c 20 53 51 4c 49 54 45 5f  zName || SQLITE_
1a10: 4f 4b 21 3d 73 71 6c 69 74 65 33 43 68 65 63 6b  OK!=sqlite3Check
1a20: 4f 62 6a 65 63 74 4e 61 6d 65 28 70 50 61 72 73  ObjectName(pPars
1a30: 65 2c 20 7a 4e 61 6d 65 29 20 29 7b 0a 20 20 20  e, zName) ){.   
1a40: 20 67 6f 74 6f 20 74 72 69 67 67 65 72 5f 63 6c   goto trigger_cl
1a50: 65 61 6e 75 70 3b 0a 20 20 7d 0a 20 20 61 73 73  eanup;.  }.  ass
1a60: 65 72 74 28 20 73 71 6c 69 74 65 33 53 63 68 65  ert( sqlite3Sche
1a70: 6d 61 4d 75 74 65 78 48 65 6c 64 28 64 62 2c 20  maMutexHeld(db, 
1a80: 69 44 62 2c 20 30 29 20 29 3b 0a 20 20 69 66 28  iDb, 0) );.  if(
1a90: 20 73 71 6c 69 74 65 33 48 61 73 68 46 69 6e 64   sqlite3HashFind
1aa0: 28 26 28 64 62 2d 3e 61 44 62 5b 69 44 62 5d 2e  (&(db->aDb[iDb].
1ab0: 70 53 63 68 65 6d 61 2d 3e 74 72 69 67 48 61 73  pSchema->trigHas
1ac0: 68 29 2c 7a 4e 61 6d 65 29 20 29 7b 0a 20 20 20  h),zName) ){.   
1ad0: 20 69 66 28 20 21 6e 6f 45 72 72 20 29 7b 0a 20   if( !noErr ){. 
1ae0: 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f       sqlite3Erro
1af0: 72 4d 73 67 28 70 50 61 72 73 65 2c 20 22 74 72  rMsg(pParse, "tr
1b00: 69 67 67 65 72 20 25 54 20 61 6c 72 65 61 64 79  igger %T already
1b10: 20 65 78 69 73 74 73 22 2c 20 70 4e 61 6d 65 29   exists", pName)
1b20: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
1b30: 20 20 20 61 73 73 65 72 74 28 20 21 64 62 2d 3e     assert( !db->
1b40: 69 6e 69 74 2e 62 75 73 79 20 29 3b 0a 20 20 20  init.busy );.   
1b50: 20 20 20 73 71 6c 69 74 65 33 43 6f 64 65 56 65     sqlite3CodeVe
1b60: 72 69 66 79 53 63 68 65 6d 61 28 70 50 61 72 73  rifySchema(pPars
1b70: 65 2c 20 69 44 62 29 3b 0a 20 20 20 20 7d 0a 20  e, iDb);.    }. 
1b80: 20 20 20 67 6f 74 6f 20 74 72 69 67 67 65 72 5f     goto trigger_
1b90: 63 6c 65 61 6e 75 70 3b 0a 20 20 7d 0a 0a 20 20  cleanup;.  }..  
1ba0: 2f 2a 20 44 6f 20 6e 6f 74 20 63 72 65 61 74 65  /* Do not create
1bb0: 20 61 20 74 72 69 67 67 65 72 20 6f 6e 20 61 20   a trigger on a 
1bc0: 73 79 73 74 65 6d 20 74 61 62 6c 65 20 2a 2f 0a  system table */.
1bd0: 20 20 69 66 28 20 73 71 6c 69 74 65 33 53 74 72    if( sqlite3Str
1be0: 4e 49 43 6d 70 28 70 54 61 62 2d 3e 7a 4e 61 6d  NICmp(pTab->zNam
1bf0: 65 2c 20 22 73 71 6c 69 74 65 5f 22 2c 20 37 29  e, "sqlite_", 7)
1c00: 3d 3d 30 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  ==0 ){.    sqlit
1c10: 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61 72 73  e3ErrorMsg(pPars
1c20: 65 2c 20 22 63 61 6e 6e 6f 74 20 63 72 65 61 74  e, "cannot creat
1c30: 65 20 74 72 69 67 67 65 72 20 6f 6e 20 73 79 73  e trigger on sys
1c40: 74 65 6d 20 74 61 62 6c 65 22 29 3b 0a 20 20 20  tem table");.   
1c50: 20 67 6f 74 6f 20 74 72 69 67 67 65 72 5f 63 6c   goto trigger_cl
1c60: 65 61 6e 75 70 3b 0a 20 20 7d 0a 0a 20 20 2f 2a  eanup;.  }..  /*
1c70: 20 49 4e 53 54 45 41 44 20 6f 66 20 74 72 69 67   INSTEAD of trig
1c80: 67 65 72 73 20 61 72 65 20 6f 6e 6c 79 20 66 6f  gers are only fo
1c90: 72 20 76 69 65 77 73 20 61 6e 64 20 76 69 65 77  r views and view
1ca0: 73 20 6f 6e 6c 79 20 73 75 70 70 6f 72 74 20 49  s only support I
1cb0: 4e 53 54 45 41 44 0a 20 20 2a 2a 20 6f 66 20 74  NSTEAD.  ** of t
1cc0: 72 69 67 67 65 72 73 2e 0a 20 20 2a 2f 0a 20 20  riggers..  */.  
1cd0: 69 66 28 20 70 54 61 62 2d 3e 70 53 65 6c 65 63  if( pTab->pSelec
1ce0: 74 20 26 26 20 74 72 5f 74 6d 21 3d 54 4b 5f 49  t && tr_tm!=TK_I
1cf0: 4e 53 54 45 41 44 20 29 7b 0a 20 20 20 20 73 71  NSTEAD ){.    sq
1d00: 6c 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50  lite3ErrorMsg(pP
1d10: 61 72 73 65 2c 20 22 63 61 6e 6e 6f 74 20 63 72  arse, "cannot cr
1d20: 65 61 74 65 20 25 73 20 74 72 69 67 67 65 72 20  eate %s trigger 
1d30: 6f 6e 20 76 69 65 77 3a 20 25 53 22 2c 20 0a 20  on view: %S", . 
1d40: 20 20 20 20 20 20 20 28 74 72 5f 74 6d 20 3d 3d         (tr_tm ==
1d50: 20 54 4b 5f 42 45 46 4f 52 45 29 3f 22 42 45 46   TK_BEFORE)?"BEF
1d60: 4f 52 45 22 3a 22 41 46 54 45 52 22 2c 20 70 54  ORE":"AFTER", pT
1d70: 61 62 6c 65 4e 61 6d 65 2c 20 30 29 3b 0a 20 20  ableName, 0);.  
1d80: 20 20 67 6f 74 6f 20 74 72 69 67 67 65 72 5f 63    goto trigger_c
1d90: 6c 65 61 6e 75 70 3b 0a 20 20 7d 0a 20 20 69 66  leanup;.  }.  if
1da0: 28 20 21 70 54 61 62 2d 3e 70 53 65 6c 65 63 74  ( !pTab->pSelect
1db0: 20 26 26 20 74 72 5f 74 6d 3d 3d 54 4b 5f 49 4e   && tr_tm==TK_IN
1dc0: 53 54 45 41 44 20 29 7b 0a 20 20 20 20 73 71 6c  STEAD ){.    sql
1dd0: 69 74 65 33 45 72 72 6f 72 4d 73 67 28 70 50 61  ite3ErrorMsg(pPa
1de0: 72 73 65 2c 20 22 63 61 6e 6e 6f 74 20 63 72 65  rse, "cannot cre
1df0: 61 74 65 20 49 4e 53 54 45 41 44 20 4f 46 22 0a  ate INSTEAD OF".
1e00: 20 20 20 20 20 20 20 20 22 20 74 72 69 67 67 65          " trigge
1e10: 72 20 6f 6e 20 74 61 62 6c 65 3a 20 25 53 22 2c  r on table: %S",
1e20: 20 70 54 61 62 6c 65 4e 61 6d 65 2c 20 30 29 3b   pTableName, 0);
1e30: 0a 20 20 20 20 67 6f 74 6f 20 74 72 69 67 67 65  .    goto trigge
1e40: 72 5f 63 6c 65 61 6e 75 70 3b 0a 20 20 7d 0a 0a  r_cleanup;.  }..
1e50: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
1e60: 4d 49 54 5f 41 55 54 48 4f 52 49 5a 41 54 49 4f  MIT_AUTHORIZATIO
1e70: 4e 0a 20 20 7b 0a 20 20 20 20 69 6e 74 20 69 54  N.  {.    int iT
1e80: 61 62 44 62 20 3d 20 73 71 6c 69 74 65 33 53 63  abDb = sqlite3Sc
1e90: 68 65 6d 61 54 6f 49 6e 64 65 78 28 64 62 2c 20  hemaToIndex(db, 
1ea0: 70 54 61 62 2d 3e 70 53 63 68 65 6d 61 29 3b 0a  pTab->pSchema);.
1eb0: 20 20 20 20 69 6e 74 20 63 6f 64 65 20 3d 20 53      int code = S
1ec0: 51 4c 49 54 45 5f 43 52 45 41 54 45 5f 54 52 49  QLITE_CREATE_TRI
1ed0: 47 47 45 52 3b 0a 20 20 20 20 63 6f 6e 73 74 20  GGER;.    const 
1ee0: 63 68 61 72 20 2a 7a 44 62 20 3d 20 64 62 2d 3e  char *zDb = db->
1ef0: 61 44 62 5b 69 54 61 62 44 62 5d 2e 7a 44 62 53  aDb[iTabDb].zDbS
1f00: 4e 61 6d 65 3b 0a 20 20 20 20 63 6f 6e 73 74 20  Name;.    const 
1f10: 63 68 61 72 20 2a 7a 44 62 54 72 69 67 20 3d 20  char *zDbTrig = 
1f20: 69 73 54 65 6d 70 20 3f 20 64 62 2d 3e 61 44 62  isTemp ? db->aDb
1f30: 5b 31 5d 2e 7a 44 62 53 4e 61 6d 65 20 3a 20 7a  [1].zDbSName : z
1f40: 44 62 3b 0a 20 20 20 20 69 66 28 20 69 54 61 62  Db;.    if( iTab
1f50: 44 62 3d 3d 31 20 7c 7c 20 69 73 54 65 6d 70 20  Db==1 || isTemp 
1f60: 29 20 63 6f 64 65 20 3d 20 53 51 4c 49 54 45 5f  ) code = SQLITE_
1f70: 43 52 45 41 54 45 5f 54 45 4d 50 5f 54 52 49 47  CREATE_TEMP_TRIG
1f80: 47 45 52 3b 0a 20 20 20 20 69 66 28 20 73 71 6c  GER;.    if( sql
1f90: 69 74 65 33 41 75 74 68 43 68 65 63 6b 28 70 50  ite3AuthCheck(pP
1fa0: 61 72 73 65 2c 20 63 6f 64 65 2c 20 7a 4e 61 6d  arse, code, zNam
1fb0: 65 2c 20 70 54 61 62 2d 3e 7a 4e 61 6d 65 2c 20  e, pTab->zName, 
1fc0: 7a 44 62 54 72 69 67 29 20 29 7b 0a 20 20 20 20  zDbTrig) ){.    
1fd0: 20 20 67 6f 74 6f 20 74 72 69 67 67 65 72 5f 63    goto trigger_c
1fe0: 6c 65 61 6e 75 70 3b 0a 20 20 20 20 7d 0a 20 20  leanup;.    }.  
1ff0: 20 20 69 66 28 20 73 71 6c 69 74 65 33 41 75 74    if( sqlite3Aut
2000: 68 43 68 65 63 6b 28 70 50 61 72 73 65 2c 20 53  hCheck(pParse, S
2010: 51 4c 49 54 45 5f 49 4e 53 45 52 54 2c 20 53 43  QLITE_INSERT, SC
2020: 48 45 4d 41 5f 54 41 42 4c 45 28 69 54 61 62 44  HEMA_TABLE(iTabD
2030: 62 29 2c 30 2c 7a 44 62 29 29 7b 0a 20 20 20 20  b),0,zDb)){.    
2040: 20 20 67 6f 74 6f 20 74 72 69 67 67 65 72 5f 63    goto trigger_c
2050: 6c 65 61 6e 75 70 3b 0a 20 20 20 20 7d 0a 20 20  leanup;.    }.  
2060: 7d 0a 23 65 6e 64 69 66 0a 0a 20 20 2f 2a 20 49  }.#endif..  /* I
2070: 4e 53 54 45 41 44 20 4f 46 20 74 72 69 67 67 65  NSTEAD OF trigge
2080: 72 73 20 63 61 6e 20 6f 6e 6c 79 20 61 70 70 65  rs can only appe
2090: 61 72 20 6f 6e 20 76 69 65 77 73 20 61 6e 64 20  ar on views and 
20a0: 42 45 46 4f 52 45 20 74 72 69 67 67 65 72 73 0a  BEFORE triggers.
20b0: 20 20 2a 2a 20 63 61 6e 6e 6f 74 20 61 70 70 65    ** cannot appe
20c0: 61 72 20 6f 6e 20 76 69 65 77 73 2e 20 20 53 6f  ar on views.  So
20d0: 20 77 65 20 6d 69 67 68 74 20 61 73 20 77 65 6c   we might as wel
20e0: 6c 20 74 72 61 6e 73 6c 61 74 65 20 65 76 65 72  l translate ever
20f0: 79 0a 20 20 2a 2a 20 49 4e 53 54 45 41 44 20 4f  y.  ** INSTEAD O
2100: 46 20 74 72 69 67 67 65 72 20 69 6e 74 6f 20 61  F trigger into a
2110: 20 42 45 46 4f 52 45 20 74 72 69 67 67 65 72 2e   BEFORE trigger.
2120: 20 20 49 74 20 73 69 6d 70 6c 69 66 69 65 73 20    It simplifies 
2130: 63 6f 64 65 0a 20 20 2a 2a 20 65 6c 73 65 77 68  code.  ** elsewh
2140: 65 72 65 2e 0a 20 20 2a 2f 0a 20 20 69 66 20 28  ere..  */.  if (
2150: 74 72 5f 74 6d 20 3d 3d 20 54 4b 5f 49 4e 53 54  tr_tm == TK_INST
2160: 45 41 44 29 7b 0a 20 20 20 20 74 72 5f 74 6d 20  EAD){.    tr_tm 
2170: 3d 20 54 4b 5f 42 45 46 4f 52 45 3b 0a 20 20 7d  = TK_BEFORE;.  }
2180: 0a 0a 20 20 2f 2a 20 42 75 69 6c 64 20 74 68 65  ..  /* Build the
2190: 20 54 72 69 67 67 65 72 20 6f 62 6a 65 63 74 20   Trigger object 
21a0: 2a 2f 0a 20 20 70 54 72 69 67 67 65 72 20 3d 20  */.  pTrigger = 
21b0: 28 54 72 69 67 67 65 72 2a 29 73 71 6c 69 74 65  (Trigger*)sqlite
21c0: 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64 62  3DbMallocZero(db
21d0: 2c 20 73 69 7a 65 6f 66 28 54 72 69 67 67 65 72  , sizeof(Trigger
21e0: 29 29 3b 0a 20 20 69 66 28 20 70 54 72 69 67 67  ));.  if( pTrigg
21f0: 65 72 3d 3d 30 20 29 20 67 6f 74 6f 20 74 72 69  er==0 ) goto tri
2200: 67 67 65 72 5f 63 6c 65 61 6e 75 70 3b 0a 20 20  gger_cleanup;.  
2210: 70 54 72 69 67 67 65 72 2d 3e 7a 4e 61 6d 65 20  pTrigger->zName 
2220: 3d 20 7a 4e 61 6d 65 3b 0a 20 20 7a 4e 61 6d 65  = zName;.  zName
2230: 20 3d 20 30 3b 0a 20 20 70 54 72 69 67 67 65 72   = 0;.  pTrigger
2240: 2d 3e 74 61 62 6c 65 20 3d 20 73 71 6c 69 74 65  ->table = sqlite
2250: 33 44 62 53 74 72 44 75 70 28 64 62 2c 20 70 54  3DbStrDup(db, pT
2260: 61 62 6c 65 4e 61 6d 65 2d 3e 61 5b 30 5d 2e 7a  ableName->a[0].z
2270: 4e 61 6d 65 29 3b 0a 20 20 70 54 72 69 67 67 65  Name);.  pTrigge
2280: 72 2d 3e 70 53 63 68 65 6d 61 20 3d 20 64 62 2d  r->pSchema = db-
2290: 3e 61 44 62 5b 69 44 62 5d 2e 70 53 63 68 65 6d  >aDb[iDb].pSchem
22a0: 61 3b 0a 20 20 70 54 72 69 67 67 65 72 2d 3e 70  a;.  pTrigger->p
22b0: 54 61 62 53 63 68 65 6d 61 20 3d 20 70 54 61 62  TabSchema = pTab
22c0: 2d 3e 70 53 63 68 65 6d 61 3b 0a 20 20 70 54 72  ->pSchema;.  pTr
22d0: 69 67 67 65 72 2d 3e 6f 70 20 3d 20 28 75 38 29  igger->op = (u8)
22e0: 6f 70 3b 0a 20 20 70 54 72 69 67 67 65 72 2d 3e  op;.  pTrigger->
22f0: 74 72 5f 74 6d 20 3d 20 74 72 5f 74 6d 3d 3d 54  tr_tm = tr_tm==T
2300: 4b 5f 42 45 46 4f 52 45 20 3f 20 54 52 49 47 47  K_BEFORE ? TRIGG
2310: 45 52 5f 42 45 46 4f 52 45 20 3a 20 54 52 49 47  ER_BEFORE : TRIG
2320: 47 45 52 5f 41 46 54 45 52 3b 0a 20 20 70 54 72  GER_AFTER;.  pTr
2330: 69 67 67 65 72 2d 3e 70 57 68 65 6e 20 3d 20 73  igger->pWhen = s
2340: 71 6c 69 74 65 33 45 78 70 72 44 75 70 28 64 62  qlite3ExprDup(db
2350: 2c 20 70 57 68 65 6e 2c 20 45 58 50 52 44 55 50  , pWhen, EXPRDUP
2360: 5f 52 45 44 55 43 45 29 3b 0a 20 20 70 54 72 69  _REDUCE);.  pTri
2370: 67 67 65 72 2d 3e 70 43 6f 6c 75 6d 6e 73 20 3d  gger->pColumns =
2380: 20 73 71 6c 69 74 65 33 49 64 4c 69 73 74 44 75   sqlite3IdListDu
2390: 70 28 64 62 2c 20 70 43 6f 6c 75 6d 6e 73 29 3b  p(db, pColumns);
23a0: 0a 20 20 61 73 73 65 72 74 28 20 70 50 61 72 73  .  assert( pPars
23b0: 65 2d 3e 70 4e 65 77 54 72 69 67 67 65 72 3d 3d  e->pNewTrigger==
23c0: 30 20 29 3b 0a 20 20 70 50 61 72 73 65 2d 3e 70  0 );.  pParse->p
23d0: 4e 65 77 54 72 69 67 67 65 72 20 3d 20 70 54 72  NewTrigger = pTr
23e0: 69 67 67 65 72 3b 0a 0a 74 72 69 67 67 65 72 5f  igger;..trigger_
23f0: 63 6c 65 61 6e 75 70 3a 0a 20 20 73 71 6c 69 74  cleanup:.  sqlit
2400: 65 33 44 62 46 72 65 65 28 64 62 2c 20 7a 4e 61  e3DbFree(db, zNa
2410: 6d 65 29 3b 0a 20 20 73 71 6c 69 74 65 33 53 72  me);.  sqlite3Sr
2420: 63 4c 69 73 74 44 65 6c 65 74 65 28 64 62 2c 20  cListDelete(db, 
2430: 70 54 61 62 6c 65 4e 61 6d 65 29 3b 0a 20 20 73  pTableName);.  s
2440: 71 6c 69 74 65 33 49 64 4c 69 73 74 44 65 6c 65  qlite3IdListDele
2450: 74 65 28 64 62 2c 20 70 43 6f 6c 75 6d 6e 73 29  te(db, pColumns)
2460: 3b 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 44  ;.  sqlite3ExprD
2470: 65 6c 65 74 65 28 64 62 2c 20 70 57 68 65 6e 29  elete(db, pWhen)
2480: 3b 0a 20 20 69 66 28 20 21 70 50 61 72 73 65 2d  ;.  if( !pParse-
2490: 3e 70 4e 65 77 54 72 69 67 67 65 72 20 29 7b 0a  >pNewTrigger ){.
24a0: 20 20 20 20 73 71 6c 69 74 65 33 44 65 6c 65 74      sqlite3Delet
24b0: 65 54 72 69 67 67 65 72 28 64 62 2c 20 70 54 72  eTrigger(db, pTr
24c0: 69 67 67 65 72 29 3b 0a 20 20 7d 65 6c 73 65 7b  igger);.  }else{
24d0: 0a 20 20 20 20 61 73 73 65 72 74 28 20 70 50 61  .    assert( pPa
24e0: 72 73 65 2d 3e 70 4e 65 77 54 72 69 67 67 65 72  rse->pNewTrigger
24f0: 3d 3d 70 54 72 69 67 67 65 72 20 29 3b 0a 20 20  ==pTrigger );.  
2500: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20  }.}../*.** This 
2510: 72 6f 75 74 69 6e 65 20 69 73 20 63 61 6c 6c 65  routine is calle
2520: 64 20 61 66 74 65 72 20 61 6c 6c 20 6f 66 20 74  d after all of t
2530: 68 65 20 74 72 69 67 67 65 72 20 61 63 74 69 6f  he trigger actio
2540: 6e 73 20 68 61 76 65 20 62 65 65 6e 20 70 61 72  ns have been par
2550: 73 65 64 0a 2a 2a 20 69 6e 20 6f 72 64 65 72 20  sed.** in order 
2560: 74 6f 20 63 6f 6d 70 6c 65 74 65 20 74 68 65 20  to complete the 
2570: 70 72 6f 63 65 73 73 20 6f 66 20 62 75 69 6c 64  process of build
2580: 69 6e 67 20 74 68 65 20 74 72 69 67 67 65 72 2e  ing the trigger.
2590: 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  .*/.void sqlite3
25a0: 46 69 6e 69 73 68 54 72 69 67 67 65 72 28 0a 20  FinishTrigger(. 
25b0: 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20   Parse *pParse, 
25c0: 20 20 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73           /* Pars
25d0: 65 72 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20  er context */.  
25e0: 54 72 69 67 67 65 72 53 74 65 70 20 2a 70 53 74  TriggerStep *pSt
25f0: 65 70 4c 69 73 74 2c 20 2f 2a 20 54 68 65 20 74  epList, /* The t
2600: 72 69 67 67 65 72 65 64 20 70 72 6f 67 72 61 6d  riggered program
2610: 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70 41 6c   */.  Token *pAl
2620: 6c 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  l             /*
2630: 20 54 6f 6b 65 6e 20 74 68 61 74 20 64 65 73 63   Token that desc
2640: 72 69 62 65 73 20 74 68 65 20 63 6f 6d 70 6c 65  ribes the comple
2650: 74 65 20 43 52 45 41 54 45 20 54 52 49 47 47 45  te CREATE TRIGGE
2660: 52 20 2a 2f 0a 29 7b 0a 20 20 54 72 69 67 67 65  R */.){.  Trigge
2670: 72 20 2a 70 54 72 69 67 20 3d 20 70 50 61 72 73  r *pTrig = pPars
2680: 65 2d 3e 70 4e 65 77 54 72 69 67 67 65 72 3b 20  e->pNewTrigger; 
2690: 20 20 2f 2a 20 54 72 69 67 67 65 72 20 62 65 69    /* Trigger bei
26a0: 6e 67 20 66 69 6e 69 73 68 65 64 20 2a 2f 0a 20  ng finished */. 
26b0: 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 20 20 20   char *zName;   
26c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
26d0: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65           /* Name
26e0: 20 6f 66 20 74 72 69 67 67 65 72 20 2a 2f 0a 20   of trigger */. 
26f0: 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70   sqlite3 *db = p
2700: 50 61 72 73 65 2d 3e 64 62 3b 20 20 20 20 20 20  Parse->db;      
2710: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
2720: 64 61 74 61 62 61 73 65 20 2a 2f 0a 20 20 44 62  database */.  Db
2730: 46 69 78 65 72 20 73 46 69 78 3b 20 20 20 20 20  Fixer sFix;     
2740: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2750: 20 20 20 20 20 20 2f 2a 20 46 69 78 65 72 20 6f        /* Fixer o
2760: 62 6a 65 63 74 20 2a 2f 0a 20 20 69 6e 74 20 69  bject */.  int i
2770: 44 62 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  Db;             
2780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2790: 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 63     /* Database c
27a0: 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 74 72  ontaining the tr
27b0: 69 67 67 65 72 20 2a 2f 0a 20 20 54 6f 6b 65 6e  igger */.  Token
27c0: 20 6e 61 6d 65 54 6f 6b 65 6e 3b 20 20 20 20 20   nameToken;     
27d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
27e0: 20 20 20 2f 2a 20 54 72 69 67 67 65 72 20 6e 61     /* Trigger na
27f0: 6d 65 20 66 6f 72 20 65 72 72 6f 72 20 72 65 70  me for error rep
2800: 6f 72 74 69 6e 67 20 2a 2f 0a 0a 20 20 70 50 61  orting */..  pPa
2810: 72 73 65 2d 3e 70 4e 65 77 54 72 69 67 67 65 72  rse->pNewTrigger
2820: 20 3d 20 30 3b 0a 20 20 69 66 28 20 4e 45 56 45   = 0;.  if( NEVE
2830: 52 28 70 50 61 72 73 65 2d 3e 6e 45 72 72 29 20  R(pParse->nErr) 
2840: 7c 7c 20 21 70 54 72 69 67 20 29 20 67 6f 74 6f  || !pTrig ) goto
2850: 20 74 72 69 67 67 65 72 66 69 6e 69 73 68 5f 63   triggerfinish_c
2860: 6c 65 61 6e 75 70 3b 0a 20 20 7a 4e 61 6d 65 20  leanup;.  zName 
2870: 3d 20 70 54 72 69 67 2d 3e 7a 4e 61 6d 65 3b 0a  = pTrig->zName;.
2880: 20 20 69 44 62 20 3d 20 73 71 6c 69 74 65 33 53    iDb = sqlite3S
2890: 63 68 65 6d 61 54 6f 49 6e 64 65 78 28 70 50 61  chemaToIndex(pPa
28a0: 72 73 65 2d 3e 64 62 2c 20 70 54 72 69 67 2d 3e  rse->db, pTrig->
28b0: 70 53 63 68 65 6d 61 29 3b 0a 20 20 70 54 72 69  pSchema);.  pTri
28c0: 67 2d 3e 73 74 65 70 5f 6c 69 73 74 20 3d 20 70  g->step_list = p
28d0: 53 74 65 70 4c 69 73 74 3b 0a 20 20 77 68 69 6c  StepList;.  whil
28e0: 65 28 20 70 53 74 65 70 4c 69 73 74 20 29 7b 0a  e( pStepList ){.
28f0: 20 20 20 20 70 53 74 65 70 4c 69 73 74 2d 3e 70      pStepList->p
2900: 54 72 69 67 20 3d 20 70 54 72 69 67 3b 0a 20 20  Trig = pTrig;.  
2910: 20 20 70 53 74 65 70 4c 69 73 74 20 3d 20 70 53    pStepList = pS
2920: 74 65 70 4c 69 73 74 2d 3e 70 4e 65 78 74 3b 0a  tepList->pNext;.
2930: 20 20 7d 0a 20 20 73 71 6c 69 74 65 33 54 6f 6b    }.  sqlite3Tok
2940: 65 6e 49 6e 69 74 28 26 6e 61 6d 65 54 6f 6b 65  enInit(&nameToke
2950: 6e 2c 20 70 54 72 69 67 2d 3e 7a 4e 61 6d 65 29  n, pTrig->zName)
2960: 3b 0a 20 20 73 71 6c 69 74 65 33 46 69 78 49 6e  ;.  sqlite3FixIn
2970: 69 74 28 26 73 46 69 78 2c 20 70 50 61 72 73 65  it(&sFix, pParse
2980: 2c 20 69 44 62 2c 20 22 74 72 69 67 67 65 72 22  , iDb, "trigger"
2990: 2c 20 26 6e 61 6d 65 54 6f 6b 65 6e 29 3b 0a 20  , &nameToken);. 
29a0: 20 69 66 28 20 73 71 6c 69 74 65 33 46 69 78 54   if( sqlite3FixT
29b0: 72 69 67 67 65 72 53 74 65 70 28 26 73 46 69 78  riggerStep(&sFix
29c0: 2c 20 70 54 72 69 67 2d 3e 73 74 65 70 5f 6c 69  , pTrig->step_li
29d0: 73 74 29 20 0a 20 20 20 7c 7c 20 73 71 6c 69 74  st) .   || sqlit
29e0: 65 33 46 69 78 45 78 70 72 28 26 73 46 69 78 2c  e3FixExpr(&sFix,
29f0: 20 70 54 72 69 67 2d 3e 70 57 68 65 6e 29 20 0a   pTrig->pWhen) .
2a00: 20 20 29 7b 0a 20 20 20 20 67 6f 74 6f 20 74 72    ){.    goto tr
2a10: 69 67 67 65 72 66 69 6e 69 73 68 5f 63 6c 65 61  iggerfinish_clea
2a20: 6e 75 70 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 69  nup;.  }..  /* i
2a30: 66 20 77 65 20 61 72 65 20 6e 6f 74 20 69 6e 69  f we are not ini
2a40: 74 69 61 6c 69 7a 69 6e 67 2c 0a 20 20 2a 2a 20  tializing,.  ** 
2a50: 62 75 69 6c 64 20 74 68 65 20 73 71 6c 69 74 65  build the sqlite
2a60: 5f 6d 61 73 74 65 72 20 65 6e 74 72 79 0a 20 20  _master entry.  
2a70: 2a 2f 0a 20 20 69 66 28 20 21 64 62 2d 3e 69 6e  */.  if( !db->in
2a80: 69 74 2e 62 75 73 79 20 29 7b 0a 20 20 20 20 56  it.busy ){.    V
2a90: 64 62 65 20 2a 76 3b 0a 20 20 20 20 63 68 61 72  dbe *v;.    char
2aa0: 20 2a 7a 3b 0a 0a 20 20 20 20 2f 2a 20 4d 61 6b   *z;..    /* Mak
2ab0: 65 20 61 6e 20 65 6e 74 72 79 20 69 6e 20 74 68  e an entry in th
2ac0: 65 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72 20  e sqlite_master 
2ad0: 74 61 62 6c 65 20 2a 2f 0a 20 20 20 20 76 20 3d  table */.    v =
2ae0: 20 73 71 6c 69 74 65 33 47 65 74 56 64 62 65 28   sqlite3GetVdbe(
2af0: 70 50 61 72 73 65 29 3b 0a 20 20 20 20 69 66 28  pParse);.    if(
2b00: 20 76 3d 3d 30 20 29 20 67 6f 74 6f 20 74 72 69   v==0 ) goto tri
2b10: 67 67 65 72 66 69 6e 69 73 68 5f 63 6c 65 61 6e  ggerfinish_clean
2b20: 75 70 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 42  up;.    sqlite3B
2b30: 65 67 69 6e 57 72 69 74 65 4f 70 65 72 61 74 69  eginWriteOperati
2b40: 6f 6e 28 70 50 61 72 73 65 2c 20 30 2c 20 69 44  on(pParse, 0, iD
2b50: 62 29 3b 0a 20 20 20 20 7a 20 3d 20 73 71 6c 69  b);.    z = sqli
2b60: 74 65 33 44 62 53 74 72 4e 44 75 70 28 64 62 2c  te3DbStrNDup(db,
2b70: 20 28 63 68 61 72 2a 29 70 41 6c 6c 2d 3e 7a 2c   (char*)pAll->z,
2b80: 20 70 41 6c 6c 2d 3e 6e 29 3b 0a 20 20 20 20 73   pAll->n);.    s
2b90: 71 6c 69 74 65 33 4e 65 73 74 65 64 50 61 72 73  qlite3NestedPars
2ba0: 65 28 70 50 61 72 73 65 2c 0a 20 20 20 20 20 20  e(pParse,.      
2bb0: 20 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 25 51   "INSERT INTO %Q
2bc0: 2e 25 73 20 56 41 4c 55 45 53 28 27 74 72 69 67  .%s VALUES('trig
2bd0: 67 65 72 27 2c 25 51 2c 25 51 2c 30 2c 27 43 52  ger',%Q,%Q,0,'CR
2be0: 45 41 54 45 20 54 52 49 47 47 45 52 20 25 71 27  EATE TRIGGER %q'
2bf0: 29 22 2c 0a 20 20 20 20 20 20 20 64 62 2d 3e 61  )",.       db->a
2c00: 44 62 5b 69 44 62 5d 2e 7a 44 62 53 4e 61 6d 65  Db[iDb].zDbSName
2c10: 2c 20 53 43 48 45 4d 41 5f 54 41 42 4c 45 28 69  , SCHEMA_TABLE(i
2c20: 44 62 29 2c 20 7a 4e 61 6d 65 2c 0a 20 20 20 20  Db), zName,.    
2c30: 20 20 20 70 54 72 69 67 2d 3e 74 61 62 6c 65 2c     pTrig->table,
2c40: 20 7a 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33   z);.    sqlite3
2c50: 44 62 46 72 65 65 28 64 62 2c 20 7a 29 3b 0a 20  DbFree(db, z);. 
2c60: 20 20 20 73 71 6c 69 74 65 33 43 68 61 6e 67 65     sqlite3Change
2c70: 43 6f 6f 6b 69 65 28 70 50 61 72 73 65 2c 20 69  Cookie(pParse, i
2c80: 44 62 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  Db);.    sqlite3
2c90: 56 64 62 65 41 64 64 50 61 72 73 65 53 63 68 65  VdbeAddParseSche
2ca0: 6d 61 4f 70 28 76 2c 20 69 44 62 2c 0a 20 20 20  maOp(v, iDb,.   
2cb0: 20 20 20 20 20 73 71 6c 69 74 65 33 4d 50 72 69       sqlite3MPri
2cc0: 6e 74 66 28 64 62 2c 20 22 74 79 70 65 3d 27 74  ntf(db, "type='t
2cd0: 72 69 67 67 65 72 27 20 41 4e 44 20 6e 61 6d 65  rigger' AND name
2ce0: 3d 27 25 71 27 22 2c 20 7a 4e 61 6d 65 29 29 3b  ='%q'", zName));
2cf0: 0a 20 20 7d 0a 0a 20 20 69 66 28 20 64 62 2d 3e  .  }..  if( db->
2d00: 69 6e 69 74 2e 62 75 73 79 20 29 7b 0a 20 20 20  init.busy ){.   
2d10: 20 54 72 69 67 67 65 72 20 2a 70 4c 69 6e 6b 20   Trigger *pLink 
2d20: 3d 20 70 54 72 69 67 3b 0a 20 20 20 20 48 61 73  = pTrig;.    Has
2d30: 68 20 2a 70 48 61 73 68 20 3d 20 26 64 62 2d 3e  h *pHash = &db->
2d40: 61 44 62 5b 69 44 62 5d 2e 70 53 63 68 65 6d 61  aDb[iDb].pSchema
2d50: 2d 3e 74 72 69 67 48 61 73 68 3b 0a 20 20 20 20  ->trigHash;.    
2d60: 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 53  assert( sqlite3S
2d70: 63 68 65 6d 61 4d 75 74 65 78 48 65 6c 64 28 64  chemaMutexHeld(d
2d80: 62 2c 20 69 44 62 2c 20 30 29 20 29 3b 0a 20 20  b, iDb, 0) );.  
2d90: 20 20 70 54 72 69 67 20 3d 20 73 71 6c 69 74 65    pTrig = sqlite
2da0: 33 48 61 73 68 49 6e 73 65 72 74 28 70 48 61 73  3HashInsert(pHas
2db0: 68 2c 20 7a 4e 61 6d 65 2c 20 70 54 72 69 67 29  h, zName, pTrig)
2dc0: 3b 0a 20 20 20 20 69 66 28 20 70 54 72 69 67 20  ;.    if( pTrig 
2dd0: 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ){.      sqlite3
2de0: 4f 6f 6d 46 61 75 6c 74 28 64 62 29 3b 0a 20 20  OomFault(db);.  
2df0: 20 20 7d 65 6c 73 65 20 69 66 28 20 70 4c 69 6e    }else if( pLin
2e00: 6b 2d 3e 70 53 63 68 65 6d 61 3d 3d 70 4c 69 6e  k->pSchema==pLin
2e10: 6b 2d 3e 70 54 61 62 53 63 68 65 6d 61 20 29 7b  k->pTabSchema ){
2e20: 0a 20 20 20 20 20 20 54 61 62 6c 65 20 2a 70 54  .      Table *pT
2e30: 61 62 3b 0a 20 20 20 20 20 20 70 54 61 62 20 3d  ab;.      pTab =
2e40: 20 73 71 6c 69 74 65 33 48 61 73 68 46 69 6e 64   sqlite3HashFind
2e50: 28 26 70 4c 69 6e 6b 2d 3e 70 54 61 62 53 63 68  (&pLink->pTabSch
2e60: 65 6d 61 2d 3e 74 62 6c 48 61 73 68 2c 20 70 4c  ema->tblHash, pL
2e70: 69 6e 6b 2d 3e 74 61 62 6c 65 29 3b 0a 20 20 20  ink->table);.   
2e80: 20 20 20 61 73 73 65 72 74 28 20 70 54 61 62 21     assert( pTab!
2e90: 3d 30 20 29 3b 0a 20 20 20 20 20 20 70 4c 69 6e  =0 );.      pLin
2ea0: 6b 2d 3e 70 4e 65 78 74 20 3d 20 70 54 61 62 2d  k->pNext = pTab-
2eb0: 3e 70 54 72 69 67 67 65 72 3b 0a 20 20 20 20 20  >pTrigger;.     
2ec0: 20 70 54 61 62 2d 3e 70 54 72 69 67 67 65 72 20   pTab->pTrigger 
2ed0: 3d 20 70 4c 69 6e 6b 3b 0a 20 20 20 20 7d 0a 20  = pLink;.    }. 
2ee0: 20 7d 0a 0a 74 72 69 67 67 65 72 66 69 6e 69 73   }..triggerfinis
2ef0: 68 5f 63 6c 65 61 6e 75 70 3a 0a 20 20 73 71 6c  h_cleanup:.  sql
2f00: 69 74 65 33 44 65 6c 65 74 65 54 72 69 67 67 65  ite3DeleteTrigge
2f10: 72 28 64 62 2c 20 70 54 72 69 67 29 3b 0a 20 20  r(db, pTrig);.  
2f20: 61 73 73 65 72 74 28 20 21 70 50 61 72 73 65 2d  assert( !pParse-
2f30: 3e 70 4e 65 77 54 72 69 67 67 65 72 20 29 3b 0a  >pNewTrigger );.
2f40: 20 20 73 71 6c 69 74 65 33 44 65 6c 65 74 65 54    sqlite3DeleteT
2f50: 72 69 67 67 65 72 53 74 65 70 28 64 62 2c 20 70  riggerStep(db, p
2f60: 53 74 65 70 4c 69 73 74 29 3b 0a 7d 0a 0a 2f 2a  StepList);.}../*
2f70: 0a 2a 2a 20 54 75 72 6e 20 61 20 53 45 4c 45 43  .** Turn a SELEC
2f80: 54 20 73 74 61 74 65 6d 65 6e 74 20 28 74 68 61  T statement (tha
2f90: 74 20 74 68 65 20 70 53 65 6c 65 63 74 20 70 61  t the pSelect pa
2fa0: 72 61 6d 65 74 65 72 20 70 6f 69 6e 74 73 20 74  rameter points t
2fb0: 6f 29 20 69 6e 74 6f 0a 2a 2a 20 61 20 74 72 69  o) into.** a tri
2fc0: 67 67 65 72 20 73 74 65 70 2e 20 20 52 65 74 75  gger step.  Retu
2fd0: 72 6e 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20  rn a pointer to 
2fe0: 61 20 54 72 69 67 67 65 72 53 74 65 70 20 73 74  a TriggerStep st
2ff0: 72 75 63 74 75 72 65 2e 0a 2a 2a 0a 2a 2a 20 54  ructure..**.** T
3000: 68 65 20 70 61 72 73 65 72 20 63 61 6c 6c 73 20  he parser calls 
3010: 74 68 69 73 20 72 6f 75 74 69 6e 65 20 77 68 65  this routine whe
3020: 6e 20 69 74 20 66 69 6e 64 73 20 61 20 53 45 4c  n it finds a SEL
3030: 45 43 54 20 73 74 61 74 65 6d 65 6e 74 20 69 6e  ECT statement in
3040: 0a 2a 2a 20 62 6f 64 79 20 6f 66 20 61 20 54 52  .** body of a TR
3050: 49 47 47 45 52 2e 20 20 0a 2a 2f 0a 54 72 69 67  IGGER.  .*/.Trig
3060: 67 65 72 53 74 65 70 20 2a 73 71 6c 69 74 65 33  gerStep *sqlite3
3070: 54 72 69 67 67 65 72 53 65 6c 65 63 74 53 74 65  TriggerSelectSte
3080: 70 28 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 53  p(sqlite3 *db, S
3090: 65 6c 65 63 74 20 2a 70 53 65 6c 65 63 74 29 7b  elect *pSelect){
30a0: 0a 20 20 54 72 69 67 67 65 72 53 74 65 70 20 2a  .  TriggerStep *
30b0: 70 54 72 69 67 67 65 72 53 74 65 70 20 3d 20 73  pTriggerStep = s
30c0: 71 6c 69 74 65 33 44 62 4d 61 6c 6c 6f 63 5a 65  qlite3DbMallocZe
30d0: 72 6f 28 64 62 2c 20 73 69 7a 65 6f 66 28 54 72  ro(db, sizeof(Tr
30e0: 69 67 67 65 72 53 74 65 70 29 29 3b 0a 20 20 69  iggerStep));.  i
30f0: 66 28 20 70 54 72 69 67 67 65 72 53 74 65 70 3d  f( pTriggerStep=
3100: 3d 30 20 29 20 7b 0a 20 20 20 20 73 71 6c 69 74  =0 ) {.    sqlit
3110: 65 33 53 65 6c 65 63 74 44 65 6c 65 74 65 28 64  e3SelectDelete(d
3120: 62 2c 20 70 53 65 6c 65 63 74 29 3b 0a 20 20 20  b, pSelect);.   
3130: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 20   return 0;.  }. 
3140: 20 70 54 72 69 67 67 65 72 53 74 65 70 2d 3e 6f   pTriggerStep->o
3150: 70 20 3d 20 54 4b 5f 53 45 4c 45 43 54 3b 0a 20  p = TK_SELECT;. 
3160: 20 70 54 72 69 67 67 65 72 53 74 65 70 2d 3e 70   pTriggerStep->p
3170: 53 65 6c 65 63 74 20 3d 20 70 53 65 6c 65 63 74  Select = pSelect
3180: 3b 0a 20 20 70 54 72 69 67 67 65 72 53 74 65 70  ;.  pTriggerStep
3190: 2d 3e 6f 72 63 6f 6e 66 20 3d 20 4f 45 5f 44 65  ->orconf = OE_De
31a0: 66 61 75 6c 74 3b 0a 20 20 72 65 74 75 72 6e 20  fault;.  return 
31b0: 70 54 72 69 67 67 65 72 53 74 65 70 3b 0a 7d 0a  pTriggerStep;.}.
31c0: 0a 2f 2a 0a 2a 2a 20 41 6c 6c 6f 63 61 74 65 20  ./*.** Allocate 
31d0: 73 70 61 63 65 20 74 6f 20 68 6f 6c 64 20 61 20  space to hold a 
31e0: 6e 65 77 20 74 72 69 67 67 65 72 20 73 74 65 70  new trigger step
31f0: 2e 20 20 54 68 65 20 61 6c 6c 6f 63 61 74 65 64  .  The allocated
3200: 20 73 70 61 63 65 0a 2a 2a 20 68 6f 6c 64 73 20   space.** holds 
3210: 62 6f 74 68 20 74 68 65 20 54 72 69 67 67 65 72  both the Trigger
3220: 53 74 65 70 20 6f 62 6a 65 63 74 20 61 6e 64 20  Step object and 
3230: 74 68 65 20 54 72 69 67 67 65 72 53 74 65 70 2e  the TriggerStep.
3240: 74 61 72 67 65 74 2e 7a 20 73 74 72 69 6e 67 2e  target.z string.
3250: 0a 2a 2a 0a 2a 2a 20 49 66 20 61 6e 20 4f 4f 4d  .**.** If an OOM
3260: 20 65 72 72 6f 72 20 6f 63 63 75 72 73 2c 20 4e   error occurs, N
3270: 55 4c 4c 20 69 73 20 72 65 74 75 72 6e 65 64 20  ULL is returned 
3280: 61 6e 64 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61  and db->mallocFa
3290: 69 6c 65 64 20 69 73 20 73 65 74 2e 0a 2a 2f 0a  iled is set..*/.
32a0: 73 74 61 74 69 63 20 54 72 69 67 67 65 72 53 74  static TriggerSt
32b0: 65 70 20 2a 74 72 69 67 67 65 72 53 74 65 70 41  ep *triggerStepA
32c0: 6c 6c 6f 63 61 74 65 28 0a 20 20 73 71 6c 69 74  llocate(.  sqlit
32d0: 65 33 20 2a 64 62 2c 20 20 20 20 20 20 20 20 20  e3 *db,         
32e0: 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61         /* Databa
32f0: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f  se connection */
3300: 0a 20 20 75 38 20 6f 70 2c 20 20 20 20 20 20 20  .  u8 op,       
3310: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3320: 2a 20 54 72 69 67 67 65 72 20 6f 70 63 6f 64 65  * Trigger opcode
3330: 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70 4e 61   */.  Token *pNa
3340: 6d 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20  me              
3350: 20 20 2f 2a 20 54 68 65 20 74 61 72 67 65 74 20    /* The target 
3360: 6e 61 6d 65 20 2a 2f 0a 29 7b 0a 20 20 54 72 69  name */.){.  Tri
3370: 67 67 65 72 53 74 65 70 20 2a 70 54 72 69 67 67  ggerStep *pTrigg
3380: 65 72 53 74 65 70 3b 0a 0a 20 20 70 54 72 69 67  erStep;..  pTrig
3390: 67 65 72 53 74 65 70 20 3d 20 73 71 6c 69 74 65  gerStep = sqlite
33a0: 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64 62  3DbMallocZero(db
33b0: 2c 20 73 69 7a 65 6f 66 28 54 72 69 67 67 65 72  , sizeof(Trigger
33c0: 53 74 65 70 29 20 2b 20 70 4e 61 6d 65 2d 3e 6e  Step) + pName->n
33d0: 20 2b 20 31 29 3b 0a 20 20 69 66 28 20 70 54 72   + 1);.  if( pTr
33e0: 69 67 67 65 72 53 74 65 70 20 29 7b 0a 20 20 20  iggerStep ){.   
33f0: 20 63 68 61 72 20 2a 7a 20 3d 20 28 63 68 61 72   char *z = (char
3400: 2a 29 26 70 54 72 69 67 67 65 72 53 74 65 70 5b  *)&pTriggerStep[
3410: 31 5d 3b 0a 20 20 20 20 6d 65 6d 63 70 79 28 7a  1];.    memcpy(z
3420: 2c 20 70 4e 61 6d 65 2d 3e 7a 2c 20 70 4e 61 6d  , pName->z, pNam
3430: 65 2d 3e 6e 29 3b 0a 20 20 20 20 73 71 6c 69 74  e->n);.    sqlit
3440: 65 33 44 65 71 75 6f 74 65 28 7a 29 3b 0a 20 20  e3Dequote(z);.  
3450: 20 20 70 54 72 69 67 67 65 72 53 74 65 70 2d 3e    pTriggerStep->
3460: 7a 54 61 72 67 65 74 20 3d 20 7a 3b 0a 20 20 20  zTarget = z;.   
3470: 20 70 54 72 69 67 67 65 72 53 74 65 70 2d 3e 6f   pTriggerStep->o
3480: 70 20 3d 20 6f 70 3b 0a 20 20 7d 0a 20 20 72 65  p = op;.  }.  re
3490: 74 75 72 6e 20 70 54 72 69 67 67 65 72 53 74 65  turn pTriggerSte
34a0: 70 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 42 75 69 6c  p;.}../*.** Buil
34b0: 64 20 61 20 74 72 69 67 67 65 72 20 73 74 65 70  d a trigger step
34c0: 20 6f 75 74 20 6f 66 20 61 6e 20 49 4e 53 45 52   out of an INSER
34d0: 54 20 73 74 61 74 65 6d 65 6e 74 2e 20 20 52 65  T statement.  Re
34e0: 74 75 72 6e 20 61 20 70 6f 69 6e 74 65 72 0a 2a  turn a pointer.*
34f0: 2a 20 74 6f 20 74 68 65 20 6e 65 77 20 74 72 69  * to the new tri
3500: 67 67 65 72 20 73 74 65 70 2e 0a 2a 2a 0a 2a 2a  gger step..**.**
3510: 20 54 68 65 20 70 61 72 73 65 72 20 63 61 6c 6c   The parser call
3520: 73 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 77  s this routine w
3530: 68 65 6e 20 69 74 20 73 65 65 73 20 61 6e 20 49  hen it sees an I
3540: 4e 53 45 52 54 20 69 6e 73 69 64 65 20 74 68 65  NSERT inside the
3550: 0a 2a 2a 20 62 6f 64 79 20 6f 66 20 61 20 74 72  .** body of a tr
3560: 69 67 67 65 72 2e 0a 2a 2f 0a 54 72 69 67 67 65  igger..*/.Trigge
3570: 72 53 74 65 70 20 2a 73 71 6c 69 74 65 33 54 72  rStep *sqlite3Tr
3580: 69 67 67 65 72 49 6e 73 65 72 74 53 74 65 70 28  iggerInsertStep(
3590: 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c 20  .  sqlite3 *db, 
35a0: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 64 61         /* The da
35b0: 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f  tabase connectio
35c0: 6e 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70 54  n */.  Token *pT
35d0: 61 62 6c 65 4e 61 6d 65 2c 20 20 2f 2a 20 4e 61  ableName,  /* Na
35e0: 6d 65 20 6f 66 20 74 68 65 20 74 61 62 6c 65 20  me of the table 
35f0: 69 6e 74 6f 20 77 68 69 63 68 20 77 65 20 69 6e  into which we in
3600: 73 65 72 74 20 2a 2f 0a 20 20 49 64 4c 69 73 74  sert */.  IdList
3610: 20 2a 70 43 6f 6c 75 6d 6e 2c 20 20 20 20 2f 2a   *pColumn,    /*
3620: 20 4c 69 73 74 20 6f 66 20 63 6f 6c 75 6d 6e 73   List of columns
3630: 20 69 6e 20 70 54 61 62 6c 65 4e 61 6d 65 20 74   in pTableName t
3640: 6f 20 69 6e 73 65 72 74 20 69 6e 74 6f 20 2a 2f  o insert into */
3650: 0a 20 20 53 65 6c 65 63 74 20 2a 70 53 65 6c 65  .  Select *pSele
3660: 63 74 2c 20 20 20 20 2f 2a 20 41 20 53 45 4c 45  ct,    /* A SELE
3670: 43 54 20 73 74 61 74 65 6d 65 6e 74 20 74 68 61  CT statement tha
3680: 74 20 73 75 70 70 6c 69 65 73 20 76 61 6c 75 65  t supplies value
3690: 73 20 2a 2f 0a 20 20 75 38 20 6f 72 63 6f 6e 66  s */.  u8 orconf
36a0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68             /* Th
36b0: 65 20 63 6f 6e 66 6c 69 63 74 20 61 6c 67 6f 72  e conflict algor
36c0: 69 74 68 6d 20 28 4f 45 5f 41 62 6f 72 74 2c 20  ithm (OE_Abort, 
36d0: 4f 45 5f 52 65 70 6c 61 63 65 2c 20 65 74 63 2e  OE_Replace, etc.
36e0: 29 20 2a 2f 0a 29 7b 0a 20 20 54 72 69 67 67 65  ) */.){.  Trigge
36f0: 72 53 74 65 70 20 2a 70 54 72 69 67 67 65 72 53  rStep *pTriggerS
3700: 74 65 70 3b 0a 0a 20 20 61 73 73 65 72 74 28 70  tep;..  assert(p
3710: 53 65 6c 65 63 74 20 21 3d 20 30 20 7c 7c 20 64  Select != 0 || d
3720: 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 29  b->mallocFailed)
3730: 3b 0a 0a 20 20 70 54 72 69 67 67 65 72 53 74 65  ;..  pTriggerSte
3740: 70 20 3d 20 74 72 69 67 67 65 72 53 74 65 70 41  p = triggerStepA
3750: 6c 6c 6f 63 61 74 65 28 64 62 2c 20 54 4b 5f 49  llocate(db, TK_I
3760: 4e 53 45 52 54 2c 20 70 54 61 62 6c 65 4e 61 6d  NSERT, pTableNam
3770: 65 29 3b 0a 20 20 69 66 28 20 70 54 72 69 67 67  e);.  if( pTrigg
3780: 65 72 53 74 65 70 20 29 7b 0a 20 20 20 20 70 54  erStep ){.    pT
3790: 72 69 67 67 65 72 53 74 65 70 2d 3e 70 53 65 6c  riggerStep->pSel
37a0: 65 63 74 20 3d 20 73 71 6c 69 74 65 33 53 65 6c  ect = sqlite3Sel
37b0: 65 63 74 44 75 70 28 64 62 2c 20 70 53 65 6c 65  ectDup(db, pSele
37c0: 63 74 2c 20 45 58 50 52 44 55 50 5f 52 45 44 55  ct, EXPRDUP_REDU
37d0: 43 45 29 3b 0a 20 20 20 20 70 54 72 69 67 67 65  CE);.    pTrigge
37e0: 72 53 74 65 70 2d 3e 70 49 64 4c 69 73 74 20 3d  rStep->pIdList =
37f0: 20 70 43 6f 6c 75 6d 6e 3b 0a 20 20 20 20 70 54   pColumn;.    pT
3800: 72 69 67 67 65 72 53 74 65 70 2d 3e 6f 72 63 6f  riggerStep->orco
3810: 6e 66 20 3d 20 6f 72 63 6f 6e 66 3b 0a 20 20 7d  nf = orconf;.  }
3820: 65 6c 73 65 7b 0a 20 20 20 20 73 71 6c 69 74 65  else{.    sqlite
3830: 33 49 64 4c 69 73 74 44 65 6c 65 74 65 28 64 62  3IdListDelete(db
3840: 2c 20 70 43 6f 6c 75 6d 6e 29 3b 0a 20 20 7d 0a  , pColumn);.  }.
3850: 20 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 44    sqlite3SelectD
3860: 65 6c 65 74 65 28 64 62 2c 20 70 53 65 6c 65 63  elete(db, pSelec
3870: 74 29 3b 0a 0a 20 20 72 65 74 75 72 6e 20 70 54  t);..  return pT
3880: 72 69 67 67 65 72 53 74 65 70 3b 0a 7d 0a 0a 2f  riggerStep;.}../
3890: 2a 0a 2a 2a 20 43 6f 6e 73 74 72 75 63 74 20 61  *.** Construct a
38a0: 20 74 72 69 67 67 65 72 20 73 74 65 70 20 74 68   trigger step th
38b0: 61 74 20 69 6d 70 6c 65 6d 65 6e 74 73 20 61 6e  at implements an
38c0: 20 55 50 44 41 54 45 20 73 74 61 74 65 6d 65 6e   UPDATE statemen
38d0: 74 20 61 6e 64 20 72 65 74 75 72 6e 0a 2a 2a 20  t and return.** 
38e0: 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 61  a pointer to tha
38f0: 74 20 74 72 69 67 67 65 72 20 73 74 65 70 2e 20  t trigger step. 
3900: 20 54 68 65 20 70 61 72 73 65 72 20 63 61 6c 6c   The parser call
3910: 73 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 77  s this routine w
3920: 68 65 6e 20 69 74 0a 2a 2a 20 73 65 65 73 20 61  hen it.** sees a
3930: 6e 20 55 50 44 41 54 45 20 73 74 61 74 65 6d 65  n UPDATE stateme
3940: 6e 74 20 69 6e 73 69 64 65 20 74 68 65 20 62 6f  nt inside the bo
3950: 64 79 20 6f 66 20 61 20 43 52 45 41 54 45 20 54  dy of a CREATE T
3960: 52 49 47 47 45 52 2e 0a 2a 2f 0a 54 72 69 67 67  RIGGER..*/.Trigg
3970: 65 72 53 74 65 70 20 2a 73 71 6c 69 74 65 33 54  erStep *sqlite3T
3980: 72 69 67 67 65 72 55 70 64 61 74 65 53 74 65 70  riggerUpdateStep
3990: 28 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c  (.  sqlite3 *db,
39a0: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
39b0: 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74  database connect
39c0: 69 6f 6e 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a  ion */.  Token *
39d0: 70 54 61 62 6c 65 4e 61 6d 65 2c 20 20 20 2f 2a  pTableName,   /*
39e0: 20 4e 61 6d 65 20 6f 66 20 74 68 65 20 74 61 62   Name of the tab
39f0: 6c 65 20 74 6f 20 62 65 20 75 70 64 61 74 65 64  le to be updated
3a00: 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73 74 20 2a   */.  ExprList *
3a10: 70 45 4c 69 73 74 2c 20 20 20 20 2f 2a 20 54 68  pEList,    /* Th
3a20: 65 20 53 45 54 20 63 6c 61 75 73 65 3a 20 6c 69  e SET clause: li
3a30: 73 74 20 6f 66 20 63 6f 6c 75 6d 6e 20 61 6e 64  st of column and
3a40: 20 6e 65 77 20 76 61 6c 75 65 73 20 2a 2f 0a 20   new values */. 
3a50: 20 45 78 70 72 20 2a 70 57 68 65 72 65 2c 20 20   Expr *pWhere,  
3a60: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 57 48 45        /* The WHE
3a70: 52 45 20 63 6c 61 75 73 65 20 2a 2f 0a 20 20 75  RE clause */.  u
3a80: 38 20 6f 72 63 6f 6e 66 20 20 20 20 20 20 20 20  8 orconf        
3a90: 20 20 20 20 2f 2a 20 54 68 65 20 63 6f 6e 66 6c      /* The confl
3aa0: 69 63 74 20 61 6c 67 6f 72 69 74 68 6d 2e 20 28  ict algorithm. (
3ab0: 4f 45 5f 41 62 6f 72 74 2c 20 4f 45 5f 49 67 6e  OE_Abort, OE_Ign
3ac0: 6f 72 65 2c 20 65 74 63 29 20 2a 2f 0a 29 7b 0a  ore, etc) */.){.
3ad0: 20 20 54 72 69 67 67 65 72 53 74 65 70 20 2a 70    TriggerStep *p
3ae0: 54 72 69 67 67 65 72 53 74 65 70 3b 0a 0a 20 20  TriggerStep;..  
3af0: 70 54 72 69 67 67 65 72 53 74 65 70 20 3d 20 74  pTriggerStep = t
3b00: 72 69 67 67 65 72 53 74 65 70 41 6c 6c 6f 63 61  riggerStepAlloca
3b10: 74 65 28 64 62 2c 20 54 4b 5f 55 50 44 41 54 45  te(db, TK_UPDATE
3b20: 2c 20 70 54 61 62 6c 65 4e 61 6d 65 29 3b 0a 20  , pTableName);. 
3b30: 20 69 66 28 20 70 54 72 69 67 67 65 72 53 74 65   if( pTriggerSte
3b40: 70 20 29 7b 0a 20 20 20 20 70 54 72 69 67 67 65  p ){.    pTrigge
3b50: 72 53 74 65 70 2d 3e 70 45 78 70 72 4c 69 73 74  rStep->pExprList
3b60: 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69   = sqlite3ExprLi
3b70: 73 74 44 75 70 28 64 62 2c 20 70 45 4c 69 73 74  stDup(db, pEList
3b80: 2c 20 45 58 50 52 44 55 50 5f 52 45 44 55 43 45  , EXPRDUP_REDUCE
3b90: 29 3b 0a 20 20 20 20 70 54 72 69 67 67 65 72 53  );.    pTriggerS
3ba0: 74 65 70 2d 3e 70 57 68 65 72 65 20 3d 20 73 71  tep->pWhere = sq
3bb0: 6c 69 74 65 33 45 78 70 72 44 75 70 28 64 62 2c  lite3ExprDup(db,
3bc0: 20 70 57 68 65 72 65 2c 20 45 58 50 52 44 55 50   pWhere, EXPRDUP
3bd0: 5f 52 45 44 55 43 45 29 3b 0a 20 20 20 20 70 54  _REDUCE);.    pT
3be0: 72 69 67 67 65 72 53 74 65 70 2d 3e 6f 72 63 6f  riggerStep->orco
3bf0: 6e 66 20 3d 20 6f 72 63 6f 6e 66 3b 0a 20 20 7d  nf = orconf;.  }
3c00: 0a 20 20 73 71 6c 69 74 65 33 45 78 70 72 4c 69  .  sqlite3ExprLi
3c10: 73 74 44 65 6c 65 74 65 28 64 62 2c 20 70 45 4c  stDelete(db, pEL
3c20: 69 73 74 29 3b 0a 20 20 73 71 6c 69 74 65 33 45  ist);.  sqlite3E
3c30: 78 70 72 44 65 6c 65 74 65 28 64 62 2c 20 70 57  xprDelete(db, pW
3c40: 68 65 72 65 29 3b 0a 20 20 72 65 74 75 72 6e 20  here);.  return 
3c50: 70 54 72 69 67 67 65 72 53 74 65 70 3b 0a 7d 0a  pTriggerStep;.}.
3c60: 0a 2f 2a 0a 2a 2a 20 43 6f 6e 73 74 72 75 63 74  ./*.** Construct
3c70: 20 61 20 74 72 69 67 67 65 72 20 73 74 65 70 20   a trigger step 
3c80: 74 68 61 74 20 69 6d 70 6c 65 6d 65 6e 74 73 20  that implements 
3c90: 61 20 44 45 4c 45 54 45 20 73 74 61 74 65 6d 65  a DELETE stateme
3ca0: 6e 74 20 61 6e 64 20 72 65 74 75 72 6e 0a 2a 2a  nt and return.**
3cb0: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68   a pointer to th
3cc0: 61 74 20 74 72 69 67 67 65 72 20 73 74 65 70 2e  at trigger step.
3cd0: 20 20 54 68 65 20 70 61 72 73 65 72 20 63 61 6c    The parser cal
3ce0: 6c 73 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20  ls this routine 
3cf0: 77 68 65 6e 20 69 74 0a 2a 2a 20 73 65 65 73 20  when it.** sees 
3d00: 61 20 44 45 4c 45 54 45 20 73 74 61 74 65 6d 65  a DELETE stateme
3d10: 6e 74 20 69 6e 73 69 64 65 20 74 68 65 20 62 6f  nt inside the bo
3d20: 64 79 20 6f 66 20 61 20 43 52 45 41 54 45 20 54  dy of a CREATE T
3d30: 52 49 47 47 45 52 2e 0a 2a 2f 0a 54 72 69 67 67  RIGGER..*/.Trigg
3d40: 65 72 53 74 65 70 20 2a 73 71 6c 69 74 65 33 54  erStep *sqlite3T
3d50: 72 69 67 67 65 72 44 65 6c 65 74 65 53 74 65 70  riggerDeleteStep
3d60: 28 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c  (.  sqlite3 *db,
3d70: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44              /* D
3d80: 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69  atabase connecti
3d90: 6f 6e 20 2a 2f 0a 20 20 54 6f 6b 65 6e 20 2a 70  on */.  Token *p
3da0: 54 61 62 6c 65 4e 61 6d 65 2c 20 20 20 20 20 20  TableName,      
3db0: 2f 2a 20 54 68 65 20 74 61 62 6c 65 20 66 72 6f  /* The table fro
3dc0: 6d 20 77 68 69 63 68 20 72 6f 77 73 20 61 72 65  m which rows are
3dd0: 20 64 65 6c 65 74 65 64 20 2a 2f 0a 20 20 45 78   deleted */.  Ex
3de0: 70 72 20 2a 70 57 68 65 72 65 20 20 20 20 20 20  pr *pWhere      
3df0: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 57 48 45        /* The WHE
3e00: 52 45 20 63 6c 61 75 73 65 20 2a 2f 0a 29 7b 0a  RE clause */.){.
3e10: 20 20 54 72 69 67 67 65 72 53 74 65 70 20 2a 70    TriggerStep *p
3e20: 54 72 69 67 67 65 72 53 74 65 70 3b 0a 0a 20 20  TriggerStep;..  
3e30: 70 54 72 69 67 67 65 72 53 74 65 70 20 3d 20 74  pTriggerStep = t
3e40: 72 69 67 67 65 72 53 74 65 70 41 6c 6c 6f 63 61  riggerStepAlloca
3e50: 74 65 28 64 62 2c 20 54 4b 5f 44 45 4c 45 54 45  te(db, TK_DELETE
3e60: 2c 20 70 54 61 62 6c 65 4e 61 6d 65 29 3b 0a 20  , pTableName);. 
3e70: 20 69 66 28 20 70 54 72 69 67 67 65 72 53 74 65   if( pTriggerSte
3e80: 70 20 29 7b 0a 20 20 20 20 70 54 72 69 67 67 65  p ){.    pTrigge
3e90: 72 53 74 65 70 2d 3e 70 57 68 65 72 65 20 3d 20  rStep->pWhere = 
3ea0: 73 71 6c 69 74 65 33 45 78 70 72 44 75 70 28 64  sqlite3ExprDup(d
3eb0: 62 2c 20 70 57 68 65 72 65 2c 20 45 58 50 52 44  b, pWhere, EXPRD
3ec0: 55 50 5f 52 45 44 55 43 45 29 3b 0a 20 20 20 20  UP_REDUCE);.    
3ed0: 70 54 72 69 67 67 65 72 53 74 65 70 2d 3e 6f 72  pTriggerStep->or
3ee0: 63 6f 6e 66 20 3d 20 4f 45 5f 44 65 66 61 75 6c  conf = OE_Defaul
3ef0: 74 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33  t;.  }.  sqlite3
3f00: 45 78 70 72 44 65 6c 65 74 65 28 64 62 2c 20 70  ExprDelete(db, p
3f10: 57 68 65 72 65 29 3b 0a 20 20 72 65 74 75 72 6e  Where);.  return
3f20: 20 70 54 72 69 67 67 65 72 53 74 65 70 3b 0a 7d   pTriggerStep;.}
3f30: 0a 0a 2f 2a 20 0a 2a 2a 20 52 65 63 75 72 73 69  ../* .** Recursi
3f40: 76 65 6c 79 20 64 65 6c 65 74 65 20 61 20 54 72  vely delete a Tr
3f50: 69 67 67 65 72 20 73 74 72 75 63 74 75 72 65 0a  igger structure.
3f60: 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 44  */.void sqlite3D
3f70: 65 6c 65 74 65 54 72 69 67 67 65 72 28 73 71 6c  eleteTrigger(sql
3f80: 69 74 65 33 20 2a 64 62 2c 20 54 72 69 67 67 65  ite3 *db, Trigge
3f90: 72 20 2a 70 54 72 69 67 67 65 72 29 7b 0a 20 20  r *pTrigger){.  
3fa0: 69 66 28 20 70 54 72 69 67 67 65 72 3d 3d 30 20  if( pTrigger==0 
3fb0: 29 20 72 65 74 75 72 6e 3b 0a 20 20 73 71 6c 69  ) return;.  sqli
3fc0: 74 65 33 44 65 6c 65 74 65 54 72 69 67 67 65 72  te3DeleteTrigger
3fd0: 53 74 65 70 28 64 62 2c 20 70 54 72 69 67 67 65  Step(db, pTrigge
3fe0: 72 2d 3e 73 74 65 70 5f 6c 69 73 74 29 3b 0a 20  r->step_list);. 
3ff0: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28 64   sqlite3DbFree(d
4000: 62 2c 20 70 54 72 69 67 67 65 72 2d 3e 7a 4e 61  b, pTrigger->zNa
4010: 6d 65 29 3b 0a 20 20 73 71 6c 69 74 65 33 44 62  me);.  sqlite3Db
4020: 46 72 65 65 28 64 62 2c 20 70 54 72 69 67 67 65  Free(db, pTrigge
4030: 72 2d 3e 74 61 62 6c 65 29 3b 0a 20 20 73 71 6c  r->table);.  sql
4040: 69 74 65 33 45 78 70 72 44 65 6c 65 74 65 28 64  ite3ExprDelete(d
4050: 62 2c 20 70 54 72 69 67 67 65 72 2d 3e 70 57 68  b, pTrigger->pWh
4060: 65 6e 29 3b 0a 20 20 73 71 6c 69 74 65 33 49 64  en);.  sqlite3Id
4070: 4c 69 73 74 44 65 6c 65 74 65 28 64 62 2c 20 70  ListDelete(db, p
4080: 54 72 69 67 67 65 72 2d 3e 70 43 6f 6c 75 6d 6e  Trigger->pColumn
4090: 73 29 3b 0a 20 20 73 71 6c 69 74 65 33 44 62 46  s);.  sqlite3DbF
40a0: 72 65 65 28 64 62 2c 20 70 54 72 69 67 67 65 72  ree(db, pTrigger
40b0: 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73  );.}../*.** This
40c0: 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61 6c   function is cal
40d0: 6c 65 64 20 74 6f 20 64 72 6f 70 20 61 20 74 72  led to drop a tr
40e0: 69 67 67 65 72 20 66 72 6f 6d 20 74 68 65 20 64  igger from the d
40f0: 61 74 61 62 61 73 65 20 73 63 68 65 6d 61 2e 20  atabase schema. 
4100: 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 6d 61 79 20  .**.** This may 
4110: 62 65 20 63 61 6c 6c 65 64 20 64 69 72 65 63 74  be called direct
4120: 6c 79 20 66 72 6f 6d 20 74 68 65 20 70 61 72 73  ly from the pars
4130: 65 72 20 61 6e 64 20 74 68 65 72 65 66 6f 72 65  er and therefore
4140: 20 69 64 65 6e 74 69 66 69 65 73 0a 2a 2a 20 74   identifies.** t
4150: 68 65 20 74 72 69 67 67 65 72 20 62 79 20 6e 61  he trigger by na
4160: 6d 65 2e 20 20 54 68 65 20 73 71 6c 69 74 65 33  me.  The sqlite3
4170: 44 72 6f 70 54 72 69 67 67 65 72 50 74 72 28 29  DropTriggerPtr()
4180: 20 72 6f 75 74 69 6e 65 20 64 6f 65 73 20 74 68   routine does th
4190: 65 0a 2a 2a 20 73 61 6d 65 20 6a 6f 62 20 61 73  e.** same job as
41a0: 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 65 78   this routine ex
41b0: 63 65 70 74 20 69 74 20 74 61 6b 65 73 20 61 20  cept it takes a 
41c0: 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 74  pointer to the t
41d0: 72 69 67 67 65 72 0a 2a 2a 20 69 6e 73 74 65 61  rigger.** instea
41e0: 64 20 6f 66 20 74 68 65 20 74 72 69 67 67 65 72  d of the trigger
41f0: 20 6e 61 6d 65 2e 0a 2a 2a 2f 0a 76 6f 69 64 20   name..**/.void 
4200: 73 71 6c 69 74 65 33 44 72 6f 70 54 72 69 67 67  sqlite3DropTrigg
4210: 65 72 28 50 61 72 73 65 20 2a 70 50 61 72 73 65  er(Parse *pParse
4220: 2c 20 53 72 63 4c 69 73 74 20 2a 70 4e 61 6d 65  , SrcList *pName
4230: 2c 20 69 6e 74 20 6e 6f 45 72 72 29 7b 0a 20 20  , int noErr){.  
4240: 54 72 69 67 67 65 72 20 2a 70 54 72 69 67 67 65  Trigger *pTrigge
4250: 72 20 3d 20 30 3b 0a 20 20 69 6e 74 20 69 3b 0a  r = 0;.  int i;.
4260: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44    const char *zD
4270: 62 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  b;.  const char 
4280: 2a 7a 4e 61 6d 65 3b 0a 20 20 73 71 6c 69 74 65  *zName;.  sqlite
4290: 33 20 2a 64 62 20 3d 20 70 50 61 72 73 65 2d 3e  3 *db = pParse->
42a0: 64 62 3b 0a 0a 20 20 69 66 28 20 64 62 2d 3e 6d  db;..  if( db->m
42b0: 61 6c 6c 6f 63 46 61 69 6c 65 64 20 29 20 67 6f  allocFailed ) go
42c0: 74 6f 20 64 72 6f 70 5f 74 72 69 67 67 65 72 5f  to drop_trigger_
42d0: 63 6c 65 61 6e 75 70 3b 0a 20 20 69 66 28 20 53  cleanup;.  if( S
42e0: 51 4c 49 54 45 5f 4f 4b 21 3d 73 71 6c 69 74 65  QLITE_OK!=sqlite
42f0: 33 52 65 61 64 53 63 68 65 6d 61 28 70 50 61 72  3ReadSchema(pPar
4300: 73 65 29 20 29 7b 0a 20 20 20 20 67 6f 74 6f 20  se) ){.    goto 
4310: 64 72 6f 70 5f 74 72 69 67 67 65 72 5f 63 6c 65  drop_trigger_cle
4320: 61 6e 75 70 3b 0a 20 20 7d 0a 0a 20 20 61 73 73  anup;.  }..  ass
4330: 65 72 74 28 20 70 4e 61 6d 65 2d 3e 6e 53 72 63  ert( pName->nSrc
4340: 3d 3d 31 20 29 3b 0a 20 20 7a 44 62 20 3d 20 70  ==1 );.  zDb = p
4350: 4e 61 6d 65 2d 3e 61 5b 30 5d 2e 7a 44 61 74 61  Name->a[0].zData
4360: 62 61 73 65 3b 0a 20 20 7a 4e 61 6d 65 20 3d 20  base;.  zName = 
4370: 70 4e 61 6d 65 2d 3e 61 5b 30 5d 2e 7a 4e 61 6d  pName->a[0].zNam
4380: 65 3b 0a 20 20 61 73 73 65 72 74 28 20 7a 44 62  e;.  assert( zDb
4390: 21 3d 30 20 7c 7c 20 73 71 6c 69 74 65 33 42 74  !=0 || sqlite3Bt
43a0: 72 65 65 48 6f 6c 64 73 41 6c 6c 4d 75 74 65 78  reeHoldsAllMutex
43b0: 65 73 28 64 62 29 20 29 3b 0a 20 20 66 6f 72 28  es(db) );.  for(
43c0: 69 3d 4f 4d 49 54 5f 54 45 4d 50 44 42 3b 20 69  i=OMIT_TEMPDB; i
43d0: 3c 64 62 2d 3e 6e 44 62 3b 20 69 2b 2b 29 7b 0a  <db->nDb; i++){.
43e0: 20 20 20 20 69 6e 74 20 6a 20 3d 20 28 69 3c 32      int j = (i<2
43f0: 29 20 3f 20 69 5e 31 20 3a 20 69 3b 20 20 2f 2a  ) ? i^1 : i;  /*
4400: 20 53 65 61 72 63 68 20 54 45 4d 50 20 62 65 66   Search TEMP bef
4410: 6f 72 65 20 4d 41 49 4e 20 2a 2f 0a 20 20 20 20  ore MAIN */.    
4420: 69 66 28 20 7a 44 62 20 26 26 20 73 71 6c 69 74  if( zDb && sqlit
4430: 65 33 53 74 72 49 43 6d 70 28 64 62 2d 3e 61 44  e3StrICmp(db->aD
4440: 62 5b 6a 5d 2e 7a 44 62 53 4e 61 6d 65 2c 20 7a  b[j].zDbSName, z
4450: 44 62 29 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a  Db) ) continue;.
4460: 20 20 20 20 61 73 73 65 72 74 28 20 73 71 6c 69      assert( sqli
4470: 74 65 33 53 63 68 65 6d 61 4d 75 74 65 78 48 65  te3SchemaMutexHe
4480: 6c 64 28 64 62 2c 20 6a 2c 20 30 29 20 29 3b 0a  ld(db, j, 0) );.
4490: 20 20 20 20 70 54 72 69 67 67 65 72 20 3d 20 73      pTrigger = s
44a0: 71 6c 69 74 65 33 48 61 73 68 46 69 6e 64 28 26  qlite3HashFind(&
44b0: 28 64 62 2d 3e 61 44 62 5b 6a 5d 2e 70 53 63 68  (db->aDb[j].pSch
44c0: 65 6d 61 2d 3e 74 72 69 67 48 61 73 68 29 2c 20  ema->trigHash), 
44d0: 7a 4e 61 6d 65 29 3b 0a 20 20 20 20 69 66 28 20  zName);.    if( 
44e0: 70 54 72 69 67 67 65 72 20 29 20 62 72 65 61 6b  pTrigger ) break
44f0: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 21 70 54 72  ;.  }.  if( !pTr
4500: 69 67 67 65 72 20 29 7b 0a 20 20 20 20 69 66 28  igger ){.    if(
4510: 20 21 6e 6f 45 72 72 20 29 7b 0a 20 20 20 20 20   !noErr ){.     
4520: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 4d 73 67   sqlite3ErrorMsg
4530: 28 70 50 61 72 73 65 2c 20 22 6e 6f 20 73 75 63  (pParse, "no suc
4540: 68 20 74 72 69 67 67 65 72 3a 20 25 53 22 2c 20  h trigger: %S", 
4550: 70 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 20 20 7d  pName, 0);.    }
4560: 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 71 6c 69  else{.      sqli
4570: 74 65 33 43 6f 64 65 56 65 72 69 66 79 4e 61 6d  te3CodeVerifyNam
4580: 65 64 53 63 68 65 6d 61 28 70 50 61 72 73 65 2c  edSchema(pParse,
4590: 20 7a 44 62 29 3b 0a 20 20 20 20 7d 0a 20 20 20   zDb);.    }.   
45a0: 20 70 50 61 72 73 65 2d 3e 63 68 65 63 6b 53 63   pParse->checkSc
45b0: 68 65 6d 61 20 3d 20 31 3b 0a 20 20 20 20 67 6f  hema = 1;.    go
45c0: 74 6f 20 64 72 6f 70 5f 74 72 69 67 67 65 72 5f  to drop_trigger_
45d0: 63 6c 65 61 6e 75 70 3b 0a 20 20 7d 0a 20 20 73  cleanup;.  }.  s
45e0: 71 6c 69 74 65 33 44 72 6f 70 54 72 69 67 67 65  qlite3DropTrigge
45f0: 72 50 74 72 28 70 50 61 72 73 65 2c 20 70 54 72  rPtr(pParse, pTr
4600: 69 67 67 65 72 29 3b 0a 0a 64 72 6f 70 5f 74 72  igger);..drop_tr
4610: 69 67 67 65 72 5f 63 6c 65 61 6e 75 70 3a 0a 20  igger_cleanup:. 
4620: 20 73 71 6c 69 74 65 33 53 72 63 4c 69 73 74 44   sqlite3SrcListD
4630: 65 6c 65 74 65 28 64 62 2c 20 70 4e 61 6d 65 29  elete(db, pName)
4640: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72  ;.}../*.** Retur
4650: 6e 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74  n a pointer to t
4660: 68 65 20 54 61 62 6c 65 20 73 74 72 75 63 74 75  he Table structu
4670: 72 65 20 66 6f 72 20 74 68 65 20 74 61 62 6c 65  re for the table
4680: 20 74 68 61 74 20 61 20 74 72 69 67 67 65 72 0a   that a trigger.
4690: 2a 2a 20 69 73 20 73 65 74 20 6f 6e 2e 0a 2a 2f  ** is set on..*/
46a0: 0a 73 74 61 74 69 63 20 54 61 62 6c 65 20 2a 74  .static Table *t
46b0: 61 62 6c 65 4f 66 54 72 69 67 67 65 72 28 54 72  ableOfTrigger(Tr
46c0: 69 67 67 65 72 20 2a 70 54 72 69 67 67 65 72 29  igger *pTrigger)
46d0: 7b 0a 20 20 72 65 74 75 72 6e 20 73 71 6c 69 74  {.  return sqlit
46e0: 65 33 48 61 73 68 46 69 6e 64 28 26 70 54 72 69  e3HashFind(&pTri
46f0: 67 67 65 72 2d 3e 70 54 61 62 53 63 68 65 6d 61  gger->pTabSchema
4700: 2d 3e 74 62 6c 48 61 73 68 2c 20 70 54 72 69 67  ->tblHash, pTrig
4710: 67 65 72 2d 3e 74 61 62 6c 65 29 3b 0a 7d 0a 0a  ger->table);.}..
4720: 0a 2f 2a 0a 2a 2a 20 44 72 6f 70 20 61 20 74 72  ./*.** Drop a tr
4730: 69 67 67 65 72 20 67 69 76 65 6e 20 61 20 70 6f  igger given a po
4740: 69 6e 74 65 72 20 74 6f 20 74 68 61 74 20 74 72  inter to that tr
4750: 69 67 67 65 72 2e 20 0a 2a 2f 0a 76 6f 69 64 20  igger. .*/.void 
4760: 73 71 6c 69 74 65 33 44 72 6f 70 54 72 69 67 67  sqlite3DropTrigg
4770: 65 72 50 74 72 28 50 61 72 73 65 20 2a 70 50 61  erPtr(Parse *pPa
4780: 72 73 65 2c 20 54 72 69 67 67 65 72 20 2a 70 54  rse, Trigger *pT
4790: 72 69 67 67 65 72 29 7b 0a 20 20 54 61 62 6c 65  rigger){.  Table
47a0: 20 20 20 2a 70 54 61 62 6c 65 3b 0a 20 20 56 64     *pTable;.  Vd
47b0: 62 65 20 2a 76 3b 0a 20 20 73 71 6c 69 74 65 33  be *v;.  sqlite3
47c0: 20 2a 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64   *db = pParse->d
47d0: 62 3b 0a 20 20 69 6e 74 20 69 44 62 3b 0a 0a 20  b;.  int iDb;.. 
47e0: 20 69 44 62 20 3d 20 73 71 6c 69 74 65 33 53 63   iDb = sqlite3Sc
47f0: 68 65 6d 61 54 6f 49 6e 64 65 78 28 70 50 61 72  hemaToIndex(pPar
4800: 73 65 2d 3e 64 62 2c 20 70 54 72 69 67 67 65 72  se->db, pTrigger
4810: 2d 3e 70 53 63 68 65 6d 61 29 3b 0a 20 20 61 73  ->pSchema);.  as
4820: 73 65 72 74 28 20 69 44 62 3e 3d 30 20 26 26 20  sert( iDb>=0 && 
4830: 69 44 62 3c 64 62 2d 3e 6e 44 62 20 29 3b 0a 20  iDb<db->nDb );. 
4840: 20 70 54 61 62 6c 65 20 3d 20 74 61 62 6c 65 4f   pTable = tableO
4850: 66 54 72 69 67 67 65 72 28 70 54 72 69 67 67 65  fTrigger(pTrigge
4860: 72 29 3b 0a 20 20 61 73 73 65 72 74 28 20 70 54  r);.  assert( pT
4870: 61 62 6c 65 20 29 3b 0a 20 20 61 73 73 65 72 74  able );.  assert
4880: 28 20 70 54 61 62 6c 65 2d 3e 70 53 63 68 65 6d  ( pTable->pSchem
4890: 61 3d 3d 70 54 72 69 67 67 65 72 2d 3e 70 53 63  a==pTrigger->pSc
48a0: 68 65 6d 61 20 7c 7c 20 69 44 62 3d 3d 31 20 29  hema || iDb==1 )
48b0: 3b 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  ;.#ifndef SQLITE
48c0: 5f 4f 4d 49 54 5f 41 55 54 48 4f 52 49 5a 41 54  _OMIT_AUTHORIZAT
48d0: 49 4f 4e 0a 20 20 7b 0a 20 20 20 20 69 6e 74 20  ION.  {.    int 
48e0: 63 6f 64 65 20 3d 20 53 51 4c 49 54 45 5f 44 52  code = SQLITE_DR
48f0: 4f 50 5f 54 52 49 47 47 45 52 3b 0a 20 20 20 20  OP_TRIGGER;.    
4900: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 20  const char *zDb 
4910: 3d 20 64 62 2d 3e 61 44 62 5b 69 44 62 5d 2e 7a  = db->aDb[iDb].z
4920: 44 62 53 4e 61 6d 65 3b 0a 20 20 20 20 63 6f 6e  DbSName;.    con
4930: 73 74 20 63 68 61 72 20 2a 7a 54 61 62 20 3d 20  st char *zTab = 
4940: 53 43 48 45 4d 41 5f 54 41 42 4c 45 28 69 44 62  SCHEMA_TABLE(iDb
4950: 29 3b 0a 20 20 20 20 69 66 28 20 69 44 62 3d 3d  );.    if( iDb==
4960: 31 20 29 20 63 6f 64 65 20 3d 20 53 51 4c 49 54  1 ) code = SQLIT
4970: 45 5f 44 52 4f 50 5f 54 45 4d 50 5f 54 52 49 47  E_DROP_TEMP_TRIG
4980: 47 45 52 3b 0a 20 20 20 20 69 66 28 20 73 71 6c  GER;.    if( sql
4990: 69 74 65 33 41 75 74 68 43 68 65 63 6b 28 70 50  ite3AuthCheck(pP
49a0: 61 72 73 65 2c 20 63 6f 64 65 2c 20 70 54 72 69  arse, code, pTri
49b0: 67 67 65 72 2d 3e 7a 4e 61 6d 65 2c 20 70 54 61  gger->zName, pTa
49c0: 62 6c 65 2d 3e 7a 4e 61 6d 65 2c 20 7a 44 62 29  ble->zName, zDb)
49d0: 20 7c 7c 0a 20 20 20 20 20 20 73 71 6c 69 74 65   ||.      sqlite
49e0: 33 41 75 74 68 43 68 65 63 6b 28 70 50 61 72 73  3AuthCheck(pPars
49f0: 65 2c 20 53 51 4c 49 54 45 5f 44 45 4c 45 54 45  e, SQLITE_DELETE
4a00: 2c 20 7a 54 61 62 2c 20 30 2c 20 7a 44 62 29 20  , zTab, 0, zDb) 
4a10: 29 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 3b  ){.      return;
4a20: 0a 20 20 20 20 7d 0a 20 20 7d 0a 23 65 6e 64 69  .    }.  }.#endi
4a30: 66 0a 0a 20 20 2f 2a 20 47 65 6e 65 72 61 74 65  f..  /* Generate
4a40: 20 63 6f 64 65 20 74 6f 20 64 65 73 74 72 6f 79   code to destroy
4a50: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 72 65   the database re
4a60: 63 6f 72 64 20 6f 66 20 74 68 65 20 74 72 69 67  cord of the trig
4a70: 67 65 72 2e 0a 20 20 2a 2f 0a 20 20 61 73 73 65  ger..  */.  asse
4a80: 72 74 28 20 70 54 61 62 6c 65 21 3d 30 20 29 3b  rt( pTable!=0 );
4a90: 0a 20 20 69 66 28 20 28 76 20 3d 20 73 71 6c 69  .  if( (v = sqli
4aa0: 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72 73  te3GetVdbe(pPars
4ab0: 65 29 29 21 3d 30 20 29 7b 0a 20 20 20 20 73 71  e))!=0 ){.    sq
4ac0: 6c 69 74 65 33 4e 65 73 74 65 64 50 61 72 73 65  lite3NestedParse
4ad0: 28 70 50 61 72 73 65 2c 0a 20 20 20 20 20 20 20  (pParse,.       
4ae0: 22 44 45 4c 45 54 45 20 46 52 4f 4d 20 25 51 2e  "DELETE FROM %Q.
4af0: 25 73 20 57 48 45 52 45 20 6e 61 6d 65 3d 25 51  %s WHERE name=%Q
4b00: 20 41 4e 44 20 74 79 70 65 3d 27 74 72 69 67 67   AND type='trigg
4b10: 65 72 27 22 2c 0a 20 20 20 20 20 20 20 64 62 2d  er'",.       db-
4b20: 3e 61 44 62 5b 69 44 62 5d 2e 7a 44 62 53 4e 61  >aDb[iDb].zDbSNa
4b30: 6d 65 2c 20 53 43 48 45 4d 41 5f 54 41 42 4c 45  me, SCHEMA_TABLE
4b40: 28 69 44 62 29 2c 20 70 54 72 69 67 67 65 72 2d  (iDb), pTrigger-
4b50: 3e 7a 4e 61 6d 65 0a 20 20 20 20 29 3b 0a 20 20  >zName.    );.  
4b60: 20 20 73 71 6c 69 74 65 33 43 68 61 6e 67 65 43    sqlite3ChangeC
4b70: 6f 6f 6b 69 65 28 70 50 61 72 73 65 2c 20 69 44  ookie(pParse, iD
4b80: 62 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 56  b);.    sqlite3V
4b90: 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f  dbeAddOp4(v, OP_
4ba0: 44 72 6f 70 54 72 69 67 67 65 72 2c 20 69 44 62  DropTrigger, iDb
4bb0: 2c 20 30 2c 20 30 2c 20 70 54 72 69 67 67 65 72  , 0, 0, pTrigger
4bc0: 2d 3e 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 7d  ->zName, 0);.  }
4bd0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 6d 6f 76 65  .}../*.** Remove
4be0: 20 61 20 74 72 69 67 67 65 72 20 66 72 6f 6d 20   a trigger from 
4bf0: 74 68 65 20 68 61 73 68 20 74 61 62 6c 65 73 20  the hash tables 
4c00: 6f 66 20 74 68 65 20 73 71 6c 69 74 65 2a 20 70  of the sqlite* p
4c10: 6f 69 6e 74 65 72 2e 0a 2a 2f 0a 76 6f 69 64 20  ointer..*/.void 
4c20: 73 71 6c 69 74 65 33 55 6e 6c 69 6e 6b 41 6e 64  sqlite3UnlinkAnd
4c30: 44 65 6c 65 74 65 54 72 69 67 67 65 72 28 73 71  DeleteTrigger(sq
4c40: 6c 69 74 65 33 20 2a 64 62 2c 20 69 6e 74 20 69  lite3 *db, int i
4c50: 44 62 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  Db, const char *
4c60: 7a 4e 61 6d 65 29 7b 0a 20 20 54 72 69 67 67 65  zName){.  Trigge
4c70: 72 20 2a 70 54 72 69 67 67 65 72 3b 0a 20 20 48  r *pTrigger;.  H
4c80: 61 73 68 20 2a 70 48 61 73 68 3b 0a 0a 20 20 61  ash *pHash;..  a
4c90: 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 53 63  ssert( sqlite3Sc
4ca0: 68 65 6d 61 4d 75 74 65 78 48 65 6c 64 28 64 62  hemaMutexHeld(db
4cb0: 2c 20 69 44 62 2c 20 30 29 20 29 3b 0a 20 20 70  , iDb, 0) );.  p
4cc0: 48 61 73 68 20 3d 20 26 28 64 62 2d 3e 61 44 62  Hash = &(db->aDb
4cd0: 5b 69 44 62 5d 2e 70 53 63 68 65 6d 61 2d 3e 74  [iDb].pSchema->t
4ce0: 72 69 67 48 61 73 68 29 3b 0a 20 20 70 54 72 69  rigHash);.  pTri
4cf0: 67 67 65 72 20 3d 20 73 71 6c 69 74 65 33 48 61  gger = sqlite3Ha
4d00: 73 68 49 6e 73 65 72 74 28 70 48 61 73 68 2c 20  shInsert(pHash, 
4d10: 7a 4e 61 6d 65 2c 20 30 29 3b 0a 20 20 69 66 28  zName, 0);.  if(
4d20: 20 41 4c 57 41 59 53 28 70 54 72 69 67 67 65 72   ALWAYS(pTrigger
4d30: 29 20 29 7b 0a 20 20 20 20 69 66 28 20 70 54 72  ) ){.    if( pTr
4d40: 69 67 67 65 72 2d 3e 70 53 63 68 65 6d 61 3d 3d  igger->pSchema==
4d50: 70 54 72 69 67 67 65 72 2d 3e 70 54 61 62 53 63  pTrigger->pTabSc
4d60: 68 65 6d 61 20 29 7b 0a 20 20 20 20 20 20 54 61  hema ){.      Ta
4d70: 62 6c 65 20 2a 70 54 61 62 20 3d 20 74 61 62 6c  ble *pTab = tabl
4d80: 65 4f 66 54 72 69 67 67 65 72 28 70 54 72 69 67  eOfTrigger(pTrig
4d90: 67 65 72 29 3b 0a 20 20 20 20 20 20 54 72 69 67  ger);.      Trig
4da0: 67 65 72 20 2a 2a 70 70 3b 0a 20 20 20 20 20 20  ger **pp;.      
4db0: 66 6f 72 28 70 70 3d 26 70 54 61 62 2d 3e 70 54  for(pp=&pTab->pT
4dc0: 72 69 67 67 65 72 3b 20 2a 70 70 21 3d 70 54 72  rigger; *pp!=pTr
4dd0: 69 67 67 65 72 3b 20 70 70 3d 26 28 28 2a 70 70  igger; pp=&((*pp
4de0: 29 2d 3e 70 4e 65 78 74 29 29 3b 0a 20 20 20 20  )->pNext));.    
4df0: 20 20 2a 70 70 20 3d 20 28 2a 70 70 29 2d 3e 70    *pp = (*pp)->p
4e00: 4e 65 78 74 3b 0a 20 20 20 20 7d 0a 20 20 20 20  Next;.    }.    
4e10: 73 71 6c 69 74 65 33 44 65 6c 65 74 65 54 72 69  sqlite3DeleteTri
4e20: 67 67 65 72 28 64 62 2c 20 70 54 72 69 67 67 65  gger(db, pTrigge
4e30: 72 29 3b 0a 20 20 20 20 64 62 2d 3e 66 6c 61 67  r);.    db->flag
4e40: 73 20 7c 3d 20 53 51 4c 49 54 45 5f 49 6e 74 65  s |= SQLITE_Inte
4e50: 72 6e 43 68 61 6e 67 65 73 3b 0a 20 20 7d 0a 7d  rnChanges;.  }.}
4e60: 0a 0a 2f 2a 0a 2a 2a 20 70 45 4c 69 73 74 20 69  ../*.** pEList i
4e70: 73 20 74 68 65 20 53 45 54 20 63 6c 61 75 73 65  s the SET clause
4e80: 20 6f 66 20 61 6e 20 55 50 44 41 54 45 20 73 74   of an UPDATE st
4e90: 61 74 65 6d 65 6e 74 2e 20 20 45 61 63 68 20 65  atement.  Each e
4ea0: 6e 74 72 79 0a 2a 2a 20 69 6e 20 70 45 4c 69 73  ntry.** in pELis
4eb0: 74 20 69 73 20 6f 66 20 74 68 65 20 66 6f 72 6d  t is of the form
4ec0: 61 74 20 3c 69 64 3e 3d 3c 65 78 70 72 3e 2e 20  at <id>=<expr>. 
4ed0: 20 49 66 20 61 6e 79 20 6f 66 20 74 68 65 20 65   If any of the e
4ee0: 6e 74 72 69 65 73 0a 2a 2a 20 69 6e 20 70 45 4c  ntries.** in pEL
4ef0: 69 73 74 20 68 61 76 65 20 61 6e 20 3c 69 64 3e  ist have an <id>
4f00: 20 77 68 69 63 68 20 6d 61 74 63 68 65 73 20 61   which matches a
4f10: 6e 20 69 64 65 6e 74 69 66 69 65 72 20 69 6e 20  n identifier in 
4f20: 70 49 64 4c 69 73 74 2c 0a 2a 2a 20 74 68 65 6e  pIdList,.** then
4f30: 20 72 65 74 75 72 6e 20 54 52 55 45 2e 20 20 49   return TRUE.  I
4f40: 66 20 70 49 64 4c 69 73 74 3d 3d 4e 55 4c 4c 2c  f pIdList==NULL,
4f50: 20 74 68 65 6e 20 69 74 20 69 73 20 63 6f 6e 73   then it is cons
4f60: 69 64 65 72 65 64 20 61 0a 2a 2a 20 77 69 6c 64  idered a.** wild
4f70: 63 61 72 64 20 74 68 61 74 20 6d 61 74 63 68 65  card that matche
4f80: 73 20 61 6e 79 74 68 69 6e 67 2e 20 20 4c 69 6b  s anything.  Lik
4f90: 65 77 69 73 65 20 69 66 20 70 45 4c 69 73 74 3d  ewise if pEList=
4fa0: 3d 4e 55 4c 4c 20 74 68 65 6e 0a 2a 2a 20 69 74  =NULL then.** it
4fb0: 20 6d 61 74 63 68 65 73 20 61 6e 79 74 68 69 6e   matches anythin
4fc0: 67 20 73 6f 20 61 6c 77 61 79 73 20 72 65 74 75  g so always retu
4fd0: 72 6e 20 74 72 75 65 2e 20 20 52 65 74 75 72 6e  rn true.  Return
4fe0: 20 66 61 6c 73 65 20 6f 6e 6c 79 0a 2a 2a 20 69   false only.** i
4ff0: 66 20 74 68 65 72 65 20 69 73 20 6e 6f 20 6d 61  f there is no ma
5000: 74 63 68 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  tch..*/.static i
5010: 6e 74 20 63 68 65 63 6b 43 6f 6c 75 6d 6e 4f 76  nt checkColumnOv
5020: 65 72 6c 61 70 28 49 64 4c 69 73 74 20 2a 70 49  erlap(IdList *pI
5030: 64 4c 69 73 74 2c 20 45 78 70 72 4c 69 73 74 20  dList, ExprList 
5040: 2a 70 45 4c 69 73 74 29 7b 0a 20 20 69 6e 74 20  *pEList){.  int 
5050: 65 3b 0a 20 20 69 66 28 20 70 49 64 4c 69 73 74  e;.  if( pIdList
5060: 3d 3d 30 20 7c 7c 20 4e 45 56 45 52 28 70 45 4c  ==0 || NEVER(pEL
5070: 69 73 74 3d 3d 30 29 20 29 20 72 65 74 75 72 6e  ist==0) ) return
5080: 20 31 3b 0a 20 20 66 6f 72 28 65 3d 30 3b 20 65   1;.  for(e=0; e
5090: 3c 70 45 4c 69 73 74 2d 3e 6e 45 78 70 72 3b 20  <pEList->nExpr; 
50a0: 65 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 73 71  e++){.    if( sq
50b0: 6c 69 74 65 33 49 64 4c 69 73 74 49 6e 64 65 78  lite3IdListIndex
50c0: 28 70 49 64 4c 69 73 74 2c 20 70 45 4c 69 73 74  (pIdList, pEList
50d0: 2d 3e 61 5b 65 5d 2e 7a 4e 61 6d 65 29 3e 3d 30  ->a[e].zName)>=0
50e0: 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 7d   ) return 1;.  }
50f0: 0a 20 20 72 65 74 75 72 6e 20 30 3b 20 0a 7d 0a  .  return 0; .}.
5100: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 61 20  ./*.** Return a 
5110: 6c 69 73 74 20 6f 66 20 61 6c 6c 20 74 72 69 67  list of all trig
5120: 67 65 72 73 20 6f 6e 20 74 61 62 6c 65 20 70 54  gers on table pT
5130: 61 62 20 69 66 20 74 68 65 72 65 20 65 78 69 73  ab if there exis
5140: 74 73 20 61 74 20 6c 65 61 73 74 0a 2a 2a 20 6f  ts at least.** o
5150: 6e 65 20 74 72 69 67 67 65 72 20 74 68 61 74 20  ne trigger that 
5160: 6d 75 73 74 20 62 65 20 66 69 72 65 64 20 77 68  must be fired wh
5170: 65 6e 20 61 6e 20 6f 70 65 72 61 74 69 6f 6e 20  en an operation 
5180: 6f 66 20 74 79 70 65 20 27 6f 70 27 20 69 73 20  of type 'op' is 
5190: 0a 2a 2a 20 70 65 72 66 6f 72 6d 65 64 20 6f 6e  .** performed on
51a0: 20 74 68 65 20 74 61 62 6c 65 2c 20 61 6e 64 2c   the table, and,
51b0: 20 69 66 20 74 68 61 74 20 6f 70 65 72 61 74 69   if that operati
51c0: 6f 6e 20 69 73 20 61 6e 20 55 50 44 41 54 45 2c  on is an UPDATE,
51d0: 20 69 66 20 61 74 0a 2a 2a 20 6c 65 61 73 74 20   if at.** least 
51e0: 6f 6e 65 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  one of the colum
51f0: 6e 73 20 69 6e 20 70 43 68 61 6e 67 65 73 20 69  ns in pChanges i
5200: 73 20 62 65 69 6e 67 20 6d 6f 64 69 66 69 65 64  s being modified
5210: 2e 0a 2a 2f 0a 54 72 69 67 67 65 72 20 2a 73 71  ..*/.Trigger *sq
5220: 6c 69 74 65 33 54 72 69 67 67 65 72 73 45 78 69  lite3TriggersExi
5230: 73 74 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61  st(.  Parse *pPa
5240: 72 73 65 2c 20 20 20 20 20 20 20 20 20 20 2f 2a  rse,          /*
5250: 20 50 61 72 73 65 20 63 6f 6e 74 65 78 74 20 2a   Parse context *
5260: 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54 61 62 2c  /.  Table *pTab,
5270: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
5280: 68 65 20 74 61 62 6c 65 20 74 68 65 20 63 6f 6e  he table the con
5290: 74 61 69 6e 73 20 74 68 65 20 74 72 69 67 67 65  tains the trigge
52a0: 72 73 20 2a 2f 0a 20 20 69 6e 74 20 6f 70 2c 20  rs */.  int op, 
52b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
52c0: 2f 2a 20 6f 6e 65 20 6f 66 20 54 4b 5f 44 45 4c  /* one of TK_DEL
52d0: 45 54 45 2c 20 54 4b 5f 49 4e 53 45 52 54 2c 20  ETE, TK_INSERT, 
52e0: 54 4b 5f 55 50 44 41 54 45 20 2a 2f 0a 20 20 45  TK_UPDATE */.  E
52f0: 78 70 72 4c 69 73 74 20 2a 70 43 68 61 6e 67 65  xprList *pChange
5300: 73 2c 20 20 20 20 20 2f 2a 20 43 6f 6c 75 6d 6e  s,     /* Column
5310: 73 20 74 68 61 74 20 63 68 61 6e 67 65 20 69 6e  s that change in
5320: 20 61 6e 20 55 50 44 41 54 45 20 73 74 61 74 65   an UPDATE state
5330: 6d 65 6e 74 20 2a 2f 0a 20 20 69 6e 74 20 2a 70  ment */.  int *p
5340: 4d 61 73 6b 20 20 20 20 20 20 20 20 20 20 20 20  Mask            
5350: 20 20 2f 2a 20 4f 55 54 3a 20 4d 61 73 6b 20 6f    /* OUT: Mask o
5360: 66 20 54 52 49 47 47 45 52 5f 42 45 46 4f 52 45  f TRIGGER_BEFORE
5370: 7c 54 52 49 47 47 45 52 5f 41 46 54 45 52 20 2a  |TRIGGER_AFTER *
5380: 2f 0a 29 7b 0a 20 20 69 6e 74 20 6d 61 73 6b 20  /.){.  int mask 
5390: 3d 20 30 3b 0a 20 20 54 72 69 67 67 65 72 20 2a  = 0;.  Trigger *
53a0: 70 4c 69 73 74 20 3d 20 30 3b 0a 20 20 54 72 69  pList = 0;.  Tri
53b0: 67 67 65 72 20 2a 70 3b 0a 0a 20 20 69 66 28 20  gger *p;..  if( 
53c0: 28 70 50 61 72 73 65 2d 3e 64 62 2d 3e 66 6c 61  (pParse->db->fla
53d0: 67 73 20 26 20 53 51 4c 49 54 45 5f 45 6e 61 62  gs & SQLITE_Enab
53e0: 6c 65 54 72 69 67 67 65 72 29 21 3d 30 20 29 7b  leTrigger)!=0 ){
53f0: 0a 20 20 20 20 70 4c 69 73 74 20 3d 20 73 71 6c  .    pList = sql
5400: 69 74 65 33 54 72 69 67 67 65 72 4c 69 73 74 28  ite3TriggerList(
5410: 70 50 61 72 73 65 2c 20 70 54 61 62 29 3b 0a 20  pParse, pTab);. 
5420: 20 7d 0a 20 20 61 73 73 65 72 74 28 20 70 4c 69   }.  assert( pLi
5430: 73 74 3d 3d 30 20 7c 7c 20 49 73 56 69 72 74 75  st==0 || IsVirtu
5440: 61 6c 28 70 54 61 62 29 3d 3d 30 20 29 3b 0a 20  al(pTab)==0 );. 
5450: 20 66 6f 72 28 70 3d 70 4c 69 73 74 3b 20 70 3b   for(p=pList; p;
5460: 20 70 3d 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20   p=p->pNext){.  
5470: 20 20 69 66 28 20 70 2d 3e 6f 70 3d 3d 6f 70 20    if( p->op==op 
5480: 26 26 20 63 68 65 63 6b 43 6f 6c 75 6d 6e 4f 76  && checkColumnOv
5490: 65 72 6c 61 70 28 70 2d 3e 70 43 6f 6c 75 6d 6e  erlap(p->pColumn
54a0: 73 2c 20 70 43 68 61 6e 67 65 73 29 20 29 7b 0a  s, pChanges) ){.
54b0: 20 20 20 20 20 20 6d 61 73 6b 20 7c 3d 20 70 2d        mask |= p-
54c0: 3e 74 72 5f 74 6d 3b 0a 20 20 20 20 7d 0a 20 20  >tr_tm;.    }.  
54d0: 7d 0a 20 20 69 66 28 20 70 4d 61 73 6b 20 29 7b  }.  if( pMask ){
54e0: 0a 20 20 20 20 2a 70 4d 61 73 6b 20 3d 20 6d 61  .    *pMask = ma
54f0: 73 6b 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e  sk;.  }.  return
5500: 20 28 6d 61 73 6b 20 3f 20 70 4c 69 73 74 20 3a   (mask ? pList :
5510: 20 30 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f   0);.}../*.** Co
5520: 6e 76 65 72 74 20 74 68 65 20 70 53 74 65 70 2d  nvert the pStep-
5530: 3e 7a 54 61 72 67 65 74 20 73 74 72 69 6e 67 20  >zTarget string 
5540: 69 6e 74 6f 20 61 20 53 72 63 4c 69 73 74 20 61  into a SrcList a
5550: 6e 64 20 72 65 74 75 72 6e 20 61 20 70 6f 69 6e  nd return a poin
5560: 74 65 72 0a 2a 2a 20 74 6f 20 74 68 61 74 20 53  ter.** to that S
5570: 72 63 4c 69 73 74 2e 0a 2a 2a 0a 2a 2a 20 54 68  rcList..**.** Th
5580: 69 73 20 72 6f 75 74 69 6e 65 20 61 64 64 73 20  is routine adds 
5590: 61 20 73 70 65 63 69 66 69 63 20 64 61 74 61 62  a specific datab
55a0: 61 73 65 20 6e 61 6d 65 2c 20 69 66 20 6e 65 65  ase name, if nee
55b0: 64 65 64 2c 20 74 6f 20 74 68 65 20 74 61 72 67  ded, to the targ
55c0: 65 74 20 77 68 65 6e 0a 2a 2a 20 66 6f 72 6d 69  et when.** formi
55d0: 6e 67 20 74 68 65 20 53 72 63 4c 69 73 74 2e 20  ng the SrcList. 
55e0: 20 54 68 69 73 20 70 72 65 76 65 6e 74 73 20 61   This prevents a
55f0: 20 74 72 69 67 67 65 72 20 69 6e 20 6f 6e 65 20   trigger in one 
5600: 64 61 74 61 62 61 73 65 20 66 72 6f 6d 0a 2a 2a  database from.**
5610: 20 72 65 66 65 72 72 69 6e 67 20 74 6f 20 61 20   referring to a 
5620: 74 61 72 67 65 74 20 69 6e 20 61 6e 6f 74 68 65  target in anothe
5630: 72 20 64 61 74 61 62 61 73 65 2e 20 20 41 6e 20  r database.  An 
5640: 65 78 63 65 70 74 69 6f 6e 20 69 73 20 77 68 65  exception is whe
5650: 6e 20 74 68 65 0a 2a 2a 20 74 72 69 67 67 65 72  n the.** trigger
5660: 20 69 73 20 69 6e 20 54 45 4d 50 20 69 6e 20 77   is in TEMP in w
5670: 68 69 63 68 20 63 61 73 65 20 69 74 20 63 61 6e  hich case it can
5680: 20 72 65 66 65 72 20 74 6f 20 61 6e 79 20 6f 74   refer to any ot
5690: 68 65 72 20 64 61 74 61 62 61 73 65 20 69 74 0a  her database it.
56a0: 2a 2a 20 77 61 6e 74 73 2e 0a 2a 2f 0a 73 74 61  ** wants..*/.sta
56b0: 74 69 63 20 53 72 63 4c 69 73 74 20 2a 74 61 72  tic SrcList *tar
56c0: 67 65 74 53 72 63 4c 69 73 74 28 0a 20 20 50 61  getSrcList(.  Pa
56d0: 72 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20  rse *pParse,    
56e0: 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73 69 6e     /* The parsin
56f0: 67 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54  g context */.  T
5700: 72 69 67 67 65 72 53 74 65 70 20 2a 70 53 74 65  riggerStep *pSte
5710: 70 20 20 20 2f 2a 20 54 68 65 20 74 72 69 67 67  p   /* The trigg
5720: 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68  er containing th
5730: 65 20 74 61 72 67 65 74 20 74 6f 6b 65 6e 20 2a  e target token *
5740: 2f 0a 29 7b 0a 20 20 73 71 6c 69 74 65 33 20 2a  /.){.  sqlite3 *
5750: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
5760: 0a 20 20 69 6e 74 20 69 44 62 3b 20 20 20 20 20  .  int iDb;     
5770: 20 20 20 20 20 20 20 20 2f 2a 20 49 6e 64 65 78          /* Index
5780: 20 6f 66 20 74 68 65 20 64 61 74 61 62 61 73 65   of the database
5790: 20 74 6f 20 75 73 65 20 2a 2f 0a 20 20 53 72 63   to use */.  Src
57a0: 4c 69 73 74 20 2a 70 53 72 63 3b 20 20 20 20 20  List *pSrc;     
57b0: 20 20 2f 2a 20 53 72 63 4c 69 73 74 20 74 6f 20    /* SrcList to 
57c0: 62 65 20 72 65 74 75 72 6e 65 64 20 2a 2f 0a 0a  be returned */..
57d0: 20 20 70 53 72 63 20 3d 20 73 71 6c 69 74 65 33    pSrc = sqlite3
57e0: 53 72 63 4c 69 73 74 41 70 70 65 6e 64 28 64 62  SrcListAppend(db
57f0: 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 20 20 69 66  , 0, 0, 0);.  if
5800: 28 20 70 53 72 63 20 29 7b 0a 20 20 20 20 61 73  ( pSrc ){.    as
5810: 73 65 72 74 28 20 70 53 72 63 2d 3e 6e 53 72 63  sert( pSrc->nSrc
5820: 3e 30 20 29 3b 0a 20 20 20 20 70 53 72 63 2d 3e  >0 );.    pSrc->
5830: 61 5b 70 53 72 63 2d 3e 6e 53 72 63 2d 31 5d 2e  a[pSrc->nSrc-1].
5840: 7a 4e 61 6d 65 20 3d 20 73 71 6c 69 74 65 33 44  zName = sqlite3D
5850: 62 53 74 72 44 75 70 28 64 62 2c 20 70 53 74 65  bStrDup(db, pSte
5860: 70 2d 3e 7a 54 61 72 67 65 74 29 3b 0a 20 20 20  p->zTarget);.   
5870: 20 69 44 62 20 3d 20 73 71 6c 69 74 65 33 53 63   iDb = sqlite3Sc
5880: 68 65 6d 61 54 6f 49 6e 64 65 78 28 64 62 2c 20  hemaToIndex(db, 
5890: 70 53 74 65 70 2d 3e 70 54 72 69 67 2d 3e 70 53  pStep->pTrig->pS
58a0: 63 68 65 6d 61 29 3b 0a 20 20 20 20 69 66 28 20  chema);.    if( 
58b0: 69 44 62 3d 3d 30 20 7c 7c 20 69 44 62 3e 3d 32  iDb==0 || iDb>=2
58c0: 20 29 7b 0a 20 20 20 20 20 20 63 6f 6e 73 74 20   ){.      const 
58d0: 63 68 61 72 20 2a 7a 44 62 3b 0a 20 20 20 20 20  char *zDb;.     
58e0: 20 61 73 73 65 72 74 28 20 69 44 62 3c 64 62 2d   assert( iDb<db-
58f0: 3e 6e 44 62 20 29 3b 0a 20 20 20 20 20 20 7a 44  >nDb );.      zD
5900: 62 20 3d 20 64 62 2d 3e 61 44 62 5b 69 44 62 5d  b = db->aDb[iDb]
5910: 2e 7a 44 62 53 4e 61 6d 65 3b 0a 20 20 20 20 20  .zDbSName;.     
5920: 20 70 53 72 63 2d 3e 61 5b 70 53 72 63 2d 3e 6e   pSrc->a[pSrc->n
5930: 53 72 63 2d 31 5d 2e 7a 44 61 74 61 62 61 73 65  Src-1].zDatabase
5940: 20 3d 20 20 73 71 6c 69 74 65 33 44 62 53 74 72   =  sqlite3DbStr
5950: 44 75 70 28 64 62 2c 20 7a 44 62 29 3b 0a 20 20  Dup(db, zDb);.  
5960: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
5970: 20 70 53 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20   pSrc;.}../*.** 
5980: 47 65 6e 65 72 61 74 65 20 56 44 42 45 20 63 6f  Generate VDBE co
5990: 64 65 20 66 6f 72 20 74 68 65 20 73 74 61 74 65  de for the state
59a0: 6d 65 6e 74 73 20 69 6e 73 69 64 65 20 74 68 65  ments inside the
59b0: 20 62 6f 64 79 20 6f 66 20 61 20 73 69 6e 67 6c   body of a singl
59c0: 65 20 0a 2a 2a 20 74 72 69 67 67 65 72 2e 0a 2a  e .** trigger..*
59d0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 63 6f 64  /.static int cod
59e0: 65 54 72 69 67 67 65 72 50 72 6f 67 72 61 6d 28  eTriggerProgram(
59f0: 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65  .  Parse *pParse
5a00: 2c 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  ,            /* 
5a10: 54 68 65 20 70 61 72 73 65 72 20 63 6f 6e 74 65  The parser conte
5a20: 78 74 20 2a 2f 0a 20 20 54 72 69 67 67 65 72 53  xt */.  TriggerS
5a30: 74 65 70 20 2a 70 53 74 65 70 4c 69 73 74 2c 20  tep *pStepList, 
5a40: 20 20 2f 2a 20 4c 69 73 74 20 6f 66 20 73 74 61    /* List of sta
5a50: 74 65 6d 65 6e 74 73 20 69 6e 73 69 64 65 20 74  tements inside t
5a60: 68 65 20 74 72 69 67 67 65 72 20 62 6f 64 79 20  he trigger body 
5a70: 2a 2f 0a 20 20 69 6e 74 20 6f 72 63 6f 6e 66 20  */.  int orconf 
5a80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5a90: 2a 20 43 6f 6e 66 6c 69 63 74 20 61 6c 67 6f 72  * Conflict algor
5aa0: 69 74 68 6d 2e 20 28 4f 45 5f 41 62 6f 72 74 2c  ithm. (OE_Abort,
5ab0: 20 65 74 63 29 20 2a 2f 20 20 0a 29 7b 0a 20 20   etc) */  .){.  
5ac0: 54 72 69 67 67 65 72 53 74 65 70 20 2a 70 53 74  TriggerStep *pSt
5ad0: 65 70 3b 0a 20 20 56 64 62 65 20 2a 76 20 3d 20  ep;.  Vdbe *v = 
5ae0: 70 50 61 72 73 65 2d 3e 70 56 64 62 65 3b 0a 20  pParse->pVdbe;. 
5af0: 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70   sqlite3 *db = p
5b00: 50 61 72 73 65 2d 3e 64 62 3b 0a 0a 20 20 61 73  Parse->db;..  as
5b10: 73 65 72 74 28 20 70 50 61 72 73 65 2d 3e 70 54  sert( pParse->pT
5b20: 72 69 67 67 65 72 54 61 62 20 26 26 20 70 50 61  riggerTab && pPa
5b30: 72 73 65 2d 3e 70 54 6f 70 6c 65 76 65 6c 20 29  rse->pToplevel )
5b40: 3b 0a 20 20 61 73 73 65 72 74 28 20 70 53 74 65  ;.  assert( pSte
5b50: 70 4c 69 73 74 20 29 3b 0a 20 20 61 73 73 65 72  pList );.  asser
5b60: 74 28 20 76 21 3d 30 20 29 3b 0a 20 20 66 6f 72  t( v!=0 );.  for
5b70: 28 70 53 74 65 70 3d 70 53 74 65 70 4c 69 73 74  (pStep=pStepList
5b80: 3b 20 70 53 74 65 70 3b 20 70 53 74 65 70 3d 70  ; pStep; pStep=p
5b90: 53 74 65 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20  Step->pNext){.  
5ba0: 20 20 2f 2a 20 46 69 67 75 72 65 20 6f 75 74 20    /* Figure out 
5bb0: 74 68 65 20 4f 4e 20 43 4f 4e 46 4c 49 43 54 20  the ON CONFLICT 
5bc0: 70 6f 6c 69 63 79 20 74 68 61 74 20 77 69 6c 6c  policy that will
5bd0: 20 62 65 20 75 73 65 64 20 66 6f 72 20 74 68 69   be used for thi
5be0: 73 20 73 74 65 70 0a 20 20 20 20 2a 2a 20 6f 66  s step.    ** of
5bf0: 20 74 68 65 20 74 72 69 67 67 65 72 20 70 72 6f   the trigger pro
5c00: 67 72 61 6d 2e 20 49 66 20 74 68 65 20 73 74 61  gram. If the sta
5c10: 74 65 6d 65 6e 74 20 74 68 61 74 20 63 61 75 73  tement that caus
5c20: 65 64 20 74 68 69 73 20 74 72 69 67 67 65 72 0a  ed this trigger.
5c30: 20 20 20 20 2a 2a 20 74 6f 20 66 69 72 65 20 68      ** to fire h
5c40: 61 64 20 61 6e 20 65 78 70 6c 69 63 69 74 20 4f  ad an explicit O
5c50: 4e 20 43 4f 4e 46 4c 49 43 54 2c 20 74 68 65 6e  N CONFLICT, then
5c60: 20 75 73 65 20 69 74 2e 20 4f 74 68 65 72 77 69   use it. Otherwi
5c70: 73 65 2c 20 75 73 65 0a 20 20 20 20 2a 2a 20 74  se, use.    ** t
5c80: 68 65 20 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 70  he ON CONFLICT p
5c90: 6f 6c 69 63 79 20 74 68 61 74 20 77 61 73 20 73  olicy that was s
5ca0: 70 65 63 69 66 69 65 64 20 61 73 20 70 61 72 74  pecified as part
5cb0: 20 6f 66 20 74 68 65 20 74 72 69 67 67 65 72 0a   of the trigger.
5cc0: 20 20 20 20 2a 2a 20 73 74 65 70 20 73 74 61 74      ** step stat
5cd0: 65 6d 65 6e 74 2e 20 45 78 61 6d 70 6c 65 3a 0a  ement. Example:.
5ce0: 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 20 20      **.    **   
5cf0: 43 52 45 41 54 45 20 54 52 49 47 47 45 52 20 41  CREATE TRIGGER A
5d00: 46 54 45 52 20 49 4e 53 45 52 54 20 4f 4e 20 74  FTER INSERT ON t
5d10: 31 20 42 45 47 49 4e 3b 0a 20 20 20 20 2a 2a 20  1 BEGIN;.    ** 
5d20: 20 20 20 20 49 4e 53 45 52 54 20 4f 52 20 52 45      INSERT OR RE
5d30: 50 4c 41 43 45 20 49 4e 54 4f 20 74 32 20 56 41  PLACE INTO t2 VA
5d40: 4c 55 45 53 28 6e 65 77 2e 61 2c 20 6e 65 77 2e  LUES(new.a, new.
5d50: 62 29 3b 0a 20 20 20 20 2a 2a 20 20 20 45 4e 44  b);.    **   END
5d60: 3b 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20  ;.    **.    ** 
5d70: 20 20 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31    INSERT INTO t1
5d80: 20 2e 2e 2e 20 3b 20 20 20 20 20 20 20 20 20 20   ... ;          
5d90: 20 20 2d 2d 20 69 6e 73 65 72 74 20 69 6e 74 6f    -- insert into
5da0: 20 74 32 20 75 73 65 73 20 52 45 50 4c 41 43 45   t2 uses REPLACE
5db0: 20 70 6f 6c 69 63 79 0a 20 20 20 20 2a 2a 20 20   policy.    **  
5dc0: 20 49 4e 53 45 52 54 20 4f 52 20 49 47 4e 4f 52   INSERT OR IGNOR
5dd0: 45 20 49 4e 54 4f 20 74 31 20 2e 2e 2e 20 3b 20  E INTO t1 ... ; 
5de0: 20 2d 2d 20 69 6e 73 65 72 74 20 69 6e 74 6f 20   -- insert into 
5df0: 74 32 20 75 73 65 73 20 49 47 4e 4f 52 45 20 70  t2 uses IGNORE p
5e00: 6f 6c 69 63 79 0a 20 20 20 20 2a 2f 0a 20 20 20  olicy.    */.   
5e10: 20 70 50 61 72 73 65 2d 3e 65 4f 72 63 6f 6e 66   pParse->eOrconf
5e20: 20 3d 20 28 6f 72 63 6f 6e 66 3d 3d 4f 45 5f 44   = (orconf==OE_D
5e30: 65 66 61 75 6c 74 29 3f 70 53 74 65 70 2d 3e 6f  efault)?pStep->o
5e40: 72 63 6f 6e 66 3a 28 75 38 29 6f 72 63 6f 6e 66  rconf:(u8)orconf
5e50: 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 70 50  ;.    assert( pP
5e60: 61 72 73 65 2d 3e 6f 6b 43 6f 6e 73 74 46 61 63  arse->okConstFac
5e70: 74 6f 72 3d 3d 30 20 29 3b 0a 0a 20 20 20 20 73  tor==0 );..    s
5e80: 77 69 74 63 68 28 20 70 53 74 65 70 2d 3e 6f 70  witch( pStep->op
5e90: 20 29 7b 0a 20 20 20 20 20 20 63 61 73 65 20 54   ){.      case T
5ea0: 4b 5f 55 50 44 41 54 45 3a 20 7b 0a 20 20 20 20  K_UPDATE: {.    
5eb0: 20 20 20 20 73 71 6c 69 74 65 33 55 70 64 61 74      sqlite3Updat
5ec0: 65 28 70 50 61 72 73 65 2c 20 0a 20 20 20 20 20  e(pParse, .     
5ed0: 20 20 20 20 20 74 61 72 67 65 74 53 72 63 4c 69       targetSrcLi
5ee0: 73 74 28 70 50 61 72 73 65 2c 20 70 53 74 65 70  st(pParse, pStep
5ef0: 29 2c 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c  ),.          sql
5f00: 69 74 65 33 45 78 70 72 4c 69 73 74 44 75 70 28  ite3ExprListDup(
5f10: 64 62 2c 20 70 53 74 65 70 2d 3e 70 45 78 70 72  db, pStep->pExpr
5f20: 4c 69 73 74 2c 20 30 29 2c 20 0a 20 20 20 20 20  List, 0), .     
5f30: 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72       sqlite3Expr
5f40: 44 75 70 28 64 62 2c 20 70 53 74 65 70 2d 3e 70  Dup(db, pStep->p
5f50: 57 68 65 72 65 2c 20 30 29 2c 20 0a 20 20 20 20  Where, 0), .    
5f60: 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 65 4f        pParse->eO
5f70: 72 63 6f 6e 66 0a 20 20 20 20 20 20 20 20 29 3b  rconf.        );
5f80: 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  .        break;.
5f90: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 63 61        }.      ca
5fa0: 73 65 20 54 4b 5f 49 4e 53 45 52 54 3a 20 7b 0a  se TK_INSERT: {.
5fb0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 49          sqlite3I
5fc0: 6e 73 65 72 74 28 70 50 61 72 73 65 2c 20 0a 20  nsert(pParse, . 
5fd0: 20 20 20 20 20 20 20 20 20 74 61 72 67 65 74 53           targetS
5fe0: 72 63 4c 69 73 74 28 70 50 61 72 73 65 2c 20 70  rcList(pParse, p
5ff0: 53 74 65 70 29 2c 0a 20 20 20 20 20 20 20 20 20  Step),.         
6000: 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 44 75   sqlite3SelectDu
6010: 70 28 64 62 2c 20 70 53 74 65 70 2d 3e 70 53 65  p(db, pStep->pSe
6020: 6c 65 63 74 2c 20 30 29 2c 20 0a 20 20 20 20 20  lect, 0), .     
6030: 20 20 20 20 20 73 71 6c 69 74 65 33 49 64 4c 69       sqlite3IdLi
6040: 73 74 44 75 70 28 64 62 2c 20 70 53 74 65 70 2d  stDup(db, pStep-
6050: 3e 70 49 64 4c 69 73 74 29 2c 20 0a 20 20 20 20  >pIdList), .    
6060: 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 65 4f        pParse->eO
6070: 72 63 6f 6e 66 0a 20 20 20 20 20 20 20 20 29 3b  rconf.        );
6080: 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  .        break;.
6090: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 63 61        }.      ca
60a0: 73 65 20 54 4b 5f 44 45 4c 45 54 45 3a 20 7b 0a  se TK_DELETE: {.
60b0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 44          sqlite3D
60c0: 65 6c 65 74 65 46 72 6f 6d 28 70 50 61 72 73 65  eleteFrom(pParse
60d0: 2c 20 0a 20 20 20 20 20 20 20 20 20 20 74 61 72  , .          tar
60e0: 67 65 74 53 72 63 4c 69 73 74 28 70 50 61 72 73  getSrcList(pPars
60f0: 65 2c 20 70 53 74 65 70 29 2c 0a 20 20 20 20 20  e, pStep),.     
6100: 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72       sqlite3Expr
6110: 44 75 70 28 64 62 2c 20 70 53 74 65 70 2d 3e 70  Dup(db, pStep->p
6120: 57 68 65 72 65 2c 20 30 29 0a 20 20 20 20 20 20  Where, 0).      
6130: 20 20 29 3b 0a 20 20 20 20 20 20 20 20 62 72 65    );.        bre
6140: 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ak;.      }.    
6150: 20 20 64 65 66 61 75 6c 74 3a 20 61 73 73 65 72    default: asser
6160: 74 28 20 70 53 74 65 70 2d 3e 6f 70 3d 3d 54 4b  t( pStep->op==TK
6170: 5f 53 45 4c 45 43 54 20 29 3b 20 7b 0a 20 20 20  _SELECT ); {.   
6180: 20 20 20 20 20 53 65 6c 65 63 74 44 65 73 74 20       SelectDest 
6190: 73 44 65 73 74 3b 0a 20 20 20 20 20 20 20 20 53  sDest;.        S
61a0: 65 6c 65 63 74 20 2a 70 53 65 6c 65 63 74 20 3d  elect *pSelect =
61b0: 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 44 75   sqlite3SelectDu
61c0: 70 28 64 62 2c 20 70 53 74 65 70 2d 3e 70 53 65  p(db, pStep->pSe
61d0: 6c 65 63 74 2c 20 30 29 3b 0a 20 20 20 20 20 20  lect, 0);.      
61e0: 20 20 73 71 6c 69 74 65 33 53 65 6c 65 63 74 44    sqlite3SelectD
61f0: 65 73 74 49 6e 69 74 28 26 73 44 65 73 74 2c 20  estInit(&sDest, 
6200: 53 52 54 5f 44 69 73 63 61 72 64 2c 20 30 29 3b  SRT_Discard, 0);
6210: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
6220: 53 65 6c 65 63 74 28 70 50 61 72 73 65 2c 20 70  Select(pParse, p
6230: 53 65 6c 65 63 74 2c 20 26 73 44 65 73 74 29 3b  Select, &sDest);
6240: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
6250: 53 65 6c 65 63 74 44 65 6c 65 74 65 28 64 62 2c  SelectDelete(db,
6260: 20 70 53 65 6c 65 63 74 29 3b 0a 20 20 20 20 20   pSelect);.     
6270: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20     break;.      
6280: 7d 0a 20 20 20 20 7d 20 0a 20 20 20 20 69 66 28  }.    } .    if(
6290: 20 70 53 74 65 70 2d 3e 6f 70 21 3d 54 4b 5f 53   pStep->op!=TK_S
62a0: 45 4c 45 43 54 20 29 7b 0a 20 20 20 20 20 20 73  ELECT ){.      s
62b0: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 30  qlite3VdbeAddOp0
62c0: 28 76 2c 20 4f 50 5f 52 65 73 65 74 43 6f 75 6e  (v, OP_ResetCoun
62d0: 74 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20  t);.    }.  }.. 
62e0: 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 23 69   return 0;.}..#i
62f0: 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42  fdef SQLITE_ENAB
6300: 4c 45 5f 45 58 50 4c 41 49 4e 5f 43 4f 4d 4d 45  LE_EXPLAIN_COMME
6310: 4e 54 53 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 66  NTS./*.** This f
6320: 75 6e 63 74 69 6f 6e 20 69 73 20 75 73 65 64 20  unction is used 
6330: 74 6f 20 61 64 64 20 56 64 62 65 43 6f 6d 6d 65  to add VdbeComme
6340: 6e 74 28 29 20 61 6e 6e 6f 74 61 74 69 6f 6e 73  nt() annotations
6350: 20 74 6f 20 61 20 56 44 42 45 0a 2a 2a 20 70 72   to a VDBE.** pr
6360: 6f 67 72 61 6d 2e 20 49 74 20 69 73 20 6e 6f 74  ogram. It is not
6370: 20 75 73 65 64 20 69 6e 20 70 72 6f 64 75 63 74   used in product
6380: 69 6f 6e 20 63 6f 64 65 2c 20 6f 6e 6c 79 20 66  ion code, only f
6390: 6f 72 20 64 65 62 75 67 67 69 6e 67 2e 0a 2a 2f  or debugging..*/
63a0: 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20 63 68  .static const ch
63b0: 61 72 20 2a 6f 6e 45 72 72 6f 72 54 65 78 74 28  ar *onErrorText(
63c0: 69 6e 74 20 6f 6e 45 72 72 6f 72 29 7b 0a 20 20  int onError){.  
63d0: 73 77 69 74 63 68 28 20 6f 6e 45 72 72 6f 72 20  switch( onError 
63e0: 29 7b 0a 20 20 20 20 63 61 73 65 20 4f 45 5f 41  ){.    case OE_A
63f0: 62 6f 72 74 3a 20 20 20 20 72 65 74 75 72 6e 20  bort:    return 
6400: 22 61 62 6f 72 74 22 3b 0a 20 20 20 20 63 61 73  "abort";.    cas
6410: 65 20 4f 45 5f 52 6f 6c 6c 62 61 63 6b 3a 20 72  e OE_Rollback: r
6420: 65 74 75 72 6e 20 22 72 6f 6c 6c 62 61 63 6b 22  eturn "rollback"
6430: 3b 0a 20 20 20 20 63 61 73 65 20 4f 45 5f 46 61  ;.    case OE_Fa
6440: 69 6c 3a 20 20 20 20 20 72 65 74 75 72 6e 20 22  il:     return "
6450: 66 61 69 6c 22 3b 0a 20 20 20 20 63 61 73 65 20  fail";.    case 
6460: 4f 45 5f 52 65 70 6c 61 63 65 3a 20 20 72 65 74  OE_Replace:  ret
6470: 75 72 6e 20 22 72 65 70 6c 61 63 65 22 3b 0a 20  urn "replace";. 
6480: 20 20 20 63 61 73 65 20 4f 45 5f 49 67 6e 6f 72     case OE_Ignor
6490: 65 3a 20 20 20 72 65 74 75 72 6e 20 22 69 67 6e  e:   return "ign
64a0: 6f 72 65 22 3b 0a 20 20 20 20 63 61 73 65 20 4f  ore";.    case O
64b0: 45 5f 44 65 66 61 75 6c 74 3a 20 20 72 65 74 75  E_Default:  retu
64c0: 72 6e 20 22 64 65 66 61 75 6c 74 22 3b 0a 20 20  rn "default";.  
64d0: 7d 0a 20 20 72 65 74 75 72 6e 20 22 6e 2f 61 22  }.  return "n/a"
64e0: 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a  ;.}.#endif../*.*
64f0: 2a 20 50 61 72 73 65 20 63 6f 6e 74 65 78 74 20  * Parse context 
6500: 73 74 72 75 63 74 75 72 65 20 70 46 72 6f 6d 20  structure pFrom 
6510: 68 61 73 20 6a 75 73 74 20 62 65 65 6e 20 75 73  has just been us
6520: 65 64 20 74 6f 20 63 72 65 61 74 65 20 61 20 73  ed to create a s
6530: 75 62 2d 76 64 62 65 0a 2a 2a 20 28 74 72 69 67  ub-vdbe.** (trig
6540: 67 65 72 20 70 72 6f 67 72 61 6d 29 2e 20 49 66  ger program). If
6550: 20 61 6e 20 65 72 72 6f 72 20 68 61 73 20 6f 63   an error has oc
6560: 63 75 72 72 65 64 2c 20 74 72 61 6e 73 66 65 72  curred, transfer
6570: 20 65 72 72 6f 72 20 69 6e 66 6f 72 6d 61 74 69   error informati
6580: 6f 6e 0a 2a 2a 20 66 72 6f 6d 20 70 46 72 6f 6d  on.** from pFrom
6590: 20 74 6f 20 70 54 6f 2e 0a 2a 2f 0a 73 74 61 74   to pTo..*/.stat
65a0: 69 63 20 76 6f 69 64 20 74 72 61 6e 73 66 65 72  ic void transfer
65b0: 50 61 72 73 65 45 72 72 6f 72 28 50 61 72 73 65  ParseError(Parse
65c0: 20 2a 70 54 6f 2c 20 50 61 72 73 65 20 2a 70 46   *pTo, Parse *pF
65d0: 72 6f 6d 29 7b 0a 20 20 61 73 73 65 72 74 28 20  rom){.  assert( 
65e0: 70 46 72 6f 6d 2d 3e 7a 45 72 72 4d 73 67 3d 3d  pFrom->zErrMsg==
65f0: 30 20 7c 7c 20 70 46 72 6f 6d 2d 3e 6e 45 72 72  0 || pFrom->nErr
6600: 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 70 54   );.  assert( pT
6610: 6f 2d 3e 7a 45 72 72 4d 73 67 3d 3d 30 20 7c 7c  o->zErrMsg==0 ||
6620: 20 70 54 6f 2d 3e 6e 45 72 72 20 29 3b 0a 20 20   pTo->nErr );.  
6630: 69 66 28 20 70 54 6f 2d 3e 6e 45 72 72 3d 3d 30  if( pTo->nErr==0
6640: 20 29 7b 0a 20 20 20 20 70 54 6f 2d 3e 7a 45 72   ){.    pTo->zEr
6650: 72 4d 73 67 20 3d 20 70 46 72 6f 6d 2d 3e 7a 45  rMsg = pFrom->zE
6660: 72 72 4d 73 67 3b 0a 20 20 20 20 70 54 6f 2d 3e  rrMsg;.    pTo->
6670: 6e 45 72 72 20 3d 20 70 46 72 6f 6d 2d 3e 6e 45  nErr = pFrom->nE
6680: 72 72 3b 0a 20 20 20 20 70 54 6f 2d 3e 72 63 20  rr;.    pTo->rc 
6690: 3d 20 70 46 72 6f 6d 2d 3e 72 63 3b 0a 20 20 7d  = pFrom->rc;.  }
66a0: 65 6c 73 65 7b 0a 20 20 20 20 73 71 6c 69 74 65  else{.    sqlite
66b0: 33 44 62 46 72 65 65 28 70 46 72 6f 6d 2d 3e 64  3DbFree(pFrom->d
66c0: 62 2c 20 70 46 72 6f 6d 2d 3e 7a 45 72 72 4d 73  b, pFrom->zErrMs
66d0: 67 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a  g);.  }.}../*.**
66e0: 20 43 72 65 61 74 65 20 61 6e 64 20 70 6f 70 75   Create and popu
66f0: 6c 61 74 65 20 61 20 6e 65 77 20 54 72 69 67 67  late a new Trigg
6700: 65 72 50 72 67 20 6f 62 6a 65 63 74 20 77 69 74  erPrg object wit
6710: 68 20 61 20 73 75 62 2d 70 72 6f 67 72 61 6d 20  h a sub-program 
6720: 0a 2a 2a 20 69 6d 70 6c 65 6d 65 6e 74 69 6e 67  .** implementing
6730: 20 74 72 69 67 67 65 72 20 70 54 72 69 67 67 65   trigger pTrigge
6740: 72 20 77 69 74 68 20 4f 4e 20 43 4f 4e 46 4c 49  r with ON CONFLI
6750: 43 54 20 70 6f 6c 69 63 79 20 6f 72 63 6f 6e 66  CT policy orconf
6760: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 54 72 69 67  ..*/.static Trig
6770: 67 65 72 50 72 67 20 2a 63 6f 64 65 52 6f 77 54  gerPrg *codeRowT
6780: 72 69 67 67 65 72 28 0a 20 20 50 61 72 73 65 20  rigger(.  Parse 
6790: 2a 70 50 61 72 73 65 2c 20 20 20 20 20 20 20 2f  *pParse,       /
67a0: 2a 20 43 75 72 72 65 6e 74 20 70 61 72 73 65 20  * Current parse 
67b0: 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54 72 69  context */.  Tri
67c0: 67 67 65 72 20 2a 70 54 72 69 67 67 65 72 2c 20  gger *pTrigger, 
67d0: 20 20 2f 2a 20 54 72 69 67 67 65 72 20 74 6f 20    /* Trigger to 
67e0: 63 6f 64 65 20 2a 2f 0a 20 20 54 61 62 6c 65 20  code */.  Table 
67f0: 2a 70 54 61 62 2c 20 20 20 20 20 20 20 20 20 2f  *pTab,         /
6800: 2a 20 54 68 65 20 74 61 62 6c 65 20 70 54 72 69  * The table pTri
6810: 67 67 65 72 20 69 73 20 61 74 74 61 63 68 65 64  gger is attached
6820: 20 74 6f 20 2a 2f 0a 20 20 69 6e 74 20 6f 72 63   to */.  int orc
6830: 6f 6e 66 20 20 20 20 20 20 20 20 20 20 20 2f 2a  onf           /*
6840: 20 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 70 6f 6c   ON CONFLICT pol
6850: 69 63 79 20 74 6f 20 63 6f 64 65 20 74 72 69 67  icy to code trig
6860: 67 65 72 20 70 72 6f 67 72 61 6d 20 77 69 74 68  ger program with
6870: 20 2a 2f 0a 29 7b 0a 20 20 50 61 72 73 65 20 2a   */.){.  Parse *
6880: 70 54 6f 70 20 3d 20 73 71 6c 69 74 65 33 50 61  pTop = sqlite3Pa
6890: 72 73 65 54 6f 70 6c 65 76 65 6c 28 70 50 61 72  rseToplevel(pPar
68a0: 73 65 29 3b 0a 20 20 73 71 6c 69 74 65 33 20 2a  se);.  sqlite3 *
68b0: 64 62 20 3d 20 70 50 61 72 73 65 2d 3e 64 62 3b  db = pParse->db;
68c0: 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 68     /* Database h
68d0: 61 6e 64 6c 65 20 2a 2f 0a 20 20 54 72 69 67 67  andle */.  Trigg
68e0: 65 72 50 72 67 20 2a 70 50 72 67 3b 20 20 20 20  erPrg *pPrg;    
68f0: 20 20 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20         /* Value 
6900: 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a 20 20 45  to return */.  E
6910: 78 70 72 20 2a 70 57 68 65 6e 20 3d 20 30 3b 20  xpr *pWhen = 0; 
6920: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 75             /* Du
6930: 70 6c 69 63 61 74 65 20 6f 66 20 74 72 69 67 67  plicate of trigg
6940: 65 72 20 57 48 45 4e 20 65 78 70 72 65 73 73 69  er WHEN expressi
6950: 6f 6e 20 2a 2f 0a 20 20 56 64 62 65 20 2a 76 3b  on */.  Vdbe *v;
6960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6970: 20 20 20 20 2f 2a 20 54 65 6d 70 6f 72 61 72 79      /* Temporary
6980: 20 56 4d 20 2a 2f 0a 20 20 4e 61 6d 65 43 6f 6e   VM */.  NameCon
6990: 74 65 78 74 20 73 4e 43 3b 20 20 20 20 20 20 20  text sNC;       
69a0: 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 63 6f 6e       /* Name con
69b0: 74 65 78 74 20 66 6f 72 20 73 75 62 2d 76 64 62  text for sub-vdb
69c0: 65 20 2a 2f 0a 20 20 53 75 62 50 72 6f 67 72 61  e */.  SubProgra
69d0: 6d 20 2a 70 50 72 6f 67 72 61 6d 20 3d 20 30 3b  m *pProgram = 0;
69e0: 20 20 20 2f 2a 20 53 75 62 2d 76 64 62 65 20 66     /* Sub-vdbe f
69f0: 6f 72 20 74 72 69 67 67 65 72 20 70 72 6f 67 72  or trigger progr
6a00: 61 6d 20 2a 2f 0a 20 20 50 61 72 73 65 20 2a 70  am */.  Parse *p
6a10: 53 75 62 50 61 72 73 65 3b 20 20 20 20 20 20 20  SubParse;       
6a20: 20 20 20 20 2f 2a 20 50 61 72 73 65 20 63 6f 6e      /* Parse con
6a30: 74 65 78 74 20 66 6f 72 20 73 75 62 2d 76 64 62  text for sub-vdb
6a40: 65 20 2a 2f 0a 20 20 69 6e 74 20 69 45 6e 64 54  e */.  int iEndT
6a50: 72 69 67 67 65 72 20 3d 20 30 3b 20 20 20 20 20  rigger = 0;     
6a60: 20 20 20 2f 2a 20 4c 61 62 65 6c 20 74 6f 20 6a     /* Label to j
6a70: 75 6d 70 20 74 6f 20 69 66 20 57 48 45 4e 20 69  ump to if WHEN i
6a80: 73 20 66 61 6c 73 65 20 2a 2f 0a 0a 20 20 61 73  s false */..  as
6a90: 73 65 72 74 28 20 70 54 72 69 67 67 65 72 2d 3e  sert( pTrigger->
6aa0: 7a 4e 61 6d 65 3d 3d 30 20 7c 7c 20 70 54 61 62  zName==0 || pTab
6ab0: 3d 3d 74 61 62 6c 65 4f 66 54 72 69 67 67 65 72  ==tableOfTrigger
6ac0: 28 70 54 72 69 67 67 65 72 29 20 29 3b 0a 20 20  (pTrigger) );.  
6ad0: 61 73 73 65 72 74 28 20 70 54 6f 70 2d 3e 70 56  assert( pTop->pV
6ae0: 64 62 65 20 29 3b 0a 0a 20 20 2f 2a 20 41 6c 6c  dbe );..  /* All
6af0: 6f 63 61 74 65 20 74 68 65 20 54 72 69 67 67 65  ocate the Trigge
6b00: 72 50 72 67 20 61 6e 64 20 53 75 62 50 72 6f 67  rPrg and SubProg
6b10: 72 61 6d 20 6f 62 6a 65 63 74 73 2e 20 54 6f 20  ram objects. To 
6b20: 65 6e 73 75 72 65 20 74 68 61 74 20 74 68 65 79  ensure that they
6b30: 0a 20 20 2a 2a 20 61 72 65 20 66 72 65 65 64 20  .  ** are freed 
6b40: 69 66 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 75  if an error occu
6b50: 72 73 2c 20 6c 69 6e 6b 20 74 68 65 6d 20 69 6e  rs, link them in
6b60: 74 6f 20 74 68 65 20 50 61 72 73 65 2e 70 54 72  to the Parse.pTr
6b70: 69 67 67 65 72 50 72 67 20 0a 20 20 2a 2a 20 6c  iggerPrg .  ** l
6b80: 69 73 74 20 6f 66 20 74 68 65 20 74 6f 70 2d 6c  ist of the top-l
6b90: 65 76 65 6c 20 50 61 72 73 65 20 6f 62 6a 65 63  evel Parse objec
6ba0: 74 20 73 6f 6f 6e 65 72 20 72 61 74 68 65 72 20  t sooner rather 
6bb0: 74 68 61 6e 20 6c 61 74 65 72 2e 20 20 2a 2f 0a  than later.  */.
6bc0: 20 20 70 50 72 67 20 3d 20 73 71 6c 69 74 65 33    pPrg = sqlite3
6bd0: 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64 62 2c  DbMallocZero(db,
6be0: 20 73 69 7a 65 6f 66 28 54 72 69 67 67 65 72 50   sizeof(TriggerP
6bf0: 72 67 29 29 3b 0a 20 20 69 66 28 20 21 70 50 72  rg));.  if( !pPr
6c00: 67 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  g ) return 0;.  
6c10: 70 50 72 67 2d 3e 70 4e 65 78 74 20 3d 20 70 54  pPrg->pNext = pT
6c20: 6f 70 2d 3e 70 54 72 69 67 67 65 72 50 72 67 3b  op->pTriggerPrg;
6c30: 0a 20 20 70 54 6f 70 2d 3e 70 54 72 69 67 67 65  .  pTop->pTrigge
6c40: 72 50 72 67 20 3d 20 70 50 72 67 3b 0a 20 20 70  rPrg = pPrg;.  p
6c50: 50 72 67 2d 3e 70 50 72 6f 67 72 61 6d 20 3d 20  Prg->pProgram = 
6c60: 70 50 72 6f 67 72 61 6d 20 3d 20 73 71 6c 69 74  pProgram = sqlit
6c70: 65 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64  e3DbMallocZero(d
6c80: 62 2c 20 73 69 7a 65 6f 66 28 53 75 62 50 72 6f  b, sizeof(SubPro
6c90: 67 72 61 6d 29 29 3b 0a 20 20 69 66 28 20 21 70  gram));.  if( !p
6ca0: 50 72 6f 67 72 61 6d 20 29 20 72 65 74 75 72 6e  Program ) return
6cb0: 20 30 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62   0;.  sqlite3Vdb
6cc0: 65 4c 69 6e 6b 53 75 62 50 72 6f 67 72 61 6d 28  eLinkSubProgram(
6cd0: 70 54 6f 70 2d 3e 70 56 64 62 65 2c 20 70 50 72  pTop->pVdbe, pPr
6ce0: 6f 67 72 61 6d 29 3b 0a 20 20 70 50 72 67 2d 3e  ogram);.  pPrg->
6cf0: 70 54 72 69 67 67 65 72 20 3d 20 70 54 72 69 67  pTrigger = pTrig
6d00: 67 65 72 3b 0a 20 20 70 50 72 67 2d 3e 6f 72 63  ger;.  pPrg->orc
6d10: 6f 6e 66 20 3d 20 6f 72 63 6f 6e 66 3b 0a 20 20  onf = orconf;.  
6d20: 70 50 72 67 2d 3e 61 43 6f 6c 6d 61 73 6b 5b 30  pPrg->aColmask[0
6d30: 5d 20 3d 20 30 78 66 66 66 66 66 66 66 66 3b 0a  ] = 0xffffffff;.
6d40: 20 20 70 50 72 67 2d 3e 61 43 6f 6c 6d 61 73 6b    pPrg->aColmask
6d50: 5b 31 5d 20 3d 20 30 78 66 66 66 66 66 66 66 66  [1] = 0xffffffff
6d60: 3b 0a 0a 20 20 2f 2a 20 41 6c 6c 6f 63 61 74 65  ;..  /* Allocate
6d70: 20 61 6e 64 20 70 6f 70 75 6c 61 74 65 20 61 20   and populate a 
6d80: 6e 65 77 20 50 61 72 73 65 20 63 6f 6e 74 65 78  new Parse contex
6d90: 74 20 74 6f 20 75 73 65 20 66 6f 72 20 63 6f 64  t to use for cod
6da0: 69 6e 67 20 74 68 65 20 0a 20 20 2a 2a 20 74 72  ing the .  ** tr
6db0: 69 67 67 65 72 20 73 75 62 2d 70 72 6f 67 72 61  igger sub-progra
6dc0: 6d 2e 20 20 2a 2f 0a 20 20 70 53 75 62 50 61 72  m.  */.  pSubPar
6dd0: 73 65 20 3d 20 73 71 6c 69 74 65 33 53 74 61 63  se = sqlite3Stac
6de0: 6b 41 6c 6c 6f 63 5a 65 72 6f 28 64 62 2c 20 73  kAllocZero(db, s
6df0: 69 7a 65 6f 66 28 50 61 72 73 65 29 29 3b 0a 20  izeof(Parse));. 
6e00: 20 69 66 28 20 21 70 53 75 62 50 61 72 73 65 20   if( !pSubParse 
6e10: 29 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 6d 65  ) return 0;.  me
6e20: 6d 73 65 74 28 26 73 4e 43 2c 20 30 2c 20 73 69  mset(&sNC, 0, si
6e30: 7a 65 6f 66 28 73 4e 43 29 29 3b 0a 20 20 73 4e  zeof(sNC));.  sN
6e40: 43 2e 70 50 61 72 73 65 20 3d 20 70 53 75 62 50  C.pParse = pSubP
6e50: 61 72 73 65 3b 0a 20 20 70 53 75 62 50 61 72 73  arse;.  pSubPars
6e60: 65 2d 3e 64 62 20 3d 20 64 62 3b 0a 20 20 70 53  e->db = db;.  pS
6e70: 75 62 50 61 72 73 65 2d 3e 70 54 72 69 67 67 65  ubParse->pTrigge
6e80: 72 54 61 62 20 3d 20 70 54 61 62 3b 0a 20 20 70  rTab = pTab;.  p
6e90: 53 75 62 50 61 72 73 65 2d 3e 70 54 6f 70 6c 65  SubParse->pTople
6ea0: 76 65 6c 20 3d 20 70 54 6f 70 3b 0a 20 20 70 53  vel = pTop;.  pS
6eb0: 75 62 50 61 72 73 65 2d 3e 7a 41 75 74 68 43 6f  ubParse->zAuthCo
6ec0: 6e 74 65 78 74 20 3d 20 70 54 72 69 67 67 65 72  ntext = pTrigger
6ed0: 2d 3e 7a 4e 61 6d 65 3b 0a 20 20 70 53 75 62 50  ->zName;.  pSubP
6ee0: 61 72 73 65 2d 3e 65 54 72 69 67 67 65 72 4f 70  arse->eTriggerOp
6ef0: 20 3d 20 70 54 72 69 67 67 65 72 2d 3e 6f 70 3b   = pTrigger->op;
6f00: 0a 20 20 70 53 75 62 50 61 72 73 65 2d 3e 6e 51  .  pSubParse->nQ
6f10: 75 65 72 79 4c 6f 6f 70 20 3d 20 70 50 61 72 73  ueryLoop = pPars
6f20: 65 2d 3e 6e 51 75 65 72 79 4c 6f 6f 70 3b 0a 0a  e->nQueryLoop;..
6f30: 20 20 76 20 3d 20 73 71 6c 69 74 65 33 47 65 74    v = sqlite3Get
6f40: 56 64 62 65 28 70 53 75 62 50 61 72 73 65 29 3b  Vdbe(pSubParse);
6f50: 0a 20 20 69 66 28 20 76 20 29 7b 0a 20 20 20 20  .  if( v ){.    
6f60: 56 64 62 65 43 6f 6d 6d 65 6e 74 28 28 76 2c 20  VdbeComment((v, 
6f70: 22 53 74 61 72 74 3a 20 25 73 2e 25 73 20 28 25  "Start: %s.%s (%
6f80: 73 20 25 73 25 73 25 73 20 4f 4e 20 25 73 29 22  s %s%s%s ON %s)"
6f90: 2c 20 0a 20 20 20 20 20 20 70 54 72 69 67 67 65  , .      pTrigge
6fa0: 72 2d 3e 7a 4e 61 6d 65 2c 20 6f 6e 45 72 72 6f  r->zName, onErro
6fb0: 72 54 65 78 74 28 6f 72 63 6f 6e 66 29 2c 0a 20  rText(orconf),. 
6fc0: 20 20 20 20 20 28 70 54 72 69 67 67 65 72 2d 3e       (pTrigger->
6fd0: 74 72 5f 74 6d 3d 3d 54 52 49 47 47 45 52 5f 42  tr_tm==TRIGGER_B
6fe0: 45 46 4f 52 45 20 3f 20 22 42 45 46 4f 52 45 22  EFORE ? "BEFORE"
6ff0: 20 3a 20 22 41 46 54 45 52 22 29 2c 0a 20 20 20   : "AFTER"),.   
7000: 20 20 20 20 20 28 70 54 72 69 67 67 65 72 2d 3e       (pTrigger->
7010: 6f 70 3d 3d 54 4b 5f 55 50 44 41 54 45 20 3f 20  op==TK_UPDATE ? 
7020: 22 55 50 44 41 54 45 22 20 3a 20 22 22 29 2c 0a  "UPDATE" : ""),.
7030: 20 20 20 20 20 20 20 20 28 70 54 72 69 67 67 65          (pTrigge
7040: 72 2d 3e 6f 70 3d 3d 54 4b 5f 49 4e 53 45 52 54  r->op==TK_INSERT
7050: 20 3f 20 22 49 4e 53 45 52 54 22 20 3a 20 22 22   ? "INSERT" : ""
7060: 29 2c 0a 20 20 20 20 20 20 20 20 28 70 54 72 69  ),.        (pTri
7070: 67 67 65 72 2d 3e 6f 70 3d 3d 54 4b 5f 44 45 4c  gger->op==TK_DEL
7080: 45 54 45 20 3f 20 22 44 45 4c 45 54 45 22 20 3a  ETE ? "DELETE" :
7090: 20 22 22 29 2c 0a 20 20 20 20 20 20 70 54 61 62   ""),.      pTab
70a0: 2d 3e 7a 4e 61 6d 65 0a 20 20 20 20 29 29 3b 0a  ->zName.    ));.
70b0: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
70c0: 4d 49 54 5f 54 52 41 43 45 0a 20 20 20 20 73 71  MIT_TRACE.    sq
70d0: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
70e0: 34 28 76 2c 20 2d 31 2c 20 0a 20 20 20 20 20 20  4(v, -1, .      
70f0: 73 71 6c 69 74 65 33 4d 50 72 69 6e 74 66 28 64  sqlite3MPrintf(d
7100: 62 2c 20 22 2d 2d 20 54 52 49 47 47 45 52 20 25  b, "-- TRIGGER %
7110: 73 22 2c 20 70 54 72 69 67 67 65 72 2d 3e 7a 4e  s", pTrigger->zN
7120: 61 6d 65 29 2c 20 50 34 5f 44 59 4e 41 4d 49 43  ame), P4_DYNAMIC
7130: 0a 20 20 20 20 29 3b 0a 23 65 6e 64 69 66 0a 0a  .    );.#endif..
7140: 20 20 20 20 2f 2a 20 49 66 20 6f 6e 65 20 77 61      /* If one wa
7150: 73 20 73 70 65 63 69 66 69 65 64 2c 20 63 6f 64  s specified, cod
7160: 65 20 74 68 65 20 57 48 45 4e 20 63 6c 61 75 73  e the WHEN claus
7170: 65 2e 20 49 66 20 69 74 20 65 76 61 6c 75 61 74  e. If it evaluat
7180: 65 73 20 74 6f 20 66 61 6c 73 65 0a 20 20 20 20  es to false.    
7190: 2a 2a 20 28 6f 72 20 4e 55 4c 4c 29 20 74 68 65  ** (or NULL) the
71a0: 20 73 75 62 2d 76 64 62 65 20 69 73 20 69 6d 6d   sub-vdbe is imm
71b0: 65 64 69 61 74 65 6c 79 20 68 61 6c 74 65 64 20  ediately halted 
71c0: 62 79 20 6a 75 6d 70 69 6e 67 20 74 6f 20 74 68  by jumping to th
71d0: 65 20 0a 20 20 20 20 2a 2a 20 4f 50 5f 48 61 6c  e .    ** OP_Hal
71e0: 74 20 69 6e 73 65 72 74 65 64 20 61 74 20 74 68  t inserted at th
71f0: 65 20 65 6e 64 20 6f 66 20 74 68 65 20 70 72 6f  e end of the pro
7200: 67 72 61 6d 2e 20 20 2a 2f 0a 20 20 20 20 69 66  gram.  */.    if
7210: 28 20 70 54 72 69 67 67 65 72 2d 3e 70 57 68 65  ( pTrigger->pWhe
7220: 6e 20 29 7b 0a 20 20 20 20 20 20 70 57 68 65 6e  n ){.      pWhen
7230: 20 3d 20 73 71 6c 69 74 65 33 45 78 70 72 44 75   = sqlite3ExprDu
7240: 70 28 64 62 2c 20 70 54 72 69 67 67 65 72 2d 3e  p(db, pTrigger->
7250: 70 57 68 65 6e 2c 20 30 29 3b 0a 20 20 20 20 20  pWhen, 0);.     
7260: 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d   if( SQLITE_OK==
7270: 73 71 6c 69 74 65 33 52 65 73 6f 6c 76 65 45 78  sqlite3ResolveEx
7280: 70 72 4e 61 6d 65 73 28 26 73 4e 43 2c 20 70 57  prNames(&sNC, pW
7290: 68 65 6e 29 20 0a 20 20 20 20 20 20 20 26 26 20  hen) .       && 
72a0: 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64  db->mallocFailed
72b0: 3d 3d 30 20 0a 20 20 20 20 20 20 29 7b 0a 20 20  ==0 .      ){.  
72c0: 20 20 20 20 20 20 69 45 6e 64 54 72 69 67 67 65        iEndTrigge
72d0: 72 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 4d  r = sqlite3VdbeM
72e0: 61 6b 65 4c 61 62 65 6c 28 76 29 3b 0a 20 20 20  akeLabel(v);.   
72f0: 20 20 20 20 20 73 71 6c 69 74 65 33 45 78 70 72       sqlite3Expr
7300: 49 66 46 61 6c 73 65 28 70 53 75 62 50 61 72 73  IfFalse(pSubPars
7310: 65 2c 20 70 57 68 65 6e 2c 20 69 45 6e 64 54 72  e, pWhen, iEndTr
7320: 69 67 67 65 72 2c 20 53 51 4c 49 54 45 5f 4a 55  igger, SQLITE_JU
7330: 4d 50 49 46 4e 55 4c 4c 29 3b 0a 20 20 20 20 20  MPIFNULL);.     
7340: 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33   }.      sqlite3
7350: 45 78 70 72 44 65 6c 65 74 65 28 64 62 2c 20 70  ExprDelete(db, p
7360: 57 68 65 6e 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  When);.    }..  
7370: 20 20 2f 2a 20 43 6f 64 65 20 74 68 65 20 74 72    /* Code the tr
7380: 69 67 67 65 72 20 70 72 6f 67 72 61 6d 20 69 6e  igger program in
7390: 74 6f 20 74 68 65 20 73 75 62 2d 76 64 62 65 2e  to the sub-vdbe.
73a0: 20 2a 2f 0a 20 20 20 20 63 6f 64 65 54 72 69 67   */.    codeTrig
73b0: 67 65 72 50 72 6f 67 72 61 6d 28 70 53 75 62 50  gerProgram(pSubP
73c0: 61 72 73 65 2c 20 70 54 72 69 67 67 65 72 2d 3e  arse, pTrigger->
73d0: 73 74 65 70 5f 6c 69 73 74 2c 20 6f 72 63 6f 6e  step_list, orcon
73e0: 66 29 3b 0a 0a 20 20 20 20 2f 2a 20 49 6e 73 65  f);..    /* Inse
73f0: 72 74 20 61 6e 20 4f 50 5f 48 61 6c 74 20 61 74  rt an OP_Halt at
7400: 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20   the end of the 
7410: 73 75 62 2d 70 72 6f 67 72 61 6d 2e 20 2a 2f 0a  sub-program. */.
7420: 20 20 20 20 69 66 28 20 69 45 6e 64 54 72 69 67      if( iEndTrig
7430: 67 65 72 20 29 7b 0a 20 20 20 20 20 20 73 71 6c  ger ){.      sql
7440: 69 74 65 33 56 64 62 65 52 65 73 6f 6c 76 65 4c  ite3VdbeResolveL
7450: 61 62 65 6c 28 76 2c 20 69 45 6e 64 54 72 69 67  abel(v, iEndTrig
7460: 67 65 72 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  ger);.    }.    
7470: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
7480: 30 28 76 2c 20 4f 50 5f 48 61 6c 74 29 3b 0a 20  0(v, OP_Halt);. 
7490: 20 20 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28 28     VdbeComment((
74a0: 76 2c 20 22 45 6e 64 3a 20 25 73 2e 25 73 22 2c  v, "End: %s.%s",
74b0: 20 70 54 72 69 67 67 65 72 2d 3e 7a 4e 61 6d 65   pTrigger->zName
74c0: 2c 20 6f 6e 45 72 72 6f 72 54 65 78 74 28 6f 72  , onErrorText(or
74d0: 63 6f 6e 66 29 29 29 3b 0a 0a 20 20 20 20 74 72  conf)));..    tr
74e0: 61 6e 73 66 65 72 50 61 72 73 65 45 72 72 6f 72  ansferParseError
74f0: 28 70 50 61 72 73 65 2c 20 70 53 75 62 50 61 72  (pParse, pSubPar
7500: 73 65 29 3b 0a 20 20 20 20 69 66 28 20 64 62 2d  se);.    if( db-
7510: 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 3d 3d 30  >mallocFailed==0
7520: 20 29 7b 0a 20 20 20 20 20 20 70 50 72 6f 67 72   ){.      pProgr
7530: 61 6d 2d 3e 61 4f 70 20 3d 20 73 71 6c 69 74 65  am->aOp = sqlite
7540: 33 56 64 62 65 54 61 6b 65 4f 70 41 72 72 61 79  3VdbeTakeOpArray
7550: 28 76 2c 20 26 70 50 72 6f 67 72 61 6d 2d 3e 6e  (v, &pProgram->n
7560: 4f 70 2c 20 26 70 54 6f 70 2d 3e 6e 4d 61 78 41  Op, &pTop->nMaxA
7570: 72 67 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70  rg);.    }.    p
7580: 50 72 6f 67 72 61 6d 2d 3e 6e 4d 65 6d 20 3d 20  Program->nMem = 
7590: 70 53 75 62 50 61 72 73 65 2d 3e 6e 4d 65 6d 3b  pSubParse->nMem;
75a0: 0a 20 20 20 20 70 50 72 6f 67 72 61 6d 2d 3e 6e  .    pProgram->n
75b0: 43 73 72 20 3d 20 70 53 75 62 50 61 72 73 65 2d  Csr = pSubParse-
75c0: 3e 6e 54 61 62 3b 0a 20 20 20 20 70 50 72 6f 67  >nTab;.    pProg
75d0: 72 61 6d 2d 3e 6e 4f 6e 63 65 20 3d 20 70 53 75  ram->nOnce = pSu
75e0: 62 50 61 72 73 65 2d 3e 6e 4f 6e 63 65 3b 0a 20  bParse->nOnce;. 
75f0: 20 20 20 70 50 72 6f 67 72 61 6d 2d 3e 74 6f 6b     pProgram->tok
7600: 65 6e 20 3d 20 28 76 6f 69 64 20 2a 29 70 54 72  en = (void *)pTr
7610: 69 67 67 65 72 3b 0a 20 20 20 20 70 50 72 67 2d  igger;.    pPrg-
7620: 3e 61 43 6f 6c 6d 61 73 6b 5b 30 5d 20 3d 20 70  >aColmask[0] = p
7630: 53 75 62 50 61 72 73 65 2d 3e 6f 6c 64 6d 61 73  SubParse->oldmas
7640: 6b 3b 0a 20 20 20 20 70 50 72 67 2d 3e 61 43 6f  k;.    pPrg->aCo
7650: 6c 6d 61 73 6b 5b 31 5d 20 3d 20 70 53 75 62 50  lmask[1] = pSubP
7660: 61 72 73 65 2d 3e 6e 65 77 6d 61 73 6b 3b 0a 20  arse->newmask;. 
7670: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 44 65     sqlite3VdbeDe
7680: 6c 65 74 65 28 76 29 3b 0a 20 20 7d 0a 0a 20 20  lete(v);.  }..  
7690: 61 73 73 65 72 74 28 20 21 70 53 75 62 50 61 72  assert( !pSubPar
76a0: 73 65 2d 3e 70 41 69 6e 63 20 20 20 20 20 20 20  se->pAinc       
76b0: 26 26 20 21 70 53 75 62 50 61 72 73 65 2d 3e 70  && !pSubParse->p
76c0: 5a 6f 6d 62 69 65 54 61 62 20 29 3b 0a 20 20 61  ZombieTab );.  a
76d0: 73 73 65 72 74 28 20 21 70 53 75 62 50 61 72 73  ssert( !pSubPars
76e0: 65 2d 3e 70 54 72 69 67 67 65 72 50 72 67 20 26  e->pTriggerPrg &
76f0: 26 20 21 70 53 75 62 50 61 72 73 65 2d 3e 6e 4d  & !pSubParse->nM
7700: 61 78 41 72 67 20 29 3b 0a 20 20 73 71 6c 69 74  axArg );.  sqlit
7710: 65 33 50 61 72 73 65 72 52 65 73 65 74 28 70 53  e3ParserReset(pS
7720: 75 62 50 61 72 73 65 29 3b 0a 20 20 73 71 6c 69  ubParse);.  sqli
7730: 74 65 33 53 74 61 63 6b 46 72 65 65 28 64 62 2c  te3StackFree(db,
7740: 20 70 53 75 62 50 61 72 73 65 29 3b 0a 0a 20 20   pSubParse);..  
7750: 72 65 74 75 72 6e 20 70 50 72 67 3b 0a 7d 0a 20  return pPrg;.}. 
7760: 20 20 20 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e     ./*.** Return
7770: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20   a pointer to a 
7780: 54 72 69 67 67 65 72 50 72 67 20 6f 62 6a 65 63  TriggerPrg objec
7790: 74 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65  t containing the
77a0: 20 73 75 62 2d 70 72 6f 67 72 61 6d 20 66 6f 72   sub-program for
77b0: 0a 2a 2a 20 74 72 69 67 67 65 72 20 70 54 72 69  .** trigger pTri
77c0: 67 67 65 72 20 77 69 74 68 20 64 65 66 61 75 6c  gger with defaul
77d0: 74 20 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 61 6c  t ON CONFLICT al
77e0: 67 6f 72 69 74 68 6d 20 6f 72 63 6f 6e 66 2e 20  gorithm orconf. 
77f0: 49 66 20 6e 6f 20 73 75 63 68 0a 2a 2a 20 54 72  If no such.** Tr
7800: 69 67 67 65 72 50 72 67 20 6f 62 6a 65 63 74 20  iggerPrg object 
7810: 65 78 69 73 74 73 2c 20 61 20 6e 65 77 20 6f 62  exists, a new ob
7820: 6a 65 63 74 20 69 73 20 61 6c 6c 6f 63 61 74 65  ject is allocate
7830: 64 20 61 6e 64 20 70 6f 70 75 6c 61 74 65 64 20  d and populated 
7840: 62 65 66 6f 72 65 0a 2a 2a 20 62 65 69 6e 67 20  before.** being 
7850: 72 65 74 75 72 6e 65 64 2e 0a 2a 2f 0a 73 74 61  returned..*/.sta
7860: 74 69 63 20 54 72 69 67 67 65 72 50 72 67 20 2a  tic TriggerPrg *
7870: 67 65 74 52 6f 77 54 72 69 67 67 65 72 28 0a 20  getRowTrigger(. 
7880: 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c 20   Parse *pParse, 
7890: 20 20 20 20 20 20 2f 2a 20 43 75 72 72 65 6e 74        /* Current
78a0: 20 70 61 72 73 65 20 63 6f 6e 74 65 78 74 20 2a   parse context *
78b0: 2f 0a 20 20 54 72 69 67 67 65 72 20 2a 70 54 72  /.  Trigger *pTr
78c0: 69 67 67 65 72 2c 20 20 20 2f 2a 20 54 72 69 67  igger,   /* Trig
78d0: 67 65 72 20 74 6f 20 63 6f 64 65 20 2a 2f 0a 20  ger to code */. 
78e0: 20 54 61 62 6c 65 20 2a 70 54 61 62 2c 20 20 20   Table *pTab,   
78f0: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 74 61 62        /* The tab
7900: 6c 65 20 74 72 69 67 67 65 72 20 70 54 72 69 67  le trigger pTrig
7910: 67 65 72 20 69 73 20 61 74 74 61 63 68 65 64 20  ger is attached 
7920: 74 6f 20 2a 2f 0a 20 20 69 6e 74 20 6f 72 63 6f  to */.  int orco
7930: 6e 66 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  nf           /* 
7940: 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 61 6c 67 6f  ON CONFLICT algo
7950: 72 69 74 68 6d 2e 20 2a 2f 0a 29 7b 0a 20 20 50  rithm. */.){.  P
7960: 61 72 73 65 20 2a 70 52 6f 6f 74 20 3d 20 73 71  arse *pRoot = sq
7970: 6c 69 74 65 33 50 61 72 73 65 54 6f 70 6c 65 76  lite3ParseToplev
7980: 65 6c 28 70 50 61 72 73 65 29 3b 0a 20 20 54 72  el(pParse);.  Tr
7990: 69 67 67 65 72 50 72 67 20 2a 70 50 72 67 3b 0a  iggerPrg *pPrg;.
79a0: 0a 20 20 61 73 73 65 72 74 28 20 70 54 72 69 67  .  assert( pTrig
79b0: 67 65 72 2d 3e 7a 4e 61 6d 65 3d 3d 30 20 7c 7c  ger->zName==0 ||
79c0: 20 70 54 61 62 3d 3d 74 61 62 6c 65 4f 66 54 72   pTab==tableOfTr
79d0: 69 67 67 65 72 28 70 54 72 69 67 67 65 72 29 20  igger(pTrigger) 
79e0: 29 3b 0a 0a 20 20 2f 2a 20 49 74 20 6d 61 79 20  );..  /* It may 
79f0: 62 65 20 74 68 61 74 20 74 68 69 73 20 74 72 69  be that this tri
7a00: 67 67 65 72 20 68 61 73 20 61 6c 72 65 61 64 79  gger has already
7a10: 20 62 65 65 6e 20 63 6f 64 65 64 20 28 6f 72 20   been coded (or 
7a20: 69 73 20 69 6e 20 74 68 65 0a 20 20 2a 2a 20 70  is in the.  ** p
7a30: 72 6f 63 65 73 73 20 6f 66 20 62 65 69 6e 67 20  rocess of being 
7a40: 63 6f 64 65 64 29 2e 20 49 66 20 74 68 69 73 20  coded). If this 
7a50: 69 73 20 74 68 65 20 63 61 73 65 2c 20 74 68 65  is the case, the
7a60: 6e 20 61 6e 20 65 6e 74 72 79 20 77 69 74 68 0a  n an entry with.
7a70: 20 20 2a 2a 20 61 20 6d 61 74 63 68 69 6e 67 20    ** a matching 
7a80: 54 72 69 67 67 65 72 50 72 67 2e 70 54 72 69 67  TriggerPrg.pTrig
7a90: 67 65 72 20 66 69 65 6c 64 20 77 69 6c 6c 20 62  ger field will b
7aa0: 65 20 70 72 65 73 65 6e 74 20 73 6f 6d 65 77 68  e present somewh
7ab0: 65 72 65 0a 20 20 2a 2a 20 69 6e 20 74 68 65 20  ere.  ** in the 
7ac0: 50 61 72 73 65 2e 70 54 72 69 67 67 65 72 50 72  Parse.pTriggerPr
7ad0: 67 20 6c 69 73 74 2e 20 53 65 61 72 63 68 20 66  g list. Search f
7ae0: 6f 72 20 73 75 63 68 20 61 6e 20 65 6e 74 72 79  or such an entry
7af0: 2e 20 20 2a 2f 0a 20 20 66 6f 72 28 70 50 72 67  .  */.  for(pPrg
7b00: 3d 70 52 6f 6f 74 2d 3e 70 54 72 69 67 67 65 72  =pRoot->pTrigger
7b10: 50 72 67 3b 20 0a 20 20 20 20 20 20 70 50 72 67  Prg; .      pPrg
7b20: 20 26 26 20 28 70 50 72 67 2d 3e 70 54 72 69 67   && (pPrg->pTrig
7b30: 67 65 72 21 3d 70 54 72 69 67 67 65 72 20 7c 7c  ger!=pTrigger ||
7b40: 20 70 50 72 67 2d 3e 6f 72 63 6f 6e 66 21 3d 6f   pPrg->orconf!=o
7b50: 72 63 6f 6e 66 29 3b 20 0a 20 20 20 20 20 20 70  rconf); .      p
7b60: 50 72 67 3d 70 50 72 67 2d 3e 70 4e 65 78 74 0a  Prg=pPrg->pNext.
7b70: 20 20 29 3b 0a 0a 20 20 2f 2a 20 49 66 20 61 6e    );..  /* If an
7b80: 20 65 78 69 73 74 69 6e 67 20 54 72 69 67 67 65   existing Trigge
7b90: 72 50 72 67 20 63 6f 75 6c 64 20 6e 6f 74 20 62  rPrg could not b
7ba0: 65 20 6c 6f 63 61 74 65 64 2c 20 63 72 65 61 74  e located, creat
7bb0: 65 20 61 20 6e 65 77 20 6f 6e 65 2e 20 2a 2f 0a  e a new one. */.
7bc0: 20 20 69 66 28 20 21 70 50 72 67 20 29 7b 0a 20    if( !pPrg ){. 
7bd0: 20 20 20 70 50 72 67 20 3d 20 63 6f 64 65 52 6f     pPrg = codeRo
7be0: 77 54 72 69 67 67 65 72 28 70 50 61 72 73 65 2c  wTrigger(pParse,
7bf0: 20 70 54 72 69 67 67 65 72 2c 20 70 54 61 62 2c   pTrigger, pTab,
7c00: 20 6f 72 63 6f 6e 66 29 3b 0a 20 20 7d 0a 0a 20   orconf);.  }.. 
7c10: 20 72 65 74 75 72 6e 20 70 50 72 67 3b 0a 7d 0a   return pPrg;.}.
7c20: 0a 2f 2a 0a 2a 2a 20 47 65 6e 65 72 61 74 65 20  ./*.** Generate 
7c30: 63 6f 64 65 20 66 6f 72 20 74 68 65 20 74 72 69  code for the tri
7c40: 67 67 65 72 20 70 72 6f 67 72 61 6d 20 61 73 73  gger program ass
7c50: 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 72 69  ociated with tri
7c60: 67 67 65 72 20 70 20 6f 6e 20 0a 2a 2a 20 74 61  gger p on .** ta
7c70: 62 6c 65 20 70 54 61 62 2e 20 54 68 65 20 72 65  ble pTab. The re
7c80: 67 2c 20 6f 72 63 6f 6e 66 20 61 6e 64 20 69 67  g, orconf and ig
7c90: 6e 6f 72 65 4a 75 6d 70 20 70 61 72 61 6d 65 74  noreJump paramet
7ca0: 65 72 73 20 70 61 73 73 65 64 20 74 6f 20 74 68  ers passed to th
7cb0: 69 73 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 20 61  is.** function a
7cc0: 72 65 20 74 68 65 20 73 61 6d 65 20 61 73 20 74  re the same as t
7cd0: 68 6f 73 65 20 64 65 73 63 72 69 62 65 64 20 69  hose described i
7ce0: 6e 20 74 68 65 20 68 65 61 64 65 72 20 66 75 6e  n the header fun
7cf0: 63 74 69 6f 6e 20 66 6f 72 0a 2a 2a 20 73 71 6c  ction for.** sql
7d00: 69 74 65 33 43 6f 64 65 52 6f 77 54 72 69 67 67  ite3CodeRowTrigg
7d10: 65 72 28 29 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  er().*/.void sql
7d20: 69 74 65 33 43 6f 64 65 52 6f 77 54 72 69 67 67  ite3CodeRowTrigg
7d30: 65 72 44 69 72 65 63 74 28 0a 20 20 50 61 72 73  erDirect(.  Pars
7d40: 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20 20 20  e *pParse,      
7d50: 20 2f 2a 20 50 61 72 73 65 20 63 6f 6e 74 65 78   /* Parse contex
7d60: 74 20 2a 2f 0a 20 20 54 72 69 67 67 65 72 20 2a  t */.  Trigger *
7d70: 70 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54  p,          /* T
7d80: 72 69 67 67 65 72 20 74 6f 20 63 6f 64 65 20 2a  rigger to code *
7d90: 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54 61 62 2c  /.  Table *pTab,
7da0: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
7db0: 74 61 62 6c 65 20 74 6f 20 63 6f 64 65 20 74 72  table to code tr
7dc0: 69 67 67 65 72 73 20 66 72 6f 6d 20 2a 2f 0a 20  iggers from */. 
7dd0: 20 69 6e 74 20 72 65 67 2c 20 20 20 20 20 20 20   int reg,       
7de0: 20 20 20 20 20 20 2f 2a 20 52 65 67 20 61 72 72        /* Reg arr
7df0: 61 79 20 63 6f 6e 74 61 69 6e 69 6e 67 20 4f 4c  ay containing OL
7e00: 44 2e 2a 20 61 6e 64 20 4e 45 57 2e 2a 20 76 61  D.* and NEW.* va
7e10: 6c 75 65 73 20 2a 2f 0a 20 20 69 6e 74 20 6f 72  lues */.  int or
7e20: 63 6f 6e 66 2c 20 20 20 20 20 20 20 20 20 20 2f  conf,          /
7e30: 2a 20 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 70 6f  * ON CONFLICT po
7e40: 6c 69 63 79 20 2a 2f 0a 20 20 69 6e 74 20 69 67  licy */.  int ig
7e50: 6e 6f 72 65 4a 75 6d 70 20 20 20 20 20 20 20 2f  noreJump       /
7e60: 2a 20 49 6e 73 74 72 75 63 74 69 6f 6e 20 74 6f  * Instruction to
7e70: 20 6a 75 6d 70 20 74 6f 20 66 6f 72 20 52 41 49   jump to for RAI
7e80: 53 45 28 49 47 4e 4f 52 45 29 20 2a 2f 0a 29 7b  SE(IGNORE) */.){
7e90: 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 73 71 6c  .  Vdbe *v = sql
7ea0: 69 74 65 33 47 65 74 56 64 62 65 28 70 50 61 72  ite3GetVdbe(pPar
7eb0: 73 65 29 3b 20 2f 2a 20 4d 61 69 6e 20 56 4d 20  se); /* Main VM 
7ec0: 2a 2f 0a 20 20 54 72 69 67 67 65 72 50 72 67 20  */.  TriggerPrg 
7ed0: 2a 70 50 72 67 3b 0a 20 20 70 50 72 67 20 3d 20  *pPrg;.  pPrg = 
7ee0: 67 65 74 52 6f 77 54 72 69 67 67 65 72 28 70 50  getRowTrigger(pP
7ef0: 61 72 73 65 2c 20 70 2c 20 70 54 61 62 2c 20 6f  arse, p, pTab, o
7f00: 72 63 6f 6e 66 29 3b 0a 20 20 61 73 73 65 72 74  rconf);.  assert
7f10: 28 20 70 50 72 67 20 7c 7c 20 70 50 61 72 73 65  ( pPrg || pParse
7f20: 2d 3e 6e 45 72 72 20 7c 7c 20 70 50 61 72 73 65  ->nErr || pParse
7f30: 2d 3e 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c  ->db->mallocFail
7f40: 65 64 20 29 3b 0a 0a 20 20 2f 2a 20 43 6f 64 65  ed );..  /* Code
7f50: 20 74 68 65 20 4f 50 5f 50 72 6f 67 72 61 6d 20   the OP_Program 
7f60: 6f 70 63 6f 64 65 20 69 6e 20 74 68 65 20 70 61  opcode in the pa
7f70: 72 65 6e 74 20 56 44 42 45 2e 20 50 34 20 6f 66  rent VDBE. P4 of
7f80: 20 74 68 65 20 4f 50 5f 50 72 6f 67 72 61 6d 20   the OP_Program 
7f90: 0a 20 20 2a 2a 20 69 73 20 61 20 70 6f 69 6e 74  .  ** is a point
7fa0: 65 72 20 74 6f 20 74 68 65 20 73 75 62 2d 76 64  er to the sub-vd
7fb0: 62 65 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68  be containing th
7fc0: 65 20 74 72 69 67 67 65 72 20 70 72 6f 67 72 61  e trigger progra
7fd0: 6d 2e 20 20 2a 2f 0a 20 20 69 66 28 20 70 50 72  m.  */.  if( pPr
7fe0: 67 20 29 7b 0a 20 20 20 20 69 6e 74 20 62 52 65  g ){.    int bRe
7ff0: 63 75 72 73 69 76 65 20 3d 20 28 70 2d 3e 7a 4e  cursive = (p->zN
8000: 61 6d 65 20 26 26 20 30 3d 3d 28 70 50 61 72 73  ame && 0==(pPars
8010: 65 2d 3e 64 62 2d 3e 66 6c 61 67 73 26 53 51 4c  e->db->flags&SQL
8020: 49 54 45 5f 52 65 63 54 72 69 67 67 65 72 73 29  ITE_RecTriggers)
8030: 29 3b 0a 0a 20 20 20 20 73 71 6c 69 74 65 33 56  );..    sqlite3V
8040: 64 62 65 41 64 64 4f 70 34 28 76 2c 20 4f 50 5f  dbeAddOp4(v, OP_
8050: 50 72 6f 67 72 61 6d 2c 20 72 65 67 2c 20 69 67  Program, reg, ig
8060: 6e 6f 72 65 4a 75 6d 70 2c 20 2b 2b 70 50 61 72  noreJump, ++pPar
8070: 73 65 2d 3e 6e 4d 65 6d 2c 0a 20 20 20 20 20 20  se->nMem,.      
8080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8090: 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 29 70 50  (const char *)pP
80a0: 72 67 2d 3e 70 50 72 6f 67 72 61 6d 2c 20 50 34  rg->pProgram, P4
80b0: 5f 53 55 42 50 52 4f 47 52 41 4d 29 3b 0a 20 20  _SUBPROGRAM);.  
80c0: 20 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28 0a 20    VdbeComment(. 
80d0: 20 20 20 20 20 20 20 28 76 2c 20 22 43 61 6c 6c         (v, "Call
80e0: 3a 20 25 73 2e 25 73 22 2c 20 28 70 2d 3e 7a 4e  : %s.%s", (p->zN
80f0: 61 6d 65 3f 70 2d 3e 7a 4e 61 6d 65 3a 22 66 6b  ame?p->zName:"fk
8100: 65 79 22 29 2c 20 6f 6e 45 72 72 6f 72 54 65 78  ey"), onErrorTex
8110: 74 28 6f 72 63 6f 6e 66 29 29 29 3b 0a 0a 20 20  t(orconf)));..  
8120: 20 20 2f 2a 20 53 65 74 20 74 68 65 20 50 35 20    /* Set the P5 
8130: 6f 70 65 72 61 6e 64 20 6f 66 20 74 68 65 20 4f  operand of the O
8140: 50 5f 50 72 6f 67 72 61 6d 20 69 6e 73 74 72 75  P_Program instru
8150: 63 74 69 6f 6e 20 74 6f 20 6e 6f 6e 2d 7a 65 72  ction to non-zer
8160: 6f 20 69 66 0a 20 20 20 20 2a 2a 20 72 65 63 75  o if.    ** recu
8170: 72 73 69 76 65 20 69 6e 76 6f 63 61 74 69 6f 6e  rsive invocation
8180: 20 6f 66 20 74 68 69 73 20 74 72 69 67 67 65 72   of this trigger
8190: 20 70 72 6f 67 72 61 6d 20 69 73 20 64 69 73 61   program is disa
81a0: 6c 6c 6f 77 65 64 2e 20 52 65 63 75 72 73 69 76  llowed. Recursiv
81b0: 65 0a 20 20 20 20 2a 2a 20 69 6e 76 6f 63 61 74  e.    ** invocat
81c0: 69 6f 6e 20 69 73 20 64 69 73 61 6c 6c 6f 77 65  ion is disallowe
81d0: 64 20 69 66 20 28 61 29 20 74 68 65 20 73 75 62  d if (a) the sub
81e0: 2d 70 72 6f 67 72 61 6d 20 69 73 20 72 65 61 6c  -program is real
81f0: 6c 79 20 61 20 74 72 69 67 67 65 72 2c 0a 20 20  ly a trigger,.  
8200: 20 20 2a 2a 20 6e 6f 74 20 61 20 66 6f 72 65 69    ** not a forei
8210: 67 6e 20 6b 65 79 20 61 63 74 69 6f 6e 2c 20 61  gn key action, a
8220: 6e 64 20 28 62 29 20 74 68 65 20 66 6c 61 67 20  nd (b) the flag 
8230: 74 6f 20 65 6e 61 62 6c 65 20 72 65 63 75 72 73  to enable recurs
8240: 69 76 65 20 74 72 69 67 67 65 72 73 0a 20 20 20  ive triggers.   
8250: 20 2a 2a 20 69 73 20 63 6c 65 61 72 2e 20 20 2a   ** is clear.  *
8260: 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64 62  /.    sqlite3Vdb
8270: 65 43 68 61 6e 67 65 50 35 28 76 2c 20 28 75 38  eChangeP5(v, (u8
8280: 29 62 52 65 63 75 72 73 69 76 65 29 3b 0a 20 20  )bRecursive);.  
8290: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20  }.}../*.** This 
82a0: 69 73 20 63 61 6c 6c 65 64 20 74 6f 20 63 6f 64  is called to cod
82b0: 65 20 74 68 65 20 72 65 71 75 69 72 65 64 20 46  e the required F
82c0: 4f 52 20 45 41 43 48 20 52 4f 57 20 74 72 69 67  OR EACH ROW trig
82d0: 67 65 72 73 20 66 6f 72 20 61 6e 20 6f 70 65 72  gers for an oper
82e0: 61 74 69 6f 6e 0a 2a 2a 20 6f 6e 20 74 61 62 6c  ation.** on tabl
82f0: 65 20 70 54 61 62 2e 20 54 68 65 20 6f 70 65 72  e pTab. The oper
8300: 61 74 69 6f 6e 20 74 6f 20 63 6f 64 65 20 74 72  ation to code tr
8310: 69 67 67 65 72 73 20 66 6f 72 20 28 49 4e 53 45  iggers for (INSE
8320: 52 54 2c 20 55 50 44 41 54 45 20 6f 72 20 44 45  RT, UPDATE or DE
8330: 4c 45 54 45 29 0a 2a 2a 20 69 73 20 67 69 76 65  LETE).** is give
8340: 6e 20 62 79 20 74 68 65 20 6f 70 20 70 61 72 61  n by the op para
8350: 6d 65 74 65 72 2e 20 54 68 65 20 74 72 5f 74 6d  meter. The tr_tm
8360: 20 70 61 72 61 6d 65 74 65 72 20 64 65 74 65 72   parameter deter
8370: 6d 69 6e 65 73 20 77 68 65 74 68 65 72 20 74 68  mines whether th
8380: 65 0a 2a 2a 20 42 45 46 4f 52 45 20 6f 72 20 41  e.** BEFORE or A
8390: 46 54 45 52 20 74 72 69 67 67 65 72 73 20 61 72  FTER triggers ar
83a0: 65 20 63 6f 64 65 64 2e 20 49 66 20 74 68 65 20  e coded. If the 
83b0: 6f 70 65 72 61 74 69 6f 6e 20 69 73 20 61 6e 20  operation is an 
83c0: 55 50 44 41 54 45 2c 20 74 68 65 6e 0a 2a 2a 20  UPDATE, then.** 
83d0: 70 61 72 61 6d 65 74 65 72 20 70 43 68 61 6e 67  parameter pChang
83e0: 65 73 20 69 73 20 70 61 73 73 65 64 20 74 68 65  es is passed the
83f0: 20 6c 69 73 74 20 6f 66 20 63 6f 6c 75 6d 6e 73   list of columns
8400: 20 62 65 69 6e 67 20 6d 6f 64 69 66 69 65 64 2e   being modified.
8410: 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65 72 65 20  .**.** If there 
8420: 61 72 65 20 6e 6f 20 74 72 69 67 67 65 72 73 20  are no triggers 
8430: 74 68 61 74 20 66 69 72 65 20 61 74 20 74 68 65  that fire at the
8440: 20 73 70 65 63 69 66 69 65 64 20 74 69 6d 65 20   specified time 
8450: 66 6f 72 20 74 68 65 20 73 70 65 63 69 66 69 65  for the specifie
8460: 64 0a 2a 2a 20 6f 70 65 72 61 74 69 6f 6e 20 6f  d.** operation o
8470: 6e 20 70 54 61 62 2c 20 74 68 69 73 20 66 75 6e  n pTab, this fun
8480: 63 74 69 6f 6e 20 69 73 20 61 20 6e 6f 2d 6f 70  ction is a no-op
8490: 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 72 65 67 20  ..**.** The reg 
84a0: 61 72 67 75 6d 65 6e 74 20 69 73 20 74 68 65 20  argument is the 
84b0: 61 64 64 72 65 73 73 20 6f 66 20 74 68 65 20 66  address of the f
84c0: 69 72 73 74 20 69 6e 20 61 6e 20 61 72 72 61 79  irst in an array
84d0: 20 6f 66 20 72 65 67 69 73 74 65 72 73 20 0a 2a   of registers .*
84e0: 2a 20 74 68 61 74 20 63 6f 6e 74 61 69 6e 20 74  * that contain t
84f0: 68 65 20 76 61 6c 75 65 73 20 73 75 62 73 74 69  he values substi
8500: 74 75 74 65 64 20 66 6f 72 20 74 68 65 20 6e 65  tuted for the ne
8510: 77 2e 2a 20 61 6e 64 20 6f 6c 64 2e 2a 20 72 65  w.* and old.* re
8520: 66 65 72 65 6e 63 65 73 0a 2a 2a 20 69 6e 20 74  ferences.** in t
8530: 68 65 20 74 72 69 67 67 65 72 20 70 72 6f 67 72  he trigger progr
8540: 61 6d 2e 20 49 66 20 4e 20 69 73 20 74 68 65 20  am. If N is the 
8550: 6e 75 6d 62 65 72 20 6f 66 20 63 6f 6c 75 6d 6e  number of column
8560: 73 20 69 6e 20 74 61 62 6c 65 20 70 54 61 62 0a  s in table pTab.
8570: 2a 2a 20 28 61 20 63 6f 70 79 20 6f 66 20 70 54  ** (a copy of pT
8580: 61 62 2d 3e 6e 43 6f 6c 29 2c 20 74 68 65 6e 20  ab->nCol), then 
8590: 72 65 67 69 73 74 65 72 73 20 61 72 65 20 70 6f  registers are po
85a0: 70 75 6c 61 74 65 64 20 61 73 20 66 6f 6c 6c 6f  pulated as follo
85b0: 77 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 52 65 67 69  ws:.**.**   Regi
85c0: 73 74 65 72 20 20 20 20 20 20 20 43 6f 6e 74 61  ster       Conta
85d0: 69 6e 73 0a 2a 2a 20 20 20 2d 2d 2d 2d 2d 2d 2d  ins.**   -------
85e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
85f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
8600: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a  ---------------.
8610: 2a 2a 20 20 20 72 65 67 2b 30 20 20 20 20 20 20  **   reg+0      
8620: 20 20 20 20 4f 4c 44 2e 72 6f 77 69 64 0a 2a 2a      OLD.rowid.**
8630: 20 20 20 72 65 67 2b 31 20 20 20 20 20 20 20 20     reg+1        
8640: 20 20 4f 4c 44 2e 2a 20 76 61 6c 75 65 20 6f 66    OLD.* value of
8650: 20 6c 65 66 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d   left-most colum
8660: 6e 20 6f 66 20 70 54 61 62 0a 2a 2a 20 20 20 2e  n of pTab.**   .
8670: 2e 2e 20 20 20 20 20 20 20 20 20 20 20 20 2e 2e  ..            ..
8680: 2e 0a 2a 2a 20 20 20 72 65 67 2b 4e 20 20 20 20  ..**   reg+N    
8690: 20 20 20 20 20 20 4f 4c 44 2e 2a 20 76 61 6c 75        OLD.* valu
86a0: 65 20 6f 66 20 72 69 67 68 74 2d 6d 6f 73 74 20  e of right-most 
86b0: 63 6f 6c 75 6d 6e 20 6f 66 20 70 54 61 62 0a 2a  column of pTab.*
86c0: 2a 20 20 20 72 65 67 2b 4e 2b 31 20 20 20 20 20  *   reg+N+1     
86d0: 20 20 20 4e 45 57 2e 72 6f 77 69 64 0a 2a 2a 20     NEW.rowid.** 
86e0: 20 20 72 65 67 2b 4e 2b 32 20 20 20 20 20 20 20    reg+N+2       
86f0: 20 4f 4c 44 2e 2a 20 76 61 6c 75 65 20 6f 66 20   OLD.* value of 
8700: 6c 65 66 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d 6e  left-most column
8710: 20 6f 66 20 70 54 61 62 0a 2a 2a 20 20 20 2e 2e   of pTab.**   ..
8720: 2e 20 20 20 20 20 20 20 20 20 20 20 20 2e 2e 2e  .            ...
8730: 0a 2a 2a 20 20 20 72 65 67 2b 4e 2b 4e 2b 31 20  .**   reg+N+N+1 
8740: 20 20 20 20 20 4e 45 57 2e 2a 20 76 61 6c 75 65       NEW.* value
8750: 20 6f 66 20 72 69 67 68 74 2d 6d 6f 73 74 20 63   of right-most c
8760: 6f 6c 75 6d 6e 20 6f 66 20 70 54 61 62 0a 2a 2a  olumn of pTab.**
8770: 0a 2a 2a 20 46 6f 72 20 4f 4e 20 44 45 4c 45 54  .** For ON DELET
8780: 45 20 74 72 69 67 67 65 72 73 2c 20 74 68 65 20  E triggers, the 
8790: 72 65 67 69 73 74 65 72 73 20 63 6f 6e 74 61 69  registers contai
87a0: 6e 69 6e 67 20 74 68 65 20 4e 45 57 2e 2a 20 76  ning the NEW.* v
87b0: 61 6c 75 65 73 20 77 69 6c 6c 0a 2a 2a 20 6e 65  alues will.** ne
87c0: 76 65 72 20 62 65 20 61 63 63 65 73 73 65 64 20  ver be accessed 
87d0: 62 79 20 74 68 65 20 74 72 69 67 67 65 72 20 70  by the trigger p
87e0: 72 6f 67 72 61 6d 2c 20 73 6f 20 74 68 65 79 20  rogram, so they 
87f0: 61 72 65 20 6e 6f 74 20 61 6c 6c 6f 63 61 74 65  are not allocate
8800: 64 20 6f 72 20 0a 2a 2a 20 70 6f 70 75 6c 61 74  d or .** populat
8810: 65 64 20 62 79 20 74 68 65 20 63 61 6c 6c 65 72  ed by the caller
8820: 20 28 74 68 65 72 65 20 69 73 20 6e 6f 20 64 61   (there is no da
8830: 74 61 20 74 6f 20 70 6f 70 75 6c 61 74 65 20 74  ta to populate t
8840: 68 65 6d 20 77 69 74 68 20 61 6e 79 77 61 79 29  hem with anyway)
8850: 2e 20 0a 2a 2a 20 53 69 6d 69 6c 61 72 6c 79 2c  . .** Similarly,
8860: 20 66 6f 72 20 4f 4e 20 49 4e 53 45 52 54 20 74   for ON INSERT t
8870: 72 69 67 67 65 72 73 20 74 68 65 20 76 61 6c 75  riggers the valu
8880: 65 73 20 73 74 6f 72 65 64 20 69 6e 20 74 68 65  es stored in the
8890: 20 4f 4c 44 2e 2a 20 72 65 67 69 73 74 65 72 73   OLD.* registers
88a0: 0a 2a 2a 20 61 72 65 20 6e 65 76 65 72 20 61 63  .** are never ac
88b0: 63 65 73 73 65 64 2c 20 61 6e 64 20 73 6f 20 61  cessed, and so a
88c0: 72 65 20 6e 6f 74 20 61 6c 6c 6f 63 61 74 65 64  re not allocated
88d0: 20 62 79 20 74 68 65 20 63 61 6c 6c 65 72 2e 20   by the caller. 
88e0: 53 6f 2c 20 66 6f 72 20 61 6e 0a 2a 2a 20 4f 4e  So, for an.** ON
88f0: 20 49 4e 53 45 52 54 20 74 72 69 67 67 65 72 2c   INSERT trigger,
8900: 20 74 68 65 20 76 61 6c 75 65 20 70 61 73 73 65   the value passe
8910: 64 20 74 6f 20 74 68 69 73 20 66 75 6e 63 74 69  d to this functi
8920: 6f 6e 20 61 73 20 70 61 72 61 6d 65 74 65 72 20  on as parameter 
8930: 72 65 67 0a 2a 2a 20 69 73 20 6e 6f 74 20 61 20  reg.** is not a 
8940: 72 65 61 64 61 62 6c 65 20 72 65 67 69 73 74 65  readable registe
8950: 72 2c 20 61 6c 74 68 6f 75 67 68 20 72 65 67 69  r, although regi
8960: 73 74 65 72 73 20 28 72 65 67 2b 4e 29 20 74 68  sters (reg+N) th
8970: 72 6f 75 67 68 20 0a 2a 2a 20 28 72 65 67 2b 4e  rough .** (reg+N
8980: 2b 4e 2b 31 29 20 61 72 65 2e 0a 2a 2a 0a 2a 2a  +N+1) are..**.**
8990: 20 50 61 72 61 6d 65 74 65 72 20 6f 72 63 6f 6e   Parameter orcon
89a0: 66 20 69 73 20 74 68 65 20 64 65 66 61 75 6c 74  f is the default
89b0: 20 63 6f 6e 66 6c 69 63 74 20 72 65 73 6f 6c 75   conflict resolu
89c0: 74 69 6f 6e 20 61 6c 67 6f 72 69 74 68 6d 20 66  tion algorithm f
89d0: 6f 72 20 74 68 65 0a 2a 2a 20 74 72 69 67 67 65  or the.** trigge
89e0: 72 20 70 72 6f 67 72 61 6d 20 74 6f 20 75 73 65  r program to use
89f0: 20 28 52 45 50 4c 41 43 45 2c 20 49 47 4e 4f 52   (REPLACE, IGNOR
8a00: 45 20 65 74 63 2e 29 2e 20 50 61 72 61 6d 65 74  E etc.). Paramet
8a10: 65 72 20 69 67 6e 6f 72 65 4a 75 6d 70 0a 2a 2a  er ignoreJump.**
8a20: 20 69 73 20 74 68 65 20 69 6e 73 74 72 75 63 74   is the instruct
8a30: 69 6f 6e 20 74 68 61 74 20 63 6f 6e 74 72 6f 6c  ion that control
8a40: 20 73 68 6f 75 6c 64 20 6a 75 6d 70 20 74 6f 20   should jump to 
8a50: 69 66 20 61 20 74 72 69 67 67 65 72 20 70 72 6f  if a trigger pro
8a60: 67 72 61 6d 0a 2a 2a 20 72 61 69 73 65 73 20 61  gram.** raises a
8a70: 6e 20 49 47 4e 4f 52 45 20 65 78 63 65 70 74 69  n IGNORE excepti
8a80: 6f 6e 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69  on..*/.void sqli
8a90: 74 65 33 43 6f 64 65 52 6f 77 54 72 69 67 67 65  te3CodeRowTrigge
8aa0: 72 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72  r(.  Parse *pPar
8ab0: 73 65 2c 20 20 20 20 20 20 20 2f 2a 20 50 61 72  se,       /* Par
8ac0: 73 65 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20  se context */.  
8ad0: 54 72 69 67 67 65 72 20 2a 70 54 72 69 67 67 65  Trigger *pTrigge
8ae0: 72 2c 20 20 20 2f 2a 20 4c 69 73 74 20 6f 66 20  r,   /* List of 
8af0: 74 72 69 67 67 65 72 73 20 6f 6e 20 74 61 62 6c  triggers on tabl
8b00: 65 20 70 54 61 62 20 2a 2f 0a 20 20 69 6e 74 20  e pTab */.  int 
8b10: 6f 70 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  op,             
8b20: 20 2f 2a 20 4f 6e 65 20 6f 66 20 54 4b 5f 55 50   /* One of TK_UP
8b30: 44 41 54 45 2c 20 54 4b 5f 49 4e 53 45 52 54 2c  DATE, TK_INSERT,
8b40: 20 54 4b 5f 44 45 4c 45 54 45 20 2a 2f 0a 20 20   TK_DELETE */.  
8b50: 45 78 70 72 4c 69 73 74 20 2a 70 43 68 61 6e 67  ExprList *pChang
8b60: 65 73 2c 20 20 2f 2a 20 43 68 61 6e 67 65 73 20  es,  /* Changes 
8b70: 6c 69 73 74 20 66 6f 72 20 61 6e 79 20 55 50 44  list for any UPD
8b80: 41 54 45 20 4f 46 20 74 72 69 67 67 65 72 73 20  ATE OF triggers 
8b90: 2a 2f 0a 20 20 69 6e 74 20 74 72 5f 74 6d 2c 20  */.  int tr_tm, 
8ba0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 6e 65            /* One
8bb0: 20 6f 66 20 54 52 49 47 47 45 52 5f 42 45 46 4f   of TRIGGER_BEFO
8bc0: 52 45 2c 20 54 52 49 47 47 45 52 5f 41 46 54 45  RE, TRIGGER_AFTE
8bd0: 52 20 2a 2f 0a 20 20 54 61 62 6c 65 20 2a 70 54  R */.  Table *pT
8be0: 61 62 2c 20 20 20 20 20 20 20 20 20 2f 2a 20 54  ab,         /* T
8bf0: 68 65 20 74 61 62 6c 65 20 74 6f 20 63 6f 64 65  he table to code
8c00: 20 74 72 69 67 67 65 72 73 20 66 72 6f 6d 20 2a   triggers from *
8c10: 2f 0a 20 20 69 6e 74 20 72 65 67 2c 20 20 20 20  /.  int reg,    
8c20: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
8c30: 66 69 72 73 74 20 69 6e 20 61 6e 20 61 72 72 61  first in an arra
8c40: 79 20 6f 66 20 72 65 67 69 73 74 65 72 73 20 28  y of registers (
8c50: 73 65 65 20 61 62 6f 76 65 29 20 2a 2f 0a 20 20  see above) */.  
8c60: 69 6e 74 20 6f 72 63 6f 6e 66 2c 20 20 20 20 20  int orconf,     
8c70: 20 20 20 20 20 2f 2a 20 4f 4e 20 43 4f 4e 46 4c       /* ON CONFL
8c80: 49 43 54 20 70 6f 6c 69 63 79 20 2a 2f 0a 20 20  ICT policy */.  
8c90: 69 6e 74 20 69 67 6e 6f 72 65 4a 75 6d 70 20 20  int ignoreJump  
8ca0: 20 20 20 20 20 2f 2a 20 49 6e 73 74 72 75 63 74       /* Instruct
8cb0: 69 6f 6e 20 74 6f 20 6a 75 6d 70 20 74 6f 20 66  ion to jump to f
8cc0: 6f 72 20 52 41 49 53 45 28 49 47 4e 4f 52 45 29  or RAISE(IGNORE)
8cd0: 20 2a 2f 0a 29 7b 0a 20 20 54 72 69 67 67 65 72   */.){.  Trigger
8ce0: 20 2a 70 3b 20 20 20 20 20 20 20 20 20 20 2f 2a   *p;          /*
8cf0: 20 55 73 65 64 20 74 6f 20 69 74 65 72 61 74 65   Used to iterate
8d00: 20 74 68 72 6f 75 67 68 20 70 54 72 69 67 67 65   through pTrigge
8d10: 72 20 6c 69 73 74 20 2a 2f 0a 0a 20 20 61 73 73  r list */..  ass
8d20: 65 72 74 28 20 6f 70 3d 3d 54 4b 5f 55 50 44 41  ert( op==TK_UPDA
8d30: 54 45 20 7c 7c 20 6f 70 3d 3d 54 4b 5f 49 4e 53  TE || op==TK_INS
8d40: 45 52 54 20 7c 7c 20 6f 70 3d 3d 54 4b 5f 44 45  ERT || op==TK_DE
8d50: 4c 45 54 45 20 29 3b 0a 20 20 61 73 73 65 72 74  LETE );.  assert
8d60: 28 20 74 72 5f 74 6d 3d 3d 54 52 49 47 47 45 52  ( tr_tm==TRIGGER
8d70: 5f 42 45 46 4f 52 45 20 7c 7c 20 74 72 5f 74 6d  _BEFORE || tr_tm
8d80: 3d 3d 54 52 49 47 47 45 52 5f 41 46 54 45 52 20  ==TRIGGER_AFTER 
8d90: 29 3b 0a 20 20 61 73 73 65 72 74 28 20 28 6f 70  );.  assert( (op
8da0: 3d 3d 54 4b 5f 55 50 44 41 54 45 29 3d 3d 28 70  ==TK_UPDATE)==(p
8db0: 43 68 61 6e 67 65 73 21 3d 30 29 20 29 3b 0a 0a  Changes!=0) );..
8dc0: 20 20 66 6f 72 28 70 3d 70 54 72 69 67 67 65 72    for(p=pTrigger
8dd0: 3b 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78 74 29  ; p; p=p->pNext)
8de0: 7b 0a 0a 20 20 20 20 2f 2a 20 53 61 6e 69 74 79  {..    /* Sanity
8df0: 20 63 68 65 63 6b 69 6e 67 3a 20 20 54 68 65 20   checking:  The 
8e00: 73 63 68 65 6d 61 20 66 6f 72 20 74 68 65 20 74  schema for the t
8e10: 72 69 67 67 65 72 20 61 6e 64 20 66 6f 72 20 74  rigger and for t
8e20: 68 65 20 74 61 62 6c 65 20 61 72 65 0a 20 20 20  he table are.   
8e30: 20 2a 2a 20 61 6c 77 61 79 73 20 64 65 66 69 6e   ** always defin
8e40: 65 64 2e 20 20 54 68 65 20 74 72 69 67 67 65 72  ed.  The trigger
8e50: 20 6d 75 73 74 20 62 65 20 69 6e 20 74 68 65 20   must be in the 
8e60: 73 61 6d 65 20 73 63 68 65 6d 61 20 61 73 20 74  same schema as t
8e70: 68 65 20 74 61 62 6c 65 0a 20 20 20 20 2a 2a 20  he table.    ** 
8e80: 6f 72 20 65 6c 73 65 20 69 74 20 6d 75 73 74 20  or else it must 
8e90: 62 65 20 61 20 54 45 4d 50 20 74 72 69 67 67 65  be a TEMP trigge
8ea0: 72 2e 20 2a 2f 0a 20 20 20 20 61 73 73 65 72 74  r. */.    assert
8eb0: 28 20 70 2d 3e 70 53 63 68 65 6d 61 21 3d 30 20  ( p->pSchema!=0 
8ec0: 29 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 70  );.    assert( p
8ed0: 2d 3e 70 54 61 62 53 63 68 65 6d 61 21 3d 30 20  ->pTabSchema!=0 
8ee0: 29 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 70  );.    assert( p
8ef0: 2d 3e 70 53 63 68 65 6d 61 3d 3d 70 2d 3e 70 54  ->pSchema==p->pT
8f00: 61 62 53 63 68 65 6d 61 20 0a 20 20 20 20 20 20  abSchema .      
8f10: 20 20 20 7c 7c 20 70 2d 3e 70 53 63 68 65 6d 61     || p->pSchema
8f20: 3d 3d 70 50 61 72 73 65 2d 3e 64 62 2d 3e 61 44  ==pParse->db->aD
8f30: 62 5b 31 5d 2e 70 53 63 68 65 6d 61 20 29 3b 0a  b[1].pSchema );.
8f40: 0a 20 20 20 20 2f 2a 20 44 65 74 65 72 6d 69 6e  .    /* Determin
8f50: 65 20 77 68 65 74 68 65 72 20 77 65 20 73 68 6f  e whether we sho
8f60: 75 6c 64 20 63 6f 64 65 20 74 68 69 73 20 74 72  uld code this tr
8f70: 69 67 67 65 72 20 2a 2f 0a 20 20 20 20 69 66 28  igger */.    if(
8f80: 20 70 2d 3e 6f 70 3d 3d 6f 70 20 0a 20 20 20 20   p->op==op .    
8f90: 20 26 26 20 70 2d 3e 74 72 5f 74 6d 3d 3d 74 72   && p->tr_tm==tr
8fa0: 5f 74 6d 20 0a 20 20 20 20 20 26 26 20 63 68 65  _tm .     && che
8fb0: 63 6b 43 6f 6c 75 6d 6e 4f 76 65 72 6c 61 70 28  ckColumnOverlap(
8fc0: 70 2d 3e 70 43 6f 6c 75 6d 6e 73 2c 20 70 43 68  p->pColumns, pCh
8fd0: 61 6e 67 65 73 29 0a 20 20 20 20 29 7b 0a 20 20  anges).    ){.  
8fe0: 20 20 20 20 73 71 6c 69 74 65 33 43 6f 64 65 52      sqlite3CodeR
8ff0: 6f 77 54 72 69 67 67 65 72 44 69 72 65 63 74 28  owTriggerDirect(
9000: 70 50 61 72 73 65 2c 20 70 2c 20 70 54 61 62 2c  pParse, p, pTab,
9010: 20 72 65 67 2c 20 6f 72 63 6f 6e 66 2c 20 69 67   reg, orconf, ig
9020: 6e 6f 72 65 4a 75 6d 70 29 3b 0a 20 20 20 20 7d  noreJump);.    }
9030: 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 72  .  }.}../*.** Tr
9040: 69 67 67 65 72 73 20 6d 61 79 20 61 63 63 65 73  iggers may acces
9050: 73 20 76 61 6c 75 65 73 20 73 74 6f 72 65 64 20  s values stored 
9060: 69 6e 20 74 68 65 20 6f 6c 64 2e 2a 20 6f 72 20  in the old.* or 
9070: 6e 65 77 2e 2a 20 70 73 65 75 64 6f 2d 74 61 62  new.* pseudo-tab
9080: 6c 65 2e 20 0a 2a 2a 20 54 68 69 73 20 66 75 6e  le. .** This fun
9090: 63 74 69 6f 6e 20 72 65 74 75 72 6e 73 20 61 20  ction returns a 
90a0: 33 32 2d 62 69 74 20 62 69 74 6d 61 73 6b 20 69  32-bit bitmask i
90b0: 6e 64 69 63 61 74 69 6e 67 20 77 68 69 63 68 20  ndicating which 
90c0: 63 6f 6c 75 6d 6e 73 20 6f 66 20 74 68 65 20 0a  columns of the .
90d0: 2a 2a 20 6f 6c 64 2e 2a 20 6f 72 20 6e 65 77 2e  ** old.* or new.
90e0: 2a 20 74 61 62 6c 65 73 20 61 63 74 75 61 6c 6c  * tables actuall
90f0: 79 20 61 72 65 20 75 73 65 64 20 62 79 20 74 72  y are used by tr
9100: 69 67 67 65 72 73 2e 20 54 68 69 73 20 69 6e 66  iggers. This inf
9110: 6f 72 6d 61 74 69 6f 6e 20 0a 2a 2a 20 6d 61 79  ormation .** may
9120: 20 62 65 20 75 73 65 64 20 62 79 20 74 68 65 20   be used by the 
9130: 63 61 6c 6c 65 72 2c 20 66 6f 72 20 65 78 61 6d  caller, for exam
9140: 70 6c 65 2c 20 74 6f 20 61 76 6f 69 64 20 68 61  ple, to avoid ha
9150: 76 69 6e 67 20 74 6f 20 6c 6f 61 64 20 74 68 65  ving to load the
9160: 20 65 6e 74 69 72 65 0a 2a 2a 20 6f 6c 64 2e 2a   entire.** old.*
9170: 20 72 65 63 6f 72 64 20 69 6e 74 6f 20 6d 65 6d   record into mem
9180: 6f 72 79 20 77 68 65 6e 20 65 78 65 63 75 74 69  ory when executi
9190: 6e 67 20 61 6e 20 55 50 44 41 54 45 20 6f 72 20  ng an UPDATE or 
91a0: 44 45 4c 45 54 45 20 63 6f 6d 6d 61 6e 64 2e 0a  DELETE command..
91b0: 2a 2a 0a 2a 2a 20 42 69 74 20 30 20 6f 66 20 74  **.** Bit 0 of t
91c0: 68 65 20 72 65 74 75 72 6e 65 64 20 6d 61 73 6b  he returned mask
91d0: 20 69 73 20 73 65 74 20 69 66 20 74 68 65 20 6c   is set if the l
91e0: 65 66 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d 6e 20  eft-most column 
91f0: 6f 66 20 74 68 65 0a 2a 2a 20 74 61 62 6c 65 20  of the.** table 
9200: 6d 61 79 20 62 65 20 61 63 63 65 73 73 65 64 20  may be accessed 
9210: 75 73 69 6e 67 20 61 6e 20 5b 6f 6c 64 7c 6e 65  using an [old|ne
9220: 77 5d 2e 3c 63 6f 6c 3e 20 72 65 66 65 72 65 6e  w].<col> referen
9230: 63 65 2e 20 42 69 74 20 31 20 69 73 20 73 65 74  ce. Bit 1 is set
9240: 20 69 66 0a 2a 2a 20 74 68 65 20 73 65 63 6f 6e   if.** the secon
9250: 64 20 6c 65 66 74 6d 6f 73 74 20 63 6f 6c 75 6d  d leftmost colum
9260: 6e 20 76 61 6c 75 65 20 69 73 20 72 65 71 75 69  n value is requi
9270: 72 65 64 2c 20 61 6e 64 20 73 6f 20 6f 6e 2e 20  red, and so on. 
9280: 49 66 20 74 68 65 72 65 0a 2a 2a 20 61 72 65 20  If there.** are 
9290: 6d 6f 72 65 20 74 68 61 6e 20 33 32 20 63 6f 6c  more than 32 col
92a0: 75 6d 6e 73 20 69 6e 20 74 68 65 20 74 61 62 6c  umns in the tabl
92b0: 65 2c 20 61 6e 64 20 61 74 20 6c 65 61 73 74 20  e, and at least 
92c0: 6f 6e 65 20 6f 66 20 74 68 65 20 63 6f 6c 75 6d  one of the colum
92d0: 6e 73 0a 2a 2a 20 77 69 74 68 20 61 6e 20 69 6e  ns.** with an in
92e0: 64 65 78 20 67 72 65 61 74 65 72 20 74 68 61 6e  dex greater than
92f0: 20 33 32 20 6d 61 79 20 62 65 20 61 63 63 65 73   32 may be acces
9300: 73 65 64 2c 20 30 78 66 66 66 66 66 66 66 66 20  sed, 0xffffffff 
9310: 69 73 20 72 65 74 75 72 6e 65 64 2e 0a 2a 2a 0a  is returned..**.
9320: 2a 2a 20 49 74 20 69 73 20 6e 6f 74 20 70 6f 73  ** It is not pos
9330: 73 69 62 6c 65 20 74 6f 20 64 65 74 65 72 6d 69  sible to determi
9340: 6e 65 20 69 66 20 74 68 65 20 6f 6c 64 2e 72 6f  ne if the old.ro
9350: 77 69 64 20 6f 72 20 6e 65 77 2e 72 6f 77 69 64  wid or new.rowid
9360: 20 63 6f 6c 75 6d 6e 20 69 73 20 0a 2a 2a 20 61   column is .** a
9370: 63 63 65 73 73 65 64 20 62 79 20 74 72 69 67 67  ccessed by trigg
9380: 65 72 73 2e 20 54 68 65 20 63 61 6c 6c 65 72 20  ers. The caller 
9390: 6d 75 73 74 20 61 6c 77 61 79 73 20 61 73 73 75  must always assu
93a0: 6d 65 20 74 68 61 74 20 69 74 20 69 73 2e 0a 2a  me that it is..*
93b0: 2a 0a 2a 2a 20 50 61 72 61 6d 65 74 65 72 20 69  *.** Parameter i
93c0: 73 4e 65 77 20 6d 75 73 74 20 62 65 20 65 69 74  sNew must be eit
93d0: 68 65 72 20 31 20 6f 72 20 30 2e 20 49 66 20 69  her 1 or 0. If i
93e0: 74 20 69 73 20 30 2c 20 74 68 65 6e 20 74 68 65  t is 0, then the
93f0: 20 6d 61 73 6b 20 72 65 74 75 72 6e 65 64 0a 2a   mask returned.*
9400: 2a 20 61 70 70 6c 69 65 73 20 74 6f 20 74 68 65  * applies to the
9410: 20 6f 6c 64 2e 2a 20 74 61 62 6c 65 2e 20 49 66   old.* table. If
9420: 20 31 2c 20 74 68 65 20 6e 65 77 2e 2a 20 74 61   1, the new.* ta
9430: 62 6c 65 2e 0a 2a 2a 0a 2a 2a 20 50 61 72 61 6d  ble..**.** Param
9440: 65 74 65 72 20 74 72 5f 74 6d 20 6d 75 73 74 20  eter tr_tm must 
9450: 62 65 20 61 20 6d 61 73 6b 20 77 69 74 68 20 6f  be a mask with o
9460: 6e 65 20 6f 72 20 62 6f 74 68 20 6f 66 20 74 68  ne or both of th
9470: 65 20 54 52 49 47 47 45 52 5f 42 45 46 4f 52 45  e TRIGGER_BEFORE
9480: 0a 2a 2a 20 61 6e 64 20 54 52 49 47 47 45 52 5f  .** and TRIGGER_
9490: 41 46 54 45 52 20 62 69 74 73 20 73 65 74 2e 20  AFTER bits set. 
94a0: 56 61 6c 75 65 73 20 61 63 63 65 73 73 65 64 20  Values accessed 
94b0: 62 79 20 42 45 46 4f 52 45 20 74 72 69 67 67 65  by BEFORE trigge
94c0: 72 73 20 61 72 65 20 6f 6e 6c 79 0a 2a 2a 20 69  rs are only.** i
94d0: 6e 63 6c 75 64 65 64 20 69 6e 20 74 68 65 20 72  ncluded in the r
94e0: 65 74 75 72 6e 65 64 20 6d 61 73 6b 20 69 66 20  eturned mask if 
94f0: 74 68 65 20 54 52 49 47 47 45 52 5f 42 45 46 4f  the TRIGGER_BEFO
9500: 52 45 20 62 69 74 20 69 73 20 73 65 74 20 69 6e  RE bit is set in
9510: 20 74 68 65 0a 2a 2a 20 74 72 5f 74 6d 20 70 61   the.** tr_tm pa
9520: 72 61 6d 65 74 65 72 2e 20 53 69 6d 69 6c 61 72  rameter. Similar
9530: 6c 79 2c 20 76 61 6c 75 65 73 20 61 63 63 65 73  ly, values acces
9540: 73 65 64 20 62 79 20 41 46 54 45 52 20 74 72 69  sed by AFTER tri
9550: 67 67 65 72 73 20 61 72 65 20 6f 6e 6c 79 0a 2a  ggers are only.*
9560: 2a 20 69 6e 63 6c 75 64 65 64 20 69 6e 20 74 68  * included in th
9570: 65 20 72 65 74 75 72 6e 65 64 20 6d 61 73 6b 20  e returned mask 
9580: 69 66 20 74 68 65 20 54 52 49 47 47 45 52 5f 41  if the TRIGGER_A
9590: 46 54 45 52 20 62 69 74 20 69 73 20 73 65 74 20  FTER bit is set 
95a0: 69 6e 20 74 72 5f 74 6d 2e 0a 2a 2f 0a 75 33 32  in tr_tm..*/.u32
95b0: 20 73 71 6c 69 74 65 33 54 72 69 67 67 65 72 43   sqlite3TriggerC
95c0: 6f 6c 6d 61 73 6b 28 0a 20 20 50 61 72 73 65 20  olmask(.  Parse 
95d0: 2a 70 50 61 72 73 65 2c 20 20 20 20 20 20 20 2f  *pParse,       /
95e0: 2a 20 50 61 72 73 65 20 63 6f 6e 74 65 78 74 20  * Parse context 
95f0: 2a 2f 0a 20 20 54 72 69 67 67 65 72 20 2a 70 54  */.  Trigger *pT
9600: 72 69 67 67 65 72 2c 20 20 20 2f 2a 20 4c 69 73  rigger,   /* Lis
9610: 74 20 6f 66 20 74 72 69 67 67 65 72 73 20 6f 6e  t of triggers on
9620: 20 74 61 62 6c 65 20 70 54 61 62 20 2a 2f 0a 20   table pTab */. 
9630: 20 45 78 70 72 4c 69 73 74 20 2a 70 43 68 61 6e   ExprList *pChan
9640: 67 65 73 2c 20 20 2f 2a 20 43 68 61 6e 67 65 73  ges,  /* Changes
9650: 20 6c 69 73 74 20 66 6f 72 20 61 6e 79 20 55 50   list for any UP
9660: 44 41 54 45 20 4f 46 20 74 72 69 67 67 65 72 73  DATE OF triggers
9670: 20 2a 2f 0a 20 20 69 6e 74 20 69 73 4e 65 77 2c   */.  int isNew,
9680: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 31 20             /* 1 
9690: 66 6f 72 20 6e 65 77 2e 2a 20 72 65 66 20 6d 61  for new.* ref ma
96a0: 73 6b 2c 20 30 20 66 6f 72 20 6f 6c 64 2e 2a 20  sk, 0 for old.* 
96b0: 72 65 66 20 6d 61 73 6b 20 2a 2f 0a 20 20 69 6e  ref mask */.  in
96c0: 74 20 74 72 5f 74 6d 2c 20 20 20 20 20 20 20 20  t tr_tm,        
96d0: 20 20 20 2f 2a 20 4d 61 73 6b 20 6f 66 20 54 52     /* Mask of TR
96e0: 49 47 47 45 52 5f 42 45 46 4f 52 45 7c 54 52 49  IGGER_BEFORE|TRI
96f0: 47 47 45 52 5f 41 46 54 45 52 20 2a 2f 0a 20 20  GGER_AFTER */.  
9700: 54 61 62 6c 65 20 2a 70 54 61 62 2c 20 20 20 20  Table *pTab,    
9710: 20 20 20 20 20 2f 2a 20 54 68 65 20 74 61 62 6c       /* The tabl
9720: 65 20 74 6f 20 63 6f 64 65 20 74 72 69 67 67 65  e to code trigge
9730: 72 73 20 66 72 6f 6d 20 2a 2f 0a 20 20 69 6e 74  rs from */.  int
9740: 20 6f 72 63 6f 6e 66 20 20 20 20 20 20 20 20 20   orconf         
9750: 20 20 2f 2a 20 44 65 66 61 75 6c 74 20 4f 4e 20    /* Default ON 
9760: 43 4f 4e 46 4c 49 43 54 20 70 6f 6c 69 63 79 20  CONFLICT policy 
9770: 66 6f 72 20 74 72 69 67 67 65 72 20 73 74 65 70  for trigger step
9780: 73 20 2a 2f 0a 29 7b 0a 20 20 63 6f 6e 73 74 20  s */.){.  const 
9790: 69 6e 74 20 6f 70 20 3d 20 70 43 68 61 6e 67 65  int op = pChange
97a0: 73 20 3f 20 54 4b 5f 55 50 44 41 54 45 20 3a 20  s ? TK_UPDATE : 
97b0: 54 4b 5f 44 45 4c 45 54 45 3b 0a 20 20 75 33 32  TK_DELETE;.  u32
97c0: 20 6d 61 73 6b 20 3d 20 30 3b 0a 20 20 54 72 69   mask = 0;.  Tri
97d0: 67 67 65 72 20 2a 70 3b 0a 0a 20 20 61 73 73 65  gger *p;..  asse
97e0: 72 74 28 20 69 73 4e 65 77 3d 3d 31 20 7c 7c 20  rt( isNew==1 || 
97f0: 69 73 4e 65 77 3d 3d 30 20 29 3b 0a 20 20 66 6f  isNew==0 );.  fo
9800: 72 28 70 3d 70 54 72 69 67 67 65 72 3b 20 70 3b  r(p=pTrigger; p;
9810: 20 70 3d 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20   p=p->pNext){.  
9820: 20 20 69 66 28 20 70 2d 3e 6f 70 3d 3d 6f 70 20    if( p->op==op 
9830: 26 26 20 28 74 72 5f 74 6d 26 70 2d 3e 74 72 5f  && (tr_tm&p->tr_
9840: 74 6d 29 0a 20 20 20 20 20 26 26 20 63 68 65 63  tm).     && chec
9850: 6b 43 6f 6c 75 6d 6e 4f 76 65 72 6c 61 70 28 70  kColumnOverlap(p
9860: 2d 3e 70 43 6f 6c 75 6d 6e 73 2c 70 43 68 61 6e  ->pColumns,pChan
9870: 67 65 73 29 0a 20 20 20 20 29 7b 0a 20 20 20 20  ges).    ){.    
9880: 20 20 54 72 69 67 67 65 72 50 72 67 20 2a 70 50    TriggerPrg *pP
9890: 72 67 3b 0a 20 20 20 20 20 20 70 50 72 67 20 3d  rg;.      pPrg =
98a0: 20 67 65 74 52 6f 77 54 72 69 67 67 65 72 28 70   getRowTrigger(p
98b0: 50 61 72 73 65 2c 20 70 2c 20 70 54 61 62 2c 20  Parse, p, pTab, 
98c0: 6f 72 63 6f 6e 66 29 3b 0a 20 20 20 20 20 20 69  orconf);.      i
98d0: 66 28 20 70 50 72 67 20 29 7b 0a 20 20 20 20 20  f( pPrg ){.     
98e0: 20 20 20 6d 61 73 6b 20 7c 3d 20 70 50 72 67 2d     mask |= pPrg-
98f0: 3e 61 43 6f 6c 6d 61 73 6b 5b 69 73 4e 65 77 5d  >aColmask[isNew]
9900: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  ;.      }.    }.
9910: 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20 6d 61    }..  return ma
9920: 73 6b 3b 0a 7d 0a 0a 23 65 6e 64 69 66 20 2f 2a  sk;.}..#endif /*
9930: 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45   !defined(SQLITE
9940: 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 29 20 2a  _OMIT_TRIGGER) *
9950: 2f 0a                                            /.