• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            isware

            ubuntu C/C++ 開發環境配置

            1. vimrc 基本配置


            1.1. 配置文件的位置

            在目錄 /etc/ 下面,有個名為vimrc 的文件,這是系統中公共的vim 配置文件,對所有用戶都有效。而在每個用戶的主目錄下,都可以自己建立私有的配置文件,命名為:“.vimrc” 。例如,/root 目錄下,通常已經存在一個.vimrc 文件。

            一個配置實例vimrc.7z

             

            1.2. 設置語法高亮顯示

            (1 )打開vimrc ,添加以下語句來使得語法高亮顯示:

            syntax on

            (2 )如果此時語法還是沒有高亮顯示,那么在/etc 目錄下的profile 文件中添加以下語句:

            export TERM=xterm-color

            (3 )設置Windows 風格的C/C++ 自動縮進(添加以下set 語句到vimrc 中)

            • 不討論制表符為8 還是為4 較好,這里設置(軟)制表符寬度為4 :

            set tabstop=4

            set softtabstop=4

            • 設置縮進的空格數為4

            set shiftwidth=4

            • 設置自動縮進:即每行的縮進值與上一行相等;使用 noautoindent 取消設置:

            set autoindent

            • 設置使用 C/C++ 語言的自動縮進方式

            set cindent

            • 設置C/C++ 語言的具體縮進方式(以我的windows 風格為例):

            set cinoptions={0,1s,t0,n-2,p2s,(03s,=.5s,>1s,=1s,:1s

            • 如果想在左側顯示文本的行號,可以用以下語句:

            set nu

            • 最后,如果沒有下列語句,就加上吧:

            if &term=="xterm"

                             set t_Co=8

                             set t_Sb=^[[4%dm

                             set t_Sf=^[[3%dm

            endif

             

            PS :

            自動縮進有兩個選項:

            代碼:

                   set autoindent

                   set cindent

             

            autoindent 就是自動縮進的意思,當你在輸入狀態用回車鍵插入一個新行,或者在 normal 狀態用 o 或者 O 插入一個新行時,autoindent 會自動地將當前行的縮進拷貝到新行,也就是" 自動對齊”,當然了,如果你在新行沒有輸入任何字符,那么這個縮進將自動刪除。

            cindent 就不同了,它會按照 C 語言的語法,自動地調整縮進的長度,比如,當你輸入了半條語句然后回車時,縮進會自動增加一個 TABSTOP 值,當你鍵入了一個右花括號時,會自動減少一個 TABSTOP 值。


            設置配色文件:

            colorscheme wombat

            wombat下載地址:

            http://www.vim.org/scripts/script.php?script_id=1778

             

            1.3. 括號自動補全

            在/etc/vim/vimrc 中添加如下代碼:

            :inoremap ( ()<ESC>i

            :inoremap ) <c-r>=ClosePair(')')<CR>

            :inoremap { {}<ESC>i

            :inoremap } <c-r>=ClosePair('}')<CR>

            :inoremap [ []<ESC>i

            :inoremap ] <c-r>=ClosePair(']')<CR>

            :inoremap ' ''<ESC>i

            :inoremap " ""<ESC>i

            function ClosePair(char)

            if getline('.')[col('.') - 1] == a:char

            return "/<Right>"

            else

            return a:char

            endif

            endf

            2. ctags 插件安裝

            你在讀程序時看了一個函數調用, 或者一個變量, 或者一個宏等等, 你想知道它們的定義在哪兒, 怎么辦呢?就用Ctag來實現這個功能:
            到http://ctags.sourceforge.net/下載,解壓后順序執行“./configure”、“make”、“make install”即可完成安裝。
                 
            然后去你的源碼目錄, 如果你的源碼是多層的目錄, 就去最上層的目錄, 在該目錄下運行命令ctags -R,現在以我的
            ~/download/anjuta-2.4.0/src/為例,

             $ cd ~/download/anjuta-2.4.0/
             $ ctags -R
            此時在~/download/anjuta-2.4.0/目錄下會生成一個 tags 文件, 現在用vim打開~/download/anjuta-2.4.0/src/main.c            
            再在vim中運行命令:
            :set tags=~/download/anjuta-2.4.0/tags
            該命令將tags文件加入到vim中來, 你也可以將這句話放到vimrc中去, 如果你經常在這個工程編程的話.
            此時,將鼠標移到一個變量上后,按下Ctrl+],便會自動跳轉到該變量的定義處,再按下Ctrl+T,便會返回到原來處。
            使用對象為變量, 結構, 宏, 等等, 都可以的, 趕快試試吧.....
            不過還有一個小瑕疵, 你修改程序后, 比如增加了函數定義, 刪除了變量定義, tags文件不能自動rebuild, 你必須手動再運行一下命令:
            $ ctags -R
            使tags文件更新一下, 不過讓人感到欣慰的是vim不用重新啟動, 正在編寫的程序也不用退出, 馬上就可以又正確使用<C-]>和<C-T>了.

             

             

            3. taglist插件安裝

                  unzip –d taglist taglist_42.zip

            cd taglist

            將taglist 目錄下的taglist.txt 文件拷貝到/usr/share/vim/vim72/doc 目錄下;

            將taglist 目錄下的taglist.vim 文件拷貝到/usr/share/vim/vim72/plugin 目錄下。

             

            vim /usr/share/vim/vim72/plugin/taglist.vim

            在if !exists(“loaded_taglist”) 的前一行,加上一句:

            let Tlist_Ctags_Cmd=”/usr/local/bin/ctags”

             

            至此,打開cpp 文件,輸入變量,再按ctrl + p 就可以有自動補全的功能了。

            還可以根據需要對taglist 進行定制,

            vim /usr/share/vim/vim72/plugin/taglist.vim

            let Tlist_Auto_Open=1

            啟動vim 自動打開Tlist

            let Tlist_File_Fold_Auto_Close=1

            當同時顯示多個文件中的tag 時,可使taglist 只顯示當前文件tag ,其它文件的tag 都被折疊起來。

             

             

            4. code_complete插件安裝

                   下載code_complete 插件,將其拷貝到/usr/share/vim/vim72/plugin/ 目錄下。

             

             

            5. tabbar.vim插件安裝

                  下載tabbar.vim 插件,將其拷貝到/usr/share/vim/vim72/plugin/ 目錄下。

            sp file.xxx

            注意: 在打開新文件時,光標一定要處在主編輯界面中,這樣才能保證標簽的位置的位置合適。

             

            關閉標簽頁使用:bd file.xxx

             


            6. a.vim插件安裝

            下載tabbar.vim 插件,將其拷貝到/usr/share/vim/vim72/plugin/ 目錄下。

            E.g. if you are editing foo.c and need to edit foo.h simply execute :A and you will be editting foo.h, to switch back to foo.c execute :A again.

             


            7. ShowFuncc.vim 插件安裝

                 下載ShowFuncc.vim 插件,將其拷貝到/usr/share/vim/vim72/plugin/ 目錄下。

            這個插件實現了按下 fd, 就可以提示當前光標所在函數的定義,另外還實現了當輸入 '(' 時,會自動匹配 tags ,展示函數的定義原型。

             


            8. omni 插件安裝

            參考~/.vim/doc/omnicppcomplete.txt

            • 按照 omni 插件

            下載omnicppcomplete-0[1].41.zip ,執行如下命令:

            unzip –n omnicppcomplete-0[1].41.zip –d ~/.vim

            將該文件解壓到~/.vim 文件夾下, 有after 、autoload 、doc 三個文件夾。

            • 生成 tags 文件

            • 方法 1

            在當前原文件所在目錄下執行

            ctags –R –c++-kinds=+p –fields=+iaS –extra=+q (注意:最后有個. )

            • 方法 2

            每次都執行這個長的命令有些麻煩,可以這樣設置:

            touch ~/.ctags

            打開.ctags 文件vim ~/.ctags ,添加如下三行命令i :

            --c++-kinds=+p

            --fields=+iaS

            --extra=+q

            在源文件所在的目錄下執行

            貌似直接用ctags –R 命令也可以。

            在VIM 中執行

            !ctags –R 命令即可。(注意:最后有個點)

            • 設置 vimrc

            設置/etc/vim/vimrc

            set nocp

            filetype plugin on

             

            set tags+=./tags

            let OmniCpp_DefaultNamespaces=[“std”]

            let OmniCpp_GlobalScopeSearch=1

            let OmniCpp_NamespaceSearch=1

            let OmniCpp_DisplayMode=1

            let OmniCpp_ShowScopeAbbr=0

            let OmniCpp_ShowPrototypeInAbbr=1

            let OmniCpp_ShowAccess=1

            let OmniCpp_MayCompleteDot=1

            let OmniCpp_MayCompleteArrow=1

            let OmniCpp_MayCompleteScope=1

            set omnifunc=complete#Complete

            set completeopt=longest,menu

             


            9. WinManager 插件安裝

             1 ) 在當前用戶下生效

            下載winmanager.zip ,執行如下命令:

            unzip –n winmanager.zip –d ~/.vim

             

            打開一個.cpp 文件,在VIM 命令模式下輸入WMToggle 展開文件夾,輸入Tlist 打開taglist 列表。

            使用ctrl 加兩個w 鍵,將光標跳轉到文件瀏覽,在光標選中的源文件按回車鍵,會在編輯窗口打開標簽。

            在當前文件夾下,創建新文件時,winmanager 并不會自動更新,需要利用ctrl+w 將光標轉移到文件瀏覽器窗口(FileExplorer ),按F5 鍵后,會進行刷新。

            vim /etc/vim/vimrc

            let g:winManagerWindowLayout=”FileExplorer,Taglist”

            在VIM 只顯示文fileexplorer 和taglist ,即只有文件夾中的文件和taglist ,也可以設置成:

            let g:winManagerWindowLayout=” BufExplorer,FileExplorer,Taglist”

            在VIM 中同時會顯示緩沖區文件,即在文件瀏覽器中會顯示.swp 文件。

            let g:winManagerWidth=30

            let g:defaultExplorer=0

             


            10. C 語言相關符號高亮顯示

                 vim /usr/share/vim/vim72/syntax/c.vim

                   1 )函數高亮顯示

                  syn match cFunctions display "[a-zA-Z_]/{-1,}/s/{-0,}(/{1}"ms=s,me=e-1

                  hi def link cFunctions Type

                  2 ) 指針符號高亮顯示

                  syn match cPointer display "*"

                  hi def link cPointer Conditional

             

                  3 ) 指針操作符高亮顯示

                  syn match cPointerOperator display "->/|/."

                  hi def link cPointerOperator Conditional

                   4 )邏輯運算符高亮顯示

                  syn match cLogicalOperator display "[!<>]=/="

                  syn match cLogicalOperator display "=="

                  hi def link cLogicalOperator Conditional

                   5 ) 位運算符高亮顯示

                  syn match cBinaryOperator display "/(&/||/|/^/|<</|>>/)=/="

                  syn match cBinaryOperator display "/~"

                  hi def link cBinaryOperator Conditional

                   6 ) 邏輯運算賦高亮顯示

                  syn match cLogicalOperator display "/&& /| ||"

                  hi def link cLogicalOperatro Conditional


            11. Doxygen


            11.1. DoxygenToolkit 設置

                 下載DoxygenToolkit.vim 到/usr/share/vim/vim72/plugin 目錄中。

                 將doxygenToolkit.vim 中的

                 “ let s:licenseTag = “ Copyright © /<enter>/<enter>” 的注釋去掉。

                 在/etc/vim/vimrc 中添加

                 let g:doxygenToolkit_authorName="siceaner@gmail.com"

                 let s:licenseTag="Copyright (C) 2010 CheJiang University EE/<enter>"

                 let s:licenseTag=s:licenseTag."All rights reserved"

                 let g:DoxygenToolkit_licenseTag=s:licenseTag

                 let g:doxygenToolkit_briefTag_funcName="yes"

                 let g:DoxygenToolkit_enhanced_color=1

                 這樣,就可以這樣,你就可以通過DoxAuthor ,DoxLic ,Dox ,Doxb 等幾個命令來生成文件、函數等常用的注釋,完成doxygen 風格的文檔了。

            11.2. Doxygen 設置

                 安裝Doxygen 生成注釋文檔。

                 1 )安裝 doxygen

                 sudo apt-get install doxygen doxygen-doc doxygen-gui graphviz

                 2 ) 生成配置文件

                 在程序所在目錄下執行doxygen -g 生成doxygen 配置文件

                 3 ) 生成注釋文檔

                 在配置文件所在目錄下,執行doxygen 配置文件名,生成注釋文檔。

             

             

             

            12. 快捷鍵設置

                 vim /etc/vim/vimrc

                 nmap <F8> :Tlist

                 nmap <F9> :WMToggle

             

                 nmap doxq :DoxAuthor

                 nmap doxw :DoxLic

                 nmap doxe :Dox

                 nmap doxr :DoxBlock


            ///////////////////////////////////////////////////////////////////////////////////////
            有重復的部分:
            在沒有怎么太深的接觸vi/vim之前,也曾經搞不懂為什么有好多linux下的程序員說vi/vim是個超級的代碼編輯器或者編譯器,也有不少的(我認 為是剛在linux編程不久的人)說,“。。頭讓門擠啦,有那么多功能強大的linux環境下的IDE不用,竟然就用個簡單的vi/vim,不用說界面類 似DOS,連編譯都要用命令。。”。。等等類似的評價吧。
                  我開始也不懂它到底哪強大,但我仍堅持使用vim可以說是據以兩點原因:
                  1、既然有那么多的前輩說它強大,那么就必定有他的道理  
                  2、我規定自己以后的發展方向是 The Embedded System on Linux,所以,在嵌入式硬件平臺資源很有限的情況下,使用耗資大的IDE有點不現實,但是vi/vim卻非常適合應用在這種硬件平臺上。
                  好了,其實我現在也是個linux下編程的新手,但我堅信我選擇用vi/vim是正確的。
                  下面我們就在Ubuntu7.10下用vi/vim搭建c/c++的編程環境,至于到底超不超級的,相信大家自有評價   ^.^
            注:本文主要參考和引用了 吳垠 的文章《手把手交你把Vim改裝成一個IDE編程環境》, 如果涉及到版權問題,請通知我,我會及時處理 ^.^      不過該文章主要是用gvim在RedHat上搭建的,考慮到在嵌入式系統的硬件平臺可能用不了gvim,故采用純粹的vi/vim,而且主機環境為 Ubuntu7.10,這樣,一些文件的安裝路徑可能和RedHat的有所區別,請讀者自己注意吧  :)

                  本文已經假設你已經升級到了完整版的Vim7.1.56,而且已經安裝了如gcc和g++等必須的編譯器。
             
            1、Vi/Vim中文幫助手冊的安裝。
                   a、 下載幫助中文包http://vcd.gro.clinux.org/-》UN*X打包文件,我下到的是vimcdoc-1.6.0.tar.gz,解壓后,進入到該解壓后的文件夾vimcdoc-1.6.0,執行命令
                  $ sudo ./vimcdoc.sh -i            //對中文幫助文件進行安裝,詳細可參考文件“INSTALL”
                  安裝完成后, 在終端打開vi/vim,輸入命令":help",即可看到,顯示的幫助文件已經為中文了。
                  b、vim編程常用命令(引):
                   建議先看看幫助手冊中的下面章節, 其中有關tags文件的部分你可以先跳過, 在后面的章節中會講到, 到時候你在回來看看, 就覺得很簡單了:
                  :help usr_29
                  :help usr_30
                   下面是我常用的一些命令, 放在這里供我備忘:
            %    跳轉到配對的括號去
            [    跳轉到代碼塊的開頭去(但要求代碼塊中'{'必須單獨占一行)
            gD    跳轉到局部變量的定義處
            ''    跳轉到光標上次停靠的地方, 是兩個', 而不是一個"
            mx    設置書簽,x只能是a-z的26個字母
            `x    跳轉到書簽處("`"是1左邊的鍵)
            >    增加縮進,"x>"表示增加以下x行的縮進
            <    減少縮進,"x<"表示減少以下x行的縮進
             
                2、語法高亮顯示:
                   編輯配置文件:$ sudo  vi /etc/vim/vimrc ,取消掉“syntax on”的注釋,就可以開啟代碼編輯時的語法高亮顯示了,并增加設置“colorscheme  murphy"  ,其中murphy是配色方案, 所有的配色方案保存在目錄“/usr/share/vim/vim71/colors”里,以“.vim”為結尾的文件。如果這里面沒有你喜歡的主題,則 在vim.org上一定會有符合你胃口的主題。
                   更炫的語法高亮:(引)
                   你可能會發現很多東西沒有高亮起來, 比如運算符號, 各種括號, 函數名, 自定義類型等, 但是看上面的圖片, 我的運算符號和函數名都加亮了^_^, 想知道為什么嗎? 哇哈哈哈哈.... 讓我來教你吧 ...
                  主要的思路是新建一個語法文件, 在文件中定義你要高亮的東東, 想高亮什么就高亮什么, 用vim就是這么自信. 所謂的語法文件就是vim用來高亮各種源文件的一個腳本, vim靠這個腳本的描述來使文件中的不同文本顯示不同的顏色, 比如C語言的語法文件放在類似于這樣的一個路徑中:  /usr/share/vim/vim71/syntax,在其中加入
                  
            "========================================================
            " Highlight All Function
            "========================================================
            syn match   cFunction "\<[a-zA-Z_][a-zA-Z_0-9]*\>[^()]*)("me=e-2
            syn match   cFunction "\<[a-zA-Z_][a-zA-Z_0-9]*\>\s*("me=e-1
            hi cFunction        gui=NONE guifg=#B5A1FF

            "========================================================
            " Highlight All Math Operator
            "========================================================
            " C math operators
            syn match       cMathOperator     display "[-+\*/%=]"
            " C pointer operators
            syn match       cPointerOperator  display "->\|\."
            " C logical   operators - boolean results
            syn match       cLogicalOperator  display "[!<>]=\="
            syn match       cLogicalOperator  display "=="
            " C bit operators
            syn match       cBinaryOperator   display "\(&\||\|\^\|<<\|>>\)=\="
            syn match       cBinaryOperator   display "\~"
            syn match       cBinaryOperatorError display "\~="
            " More C logical operators - highlight in preference to binary
            syn match       cLogicalOperator  display "&&\|||"
            syn match       cLogicalOperatorError display "\(&&\|||\)="

            " Math Operator
            hi cMathOperator            guifg=#3EFFE2
            hi cPointerOperator         guifg=#3EFFE2
            hi cLogicalOperator         guifg=#3EFFE2
            hi cBinaryOperator          guifg=#3EFFE2
            hi cBinaryOperatorError     guifg=#3EFFE2
            hi cLogicalOperator         guifg=#3EFFE2
            hi cLogicalOperatorError    guifg=#3EFFE2
            "=============================================================================
            再打開你的C文件看看, 是不是又明亮了許多. 還有一個壓箱底的要告訴你, 如果你自己增加了一個類型或者結構之類的, 怎么讓
            它也象"int", "void"這樣高亮起來呢? 再在上面的文件添加如下的設置:
            "========================================================
            " My Own DataType
            "========================================================
            syn keyword cType       My_Type_1 My_Type_2 My_Type_3

                  3、在程序中跳來跳去:Ctags的使用
                  你在讀程序時看了一個函數調用, 或者一個變量, 或者一個宏等等, 你想知道它們的定義在哪兒, 怎么辦呢?就用Ctag來實現這個功能:
                  到http://ctags.sourceforge.net/下載,解壓后順序執行“./configure”、“make”、“make install”即可完成安裝。
                 
              然后去你的源碼目錄, 如果你的源碼是多層的目錄, 就去最上層的目錄, 在該目錄下運行命令ctags -R,現在以我的
            ~/download/anjuta-2.4.0/src/為例,

             $ cd ~/download/anjuta-2.4.0/
             $ ctags -R
              此時在~/download/anjuta-2.4.0/目錄下會生成一個 tags 文件, 現在用vim打開~/download/anjuta-2.4.0/src/main.c            
            再在vim中運行命令:
            :set tags=~/download/anjuta-2.4.0/tags
            該命令將tags文件加入到vim中來, 你也可以將這句話放到vimrc中去, 如果你經常在這個工程編程的話.
            此時,將鼠標移到一個變量上后,按下Ctrl+],便會自動跳轉到該變量的定義處,再按下Ctrl+T,便會返回到原來處。
            使用對象為變量, 結構, 宏, 等等, 都可以的, 趕快試試吧.....
            此時在回頭學習一下第3節中說的vim手冊吧          
            :help usr_29
            不過還有一個小瑕疵, 你修改程序后, 比如增加了函數定義, 刪除了變量定義, tags文件不能自動rebuild, 你必須手動再運行一下命令:
            $ ctags -R
            使tags文件更新一下, 不過讓人感到欣慰的是vim不用重新啟動, 正在編寫的程序也不用退出, 馬上就可以又正確使用<C-]>和<C-T>了.


                  4、教你高效的瀏覽源碼--插件:Taglist
            下載地址    http://www.vim.org/scripts/script.php?script_id=273
            版本    4.5
            下載完成并解壓縮后,將相應的插件和doc復制到vim目錄:
            h-jingbo@Ubuntu:/usr/share/vim/vim71$ sudo cp /home/h-jingbo/download/plugin/taglist.vim plugin/
            h-jingbo@Ubuntu:/usr/share/vim/vim71$ sudo cp /home/h-jingbo/download/doc/taglist.txt doc/
                    由于以前已經安裝過了中文的help文件,所以在vi中輸入命令 :help taglist.txt是會提示找不到該幫助文件,可能是由于已經更改了vim的幫助文件的路徑了吧,這就不詳細研究了。
                    為了顯示Tlist的窗口的關閉于打開合適些,在文件 /etc/vim/vimrc 配置文件中加入下列的設置:

            let Tlist_Show_One_File=1
            let Tlist_Exit_OnlyWindow=1
                   用vim打開一個程序代碼后,執行命令 : Tlist,即可看到形如下面的界面:

                    其中,左面的窗口為運行Tlist形成的窗口,右邊為該文件的源代碼,在不同的窗口間,可以用Ctrl+兩次W進行切換,TagList窗口, 其中列出了main.c文件中的tag, 并且按照"typedef", "variable", "function"等進行了分類. 將光標移到左側的如圖所示的變量, 按下回車后, 源程序會自動跳轉到該變量的定義處,這就是TagList最基本也是最常用的操作. 再教你一個常用的操作, 你在瀏覽TagList窗口時, 如果還不想讓源碼跳轉, 但是想看看tag在源碼中完整的表達, 可以將光標移到你想要看的tag上, 然后按下空格鍵, 在下面的命令欄中, 如圖下邊含“=0”字樣的方框, 會顯示該tag在源碼中完整的寫法, 而不會跳轉到源碼處.
                   TagList插件我就介紹到這里, 其實它還有很多用法和設置, 我沒法一一地教你了, 好在TagList有一份詳細的幫助手冊 taglist.txt, 有時間好好鉆研下吧 : )
                   5、文件瀏覽和窗口管理器--插件:WinManager
            下載地址    http://www.vim.org/scripts/script.php?script_id=95
            版本    2.x
            手冊    :help winmanager
                   當我們打開vi,執行命令 “:e ~/download/anjuta-2.4.0/src/”時,可以看到如下的畫面,

                 可以發現,會顯示我的路徑“~/download/anjuta-2.4.0/src/”下的文件目錄,這個功能就是由vi默認的以安裝的插件netrw.vim實現的,
            在該界面上你可以用下面的一些命令來進行常用的目錄和文件操作:
            <F1>    顯示幫助
            <cr>    如果光標下是目錄, 則進入該目錄; 如果光標下文件, 則打開該文件
            -
            返回上級目錄
            c
            切換vim 當前工作目錄正在瀏覽的目錄
            d
            創建目錄
            D
            刪除目錄或文件
            i
            切換顯示方式
            R
            文件或目錄重命名
            s
            選擇排序方式
            x
            定制瀏覽方式, 使用你指定的程序打開該文件

                     我這里不是教你怎么用netrw.vim插件, 而是要教你通過WinManager插件來將TagList窗口和netrw窗口整合起來,在文件/etc/vim/vimrc中加入下面的兩句配置:

            let g:winManagerWindowLayout='FileExplorer|TagList'
            nmap wm :WMToggle<cr>
            我打開~/download/anjuta-2.4.0/src/目錄下的main.c的源文件,在normal狀態下輸入"wm",可以看到如下:

                       其中左上邊是netrw窗口, 左下邊是TagList窗口, 當再次輸入"wm"命令時這兩個窗口又關閉了.

                     WinManager的功能主要就是我介紹的這些, 但是它還有其他一些高級功能, 還可以支持其他幾個插件, 如果你覺得我介紹的還不夠你用, 建議你把它的幫助手冊好好研究一下,就是插件壓縮包中doc里的文件。

              6、Cscope的使用:
                   這下更厲害了, 用Cscope自己的話說 - "你可以把它當做是超過頻的ctags", 其功能和強大程度可見一斑吧, 關于它的介紹我就不詳細說了, 如果你安裝好了前文介紹的中文幫助手冊, 用下面的命令看看介紹吧:
            :help if_cscop.txt
                  我在這里簡單摘抄一點, 供還在猶豫的朋友看看:
            Cscope 是一個交互式的屏幕下使用的工具,用來幫助你:
            * 無須在厚厚的程序清單中翻來翻去就可以認識一個 C 程序的工作原理。
            * 無須熟悉整個程序就可以知道清楚程序 bug 所要修改的代碼位置。
            * 檢查提議的改動 (如添加一個枚舉值) 可能會產生的效果。
            * 驗證所有的源文件都已經作了需要的修改;例如給某一個現存的函數添加一個參數。
            * 在所有相關的源文件中對一個全局變量改名。
            * 在所有相關的位置將一個常數改為一個預處理符號。

            它被設計用來回答以下的問題:
            * 什么地方用到了這個符號?
            * 這是在什么地方定義的?
            * 這個變量在哪里被賦值?
            * 這個全局符號的定義在哪里?
            * 這個函數在源文件中的哪個地方?
            * 哪些函數調用了這個函數?
            * 這個函數調用了哪些函數?
            * 信息 "out of space" 從哪來?
            * 這個源文件在整個目錄結構中處于什么位置?
            * 哪些文件包含這個頭文件?
            下載地址    http://cscope.sourceforge.net
            版本
            15.x
                 安裝和往常一樣,解壓-》“./configure”“make”“make install”,這些都需要root權限。
            在/etc/vim/vimrc增加以下設置:
            :set cscopequickfix=s-,c-,d-,i-,t-,e-    
            這個是設定是否使用 quickfix 窗口來顯示 cscope 結果, 用法在后面會說到。
            跟Ctags一樣, 要使用其功能必須先為你的代碼生成一個cscope的數據庫, 比如我的項目在“~/download/anjuta-2.4.0”,則在該目錄下運行下面的命令:
            $ sudo cscope -Rbq
            # 此后會生成三個文件
            $ ls -l cscope.*
            -rw-r--r-- 1 root root 1318912 2008-03-26 21:18 cscope.in.out
            -rw-r--r-- 1 root root 7843983 2008-03-26 21:18 cscope.out
            -rw-r--r-- 1 root root 5553000 2008-03-26 21:18 cscope.po.out
            # 打開文件, 開始Coding
            $ cd src
            $ vi main.c
            進入vim后第一件事是要把剛才生成的cscope文件導入到vim中來, 用下面的命令:
            :cs add ~/download/anjuta-2.4.0/cscope.out ~/download/anjuta-2.4.0
            上面這條命令很重要, 必須寫全, 不能只寫前半句:
            :cs add ~/download/anjuta-2.4.0/cscope.out
            因為源碼是多級目錄的, 如果這樣寫, cscope是無法在子目錄中的源碼中工作的, 當然, 如果你的源碼都在同一級目錄中就無所謂了. 如果你要經常用cscope的話, 可以把上面那句加到vimrc中去.
            下面我們來操練一下, 查找函數vim_strsave()的定義, 用命令:
            :cs find g get_real_path
            如下圖:

            按下回車后會自動跳轉到get_real_path()的定義處. 此時你肯定會說Ctags也可以做到這個呀, 那么下面說的這個Ctags就無法做到了, 我想查找get_real_path()到底在那些地方被調用過了, 用命令:
            :cs find c get_real_path 按下回車后vim會自動跳轉到第一個符合要求的地方, 并且在命令欄顯示有多少符合要求的結果, 如圖:

            如果自動跳轉的位置你不滿意, 想看其他的結果, 可以用下面的命令打開QuickFix窗口:
            :cw
            如圖:

            這時你就可以慢慢挑選了^_^(當然,這里只有一處調用了。。。舉例不當,哈哈)

            cscope的主要功能是通過同的子命令"find"來實現的
            "cscope find"的用法:
            cs find c|d|e|f|g|i|s|t name
            0 或 s    查找本 C 符號(可以跳過注釋)
            1 或 g    查找本定義
            2 或 d    查找本函數調用的函數
            3 或 c    查找調用本函數的函數
            4 或 t    查找本字符串
            6 或 e    查找本 egrep 模式
            7 或 f    查找本文件
            8 或 i    查找包含本文件的文件
            如果每次查找都要輸入一長串命令的話還真是件討人厭的事情, Cscope的幫助手冊中推薦了一些快捷鍵的用法, 下面是其中一組, 也是我用的, 將下面的內容添加到/etc/vim/vimrc中, 并重啟vim:
            nmap <C-_>s :cs find s <C-R>=expand("<cword>")<CR><CR>
            nmap <C-_>g :cs find g <C-R>=expand("<cword>")<CR><CR>
            nmap <C-_>c :cs find c <C-R>=expand("<cword>")<CR><CR>
            nmap <C-_>t :cs find t <C-R>=expand("<cword>")<CR><CR>
            nmap <C-_>e :cs find e <C-R>=expand("<cword>")<CR><CR>
            nmap <C-_>f :cs find f <C-R>=expand("<cfile>")<CR><CR>
            nmap <C-_>i :cs find i ^<C-R>=expand("<cfile>")<CR>$<CR>
            nmap <C-_>d :cs find d <C-R>=expand("<cword>")<CR><CR>
            當光標停在某個你要查找的詞上時, 按下<C-_>g, 就是查找該對象的定義, 其他的同理.
            按這種組合鍵有一點技巧,按了<C-_>后要馬上按下一個鍵,否則屏幕一閃就回到nomal狀態了
            <C-_>g的按法是先按"Ctrl+Shift+-", 然后很快再按"g"

            很奇怪, 其中的這句:
            nmap <C-_>i :cs find i ^<C-R>=expand("<cfile>")<CR>$<CR>
            在我的vim中無法工作, 但是我改成:
            nmap <C-_>i :cs find i <C-R>=expand("<cfile>")<CR><CR>
            就可以正常工作了, 不知道是什么原因? 有哪位朋友知道請告訴我.

            cscope的其他功能你可以通過幫助手冊自己慢慢學習

            reset : 重新初始化所有連接。
            用法  : cs reset

             7、QuickFix窗口:
            在上一節的圖中大家可以看到在窗口下面有一個顯示查詢結果的窗口, 這個窗口中列出了查詢命令的查詢結果, 用戶可以從這個窗口中選擇每個結果進行查看, 這個窗口叫"QuickFix"窗口, 以前也是一個vim的插件來的, 只不過現在成了vim的標準插件, 不用你在去安裝了, QuickFix窗口的主要作用就是上面看到的那個功能: 輸出一些供選擇的結果, 可以被很多命令調用, 更詳細的介紹和使用方法請用下面的命令打開QuickFix的手冊來學習吧:
            :help quickfix 這里我一個常用的例子來再介紹一種QuickFix窗口的使用方法. 這個例子是要模仿平時我們編程時, 當編譯出錯時, QuickFix會把出錯的信息列出來, 供我們一條條地查看和修改. 首先還是用vim打開 ~/download/anjuta-2.4.0/src/main.c,事先最好先編譯過main.c, 否則一會兒編譯的時候有點慢, 或者你也可以自己寫一個小的有錯誤的程序來跟著我做下面的步驟, 見下圖:

            當我們執行完make以后, 顯然編譯會報很多錯誤, 當編譯結束并退出到源碼界面時, 剛才編譯器報的錯誤都已經看不到了, 但是我們可以用QuickFix窗口再將錯誤信息找出來, 用下面的命令調出QuickFix窗口:
            :cw 此時你就可以看如上圖所示的QuickFix窗口了。
            在下面的QuickFix窗口中我們可以找到每一個編譯錯誤, 同樣你可以用鼠標點擊每一條記錄, 代碼會馬上自動跳轉到錯誤處, 你還可以用下面的命令來跳轉:
            :cn        // 切換到下一個結果
            :cp        // 切換到上一個結果
            如果你經常使用這兩個命令, 你還可以給他們設定快捷鍵, 比如在/etc/vim/vimrc中增加:
            nmap <F6> :cn<cr>
            nmap <F7> :cp<cr>

            其還有其他的命令/插件也會用到QuickFix窗口, 但是用法基本上的都是類似的, 本文后面還會用到QuickFix窗口, 接著往下看吧.


            8、快速瀏覽和操作Buffer--插件: MiniBufExplorer:                                                            
            下載地址    http://www.vim.org/scripts/script.php?script_id=159
            版本    6.3.2
            至于如何安裝,就不再闡述了。
            在編程的時候不可能永遠只編輯一個文件, 你肯定會打開很多源文件進行編輯, 如果每個文件都打開一個vim進行編輯
            的話那操作起來將是多麻煩啊, 所以vim有buffer(緩沖區)的概念, 可以看vim的幫助:
            :help buffer
            vim自帶的buffer管理工具只有:ls, :bnext, :bdelete 等的命令, 既不好用, 又不直觀. 現在隆重向你推薦一款vim插件
            (plugin): MiniBufExplorer

            使用方法:
            重新啟動vim, 當你只編輯一個buffer的時候MiniBufExplorer派不上用場, 當你打開第二個buffer的時候,
             MiniBufExplorer窗口就自動彈出來了, 見下圖:

            上面那個狹長的窗口就是MiniBufExplorer窗口, 其中列出了當前所有已經打開的buffer, 當你把光標置于這個窗口時, 有下面幾個快捷鍵可以用:
            <Tab>    向前循環切換到每個buffer名上
            <S-Tab>    向后循環切換到每個buffer名上
            <Enter>    在打開光標所在的buffer
            d    刪除光標所在的buffer
            以下的兩個功能需要在/etc/vim/vimrc中增加:
            let g:miniBufExplMapCTabSwitchBufs = 1
            <C-Tab>    向前循環切換到每個buffer上,并在但前窗口打開
            <C-S-Tab>    向后循環切換到每個buffer上,并在但前窗口打開在/etc/vim/vimrc中設置:
            let g:miniBufExplMapWindowNavArrows = 1 是用<C-箭頭鍵>切換到上下左右窗口中去

            9、c/h文件相互切換--插件: A:
            下載地址    http://www.vim.org/scripts/script.php?script_id=31
            版本
            2.18
            下面介紹它的用法:
            作為一個C程序員, 日常Coding時在源文件與頭文件間進行切換是再平常不過的事了, 直接用vim打開其源/頭文件其實也不是什么麻煩事, 但是只用一個按鍵就切換過來了, 這是多么貼心的功能啊....
            安裝好a.vim后有下面的幾個命令可以用了:
            :A    在新Buffer中切換到c\h文件
            :AS    橫向分割窗口并打開c\h文件
            :AV    縱向分割窗口并打開c\h文件
            :AT    新建一個標簽頁并打開c\h文件 其他還有一些命令, 你可以在它的網頁上看看, 我都沒用過, 其實也都是大同小異, 找到自己最順手的就行了.

            我在/etc/vim/vimrc中增加了一句:
            nnoremap <silent> <F12> :A<CR>
            意思是按F12時在一個新的buffer中打開c\h文件, 這樣在寫程序的時候就可以不假思索地在c/h文件間進行切換, 減少了按鍵的次數, 思路也就更流暢了, 阿彌陀佛....

            10、在工程中查找--插件: Grep:
            下載地址    http://www.vim.org/scripts/script.php?script_id=311
            版本    1.9
            下面介紹它的用法:
            vim有自己的查找功能, 但是跟shell中的grep比起來還是有些差距的, 有時Coding正火急火燎的時候, 真想按下F3, 對光標所在的詞來個全工程范圍的grep, 不用敲那些繁瑣的命令, 現在福音來了, 跟我同樣懶的人不在少數, 在grep.vim腳本的前部可以找到一些說明文檔:
            :Grep    按照指定的規則在指定的文件中查找
            :Rgrep    同上, 但是是遞歸的grep
            :GrepBuffer    在所有打開的緩沖區中查找
            :Bgrep    同上
            :GrepArgs    在vim的argument filenames (:args)中查找
            :Fgrep    運行fgrep
            :Rfgrep    運行遞歸的fgrep
            :Egrep    運行egrep
            :Regrep    運行遞歸的egrep
            :Agrep    運行agrep
            :Ragrep    運行遞歸的agrep
            上面的命令是類似這樣調用的:
            :Grep   [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Rgrep  [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Fgrep  [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Rfgrep [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Egrep  [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Regrep [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Agrep  [<grep_options>] [<search_pattern> [<file_name(s)>]
            :Ragrep [<grep_options>] [<search_pattern> [<file_name(s)>]
            :GrepBuffer [<grep_options>] [<search_pattern>]
            :Bgrep [<grep_options>] [<search_pattern>]
            :GrepArgs [<grep_options>] [<search_pattern>]
            但是我從來都不用敲上面那些命令的^_^, 因為我在/etc/vim/vimrc中增加了下面這句:
            nnoremap <silent> <F3> :Grep<CR>
            比如,你想在main.c中查找變量“get_real_path”,則將光標放在“get_real_path”上,按下F3,在最下面的命令行會顯示:
            Search for pattern: get_real_path 此時你還可以編輯該行, grep支持正則表達式, 你想全詞匹配的話可以改成:
            Search for pattern: \<get_real_path\> 然后按下回車:
            在最下面的命令行會顯示:
            Search in files: *
            是問你搜索范圍, 默認是該目錄下的所有文件, 此時你還可以編輯該行, 比如你只想搜索源碼文件:
            Search in files: *.c *.h                          //當然也可只設定文件main.c
            然后在按下回車, 會在彈出的QuickFix窗口中列出所有符合條件的搜索結果, 你可以在其中查找你想要的結果。
                    其實還有一些其他功能和設置, 但是我都沒有用過, 這些功能再加上正則表達式, 已經夠我用了, 其他的你可以在網頁上看看它的文檔, 如果有什么驚人發現記得跟我互通有無, 共同進步哦....

            11、高亮的書簽--插件: VisualMark:
            下載地址    http://www.vim.org/scripts/script.php?script_id=1026
            版本
            0.4
            下面介紹它的用法:
            vim也和其他編輯器一樣有"書簽"概念, 在vim中叫"Mark", 可以用下面的命令查看相關說明:
            :help Mark 該"書簽"有個很很大的缺點: 不可見.
            我下面要介紹的Visual Mark插件跟vim中的"Mark"沒有什么關系, 并不是使其可見, 而是自己本身就是"可見的書簽", 接著往下看就明白了, 用作者的話說就是"類似UltraEdit中的書簽".
            另外, 網上也有使vim中的Mark可見的插件, 但是我試了一下, 好像沒Visual Mark好用, 我就不介紹了.

            按照上面的方法安裝好Visual Mark后, 你什么也不用設置, 如果是gvim, 直接在代碼上按下Ctrl+F2, 如果是vim, 用"mm", 怎么樣, 發現光標所在的行變高亮了吧。
            如果你設置了多個書簽, 你可以用F2鍵正向在期間切換, 用Shift+F2反向在期間切換.
            好了, 我Visual Mark介紹完了, 夠簡單吧^_^.

            如果你嫌書簽的顏色不好看, 你還可以自己定義, 不過是修改這個插件腳本的的源碼, 在目錄/usr/share/vim/vim71/plugin/中找到并打開visualmark.vim, 找到下面這段代碼:
            if &bg == "dark"  // 根據你的背景色風格來設置不同的書簽顏色
             highlight SignColor ctermfg=white ctermbg=blue guifg=wheat guibg=peru
            else             // 主要就是修改guibg的值來設置書簽的顏色
             highlight SignColor ctermbg=white ctermfg=blue guibg=grey guifg=RoyalBlue3
            endif

            12、自動補全:

            用 過Microsoft Visual Studio的朋友一定知道代碼補全功能, 輸入一個對象名后再輸入"."或者"->", 則其成員名都可以列出來, 使Coding流暢了許多, 實現很多懶人的夢想, 現在我要告訴你, 這不再是Microsoft Visual Studio的專利了, vim也可以做到! 下面由我來教你, 該功能要tags文件的支持, 并且是ctags 5.6版本, 可以看看前文介紹tags文件的章節.

            我這里要介紹的功能叫"new-omni-completion(全能補全)", 你可以用下面的命令看看介紹:
            :help new-omni-completion
            你還需要在/etc/vim/vimrc文件中增加下面兩句:
            filetype plugin indent on 打開文件類型檢測, 加了這句才可以用智能補全
            set completeopt=longest,menu 關掉智能補全時的預覽窗口

            請確定你的Ctags 5.6已經安裝好, 并且生成的tags文件已經可以用了, 那么我們就要抄家伙開搞了.
            用vim打開源文件
            $ vi ~/download/anjuta-2.4.0/src/main.c 設置tags文件
            :set tags=~/download/anjuta-2.4.0/src/tags 隨便找一個有成員變量的對象, 進入Insert模式, 將光標放在"->"后面,
            然后按下"Ctrl+X Ctrl+O", 此時會彈出一個下列菜單, 顯示所有匹配的標簽。
            此時有一些快捷鍵可以用:
            Ctrl+P    向前切換成員
            Ctrl+N    向后切換成員
            Ctrl+E    表示退出下拉窗口, 并退回到原來錄入的文字
            Ctrl+Y    表示退出下拉窗口, 并接受當前選項
            如果你增加了一些成員變量, 全能補全還不能馬上將新成員補全, 需要你重新生成一下tags文件, 但是你不用重啟vim, 只是重新生成一下tags文件就行了, 這時全能補全已經可以自動補全了, 還真夠"全能"吧.

            vim中的其他補全方式還有:
            Ctrl+X Ctrl+L
            整行補全
            Ctrl+X Ctrl+N    根據當前文件里關鍵字補全
            Ctrl+X Ctrl+K    根據字典補全
            Ctrl+X Ctrl+T    根據同義詞字典補全
            Ctrl+X Ctrl+I    根據頭文件內關鍵字補全
            Ctrl+X Ctrl+]    根據標簽補全
            Ctrl+X Ctrl+F    補全文件名
            Ctrl+X Ctrl+D    補全宏定義
            Ctrl+X Ctrl+V    補全vim命令
            Ctrl+X Ctrl+U    用戶自定義補全方式
            Ctrl+X Ctrl+S    拼寫建議

            13、加速你的補全--插件:SuperTab
            下載地址    http://www.vim.org/scripts/script.php?script_id=1643
            版本    0.45
            在上面一節中你應該學會了自動補全代碼的功能, 按下"Ctrl+X Ctrl+O"就搞定了, 如果你夠懶的話肯定會說"這么麻煩啊, 居然要按四個鍵", 不必為此自責, 因為Gergely Kontra 和 Eric Van Dewoestine也跟你差不多, 只不過人家開發了supertab.vim這個插件, 可以永遠懶下去了, 下面我來教你偷懶吧.

            在你的/etc/vim/vimrc文件中加上這兩句:
            let g:SuperTabRetainCompletionType=2
            let g:SuperTabDefaultCompletionType="<C-X><C-O>"
            以后當你準備按"Ctrl+X Ctrl+O"的時候直接按<Tab>就好了, 夠爽吧 ....

            我稍微再介紹一下上面那兩句配置信息:
            let g:SuperTabDefaultCompletionType="<C-X><C-O>"
            " 設置按下<Tab>后默認的補全方式, 默認是<C-P>,
            " 現在改為<C-X><C-O>. 關于<C-P>的補全方式,
            " 還有其他的補全方式, 你可以看看下面的一些幫助:
            " :help ins-completion
            " :help compl-omni

            let g:SuperTabRetainCompletionType=2
            " 0 - 不記錄上次的補全方式
            " 1 - 記住上次的補全方式,直到用其他的補全命令改變它
            " 2 - 記住上次的補全方式,直到按ESC退出插入模式為止

            問題:
            但 是現在我的<Tab>鍵不好用了, 我以前愛用<Tab>進行縮進, 如果前面有字符按下<Tab>鍵后就會進行補全, 而不是我想要的縮進功能, 不知道有沒有快捷鍵可以暫時關閉和激活SuperTab鍵的功能. 如果哪位朋友知道, 請一定記得告訴我啊....


            Help poor children in Uganda!
            "幫助可憐的烏干達兒童"
            vim的作者開發了這么個強大, 好用的編輯器, 并且是完全開源, 完全免費的, 不知道比爾蓋子會不會覺得這個人真是不可理喻. 作者對用戶用戶的唯一期望就是幫助烏干達的兒童, 可以用命令:hlep kcc查看詳細的內容,

            1、捐助一個讀小學的孩子:每月 17 歐元 (或更多)。
            2、捐助一個讀中學的孩子:每月 25 歐元 (或更多)。
            3、捐助診所:每月或每季度,數額不限。
            4、一次性捐贈。

            有條件的就資助一下, 沒條件的就像我一樣幫助宣傳一下吧, 這也算是開源精神.....

            另轉一個鏈接
            http://blog.csdn.net/yangyang_gnu/article/details/6642271

            posted on 2011-07-25 10:56 艾斯維亞 閱讀(4247) 評論(0)  編輯 收藏 引用

            久久久久久国产精品美女| 国产成人无码精品久久久性色| 精品精品国产自在久久高清| 香蕉久久夜色精品国产小说| 亚洲国产成人久久笫一页| 亚洲av成人无码久久精品| 99久久综合国产精品二区| 伊人久久大香线蕉av不变影院| 精品999久久久久久中文字幕| 性做久久久久久久久浪潮| 精品一区二区久久| 日韩精品久久久久久久电影| 久久精品男人影院| 久久综合狠狠综合久久| 一本久久免费视频| 精品国产青草久久久久福利 | 久久精品国产色蜜蜜麻豆| 亚洲αv久久久噜噜噜噜噜| 国産精品久久久久久久| 人人狠狠综合久久88成人| 久久这里只有精品首页| 久久久久久国产精品无码下载| 俺来也俺去啦久久综合网| 久久99精品久久久久久hb无码 | 久久精品免费观看| 国产成人久久精品激情| 亚洲精品白浆高清久久久久久| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 久久久久久久人妻无码中文字幕爆 | 国产精品久久久久久五月尺| 99热都是精品久久久久久| 久久国产乱子伦精品免费强| 久久人爽人人爽人人片AV| 久久人人爽人人爽人人片AV不| 伊人久久大香线蕉综合Av| 伊人久久精品无码二区麻豆| 热re99久久6国产精品免费| 亚洲人成伊人成综合网久久久| 无码精品久久久天天影视| 亚洲AV无码久久寂寞少妇| 久久99精品久久只有精品|