IOS开发环境windows化攻略

2020-01-14 14:52:24刘景俊



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,通常有两种方法: