<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Natural

     

    Clearcase靜態(tài)視圖下post-review,view diff時異常問題解析

    環(huán)境:
    Windows XP
    RBTools 0.4.2
    ReviewBoard 1.7.1

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

    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

        把該文件在動態(tài)視圖下也post-review一下,比較了一下,發(fā)現(xiàn)靜態(tài)視圖下生成的diff文件不對。
        直接用diff、cat命令測試,卻是因為在CC靜態(tài)視圖下,帶版本信息的文件是無法訪問的。這樣的話只得先用cleartool get命令把文件拷貝一份臨時文件,再用diff去比較臨時文件。
        在eclipse裝上python插件,post-review調(diào)試,逐步跟進,找到了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相應(yīng)位置。
        于是,世界又一片清凈了。。。。。

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

    評論

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

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

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

    @網(wǎng)絡(luò)記事本
    一款強大的SCM工具,IBM出品的商業(yè)軟件。詳情自行谷歌之,順便無視1樓。  回復(fù)  更多評論   

    導(dǎo)航

    統(tǒng)計

    常用鏈接

    留言簿(8)

    隨筆分類(83)

    隨筆檔案(78)

    文章檔案(2)

    相冊

    收藏夾(7)

    最新隨筆

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 美女视频黄频a免费大全视频| 亚洲s色大片在线观看| 亚洲mv国产精品mv日本mv| 嫩草成人永久免费观看| 亚洲AV无码国产精品麻豆天美| 中文字幕av无码不卡免费| 国产亚洲精品岁国产微拍精品| 中文字幕视频免费在线观看| 狠狠亚洲婷婷综合色香五月排名| japanese色国产在线看免费| 亚洲综合国产精品第一页| 99视频免费在线观看| 亚洲成A∨人片在线观看不卡| 少妇人妻偷人精品免费视频| 久久亚洲AV成人无码软件| 国拍在线精品视频免费观看| 亚洲伦理中文字幕| 国产福利免费观看| 国产日韩久久免费影院| 亚洲久本草在线中文字幕| 国产免费的野战视频| 久久亚洲精品无码av| 在线精品亚洲一区二区三区| 久久国产色AV免费观看| 亚洲大尺度无码无码专线一区| 亚洲精品国产va在线观看蜜芽| 免费在线中文日本| 亚洲色成人WWW永久在线观看 | 深夜福利在线视频免费| 亚洲永久精品ww47| 曰批视频免费30分钟成人| WWW国产亚洲精品久久麻豆| 国产亚洲精品精华液| 97在线线免费观看视频在线观看| 337P日本欧洲亚洲大胆艺术图| 亚洲色偷拍另类无码专区| 69式互添免费视频| 色爽黄1000部免费软件下载| 亚洲黄色在线观看视频| 日韩精品电影一区亚洲| 中文字幕免费观看|