System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact e8e3bee9704841a562cadb8eb8957ac881a6ba3b:


0000: 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  /***************
0010: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0020: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 20 2a 20 41 44 4f  *********. * ADO
0040: 2e 4e 45 54 20 32 2e 30 20 44 61 74 61 20 50 72  .NET 2.0 Data Pr
0050: 6f 76 69 64 65 72 20 66 6f 72 20 53 51 4c 69 74  ovider for SQLit
0060: 65 20 56 65 72 73 69 6f 6e 20 33 2e 58 0a 20 2a  e Version 3.X. *
0070: 20 57 72 69 74 74 65 6e 20 62 79 20 52 6f 62 65   Written by Robe
0080: 72 74 20 53 69 6d 70 73 6f 6e 20 28 72 6f 62 65  rt Simpson (robe
0090: 72 74 40 62 6c 61 63 6b 63 61 73 74 6c 65 73 6f  rt@blackcastleso
00a0: 66 74 2e 63 6f 6d 29 0a 20 2a 20 0a 20 2a 20 52  ft.com). * . * R
00b0: 65 6c 65 61 73 65 64 20 74 6f 20 74 68 65 20 70  eleased to the p
00c0: 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c 20 75 73  ublic domain, us
00d0: 65 20 61 74 20 79 6f 75 72 20 6f 77 6e 20 72 69  e at your own ri
00e0: 73 6b 21 0a 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  sk!. ***********
00f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0100: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0110: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 0a  *************/..
0120: 6e 61 6d 65 73 70 61 63 65 20 53 51 4c 69 74 65  namespace SQLite
0130: 2e 44 65 73 69 67 6e 65 72 2e 44 65 73 69 67 6e  .Designer.Design
0140: 0a 7b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65  .{.  using Syste
0150: 6d 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65  m;.  using Syste
0160: 6d 2e 43 6f 6c 6c 65 63 74 69 6f 6e 73 2e 47 65  m.Collections.Ge
0170: 6e 65 72 69 63 3b 0a 20 20 75 73 69 6e 67 20 53  neric;.  using S
0180: 79 73 74 65 6d 2e 54 65 78 74 3b 0a 20 20 75 73  ystem.Text;.  us
0190: 69 6e 67 20 53 79 73 74 65 6d 2e 43 6f 6d 70 6f  ing System.Compo
01a0: 6e 65 6e 74 4d 6f 64 65 6c 3b 0a 20 20 75 73 69  nentModel;.  usi
01b0: 6e 67 20 53 79 73 74 65 6d 2e 44 61 74 61 3b 0a  ng System.Data;.
01c0: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44    using System.D
01d0: 61 74 61 2e 43 6f 6d 6d 6f 6e 3b 0a 0a 20 20 69  ata.Common;..  i
01e0: 6e 74 65 72 6e 61 6c 20 63 6c 61 73 73 20 50 72  nternal class Pr
01f0: 69 6d 61 72 79 4b 65 79 20 3a 20 49 6e 64 65 78  imaryKey : Index
0200: 2c 20 49 43 6c 6f 6e 65 61 62 6c 65 0a 20 20 7b  , ICloneable.  {
0210: 0a 20 20 20 20 70 72 69 76 61 74 65 20 62 6f 6f  .    private boo
0220: 6c 20 5f 61 75 74 6f 69 6e 63 72 65 6d 65 6e 74  l _autoincrement
0230: 3b 0a 0a 20 20 20 20 69 6e 74 65 72 6e 61 6c 20  ;..    internal 
0240: 50 72 69 6d 61 72 79 4b 65 79 28 44 62 43 6f 6e  PrimaryKey(DbCon
0250: 6e 65 63 74 69 6f 6e 20 63 6e 6e 2c 20 54 61 62  nection cnn, Tab
0260: 6c 65 20 74 61 62 6c 65 2c 20 44 61 74 61 52 6f  le table, DataRo
0270: 77 20 72 6f 77 29 0a 20 20 20 20 20 20 3a 20 62  w row).      : b
0280: 61 73 65 28 63 6e 6e 2c 20 74 61 62 6c 65 2c 20  ase(cnn, table, 
0290: 72 6f 77 29 0a 20 20 20 20 7b 0a 20 20 20 20 20  row).    {.     
02a0: 20 69 66 20 28 53 74 72 69 6e 67 2e 49 73 4e 75   if (String.IsNu
02b0: 6c 6c 4f 72 45 6d 70 74 79 28 5f 6e 61 6d 65 29  llOrEmpty(_name)
02c0: 20 3d 3d 20 66 61 6c 73 65 20 26 26 20 5f 6e 61   == false && _na
02d0: 6d 65 2e 53 74 61 72 74 73 57 69 74 68 28 22 73  me.StartsWith("s
02e0: 71 6c 69 74 65 5f 22 2c 20 53 74 72 69 6e 67 43  qlite_", StringC
02f0: 6f 6d 70 61 72 69 73 6f 6e 2e 4f 72 64 69 6e 61  omparison.Ordina
0300: 6c 49 67 6e 6f 72 65 43 61 73 65 29 29 0a 20 20  lIgnoreCase)).  
0310: 20 20 20 20 20 20 5f 6e 61 6d 65 20 3d 20 6e 75        _name = nu
0320: 6c 6c 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70  ll;.    }..    p
0330: 72 6f 74 65 63 74 65 64 20 50 72 69 6d 61 72 79  rotected Primary
0340: 4b 65 79 28 50 72 69 6d 61 72 79 4b 65 79 20 73  Key(PrimaryKey s
0350: 6f 75 72 63 65 29 0a 20 20 20 20 20 20 3a 20 62  ource).      : b
0360: 61 73 65 28 73 6f 75 72 63 65 29 0a 20 20 20 20  ase(source).    
0370: 7b 0a 20 20 20 20 20 20 5f 61 75 74 6f 69 6e 63  {.      _autoinc
0380: 72 65 6d 65 6e 74 20 3d 20 73 6f 75 72 63 65 2e  rement = source.
0390: 5f 61 75 74 6f 69 6e 63 72 65 6d 65 6e 74 3b 0a  _autoincrement;.
03a0: 20 20 20 20 7d 0a 0a 20 20 20 20 70 75 62 6c 69      }..    publi
03b0: 63 20 6f 76 65 72 72 69 64 65 20 49 6e 64 65 78  c override Index
03c0: 54 79 70 65 45 6e 75 6d 20 49 6e 64 65 78 54 79  TypeEnum IndexTy
03d0: 70 65 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 67  pe.    {.      g
03e0: 65 74 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  et.      {.     
03f0: 20 20 20 72 65 74 75 72 6e 20 49 6e 64 65 78 54     return IndexT
0400: 79 70 65 45 6e 75 6d 2e 50 72 69 6d 61 72 79 4b  ypeEnum.PrimaryK
0410: 65 79 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ey;.      }.    
0420: 7d 0a 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  }..    protected
0430: 20 6f 76 65 72 72 69 64 65 20 73 74 72 69 6e 67   override string
0440: 20 4e 61 6d 65 50 72 65 66 69 78 0a 20 20 20 20   NamePrefix.    
0450: 7b 0a 20 20 20 20 20 20 67 65 74 0a 20 20 20 20  {.      get.    
0460: 20 20 7b 0a 20 20 20 20 20 20 20 20 72 65 74 75    {.        retu
0470: 72 6e 20 22 50 4b 22 3b 0a 20 20 20 20 20 20 7d  rn "PK";.      }
0480: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70 72 6f 74  .    }..    prot
0490: 65 63 74 65 64 20 6f 76 65 72 72 69 64 65 20 73  ected override s
04a0: 74 72 69 6e 67 20 4e 65 77 4e 61 6d 65 0a 20 20  tring NewName.  
04b0: 20 20 7b 0a 20 20 20 20 20 20 67 65 74 0a 20 20    {.      get.  
04c0: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 72 65      {.        re
04d0: 74 75 72 6e 20 54 61 62 6c 65 2e 4e 61 6d 65 3b  turn Table.Name;
04e0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a  .      }.    }..
04f0: 20 20 20 20 5b 42 72 6f 77 73 61 62 6c 65 28 66      [Browsable(f
0500: 61 6c 73 65 29 5d 0a 20 20 20 20 70 75 62 6c 69  alse)].    publi
0510: 63 20 6f 76 65 72 72 69 64 65 20 62 6f 6f 6c 20  c override bool 
0520: 55 6e 69 71 75 65 0a 20 20 20 20 7b 0a 20 20 20  Unique.    {.   
0530: 20 20 20 67 65 74 0a 20 20 20 20 20 20 7b 0a 20     get.      {. 
0540: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 74 72         return tr
0550: 75 65 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ue;.      }.    
0560: 20 20 73 65 74 0a 20 20 20 20 20 20 7b 0a 20 20    set.      {.  
0570: 20 20 20 20 20 20 62 61 73 65 2e 55 6e 69 71 75        base.Uniqu
0580: 65 20 3d 20 74 72 75 65 3b 0a 20 20 20 20 20 20  e = true;.      
0590: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 5b 44 65  }.    }..    [De
05a0: 66 61 75 6c 74 56 61 6c 75 65 28 43 6f 6e 66 6c  faultValue(Confl
05b0: 69 63 74 45 6e 75 6d 2e 41 62 6f 72 74 29 5d 0a  ictEnum.Abort)].
05c0: 20 20 20 20 5b 44 69 73 70 6c 61 79 4e 61 6d 65      [DisplayName
05d0: 28 22 4f 6e 20 43 6f 6e 66 6c 69 63 74 22 29 5d  ("On Conflict")]
05e0: 0a 20 20 20 20 5b 43 61 74 65 67 6f 72 79 28 22  .    [Category("
05f0: 43 6f 6e 73 74 72 61 69 6e 74 73 22 29 5d 0a 20  Constraints")]. 
0600: 20 20 20 5b 44 65 73 63 72 69 70 74 69 6f 6e 28     [Description(
0610: 22 53 70 65 63 69 66 69 65 73 20 77 68 61 74 20  "Specifies what 
0620: 61 63 74 69 6f 6e 20 74 6f 20 74 61 6b 65 20 77  action to take w
0630: 68 65 6e 20 74 68 65 20 70 72 69 6d 61 72 79 20  hen the primary 
0640: 6b 65 79 20 63 6f 6e 73 74 72 61 69 6e 74 20 69  key constraint i
0650: 73 20 76 69 6f 6c 61 74 65 64 2e 22 29 5d 0a 20  s violated.")]. 
0660: 20 20 20 70 75 62 6c 69 63 20 43 6f 6e 66 6c 69     public Confli
0670: 63 74 45 6e 75 6d 20 43 6f 6e 66 6c 69 63 74 0a  ctEnum Conflict.
0680: 20 20 20 20 7b 0a 20 20 20 20 20 20 67 65 74 20      {.      get 
0690: 7b 20 72 65 74 75 72 6e 20 5f 63 6f 6e 66 6c 69  { return _confli
06a0: 63 74 3b 20 7d 0a 20 20 20 20 20 20 73 65 74 0a  ct; }.      set.
06b0: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
06c0: 69 66 20 28 76 61 6c 75 65 20 21 3d 20 5f 63 6f  if (value != _co
06d0: 6e 66 6c 69 63 74 29 0a 20 20 20 20 20 20 20 20  nflict).        
06e0: 7b 0a 20 20 20 20 20 20 20 20 20 20 5f 63 6f 6e  {.          _con
06f0: 66 6c 69 63 74 20 3d 20 76 61 6c 75 65 3b 0a 20  flict = value;. 
0700: 20 20 20 20 20 20 20 20 20 4d 61 6b 65 44 69 72           MakeDir
0710: 74 79 28 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  ty();.        }.
0720: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20        }.    }.. 
0730: 20 20 20 5b 44 65 66 61 75 6c 74 56 61 6c 75 65     [DefaultValue
0740: 28 66 61 6c 73 65 29 5d 0a 20 20 20 20 5b 43 61  (false)].    [Ca
0750: 74 65 67 6f 72 79 28 22 43 6f 6e 73 74 72 61 69  tegory("Constrai
0760: 6e 74 73 22 29 5d 0a 20 20 20 20 5b 44 65 73 63  nts")].    [Desc
0770: 72 69 70 74 69 6f 6e 28 22 43 61 6e 20 6f 6e 6c  ription("Can onl
0780: 79 20 62 65 20 65 6e 61 62 6c 65 64 20 66 6f 72  y be enabled for
0790: 20 61 20 73 69 6e 67 6c 65 20 63 6f 6c 75 6d 6e   a single column
07a0: 20 70 72 69 6d 61 72 79 20 6b 65 79 20 6f 66 20   primary key of 
07b0: 74 79 70 65 20 49 4e 54 45 47 45 52 2e 20 20 57  type INTEGER.  W
07c0: 68 65 6e 20 73 65 74 2c 20 74 68 65 20 70 72 69  hen set, the pri
07d0: 6d 61 72 79 20 6b 65 79 20 69 73 20 67 75 61 72  mary key is guar
07e0: 61 6e 74 65 65 64 20 74 6f 20 69 6e 63 72 65 6d  anteed to increm
07f0: 65 6e 74 20 69 6e 20 73 65 71 75 65 6e 63 65 2c  ent in sequence,
0800: 20 61 6e 64 20 6e 6f 20 70 72 65 76 69 6f 75 73   and no previous
0810: 6c 79 20 64 65 6c 65 74 65 64 20 6f 72 20 75 6e  ly deleted or un
0820: 63 6f 6d 6d 69 74 74 65 64 20 76 61 6c 75 65 73  committed values
0830: 20 77 69 6c 6c 20 65 76 65 72 20 62 65 20 75 73   will ever be us
0840: 65 64 2e 22 29 5d 0a 20 20 20 20 70 75 62 6c 69  ed.")].    publi
0850: 63 20 62 6f 6f 6c 20 41 75 74 6f 49 6e 63 72 65  c bool AutoIncre
0860: 6d 65 6e 74 0a 20 20 20 20 7b 0a 20 20 20 20 20  ment.    {.     
0870: 20 67 65 74 0a 20 20 20 20 20 20 7b 0a 20 20 20   get.      {.   
0880: 20 20 20 20 20 69 66 20 28 43 6f 6c 75 6d 6e 73       if (Columns
0890: 2e 43 6f 75 6e 74 20 3e 20 31 29 20 72 65 74 75  .Count > 1) retu
08a0: 72 6e 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20  rn false;.      
08b0: 20 20 69 66 20 28 43 6f 6c 75 6d 6e 73 2e 43 6f    if (Columns.Co
08c0: 75 6e 74 20 3d 3d 20 31 20 26 26 20 43 6f 6c 75  unt == 1 && Colu
08d0: 6d 6e 73 5b 30 5d 2e 53 6f 72 74 4d 6f 64 65 20  mns[0].SortMode 
08e0: 21 3d 20 43 6f 6c 75 6d 6e 53 6f 72 74 4d 6f 64  != ColumnSortMod
08f0: 65 2e 41 73 63 65 6e 64 69 6e 67 29 20 72 65 74  e.Ascending) ret
0900: 75 72 6e 20 66 61 6c 73 65 3b 0a 20 20 20 20 20  urn false;.     
0910: 20 20 20 72 65 74 75 72 6e 20 5f 61 75 74 6f 69     return _autoi
0920: 6e 63 72 65 6d 65 6e 74 3b 0a 20 20 20 20 20 20  ncrement;.      
0930: 7d 0a 20 20 20 20 20 20 73 65 74 0a 20 20 20 20  }.      set.    
0940: 20 20 7b 0a 20 20 20 20 20 20 20 20 69 66 20 28    {.        if (
0950: 76 61 6c 75 65 20 21 3d 20 5f 61 75 74 6f 69 6e  value != _autoin
0960: 63 72 65 6d 65 6e 74 29 0a 20 20 20 20 20 20 20  crement).       
0970: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 5f 61 75   {.          _au
0980: 74 6f 69 6e 63 72 65 6d 65 6e 74 20 3d 20 76 61  toincrement = va
0990: 6c 75 65 3b 0a 20 20 20 20 20 20 20 20 20 20 4d  lue;.          M
09a0: 61 6b 65 44 69 72 74 79 28 29 3b 0a 20 20 20 20  akeDirty();.    
09b0: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20      }.      }.  
09c0: 20 20 7d 0a 0a 20 20 20 20 23 72 65 67 69 6f 6e    }..    #region
09d0: 20 49 43 6c 6f 6e 65 61 62 6c 65 20 4d 65 6d 62   ICloneable Memb
09e0: 65 72 73 0a 0a 20 20 20 20 6f 62 6a 65 63 74 20  ers..    object 
09f0: 49 43 6c 6f 6e 65 61 62 6c 65 2e 43 6c 6f 6e 65  ICloneable.Clone
0a00: 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 72  ().    {.      r
0a10: 65 74 75 72 6e 20 6e 65 77 20 50 72 69 6d 61 72  eturn new Primar
0a20: 79 4b 65 79 28 74 68 69 73 29 3b 0a 20 20 20 20  yKey(this);.    
0a30: 7d 0a 0a 20 20 20 20 23 65 6e 64 72 65 67 69 6f  }..    #endregio
0a40: 6e 0a 20 20 7d 0a 7d 0a                          n.  }.}.