IOS開發環境windows化攻略

來源:互聯網
上載者:User

1. XCode

Perference
General
Double Click Navigation - 預設雙擊後會彈出新視窗(Use Seperate Window),這個和vc不一樣,主要這個視窗位置和大小通常讓人有不連貫感。改為Same as Click就和vc一樣

Text Editing
Editing
While editing Automatically trim trailing whitespace (去除尾部空白)
Including whitespace-only lines (全空行也去除空白,注意還保留斷行符號)
這個其實是我們正常編碼會做的,但這樣和老代碼交接處以後的patch可能會產生衝突。如果自己平常習慣好,推薦不勾。
Default text encoding 選 Simplified Chinese(Mac OS)
Default line ending 選 Windows(CRLF)
Convert existing files on save 不勾

保持與windows版本代碼設定一致,基準上通常已經有設定了就不要改變了,否則mac port的diff會讓你的diff檔案滿屏都是^M(單檔案中存在兩種行尾格式)

Indentation
Prefer indent using: Tabs
Tab width: 4 spaces
Indent width: 4 space
Tab Key: Inserts tab charater
Line wrapping: Wrap Line to editor width 勾上
Indent wrapped lines by: 4 space
Syntax-aware indenting 不勾,自動修改非常討厭,尤其是你從diff檔案拷貝衝突的部分時

Key Bindings 修改常用快速鍵,盡量保持和vc/va一致,va的Alt+ <- -> 和 alt+o alt+m 沒找到,其他常用的,修改如下:

(\ Shift | Alt 左上箭 Home)

部分和系統的快速鍵衝突了,可以在系統喜好設定->鍵盤->鍵盤快速鍵修改掉。

順便一提,Navigators(左邊那一列)下面有個過濾器,但有時候自己會忘記了發現找不到結果時,注意看看是不是在裡面殘留了上次的過濾關鍵字。

2. 版本管理工具

svn:
Versions 可惜不免費。取老版本有點費事,左上方點select,在revision裡面輸入版本號碼後切換下After/Before能比較好選到比較老的版本。
Hg/Git:
SourceTree 比MacHG之流好了不止一點,無論效率還是使用習慣,而且是免費的,在他的官網註冊個使用者,導一個lensence檔案進專網就能一直用了。

文本編輯:
Sublimt Text2 特別清爽的編輯器,有不少特別的功能,對我來說主要是可以改Copy等操作的快速鍵,支援各種檔案的文法高亮,對GBK支援不好,要下一個外掛程式。不過此外掛程式會導致大檔案開啟比較慢。

7z解壓縮:
7zX等 貌似都是要扔到Dock,然後拖放進去來用的,用了兩個大的包解壓效率貌似都很差,於是我對Mac都傳zip了現在。

3. 版本同步

A) MacOS的diff/patch

由於mac下內建了diff/patch,所以就無所謂要拷gnuwin32的那些exe了(且由于格式不一樣,不支援那些exe)
修改原先mydiff.bat下的內容,添加mac相關的過濾,-x.DS_Store -x*.xcworkspacedata -xxcuserdata,然後將原來的那些%1等改為$1 $2
複製代碼 代碼如下:diff -Nur --ignore-file-name-case -xDebug -xRelease -xDebug_Kalydo -xRelease_Kalydo -xEnv -xEnvNormal -xEnvWeb -xpdb -xVTune -xboost -xstlport -xDXSDK -x.svn -x.hg -x*.hgignore -x.git -x.gitignore -x*.vsp -x*.psess -x*.swp -x*.ncb -x*.opt -x*.scc -x*.plg -x*.clw -x*.aps -x*.org -x*.orig -x*.rej -x*.rar -x*.Administrator.user -x*.suo -x*.bak -x*.map -x*.ico -x*.vcproj.list -x*.vcproj.lnt -x.DS_Store -x*.xcworkspacedata -xxcuserdata $1 $2

注意$2後不應該有任何分行符號,否則diff的時候路徑會有問題。
然後去掉尾碼名,放在etc/paths中的任意一個路徑下(或者放在你喜歡的路徑,然後添加到etc/paths)的內容中,即設定環境變數。
然後 chmod 777 mydiff,給這個shell指令碼許可權。

這樣就可以和windows一樣的使用了mydiff了。

B) 在Mac下使用windows風格的diff檔案

由於MacPort(Unix)的diff,本身的輸出(^+++/^---/^@@等)是LF,差異部分的輸出是沿用原文的行尾。這樣一來,其實上只對修改前後全文都是unix格式的行尾(LF)支援良好。

而征服項目中,普遍採用windows的行尾符(CRLF),於是diff出來的檔案其實是一個混合兩種行尾符的檔案。也就是用gvim查看這種檔案的時候,會看到^M符號的原因。

而這與我們在windows中採用的gunwin32的diff/patch的效果不盡相同,後者本身的輸出是CRLF,而差異部分也是沿用原來的。

這樣一來,就產生了一個尷尬的情況,即一個平台diff出來的補丁難以在另外一個平台使用。通常我們都是對Mac版本同步windows的diff,通常有兩種方法:

i. 在Mac的windows虛擬機器中用gunwin32的patch

注意此時patch不直接支援網路位置的檔案夾,在設定共用(虛擬機器/共用/共用設定)後,在windows虛擬機器中映射網路磁碟機(資源管理員/工具/映射網路磁碟機)即可解決此問題。

ii. 直接在Mac上用shell指令碼處理。

建立一個shell檔案iospatch,內容如下:

複製代碼 代碼如下:awk '/^\+\+\+|^---|^@@|^diff|^Binary|^File/ { sub(/\r$/,"") }; {print}' > unixLF.diff
patch $@ < unixLF.diff

注意要和上述mydiff的shell一樣處理好路徑,賦予許可權。

用法和patch一樣,只是現在我們會寫iospatch -arg < file,比如 iospatch -p1 < ..\win.diff

這個方法可以避免龜速的黑蘋果開了虛擬機器後雪上加霜,且可以同時相容Unix/windows兩種風格的diff,推薦使用。

C) 版本功能同步,衝突解決

apple的東西由於審核等原因,版本更新相對不頻繁,經常會有好幾個大版本了才同步一次,同步工作量很大,每個人都要同步數十個補丁,而由於windows和mac分支的差異相當大,基本會有很多的衝突,又由於XCode編譯慢,資源需要重新轉化等原因,很難做到每個補丁都check in一次,這樣就通常會是幾十個補丁合成一個大變更檔案,然後把這個檔案check in上去。
幾十個補丁的衝突解決,萬一後面出了點什麼事情(比如某個衝突未解決),基本很難在svn上看出來。於是推薦採用一個本地的版本管理工具,如上所述的SourceTree,由於HG/Git等都是本地倉庫的,使用起來非常簡單。也不像svn那樣對check in要求嚴格,這樣我們可以連帶orig/rej檔案check in到我們的本地倉庫,方便之後的核對。
而要在本地還原修改,清理冗餘檔案,查看變更的時候,都顯得尤為方便,且基準更新的時候,我們也可以取到另外一個分支,再合并分支,實現在本地merge後重出補丁,可以弱化對基準的需求。

本文附件:

IOS開發環境windows化攻略_代碼附件.zip
: /201306/other/IOS_windows_fj_jb51.rar
內容(注意shell/bat檔案中部分空格斷行符號是敏感的,有問題請直接下載一份)
mac下批量混合格式diff轉成unix格式diff diff2unix 複製代碼 代碼如下:#diff2unix
#Ruoqian, Chen<piao.polar@gmail.com>
#2013.2.7
#----------
#trans diff patch with windows LE (CRLF) to Unix LE(LF)
#-----------
#usage
#diff2unix trans curent dir
#diff2unix path trans dir or file
#when trans dir, will trans all files and child dir in it.
#----------
if [ $# == 0 ]
then
path=`pwd`
else
path=$1
fi
if [ -f $path ]
then
file=${path##*/}
ext=${file##*.}
if [[ "$file" != mac* ]] && [ $ext = "diff" ]
then
new_file="mac_"$file
echo $path "->" $new_file
awk '/^\+\+\+|^---|^@@|^diff|^Binary|^File/ { sub(/\r$/,"") }; {print}' < $path > $new_file
fi
else
for file in `ls $path`
do
diff2unix $path"/"$file
done
fi

windows下批量混合格式diff轉成windows/dos格式diff diff2win.bat 複製代碼 代碼如下:::diff2win
::Ruoqian,Chen<piao.polar@gmail.com>
::----------
::Trans file with unix LE(LF) or mix LE(LF/CRLF) to window LE(CRLF)
::----------
::2013.2.16
::usage
::diff2win trans curent dir
::diff2win path trans dir or file
::----------
@echo off
setlocal enabledelayedexpansion
set WorkPath=%cd%
if [%1] neq [] set WorkPath=%1&& (dir /ad %1 >nul 2>nul ) && goto TRANS_DIR || goto TRANS_FILE
:TRANS_DIR
for /f "delims=" %%i in ('dir !WorkPath! /a-d /b ^| findstr .diff$ ^| findstr -v ^win_') do (
echo !WorkPath!/%%i -^> win_%%i
gawk -v BINMODE="rw" "/^\+\+\+|^---|^@@|^diff|^Binary|^File/ { sub(/$/,\"\r\") }; {print}" < !WorkPath!/%%i > win_%%i
)
goto :eof
:TRANS_FILE
for /f "delims=" %%i in ('dir %WorkPath% /b') do (
echo %WorkPath% -^> win_%%i
gawk -v BINMODE="rw" "/^\+\+\+|^---|^@@|^diff|^Binary|^File/ { sub(/$/,\"\r\") }; {print}" < %WorkPath% > win_%%i
)
::gawk -v BINMODE="rw" "/^\+\+\+|^---|^@@|^diff|^Binary|^File/ { sub(/$/,\"\r\") }; {print}" < in > out
::----------
::2013.2.8
::usage
::diff2win < file_in > file_out
::e.g.
::diff2win < unix.diff > win.diff
::----------
::@echo off
::gawk 1
::http://www.gnu.org/software/gawk/manual/html_node/PC-Using.html
::Under MS-Windows, OS/2 and MS-DOS, gawk (and many other text programs) silently translate end-of-line "\r\n" to "\n" on input and "\n" to "\r\n" on output.

windonws下直接打各種格式diff winpatch.bat 複製代碼 代碼如下:::winpatch
::Ruoqian, Chen<piao.polar@gmail.com>
::2013.2.16
::
::call gnu patch to patch a diff file with windows LE (CRLF) or Unix LE(LF) or mix LE
::----------
::usage
::the same to patch use patch --help to read it
::e.g. winpatch -p1 < ../mac.diff
::or winpatch -p1 -R < ../mac.diff
::----------
@echo off
gawk -v BINMODE="rw" "/^\+\+\+|^---|^@@|^diff|^Binary|^File/ { sub(/$/,\"\r\") }; {print}" > dosCRLF.diff
patch %1 %2 %3 %4 %5 %6 %7 %8 %9 < dosCRLF.diff

2013.3.4.更新

1. 關於Versions
commit的時候尤其要注意不要遺漏了檔案的增刪。點擊Changed,會看到目錄下的修改,其中新增檔案顯示為圓問號,刪除檔案顯示為虛方問號,右鍵點擊Add或Delete,使之表徵圖變化為正確的增刪表徵圖即可。
2. 關於Sublimt Text2
a) 解決中文亂碼的外掛程式
資源和說明見:https://github.com/seanliang/ConvertToUTF8/blob/master/README.zh_CN.md
b) 修改快速鍵為windows樣式
Preferences->Key Bindings - User 將windows版本的拷過來
或直接可以從這裡自取 https://gist.github.com/piaopolar/5081327
c) 修改將檔案拖放到視窗內不開啟新視窗
Preferences->Setting - Default
"open_files_in_new_window" : false

d) 自動換行
Preferences->Setting - Default
"word_wrap" : "true"
3. iospatch 和 winpatch 的中間檔案目錄放在當前路徑不大好,往往會導致反到工作目錄中去了。
在檔案名稱前面加\(windows)或/(Unix),放到根目錄即可,或直接往系統臨時檔案目錄或自己預期的目錄即可規避此問題。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.