CEF的构造说明:
https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding

chromium的源码地址:
https://chromium.googlesource.com/chromium/src.git

cef的源码地址:
https://bitbucket.org/chromiumembedded/cef/src/2357?at=2357

CEF源码中的文件CHROMIUM_BUILD_COMPATIBILITY.txt中有相应的chromium的tag(如:refs/tags/43.0.2357.130)

下载源码编译,先下载depot_tools并添加到环境变量path中。

自动下载编译:
1、mkdir code
2、cd code
3、下载depot_tools并解压到当前文件夹。
4、创建automate文件夹,将下载的automate-git.py放在其下面。
5、创建chromium文件夹,并在其下面创建update.bat,update.bat文件内容为:
python ..\automate\automate-git.py --download-dir=g:\code\chromium --depot-tools-dir=g:\code\depot_tools --branch=2357
6、在命令行执行update.bat自动下载并编译源码。
备注:bat中的选项可以有:
--download-dir 源码下载目录
--depot-tools-dir 工具包目录
--branch 源码分支(默认trunk主分支)
--checkout 指定patch版本(默认最近提交)
--no-build 下载完不自动开始编译(我们需要修改编译配置)
--no-update 确定源码下载完毕仅重新编译时使用
--force-build 强制编译(发现在有成功编译的时候再编译不会执行,可以加上这个
--no-debug-build 只编译release版本
--no-release-build 只编译debug版本
如何确定--checkout值
如果确定需要分支下的最新版本,请略过此节。
1.从http://cefbuilds.com/检查目标版本的hash值。例:3.2357.1281.gd660177中的gd660177
2.从https://bitbucket.org/chromiumembedded/cef/branches/进入目标分支。例:2357
3.在Commits中检索目标hash,注意版本号中hash为8位,commits中为7位,可以忽略第一位搜索。例:gd660177->d660177
4.点击相应commit,即可在地址栏中得到checkout值。例:d66017718b0f0d44da42b706c3c2aa5c0c103852

手工下载编译:

按照https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding文中段

Release Branch

下面的操作一步一步进行。

(注意:先下载chromium源码,再下载cef源码,cef源码务必放在chromium源码的src下面的cef文件夹里)

0、先要将windows的语言变成英语,安装vs2015 professional update3, windows sdk Win10.0.10586

1、设置环境变量
set DEPOT_TOOLS_WIN_TOOLCHAIN=0
set GYP_GENERATORS=ninja
set GYP_MSVS_VERSION=2015
SET CEF_USE_GN=0
set CEF_ARCHIVE_FORMAT=tar.gz
set GYP_DEFINES=branding=Chromium buildtype=Official proprietary_codecs=1 ffmpeg_branding=Chrome windows_sdk_path="C:\Program Files (x86)\Windows Kits\10"

要支持播mp3必须修改chromium\src\cef\cef.gypi,下面variables增加两行。

'variables': {
'proprietary_codecs': 1,
'ffmpeg_branding': 'Chrome',

2、进入到chromium\src\cef目录,执行cef_create_projects.bat
3、进入到chromium\src目录,使用ninja进行编译(区别在于编译过程信息输出的位置)

ninja -C out\Debug libcef

ninja -C out\Debug libcef > d:\build.log

下面错误解决办法:打开eglext.h,在其第62行下面加入:typedef EGLAttribKHR EGLAttrib;即可。

  1. src\third_party\swiftshader\include\egl\eglext.h(119): error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
  2. src\third_party\swiftshader\include\egl\eglext.h(119): error C2143: syntax error: missing ',' before '*'
  3. src\third_party\swiftshader\include\egl\eglext.h(120): error C2061: syntax error: identifier 'EGLAttrib'
  4. src\third_party\swiftshader\include\egl\eglext.h(515): error C2061: syntax error: identifier 'EGLAttrib

Release下链接错误:
ffmpeg.lib(ffmpeg.wavdec.obj) : error LNK2001: unresolved external symbol _ff_w64_guid_data
原因:https://chromium-review.googlesource.com/c/343398/4

解决办法:
第一步(不知道不改行不行,单做这一步肯定是不行)
chromium/src/third_party/ffmpeg/ffmpeg_generated.gni
chromium/src/third_party/ffmpeg/ffmpeg_generated.gypi
"libavformat/vorbiscomment.c",下面新增下面一行。
"libavformat/w64.c",
第二步 (一定要做)
chromium\src\out\Release\obj\third_party\ffmpeg\ffmpeg.ninja,按wavdec关键字搜索,
1、找到
build obj\third_party\ffmpeg\libavformat\ffmpeg.wavdec.obj: cc $
..\..\third_party\ffmpeg\libavformat\wavdec.c
这两行复制一份插到当前位置,并把wavdec改成w64,结果变成:
build obj\third_party\ffmpeg\libavformat\ffmpeg.w64.obj: cc $
..\..\third_party\ffmpeg\libavformat\w64.c
build obj\third_party\ffmpeg\libavformat\ffmpeg.wavdec.obj: cc $
..\..\third_party\ffmpeg\libavformat\wavdec.c
2、继续找到行:obj\third_party\ffmpeg\libavformat\ffmpeg.wavdec.obj $
这行复制一份插到当前位置,并把wavdec改成w64,结果变成:
obj\third_party\ffmpeg\libavformat\ffmpeg.w64.obj $
obj\third_party\ffmpeg\libavformat\ffmpeg.wavdec.obj $

CEF源码编译的更多相关文章

  1. CEF源码编译和生产库的使用

    CEF版本是Branch 2171 开发环境是VS2012 查看一下libcef_dll_wrapper工程属性,确定Code Generation 选择MTD(Debug) 或者MT(Release ...

  2. 【chromium】 cef源码下载

    至少需要17GB的磁盘空间,不光有CEF源码,还会下载chromium源码.编译master分支的话,如果编译到chromium可能会需要windows sdk,windows sdk的版本可以参考下 ...

  3. Android 5.0源码编译问题

    如果是自己通过repo和git直接从google官网上download的源码,请忽略这个问题,但是由于google在国内被限制登录,通过这一种方法不是每个人都能download下来源码,通常的做法就是 ...

  4. Android stdio Apktool源码编译

    Android Apktool源码编译 标签(空格分隔): Android Apktool 源码编译 需求 习惯NetBeans调试smali需要用Apktool反编译apk,需要用-d的参数才能生成 ...

  5. SSH/SSL 源码编译安装简易操作说明

    环境:CentOS 6.7 安全加固需求,由于某盟扫描系统主机有SSL系列漏洞,客户要求必须修复: 解决方案:将SSH/SSL升级到最新版本,删除SSL旧版本(实测不删除旧版本某盟扫描无法通过). 当 ...

  6. Hadoop源码编译过程

    一.           为什么要编译Hadoop源码 Hadoop是使用Java语言开发的,但是有一些需求和操作并不适合使用java,所以就引入了本地库(Native Libraries)的概念,通 ...

  7. World Wind .NET源码编译问题处理

    World  Wind  .NET源码编译问题处理 下载了World_Wind_1.4.0_Source源码(http://worldwindcentral.com/wiki/NASA_World_W ...

  8. 源码编译安装 MySQL 5.5.x 实践

    1.安装cmakeMySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具.因此,我们首先要在系统中源码编译安装cmake工具. # wget ht ...

  9. Linux 安装node.js ---- 源码编译的方式

    一 : 普通用户: 安装前准备环境: 1.检查Linux 版本 命令: cat /etc/redhat-release 2.检查 gcc.gcc-c++ 是否安装过 命令: rpm -q gcc rp ...

随机推荐

  1. 常用模块-----configparser & subprocess

    configparser 模块 功能:操作模块类的文件,configparser类型文件的操作类似于字典,大多数用法和字典相同. 新建文件: import configparser cfg=confi ...

  2. seajs 入门

    最近想搞搞JS模块化, 读到了园子里的一篇好文:  http://www.cnblogs.com/lvdabao/p/js-modules-develop.html 看里面讲seajs不错, 于是想学 ...

  3. CentOS/Linux 卸载MATLAB

    rm -rf /usr/local/MATLAB/R2012arm /usr/local/bin/matlab /usr/local/bin/mcc /usr/local/bin/mex /usr/l ...

  4. wareshark网络协议分析之ARP

    一.ARP协议简介 简单的说ARP协议就是实现ip地址到物理地址的映射.当一台主机把以太网数据帧发送到位于同一局域网上的另一台主机时,是根据48bit的以太网地址(物理地址)来确定网络接口的. ARP ...

  5. ZooKeeper-znode概念与使用

    可以将ZK看作一个具有高可用性特征的文件系统.这个文件系统中没有文件和目录,而是统一使用节点(znode)的概念,称为znode.znode既可以作为保存数据的容器(如同文件),也可以作为保存其他zn ...

  6. PAT1028. List Sorting (25)

    id用int,避免了id的strcmp,不然用string就超时. #include <iostream> #include <vector> #include <alg ...

  7. codeforces 705B:Spider Man

    Description Peter Parker wants to play a game with Dr. Octopus. The game is about cycles. Cycle is a ...

  8. 使用Navicat进行数据库自动备份

    今天经历一次数据库丢库事件,顿时觉得定时备份数据库很重要. 但是每天自己手动备份实在是太麻烦了,于是乎,想到用计划任务进行每天定时自动备份. 发现Navicat自带就有备份  还可以直接计划任务,贼方 ...

  9. STL视频_02

    [01:05]主要讲一下几个要点: 1.模板.函数模板 类模板 以及它们的用法 2.容器.什么是容器 和 容器的分类,各种容器的数据结构 3.容器vector的具体用法,包括迭代器的具体用法 [01: ...

  10. review36

    对于Thread(Runnable target)构造方法创建的线程,轮到它来享用CPU资源时,目标对象就会自动调用接口中的run()方法,因此,对于使用同一目标对象的线程,目标对象的成员变量自然就是 ...