<!DOCTYPE html>
<html lang='en'>
<head>
<title>Add pixel conversion correctness test - tigervnc.git - High performance, multi-platform VNC client and server: https://github.com/TigerVNC/tigervnc</title>
<meta name='generator' content='cgit v1.2.3'/>
<meta name='robots' content='index, nofollow'/>
<link rel='stylesheet' type='text/css' href='/cgit.css'/>
<link rel='shortcut icon' href='/favicon.ico'/>
<link rel='alternate' title='Atom feed' href='https://source.dussan.org/tigervnc.git/atom/common/rfb/SecurityClient.cxx?h=master' type='application/atom+xml'/>
</head>
<body>
<div id='cgit'><table id='header'>
<tr>
<td class='logo' rowspan='2'><a href='/'><img src='/cgit.png' alt='cgit logo'/></a></td>
<td class='main'><a href='/'>index</a> : <a href='/tigervnc.git/'>tigervnc.git</a></td><td class='form'><form method='get'>
<input type='hidden' name='id' value='41deb88359d96b782f8da7126c8060bd285686e6'/><select name='h' onchange='this.form.submit();'>
<option value='1.0-branch'>1.0-branch</option>
<option value='1.1-branch'>1.1-branch</option>
<option value='1.10-branch'>1.10-branch</option>
<option value='1.11-branch'>1.11-branch</option>
<option value='1.12-branch'>1.12-branch</option>
<option value='1.13-branch'>1.13-branch</option>
<option value='1.14-branch'>1.14-branch</option>
<option value='1.15-branch'>1.15-branch</option>
<option value='1.2-branch'>1.2-branch</option>
<option value='1.3-branch'>1.3-branch</option>
<option value='1.4-branch'>1.4-branch</option>
<option value='1.5-branch'>1.5-branch</option>
<option value='1.6-branch'>1.6-branch</option>
<option value='1.7-branch'>1.7-branch</option>
<option value='1.8-branch'>1.8-branch</option>
<option value='1.9-branch'>1.9-branch</option>
<option value='master' selected='selected'>master</option>
</select> <input type='submit' value='switch'/></form></td></tr>
<tr><td class='sub'>High performance, multi-platform VNC client and server: https://github.com/TigerVNC/tigervnc</td><td class='sub right'>www-data</td></tr></table>
<table class='tabs'><tr><td>
<a href='/tigervnc.git/about/'>about</a><a href='/tigervnc.git/'>summary</a><a href='/tigervnc.git/refs/?id=41deb88359d96b782f8da7126c8060bd285686e6'>refs</a><a href='/tigervnc.git/log/common/rfb/SecurityClient.cxx'>log</a><a href='/tigervnc.git/tree/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>tree</a><a class='active' href='/tigervnc.git/commit/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>commit</a><a href='/tigervnc.git/diff/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>diff</a><a href='/tigervnc.git/stats/common/rfb/SecurityClient.cxx'>stats</a></td><td class='form'><form class='right' method='get' action='/tigervnc.git/log/common/rfb/SecurityClient.cxx'>
<input type='hidden' name='id' value='41deb88359d96b782f8da7126c8060bd285686e6'/><select name='qt'>
<option value='grep'>log msg</option>
<option value='author'>author</option>
<option value='committer'>committer</option>
<option value='range'>range</option>
</select>
<input class='txt' type='search' size='10' name='q' value=''/>
<input type='submit' value='search'/>
</form>
</td></tr></table>
<div class='path'>path: <a href='/tigervnc.git/commit/?id=41deb88359d96b782f8da7126c8060bd285686e6'>root</a>/<a href='/tigervnc.git/commit/common?id=41deb88359d96b782f8da7126c8060bd285686e6'>common</a>/<a href='/tigervnc.git/commit/common/rfb?id=41deb88359d96b782f8da7126c8060bd285686e6'>rfb</a>/<a href='/tigervnc.git/commit/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>SecurityClient.cxx</a></div><div class='content'><div class='cgit-panel'><b>diff options</b><form method='get'><input type='hidden' name='id' value='41deb88359d96b782f8da7126c8060bd285686e6'/><table><tr><td colspan='2'/></tr><tr><td class='label'>context:</td><td class='ctrl'><select name='context' onchange='this.form.submit();'><option value='1'>1</option><option value='2'>2</option><option value='3' selected='selected'>3</option><option value='4'>4</option><option value='5'>5</option><option value='6'>6</option><option value='7'>7</option><option value='8'>8</option><option value='9'>9</option><option value='10'>10</option><option value='15'>15</option><option value='20'>20</option><option value='25'>25</option><option value='30'>30</option><option value='35'>35</option><option value='40'>40</option></select></td></tr><tr><td class='label'>space:</td><td class='ctrl'><select name='ignorews' onchange='this.form.submit();'><option value='0' selected='selected'>include</option><option value='1'>ignore</option></select></td></tr><tr><td class='label'>mode:</td><td class='ctrl'><select name='dt' onchange='this.form.submit();'><option value='0' selected='selected'>unified</option><option value='1'>ssdiff</option><option value='2'>stat only</option></select></td></tr><tr><td/><td class='ctrl'><noscript><input type='submit' value='reload'/></noscript></td></tr></table></form></div><table summary='commit info' class='commit-info'>
<tr><th>author</th><td>Pierre Ossman &lt;ossman@cendio.se&gt;</td><td class='right'>2014-09-25 09:58:55 +0200</td></tr>
<tr><th>committer</th><td>Pierre Ossman &lt;ossman@cendio.se&gt;</td><td class='right'>2014-09-25 15:03:39 +0200</td></tr>
<tr><th>commit</th><td colspan='2' class='oid'><a href='/tigervnc.git/commit/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>41deb88359d96b782f8da7126c8060bd285686e6</a> (<a href='/tigervnc.git/patch/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>patch</a>)</td></tr>
<tr><th>tree</th><td colspan='2' class='oid'><a href='/tigervnc.git/tree/?id=41deb88359d96b782f8da7126c8060bd285686e6'>fada4afdb8e1bbcb0f303068f15bb90f5913f006</a> /<a href='/tigervnc.git/tree/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6'>common/rfb/SecurityClient.cxx</a></td></tr>
<tr><th>parent</th><td colspan='2' class='oid'><a href='/tigervnc.git/commit/common/rfb/SecurityClient.cxx?id=a4148f867fac7c70fc7d2a02cb0f9b20ce5d9394'>a4148f867fac7c70fc7d2a02cb0f9b20ce5d9394</a> (<a href='/tigervnc.git/diff/common/rfb/SecurityClient.cxx?id=41deb88359d96b782f8da7126c8060bd285686e6&amp;id2=a4148f867fac7c70fc7d2a02cb0f9b20ce5d9394'>diff</a>)</td></tr><tr><th>download</th><td colspan='2' class='oid'><a href='/tigervnc.git/snapshot/tigervnc-41deb88359d96b782f8da7126c8060bd285686e6.tar.gz'>tigervnc-41deb88359d96b782f8da7126c8060bd285686e6.tar.gz</a><br/><a href='/tigervnc.git/snapshot/tigervnc-41deb88359d96b782f8da7126c8060bd285686e6.zip'>tigervnc-41deb88359d96b782f8da7126c8060bd285686e6.zip</a><br/></td></tr></table>
<div class='commit-subject'>Add pixel conversion correctness test</div><div class='commit-msg'></div><div class='diffstat-header'><a href='/tigervnc.git/diff/?id=41deb88359d96b782f8da7126c8060bd285686e6'>Diffstat</a> (limited to 'common/rfb/SecurityClient.cxx')</div><table summary='diffstat' class='diffstat'></table><div class='diffstat-summary'>0 files changed, 0 insertions, 0 deletions</div><table summary='diff' class='diff'><tr><td></td></tr></table></div> <!-- class=content -->
<div class='footer'>generated by <a href='https://git.zx2c4.com/cgit/about/'>cgit v1.2.3</a> (<a href='https://git-scm.com/'>git 2.39.1</a>) at 2025-08-09 23:17:19 +0000</div>
</div> <!-- id=cgit -->
</body>
</html>
 padding-right: 5px; }
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
.highlight .hll { background-color: #ffffcc }
.highlight .c { color: #888888 } /* Comment */
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
.highlight .k { color: #008800; font-weight: bold } /* Keyword */
.highlight .ch { color: #888888 } /* Comment.Hashbang */
.highlight .cm { color: #888888 } /* Comment.Multiline */
.highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */
.highlight .cpf { color: #888888 } /* Comment.PreprocFile */
.highlight .c1 { color: #888888 } /* Comment.Single */
.highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gr { color: #aa0000 } /* Generic.Error */
.highlight .gh { color: #333333 } /* Generic.Heading */
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
.highlight .go { color: #888888 } /* Generic.Output */
.highlight .gp { color: #555555 } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #666666 } /* Generic.Subheading */
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
.highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */
.highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */
.highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */
.highlight .kp { color: #008800 } /* Keyword.Pseudo */
.highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */
.highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */
.highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */
.highlight .na { color: #336699 } /* Name.Attribute */
.highlight .nb { color: #003388 } /* Name.Builtin */
.highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */
.highlight .no { color: #003366; font-weight: bold } /* Name.Constant */
.highlight .nd { color: #555555 } /* Name.Decorator */
.highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */
.highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */
.highlight .nl { color: #336699; font-style: italic } /* Name.Label */
.highlight .nn { color: #bb0066; font-weight: bold } /* Name.Namespace */
.highlight .py { color: #336699; font-weight: bold } /* Name.Property */
.highlight .nt { color: #bb0066; font-weight: bold } /* Name.Tag */
.highlight .nv { color: #336699 } /* Name.Variable */
.highlight .ow { color: #008800 } /* Operator.Word */
.highlight .w { color: #bbbbbb } /* Text.Whitespace */
.highlight .mb { color: #0000DD; font-weight: bold } /* Literal.Number.Bin */
.highlight .mf { color: #0000DD; font-weight: bold } /* Literal.Number.Float */
.highlight .mh { color: #0000DD; font-weight: bold } /* Literal.Number.Hex */
.highlight .mi { color: #0000DD; font-weight: bold } /* Literal.Number.Integer */
.highlight .mo { color: #0000DD; font-weight: bold } /* Literal.Number.Oct */
.highlight .sa { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Affix */
.highlight .sb { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Backtick */
.highlight .sc { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Char */
.highlight .dl { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Delimiter */
.highlight .sd { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Doc */
.highlight .s2 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Double */
.highlight .se { color: #0044dd; background-color: #fff0f0 } /* Literal.String.Escape */
.highlight .sh { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Heredoc */
.highlight .si { color: #3333bb; background-color: #fff0f0 } /* Literal.String.Interpol */
.highlight .sx { color: #22bb22; background-color: #f0fff0 } /* Literal.String.Other */
.highlight .sr { color: #008800; background-color: #fff0ff } /* Literal.String.Regex */
.highlight .s1 { color: #dd2200; background-color: #fff0f0 } /* Literal.String.Single */
.highlight .ss { color: #aa6600; background-color: #fff0f0 } /* Literal.String.Symbol */
.highlight .bp { color: #003388 } /* Name.Builtin.Pseudo */
.highlight .fm { color: #0066bb; font-weight: bold } /* Name.Function.Magic */
.highlight .vc { color: #336699 } /* Name.Variable.Class */
.highlight .vg { color: #dd7700 } /* Name.Variable.Global */
.highlight .vi { color: #3333bb } /* Name.Variable.Instance */
.highlight .vm { color: #336699 } /* Name.Variable.Magic */
.highlight .il { color: #0000DD; font-weight: bold } /* Literal.Number.Integer.Long */</style><div class="highlight"><pre><span></span><span class="cm">/*</span>
<span class="cm"> * Copyright 2011 James Moger.</span>
<span class="cm"> *</span>
<span class="cm"> * Licensed under the Apache License, Version 2.0 (the &quot;License&quot;);</span>
<span class="cm"> * you may not use this file except in compliance with the License.</span>
<span class="cm"> * You may obtain a copy of the License at</span>
<span class="cm"> *</span>
<span class="cm"> *     http://www.apache.org/licenses/LICENSE-2.0</span>
<span class="cm"> *</span>
<span class="cm"> * Unless required by applicable law or agreed to in writing, software</span>
<span class="cm"> * distributed under the License is distributed on an &quot;AS IS&quot; BASIS,</span>
<span class="cm"> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span>
<span class="cm"> * See the License for the specific language governing permissions and</span>
<span class="cm"> * limitations under the License.</span>
<span class="cm"> */</span>

<span class="kn">package</span><span class="w"> </span><span class="nn">com.iciql</span><span class="p">;</span>

<span class="kn">import</span><span class="w"> </span><span class="nn">com.iciql.TableDefinition.FieldDefinition</span><span class="p">;</span>
<span class="kn">import</span><span class="w"> </span><span class="nn">com.iciql.util.StatementBuilder</span><span class="p">;</span>

<span class="cm">/**</span>
<span class="cm"> * MySQL database dialect.</span>
<span class="cm"> */</span>
<span class="kd">public</span><span class="w"> </span><span class="kd">class</span> <span class="nc">SQLDialectMySQL</span><span class="w"> </span><span class="kd">extends</span><span class="w"> </span><span class="n">SQLDialectDefault</span><span class="w"> </span><span class="p">{</span>

<span class="w">	</span><span class="nd">@Override</span>
<span class="w">	</span><span class="kd">public</span><span class="w"> </span><span class="n">String</span><span class="w"> </span><span class="nf">convertSqlType</span><span class="p">(</span><span class="n">String</span><span class="w"> </span><span class="n">sqlType</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">		</span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="n">sqlType</span><span class="p">.</span><span class="na">equals</span><span class="p">(</span><span class="s">&quot;CLOB&quot;</span><span class="p">))</span><span class="w"> </span><span class="p">{</span>
<span class="w">			</span><span class="k">return</span><span class="w"> </span><span class="s">&quot;TEXT&quot;</span><span class="p">;</span>
<span class="w">		</span><span class="p">}</span>
<span class="w">		</span><span class="k">return</span><span class="w"> </span><span class="n">sqlType</span><span class="p">;</span>
<span class="w">	</span><span class="p">}</span>

<span class="w">	</span><span class="nd">@Override</span>
<span class="w">	</span><span class="kd">protected</span><span class="w"> </span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span><span class="w"> </span><span class="n">String</span><span class="w"> </span><span class="nf">prepareCreateTable</span><span class="p">(</span><span class="n">TableDefinition</span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span><span class="w"> </span><span class="n">def</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">		</span><span class="k">return</span><span class="w"> </span><span class="s">&quot;CREATE TABLE IF NOT EXISTS&quot;</span><span class="p">;</span>
<span class="w">	</span><span class="p">}</span>
<span class="w">	</span>
<span class="w">	</span><span class="nd">@Override</span>
<span class="w">	</span><span class="kd">public</span><span class="w"> </span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="nf">prepareDropView</span><span class="p">(</span><span class="n">SQLStatement</span><span class="w"> </span><span class="n">stat</span><span class="p">,</span><span class="w"> </span><span class="n">TableDefinition</span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span><span class="w"> </span><span class="n">def</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">		</span><span class="n">StatementBuilder</span><span class="w"> </span><span class="n">buff</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="k">new</span><span class="w"> </span><span class="n">StatementBuilder</span><span class="p">(</span><span class="s">&quot;DROP VIEW IF EXISTS &quot;</span>
<span class="w">				</span><span class="o">+</span><span class="w"> </span><span class="n">prepareTableName</span><span class="p">(</span><span class="n">def</span><span class="p">.</span><span class="na">schemaName</span><span class="p">,</span><span class="w"> </span><span class="n">def</span><span class="p">.</span><span class="na">tableName</span><span class="p">));</span>
<span class="w">		</span><span class="n">stat</span><span class="p">.</span><span class="na">setSQL</span><span class="p">(</span><span class="n">buff</span><span class="p">.</span><span class="na">toString</span><span class="p">());</span>
<span class="w">		</span><span class="k">return</span><span class="p">;</span>
<span class="w">	</span><span class="p">}</span>
<span class="w">	</span>
<span class="w">	</span><span class="nd">@Override</span>
<span class="w">	</span><span class="kd">public</span><span class="w"> </span><span class="n">String</span><span class="w"> </span><span class="nf">prepareColumnName</span><span class="p">(</span><span class="n">String</span><span class="w"> </span><span class="n">name</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">		</span><span class="k">return</span><span class="w"> </span><span class="s">&quot;`&quot;</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="n">name</span><span class="w"> </span><span class="o">+</span><span class="w"> </span><span class="s">&quot;`&quot;</span><span class="p">;</span>
<span class="w">	</span><span class="p">}</span>

<span class="w">	</span><span class="nd">@Override</span>
<span class="w">	</span><span class="kd">protected</span><span class="w"> </span><span class="kt">boolean</span><span class="w"> </span><span class="nf">prepareColumnDefinition</span><span class="p">(</span><span class="n">StatementBuilder</span><span class="w"> </span><span class="n">buff</span><span class="p">,</span><span class="w"> </span><span class="n">String</span><span class="w"> </span><span class="n">dataType</span><span class="p">,</span><span class="w"> </span><span class="kt">boolean</span><span class="w"> </span><span class="n">isAutoIncrement</span><span class="p">,</span>
<span class="w">			</span><span class="kt">boolean</span><span class="w"> </span><span class="n">isPrimaryKey</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">		</span><span class="n">String</span><span class="w"> </span><span class="n">convertedType</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">convertSqlType</span><span class="p">(</span><span class="n">dataType</span><span class="p">);</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="n">convertedType</span><span class="p">);</span>
<span class="w">		</span><span class="k">if</span><span class="w"> </span><span class="p">(</span><span class="n">isIntegerType</span><span class="p">(</span><span class="n">dataType</span><span class="p">)</span><span class="w"> </span><span class="o">&amp;&amp;</span><span class="w"> </span><span class="n">isAutoIncrement</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="s">&quot; AUTO_INCREMENT&quot;</span><span class="p">);</span>
<span class="w">		</span><span class="p">}</span>
<span class="w">		</span><span class="k">return</span><span class="w"> </span><span class="kc">false</span><span class="p">;</span>
<span class="w">	</span><span class="p">}</span>

<span class="w">	</span><span class="nd">@Override</span>
<span class="w">	</span><span class="kd">public</span><span class="w"> </span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span><span class="w"> </span><span class="kt">void</span><span class="w"> </span><span class="nf">prepareMerge</span><span class="p">(</span><span class="n">SQLStatement</span><span class="w"> </span><span class="n">stat</span><span class="p">,</span><span class="w"> </span><span class="n">String</span><span class="w"> </span><span class="n">schemaName</span><span class="p">,</span><span class="w"> </span><span class="n">String</span><span class="w"> </span><span class="n">tableName</span><span class="p">,</span>
<span class="w">			</span><span class="n">TableDefinition</span><span class="o">&lt;</span><span class="n">T</span><span class="o">&gt;</span><span class="w"> </span><span class="n">def</span><span class="p">,</span><span class="w"> </span><span class="n">Object</span><span class="w"> </span><span class="n">obj</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">		</span><span class="n">StatementBuilder</span><span class="w"> </span><span class="n">buff</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="k">new</span><span class="w"> </span><span class="n">StatementBuilder</span><span class="p">(</span><span class="s">&quot;INSERT INTO &quot;</span><span class="p">);</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="n">prepareTableName</span><span class="p">(</span><span class="n">schemaName</span><span class="p">,</span><span class="w"> </span><span class="n">tableName</span><span class="p">)).</span><span class="na">append</span><span class="p">(</span><span class="s">&quot; (&quot;</span><span class="p">);</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">resetCount</span><span class="p">();</span>
<span class="w">		</span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="n">FieldDefinition</span><span class="w"> </span><span class="n">field</span><span class="w"> </span><span class="p">:</span><span class="w"> </span><span class="n">def</span><span class="p">.</span><span class="na">fields</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">appendExceptFirst</span><span class="p">(</span><span class="s">&quot;, &quot;</span><span class="p">);</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="n">field</span><span class="p">.</span><span class="na">columnName</span><span class="p">);</span>
<span class="w">		</span><span class="p">}</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">resetCount</span><span class="p">();</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="s">&quot;) VALUES (&quot;</span><span class="p">);</span>
<span class="w">		</span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="n">FieldDefinition</span><span class="w"> </span><span class="n">field</span><span class="w"> </span><span class="p">:</span><span class="w"> </span><span class="n">def</span><span class="p">.</span><span class="na">fields</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">appendExceptFirst</span><span class="p">(</span><span class="s">&quot;, &quot;</span><span class="p">);</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="sc">&#39;?&#39;</span><span class="p">);</span>
<span class="w">			</span><span class="n">Object</span><span class="w"> </span><span class="n">value</span><span class="w"> </span><span class="o">=</span><span class="w"> </span><span class="n">def</span><span class="p">.</span><span class="na">getValue</span><span class="p">(</span><span class="n">obj</span><span class="p">,</span><span class="w"> </span><span class="n">field</span><span class="p">);</span>
<span class="w">			</span><span class="n">stat</span><span class="p">.</span><span class="na">addParameter</span><span class="p">(</span><span class="n">value</span><span class="p">);</span>
<span class="w">		</span><span class="p">}</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="s">&quot;) ON DUPLICATE KEY UPDATE &quot;</span><span class="p">);</span>
<span class="w">		</span><span class="n">buff</span><span class="p">.</span><span class="na">resetCount</span><span class="p">();</span>
<span class="w">		</span><span class="k">for</span><span class="w"> </span><span class="p">(</span><span class="n">FieldDefinition</span><span class="w"> </span><span class="n">field</span><span class="w"> </span><span class="p">:</span><span class="w"> </span><span class="n">def</span><span class="p">.</span><span class="na">fields</span><span class="p">)</span><span class="w"> </span><span class="p">{</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">appendExceptFirst</span><span class="p">(</span><span class="s">&quot;, &quot;</span><span class="p">);</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="n">field</span><span class="p">.</span><span class="na">columnName</span><span class="p">);</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="s">&quot;=VALUES(&quot;</span><span class="p">);</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="n">field</span><span class="p">.</span><span class="na">columnName</span><span class="p">);</span>
<span class="w">			</span><span class="n">buff</span><span class="p">.</span><span class="na">append</span><span class="p">(</span><span class="sc">&#39;)&#39;</span><span class="p">);</span>
<span class="w">		</span><span class="p">}</span>
<span class="w">		</span><span class="n">stat</span><span class="p">.</span><span class="na">setSQL</span><span class="p">(</span><span class="n">buff</span><span class="p">.</span><span class="na">toString</span><span class="p">());</span>
<span class="w">	</span><span class="p">}</span>
<span class="p">}</span>
</pre></div>
</code></pre></td></tr></table>
</div> <!-- class=content -->
<div class='footer'>generated by <a href='https://git.zx2c4.com/cgit/about/'>cgit v1.2.3</a> (<a href='https://git-scm.com/'>git 2.39.1</a>) at 2025-08-09 23:17:19 +0000</div>
</div> <!-- id=cgit -->
</body>
</html>
