/ Hex Artifact Content
Login

Artifact 3419bb9862983d84d70735fb4c94b21b934cd0c5:


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 74 6f 6b 65 6e 20 3d 20 28 76 6f  ram->token = (vo
75e0: 69 64 20 2a 29 70 54 72 69 67 67 65 72 3b 0a 20  id *)pTrigger;. 
75f0: 20 20 20 70 50 72 67 2d 3e 61 43 6f 6c 6d 61 73     pPrg->aColmas
7600: 6b 5b 30 5d 20 3d 20 70 53 75 62 50 61 72 73 65  k[0] = pSubParse
7610: 2d 3e 6f 6c 64 6d 61 73 6b 3b 0a 20 20 20 20 70  ->oldmask;.    p
7620: 50 72 67 2d 3e 61 43 6f 6c 6d 61 73 6b 5b 31 5d  Prg->aColmask[1]
7630: 20 3d 20 70 53 75 62 50 61 72 73 65 2d 3e 6e 65   = pSubParse->ne
7640: 77 6d 61 73 6b 3b 0a 20 20 20 20 73 71 6c 69 74  wmask;.    sqlit
7650: 65 33 56 64 62 65 44 65 6c 65 74 65 28 76 29 3b  e3VdbeDelete(v);
7660: 0a 20 20 7d 0a 0a 20 20 61 73 73 65 72 74 28 20  .  }..  assert( 
7670: 21 70 53 75 62 50 61 72 73 65 2d 3e 70 41 69 6e  !pSubParse->pAin
7680: 63 20 20 20 20 20 20 20 26 26 20 21 70 53 75 62  c       && !pSub
7690: 50 61 72 73 65 2d 3e 70 5a 6f 6d 62 69 65 54 61  Parse->pZombieTa
76a0: 62 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 21  b );.  assert( !
76b0: 70 53 75 62 50 61 72 73 65 2d 3e 70 54 72 69 67  pSubParse->pTrig
76c0: 67 65 72 50 72 67 20 26 26 20 21 70 53 75 62 50  gerPrg && !pSubP
76d0: 61 72 73 65 2d 3e 6e 4d 61 78 41 72 67 20 29 3b  arse->nMaxArg );
76e0: 0a 20 20 73 71 6c 69 74 65 33 50 61 72 73 65 72  .  sqlite3Parser
76f0: 52 65 73 65 74 28 70 53 75 62 50 61 72 73 65 29  Reset(pSubParse)
7700: 3b 0a 20 20 73 71 6c 69 74 65 33 53 74 61 63 6b  ;.  sqlite3Stack
7710: 46 72 65 65 28 64 62 2c 20 70 53 75 62 50 61 72  Free(db, pSubPar
7720: 73 65 29 3b 0a 0a 20 20 72 65 74 75 72 6e 20 70  se);..  return p
7730: 50 72 67 3b 0a 7d 0a 20 20 20 20 0a 2f 2a 0a 2a  Prg;.}.    ./*.*
7740: 2a 20 52 65 74 75 72 6e 20 61 20 70 6f 69 6e 74  * Return a point
7750: 65 72 20 74 6f 20 61 20 54 72 69 67 67 65 72 50  er to a TriggerP
7760: 72 67 20 6f 62 6a 65 63 74 20 63 6f 6e 74 61 69  rg object contai
7770: 6e 69 6e 67 20 74 68 65 20 73 75 62 2d 70 72 6f  ning the sub-pro
7780: 67 72 61 6d 20 66 6f 72 0a 2a 2a 20 74 72 69 67  gram for.** trig
7790: 67 65 72 20 70 54 72 69 67 67 65 72 20 77 69 74  ger pTrigger wit
77a0: 68 20 64 65 66 61 75 6c 74 20 4f 4e 20 43 4f 4e  h default ON CON
77b0: 46 4c 49 43 54 20 61 6c 67 6f 72 69 74 68 6d 20  FLICT algorithm 
77c0: 6f 72 63 6f 6e 66 2e 20 49 66 20 6e 6f 20 73 75  orconf. If no su
77d0: 63 68 0a 2a 2a 20 54 72 69 67 67 65 72 50 72 67  ch.** TriggerPrg
77e0: 20 6f 62 6a 65 63 74 20 65 78 69 73 74 73 2c 20   object exists, 
77f0: 61 20 6e 65 77 20 6f 62 6a 65 63 74 20 69 73 20  a new object is 
7800: 61 6c 6c 6f 63 61 74 65 64 20 61 6e 64 20 70 6f  allocated and po
7810: 70 75 6c 61 74 65 64 20 62 65 66 6f 72 65 0a 2a  pulated before.*
7820: 2a 20 62 65 69 6e 67 20 72 65 74 75 72 6e 65 64  * being returned
7830: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 54 72 69 67  ..*/.static Trig
7840: 67 65 72 50 72 67 20 2a 67 65 74 52 6f 77 54 72  gerPrg *getRowTr
7850: 69 67 67 65 72 28 0a 20 20 50 61 72 73 65 20 2a  igger(.  Parse *
7860: 70 50 61 72 73 65 2c 20 20 20 20 20 20 20 2f 2a  pParse,       /*
7870: 20 43 75 72 72 65 6e 74 20 70 61 72 73 65 20 63   Current parse c
7880: 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54 72 69 67  ontext */.  Trig
7890: 67 65 72 20 2a 70 54 72 69 67 67 65 72 2c 20 20  ger *pTrigger,  
78a0: 20 2f 2a 20 54 72 69 67 67 65 72 20 74 6f 20 63   /* Trigger to c
78b0: 6f 64 65 20 2a 2f 0a 20 20 54 61 62 6c 65 20 2a  ode */.  Table *
78c0: 70 54 61 62 2c 20 20 20 20 20 20 20 20 20 2f 2a  pTab,         /*
78d0: 20 54 68 65 20 74 61 62 6c 65 20 74 72 69 67 67   The table trigg
78e0: 65 72 20 70 54 72 69 67 67 65 72 20 69 73 20 61  er pTrigger is a
78f0: 74 74 61 63 68 65 64 20 74 6f 20 2a 2f 0a 20 20  ttached to */.  
7900: 69 6e 74 20 6f 72 63 6f 6e 66 20 20 20 20 20 20  int orconf      
7910: 20 20 20 20 20 2f 2a 20 4f 4e 20 43 4f 4e 46 4c       /* ON CONFL
7920: 49 43 54 20 61 6c 67 6f 72 69 74 68 6d 2e 20 2a  ICT algorithm. *
7930: 2f 0a 29 7b 0a 20 20 50 61 72 73 65 20 2a 70 52  /.){.  Parse *pR
7940: 6f 6f 74 20 3d 20 73 71 6c 69 74 65 33 50 61 72  oot = sqlite3Par
7950: 73 65 54 6f 70 6c 65 76 65 6c 28 70 50 61 72 73  seToplevel(pPars
7960: 65 29 3b 0a 20 20 54 72 69 67 67 65 72 50 72 67  e);.  TriggerPrg
7970: 20 2a 70 50 72 67 3b 0a 0a 20 20 61 73 73 65 72   *pPrg;..  asser
7980: 74 28 20 70 54 72 69 67 67 65 72 2d 3e 7a 4e 61  t( pTrigger->zNa
7990: 6d 65 3d 3d 30 20 7c 7c 20 70 54 61 62 3d 3d 74  me==0 || pTab==t
79a0: 61 62 6c 65 4f 66 54 72 69 67 67 65 72 28 70 54  ableOfTrigger(pT
79b0: 72 69 67 67 65 72 29 20 29 3b 0a 0a 20 20 2f 2a  rigger) );..  /*
79c0: 20 49 74 20 6d 61 79 20 62 65 20 74 68 61 74 20   It may be that 
79d0: 74 68 69 73 20 74 72 69 67 67 65 72 20 68 61 73  this trigger has
79e0: 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 63 6f   already been co
79f0: 64 65 64 20 28 6f 72 20 69 73 20 69 6e 20 74 68  ded (or is in th
7a00: 65 0a 20 20 2a 2a 20 70 72 6f 63 65 73 73 20 6f  e.  ** process o
7a10: 66 20 62 65 69 6e 67 20 63 6f 64 65 64 29 2e 20  f being coded). 
7a20: 49 66 20 74 68 69 73 20 69 73 20 74 68 65 20 63  If this is the c
7a30: 61 73 65 2c 20 74 68 65 6e 20 61 6e 20 65 6e 74  ase, then an ent
7a40: 72 79 20 77 69 74 68 0a 20 20 2a 2a 20 61 20 6d  ry with.  ** a m
7a50: 61 74 63 68 69 6e 67 20 54 72 69 67 67 65 72 50  atching TriggerP
7a60: 72 67 2e 70 54 72 69 67 67 65 72 20 66 69 65 6c  rg.pTrigger fiel
7a70: 64 20 77 69 6c 6c 20 62 65 20 70 72 65 73 65 6e  d will be presen
7a80: 74 20 73 6f 6d 65 77 68 65 72 65 0a 20 20 2a 2a  t somewhere.  **
7a90: 20 69 6e 20 74 68 65 20 50 61 72 73 65 2e 70 54   in the Parse.pT
7aa0: 72 69 67 67 65 72 50 72 67 20 6c 69 73 74 2e 20  riggerPrg list. 
7ab0: 53 65 61 72 63 68 20 66 6f 72 20 73 75 63 68 20  Search for such 
7ac0: 61 6e 20 65 6e 74 72 79 2e 20 20 2a 2f 0a 20 20  an entry.  */.  
7ad0: 66 6f 72 28 70 50 72 67 3d 70 52 6f 6f 74 2d 3e  for(pPrg=pRoot->
7ae0: 70 54 72 69 67 67 65 72 50 72 67 3b 20 0a 20 20  pTriggerPrg; .  
7af0: 20 20 20 20 70 50 72 67 20 26 26 20 28 70 50 72      pPrg && (pPr
7b00: 67 2d 3e 70 54 72 69 67 67 65 72 21 3d 70 54 72  g->pTrigger!=pTr
7b10: 69 67 67 65 72 20 7c 7c 20 70 50 72 67 2d 3e 6f  igger || pPrg->o
7b20: 72 63 6f 6e 66 21 3d 6f 72 63 6f 6e 66 29 3b 20  rconf!=orconf); 
7b30: 0a 20 20 20 20 20 20 70 50 72 67 3d 70 50 72 67  .      pPrg=pPrg
7b40: 2d 3e 70 4e 65 78 74 0a 20 20 29 3b 0a 0a 20 20  ->pNext.  );..  
7b50: 2f 2a 20 49 66 20 61 6e 20 65 78 69 73 74 69 6e  /* If an existin
7b60: 67 20 54 72 69 67 67 65 72 50 72 67 20 63 6f 75  g TriggerPrg cou
7b70: 6c 64 20 6e 6f 74 20 62 65 20 6c 6f 63 61 74 65  ld not be locate
7b80: 64 2c 20 63 72 65 61 74 65 20 61 20 6e 65 77 20  d, create a new 
7b90: 6f 6e 65 2e 20 2a 2f 0a 20 20 69 66 28 20 21 70  one. */.  if( !p
7ba0: 50 72 67 20 29 7b 0a 20 20 20 20 70 50 72 67 20  Prg ){.    pPrg 
7bb0: 3d 20 63 6f 64 65 52 6f 77 54 72 69 67 67 65 72  = codeRowTrigger
7bc0: 28 70 50 61 72 73 65 2c 20 70 54 72 69 67 67 65  (pParse, pTrigge
7bd0: 72 2c 20 70 54 61 62 2c 20 6f 72 63 6f 6e 66 29  r, pTab, orconf)
7be0: 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20  ;.  }..  return 
7bf0: 70 50 72 67 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 47  pPrg;.}../*.** G
7c00: 65 6e 65 72 61 74 65 20 63 6f 64 65 20 66 6f 72  enerate code for
7c10: 20 74 68 65 20 74 72 69 67 67 65 72 20 70 72 6f   the trigger pro
7c20: 67 72 61 6d 20 61 73 73 6f 63 69 61 74 65 64 20  gram associated 
7c30: 77 69 74 68 20 74 72 69 67 67 65 72 20 70 20 6f  with trigger p o
7c40: 6e 20 0a 2a 2a 20 74 61 62 6c 65 20 70 54 61 62  n .** table pTab
7c50: 2e 20 54 68 65 20 72 65 67 2c 20 6f 72 63 6f 6e  . The reg, orcon
7c60: 66 20 61 6e 64 20 69 67 6e 6f 72 65 4a 75 6d 70  f and ignoreJump
7c70: 20 70 61 72 61 6d 65 74 65 72 73 20 70 61 73 73   parameters pass
7c80: 65 64 20 74 6f 20 74 68 69 73 0a 2a 2a 20 66 75  ed to this.** fu
7c90: 6e 63 74 69 6f 6e 20 61 72 65 20 74 68 65 20 73  nction are the s
7ca0: 61 6d 65 20 61 73 20 74 68 6f 73 65 20 64 65 73  ame as those des
7cb0: 63 72 69 62 65 64 20 69 6e 20 74 68 65 20 68 65  cribed in the he
7cc0: 61 64 65 72 20 66 75 6e 63 74 69 6f 6e 20 66 6f  ader function fo
7cd0: 72 0a 2a 2a 20 73 71 6c 69 74 65 33 43 6f 64 65  r.** sqlite3Code
7ce0: 52 6f 77 54 72 69 67 67 65 72 28 29 0a 2a 2f 0a  RowTrigger().*/.
7cf0: 76 6f 69 64 20 73 71 6c 69 74 65 33 43 6f 64 65  void sqlite3Code
7d00: 52 6f 77 54 72 69 67 67 65 72 44 69 72 65 63 74  RowTriggerDirect
7d10: 28 0a 20 20 50 61 72 73 65 20 2a 70 50 61 72 73  (.  Parse *pPars
7d20: 65 2c 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73  e,       /* Pars
7d30: 65 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54  e context */.  T
7d40: 72 69 67 67 65 72 20 2a 70 2c 20 20 20 20 20 20  rigger *p,      
7d50: 20 20 20 20 2f 2a 20 54 72 69 67 67 65 72 20 74      /* Trigger t
7d60: 6f 20 63 6f 64 65 20 2a 2f 0a 20 20 54 61 62 6c  o code */.  Tabl
7d70: 65 20 2a 70 54 61 62 2c 20 20 20 20 20 20 20 20  e *pTab,        
7d80: 20 2f 2a 20 54 68 65 20 74 61 62 6c 65 20 74 6f   /* The table to
7d90: 20 63 6f 64 65 20 74 72 69 67 67 65 72 73 20 66   code triggers f
7da0: 72 6f 6d 20 2a 2f 0a 20 20 69 6e 74 20 72 65 67  rom */.  int reg
7db0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ,             /*
7dc0: 20 52 65 67 20 61 72 72 61 79 20 63 6f 6e 74 61   Reg array conta
7dd0: 69 6e 69 6e 67 20 4f 4c 44 2e 2a 20 61 6e 64 20  ining OLD.* and 
7de0: 4e 45 57 2e 2a 20 76 61 6c 75 65 73 20 2a 2f 0a  NEW.* values */.
7df0: 20 20 69 6e 74 20 6f 72 63 6f 6e 66 2c 20 20 20    int orconf,   
7e00: 20 20 20 20 20 20 20 2f 2a 20 4f 4e 20 43 4f 4e         /* ON CON
7e10: 46 4c 49 43 54 20 70 6f 6c 69 63 79 20 2a 2f 0a  FLICT policy */.
7e20: 20 20 69 6e 74 20 69 67 6e 6f 72 65 4a 75 6d 70    int ignoreJump
7e30: 20 20 20 20 20 20 20 2f 2a 20 49 6e 73 74 72 75         /* Instru
7e40: 63 74 69 6f 6e 20 74 6f 20 6a 75 6d 70 20 74 6f  ction to jump to
7e50: 20 66 6f 72 20 52 41 49 53 45 28 49 47 4e 4f 52   for RAISE(IGNOR
7e60: 45 29 20 2a 2f 0a 29 7b 0a 20 20 56 64 62 65 20  E) */.){.  Vdbe 
7e70: 2a 76 20 3d 20 73 71 6c 69 74 65 33 47 65 74 56  *v = sqlite3GetV
7e80: 64 62 65 28 70 50 61 72 73 65 29 3b 20 2f 2a 20  dbe(pParse); /* 
7e90: 4d 61 69 6e 20 56 4d 20 2a 2f 0a 20 20 54 72 69  Main VM */.  Tri
7ea0: 67 67 65 72 50 72 67 20 2a 70 50 72 67 3b 0a 20  ggerPrg *pPrg;. 
7eb0: 20 70 50 72 67 20 3d 20 67 65 74 52 6f 77 54 72   pPrg = getRowTr
7ec0: 69 67 67 65 72 28 70 50 61 72 73 65 2c 20 70 2c  igger(pParse, p,
7ed0: 20 70 54 61 62 2c 20 6f 72 63 6f 6e 66 29 3b 0a   pTab, orconf);.
7ee0: 20 20 61 73 73 65 72 74 28 20 70 50 72 67 20 7c    assert( pPrg |
7ef0: 7c 20 70 50 61 72 73 65 2d 3e 6e 45 72 72 20 7c  | pParse->nErr |
7f00: 7c 20 70 50 61 72 73 65 2d 3e 64 62 2d 3e 6d 61  | pParse->db->ma
7f10: 6c 6c 6f 63 46 61 69 6c 65 64 20 29 3b 0a 0a 20  llocFailed );.. 
7f20: 20 2f 2a 20 43 6f 64 65 20 74 68 65 20 4f 50 5f   /* Code the OP_
7f30: 50 72 6f 67 72 61 6d 20 6f 70 63 6f 64 65 20 69  Program opcode i
7f40: 6e 20 74 68 65 20 70 61 72 65 6e 74 20 56 44 42  n the parent VDB
7f50: 45 2e 20 50 34 20 6f 66 20 74 68 65 20 4f 50 5f  E. P4 of the OP_
7f60: 50 72 6f 67 72 61 6d 20 0a 20 20 2a 2a 20 69 73  Program .  ** is
7f70: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68   a pointer to th
7f80: 65 20 73 75 62 2d 76 64 62 65 20 63 6f 6e 74 61  e sub-vdbe conta
7f90: 69 6e 69 6e 67 20 74 68 65 20 74 72 69 67 67 65  ining the trigge
7fa0: 72 20 70 72 6f 67 72 61 6d 2e 20 20 2a 2f 0a 20  r program.  */. 
7fb0: 20 69 66 28 20 70 50 72 67 20 29 7b 0a 20 20 20   if( pPrg ){.   
7fc0: 20 69 6e 74 20 62 52 65 63 75 72 73 69 76 65 20   int bRecursive 
7fd0: 3d 20 28 70 2d 3e 7a 4e 61 6d 65 20 26 26 20 30  = (p->zName && 0
7fe0: 3d 3d 28 70 50 61 72 73 65 2d 3e 64 62 2d 3e 66  ==(pParse->db->f
7ff0: 6c 61 67 73 26 53 51 4c 49 54 45 5f 52 65 63 54  lags&SQLITE_RecT
8000: 72 69 67 67 65 72 73 29 29 3b 0a 0a 20 20 20 20  riggers));..    
8010: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70  sqlite3VdbeAddOp
8020: 34 28 76 2c 20 4f 50 5f 50 72 6f 67 72 61 6d 2c  4(v, OP_Program,
8030: 20 72 65 67 2c 20 69 67 6e 6f 72 65 4a 75 6d 70   reg, ignoreJump
8040: 2c 20 2b 2b 70 50 61 72 73 65 2d 3e 6e 4d 65 6d  , ++pParse->nMem
8050: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
8060: 20 20 20 20 20 20 20 20 28 63 6f 6e 73 74 20 63          (const c
8070: 68 61 72 20 2a 29 70 50 72 67 2d 3e 70 50 72 6f  har *)pPrg->pPro
8080: 67 72 61 6d 2c 20 50 34 5f 53 55 42 50 52 4f 47  gram, P4_SUBPROG
8090: 52 41 4d 29 3b 0a 20 20 20 20 56 64 62 65 43 6f  RAM);.    VdbeCo
80a0: 6d 6d 65 6e 74 28 0a 20 20 20 20 20 20 20 20 28  mment(.        (
80b0: 76 2c 20 22 43 61 6c 6c 3a 20 25 73 2e 25 73 22  v, "Call: %s.%s"
80c0: 2c 20 28 70 2d 3e 7a 4e 61 6d 65 3f 70 2d 3e 7a  , (p->zName?p->z
80d0: 4e 61 6d 65 3a 22 66 6b 65 79 22 29 2c 20 6f 6e  Name:"fkey"), on
80e0: 45 72 72 6f 72 54 65 78 74 28 6f 72 63 6f 6e 66  ErrorText(orconf
80f0: 29 29 29 3b 0a 0a 20 20 20 20 2f 2a 20 53 65 74  )));..    /* Set
8100: 20 74 68 65 20 50 35 20 6f 70 65 72 61 6e 64 20   the P5 operand 
8110: 6f 66 20 74 68 65 20 4f 50 5f 50 72 6f 67 72 61  of the OP_Progra
8120: 6d 20 69 6e 73 74 72 75 63 74 69 6f 6e 20 74 6f  m instruction to
8130: 20 6e 6f 6e 2d 7a 65 72 6f 20 69 66 0a 20 20 20   non-zero if.   
8140: 20 2a 2a 20 72 65 63 75 72 73 69 76 65 20 69 6e   ** recursive in
8150: 76 6f 63 61 74 69 6f 6e 20 6f 66 20 74 68 69 73  vocation of this
8160: 20 74 72 69 67 67 65 72 20 70 72 6f 67 72 61 6d   trigger program
8170: 20 69 73 20 64 69 73 61 6c 6c 6f 77 65 64 2e 20   is disallowed. 
8180: 52 65 63 75 72 73 69 76 65 0a 20 20 20 20 2a 2a  Recursive.    **
8190: 20 69 6e 76 6f 63 61 74 69 6f 6e 20 69 73 20 64   invocation is d
81a0: 69 73 61 6c 6c 6f 77 65 64 20 69 66 20 28 61 29  isallowed if (a)
81b0: 20 74 68 65 20 73 75 62 2d 70 72 6f 67 72 61 6d   the sub-program
81c0: 20 69 73 20 72 65 61 6c 6c 79 20 61 20 74 72 69   is really a tri
81d0: 67 67 65 72 2c 0a 20 20 20 20 2a 2a 20 6e 6f 74  gger,.    ** not
81e0: 20 61 20 66 6f 72 65 69 67 6e 20 6b 65 79 20 61   a foreign key a
81f0: 63 74 69 6f 6e 2c 20 61 6e 64 20 28 62 29 20 74  ction, and (b) t
8200: 68 65 20 66 6c 61 67 20 74 6f 20 65 6e 61 62 6c  he flag to enabl
8210: 65 20 72 65 63 75 72 73 69 76 65 20 74 72 69 67  e recursive trig
8220: 67 65 72 73 0a 20 20 20 20 2a 2a 20 69 73 20 63  gers.    ** is c
8230: 6c 65 61 72 2e 20 20 2a 2f 0a 20 20 20 20 73 71  lear.  */.    sq
8240: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
8250: 35 28 76 2c 20 28 75 38 29 62 52 65 63 75 72 73  5(v, (u8)bRecurs
8260: 69 76 65 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a  ive);.  }.}../*.
8270: 2a 2a 20 54 68 69 73 20 69 73 20 63 61 6c 6c 65  ** This is calle
8280: 64 20 74 6f 20 63 6f 64 65 20 74 68 65 20 72 65  d to code the re
8290: 71 75 69 72 65 64 20 46 4f 52 20 45 41 43 48 20  quired FOR EACH 
82a0: 52 4f 57 20 74 72 69 67 67 65 72 73 20 66 6f 72  ROW triggers for
82b0: 20 61 6e 20 6f 70 65 72 61 74 69 6f 6e 0a 2a 2a   an operation.**
82c0: 20 6f 6e 20 74 61 62 6c 65 20 70 54 61 62 2e 20   on table pTab. 
82d0: 54 68 65 20 6f 70 65 72 61 74 69 6f 6e 20 74 6f  The operation to
82e0: 20 63 6f 64 65 20 74 72 69 67 67 65 72 73 20 66   code triggers f
82f0: 6f 72 20 28 49 4e 53 45 52 54 2c 20 55 50 44 41  or (INSERT, UPDA
8300: 54 45 20 6f 72 20 44 45 4c 45 54 45 29 0a 2a 2a  TE or DELETE).**
8310: 20 69 73 20 67 69 76 65 6e 20 62 79 20 74 68 65   is given by the
8320: 20 6f 70 20 70 61 72 61 6d 65 74 65 72 2e 20 54   op parameter. T
8330: 68 65 20 74 72 5f 74 6d 20 70 61 72 61 6d 65 74  he tr_tm paramet
8340: 65 72 20 64 65 74 65 72 6d 69 6e 65 73 20 77 68  er determines wh
8350: 65 74 68 65 72 20 74 68 65 0a 2a 2a 20 42 45 46  ether the.** BEF
8360: 4f 52 45 20 6f 72 20 41 46 54 45 52 20 74 72 69  ORE or AFTER tri
8370: 67 67 65 72 73 20 61 72 65 20 63 6f 64 65 64 2e  ggers are coded.
8380: 20 49 66 20 74 68 65 20 6f 70 65 72 61 74 69 6f   If the operatio
8390: 6e 20 69 73 20 61 6e 20 55 50 44 41 54 45 2c 20  n is an UPDATE, 
83a0: 74 68 65 6e 0a 2a 2a 20 70 61 72 61 6d 65 74 65  then.** paramete
83b0: 72 20 70 43 68 61 6e 67 65 73 20 69 73 20 70 61  r pChanges is pa
83c0: 73 73 65 64 20 74 68 65 20 6c 69 73 74 20 6f 66  ssed the list of
83d0: 20 63 6f 6c 75 6d 6e 73 20 62 65 69 6e 67 20 6d   columns being m
83e0: 6f 64 69 66 69 65 64 2e 0a 2a 2a 0a 2a 2a 20 49  odified..**.** I
83f0: 66 20 74 68 65 72 65 20 61 72 65 20 6e 6f 20 74  f there are no t
8400: 72 69 67 67 65 72 73 20 74 68 61 74 20 66 69 72  riggers that fir
8410: 65 20 61 74 20 74 68 65 20 73 70 65 63 69 66 69  e at the specifi
8420: 65 64 20 74 69 6d 65 20 66 6f 72 20 74 68 65 20  ed time for the 
8430: 73 70 65 63 69 66 69 65 64 0a 2a 2a 20 6f 70 65  specified.** ope
8440: 72 61 74 69 6f 6e 20 6f 6e 20 70 54 61 62 2c 20  ration on pTab, 
8450: 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 69 73  this function is
8460: 20 61 20 6e 6f 2d 6f 70 2e 0a 2a 2a 0a 2a 2a 20   a no-op..**.** 
8470: 54 68 65 20 72 65 67 20 61 72 67 75 6d 65 6e 74  The reg argument
8480: 20 69 73 20 74 68 65 20 61 64 64 72 65 73 73 20   is the address 
8490: 6f 66 20 74 68 65 20 66 69 72 73 74 20 69 6e 20  of the first in 
84a0: 61 6e 20 61 72 72 61 79 20 6f 66 20 72 65 67 69  an array of regi
84b0: 73 74 65 72 73 20 0a 2a 2a 20 74 68 61 74 20 63  sters .** that c
84c0: 6f 6e 74 61 69 6e 20 74 68 65 20 76 61 6c 75 65  ontain the value
84d0: 73 20 73 75 62 73 74 69 74 75 74 65 64 20 66 6f  s substituted fo
84e0: 72 20 74 68 65 20 6e 65 77 2e 2a 20 61 6e 64 20  r the new.* and 
84f0: 6f 6c 64 2e 2a 20 72 65 66 65 72 65 6e 63 65 73  old.* references
8500: 0a 2a 2a 20 69 6e 20 74 68 65 20 74 72 69 67 67  .** in the trigg
8510: 65 72 20 70 72 6f 67 72 61 6d 2e 20 49 66 20 4e  er program. If N
8520: 20 69 73 20 74 68 65 20 6e 75 6d 62 65 72 20 6f   is the number o
8530: 66 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 74 61 62  f columns in tab
8540: 6c 65 20 70 54 61 62 0a 2a 2a 20 28 61 20 63 6f  le pTab.** (a co
8550: 70 79 20 6f 66 20 70 54 61 62 2d 3e 6e 43 6f 6c  py of pTab->nCol
8560: 29 2c 20 74 68 65 6e 20 72 65 67 69 73 74 65 72  ), then register
8570: 73 20 61 72 65 20 70 6f 70 75 6c 61 74 65 64 20  s are populated 
8580: 61 73 20 66 6f 6c 6c 6f 77 73 3a 0a 2a 2a 0a 2a  as follows:.**.*
8590: 2a 20 20 20 52 65 67 69 73 74 65 72 20 20 20 20  *   Register    
85a0: 20 20 20 43 6f 6e 74 61 69 6e 73 0a 2a 2a 20 20     Contains.**  
85b0: 20 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   ---------------
85c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
85d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
85e0: 2d 2d 2d 2d 2d 2d 2d 0a 2a 2a 20 20 20 72 65 67  -------.**   reg
85f0: 2b 30 20 20 20 20 20 20 20 20 20 20 4f 4c 44 2e  +0          OLD.
8600: 72 6f 77 69 64 0a 2a 2a 20 20 20 72 65 67 2b 31  rowid.**   reg+1
8610: 20 20 20 20 20 20 20 20 20 20 4f 4c 44 2e 2a 20            OLD.* 
8620: 76 61 6c 75 65 20 6f 66 20 6c 65 66 74 2d 6d 6f  value of left-mo
8630: 73 74 20 63 6f 6c 75 6d 6e 20 6f 66 20 70 54 61  st column of pTa
8640: 62 0a 2a 2a 20 20 20 2e 2e 2e 20 20 20 20 20 20  b.**   ...      
8650: 20 20 20 20 20 20 2e 2e 2e 0a 2a 2a 20 20 20 72        ....**   r
8660: 65 67 2b 4e 20 20 20 20 20 20 20 20 20 20 4f 4c  eg+N          OL
8670: 44 2e 2a 20 76 61 6c 75 65 20 6f 66 20 72 69 67  D.* value of rig
8680: 68 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d 6e 20 6f  ht-most column o
8690: 66 20 70 54 61 62 0a 2a 2a 20 20 20 72 65 67 2b  f pTab.**   reg+
86a0: 4e 2b 31 20 20 20 20 20 20 20 20 4e 45 57 2e 72  N+1        NEW.r
86b0: 6f 77 69 64 0a 2a 2a 20 20 20 72 65 67 2b 4e 2b  owid.**   reg+N+
86c0: 32 20 20 20 20 20 20 20 20 4f 4c 44 2e 2a 20 76  2        OLD.* v
86d0: 61 6c 75 65 20 6f 66 20 6c 65 66 74 2d 6d 6f 73  alue of left-mos
86e0: 74 20 63 6f 6c 75 6d 6e 20 6f 66 20 70 54 61 62  t column of pTab
86f0: 0a 2a 2a 20 20 20 2e 2e 2e 20 20 20 20 20 20 20  .**   ...       
8700: 20 20 20 20 20 2e 2e 2e 0a 2a 2a 20 20 20 72 65       ....**   re
8710: 67 2b 4e 2b 4e 2b 31 20 20 20 20 20 20 4e 45 57  g+N+N+1      NEW
8720: 2e 2a 20 76 61 6c 75 65 20 6f 66 20 72 69 67 68  .* value of righ
8730: 74 2d 6d 6f 73 74 20 63 6f 6c 75 6d 6e 20 6f 66  t-most column of
8740: 20 70 54 61 62 0a 2a 2a 0a 2a 2a 20 46 6f 72 20   pTab.**.** For 
8750: 4f 4e 20 44 45 4c 45 54 45 20 74 72 69 67 67 65  ON DELETE trigge
8760: 72 73 2c 20 74 68 65 20 72 65 67 69 73 74 65 72  rs, the register
8770: 73 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65  s containing the
8780: 20 4e 45 57 2e 2a 20 76 61 6c 75 65 73 20 77 69   NEW.* values wi
8790: 6c 6c 0a 2a 2a 20 6e 65 76 65 72 20 62 65 20 61  ll.** never be a
87a0: 63 63 65 73 73 65 64 20 62 79 20 74 68 65 20 74  ccessed by the t
87b0: 72 69 67 67 65 72 20 70 72 6f 67 72 61 6d 2c 20  rigger program, 
87c0: 73 6f 20 74 68 65 79 20 61 72 65 20 6e 6f 74 20  so they are not 
87d0: 61 6c 6c 6f 63 61 74 65 64 20 6f 72 20 0a 2a 2a  allocated or .**
87e0: 20 70 6f 70 75 6c 61 74 65 64 20 62 79 20 74 68   populated by th
87f0: 65 20 63 61 6c 6c 65 72 20 28 74 68 65 72 65 20  e caller (there 
8800: 69 73 20 6e 6f 20 64 61 74 61 20 74 6f 20 70 6f  is no data to po
8810: 70 75 6c 61 74 65 20 74 68 65 6d 20 77 69 74 68  pulate them with
8820: 20 61 6e 79 77 61 79 29 2e 20 0a 2a 2a 20 53 69   anyway). .** Si
8830: 6d 69 6c 61 72 6c 79 2c 20 66 6f 72 20 4f 4e 20  milarly, for ON 
8840: 49 4e 53 45 52 54 20 74 72 69 67 67 65 72 73 20  INSERT triggers 
8850: 74 68 65 20 76 61 6c 75 65 73 20 73 74 6f 72 65  the values store
8860: 64 20 69 6e 20 74 68 65 20 4f 4c 44 2e 2a 20 72  d in the OLD.* r
8870: 65 67 69 73 74 65 72 73 0a 2a 2a 20 61 72 65 20  egisters.** are 
8880: 6e 65 76 65 72 20 61 63 63 65 73 73 65 64 2c 20  never accessed, 
8890: 61 6e 64 20 73 6f 20 61 72 65 20 6e 6f 74 20 61  and so are not a
88a0: 6c 6c 6f 63 61 74 65 64 20 62 79 20 74 68 65 20  llocated by the 
88b0: 63 61 6c 6c 65 72 2e 20 53 6f 2c 20 66 6f 72 20  caller. So, for 
88c0: 61 6e 0a 2a 2a 20 4f 4e 20 49 4e 53 45 52 54 20  an.** ON INSERT 
88d0: 74 72 69 67 67 65 72 2c 20 74 68 65 20 76 61 6c  trigger, the val
88e0: 75 65 20 70 61 73 73 65 64 20 74 6f 20 74 68 69  ue passed to thi
88f0: 73 20 66 75 6e 63 74 69 6f 6e 20 61 73 20 70 61  s function as pa
8900: 72 61 6d 65 74 65 72 20 72 65 67 0a 2a 2a 20 69  rameter reg.** i
8910: 73 20 6e 6f 74 20 61 20 72 65 61 64 61 62 6c 65  s not a readable
8920: 20 72 65 67 69 73 74 65 72 2c 20 61 6c 74 68 6f   register, altho
8930: 75 67 68 20 72 65 67 69 73 74 65 72 73 20 28 72  ugh registers (r
8940: 65 67 2b 4e 29 20 74 68 72 6f 75 67 68 20 0a 2a  eg+N) through .*
8950: 2a 20 28 72 65 67 2b 4e 2b 4e 2b 31 29 20 61 72  * (reg+N+N+1) ar
8960: 65 2e 0a 2a 2a 0a 2a 2a 20 50 61 72 61 6d 65 74  e..**.** Paramet
8970: 65 72 20 6f 72 63 6f 6e 66 20 69 73 20 74 68 65  er orconf is the
8980: 20 64 65 66 61 75 6c 74 20 63 6f 6e 66 6c 69 63   default conflic
8990: 74 20 72 65 73 6f 6c 75 74 69 6f 6e 20 61 6c 67  t resolution alg
89a0: 6f 72 69 74 68 6d 20 66 6f 72 20 74 68 65 0a 2a  orithm for the.*
89b0: 2a 20 74 72 69 67 67 65 72 20 70 72 6f 67 72 61  * trigger progra
89c0: 6d 20 74 6f 20 75 73 65 20 28 52 45 50 4c 41 43  m to use (REPLAC
89d0: 45 2c 20 49 47 4e 4f 52 45 20 65 74 63 2e 29 2e  E, IGNORE etc.).
89e0: 20 50 61 72 61 6d 65 74 65 72 20 69 67 6e 6f 72   Parameter ignor
89f0: 65 4a 75 6d 70 0a 2a 2a 20 69 73 20 74 68 65 20  eJump.** is the 
8a00: 69 6e 73 74 72 75 63 74 69 6f 6e 20 74 68 61 74  instruction that
8a10: 20 63 6f 6e 74 72 6f 6c 20 73 68 6f 75 6c 64 20   control should 
8a20: 6a 75 6d 70 20 74 6f 20 69 66 20 61 20 74 72 69  jump to if a tri
8a30: 67 67 65 72 20 70 72 6f 67 72 61 6d 0a 2a 2a 20  gger program.** 
8a40: 72 61 69 73 65 73 20 61 6e 20 49 47 4e 4f 52 45  raises an IGNORE
8a50: 20 65 78 63 65 70 74 69 6f 6e 2e 0a 2a 2f 0a 76   exception..*/.v
8a60: 6f 69 64 20 73 71 6c 69 74 65 33 43 6f 64 65 52  oid sqlite3CodeR
8a70: 6f 77 54 72 69 67 67 65 72 28 0a 20 20 50 61 72  owTrigger(.  Par
8a80: 73 65 20 2a 70 50 61 72 73 65 2c 20 20 20 20 20  se *pParse,     
8a90: 20 20 2f 2a 20 50 61 72 73 65 20 63 6f 6e 74 65    /* Parse conte
8aa0: 78 74 20 2a 2f 0a 20 20 54 72 69 67 67 65 72 20  xt */.  Trigger 
8ab0: 2a 70 54 72 69 67 67 65 72 2c 20 20 20 2f 2a 20  *pTrigger,   /* 
8ac0: 4c 69 73 74 20 6f 66 20 74 72 69 67 67 65 72 73  List of triggers
8ad0: 20 6f 6e 20 74 61 62 6c 65 20 70 54 61 62 20 2a   on table pTab *
8ae0: 2f 0a 20 20 69 6e 74 20 6f 70 2c 20 20 20 20 20  /.  int op,     
8af0: 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 6e 65 20           /* One 
8b00: 6f 66 20 54 4b 5f 55 50 44 41 54 45 2c 20 54 4b  of TK_UPDATE, TK
8b10: 5f 49 4e 53 45 52 54 2c 20 54 4b 5f 44 45 4c 45  _INSERT, TK_DELE
8b20: 54 45 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73 74  TE */.  ExprList
8b30: 20 2a 70 43 68 61 6e 67 65 73 2c 20 20 2f 2a 20   *pChanges,  /* 
8b40: 43 68 61 6e 67 65 73 20 6c 69 73 74 20 66 6f 72  Changes list for
8b50: 20 61 6e 79 20 55 50 44 41 54 45 20 4f 46 20 74   any UPDATE OF t
8b60: 72 69 67 67 65 72 73 20 2a 2f 0a 20 20 69 6e 74  riggers */.  int
8b70: 20 74 72 5f 74 6d 2c 20 20 20 20 20 20 20 20 20   tr_tm,         
8b80: 20 20 2f 2a 20 4f 6e 65 20 6f 66 20 54 52 49 47    /* One of TRIG
8b90: 47 45 52 5f 42 45 46 4f 52 45 2c 20 54 52 49 47  GER_BEFORE, TRIG
8ba0: 47 45 52 5f 41 46 54 45 52 20 2a 2f 0a 20 20 54  GER_AFTER */.  T
8bb0: 61 62 6c 65 20 2a 70 54 61 62 2c 20 20 20 20 20  able *pTab,     
8bc0: 20 20 20 20 2f 2a 20 54 68 65 20 74 61 62 6c 65      /* The table
8bd0: 20 74 6f 20 63 6f 64 65 20 74 72 69 67 67 65 72   to code trigger
8be0: 73 20 66 72 6f 6d 20 2a 2f 0a 20 20 69 6e 74 20  s from */.  int 
8bf0: 72 65 67 2c 20 20 20 20 20 20 20 20 20 20 20 20  reg,            
8c00: 20 2f 2a 20 54 68 65 20 66 69 72 73 74 20 69 6e   /* The first in
8c10: 20 61 6e 20 61 72 72 61 79 20 6f 66 20 72 65 67   an array of reg
8c20: 69 73 74 65 72 73 20 28 73 65 65 20 61 62 6f 76  isters (see abov
8c30: 65 29 20 2a 2f 0a 20 20 69 6e 74 20 6f 72 63 6f  e) */.  int orco
8c40: 6e 66 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20  nf,          /* 
8c50: 4f 4e 20 43 4f 4e 46 4c 49 43 54 20 70 6f 6c 69  ON CONFLICT poli
8c60: 63 79 20 2a 2f 0a 20 20 69 6e 74 20 69 67 6e 6f  cy */.  int igno
8c70: 72 65 4a 75 6d 70 20 20 20 20 20 20 20 2f 2a 20  reJump       /* 
8c80: 49 6e 73 74 72 75 63 74 69 6f 6e 20 74 6f 20 6a  Instruction to j
8c90: 75 6d 70 20 74 6f 20 66 6f 72 20 52 41 49 53 45  ump to for RAISE
8ca0: 28 49 47 4e 4f 52 45 29 20 2a 2f 0a 29 7b 0a 20  (IGNORE) */.){. 
8cb0: 20 54 72 69 67 67 65 72 20 2a 70 3b 20 20 20 20   Trigger *p;    
8cc0: 20 20 20 20 20 20 2f 2a 20 55 73 65 64 20 74 6f        /* Used to
8cd0: 20 69 74 65 72 61 74 65 20 74 68 72 6f 75 67 68   iterate through
8ce0: 20 70 54 72 69 67 67 65 72 20 6c 69 73 74 20 2a   pTrigger list *
8cf0: 2f 0a 0a 20 20 61 73 73 65 72 74 28 20 6f 70 3d  /..  assert( op=
8d00: 3d 54 4b 5f 55 50 44 41 54 45 20 7c 7c 20 6f 70  =TK_UPDATE || op
8d10: 3d 3d 54 4b 5f 49 4e 53 45 52 54 20 7c 7c 20 6f  ==TK_INSERT || o
8d20: 70 3d 3d 54 4b 5f 44 45 4c 45 54 45 20 29 3b 0a  p==TK_DELETE );.
8d30: 20 20 61 73 73 65 72 74 28 20 74 72 5f 74 6d 3d    assert( tr_tm=
8d40: 3d 54 52 49 47 47 45 52 5f 42 45 46 4f 52 45 20  =TRIGGER_BEFORE 
8d50: 7c 7c 20 74 72 5f 74 6d 3d 3d 54 52 49 47 47 45  || tr_tm==TRIGGE
8d60: 52 5f 41 46 54 45 52 20 29 3b 0a 20 20 61 73 73  R_AFTER );.  ass
8d70: 65 72 74 28 20 28 6f 70 3d 3d 54 4b 5f 55 50 44  ert( (op==TK_UPD
8d80: 41 54 45 29 3d 3d 28 70 43 68 61 6e 67 65 73 21  ATE)==(pChanges!
8d90: 3d 30 29 20 29 3b 0a 0a 20 20 66 6f 72 28 70 3d  =0) );..  for(p=
8da0: 70 54 72 69 67 67 65 72 3b 20 70 3b 20 70 3d 70  pTrigger; p; p=p
8db0: 2d 3e 70 4e 65 78 74 29 7b 0a 0a 20 20 20 20 2f  ->pNext){..    /
8dc0: 2a 20 53 61 6e 69 74 79 20 63 68 65 63 6b 69 6e  * Sanity checkin
8dd0: 67 3a 20 20 54 68 65 20 73 63 68 65 6d 61 20 66  g:  The schema f
8de0: 6f 72 20 74 68 65 20 74 72 69 67 67 65 72 20 61  or the trigger a
8df0: 6e 64 20 66 6f 72 20 74 68 65 20 74 61 62 6c 65  nd for the table
8e00: 20 61 72 65 0a 20 20 20 20 2a 2a 20 61 6c 77 61   are.    ** alwa
8e10: 79 73 20 64 65 66 69 6e 65 64 2e 20 20 54 68 65  ys defined.  The
8e20: 20 74 72 69 67 67 65 72 20 6d 75 73 74 20 62 65   trigger must be
8e30: 20 69 6e 20 74 68 65 20 73 61 6d 65 20 73 63 68   in the same sch
8e40: 65 6d 61 20 61 73 20 74 68 65 20 74 61 62 6c 65  ema as the table
8e50: 0a 20 20 20 20 2a 2a 20 6f 72 20 65 6c 73 65 20  .    ** or else 
8e60: 69 74 20 6d 75 73 74 20 62 65 20 61 20 54 45 4d  it must be a TEM
8e70: 50 20 74 72 69 67 67 65 72 2e 20 2a 2f 0a 20 20  P trigger. */.  
8e80: 20 20 61 73 73 65 72 74 28 20 70 2d 3e 70 53 63    assert( p->pSc
8e90: 68 65 6d 61 21 3d 30 20 29 3b 0a 20 20 20 20 61  hema!=0 );.    a
8ea0: 73 73 65 72 74 28 20 70 2d 3e 70 54 61 62 53 63  ssert( p->pTabSc
8eb0: 68 65 6d 61 21 3d 30 20 29 3b 0a 20 20 20 20 61  hema!=0 );.    a
8ec0: 73 73 65 72 74 28 20 70 2d 3e 70 53 63 68 65 6d  ssert( p->pSchem
8ed0: 61 3d 3d 70 2d 3e 70 54 61 62 53 63 68 65 6d 61  a==p->pTabSchema
8ee0: 20 0a 20 20 20 20 20 20 20 20 20 7c 7c 20 70 2d   .         || p-
8ef0: 3e 70 53 63 68 65 6d 61 3d 3d 70 50 61 72 73 65  >pSchema==pParse
8f00: 2d 3e 64 62 2d 3e 61 44 62 5b 31 5d 2e 70 53 63  ->db->aDb[1].pSc
8f10: 68 65 6d 61 20 29 3b 0a 0a 20 20 20 20 2f 2a 20  hema );..    /* 
8f20: 44 65 74 65 72 6d 69 6e 65 20 77 68 65 74 68 65  Determine whethe
8f30: 72 20 77 65 20 73 68 6f 75 6c 64 20 63 6f 64 65  r we should code
8f40: 20 74 68 69 73 20 74 72 69 67 67 65 72 20 2a 2f   this trigger */
8f50: 0a 20 20 20 20 69 66 28 20 70 2d 3e 6f 70 3d 3d  .    if( p->op==
8f60: 6f 70 20 0a 20 20 20 20 20 26 26 20 70 2d 3e 74  op .     && p->t
8f70: 72 5f 74 6d 3d 3d 74 72 5f 74 6d 20 0a 20 20 20  r_tm==tr_tm .   
8f80: 20 20 26 26 20 63 68 65 63 6b 43 6f 6c 75 6d 6e    && checkColumn
8f90: 4f 76 65 72 6c 61 70 28 70 2d 3e 70 43 6f 6c 75  Overlap(p->pColu
8fa0: 6d 6e 73 2c 20 70 43 68 61 6e 67 65 73 29 0a 20  mns, pChanges). 
8fb0: 20 20 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69     ){.      sqli
8fc0: 74 65 33 43 6f 64 65 52 6f 77 54 72 69 67 67 65  te3CodeRowTrigge
8fd0: 72 44 69 72 65 63 74 28 70 50 61 72 73 65 2c 20  rDirect(pParse, 
8fe0: 70 2c 20 70 54 61 62 2c 20 72 65 67 2c 20 6f 72  p, pTab, reg, or
8ff0: 63 6f 6e 66 2c 20 69 67 6e 6f 72 65 4a 75 6d 70  conf, ignoreJump
9000: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a  );.    }.  }.}..
9010: 2f 2a 0a 2a 2a 20 54 72 69 67 67 65 72 73 20 6d  /*.** Triggers m
9020: 61 79 20 61 63 63 65 73 73 20 76 61 6c 75 65 73  ay access values
9030: 20 73 74 6f 72 65 64 20 69 6e 20 74 68 65 20 6f   stored in the o
9040: 6c 64 2e 2a 20 6f 72 20 6e 65 77 2e 2a 20 70 73  ld.* or new.* ps
9050: 65 75 64 6f 2d 74 61 62 6c 65 2e 20 0a 2a 2a 20  eudo-table. .** 
9060: 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 72 65  This function re
9070: 74 75 72 6e 73 20 61 20 33 32 2d 62 69 74 20 62  turns a 32-bit b
9080: 69 74 6d 61 73 6b 20 69 6e 64 69 63 61 74 69 6e  itmask indicatin
9090: 67 20 77 68 69 63 68 20 63 6f 6c 75 6d 6e 73 20  g which columns 
90a0: 6f 66 20 74 68 65 20 0a 2a 2a 20 6f 6c 64 2e 2a  of the .** old.*
90b0: 20 6f 72 20 6e 65 77 2e 2a 20 74 61 62 6c 65 73   or new.* tables
90c0: 20 61 63 74 75 61 6c 6c 79 20 61 72 65 20 75 73   actually are us
90d0: 65 64 20 62 79 20 74 72 69 67 67 65 72 73 2e 20  ed by triggers. 
90e0: 54 68 69 73 20 69 6e 66 6f 72 6d 61 74 69 6f 6e  This information
90f0: 20 0a 2a 2a 20 6d 61 79 20 62 65 20 75 73 65 64   .** may be used
9100: 20 62 79 20 74 68 65 20 63 61 6c 6c 65 72 2c 20   by the caller, 
9110: 66 6f 72 20 65 78 61 6d 70 6c 65 2c 20 74 6f 20  for example, to 
9120: 61 76 6f 69 64 20 68 61 76 69 6e 67 20 74 6f 20  avoid having to 
9130: 6c 6f 61 64 20 74 68 65 20 65 6e 74 69 72 65 0a  load the entire.
9140: 2a 2a 20 6f 6c 64 2e 2a 20 72 65 63 6f 72 64 20  ** old.* record 
9150: 69 6e 74 6f 20 6d 65 6d 6f 72 79 20 77 68 65 6e  into memory when
9160: 20 65 78 65 63 75 74 69 6e 67 20 61 6e 20 55 50   executing an UP
9170: 44 41 54 45 20 6f 72 20 44 45 4c 45 54 45 20 63  DATE or DELETE c
9180: 6f 6d 6d 61 6e 64 2e 0a 2a 2a 0a 2a 2a 20 42 69  ommand..**.** Bi
9190: 74 20 30 20 6f 66 20 74 68 65 20 72 65 74 75 72  t 0 of the retur
91a0: 6e 65 64 20 6d 61 73 6b 20 69 73 20 73 65 74 20  ned mask is set 
91b0: 69 66 20 74 68 65 20 6c 65 66 74 2d 6d 6f 73 74  if the left-most
91c0: 20 63 6f 6c 75 6d 6e 20 6f 66 20 74 68 65 0a 2a   column of the.*
91d0: 2a 20 74 61 62 6c 65 20 6d 61 79 20 62 65 20 61  * table may be a
91e0: 63 63 65 73 73 65 64 20 75 73 69 6e 67 20 61 6e  ccessed using an
91f0: 20 5b 6f 6c 64 7c 6e 65 77 5d 2e 3c 63 6f 6c 3e   [old|new].<col>
9200: 20 72 65 66 65 72 65 6e 63 65 2e 20 42 69 74 20   reference. Bit 
9210: 31 20 69 73 20 73 65 74 20 69 66 0a 2a 2a 20 74  1 is set if.** t
9220: 68 65 20 73 65 63 6f 6e 64 20 6c 65 66 74 6d 6f  he second leftmo
9230: 73 74 20 63 6f 6c 75 6d 6e 20 76 61 6c 75 65 20  st column value 
9240: 69 73 20 72 65 71 75 69 72 65 64 2c 20 61 6e 64  is required, and
9250: 20 73 6f 20 6f 6e 2e 20 49 66 20 74 68 65 72 65   so on. If there
9260: 0a 2a 2a 20 61 72 65 20 6d 6f 72 65 20 74 68 61  .** are more tha
9270: 6e 20 33 32 20 63 6f 6c 75 6d 6e 73 20 69 6e 20  n 32 columns in 
9280: 74 68 65 20 74 61 62 6c 65 2c 20 61 6e 64 20 61  the table, and a
9290: 74 20 6c 65 61 73 74 20 6f 6e 65 20 6f 66 20 74  t least one of t
92a0: 68 65 20 63 6f 6c 75 6d 6e 73 0a 2a 2a 20 77 69  he columns.** wi
92b0: 74 68 20 61 6e 20 69 6e 64 65 78 20 67 72 65 61  th an index grea
92c0: 74 65 72 20 74 68 61 6e 20 33 32 20 6d 61 79 20  ter than 32 may 
92d0: 62 65 20 61 63 63 65 73 73 65 64 2c 20 30 78 66  be accessed, 0xf
92e0: 66 66 66 66 66 66 66 20 69 73 20 72 65 74 75 72  fffffff is retur
92f0: 6e 65 64 2e 0a 2a 2a 0a 2a 2a 20 49 74 20 69 73  ned..**.** It is
9300: 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65 20 74 6f   not possible to
9310: 20 64 65 74 65 72 6d 69 6e 65 20 69 66 20 74 68   determine if th
9320: 65 20 6f 6c 64 2e 72 6f 77 69 64 20 6f 72 20 6e  e old.rowid or n
9330: 65 77 2e 72 6f 77 69 64 20 63 6f 6c 75 6d 6e 20  ew.rowid column 
9340: 69 73 20 0a 2a 2a 20 61 63 63 65 73 73 65 64 20  is .** accessed 
9350: 62 79 20 74 72 69 67 67 65 72 73 2e 20 54 68 65  by triggers. The
9360: 20 63 61 6c 6c 65 72 20 6d 75 73 74 20 61 6c 77   caller must alw
9370: 61 79 73 20 61 73 73 75 6d 65 20 74 68 61 74 20  ays assume that 
9380: 69 74 20 69 73 2e 0a 2a 2a 0a 2a 2a 20 50 61 72  it is..**.** Par
9390: 61 6d 65 74 65 72 20 69 73 4e 65 77 20 6d 75 73  ameter isNew mus
93a0: 74 20 62 65 20 65 69 74 68 65 72 20 31 20 6f 72  t be either 1 or
93b0: 20 30 2e 20 49 66 20 69 74 20 69 73 20 30 2c 20   0. If it is 0, 
93c0: 74 68 65 6e 20 74 68 65 20 6d 61 73 6b 20 72 65  then the mask re
93d0: 74 75 72 6e 65 64 0a 2a 2a 20 61 70 70 6c 69 65  turned.** applie
93e0: 73 20 74 6f 20 74 68 65 20 6f 6c 64 2e 2a 20 74  s to the old.* t
93f0: 61 62 6c 65 2e 20 49 66 20 31 2c 20 74 68 65 20  able. If 1, the 
9400: 6e 65 77 2e 2a 20 74 61 62 6c 65 2e 0a 2a 2a 0a  new.* table..**.
9410: 2a 2a 20 50 61 72 61 6d 65 74 65 72 20 74 72 5f  ** Parameter tr_
9420: 74 6d 20 6d 75 73 74 20 62 65 20 61 20 6d 61 73  tm must be a mas
9430: 6b 20 77 69 74 68 20 6f 6e 65 20 6f 72 20 62 6f  k with one or bo
9440: 74 68 20 6f 66 20 74 68 65 20 54 52 49 47 47 45  th of the TRIGGE
9450: 52 5f 42 45 46 4f 52 45 0a 2a 2a 20 61 6e 64 20  R_BEFORE.** and 
9460: 54 52 49 47 47 45 52 5f 41 46 54 45 52 20 62 69  TRIGGER_AFTER bi
9470: 74 73 20 73 65 74 2e 20 56 61 6c 75 65 73 20 61  ts set. Values a
9480: 63 63 65 73 73 65 64 20 62 79 20 42 45 46 4f 52  ccessed by BEFOR
9490: 45 20 74 72 69 67 67 65 72 73 20 61 72 65 20 6f  E triggers are o
94a0: 6e 6c 79 0a 2a 2a 20 69 6e 63 6c 75 64 65 64 20  nly.** included 
94b0: 69 6e 20 74 68 65 20 72 65 74 75 72 6e 65 64 20  in the returned 
94c0: 6d 61 73 6b 20 69 66 20 74 68 65 20 54 52 49 47  mask if the TRIG
94d0: 47 45 52 5f 42 45 46 4f 52 45 20 62 69 74 20 69  GER_BEFORE bit i
94e0: 73 20 73 65 74 20 69 6e 20 74 68 65 0a 2a 2a 20  s set in the.** 
94f0: 74 72 5f 74 6d 20 70 61 72 61 6d 65 74 65 72 2e  tr_tm parameter.
9500: 20 53 69 6d 69 6c 61 72 6c 79 2c 20 76 61 6c 75   Similarly, valu
9510: 65 73 20 61 63 63 65 73 73 65 64 20 62 79 20 41  es accessed by A
9520: 46 54 45 52 20 74 72 69 67 67 65 72 73 20 61 72  FTER triggers ar
9530: 65 20 6f 6e 6c 79 0a 2a 2a 20 69 6e 63 6c 75 64  e only.** includ
9540: 65 64 20 69 6e 20 74 68 65 20 72 65 74 75 72 6e  ed in the return
9550: 65 64 20 6d 61 73 6b 20 69 66 20 74 68 65 20 54  ed mask if the T
9560: 52 49 47 47 45 52 5f 41 46 54 45 52 20 62 69 74  RIGGER_AFTER bit
9570: 20 69 73 20 73 65 74 20 69 6e 20 74 72 5f 74 6d   is set in tr_tm
9580: 2e 0a 2a 2f 0a 75 33 32 20 73 71 6c 69 74 65 33  ..*/.u32 sqlite3
9590: 54 72 69 67 67 65 72 43 6f 6c 6d 61 73 6b 28 0a  TriggerColmask(.
95a0: 20 20 50 61 72 73 65 20 2a 70 50 61 72 73 65 2c    Parse *pParse,
95b0: 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73 65 20         /* Parse 
95c0: 63 6f 6e 74 65 78 74 20 2a 2f 0a 20 20 54 72 69  context */.  Tri
95d0: 67 67 65 72 20 2a 70 54 72 69 67 67 65 72 2c 20  gger *pTrigger, 
95e0: 20 20 2f 2a 20 4c 69 73 74 20 6f 66 20 74 72 69    /* List of tri
95f0: 67 67 65 72 73 20 6f 6e 20 74 61 62 6c 65 20 70  ggers on table p
9600: 54 61 62 20 2a 2f 0a 20 20 45 78 70 72 4c 69 73  Tab */.  ExprLis
9610: 74 20 2a 70 43 68 61 6e 67 65 73 2c 20 20 2f 2a  t *pChanges,  /*
9620: 20 43 68 61 6e 67 65 73 20 6c 69 73 74 20 66 6f   Changes list fo
9630: 72 20 61 6e 79 20 55 50 44 41 54 45 20 4f 46 20  r any UPDATE OF 
9640: 74 72 69 67 67 65 72 73 20 2a 2f 0a 20 20 69 6e  triggers */.  in
9650: 74 20 69 73 4e 65 77 2c 20 20 20 20 20 20 20 20  t isNew,        
9660: 20 20 20 2f 2a 20 31 20 66 6f 72 20 6e 65 77 2e     /* 1 for new.
9670: 2a 20 72 65 66 20 6d 61 73 6b 2c 20 30 20 66 6f  * ref mask, 0 fo
9680: 72 20 6f 6c 64 2e 2a 20 72 65 66 20 6d 61 73 6b  r old.* ref mask
9690: 20 2a 2f 0a 20 20 69 6e 74 20 74 72 5f 74 6d 2c   */.  int tr_tm,
96a0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4d 61             /* Ma
96b0: 73 6b 20 6f 66 20 54 52 49 47 47 45 52 5f 42 45  sk of TRIGGER_BE
96c0: 46 4f 52 45 7c 54 52 49 47 47 45 52 5f 41 46 54  FORE|TRIGGER_AFT
96d0: 45 52 20 2a 2f 0a 20 20 54 61 62 6c 65 20 2a 70  ER */.  Table *p
96e0: 54 61 62 2c 20 20 20 20 20 20 20 20 20 2f 2a 20  Tab,         /* 
96f0: 54 68 65 20 74 61 62 6c 65 20 74 6f 20 63 6f 64  The table to cod
9700: 65 20 74 72 69 67 67 65 72 73 20 66 72 6f 6d 20  e triggers from 
9710: 2a 2f 0a 20 20 69 6e 74 20 6f 72 63 6f 6e 66 20  */.  int orconf 
9720: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 65 66            /* Def
9730: 61 75 6c 74 20 4f 4e 20 43 4f 4e 46 4c 49 43 54  ault ON CONFLICT
9740: 20 70 6f 6c 69 63 79 20 66 6f 72 20 74 72 69 67   policy for trig
9750: 67 65 72 20 73 74 65 70 73 20 2a 2f 0a 29 7b 0a  ger steps */.){.
9760: 20 20 63 6f 6e 73 74 20 69 6e 74 20 6f 70 20 3d    const int op =
9770: 20 70 43 68 61 6e 67 65 73 20 3f 20 54 4b 5f 55   pChanges ? TK_U
9780: 50 44 41 54 45 20 3a 20 54 4b 5f 44 45 4c 45 54  PDATE : TK_DELET
9790: 45 3b 0a 20 20 75 33 32 20 6d 61 73 6b 20 3d 20  E;.  u32 mask = 
97a0: 30 3b 0a 20 20 54 72 69 67 67 65 72 20 2a 70 3b  0;.  Trigger *p;
97b0: 0a 0a 20 20 61 73 73 65 72 74 28 20 69 73 4e 65  ..  assert( isNe
97c0: 77 3d 3d 31 20 7c 7c 20 69 73 4e 65 77 3d 3d 30  w==1 || isNew==0
97d0: 20 29 3b 0a 20 20 66 6f 72 28 70 3d 70 54 72 69   );.  for(p=pTri
97e0: 67 67 65 72 3b 20 70 3b 20 70 3d 70 2d 3e 70 4e  gger; p; p=p->pN
97f0: 65 78 74 29 7b 0a 20 20 20 20 69 66 28 20 70 2d  ext){.    if( p-
9800: 3e 6f 70 3d 3d 6f 70 20 26 26 20 28 74 72 5f 74  >op==op && (tr_t
9810: 6d 26 70 2d 3e 74 72 5f 74 6d 29 0a 20 20 20 20  m&p->tr_tm).    
9820: 20 26 26 20 63 68 65 63 6b 43 6f 6c 75 6d 6e 4f   && checkColumnO
9830: 76 65 72 6c 61 70 28 70 2d 3e 70 43 6f 6c 75 6d  verlap(p->pColum
9840: 6e 73 2c 70 43 68 61 6e 67 65 73 29 0a 20 20 20  ns,pChanges).   
9850: 20 29 7b 0a 20 20 20 20 20 20 54 72 69 67 67 65   ){.      Trigge
9860: 72 50 72 67 20 2a 70 50 72 67 3b 0a 20 20 20 20  rPrg *pPrg;.    
9870: 20 20 70 50 72 67 20 3d 20 67 65 74 52 6f 77 54    pPrg = getRowT
9880: 72 69 67 67 65 72 28 70 50 61 72 73 65 2c 20 70  rigger(pParse, p
9890: 2c 20 70 54 61 62 2c 20 6f 72 63 6f 6e 66 29 3b  , pTab, orconf);
98a0: 0a 20 20 20 20 20 20 69 66 28 20 70 50 72 67 20  .      if( pPrg 
98b0: 29 7b 0a 20 20 20 20 20 20 20 20 6d 61 73 6b 20  ){.        mask 
98c0: 7c 3d 20 70 50 72 67 2d 3e 61 43 6f 6c 6d 61 73  |= pPrg->aColmas
98d0: 6b 5b 69 73 4e 65 77 5d 3b 0a 20 20 20 20 20 20  k[isNew];.      
98e0: 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 72  }.    }.  }..  r
98f0: 65 74 75 72 6e 20 6d 61 73 6b 3b 0a 7d 0a 0a 23  eturn mask;.}..#
9900: 65 6e 64 69 66 20 2f 2a 20 21 64 65 66 69 6e 65  endif /* !define
9910: 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 54 52  d(SQLITE_OMIT_TR
9920: 49 47 47 45 52 29 20 2a 2f 0a                    IGGER) */.