File: M000023.html

package info (click to toggle)
wfo 0.1-2
  • links: PTS
  • area: main
  • in suites: lenny, squeeze, wheezy
  • size: 1,508 kB
  • ctags: 485
  • sloc: ruby: 1,996; makefile: 66
file content (45 lines) | stat: -rw-r--r-- 4,161 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
<?xml version="1.0" encoding="iso-8859-1"?>
<!DOCTYPE html 
     PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html>
<head>
  <title>merge (WFO)</title>
  <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
  <link rel="stylesheet" href="../.././rdoc-style.css" type="text/css" media="screen" />
</head>
<body class="standalone-code">
  <pre><span class="ruby-comment cmt"># File wfo/main.rb, line 219</span>
  <span class="ruby-keyword kw">def</span> <span class="ruby-identifier">merge</span>(<span class="ruby-identifier">local_text</span>, <span class="ruby-identifier">original_text</span>, <span class="ruby-identifier">remote_text</span>)
    <span class="ruby-identifier">original_file</span> = <span class="ruby-identifier">tempfile</span>(<span class="ruby-value str">&quot;wfo.original&quot;</span>, <span class="ruby-identifier">original_text</span>)
    <span class="ruby-identifier">local_file</span> = <span class="ruby-identifier">tempfile</span>(<span class="ruby-value str">&quot;wfo.local&quot;</span>, <span class="ruby-identifier">local_text</span>)
    <span class="ruby-identifier">remote_file</span> = <span class="ruby-identifier">tempfile</span>(<span class="ruby-value str">&quot;wfo.remote&quot;</span>, <span class="ruby-identifier">remote_text</span>)
    <span class="ruby-identifier">command</span> = [<span class="ruby-value str">'diff3'</span>, <span class="ruby-value str">'-mE'</span>,
      <span class="ruby-value str">'-L'</span>, <span class="ruby-value str">'edited by you'</span>,
      <span class="ruby-value str">'-L'</span>, <span class="ruby-value str">'before edited'</span>,
      <span class="ruby-value str">'-L'</span>, <span class="ruby-value str">'edited by others'</span>,
      <span class="ruby-identifier">local_file</span>.<span class="ruby-identifier">path</span>,
      <span class="ruby-identifier">original_file</span>.<span class="ruby-identifier">path</span>,
      <span class="ruby-identifier">remote_file</span>.<span class="ruby-identifier">path</span>]
    <span class="ruby-identifier">merged</span> = <span class="ruby-constant">IO</span>.<span class="ruby-identifier">popen</span>(<span class="ruby-constant">Escape</span>.<span class="ruby-identifier">shell_command</span>(<span class="ruby-identifier">command</span>), <span class="ruby-value str">'r'</span>) {<span class="ruby-operator">|</span><span class="ruby-identifier">f</span><span class="ruby-operator">|</span>
      <span class="ruby-identifier">f</span>.<span class="ruby-identifier">read</span>
    }
    <span class="ruby-identifier">status</span> = <span class="ruby-identifier">$?</span>
    <span class="ruby-keyword kw">unless</span> <span class="ruby-identifier">status</span>.<span class="ruby-identifier">exited?</span>
      <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;[bug] unexpected diff3 failure: #{status.inspect}&quot;</span>
    <span class="ruby-keyword kw">end</span>
    <span class="ruby-keyword kw">case</span> <span class="ruby-identifier">status</span>.<span class="ruby-identifier">exitstatus</span>
    <span class="ruby-keyword kw">when</span> <span class="ruby-value">0</span>
      <span class="ruby-identifier">conflict</span> = <span class="ruby-keyword kw">false</span>
    <span class="ruby-keyword kw">when</span> <span class="ruby-value">1</span>
      <span class="ruby-identifier">conflict</span> = <span class="ruby-keyword kw">true</span>
    <span class="ruby-keyword kw">when</span> <span class="ruby-value">2</span>
      <span class="ruby-identifier">raise</span> <span class="ruby-value str">&quot;diff3 failed&quot;</span>
    <span class="ruby-keyword kw">else</span>
      <span class="ruby-identifier">raise</span> <span class="ruby-node">&quot;[bug] unexpected diff3 status: #{status.inspect}&quot;</span>
    <span class="ruby-keyword kw">end</span>
    <span class="ruby-keyword kw">return</span> <span class="ruby-identifier">merged</span>, <span class="ruby-identifier">conflict</span>
  <span class="ruby-keyword kw">end</span></pre>
</body>
</html>