System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact f8138c76d02d765a6ba9bcfbfe58b909cd5fb252:


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 0a 7b 0a 20 20 75 73  .Designer.{.  us
0140: 69 6e 67 20 53 79 73 74 65 6d 3b 0a 20 20 75 73  ing System;.  us
0150: 69 6e 67 20 53 79 73 74 65 6d 2e 43 6f 6d 70 6f  ing System.Compo
0160: 6e 65 6e 74 4d 6f 64 65 6c 3b 0a 20 20 75 73 69  nentModel;.  usi
0170: 6e 67 20 53 79 73 74 65 6d 2e 43 6f 6d 70 6f 6e  ng System.Compon
0180: 65 6e 74 4d 6f 64 65 6c 2e 44 65 73 69 67 6e 3b  entModel.Design;
0190: 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e  .  using System.
01a0: 44 72 61 77 69 6e 67 2e 44 65 73 69 67 6e 3b 0a  Drawing.Design;.
01b0: 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 44    using System.D
01c0: 61 74 61 2e 43 6f 6d 6d 6f 6e 3b 0a 20 20 75 73  ata.Common;.  us
01d0: 69 6e 67 20 53 79 73 74 65 6d 2e 52 65 66 6c 65  ing System.Refle
01e0: 63 74 69 6f 6e 3b 0a 20 20 75 73 69 6e 67 20 53  ction;.  using S
01f0: 79 73 74 65 6d 2e 43 6f 6c 6c 65 63 74 69 6f 6e  ystem.Collection
0200: 73 2e 47 65 6e 65 72 69 63 3b 0a 20 20 75 73 69  s.Generic;.  usi
0210: 6e 67 20 53 79 73 74 65 6d 2e 57 69 6e 64 6f 77  ng System.Window
0220: 73 2e 46 6f 72 6d 73 3b 0a 20 20 75 73 69 6e 67  s.Forms;.  using
0230: 20 53 79 73 74 65 6d 2e 44 72 61 77 69 6e 67 3b   System.Drawing;
0240: 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e  .  using System.
0250: 52 75 6e 74 69 6d 65 2e 53 65 72 69 61 6c 69 7a  Runtime.Serializ
0260: 61 74 69 6f 6e 3b 0a 20 20 75 73 69 6e 67 20 53  ation;.  using S
0270: 79 73 74 65 6d 2e 47 6c 6f 62 61 6c 69 7a 61 74  ystem.Globalizat
0280: 69 6f 6e 3b 0a 0a 20 20 2f 2f 2f 20 3c 73 75 6d  ion;..  /// <sum
0290: 6d 61 72 79 3e 0a 20 20 2f 2f 2f 20 50 72 6f 76  mary>.  /// Prov
02a0: 69 64 65 73 20 61 20 74 6f 6f 6c 62 6f 78 69 74  ides a toolboxit
02b0: 65 6d 20 66 6f 72 20 61 20 53 51 4c 69 74 65 44  em for a SQLiteD
02c0: 61 74 61 41 64 61 70 74 65 72 2e 20 20 54 68 69  ataAdapter.  Thi
02d0: 73 20 69 73 20 72 65 71 75 69 72 65 64 20 69 6e  s is required in
02e0: 20 6f 72 64 65 72 20 66 6f 72 20 75 73 20 74 6f   order for us to
02f0: 20 0a 20 20 2f 2f 2f 20 70 6f 70 20 75 70 20 74   .  /// pop up t
0300: 68 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 77 69  he connection wi
0310: 7a 61 72 64 20 77 68 65 6e 20 79 6f 75 20 64 72  zard when you dr
0320: 6f 70 20 74 68 65 20 74 6f 6f 6c 20 6f 6e 20 61  op the tool on a
0330: 20 66 6f 72 6d 2c 20 61 6e 64 20 74 6f 20 63 72   form, and to cr
0340: 65 61 74 65 20 74 68 65 20 68 69 64 64 65 6e 20  eate the hidden 
0350: 63 6f 6d 6d 61 6e 64 73 0a 20 20 2f 2f 2f 20 74  commands.  /// t
0360: 68 61 74 20 61 72 65 20 61 73 73 69 67 6e 65 64  hat are assigned
0370: 20 74 6f 20 74 68 65 20 64 61 74 61 20 61 64 61   to the data ada
0380: 70 74 65 72 20 61 6e 64 20 6b 65 65 70 20 74 68  pter and keep th
0390: 65 6d 20 68 69 64 64 65 6e 2e 20 20 54 68 65 20  em hidden.  The 
03a0: 68 69 64 69 6e 67 20 61 74 20 72 75 6e 74 69 6d  hiding at runtim
03b0: 65 20 6f 66 20 74 68 65 20 63 6f 6e 74 72 6f 6c  e of the control
03c0: 73 0a 20 20 2f 2f 2f 20 69 73 20 61 63 63 6f 6d  s.  /// is accom
03d0: 70 6c 69 73 68 65 64 20 62 6f 74 68 20 68 65 72  plished both her
03e0: 65 20 64 75 72 69 6e 67 20 74 68 65 20 63 72 65  e during the cre
03f0: 61 74 69 6f 6e 20 6f 66 20 74 68 65 20 63 6f 6d  ation of the com
0400: 70 6f 6e 65 6e 74 73 20 61 6e 64 20 69 6e 20 74  ponents and in t
0410: 68 65 20 53 51 4c 69 74 65 43 6f 6d 6d 61 6e 64  he SQLiteCommand
0420: 44 65 73 69 67 6e 65 72 0a 20 20 2f 2f 2f 20 77  Designer.  /// w
0430: 68 69 63 68 20 70 72 6f 76 69 64 65 73 20 70 72  hich provides pr
0440: 6f 70 65 72 74 69 65 73 20 74 6f 20 68 69 64 65  operties to hide
0450: 20 74 68 65 20 6f 62 6a 65 63 74 73 20 77 68 65   the objects whe
0460: 6e 20 74 68 65 79 27 72 65 20 73 75 70 70 6f 73  n they're suppos
0470: 65 64 20 74 6f 20 62 65 20 68 69 64 64 65 6e 2e  ed to be hidden.
0480: 0a 20 20 2f 2f 2f 20 0a 20 20 2f 2f 2f 20 54 68  .  /// .  /// Th
0490: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 77 69 7a  e connection wiz
04a0: 61 72 64 20 69 73 20 69 6e 73 74 61 6e 74 69 61  ard is instantia
04b0: 74 65 64 20 69 6e 20 74 68 65 20 56 53 44 65 73  ted in the VSDes
04c0: 69 67 6e 65 72 20 74 68 72 6f 75 67 68 20 72 65  igner through re
04d0: 66 6c 65 63 74 69 6f 6e 2e 0a 20 20 2f 2f 2f 20  flection..  /// 
04e0: 3c 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 5b 53 65  </summary>.  [Se
04f0: 72 69 61 6c 69 7a 61 62 6c 65 5d 0a 20 20 5b 54  rializable].  [T
0500: 6f 6f 6c 62 6f 78 49 74 65 6d 28 74 79 70 65 6f  oolboxItem(typeo
0510: 66 28 53 51 4c 69 74 65 44 61 74 61 41 64 61 70  f(SQLiteDataAdap
0520: 74 65 72 54 6f 6f 6c 62 6f 78 49 74 65 6d 29 29  terToolboxItem))
0530: 5d 0a 20 20 69 6e 74 65 72 6e 61 6c 20 73 65 61  ].  internal sea
0540: 6c 65 64 20 63 6c 61 73 73 20 53 51 4c 69 74 65  led class SQLite
0550: 44 61 74 61 41 64 61 70 74 65 72 54 6f 6f 6c 62  DataAdapterToolb
0560: 6f 78 49 74 65 6d 20 3a 20 54 6f 6f 6c 62 6f 78  oxItem : Toolbox
0570: 49 74 65 6d 0a 20 20 7b 0a 20 20 20 20 70 72 69  Item.  {.    pri
0580: 76 61 74 65 20 73 74 61 74 69 63 20 54 79 70 65  vate static Type
0590: 20 5f 77 69 7a 61 72 64 3b 0a 20 20 20 20 0a 20   _wizard;.    . 
05a0: 20 20 20 69 6e 74 65 72 6e 61 6c 20 73 74 61 74     internal stat
05b0: 69 63 20 41 73 73 65 6d 62 6c 79 20 5f 76 73 64  ic Assembly _vsd
05c0: 65 73 69 67 6e 65 72 3b 0a 0a 20 20 20 20 73 74  esigner;..    st
05d0: 61 74 69 63 20 53 51 4c 69 74 65 44 61 74 61 41  atic SQLiteDataA
05e0: 64 61 70 74 65 72 54 6f 6f 6c 62 6f 78 49 74 65  dapterToolboxIte
05f0: 6d 28 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20  m().    {.      
0600: 5f 76 73 64 65 73 69 67 6e 65 72 20 3d 20 41 73  _vsdesigner = As
0610: 73 65 6d 62 6c 79 2e 4c 6f 61 64 28 22 4d 69 63  sembly.Load("Mic
0620: 72 6f 73 6f 66 74 2e 56 53 44 65 73 69 67 6e 65  rosoft.VSDesigne
0630: 72 2c 20 56 65 72 73 69 6f 6e 3d 38 2e 30 2e 30  r, Version=8.0.0
0640: 2e 30 2c 20 43 75 6c 74 75 72 65 3d 6e 65 75 74  .0, Culture=neut
0650: 72 61 6c 2c 20 50 75 62 6c 69 63 4b 65 79 54 6f  ral, PublicKeyTo
0660: 6b 65 6e 3d 62 30 33 66 35 66 37 66 31 31 64 35  ken=b03f5f7f11d5
0670: 30 61 33 61 22 29 3b 0a 20 20 20 20 20 20 5f 77  0a3a");.      _w
0680: 69 7a 61 72 64 20 3d 20 5f 76 73 64 65 73 69 67  izard = _vsdesig
0690: 6e 65 72 2e 47 65 74 54 79 70 65 28 22 4d 69 63  ner.GetType("Mic
06a0: 72 6f 73 6f 66 74 2e 56 53 44 65 73 69 67 6e 65  rosoft.VSDesigne
06b0: 72 2e 44 61 74 61 2e 56 53 2e 44 61 74 61 41 64  r.Data.VS.DataAd
06c0: 61 70 74 65 72 57 69 7a 61 72 64 22 29 3b 0a 20  apterWizard");. 
06d0: 20 20 20 7d 0a 0a 20 20 20 20 70 75 62 6c 69 63     }..    public
06e0: 20 53 51 4c 69 74 65 44 61 74 61 41 64 61 70 74   SQLiteDataAdapt
06f0: 65 72 54 6f 6f 6c 62 6f 78 49 74 65 6d 28 54 79  erToolboxItem(Ty
0700: 70 65 20 74 79 70 65 29 20 3a 20 74 68 69 73 28  pe type) : this(
0710: 74 79 70 65 2c 20 28 42 69 74 6d 61 70 29 6e 75  type, (Bitmap)nu
0720: 6c 6c 29 0a 20 20 20 20 7b 0a 20 20 20 20 7d 0a  ll).    {.    }.
0730: 0a 20 20 20 20 70 75 62 6c 69 63 20 53 51 4c 69  .    public SQLi
0740: 74 65 44 61 74 61 41 64 61 70 74 65 72 54 6f 6f  teDataAdapterToo
0750: 6c 62 6f 78 49 74 65 6d 28 54 79 70 65 20 74 79  lboxItem(Type ty
0760: 70 65 2c 20 42 69 74 6d 61 70 20 62 6d 70 29 20  pe, Bitmap bmp) 
0770: 3a 20 62 61 73 65 28 74 79 70 65 29 0a 20 20 20  : base(type).   
0780: 20 7b 0a 20 20 20 20 20 20 44 69 73 70 6c 61 79   {.      Display
0790: 4e 61 6d 65 20 3d 20 22 53 51 4c 69 74 65 44 61  Name = "SQLiteDa
07a0: 74 61 41 64 61 70 74 65 72 22 3b 0a 20 20 20 20  taAdapter";.    
07b0: 7d 0a 0a 20 20 20 20 70 72 69 76 61 74 65 20 53  }..    private S
07c0: 51 4c 69 74 65 44 61 74 61 41 64 61 70 74 65 72  QLiteDataAdapter
07d0: 54 6f 6f 6c 62 6f 78 49 74 65 6d 28 53 65 72 69  ToolboxItem(Seri
07e0: 61 6c 69 7a 61 74 69 6f 6e 49 6e 66 6f 20 69 6e  alizationInfo in
07f0: 66 6f 2c 20 53 74 72 65 61 6d 69 6e 67 43 6f 6e  fo, StreamingCon
0800: 74 65 78 74 20 63 6f 6e 74 65 78 74 29 0a 20 20  text context).  
0810: 20 20 7b 0a 20 20 20 20 20 20 44 65 73 65 72 69    {.      Deseri
0820: 61 6c 69 7a 65 28 69 6e 66 6f 2c 20 63 6f 6e 74  alize(info, cont
0830: 65 78 74 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  ext);.    }..   
0840: 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79 3e 0a 20   /// <summary>. 
0850: 20 20 20 2f 2f 2f 20 43 72 65 61 74 65 73 20 74     /// Creates t
0860: 68 65 20 6e 65 63 65 73 73 61 72 79 20 63 6f 6d  he necessary com
0870: 70 6f 6e 65 6e 74 73 20 61 73 73 6f 63 69 61 74  ponents associat
0880: 65 64 20 77 69 74 68 20 74 68 69 73 20 64 61 74  ed with this dat
0890: 61 20 61 64 61 70 74 65 72 20 69 6e 73 74 61 6e  a adapter instan
08a0: 63 65 0a 20 20 20 20 2f 2f 2f 20 3c 2f 73 75 6d  ce.    /// </sum
08b0: 6d 61 72 79 3e 0a 20 20 20 20 2f 2f 2f 20 3c 70  mary>.    /// <p
08c0: 61 72 61 6d 20 6e 61 6d 65 3d 22 68 6f 73 74 22  aram name="host"
08d0: 3e 54 68 65 20 64 65 73 69 67 6e 65 72 20 68 6f  >The designer ho
08e0: 73 74 3c 2f 70 61 72 61 6d 3e 0a 20 20 20 20 2f  st</param>.    /
08f0: 2f 2f 20 3c 72 65 74 75 72 6e 73 3e 54 68 65 20  // <returns>The 
0900: 63 6f 6d 70 6f 6e 65 6e 74 73 20 63 72 65 61 74  components creat
0910: 65 64 20 62 79 20 74 68 69 73 20 74 6f 6f 6c 62  ed by this toolb
0920: 6f 78 20 69 74 65 6d 3c 2f 72 65 74 75 72 6e 73  ox item</returns
0930: 3e 0d 0a 20 20 20 20 70 72 6f 74 65 63 74 65 64  >..    protected
0940: 20 6f 76 65 72 72 69 64 65 20 49 43 6f 6d 70 6f   override ICompo
0950: 6e 65 6e 74 5b 5d 20 43 72 65 61 74 65 43 6f 6d  nent[] CreateCom
0960: 70 6f 6e 65 6e 74 73 43 6f 72 65 28 49 44 65 73  ponentsCore(IDes
0970: 69 67 6e 65 72 48 6f 73 74 20 68 6f 73 74 29 0d  ignerHost host).
0980: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20  .    {..        
0990: 4c 69 73 74 3c 49 43 6f 6d 70 6f 6e 65 6e 74 3e  List<IComponent>
09a0: 20 6c 69 73 74 20 3d 20 6e 65 77 20 4c 69 73 74   list = new List
09b0: 3c 49 43 6f 6d 70 6f 6e 65 6e 74 3e 28 29 3b 0d  <IComponent>();.
09c0: 0a 20 20 20 20 20 20 20 20 44 62 50 72 6f 76 69  .        DbProvi
09d0: 64 65 72 46 61 63 74 6f 72 79 20 66 61 63 74 3b  derFactory fact;
09e0: 0d 0a 0d 0a 20 20 20 20 20 20 20 20 69 66 20 28  ....        if (
09f0: 53 51 4c 69 74 65 4f 70 74 69 6f 6e 73 2e 47 65  SQLiteOptions.Ge
0a00: 74 50 72 6f 76 69 64 65 72 46 61 63 74 6f 72 79  tProviderFactory
0a10: 28 53 51 4c 69 74 65 4f 70 74 69 6f 6e 73 2e 47  (SQLiteOptions.G
0a20: 65 74 50 72 6f 76 69 64 65 72 4e 61 6d 65 28 29  etProviderName()
0a30: 2c 20 74 72 75 65 2c 20 6f 75 74 20 66 61 63 74  , true, out fact
0a40: 29 29 0d 0a 20 20 20 20 20 20 20 20 7b 0d 0a 20  ))..        {.. 
0a50: 20 20 20 20 20 20 20 20 20 20 20 44 62 44 61 74             DbDat
0a60: 61 41 64 61 70 74 65 72 20 64 61 74 61 41 64 61  aAdapter dataAda
0a70: 70 74 65 72 20 3d 20 66 61 63 74 2e 43 72 65 61  pter = fact.Crea
0a80: 74 65 44 61 74 61 41 64 61 70 74 65 72 28 29 3b  teDataAdapter();
0a90: 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 49 43  ..            IC
0aa0: 6f 6e 74 61 69 6e 65 72 20 63 6f 6e 74 61 69 6e  ontainer contain
0ab0: 65 72 20 3d 20 68 6f 73 74 2e 43 6f 6e 74 61 69  er = host.Contai
0ac0: 6e 65 72 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20  ner;....        
0ad0: 20 20 20 20 75 73 69 6e 67 20 28 44 62 43 6f 6d      using (DbCom
0ae0: 6d 61 6e 64 20 61 64 61 70 74 65 72 43 6f 6d 6d  mand adapterComm
0af0: 61 6e 64 20 3d 20 66 61 63 74 2e 43 72 65 61 74  and = fact.Creat
0b00: 65 43 6f 6d 6d 61 6e 64 28 29 29 0d 0a 20 20 20  eCommand())..   
0b10: 20 20 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20           {..    
0b20: 20 20 20 20 20 20 20 20 20 20 20 20 49 43 6c 6f              IClo
0b30: 6e 65 61 62 6c 65 20 61 64 61 70 74 65 72 20 3d  neable adapter =
0b40: 20 28 49 43 6c 6f 6e 65 61 62 6c 65 29 61 64 61   (ICloneable)ada
0b50: 70 74 65 72 43 6f 6d 6d 61 6e 64 3b 0d 0a 0d 0a  pterCommand;....
0b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b70: 61 64 61 70 74 65 72 43 6f 6d 6d 61 6e 64 2e 44  adapterCommand.D
0b80: 65 73 69 67 6e 54 69 6d 65 56 69 73 69 62 6c 65  esignTimeVisible
0b90: 20 3d 20 66 61 6c 73 65 3b 0d 0a 20 20 20 20 20   = false;..     
0ba0: 20 20 20 20 20 20 20 20 20 20 20 64 61 74 61 41             dataA
0bb0: 64 61 70 74 65 72 2e 53 65 6c 65 63 74 43 6f 6d  dapter.SelectCom
0bc0: 6d 61 6e 64 20 3d 20 28 44 62 43 6f 6d 6d 61 6e  mand = (DbComman
0bd0: 64 29 61 64 61 70 74 65 72 2e 43 6c 6f 6e 65 28  d)adapter.Clone(
0be0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
0bf0: 20 20 20 20 63 6f 6e 74 61 69 6e 65 72 2e 41 64      container.Ad
0c00: 64 28 64 61 74 61 41 64 61 70 74 65 72 2e 53 65  d(dataAdapter.Se
0c10: 6c 65 63 74 43 6f 6d 6d 61 6e 64 2c 20 47 65 6e  lectCommand, Gen
0c20: 65 72 61 74 65 4e 61 6d 65 28 63 6f 6e 74 61 69  erateName(contai
0c30: 6e 65 72 2c 20 22 53 65 6c 65 63 74 43 6f 6d 6d  ner, "SelectComm
0c40: 61 6e 64 22 29 29 3b 0d 0a 0d 0a 20 20 20 20 20  and"));....     
0c50: 20 20 20 20 20 20 20 20 20 20 20 64 61 74 61 41             dataA
0c60: 64 61 70 74 65 72 2e 49 6e 73 65 72 74 43 6f 6d  dapter.InsertCom
0c70: 6d 61 6e 64 20 3d 20 28 44 62 43 6f 6d 6d 61 6e  mand = (DbComman
0c80: 64 29 61 64 61 70 74 65 72 2e 43 6c 6f 6e 65 28  d)adapter.Clone(
0c90: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
0ca0: 20 20 20 20 63 6f 6e 74 61 69 6e 65 72 2e 41 64      container.Ad
0cb0: 64 28 64 61 74 61 41 64 61 70 74 65 72 2e 49 6e  d(dataAdapter.In
0cc0: 73 65 72 74 43 6f 6d 6d 61 6e 64 2c 20 47 65 6e  sertCommand, Gen
0cd0: 65 72 61 74 65 4e 61 6d 65 28 63 6f 6e 74 61 69  erateName(contai
0ce0: 6e 65 72 2c 20 22 49 6e 73 65 72 74 43 6f 6d 6d  ner, "InsertComm
0cf0: 61 6e 64 22 29 29 3b 0d 0a 0d 0a 20 20 20 20 20  and"));....     
0d00: 20 20 20 20 20 20 20 20 20 20 20 64 61 74 61 41             dataA
0d10: 64 61 70 74 65 72 2e 55 70 64 61 74 65 43 6f 6d  dapter.UpdateCom
0d20: 6d 61 6e 64 20 3d 20 28 44 62 43 6f 6d 6d 61 6e  mand = (DbComman
0d30: 64 29 61 64 61 70 74 65 72 2e 43 6c 6f 6e 65 28  d)adapter.Clone(
0d40: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
0d50: 20 20 20 20 63 6f 6e 74 61 69 6e 65 72 2e 41 64      container.Ad
0d60: 64 28 64 61 74 61 41 64 61 70 74 65 72 2e 55 70  d(dataAdapter.Up
0d70: 64 61 74 65 43 6f 6d 6d 61 6e 64 2c 20 47 65 6e  dateCommand, Gen
0d80: 65 72 61 74 65 4e 61 6d 65 28 63 6f 6e 74 61 69  erateName(contai
0d90: 6e 65 72 2c 20 22 55 70 64 61 74 65 43 6f 6d 6d  ner, "UpdateComm
0da0: 61 6e 64 22 29 29 3b 0d 0a 0d 0a 20 20 20 20 20  and"));....     
0db0: 20 20 20 20 20 20 20 20 20 20 20 64 61 74 61 41             dataA
0dc0: 64 61 70 74 65 72 2e 44 65 6c 65 74 65 43 6f 6d  dapter.DeleteCom
0dd0: 6d 61 6e 64 20 3d 20 28 44 62 43 6f 6d 6d 61 6e  mand = (DbComman
0de0: 64 29 61 64 61 70 74 65 72 2e 43 6c 6f 6e 65 28  d)adapter.Clone(
0df0: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
0e00: 20 20 20 20 63 6f 6e 74 61 69 6e 65 72 2e 41 64      container.Ad
0e10: 64 28 64 61 74 61 41 64 61 70 74 65 72 2e 44 65  d(dataAdapter.De
0e20: 6c 65 74 65 43 6f 6d 6d 61 6e 64 2c 20 47 65 6e  leteCommand, Gen
0e30: 65 72 61 74 65 4e 61 6d 65 28 63 6f 6e 74 61 69  erateName(contai
0e40: 6e 65 72 2c 20 22 44 65 6c 65 74 65 43 6f 6d 6d  ner, "DeleteComm
0e50: 61 6e 64 22 29 29 3b 0d 0a 20 20 20 20 20 20 20  and"));..       
0e60: 20 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20       }....      
0e70: 20 20 20 20 20 20 49 54 79 70 65 52 65 73 6f 6c        ITypeResol
0e80: 75 74 69 6f 6e 53 65 72 76 69 63 65 20 74 79 70  utionService typ
0e90: 65 52 65 73 53 65 72 76 69 63 65 20 3d 20 28 49  eResService = (I
0ea0: 54 79 70 65 52 65 73 6f 6c 75 74 69 6f 6e 53 65  TypeResolutionSe
0eb0: 72 76 69 63 65 29 68 6f 73 74 2e 47 65 74 53 65  rvice)host.GetSe
0ec0: 72 76 69 63 65 28 74 79 70 65 6f 66 28 49 54 79  rvice(typeof(ITy
0ed0: 70 65 52 65 73 6f 6c 75 74 69 6f 6e 53 65 72 76  peResolutionServ
0ee0: 69 63 65 29 29 3b 0d 0a 20 20 20 20 20 20 20 20  ice));..        
0ef0: 20 20 20 20 69 66 20 28 74 79 70 65 52 65 73 53      if (typeResS
0f00: 65 72 76 69 63 65 20 21 3d 20 6e 75 6c 6c 29 0d  ervice != null).
0f10: 0a 20 20 20 20 20 20 20 20 20 20 20 20 7b 0d 0a  .            {..
0f20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0f30: 74 79 70 65 52 65 73 53 65 72 76 69 63 65 2e 52  typeResService.R
0f40: 65 66 65 72 65 6e 63 65 41 73 73 65 6d 62 6c 79  eferenceAssembly
0f50: 28 64 61 74 61 41 64 61 70 74 65 72 2e 47 65 74  (dataAdapter.Get
0f60: 54 79 70 65 28 29 2e 41 73 73 65 6d 62 6c 79 2e  Type().Assembly.
0f70: 47 65 74 4e 61 6d 65 28 29 29 3b 0d 0a 20 20 20  GetName());..   
0f80: 20 20 20 20 20 20 20 20 20 7d 0d 0a 0d 0a 20 20           }....  
0f90: 20 20 20 20 20 20 20 20 20 20 63 6f 6e 74 61 69            contai
0fa0: 6e 65 72 2e 41 64 64 28 64 61 74 61 41 64 61 70  ner.Add(dataAdap
0fb0: 74 65 72 29 3b 0d 0a 0d 0a 20 20 20 20 20 20 20  ter);....       
0fc0: 20 20 20 20 20 6c 69 73 74 2e 41 64 64 28 64 61       list.Add(da
0fd0: 74 61 41 64 61 70 74 65 72 29 3b 0d 0a 0d 0a 20  taAdapter);.... 
0fe0: 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20 53 68             // Sh
0ff0: 6f 77 20 74 68 65 20 63 6f 6e 6e 65 63 74 69 6f  ow the connectio
1000: 6e 20 77 69 7a 61 72 64 20 69 66 20 77 65 20 68  n wizard if we h
1010: 61 76 65 20 61 20 74 79 70 65 20 66 6f 72 20 69  ave a type for i
1020: 74 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  t..            i
1030: 66 20 28 5f 77 69 7a 61 72 64 20 21 3d 20 6e 75  f (_wizard != nu
1040: 6c 6c 29 0d 0a 20 20 20 20 20 20 20 20 20 20 20  ll)..           
1050: 20 7b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20   {..            
1060: 20 20 20 20 75 73 69 6e 67 20 28 46 6f 72 6d 20      using (Form 
1070: 77 69 7a 61 72 64 20 3d 20 28 46 6f 72 6d 29 41  wizard = (Form)A
1080: 63 74 69 76 61 74 6f 72 2e 43 72 65 61 74 65 49  ctivator.CreateI
1090: 6e 73 74 61 6e 63 65 28 5f 77 69 7a 61 72 64 2c  nstance(_wizard,
10a0: 20 6e 65 77 20 6f 62 6a 65 63 74 5b 5d 20 7b 20   new object[] { 
10b0: 68 6f 73 74 2c 20 64 61 74 61 41 64 61 70 74 65  host, dataAdapte
10c0: 72 20 7d 29 29 0d 0a 20 20 20 20 20 20 20 20 20  r }))..         
10d0: 20 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20         {..      
10e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77 69                wi
10f0: 7a 61 72 64 2e 53 68 6f 77 44 69 61 6c 6f 67 28  zard.ShowDialog(
1100: 29 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20  );..            
1110: 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 20 20 20      }..         
1120: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20 20     }....        
1130: 20 20 20 20 69 66 20 28 64 61 74 61 41 64 61 70      if (dataAdap
1140: 74 65 72 2e 53 65 6c 65 63 74 43 6f 6d 6d 61 6e  ter.SelectComman
1150: 64 20 21 3d 20 6e 75 6c 6c 29 20 6c 69 73 74 2e  d != null) list.
1160: 41 64 64 28 64 61 74 61 41 64 61 70 74 65 72 2e  Add(dataAdapter.
1170: 53 65 6c 65 63 74 43 6f 6d 6d 61 6e 64 29 3b 0d  SelectCommand);.
1180: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 20  .            if 
1190: 28 64 61 74 61 41 64 61 70 74 65 72 2e 49 6e 73  (dataAdapter.Ins
11a0: 65 72 74 43 6f 6d 6d 61 6e 64 20 21 3d 20 6e 75  ertCommand != nu
11b0: 6c 6c 29 20 6c 69 73 74 2e 41 64 64 28 64 61 74  ll) list.Add(dat
11c0: 61 41 64 61 70 74 65 72 2e 49 6e 73 65 72 74 43  aAdapter.InsertC
11d0: 6f 6d 6d 61 6e 64 29 3b 0d 0a 20 20 20 20 20 20  ommand);..      
11e0: 20 20 20 20 20 20 69 66 20 28 64 61 74 61 41 64        if (dataAd
11f0: 61 70 74 65 72 2e 44 65 6c 65 74 65 43 6f 6d 6d  apter.DeleteComm
1200: 61 6e 64 20 21 3d 20 6e 75 6c 6c 29 20 6c 69 73  and != null) lis
1210: 74 2e 41 64 64 28 64 61 74 61 41 64 61 70 74 65  t.Add(dataAdapte
1220: 72 2e 44 65 6c 65 74 65 43 6f 6d 6d 61 6e 64 29  r.DeleteCommand)
1230: 3b 0d 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  ;..            i
1240: 66 20 28 64 61 74 61 41 64 61 70 74 65 72 2e 55  f (dataAdapter.U
1250: 70 64 61 74 65 43 6f 6d 6d 61 6e 64 20 21 3d 20  pdateCommand != 
1260: 6e 75 6c 6c 29 20 6c 69 73 74 2e 41 64 64 28 64  null) list.Add(d
1270: 61 74 61 41 64 61 70 74 65 72 2e 55 70 64 61 74  ataAdapter.Updat
1280: 65 43 6f 6d 6d 61 6e 64 29 3b 0d 0a 20 20 20 20  eCommand);..    
1290: 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 20      }....       
12a0: 20 72 65 74 75 72 6e 20 6c 69 73 74 2e 54 6f 41   return list.ToA
12b0: 72 72 61 79 28 29 3b 0d 0a 20 20 20 20 7d 0a 0a  rray();..    }..
12c0: 20 20 20 20 2f 2f 2f 20 3c 73 75 6d 6d 61 72 79      /// <summary
12d0: 3e 0a 20 20 20 20 2f 2f 2f 20 47 65 6e 65 72 61  >.    /// Genera
12e0: 74 65 73 20 61 20 75 6e 69 71 75 65 20 6e 61 6d  tes a unique nam
12f0: 65 20 66 6f 72 20 74 68 65 20 67 69 76 65 6e 20  e for the given 
1300: 6f 62 6a 65 63 74 0a 20 20 20 20 2f 2f 2f 20 3c  object.    /// <
1310: 2f 73 75 6d 6d 61 72 79 3e 0a 20 20 20 20 2f 2f  /summary>.    //
1320: 2f 20 3c 70 61 72 61 6d 20 6e 61 6d 65 3d 22 63  / <param name="c
1330: 6f 6e 74 61 69 6e 65 72 22 3e 54 68 65 20 63 6f  ontainer">The co
1340: 6e 74 61 69 6e 65 72 20 77 68 65 72 65 20 77 65  ntainer where we
1350: 27 72 65 20 62 65 69 6e 67 20 69 6e 73 74 61 6e  're being instan
1360: 74 69 61 74 65 64 3c 2f 70 61 72 61 6d 3e 0a 20  tiated</param>. 
1370: 20 20 20 2f 2f 2f 20 3c 70 61 72 61 6d 20 6e 61     /// <param na
1380: 6d 65 3d 22 62 61 73 65 4e 61 6d 65 22 3e 54 68  me="baseName">Th
1390: 65 20 63 6f 72 65 20 6e 61 6d 65 20 6f 66 20 74  e core name of t
13a0: 68 65 20 6f 62 6a 65 63 74 20 74 6f 20 63 72 65  he object to cre
13b0: 61 74 65 20 61 20 75 6e 69 71 75 65 20 69 6e 73  ate a unique ins
13c0: 74 61 6e 63 65 20 6f 66 3c 2f 70 61 72 61 6d 3e  tance of</param>
13d0: 0a 20 20 20 20 2f 2f 2f 20 3c 72 65 74 75 72 6e  .    /// <return
13e0: 73 3e 41 20 75 6e 69 71 75 65 20 6e 61 6d 65 20  s>A unique name 
13f0: 77 69 74 68 69 6e 20 74 68 65 20 67 69 76 65 6e  within the given
1400: 20 63 6f 6e 74 61 69 6e 65 72 3c 2f 72 65 74 75   container</retu
1410: 72 6e 73 3e 0a 20 20 20 20 70 72 69 76 61 74 65  rns>.    private
1420: 20 73 74 61 74 69 63 20 73 74 72 69 6e 67 20 47   static string G
1430: 65 6e 65 72 61 74 65 4e 61 6d 65 28 49 43 6f 6e  enerateName(ICon
1440: 74 61 69 6e 65 72 20 63 6f 6e 74 61 69 6e 65 72  tainer container
1450: 2c 20 73 74 72 69 6e 67 20 62 61 73 65 4e 61 6d  , string baseNam
1460: 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 43  e).    {.      C
1470: 6f 6d 70 6f 6e 65 6e 74 43 6f 6c 6c 65 63 74 69  omponentCollecti
1480: 6f 6e 20 63 6f 6c 6c 20 3d 20 63 6f 6e 74 61 69  on coll = contai
1490: 6e 65 72 2e 43 6f 6d 70 6f 6e 65 6e 74 73 3b 0a  ner.Components;.
14a0: 20 20 20 20 20 20 73 74 72 69 6e 67 20 75 6e 69        string uni
14b0: 71 75 65 4e 61 6d 65 3b 0a 20 20 20 20 20 20 69  queName;.      i
14c0: 6e 74 20 6e 20 3d 20 31 3b 0a 20 20 20 20 20 20  nt n = 1;.      
14d0: 64 6f 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  do.      {.     
14e0: 20 20 20 75 6e 69 71 75 65 4e 61 6d 65 20 3d 20     uniqueName = 
14f0: 53 74 72 69 6e 67 2e 46 6f 72 6d 61 74 28 43 75  String.Format(Cu
1500: 6c 74 75 72 65 49 6e 66 6f 2e 49 6e 76 61 72 69  ltureInfo.Invari
1510: 61 6e 74 43 75 6c 74 75 72 65 2c 20 22 73 71 6c  antCulture, "sql
1520: 69 74 65 7b 30 7d 7b 31 7d 22 2c 20 62 61 73 65  ite{0}{1}", base
1530: 4e 61 6d 65 2c 20 6e 2b 2b 29 3b 0a 20 20 20 20  Name, n++);.    
1540: 20 20 7d 20 77 68 69 6c 65 20 28 63 6f 6c 6c 5b    } while (coll[
1550: 75 6e 69 71 75 65 4e 61 6d 65 5d 20 21 3d 20 6e  uniqueName] != n
1560: 75 6c 6c 29 3b 0a 0a 20 20 20 20 20 20 72 65 74  ull);..      ret
1570: 75 72 6e 20 75 6e 69 71 75 65 4e 61 6d 65 3b 0a  urn uniqueName;.
1580: 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a                  }.  }.}.