Natural

           

          Clearcase靜態視圖下post-review,view diff時異常問題解析

          環境:
          Windows XP
          RBTools 0.4.2
          ReviewBoard 1.7.1

              之前搭建了reviewboard,一開始是在動態視圖下測試的,一切順利。
              當切換到靜態視圖下,用post-review提交所有checkedout文件時,命令顯示似乎也一切正常,最后也輸出了提交成功的提示信息“Review request #10 posted”。
              但到reviewboard上打開該request,進行view diff時,出現如下異常:

          Traceback (most recent call last):
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\views.py", line 383in view_diff_fragment
              file 
          = get_requested_diff_file()
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\views.py", line 309in get_requested_diff_file
              populate_diff_chunks(files, highlighting)
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\diffutils.py", line 1197in populate_diff_chunks
              large_data
          =True)
            File 
          "F:\CodeReview\Python27\lib\site-packages\djblets-0.7.8-py2.7.egg\djblets\util\misc.py", line 156in cache_memoize
              data 
          = lookup_callable()
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\diffutils.py", line 1196in <lambda>
              enable_syntax_highlighting)),
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\diffutils.py", line 599in get_chunks
              new 
          = get_patched_file(old, filediff)
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\diffutils.py", line 392in get_patched_file
              
          return patch(diff, buffer, filediff.dest_file)
            File 
          "F:\CodeReview\Python27\lib\site-packages\reviewboard-1.7.2-py2.7.egg\reviewboard\diffviewer\diffutils.py", line 251in patch
              (filename, tempdir, patch_output))
          Exception: The patch to 
          '{clearcase file path}' didn't apply cleanly. The temporary files have been left in 'e:\temp\reviewboard.yoegta' for debugging purposes.
          `patch` returned: patching file e:\temp\reviewboard.yoegta\tmpmvzzpi
          Patch attempted to create file e:\temp\reviewboard.yoegta\tmpmvzzpi, which already exists.
          Hunk 
          #1 FAILED at 1.
          1 out of 1 hunk FAILED -- saving rejects to file e:\temp\reviewboard.yoegta\tmpmvzzpi-new.rej

              把該文件在動態視圖下也post-review一下,比較了一下,發現靜態視圖下生成的diff文件不對。
              直接用diff、cat命令測試,卻是因為在CC靜態視圖下,帶版本信息的文件是無法訪問的。這樣的話只得先用cleartool get命令把文件拷貝一份臨時文件,再用diff去比較臨時文件。
              在eclipse裝上python插件,post-review調試,逐步跟進,找到了diff代碼的位置:
              def diff_files(self, old_file, new_file):
              "C:\Python27\Lib\site-packages\RBTools-0.4.2-py2.7\rbtools\clients\clearcase.py" 262行

              代碼改動如下:
              def diff_files(self, old_file, new_file):
                  
          # in snapshot view, diff command can't access clearcase file which with version path
                  # create temporary file backup instead of clearcase file according by 'cleartool get' command
                  if self.viewtype == "snapshot":
                      temp_old_file 
          = make_tempfile()
                      temp_new_file 
          = make_tempfile()
                      
          if cpath.exists(temp_old_file):
                          os.unlink(temp_old_file)
                      
          if cpath.exists(temp_new_file):
                          os.unlink(temp_new_file)
                          
                      execute([
          "cleartool""get" , "-to", temp_old_file, old_file])
                      execute([
          "cleartool""get" , "-to", temp_new_file, new_file])
                      diff_cmd 
          = ["diff""-uN", temp_old_file, temp_new_file]
                  
          else:
                      diff_cmd 
          = ["diff""-uN", old_file, new_file]
                  
          """Return unified diff for file.

                  Most effective and reliable way is use gnu diff.
                  
          """
                  dl 
          = execute(diff_cmd, extra_ignore_errors=(12),
                               translate_newlines
          =False)
                  
                  
          # replace temporary file in snapshot view
                  if self.viewtype == "snapshot":
                      dl 
          = dl.replace(temp_old_file, old_file)
                      dl 
          = dl.replace(temp_new_file, new_file)

              改動后重新編譯一下,塞回到RBTools相應位置。
              于是,世界又一片清凈了。。。。。

          posted on 2013-02-01 11:21 此號已被刪 閱讀(2103) 評論(2)  編輯  收藏 所屬分類: ReviewBoard

          評論

          # re: Clearcase靜態視圖下post-review,view diff時異常問題解析 2013-02-02 06:16 tcmaster

          這年頭居然還有人在用clearcase!同情一個,鄙視一個。  回復  更多評論   

          # re: Clearcase靜態視圖下post-review,view diff時異常問題解析 2013-02-03 13:54 此號已被刪

          @網絡記事本
          一款強大的SCM工具,IBM出品的商業軟件。詳情自行谷歌之,順便無視1樓。  回復  更多評論   

          導航

          統計

          常用鏈接

          留言簿(8)

          隨筆分類(83)

          隨筆檔案(78)

          文章檔案(2)

          相冊

          收藏夾(7)

          最新隨筆

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 盐津县| 苍梧县| 三穗县| 高邑县| 石阡县| 托克托县| 洛南县| 同心县| 收藏| 南汇区| 襄垣县| 贡山| 庄浪县| 墨玉县| 张家界市| 马鞍山市| 襄汾县| 深水埗区| 正宁县| 扶沟县| 龙胜| 临邑县| 东乌| 滁州市| 古浪县| 乐清市| 桃园县| 山阴县| 漯河市| 哈巴河县| 汾阳市| 常山县| 义马市| 会泽县| 肃宁县| 克什克腾旗| 休宁县| 新干县| 含山县| 抚松县| 游戏|