System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact b1d4e532e299ef51c2bb2dab426187a7883a78e7:


0000: ef bb bf 2f 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 2a 2a 2a 0a 20 2a 20  ************. * 
0040: 41 44 4f 2e 4e 45 54 20 32 2e 30 20 44 61 74 61  ADO.NET 2.0 Data
0050: 20 50 72 6f 76 69 64 65 72 20 66 6f 72 20 53 51   Provider for SQ
0060: 4c 69 74 65 20 56 65 72 73 69 6f 6e 20 33 2e 58  Lite Version 3.X
0070: 0a 20 2a 20 57 72 69 74 74 65 6e 20 62 79 20 52  . * Written by R
0080: 6f 62 65 72 74 20 53 69 6d 70 73 6f 6e 20 28 72  obert Simpson (r
0090: 6f 62 65 72 74 40 62 6c 61 63 6b 63 61 73 74 6c  obert@blackcastl
00a0: 65 73 6f 66 74 2e 63 6f 6d 29 0a 20 2a 20 0a 20  esoft.com). * . 
00b0: 2a 20 52 65 6c 65 61 73 65 64 20 74 6f 20 74 68  * Released to th
00c0: 65 20 70 75 62 6c 69 63 20 64 6f 6d 61 69 6e 2c  e public domain,
00d0: 20 75 73 65 20 61 74 20 79 6f 75 72 20 6f 77 6e   use at your own
00e0: 20 72 69 73 6b 21 0a 20 2a 2a 2a 2a 2a 2a 2a 2a   risk!. ********
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 2a 2a 2a  ****************
0120: 2f 0a 0a 6e 61 6d 65 73 70 61 63 65 20 53 51 4c  /..namespace SQL
0130: 69 74 65 2e 44 65 73 69 67 6e 65 72 0a 7b 0a 20  ite.Designer.{. 
0140: 20 75 73 69 6e 67 20 53 79 73 74 65 6d 3b 0a 20   using System;. 
0150: 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 43 6f   using System.Co
0160: 6c 6c 65 63 74 69 6f 6e 73 2e 47 65 6e 65 72 69  llections.Generi
0170: 63 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65  c;.  using Syste
0180: 6d 2e 43 6f 6d 70 6f 6e 65 6e 74 4d 6f 64 65 6c  m.ComponentModel
0190: 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  ;.  using System
01a0: 2e 44 61 74 61 3b 0a 20 20 75 73 69 6e 67 20 53  .Data;.  using S
01b0: 79 73 74 65 6d 2e 44 72 61 77 69 6e 67 3b 0a 20  ystem.Drawing;. 
01c0: 20 75 73 69 6e 67 20 53 79 73 74 65 6d 2e 54 65   using System.Te
01d0: 78 74 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74  xt;.  using Syst
01e0: 65 6d 2e 57 69 6e 64 6f 77 73 2e 46 6f 72 6d 73  em.Windows.Forms
01f0: 3b 0a 20 20 75 73 69 6e 67 20 53 79 73 74 65 6d  ;.  using System
0200: 2e 47 6c 6f 62 61 6c 69 7a 61 74 69 6f 6e 3b 0a  .Globalization;.
0210: 20 20 75 73 69 6e 67 20 53 51 4c 69 74 65 2e 44    using SQLite.D
0220: 65 73 69 67 6e 65 72 2e 44 65 73 69 67 6e 3b 0a  esigner.Design;.
0230: 0a 20 20 70 75 62 6c 69 63 20 70 61 72 74 69 61  .  public partia
0240: 6c 20 63 6c 61 73 73 20 43 68 61 6e 67 65 53 63  l class ChangeSc
0250: 72 69 70 74 44 69 61 6c 6f 67 20 3a 20 46 6f 72  riptDialog : For
0260: 6d 0a 20 20 7b 0a 20 20 20 20 70 72 69 76 61 74  m.  {.    privat
0270: 65 20 73 74 72 69 6e 67 20 5f 74 61 62 6c 65 4e  e string _tableN
0280: 61 6d 65 3b 0a 20 20 20 20 70 72 69 76 61 74 65  ame;.    private
0290: 20 73 74 61 74 69 63 20 62 6f 6f 6c 20 5f 64 65   static bool _de
02a0: 66 61 75 6c 74 53 61 76 65 3b 0a 0a 20 20 20 20  faultSave;..    
02b0: 70 75 62 6c 69 63 20 43 68 61 6e 67 65 53 63 72  public ChangeScr
02c0: 69 70 74 44 69 61 6c 6f 67 28 73 74 72 69 6e 67  iptDialog(string
02d0: 20 74 61 62 6c 65 4e 61 6d 65 2c 20 73 74 72 69   tableName, stri
02e0: 6e 67 20 73 63 72 69 70 74 2c 20 73 74 72 69 6e  ng script, strin
02f0: 67 20 6f 72 69 67 69 6e 61 6c 29 0a 20 20 20 20  g original).    
0300: 7b 0a 20 20 20 20 20 20 5f 74 61 62 6c 65 4e 61  {.      _tableNa
0310: 6d 65 20 3d 20 74 61 62 6c 65 4e 61 6d 65 3b 0a  me = tableName;.
0320: 20 20 20 20 20 20 49 6e 69 74 69 61 6c 69 7a 65        Initialize
0330: 43 6f 6d 70 6f 6e 65 6e 74 28 29 3b 0a 0a 20 20  Component();..  
0340: 20 20 20 20 5f 73 63 72 69 70 74 2e 54 65 78 74      _script.Text
0350: 20 3d 20 73 63 72 69 70 74 3b 0a 20 20 20 20 20   = script;.     
0360: 20 5f 6f 72 69 67 69 6e 61 6c 2e 54 65 78 74 20   _original.Text 
0370: 3d 20 6f 72 69 67 69 6e 61 6c 3b 0a 0a 20 20 20  = original;..   
0380: 20 20 20 5f 73 61 76 65 4f 72 69 67 2e 43 68 65     _saveOrig.Che
0390: 63 6b 65 64 20 3d 20 5f 64 65 66 61 75 6c 74 53  cked = _defaultS
03a0: 61 76 65 3b 0a 0a 20 20 20 20 20 20 69 66 20 28  ave;..      if (
03b0: 53 74 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f 72 45  String.IsNullOrE
03c0: 6d 70 74 79 28 6f 72 69 67 69 6e 61 6c 29 20 7c  mpty(original) |
03d0: 7c 20 53 74 72 69 6e 67 2e 49 73 4e 75 6c 6c 4f  | String.IsNullO
03e0: 72 45 6d 70 74 79 28 73 63 72 69 70 74 29 29 0a  rEmpty(script)).
03f0: 20 20 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20        {.        
0400: 69 6e 74 20 69 6e 63 72 65 61 73 65 20 3d 20 5f  int increase = _
0410: 73 70 6c 69 74 74 65 72 2e 54 6f 70 20 2d 20 5f  splitter.Top - _
0420: 73 68 6f 77 2e 54 6f 70 3b 0a 20 20 20 20 20 20  show.Top;.      
0430: 20 20 5f 73 68 6f 77 2e 56 69 73 69 62 6c 65 20    _show.Visible 
0440: 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20 20  = false;.       
0450: 20 5f 73 70 6c 69 74 74 65 72 2e 54 6f 70 20 3d   _splitter.Top =
0460: 20 5f 73 68 6f 77 2e 54 6f 70 3b 0a 20 20 20 20   _show.Top;.    
0470: 20 20 20 20 5f 73 70 6c 69 74 74 65 72 2e 48 65      _splitter.He
0480: 69 67 68 74 20 2b 3d 20 69 6e 63 72 65 61 73 65  ight += increase
0490: 3b 0a 20 20 20 20 20 20 20 20 5f 73 61 76 65 4f  ;.        _saveO
04a0: 72 69 67 2e 56 69 73 69 62 6c 65 20 3d 20 66 61  rig.Visible = fa
04b0: 6c 73 65 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20  lse;.      }..  
04c0: 20 20 20 20 69 66 20 28 53 74 72 69 6e 67 2e 49      if (String.I
04d0: 73 4e 75 6c 6c 4f 72 45 6d 70 74 79 28 73 63 72  sNullOrEmpty(scr
04e0: 69 70 74 29 20 3d 3d 20 66 61 6c 73 65 29 0a 20  ipt) == false). 
04f0: 20 20 20 20 20 20 20 5f 73 70 6c 69 74 74 65 72         _splitter
0500: 2e 50 61 6e 65 6c 31 43 6f 6c 6c 61 70 73 65 64  .Panel1Collapsed
0510: 20 3d 20 74 72 75 65 3b 0a 20 20 20 20 20 20 65   = true;.      e
0520: 6c 73 65 0a 20 20 20 20 20 20 20 20 5f 73 70 6c  lse.        _spl
0530: 69 74 74 65 72 2e 50 61 6e 65 6c 32 43 6f 6c 6c  itter.Panel2Coll
0540: 61 70 73 65 64 20 3d 20 74 72 75 65 3b 0a 20 20  apsed = true;.  
0550: 20 20 7d 0a 0a 20 20 20 20 70 72 69 76 61 74 65    }..    private
0560: 20 76 6f 69 64 20 6e 6f 42 75 74 74 6f 6e 5f 43   void noButton_C
0570: 6c 69 63 6b 28 6f 62 6a 65 63 74 20 73 65 6e 64  lick(object send
0580: 65 72 2c 20 45 76 65 6e 74 41 72 67 73 20 65 29  er, EventArgs e)
0590: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 44 69 61  .    {.      Dia
05a0: 6c 6f 67 52 65 73 75 6c 74 20 3d 20 44 69 61 6c  logResult = Dial
05b0: 6f 67 52 65 73 75 6c 74 2e 43 61 6e 63 65 6c 3b  ogResult.Cancel;
05c0: 0a 20 20 20 20 20 20 43 6c 6f 73 65 28 29 3b 0a  .      Close();.
05d0: 20 20 20 20 7d 0a 0a 20 20 20 20 70 72 69 76 61      }..    priva
05e0: 74 65 20 76 6f 69 64 20 79 65 73 42 75 74 74 6f  te void yesButto
05f0: 6e 5f 43 6c 69 63 6b 28 6f 62 6a 65 63 74 20 73  n_Click(object s
0600: 65 6e 64 65 72 2c 20 45 76 65 6e 74 41 72 67 73  ender, EventArgs
0610: 20 65 29 0a 20 20 20 20 7b 0a 20 20 20 20 20 20   e).    {.      
0620: 75 73 69 6e 67 20 28 53 61 76 65 46 69 6c 65 44  using (SaveFileD
0630: 69 61 6c 6f 67 20 73 61 76 65 20 3d 20 6e 65 77  ialog save = new
0640: 20 53 61 76 65 46 69 6c 65 44 69 61 6c 6f 67 28   SaveFileDialog(
0650: 29 29 0a 20 20 20 20 20 20 7b 0a 20 20 20 20 20  )).      {.     
0660: 20 20 20 73 61 76 65 2e 44 65 66 61 75 6c 74 45     save.DefaultE
0670: 78 74 20 3d 20 22 73 71 6c 22 3b 0a 20 20 20 20  xt = "sql";.    
0680: 20 20 20 20 73 61 76 65 2e 4f 76 65 72 77 72 69      save.Overwri
0690: 74 65 50 72 6f 6d 70 74 20 3d 20 74 72 75 65 3b  tePrompt = true;
06a0: 0a 20 20 20 20 20 20 20 20 73 61 76 65 2e 46 69  .        save.Fi
06b0: 6c 74 65 72 20 3d 20 22 53 51 4c 20 53 63 72 69  lter = "SQL Scri
06c0: 70 74 20 46 69 6c 65 73 20 28 2a 2e 73 71 6c 29  pt Files (*.sql)
06d0: 7c 2a 2e 73 71 6c 7c 41 6c 6c 20 46 69 6c 65 73  |*.sql|All Files
06e0: 20 28 2a 2e 2a 29 7c 2a 2e 2a 22 3b 0a 20 20 20   (*.*)|*.*";.   
06f0: 20 20 20 20 20 73 61 76 65 2e 46 69 6c 65 4e 61       save.FileNa
0700: 6d 65 20 3d 20 53 74 72 69 6e 67 2e 46 6f 72 6d  me = String.Form
0710: 61 74 28 43 75 6c 74 75 72 65 49 6e 66 6f 2e 49  at(CultureInfo.I
0720: 6e 76 61 72 69 61 6e 74 43 75 6c 74 75 72 65 2c  nvariantCulture,
0730: 20 22 7b 30 7d 2e 73 71 6c 22 2c 20 5f 74 61 62   "{0}.sql", _tab
0740: 6c 65 4e 61 6d 65 29 3b 0a 20 20 20 20 20 20 20  leName);.       
0750: 20 73 61 76 65 2e 54 69 74 6c 65 20 3d 20 22 53   save.Title = "S
0760: 61 76 65 20 53 51 4c 69 74 65 20 43 68 61 6e 67  ave SQLite Chang
0770: 65 20 53 63 72 69 70 74 22 3b 0a 0a 20 20 20 20  e Script";..    
0780: 20 20 20 20 44 69 61 6c 6f 67 52 65 73 75 6c 74      DialogResult
0790: 20 3d 20 73 61 76 65 2e 53 68 6f 77 44 69 61 6c   = save.ShowDial
07a0: 6f 67 28 74 68 69 73 29 3b 0a 0a 20 20 20 20 20  og(this);..     
07b0: 20 20 20 69 66 20 28 44 69 61 6c 6f 67 52 65 73     if (DialogRes
07c0: 75 6c 74 20 3d 3d 20 44 69 61 6c 6f 67 52 65 73  ult == DialogRes
07d0: 75 6c 74 2e 4f 4b 29 0a 20 20 20 20 20 20 20 20  ult.OK).        
07e0: 7b 0a 20 20 20 20 20 20 20 20 20 20 5f 64 65 66  {.          _def
07f0: 61 75 6c 74 53 61 76 65 20 3d 20 5f 73 61 76 65  aultSave = _save
0800: 4f 72 69 67 2e 43 68 65 63 6b 65 64 3b 0a 0a 20  Orig.Checked;.. 
0810: 20 20 20 20 20 20 20 20 20 75 73 69 6e 67 20 28           using (
0820: 53 79 73 74 65 6d 2e 49 4f 2e 53 74 72 65 61 6d  System.IO.Stream
0830: 57 72 69 74 65 72 20 77 72 69 74 65 72 20 3d 20  Writer writer = 
0840: 6e 65 77 20 53 79 73 74 65 6d 2e 49 4f 2e 53 74  new System.IO.St
0850: 72 65 61 6d 57 72 69 74 65 72 28 73 61 76 65 2e  reamWriter(save.
0860: 46 69 6c 65 4e 61 6d 65 2c 20 66 61 6c 73 65 2c  FileName, false,
0870: 20 45 6e 63 6f 64 69 6e 67 2e 55 54 46 38 29 29   Encoding.UTF8))
0880: 0a 20 20 20 20 20 20 20 20 20 20 7b 0a 20 20 20  .          {.   
0890: 20 20 20 20 20 20 20 20 20 69 66 20 28 28 5f 73           if ((_s
08a0: 68 6f 77 2e 56 69 73 69 62 6c 65 20 3d 3d 20 74  how.Visible == t
08b0: 72 75 65 20 26 26 20 5f 73 61 76 65 4f 72 69 67  rue && _saveOrig
08c0: 2e 43 68 65 63 6b 65 64 20 3d 3d 20 74 72 75 65  .Checked == true
08d0: 29 20 7c 7c 20 28 5f 73 68 6f 77 2e 56 69 73 69  ) || (_show.Visi
08e0: 62 6c 65 20 3d 3d 20 66 61 6c 73 65 20 26 26 20  ble == false && 
08f0: 5f 73 70 6c 69 74 74 65 72 2e 50 61 6e 65 6c 32  _splitter.Panel2
0900: 43 6f 6c 6c 61 70 73 65 64 20 3d 3d 20 74 72 75  Collapsed == tru
0910: 65 29 29 0a 20 20 20 20 20 20 20 20 20 20 20 20  e)).            
0920: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  {.              
0930: 69 66 20 28 5f 73 68 6f 77 2e 56 69 73 69 62 6c  if (_show.Visibl
0940: 65 20 3d 3d 20 74 72 75 65 29 20 77 72 69 74 65  e == true) write
0950: 72 2e 57 72 69 74 65 4c 69 6e 65 28 22 2f 2a 22  r.WriteLine("/*"
0960: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  );.             
0970: 20 77 72 69 74 65 72 2e 57 72 69 74 65 4c 69 6e   writer.WriteLin
0980: 65 28 5f 6f 72 69 67 69 6e 61 6c 2e 54 65 78 74  e(_original.Text
0990: 2e 52 65 70 6c 61 63 65 28 22 5c 72 22 2c 20 22  .Replace("\r", "
09a0: 22 29 2e 54 72 69 6d 45 6e 64 28 27 5c 6e 27 29  ").TrimEnd('\n')
09b0: 2e 52 65 70 6c 61 63 65 28 22 5c 6e 22 2c 20 22  .Replace("\n", "
09c0: 5c 72 5c 6e 22 29 29 3b 0a 20 20 20 20 20 20 20  \r\n"));.       
09d0: 20 20 20 20 20 20 20 69 66 20 28 5f 73 68 6f 77         if (_show
09e0: 2e 56 69 73 69 62 6c 65 20 3d 3d 20 74 72 75 65  .Visible == true
09f0: 29 20 77 72 69 74 65 72 2e 57 72 69 74 65 4c 69  ) writer.WriteLi
0a00: 6e 65 28 22 2a 2f 22 29 3b 0a 20 20 20 20 20 20  ne("*/");.      
0a10: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
0a20: 20 20 20 20 69 66 20 28 5f 73 68 6f 77 2e 56 69      if (_show.Vi
0a30: 73 69 62 6c 65 20 3d 3d 20 74 72 75 65 20 7c 7c  sible == true ||
0a40: 20 5f 73 70 6c 69 74 74 65 72 2e 50 61 6e 65 6c   _splitter.Panel
0a50: 32 43 6f 6c 6c 61 70 73 65 64 20 3d 3d 20 66 61  2Collapsed == fa
0a60: 6c 73 65 29 20 0a 20 20 20 20 20 20 20 20 20 20  lse) .          
0a70: 20 20 20 20 77 72 69 74 65 72 2e 57 72 69 74 65      writer.Write
0a80: 4c 69 6e 65 28 5f 73 63 72 69 70 74 2e 54 65 78  Line(_script.Tex
0a90: 74 2e 52 65 70 6c 61 63 65 28 22 5c 72 22 2c 20  t.Replace("\r", 
0aa0: 22 22 29 2e 54 72 69 6d 45 6e 64 28 27 5c 6e 27  "").TrimEnd('\n'
0ab0: 29 2e 52 65 70 6c 61 63 65 28 22 5c 6e 22 2c 20  ).Replace("\n", 
0ac0: 22 5c 72 5c 6e 22 29 29 3b 0a 20 20 20 20 20 20  "\r\n"));.      
0ad0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a      }.        }.
0ae0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 43 6c        }.      Cl
0af0: 6f 73 65 28 29 3b 0a 20 20 20 20 7d 0a 0a 20 20  ose();.    }..  
0b00: 20 20 70 72 69 76 61 74 65 20 76 6f 69 64 20 5f    private void _
0b10: 73 68 6f 77 5f 4c 69 6e 6b 43 6c 69 63 6b 65 64  show_LinkClicked
0b20: 28 6f 62 6a 65 63 74 20 73 65 6e 64 65 72 2c 20  (object sender, 
0b30: 4c 69 6e 6b 4c 61 62 65 6c 4c 69 6e 6b 43 6c 69  LinkLabelLinkCli
0b40: 63 6b 65 64 45 76 65 6e 74 41 72 67 73 20 65 29  ckedEventArgs e)
0b50: 0a 20 20 20 20 7b 0a 20 20 20 20 20 20 73 74 72  .    {.      str
0b60: 69 6e 67 20 6f 6c 64 20 3d 20 5f 73 68 6f 77 2e  ing old = _show.
0b70: 54 65 78 74 3b 0a 20 20 20 20 20 20 5f 73 68 6f  Text;.      _sho
0b80: 77 2e 54 65 78 74 20 3d 20 5f 73 68 6f 77 2e 54  w.Text = _show.T
0b90: 61 67 2e 54 6f 53 74 72 69 6e 67 28 29 3b 0a 20  ag.ToString();. 
0ba0: 20 20 20 20 20 5f 73 68 6f 77 2e 54 61 67 20 3d       _show.Tag =
0bb0: 20 6f 6c 64 3b 0a 0a 20 20 20 20 20 20 69 66 20   old;..      if 
0bc0: 28 5f 73 70 6c 69 74 74 65 72 2e 49 73 53 70 6c  (_splitter.IsSpl
0bd0: 69 74 74 65 72 46 69 78 65 64 29 0a 20 20 20 20  itterFixed).    
0be0: 20 20 7b 0a 20 20 20 20 20 20 20 20 5f 73 70 6c    {.        _spl
0bf0: 69 74 74 65 72 2e 49 73 53 70 6c 69 74 74 65 72  itter.IsSplitter
0c00: 46 69 78 65 64 20 3d 20 66 61 6c 73 65 3b 0a 20  Fixed = false;. 
0c10: 20 20 20 20 20 20 20 5f 73 70 6c 69 74 74 65 72         _splitter
0c20: 2e 50 61 6e 65 6c 31 43 6f 6c 6c 61 70 73 65 64  .Panel1Collapsed
0c30: 20 3d 20 66 61 6c 73 65 3b 0a 20 20 20 20 20 20   = false;.      
0c40: 7d 0a 20 20 20 20 20 20 65 6c 73 65 0a 20 20 20  }.      else.   
0c50: 20 20 20 7b 0a 20 20 20 20 20 20 20 20 5f 73 70     {.        _sp
0c60: 6c 69 74 74 65 72 2e 49 73 53 70 6c 69 74 74 65  litter.IsSplitte
0c70: 72 46 69 78 65 64 20 3d 20 74 72 75 65 3b 0a 20  rFixed = true;. 
0c80: 20 20 20 20 20 20 20 5f 73 70 6c 69 74 74 65 72         _splitter
0c90: 2e 50 61 6e 65 6c 31 43 6f 6c 6c 61 70 73 65 64  .Panel1Collapsed
0ca0: 20 3d 20 74 72 75 65 3b 0a 20 20 20 20 20 20 7d   = true;.      }
0cb0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a           .    }.  }.}.