从零开始记录Qt Creator构建cmake项目(四)



  • Hi,不知不觉我们很快就写第四篇简易的cmake教程了(需要看以前的教程请查阅这里)。这次是介绍多文件的处理方法。虽然我们可以在一个CMakeLists.txt文件中书写几乎无限的cpp文件,但是这显然不利于管理,我们需要做的,就是模块化,这样一旦新的功能需要添加进来的时候,我们就新开一个模块,既方便又容易管理。

    下面我就将原有的例子稍微修改一下。假设我们要创建两个类ProgrammerDesigner,这两个类都具有实现基类Personwork()方法,那么我们希望这两个类分布在不同的模块中。那么用C++代码很容易写出:
    person.h

    #ifndef PERSON_H
    #define PERSON_H
    
    class Person
    {
    public:
        Person( void );
        void eat( void );
        virtual void work( void );
    };
    
    #endif // PERSON_H
    

    person.cpp

    #include <iostream>
    #include "person.h"
    
    Person::Person( void )
    {
    
    }
    
    void Person::eat( void )
    {
        std::cout << "Person eat.";
    }
    
    void Person::work( void )
    {
        std::cout << "Person work.";
    }
    

    designer.h

    #ifndef DESIGNER_H
    #define DESIGNER_H
    
    #include "../person.h"
    
    class Designer: public Person
    {
    public:
        Designer( void );
        void work( void );
    };
    
    #endif // DESIGNER_H
    

    designer.cpp

    #include <iostream>
    #include "designer.h"
    
    Designer::Designer( void )
    {
    
    }
    
    void Designer::work( void )
    {
        std::cout << "Designer designs.";
    }
    

    programmer.h

    #ifndef PROGRAMMER_H
    #define PROGRAMMER_H
    
    #include "../person.h"
    
    class Programmer: public Person
    {
    public:
        Programmer( void );
        void work( void );
    };
    
    #endif // PROGRAMMER_H
    

    programmer.cpp

    #include <iostream>
    #include "programmer.h"
    
    Programmer::Programmer( void )
    {
    
    }
    
    void Programmer::work( void )
    {
        std::cout << "Programmer programs.";
    }
    

    我们同时在项目根目录下建立了programmer和designer文件夹。这个时候,要用模块化的思想构建,就必须在两个文件夹下同时放入CMakeLists.txt文件。最后主项目只需要包含这两个文件就行啦。
    下面是designer文件夹下CMakeLists.txt的写法:

    # 规定了cmake的最小支持版本
    cmake_minimum_required(VERSION 2.8)
    
    # 设置了库文件所需的源文件,并且是静态库
    add_library( Designer STATIC
      designer.cpp
    )
    

    然后就是programmer文件夹下的CMakeLists.txt的写法:

    # 规定了cmake的最小支持版本
    cmake_minimum_required(VERSION 2.8)
    
    # 设置了库文件所需的源文件,并且是静态库
    add_library( Programmer STATIC
      programmer.cpp
    )
    

    最后就是主CMakeLists.txt的写法:

    # 规定了cmake的最小支持版本
    cmake_minimum_required(VERSION 2.8)
    
    # 规定了项目的名称
    project(cmake_tutorial_0)
    
    # 规定了项目的源文件名称
    add_executable( ${PROJECT_NAME}
                    "main.cpp"
                    "person.cpp" )
    
    # 添加一些编译选项(开启所有警告(warn all),使用C++11语法)
    add_definitions("-Wall -std=c++11")
    
    # 添加子项目
    add_subdirectory( programmer )
    add_subdirectory( designer )
    
    # 链接静态库
    target_link_libraries( ${PROJECT_NAME} Programmer Designer )
    

    这里需要注意的是,我们建立的是静态库,所以在add_library()方法中第二个参数要写成STATIC。详细请参考add_library()的用法。

    最后要链接库,静态链接相对来说简单一些,只需要把库名称添加进入target_link_libraries()方法中就成了。此外因为programmer和designer是子文件夹,所以需要使用add_subdirectory()方法将子项目添加进来。怎么样,应该也不难吧。最后程序运行结果是:

    Programmer programs.Designer designs.


 

最近的回复

  • 随后在git for windows这个软件中输入

    git clone git@git.coding.net:jiangcaiyang1/qtdreamrelease_windows.git

    就可以获得一个空的项目了。其它的项目也是同样的操作方法。然后呢,将此作为自动构建的代码库吧。
    此次介绍就是这样~😘 😘 🐧

    阅读更多
  • 0_1540027445466_很好.jpg
    萌梦安装包的分发始终是一个难题。要有一个稳定并且有效的方法进行分包,才能让大家都能够享受到萌梦动作编辑器的最新功能。我们目前有两种分发的方法:

    离线安装包。通常的位置是
    1.1 百度云盘
    1.2 QQ群文件
    1.3 github
    其中百度云盘和QQ群文件不会定期地更新,只有github的文件会定期更新。因为构建脚本要求每次有更改,都让github的文件更新。

    在线安装包。通常的位置是
    2.1 百度云盘
    2.2 QQ群文件
    2.3 github
    这里在线安装包的代码库主要还是在github中,在线安装包非常依赖CDN加速。目前github这块儿在国内做得不太好,还是希望在国内找一个类似的加速。目前可以选的只有两家:

    码云

    coding

    因为以前做过coding的加速,目前coding已经和腾讯云战略合作,所有的代码都要迁移到腾讯云了。而且对于代码库的空间要求变高了。128M。目前我的一个账号显然满足不了要求。所以有必要再注册一个账号。

    下面记录一下新建coding代码库的方法,并且尝试将萌梦安装包的线上代码库部分移动到coding代码库中。

    注册

    到这个位置注册。

    https://coding.net/register

    相信很快就会带你跳转到腾讯云中。不过这里我选择的是邮箱的方式,因为我希望注册尽量多的账号。

    设置ssh密钥

    进入控制台后,是这样的:
    0_1540028446495_2eeb7e93-c15b-4c82-9b36-58e1c304ea3f-image.png
    这个时候,我们要先创建项目,然后ssh的公钥。
    0_1540028822318_b3e81b93-099c-42d5-820d-deaf8d445913-image.png

    创建以后,开始部署公钥。在这里:
    0_1540028925337_d8059b64-8535-45e5-ba4c-d7454505aa5a-image.png
    这期间最好用OpenSSL生成SSH密钥。
    我使用的是git for windows来生成密钥的。方法是

    ssh-keygen

    如果你生成好了密钥,可以直接打开密钥内容看看:

    cat ~/.ssh/id_rsa.pub

    然后粘贴到网站的文本框中。

    添加好了之后,勾选“准许推送权限”,需要推送代码到代码库中。

    阅读更多

关注我们

微博
QQ群











召唤伊斯特瓦尔