mirror of
https://github.com/alliedmodders/hl2sdk.git
synced 2025-01-04 00:23:25 +08:00
Update Protobuf and add protos for CS2 (#176)
* Replace protobuf 2.6.1 with 3.21.8 * Update/add protobuf libs * Add CS2 protos * Remove old csgo/dota protos * Add versioned protoc bin * Comment out Valve's `schema` define for now * Use ENetworkDisconnectionReason * Fix-up `offsetof` to avoid errors on some Clang versions
This commit is contained in:
parent
e6dc3f8a40
commit
c5d57c03ee
19
common/connectionless_netmessages.proto
Normal file
19
common/connectionless_netmessages.proto
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
import "netmessages.proto";
|
||||||
|
|
||||||
|
message C2S_CONNECT_Message {
|
||||||
|
optional uint32 host_version = 1;
|
||||||
|
optional uint32 auth_protocol = 2;
|
||||||
|
optional uint32 challenge_number = 3;
|
||||||
|
optional fixed64 reservation_cookie = 4;
|
||||||
|
optional bool low_violence = 5;
|
||||||
|
optional bytes encrypted_password = 6;
|
||||||
|
repeated .CCLCMsg_SplitPlayerConnect splitplayers = 7;
|
||||||
|
optional bytes auth_steam = 8;
|
||||||
|
optional string challenge_context = 9;
|
||||||
|
optional sint32 use_snp = 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
message C2S_CONNECTION_Message {
|
||||||
|
optional string addon_name = 1;
|
||||||
|
optional bool use_snp = 2;
|
||||||
|
}
|
14
common/engine_gcmessages.proto
Normal file
14
common/engine_gcmessages.proto
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import "google/protobuf/descriptor.proto";
|
||||||
|
|
||||||
|
message CEngineGotvSyncPacket {
|
||||||
|
optional uint64 match_id = 1;
|
||||||
|
optional uint32 instance_id = 2;
|
||||||
|
optional uint32 signupfragment = 3;
|
||||||
|
optional uint32 currentfragment = 4;
|
||||||
|
optional float tickrate = 5;
|
||||||
|
optional uint32 tick = 6;
|
||||||
|
optional float rtdelay = 8;
|
||||||
|
optional float rcvage = 9;
|
||||||
|
optional float keyframe_interval = 10;
|
||||||
|
optional uint32 cdndelay = 11;
|
||||||
|
}
|
604
common/netmessages.proto
Normal file
604
common/netmessages.proto
Normal file
@ -0,0 +1,604 @@
|
|||||||
|
import "networkbasetypes.proto";
|
||||||
|
|
||||||
|
enum CLC_Messages {
|
||||||
|
clc_ClientInfo = 20;
|
||||||
|
clc_Move = 21;
|
||||||
|
clc_VoiceData = 22;
|
||||||
|
clc_BaselineAck = 23;
|
||||||
|
clc_ListenEvents = 24;
|
||||||
|
clc_RespondCvarValue = 25;
|
||||||
|
clc_FileCRCCheck = 26;
|
||||||
|
clc_LoadingProgress = 27;
|
||||||
|
clc_SplitPlayerConnect = 28;
|
||||||
|
clc_ClientMessage = 29;
|
||||||
|
clc_SplitPlayerDisconnect = 30;
|
||||||
|
clc_ServerStatus = 31;
|
||||||
|
clc_ServerPing = 32;
|
||||||
|
clc_RequestPause = 33;
|
||||||
|
clc_CmdKeyValues = 34;
|
||||||
|
clc_RconServerDetails = 35;
|
||||||
|
clc_HltvReplay = 36;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum SVC_Messages {
|
||||||
|
svc_ServerInfo = 40;
|
||||||
|
svc_FlattenedSerializer = 41;
|
||||||
|
svc_ClassInfo = 42;
|
||||||
|
svc_SetPause = 43;
|
||||||
|
svc_CreateStringTable = 44;
|
||||||
|
svc_UpdateStringTable = 45;
|
||||||
|
svc_VoiceInit = 46;
|
||||||
|
svc_VoiceData = 47;
|
||||||
|
svc_Print = 48;
|
||||||
|
svc_Sounds = 49;
|
||||||
|
svc_SetView = 50;
|
||||||
|
svc_ClearAllStringTables = 51;
|
||||||
|
svc_CmdKeyValues = 52;
|
||||||
|
svc_BSPDecal = 53;
|
||||||
|
svc_SplitScreen = 54;
|
||||||
|
svc_PacketEntities = 55;
|
||||||
|
svc_Prefetch = 56;
|
||||||
|
svc_Menu = 57;
|
||||||
|
svc_GetCvarValue = 58;
|
||||||
|
svc_StopSound = 59;
|
||||||
|
svc_PeerList = 60;
|
||||||
|
svc_PacketReliable = 61;
|
||||||
|
svc_HLTVStatus = 62;
|
||||||
|
svc_ServerSteamID = 63;
|
||||||
|
svc_FullFrameSplit = 70;
|
||||||
|
svc_RconServerDetails = 71;
|
||||||
|
svc_UserMessage = 72;
|
||||||
|
svc_HltvReplay = 73;
|
||||||
|
svc_Broadcast_Command = 74;
|
||||||
|
svc_HltvFixupOperatorStatus = 75;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum VoiceDataFormat_t {
|
||||||
|
VOICEDATA_FORMAT_STEAM = 0;
|
||||||
|
VOICEDATA_FORMAT_ENGINE = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum RequestPause_t {
|
||||||
|
RP_PAUSE = 0;
|
||||||
|
RP_UNPAUSE = 1;
|
||||||
|
RP_TOGGLEPAUSE = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum PrefetchType {
|
||||||
|
PFT_SOUND = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum ESplitScreenMessageType {
|
||||||
|
MSG_SPLITSCREEN_ADDUSER = 0;
|
||||||
|
MSG_SPLITSCREEN_REMOVEUSER = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum EQueryCvarValueStatus {
|
||||||
|
eQueryCvarValueStatus_ValueIntact = 0;
|
||||||
|
eQueryCvarValueStatus_CvarNotFound = 1;
|
||||||
|
eQueryCvarValueStatus_NotACvar = 2;
|
||||||
|
eQueryCvarValueStatus_CvarProtected = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum DIALOG_TYPE {
|
||||||
|
DIALOG_MSG = 0;
|
||||||
|
DIALOG_MENU = 1;
|
||||||
|
DIALOG_TEXT = 2;
|
||||||
|
DIALOG_ENTRY = 3;
|
||||||
|
DIALOG_ASKCONNECT = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum SVC_Messages_LowFrequency {
|
||||||
|
svc_dummy = 600;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum Bidirectional_Messages {
|
||||||
|
bi_RebroadcastGameEvent = 16;
|
||||||
|
bi_RebroadcastSource = 17;
|
||||||
|
bi_GameEvent = 18;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum Bidirectional_Messages_LowFrequency {
|
||||||
|
bi_RelayInfo = 700;
|
||||||
|
bi_RelayPacket = 701;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum ReplayEventType_t {
|
||||||
|
REPLAY_EVENT_CANCEL = 0;
|
||||||
|
REPLAY_EVENT_DEATH = 1;
|
||||||
|
REPLAY_EVENT_GENERIC = 2;
|
||||||
|
REPLAY_EVENT_STUCK_NEED_FULL_UPDATE = 3;
|
||||||
|
REPLAY_EVENT_VICTORY = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_ClientInfo {
|
||||||
|
optional fixed32 send_table_crc = 1;
|
||||||
|
optional uint32 server_count = 2;
|
||||||
|
optional bool is_hltv = 3;
|
||||||
|
optional uint32 friends_id = 5;
|
||||||
|
optional string friends_name = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_Move {
|
||||||
|
optional bytes data = 3;
|
||||||
|
optional uint32 command_number = 4;
|
||||||
|
optional uint32 num_commands = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgVoiceAudio {
|
||||||
|
optional .VoiceDataFormat_t format = 1 [default = VOICEDATA_FORMAT_STEAM];
|
||||||
|
optional bytes voice_data = 2;
|
||||||
|
optional int32 sequence_bytes = 3;
|
||||||
|
optional uint32 section_number = 4;
|
||||||
|
optional uint32 sample_rate = 5;
|
||||||
|
optional uint32 uncompressed_sample_offset = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_VoiceData {
|
||||||
|
optional .CMsgVoiceAudio audio = 1;
|
||||||
|
optional fixed64 xuid = 2;
|
||||||
|
optional uint32 tick = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_BaselineAck {
|
||||||
|
optional int32 baseline_tick = 1;
|
||||||
|
optional int32 baseline_nr = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_ListenEvents {
|
||||||
|
repeated fixed32 event_mask = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_RespondCvarValue {
|
||||||
|
optional int32 cookie = 1;
|
||||||
|
optional int32 status_code = 2;
|
||||||
|
optional string name = 3;
|
||||||
|
optional string value = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_FileCRCCheck {
|
||||||
|
optional int32 code_path = 1;
|
||||||
|
optional string path = 2;
|
||||||
|
optional int32 code_filename = 3;
|
||||||
|
optional string filename = 4;
|
||||||
|
optional fixed32 crc = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_LoadingProgress {
|
||||||
|
optional int32 progress = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_SplitPlayerConnect {
|
||||||
|
optional string playername = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_ClientMessage {
|
||||||
|
optional int32 msg_type = 1;
|
||||||
|
optional bytes data = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_SplitPlayerDisconnect {
|
||||||
|
optional int32 slot = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_ServerStatus {
|
||||||
|
optional bool simplified = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_ServerPing {
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_RequestPause {
|
||||||
|
optional .RequestPause_t pause_type = 1 [default = RP_PAUSE];
|
||||||
|
optional int32 pause_group = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_CmdKeyValues {
|
||||||
|
optional bytes data = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_RconServerDetails {
|
||||||
|
optional bytes token = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_ServerInfo {
|
||||||
|
optional int32 protocol = 1;
|
||||||
|
optional int32 server_count = 2;
|
||||||
|
optional bool is_dedicated = 3;
|
||||||
|
optional bool is_hltv = 4;
|
||||||
|
optional int32 c_os = 6;
|
||||||
|
optional int32 max_clients = 10;
|
||||||
|
optional int32 max_classes = 11;
|
||||||
|
optional int32 player_slot = 12 [default = -1];
|
||||||
|
optional float tick_interval = 13;
|
||||||
|
optional string game_dir = 14;
|
||||||
|
optional string map_name = 15;
|
||||||
|
optional string sky_name = 16;
|
||||||
|
optional string host_name = 17;
|
||||||
|
optional string addon_name = 18;
|
||||||
|
optional .CSVCMsg_GameSessionConfiguration game_session_config = 19;
|
||||||
|
optional bytes game_session_manifest = 20;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_ClassInfo {
|
||||||
|
message class_t {
|
||||||
|
optional int32 class_id = 1;
|
||||||
|
optional string class_name = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional bool create_on_client = 1;
|
||||||
|
repeated .CSVCMsg_ClassInfo.class_t classes = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_SetPause {
|
||||||
|
optional bool paused = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_VoiceInit {
|
||||||
|
optional int32 quality = 1;
|
||||||
|
optional string codec = 2;
|
||||||
|
optional int32 version = 3 [default = 0];
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_Print {
|
||||||
|
optional string text = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_Sounds {
|
||||||
|
message sounddata_t {
|
||||||
|
optional sint32 origin_x = 1;
|
||||||
|
optional sint32 origin_y = 2;
|
||||||
|
optional sint32 origin_z = 3;
|
||||||
|
optional uint32 volume = 4;
|
||||||
|
optional float delay_value = 5;
|
||||||
|
optional int32 sequence_number = 6;
|
||||||
|
optional int32 entity_index = 7 [default = -1];
|
||||||
|
optional int32 channel = 8;
|
||||||
|
optional int32 pitch = 9;
|
||||||
|
optional int32 flags = 10;
|
||||||
|
optional uint32 sound_num = 11;
|
||||||
|
optional fixed32 sound_num_handle = 12;
|
||||||
|
optional int32 speaker_entity = 13;
|
||||||
|
optional int32 random_seed = 14;
|
||||||
|
optional int32 sound_level = 15;
|
||||||
|
optional bool is_sentence = 16;
|
||||||
|
optional bool is_ambient = 17;
|
||||||
|
optional uint32 guid = 18;
|
||||||
|
optional fixed64 sound_resource_id = 19;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional bool reliable_sound = 1;
|
||||||
|
repeated .CSVCMsg_Sounds.sounddata_t sounds = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_Prefetch {
|
||||||
|
optional int32 sound_index = 1;
|
||||||
|
optional .PrefetchType resource_type = 2 [default = PFT_SOUND];
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_SetView {
|
||||||
|
optional int32 entity_index = 1 [default = -1];
|
||||||
|
optional int32 slot = 2 [default = -1];
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_FixAngle {
|
||||||
|
optional bool relative = 1;
|
||||||
|
optional .CMsgQAngle angle = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_CrosshairAngle {
|
||||||
|
optional .CMsgQAngle angle = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_BSPDecal {
|
||||||
|
optional .CMsgVector pos = 1;
|
||||||
|
optional int32 decal_texture_index = 2;
|
||||||
|
optional int32 entity_index = 3 [default = -1];
|
||||||
|
optional int32 model_index = 4;
|
||||||
|
optional bool low_priority = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_SplitScreen {
|
||||||
|
optional .ESplitScreenMessageType type = 1 [default = MSG_SPLITSCREEN_ADDUSER];
|
||||||
|
optional int32 slot = 2;
|
||||||
|
optional int32 player_index = 3 [default = -1];
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_GetCvarValue {
|
||||||
|
optional int32 cookie = 1;
|
||||||
|
optional string cvar_name = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_Menu {
|
||||||
|
optional int32 dialog_type = 1;
|
||||||
|
optional bytes menu_key_values = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_UserMessage {
|
||||||
|
optional int32 msg_type = 1;
|
||||||
|
optional bytes msg_data = 2;
|
||||||
|
optional int32 passthrough = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_SendTable {
|
||||||
|
message sendprop_t {
|
||||||
|
optional int32 type = 1;
|
||||||
|
optional string var_name = 2;
|
||||||
|
optional int32 flags = 3;
|
||||||
|
optional int32 priority = 4;
|
||||||
|
optional string dt_name = 5;
|
||||||
|
optional int32 num_elements = 6;
|
||||||
|
optional float low_value = 7;
|
||||||
|
optional float high_value = 8;
|
||||||
|
optional int32 num_bits = 9;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional bool is_end = 1;
|
||||||
|
optional string net_table_name = 2;
|
||||||
|
optional bool needs_decoder = 3;
|
||||||
|
repeated .CSVCMsg_SendTable.sendprop_t props = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_GameEventList {
|
||||||
|
message key_t {
|
||||||
|
optional int32 type = 1;
|
||||||
|
optional string name = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message descriptor_t {
|
||||||
|
optional int32 eventid = 1;
|
||||||
|
optional string name = 2;
|
||||||
|
repeated .CSVCMsg_GameEventList.key_t keys = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
repeated .CSVCMsg_GameEventList.descriptor_t descriptors = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_PacketEntities {
|
||||||
|
message command_queue_info_t {
|
||||||
|
optional uint32 commands_queued = 1;
|
||||||
|
optional uint32 command_queue_desired_size = 2;
|
||||||
|
optional uint32 starved_command_ticks = 3;
|
||||||
|
optional float time_dilation_percent = 4;
|
||||||
|
optional uint32 discarded_command_ticks = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
message alternate_baseline_t {
|
||||||
|
optional int32 entity_index = 1;
|
||||||
|
optional int32 baseline_index = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional int32 max_entries = 1;
|
||||||
|
optional int32 updated_entries = 2;
|
||||||
|
optional bool is_delta = 3;
|
||||||
|
optional bool update_baseline = 4;
|
||||||
|
optional int32 baseline = 5;
|
||||||
|
optional int32 delta_from = 6;
|
||||||
|
optional bytes entity_data = 7;
|
||||||
|
optional bool pending_full_frame = 8;
|
||||||
|
optional uint32 active_spawngroup_handle = 9;
|
||||||
|
optional uint32 max_spawngroup_creationsequence = 10;
|
||||||
|
optional uint32 last_cmd_number = 11;
|
||||||
|
optional uint32 server_tick = 12;
|
||||||
|
optional bytes serialized_entities = 13;
|
||||||
|
optional .CSVCMsg_PacketEntities.command_queue_info_t command_queue_info = 14;
|
||||||
|
repeated .CSVCMsg_PacketEntities.alternate_baseline_t alternate_baselines = 15;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_TempEntities {
|
||||||
|
optional bool reliable = 1;
|
||||||
|
optional int32 num_entries = 2;
|
||||||
|
optional bytes entity_data = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_CreateStringTable {
|
||||||
|
optional string name = 1;
|
||||||
|
optional int32 num_entries = 2;
|
||||||
|
optional bool user_data_fixed_size = 3;
|
||||||
|
optional int32 user_data_size = 4;
|
||||||
|
optional int32 user_data_size_bits = 5;
|
||||||
|
optional int32 flags = 6;
|
||||||
|
optional bytes string_data = 7;
|
||||||
|
optional int32 uncompressed_size = 8;
|
||||||
|
optional bool data_compressed = 9;
|
||||||
|
optional bool using_varint_bitcounts = 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_UpdateStringTable {
|
||||||
|
optional int32 table_id = 1;
|
||||||
|
optional int32 num_changed_entries = 2;
|
||||||
|
optional bytes string_data = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_VoiceData {
|
||||||
|
optional .CMsgVoiceAudio audio = 1;
|
||||||
|
optional int32 client = 2 [default = -1];
|
||||||
|
optional bool proximity = 3;
|
||||||
|
optional fixed64 xuid = 4;
|
||||||
|
optional int32 audible_mask = 5;
|
||||||
|
optional uint32 tick = 6;
|
||||||
|
optional int32 passthrough = 7;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_PacketReliable {
|
||||||
|
optional int32 tick = 1;
|
||||||
|
optional int32 messagessize = 2;
|
||||||
|
optional bool state = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_FullFrameSplit {
|
||||||
|
optional int32 tick = 1;
|
||||||
|
optional int32 section = 2;
|
||||||
|
optional int32 total = 3;
|
||||||
|
optional bytes data = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_HLTVStatus {
|
||||||
|
optional string master = 1;
|
||||||
|
optional int32 clients = 2;
|
||||||
|
optional int32 slots = 3;
|
||||||
|
optional int32 proxies = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_ServerSteamID {
|
||||||
|
optional uint64 steam_id = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_CmdKeyValues {
|
||||||
|
optional bytes data = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_RconServerDetails {
|
||||||
|
optional bytes token = 1;
|
||||||
|
optional string details = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgIPCAddress {
|
||||||
|
optional fixed64 computer_guid = 1;
|
||||||
|
optional uint32 process_id = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgServerPeer {
|
||||||
|
optional int32 player_slot = 1 [default = -1];
|
||||||
|
optional fixed64 steamid = 2;
|
||||||
|
optional .CMsgIPCAddress ipc = 3;
|
||||||
|
optional bool they_hear_you = 4;
|
||||||
|
optional bool you_hear_them = 5;
|
||||||
|
optional bool is_listenserver_host = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_PeerList {
|
||||||
|
repeated .CMsgServerPeer peer = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_ClearAllStringTables {
|
||||||
|
optional string mapname = 1;
|
||||||
|
optional bool create_tables_skipped = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message ProtoFlattenedSerializerField_t {
|
||||||
|
message polymorphic_field_t {
|
||||||
|
optional int32 polymorphic_field_serializer_name_sym = 1;
|
||||||
|
optional int32 polymorphic_field_serializer_version = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional int32 var_type_sym = 1;
|
||||||
|
optional int32 var_name_sym = 2;
|
||||||
|
optional int32 bit_count = 3;
|
||||||
|
optional float low_value = 4;
|
||||||
|
optional float high_value = 5;
|
||||||
|
optional int32 encode_flags = 6;
|
||||||
|
optional int32 field_serializer_name_sym = 7;
|
||||||
|
optional int32 field_serializer_version = 8;
|
||||||
|
optional int32 send_node_sym = 9;
|
||||||
|
optional int32 var_encoder_sym = 10;
|
||||||
|
repeated .ProtoFlattenedSerializerField_t.polymorphic_field_t polymorphic_types = 11;
|
||||||
|
}
|
||||||
|
|
||||||
|
message ProtoFlattenedSerializer_t {
|
||||||
|
optional int32 serializer_name_sym = 1;
|
||||||
|
optional int32 serializer_version = 2;
|
||||||
|
repeated int32 fields_index = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_FlattenedSerializer {
|
||||||
|
repeated .ProtoFlattenedSerializer_t serializers = 1;
|
||||||
|
repeated string symbols = 2;
|
||||||
|
repeated .ProtoFlattenedSerializerField_t fields = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_StopSound {
|
||||||
|
optional fixed32 guid = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CBidirMsg_RebroadcastGameEvent {
|
||||||
|
optional bool posttoserver = 1;
|
||||||
|
optional int32 buftype = 2;
|
||||||
|
optional uint32 clientbitcount = 3;
|
||||||
|
optional uint64 receivingclients = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CBidirMsg_RebroadcastSource {
|
||||||
|
optional int32 eventsource = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgServerNetworkStats {
|
||||||
|
message Port {
|
||||||
|
optional int32 port = 1;
|
||||||
|
optional string name = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message Player {
|
||||||
|
optional uint64 steamid = 1;
|
||||||
|
optional string remote_addr = 2;
|
||||||
|
optional int32 ping_stddev_ms = 3;
|
||||||
|
optional int32 ping_avg_ms = 4;
|
||||||
|
optional float packet_loss_pct = 5;
|
||||||
|
optional bool is_bot = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional bool dedicated = 1;
|
||||||
|
optional int32 cpu_usage = 2;
|
||||||
|
optional int32 memory_used_mb = 3;
|
||||||
|
optional int32 memory_free_mb = 4;
|
||||||
|
optional int32 uptime = 5;
|
||||||
|
optional int32 spawn_count = 6;
|
||||||
|
optional int32 num_clients = 8;
|
||||||
|
optional int32 num_bots = 9;
|
||||||
|
optional int32 num_spectators = 10;
|
||||||
|
optional int32 num_tv_relays = 11;
|
||||||
|
optional float fps = 12;
|
||||||
|
repeated .CMsgServerNetworkStats.Port ports = 17;
|
||||||
|
optional float avg_latency_out = 18;
|
||||||
|
optional float avg_latency_in = 19;
|
||||||
|
optional float avg_packets_out = 20;
|
||||||
|
optional float avg_packets_in = 21;
|
||||||
|
optional float avg_loss_out = 22;
|
||||||
|
optional float avg_loss_in = 23;
|
||||||
|
optional float avg_data_out = 24;
|
||||||
|
optional float avg_data_in = 25;
|
||||||
|
optional uint64 total_data_in = 26;
|
||||||
|
optional uint64 total_packets_in = 27;
|
||||||
|
optional uint64 total_data_out = 28;
|
||||||
|
optional uint64 total_packets_out = 29;
|
||||||
|
repeated .CMsgServerNetworkStats.Player players = 30;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_HltvReplay {
|
||||||
|
optional int32 delay = 1;
|
||||||
|
optional int32 primary_target = 2 [default = -1];
|
||||||
|
optional int32 replay_stop_at = 3;
|
||||||
|
optional int32 replay_start_at = 4;
|
||||||
|
optional int32 replay_slowdown_begin = 5;
|
||||||
|
optional int32 replay_slowdown_end = 6;
|
||||||
|
optional float replay_slowdown_rate = 7;
|
||||||
|
optional int32 reason = 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_HltvReplay {
|
||||||
|
optional int32 request = 1;
|
||||||
|
optional float slowdown_length = 2;
|
||||||
|
optional float slowdown_rate = 3;
|
||||||
|
optional int32 primary_target = 4 [default = -1];
|
||||||
|
optional float event_time = 5;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_Broadcast_Command {
|
||||||
|
optional string cmd = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CCLCMsg_HltvFixupOperatorTick {
|
||||||
|
optional int32 tick = 1;
|
||||||
|
optional bytes props_data = 2;
|
||||||
|
optional .CMsgVector origin = 3;
|
||||||
|
optional .CMsgQAngle eye_angles = 4;
|
||||||
|
optional int32 observer_mode = 5;
|
||||||
|
optional bool cameraman_scoreboard = 6;
|
||||||
|
optional int32 observer_target = 7;
|
||||||
|
optional .CMsgVector view_offset = 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_HltvFixupOperatorStatus {
|
||||||
|
optional uint32 mode = 1;
|
||||||
|
optional string override_operator_name = 2;
|
||||||
|
}
|
126
common/network_connection.proto
Normal file
126
common/network_connection.proto
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
import "google/protobuf/descriptor.proto";
|
||||||
|
|
||||||
|
extend .google.protobuf.EnumValueOptions {
|
||||||
|
optional string network_connection_token = 50500;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum ENetworkDisconnectionReason {
|
||||||
|
NETWORK_DISCONNECT_INVALID = 0;
|
||||||
|
NETWORK_DISCONNECT_SHUTDOWN = 1;
|
||||||
|
NETWORK_DISCONNECT_DISCONNECT_BY_USER = 2 [(network_connection_token) = "#GameUI_Disconnect_User"];
|
||||||
|
NETWORK_DISCONNECT_DISCONNECT_BY_SERVER = 3 [(network_connection_token) = "#GameUI_Disconnect_Server"];
|
||||||
|
NETWORK_DISCONNECT_LOST = 4 [(network_connection_token) = "#GameUI_Disconnect_ConnectionLost"];
|
||||||
|
NETWORK_DISCONNECT_OVERFLOW = 5 [(network_connection_token) = "#GameUI_Disconnect_ConnectionOverflow"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_BANNED = 6 [(network_connection_token) = "#GameUI_Disconnect_SteamIDBanned"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_INUSE = 7 [(network_connection_token) = "#GameUI_Disconnect_SteamIDInUse"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_TICKET = 8 [(network_connection_token) = "#GameUI_Disconnect_SteamTicket"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_LOGON = 9 [(network_connection_token) = "#GameUI_Disconnect_SteamLogon"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_AUTHCANCELLED = 10 [(network_connection_token) = "#GameUI_Disconnect_SteamLogon"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_AUTHALREADYUSED = 11 [(network_connection_token) = "#GameUI_Disconnect_SteamLogon"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_AUTHINVALID = 12 [(network_connection_token) = "#GameUI_Disconnect_SteamLogon"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_VACBANSTATE = 13 [(network_connection_token) = "#GameUI_Disconnect_SteamVAC"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_LOGGED_IN_ELSEWHERE = 14 [(network_connection_token) = "#GameUI_Disconnect_SteamInUse"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_VAC_CHECK_TIMEDOUT = 15 [(network_connection_token) = "#GameUI_Disconnect_SteamTimeOut"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_DROPPED = 16 [(network_connection_token) = "#GameUI_Disconnect_SteamDropped"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_OWNERSHIP = 17 [(network_connection_token) = "#GameUI_Disconnect_SteamOwnership"];
|
||||||
|
NETWORK_DISCONNECT_SERVERINFO_OVERFLOW = 18 [(network_connection_token) = "#GameUI_Disconnect_ServerInfoOverflow"];
|
||||||
|
NETWORK_DISCONNECT_TICKMSG_OVERFLOW = 19 [(network_connection_token) = "#GameUI_Disconnect_TickMessage"];
|
||||||
|
NETWORK_DISCONNECT_STRINGTABLEMSG_OVERFLOW = 20 [(network_connection_token) = "#GameUI_Disconnect_StringTableMessage"];
|
||||||
|
NETWORK_DISCONNECT_DELTAENTMSG_OVERFLOW = 21 [(network_connection_token) = "#GameUI_Disconnect_DeltaEntMessage"];
|
||||||
|
NETWORK_DISCONNECT_TEMPENTMSG_OVERFLOW = 22 [(network_connection_token) = "#GameUI_Disconnect_TempEntMessage"];
|
||||||
|
NETWORK_DISCONNECT_SOUNDSMSG_OVERFLOW = 23 [(network_connection_token) = "#GameUI_Disconnect_SoundsMessage"];
|
||||||
|
NETWORK_DISCONNECT_SNAPSHOTOVERFLOW = 24 [(network_connection_token) = "#GameUI_Disconnect_SnapshotOverflow"];
|
||||||
|
NETWORK_DISCONNECT_SNAPSHOTERROR = 25 [(network_connection_token) = "#GameUI_Disconnect_SnapshotError"];
|
||||||
|
NETWORK_DISCONNECT_RELIABLEOVERFLOW = 26 [(network_connection_token) = "#GameUI_Disconnect_ReliableOverflow"];
|
||||||
|
NETWORK_DISCONNECT_BADDELTATICK = 27 [(network_connection_token) = "#GameUI_Disconnect_BadClientDeltaTick"];
|
||||||
|
NETWORK_DISCONNECT_NOMORESPLITS = 28 [(network_connection_token) = "#GameUI_Disconnect_NoMoreSplits"];
|
||||||
|
NETWORK_DISCONNECT_TIMEDOUT = 29 [(network_connection_token) = "#GameUI_Disconnect_TimedOut"];
|
||||||
|
NETWORK_DISCONNECT_DISCONNECTED = 30 [(network_connection_token) = "#GameUI_Disconnect_Disconnected"];
|
||||||
|
NETWORK_DISCONNECT_LEAVINGSPLIT = 31 [(network_connection_token) = "#GameUI_Disconnect_LeavingSplit"];
|
||||||
|
NETWORK_DISCONNECT_DIFFERENTCLASSTABLES = 32 [(network_connection_token) = "#GameUI_Disconnect_DifferentClassTables"];
|
||||||
|
NETWORK_DISCONNECT_BADRELAYPASSWORD = 33 [(network_connection_token) = "#GameUI_Disconnect_BadRelayPassword"];
|
||||||
|
NETWORK_DISCONNECT_BADSPECTATORPASSWORD = 34 [(network_connection_token) = "#GameUI_Disconnect_BadSpectatorPassword"];
|
||||||
|
NETWORK_DISCONNECT_HLTVRESTRICTED = 35 [(network_connection_token) = "#GameUI_Disconnect_HLTVRestricted"];
|
||||||
|
NETWORK_DISCONNECT_NOSPECTATORS = 36 [(network_connection_token) = "#GameUI_Disconnect_NoSpectators"];
|
||||||
|
NETWORK_DISCONNECT_HLTVUNAVAILABLE = 37 [(network_connection_token) = "#GameUI_Disconnect_HLTVUnavailable"];
|
||||||
|
NETWORK_DISCONNECT_HLTVSTOP = 38 [(network_connection_token) = "#GameUI_Disconnect_HLTVStop"];
|
||||||
|
NETWORK_DISCONNECT_KICKED = 39 [(network_connection_token) = "#GameUI_Disconnect_Kicked"];
|
||||||
|
NETWORK_DISCONNECT_BANADDED = 40 [(network_connection_token) = "#GameUI_Disconnect_BanAdded"];
|
||||||
|
NETWORK_DISCONNECT_KICKBANADDED = 41 [(network_connection_token) = "#GameUI_Disconnect_KickBanAdded"];
|
||||||
|
NETWORK_DISCONNECT_HLTVDIRECT = 42 [(network_connection_token) = "#GameUI_Disconnect_HLTVDirect"];
|
||||||
|
NETWORK_DISCONNECT_PURESERVER_CLIENTEXTRA = 43 [(network_connection_token) = "#GameUI_Disconnect_PureServer_ClientExtra"];
|
||||||
|
NETWORK_DISCONNECT_PURESERVER_MISMATCH = 44 [(network_connection_token) = "#GameUI_Disconnect_PureServer_Mismatch"];
|
||||||
|
NETWORK_DISCONNECT_USERCMD = 45 [(network_connection_token) = "#GameUI_Disconnect_UserCmd"];
|
||||||
|
NETWORK_DISCONNECT_REJECTED_BY_GAME = 46 [(network_connection_token) = "#GameUI_Disconnect_RejectedByGame"];
|
||||||
|
NETWORK_DISCONNECT_MESSAGE_PARSE_ERROR = 47 [(network_connection_token) = "#GameUI_Disconnect_MessageParseError"];
|
||||||
|
NETWORK_DISCONNECT_INVALID_MESSAGE_ERROR = 48 [(network_connection_token) = "#GameUI_Disconnect_InvalidMessageError"];
|
||||||
|
NETWORK_DISCONNECT_BAD_SERVER_PASSWORD = 49 [(network_connection_token) = "#GameUI_Disconnect_BadServerPassword"];
|
||||||
|
NETWORK_DISCONNECT_DIRECT_CONNECT_RESERVATION = 50;
|
||||||
|
NETWORK_DISCONNECT_CONNECTION_FAILURE = 51 [(network_connection_token) = "#GameUI_Disconnect_ConnectionFailure"];
|
||||||
|
NETWORK_DISCONNECT_NO_PEER_GROUP_HANDLERS = 52 [(network_connection_token) = "#GameUI_Disconnect_NoPeerGroupHandlers"];
|
||||||
|
NETWORK_DISCONNECT_RECONNECTION = 53;
|
||||||
|
NETWORK_DISCONNECT_LOOPSHUTDOWN = 54 [(network_connection_token) = "#GameUI_Disconnect_LoopShutdown"];
|
||||||
|
NETWORK_DISCONNECT_LOOPDEACTIVATE = 55 [(network_connection_token) = "#GameUI_Disconnect_LoopDeactivate"];
|
||||||
|
NETWORK_DISCONNECT_HOST_ENDGAME = 56 [(network_connection_token) = "#GameUI_Disconnect_Host_EndGame"];
|
||||||
|
NETWORK_DISCONNECT_LOOP_LEVELLOAD_ACTIVATE = 57 [(network_connection_token) = "#GameUI_Disconnect_LoopLevelLoadActivate"];
|
||||||
|
NETWORK_DISCONNECT_CREATE_SERVER_FAILED = 58 [(network_connection_token) = "#GameUI_Disconnect_CreateServerFailed"];
|
||||||
|
NETWORK_DISCONNECT_EXITING = 59 [(network_connection_token) = "#GameUI_Disconnect_ExitingEngine"];
|
||||||
|
NETWORK_DISCONNECT_REQUEST_HOSTSTATE_IDLE = 60 [(network_connection_token) = "#GameUI_Disconnect_Request_HSIdle"];
|
||||||
|
NETWORK_DISCONNECT_REQUEST_HOSTSTATE_HLTVRELAY = 61 [(network_connection_token) = "#GameUI_Disconnect_Request_HLTVRelay"];
|
||||||
|
NETWORK_DISCONNECT_CLIENT_CONSISTENCY_FAIL = 62 [(network_connection_token) = "#GameUI_ClientConsistencyFail"];
|
||||||
|
NETWORK_DISCONNECT_CLIENT_UNABLE_TO_CRC_MAP = 63 [(network_connection_token) = "#GameUI_ClientUnableToCRCMap"];
|
||||||
|
NETWORK_DISCONNECT_CLIENT_NO_MAP = 64 [(network_connection_token) = "#GameUI_ClientNoMap"];
|
||||||
|
NETWORK_DISCONNECT_CLIENT_DIFFERENT_MAP = 65 [(network_connection_token) = "#GameUI_ClientDifferentMap"];
|
||||||
|
NETWORK_DISCONNECT_SERVER_REQUIRES_STEAM = 66 [(network_connection_token) = "#GameUI_ServerRequireSteams"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_DENY_MISC = 67 [(network_connection_token) = "#GameUI_Disconnect_SteamDeny_Misc"];
|
||||||
|
NETWORK_DISCONNECT_STEAM_DENY_BAD_ANTI_CHEAT = 68 [(network_connection_token) = "#GameUI_Disconnect_SteamDeny_BadAntiCheat"];
|
||||||
|
NETWORK_DISCONNECT_SERVER_SHUTDOWN = 69 [(network_connection_token) = "#GameUI_Disconnect_ServerShutdown"];
|
||||||
|
NETWORK_DISCONNECT_REPLAY_INCOMPATIBLE = 71 [(network_connection_token) = "#GameUI_Disconnect_ReplayIncompatible"];
|
||||||
|
NETWORK_DISCONNECT_CONNECT_REQUEST_TIMEDOUT = 72 [(network_connection_token) = "#GameUI_Disconnect_ConnectionTimedout"];
|
||||||
|
NETWORK_DISCONNECT_SERVER_INCOMPATIBLE = 73 [(network_connection_token) = "#GameUI_Disconnect_ServerIncompatible"];
|
||||||
|
NETWORK_DISCONNECT_LOCALPROBLEM_MANYRELAYS = 74 [(network_connection_token) = "#GameUI_Disconnect_LocalProblem_ManyRelays"];
|
||||||
|
NETWORK_DISCONNECT_LOCALPROBLEM_HOSTEDSERVERPRIMARYRELAY = 75 [(network_connection_token) = "#GameUI_Disconnect_LocalProblem_HostedServerPrimaryRelay"];
|
||||||
|
NETWORK_DISCONNECT_LOCALPROBLEM_NETWORKCONFIG = 76 [(network_connection_token) = "#GameUI_Disconnect_LocalProblem_NetworkConfig"];
|
||||||
|
NETWORK_DISCONNECT_LOCALPROBLEM_OTHER = 77 [(network_connection_token) = "#GameUI_Disconnect_LocalProblem_Other"];
|
||||||
|
NETWORK_DISCONNECT_REMOTE_TIMEOUT = 79 [(network_connection_token) = "#GameUI_Disconnect_RemoteProblem_Timeout"];
|
||||||
|
NETWORK_DISCONNECT_REMOTE_TIMEOUT_CONNECTING = 80 [(network_connection_token) = "#GameUI_Disconnect_RemoteProblem_TimeoutConnecting"];
|
||||||
|
NETWORK_DISCONNECT_REMOTE_OTHER = 81 [(network_connection_token) = "#GameUI_Disconnect_RemoteProblem_Other"];
|
||||||
|
NETWORK_DISCONNECT_REMOTE_BADCRYPT = 82 [(network_connection_token) = "#GameUI_Disconnect_RemoteProblem_BadCrypt"];
|
||||||
|
NETWORK_DISCONNECT_REMOTE_CERTNOTTRUSTED = 83 [(network_connection_token) = "#GameUI_Disconnect_RemoteProblem_BadCert"];
|
||||||
|
NETWORK_DISCONNECT_UNUSUAL = 84 [(network_connection_token) = "#GameUI_Disconnect_Unusual"];
|
||||||
|
NETWORK_DISCONNECT_INTERNAL_ERROR = 85 [(network_connection_token) = "#GameUI_Disconnect_InternalError"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_BADCHALLENGE = 128 [(network_connection_token) = "#GameUI_ServerRejectBadChallenge"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_NOLOBBY = 129 [(network_connection_token) = "#GameUI_ServerNoLobby"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_BACKGROUND_MAP = 130 [(network_connection_token) = "#Valve_Reject_Background_Map"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_SINGLE_PLAYER = 131 [(network_connection_token) = "#Valve_Reject_Single_Player"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_HIDDEN_GAME = 132 [(network_connection_token) = "#Valve_Reject_Hidden_Game"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_LANRESTRICT = 133 [(network_connection_token) = "#GameUI_ServerRejectLANRestrict"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_BADPASSWORD = 134 [(network_connection_token) = "#GameUI_ServerRejectBadPassword"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_SERVERFULL = 135 [(network_connection_token) = "#GameUI_ServerRejectServerFull"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_INVALIDRESERVATION = 136 [(network_connection_token) = "#GameUI_ServerRejectInvalidReservation"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_FAILEDCHANNEL = 137 [(network_connection_token) = "#GameUI_ServerRejectFailedChannel"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_CONNECT_FROM_LOBBY = 138 [(network_connection_token) = "#Valve_Reject_Connect_From_Lobby"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_RESERVED_FOR_LOBBY = 139 [(network_connection_token) = "#Valve_Reject_Reserved_For_Lobby"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_INVALIDKEYLENGTH = 140 [(network_connection_token) = "#GameUI_ServerReject_InvalidKeyLength"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_OLDPROTOCOL = 141 [(network_connection_token) = "#GameUI_ServerRejectOldProtocol"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_NEWPROTOCOL = 142 [(network_connection_token) = "#GameUI_ServerRejectNewProtocol"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_INVALIDCONNECTION = 143 [(network_connection_token) = "#GameUI_ServerRejectInvalidConnection"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_INVALIDCERTLEN = 144 [(network_connection_token) = "#GameUI_ServerRejectInvalidCertLen"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_INVALIDSTEAMCERTLEN = 145 [(network_connection_token) = "#GameUI_ServerRejectInvalidSteamCertLen"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_STEAM = 146 [(network_connection_token) = "#GameUI_ServerRejectSteam"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_SERVERAUTHDISABLED = 147 [(network_connection_token) = "#GameUI_ServerAuthDisabled"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_SERVERCDKEYAUTHINVALID = 148 [(network_connection_token) = "#GameUI_ServerCDKeyAuthInvalid"];
|
||||||
|
NETWORK_DISCONNECT_REJECT_BANNED = 149 [(network_connection_token) = "#GameUI_ServerRejectBanned"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_TEAMKILLING = 150 [(network_connection_token) = "#Player_DisconnectReason_TeamKilling"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_TK_START = 151 [(network_connection_token) = "#Player_DisconnectReason_TK_Start"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_UNTRUSTEDACCOUNT = 152 [(network_connection_token) = "#Player_DisconnectReason_UntrustedAccount"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_CONVICTEDACCOUNT = 153 [(network_connection_token) = "#Player_DisconnectReason_ConvictedAccount"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_COMPETITIVECOOLDOWN = 154 [(network_connection_token) = "#Player_DisconnectReason_CompetitiveCooldown"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_TEAMHURTING = 155 [(network_connection_token) = "#Player_DisconnectReason_TeamHurting"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_HOSTAGEKILLING = 156 [(network_connection_token) = "#Player_DisconnectReason_HostageKilling"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_VOTEDOFF = 157 [(network_connection_token) = "#Player_DisconnectReason_VotedOff"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_IDLE = 158 [(network_connection_token) = "#Player_DisconnectReason_Idle"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_SUICIDE = 159 [(network_connection_token) = "#Player_DisconnectReason_Suicide"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_NOSTEAMLOGIN = 160 [(network_connection_token) = "#Player_DisconnectReason_NoSteamLogin"];
|
||||||
|
NETWORK_DISCONNECT_KICKED_NOSTEAMTICKET = 161 [(network_connection_token) = "#Player_DisconnectReason_NoSteamTicket"];
|
||||||
|
}
|
244
common/networkbasetypes.proto
Normal file
244
common/networkbasetypes.proto
Normal file
@ -0,0 +1,244 @@
|
|||||||
|
import "network_connection.proto";
|
||||||
|
|
||||||
|
enum SignonState_t {
|
||||||
|
SIGNONSTATE_NONE = 0;
|
||||||
|
SIGNONSTATE_CHALLENGE = 1;
|
||||||
|
SIGNONSTATE_CONNECTED = 2;
|
||||||
|
SIGNONSTATE_NEW = 3;
|
||||||
|
SIGNONSTATE_PRESPAWN = 4;
|
||||||
|
SIGNONSTATE_SPAWN = 5;
|
||||||
|
SIGNONSTATE_FULL = 6;
|
||||||
|
SIGNONSTATE_CHANGELEVEL = 7;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum NET_Messages {
|
||||||
|
net_NOP = 0;
|
||||||
|
net_Disconnect = 1;
|
||||||
|
net_SplitScreenUser = 3;
|
||||||
|
net_Tick = 4;
|
||||||
|
net_StringCmd = 5;
|
||||||
|
net_SetConVar = 6;
|
||||||
|
net_SignonState = 7;
|
||||||
|
net_SpawnGroup_Load = 8;
|
||||||
|
net_SpawnGroup_ManifestUpdate = 9;
|
||||||
|
net_SpawnGroup_SetCreationTick = 11;
|
||||||
|
net_SpawnGroup_Unload = 12;
|
||||||
|
net_SpawnGroup_LoadCompleted = 13;
|
||||||
|
net_DebugOverlay = 15;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum SpawnGroupFlags_t {
|
||||||
|
SPAWN_GROUP_LOAD_ENTITIES_FROM_SAVE = 1;
|
||||||
|
SPAWN_GROUP_DONT_SPAWN_ENTITIES = 2;
|
||||||
|
SPAWN_GROUP_SYNCHRONOUS_SPAWN = 4;
|
||||||
|
SPAWN_GROUP_IS_INITIAL_SPAWN_GROUP = 8;
|
||||||
|
SPAWN_GROUP_CREATE_CLIENT_ONLY_ENTITIES = 16;
|
||||||
|
SPAWN_GROUP_BLOCK_UNTIL_LOADED = 64;
|
||||||
|
SPAWN_GROUP_LOAD_STREAMING_DATA = 128;
|
||||||
|
SPAWN_GROUP_CREATE_NEW_SCENE_WORLD = 256;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgVector {
|
||||||
|
optional float x = 1;
|
||||||
|
optional float y = 2;
|
||||||
|
optional float z = 3;
|
||||||
|
optional float w = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgVector2D {
|
||||||
|
optional float x = 1;
|
||||||
|
optional float y = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgQAngle {
|
||||||
|
optional float x = 1;
|
||||||
|
optional float y = 2;
|
||||||
|
optional float z = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgQuaternion {
|
||||||
|
optional float x = 1;
|
||||||
|
optional float y = 2;
|
||||||
|
optional float z = 3;
|
||||||
|
optional float w = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgTransform {
|
||||||
|
optional .CMsgVector position = 1;
|
||||||
|
optional float scale = 2;
|
||||||
|
optional .CMsgQuaternion orientation = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgRGBA {
|
||||||
|
optional int32 r = 1;
|
||||||
|
optional int32 g = 2;
|
||||||
|
optional int32 b = 3;
|
||||||
|
optional int32 a = 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsgPlayerInfo {
|
||||||
|
optional string name = 1;
|
||||||
|
optional fixed64 xuid = 2;
|
||||||
|
optional int32 userid = 3;
|
||||||
|
optional fixed64 steamid = 4;
|
||||||
|
optional bool fakeplayer = 5;
|
||||||
|
optional bool ishltv = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CEntityMsg {
|
||||||
|
optional uint32 target_entity = 1 [default = 16777215];
|
||||||
|
}
|
||||||
|
|
||||||
|
message CMsg_CVars {
|
||||||
|
message CVar {
|
||||||
|
optional string name = 1;
|
||||||
|
optional string value = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
repeated .CMsg_CVars.CVar cvars = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_NOP {
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SplitScreenUser {
|
||||||
|
optional int32 slot = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_Disconnect {
|
||||||
|
optional .ENetworkDisconnectionReason reason = 2 [default = NETWORK_DISCONNECT_INVALID];
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_Tick {
|
||||||
|
optional uint32 tick = 1;
|
||||||
|
optional uint32 host_frametime = 2;
|
||||||
|
optional uint32 host_frametime_std_deviation = 3;
|
||||||
|
optional uint32 host_computationtime = 4;
|
||||||
|
optional uint32 host_computationtime_std_deviation = 5;
|
||||||
|
optional uint32 host_framestarttime_std_deviation = 6;
|
||||||
|
optional uint32 host_loss = 7;
|
||||||
|
optional uint32 host_unfiltered_frametime = 8;
|
||||||
|
optional uint32 hltv_replay_flags = 9;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_StringCmd {
|
||||||
|
optional string command = 1;
|
||||||
|
optional uint32 prediction_sync = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SetConVar {
|
||||||
|
optional .CMsg_CVars convars = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SignonState {
|
||||||
|
optional .SignonState_t signon_state = 1 [default = SIGNONSTATE_NONE];
|
||||||
|
optional uint32 spawn_count = 2;
|
||||||
|
optional uint32 num_server_players = 3;
|
||||||
|
repeated string players_networkids = 4;
|
||||||
|
optional string map_name = 5;
|
||||||
|
optional string addons = 6;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_GameEvent {
|
||||||
|
message key_t {
|
||||||
|
optional int32 type = 1;
|
||||||
|
optional string val_string = 2;
|
||||||
|
optional float val_float = 3;
|
||||||
|
optional int32 val_long = 4;
|
||||||
|
optional int32 val_short = 5;
|
||||||
|
optional int32 val_byte = 6;
|
||||||
|
optional bool val_bool = 7;
|
||||||
|
optional uint64 val_uint64 = 8;
|
||||||
|
}
|
||||||
|
|
||||||
|
optional string event_name = 1;
|
||||||
|
optional int32 eventid = 2;
|
||||||
|
repeated .CSVCMsg_GameEvent.key_t keys = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsgList_GameEvents {
|
||||||
|
message event_t {
|
||||||
|
optional int32 tick = 1;
|
||||||
|
optional .CSVCMsg_GameEvent event = 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
repeated .CSVCMsgList_GameEvents.event_t events = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SpawnGroup_Load {
|
||||||
|
optional string worldname = 1;
|
||||||
|
optional string entitylumpname = 2;
|
||||||
|
optional string entityfiltername = 3;
|
||||||
|
optional uint32 spawngrouphandle = 4;
|
||||||
|
optional uint32 spawngroupownerhandle = 5;
|
||||||
|
optional .CMsgVector world_offset_pos = 6;
|
||||||
|
optional .CMsgQAngle world_offset_angle = 7;
|
||||||
|
optional bytes spawngroupmanifest = 8;
|
||||||
|
optional uint32 flags = 9;
|
||||||
|
optional int32 tickcount = 10;
|
||||||
|
optional bool manifestincomplete = 11;
|
||||||
|
optional string localnamefixup = 12;
|
||||||
|
optional string parentnamefixup = 13;
|
||||||
|
optional int32 manifestloadpriority = 14;
|
||||||
|
optional uint32 worldgroupid = 15;
|
||||||
|
optional uint32 creationsequence = 16;
|
||||||
|
optional string savegamefilename = 17;
|
||||||
|
optional uint32 spawngroupparenthandle = 18;
|
||||||
|
optional bool leveltransition = 19;
|
||||||
|
optional string worldgroupname = 20;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SpawnGroup_ManifestUpdate {
|
||||||
|
optional uint32 spawngrouphandle = 1;
|
||||||
|
optional bytes spawngroupmanifest = 2;
|
||||||
|
optional bool manifestincomplete = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SpawnGroup_SetCreationTick {
|
||||||
|
optional uint32 spawngrouphandle = 1;
|
||||||
|
optional int32 tickcount = 2;
|
||||||
|
optional uint32 creationsequence = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SpawnGroup_Unload {
|
||||||
|
optional uint32 spawngrouphandle = 1;
|
||||||
|
optional uint32 flags = 2;
|
||||||
|
optional int32 tickcount = 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_SpawnGroup_LoadCompleted {
|
||||||
|
optional uint32 spawngrouphandle = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CSVCMsg_GameSessionConfiguration {
|
||||||
|
optional bool is_multiplayer = 1;
|
||||||
|
optional bool is_loadsavegame = 2;
|
||||||
|
optional bool is_background_map = 3;
|
||||||
|
optional bool is_headless = 4;
|
||||||
|
optional uint32 min_client_limit = 5;
|
||||||
|
optional uint32 max_client_limit = 6;
|
||||||
|
optional uint32 max_clients = 7;
|
||||||
|
optional fixed32 tick_interval = 8;
|
||||||
|
optional string hostname = 9;
|
||||||
|
optional string savegamename = 10;
|
||||||
|
optional string s1_mapname = 11;
|
||||||
|
optional string gamemode = 12;
|
||||||
|
optional string server_ip_address = 13;
|
||||||
|
optional bytes data = 14;
|
||||||
|
optional bool is_localonly = 15;
|
||||||
|
optional bool no_steam_server = 19;
|
||||||
|
optional bool is_transition = 16;
|
||||||
|
optional string previouslevel = 17;
|
||||||
|
optional string landmarkname = 18;
|
||||||
|
}
|
||||||
|
|
||||||
|
message CNETMsg_DebugOverlay {
|
||||||
|
optional int32 etype = 1;
|
||||||
|
repeated .CMsgVector vectors = 2;
|
||||||
|
repeated .CMsgRGBA colors = 3;
|
||||||
|
repeated float dimensions = 4;
|
||||||
|
repeated float times = 5;
|
||||||
|
repeated bool bools = 6;
|
||||||
|
repeated uint64 uint64s = 7;
|
||||||
|
repeated string strings = 8;
|
||||||
|
}
|
@ -1,593 +0,0 @@
|
|||||||
2014-10-20 version 2.6.1:
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Added atomicops support for Solaris.
|
|
||||||
* Released memory allocated by InitializeDefaultRepeatedFields() and
|
|
||||||
GetEmptyString(). Some memory sanitizers reported them as memory leaks.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Updated DynamicMessage.setField() to handle repeated enum values
|
|
||||||
correctly.
|
|
||||||
* Fixed a bug that caused NullPointerException to be thrown when
|
|
||||||
converting manually constructed FileDescriptorProto to
|
|
||||||
FileDescriptor.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Fixed WhichOneof() to work with de-serialized protobuf messages.
|
|
||||||
* Fixed a missing file problem of Python C++ implementation.
|
|
||||||
|
|
||||||
2014-08-15 version 2.6.0:
|
|
||||||
|
|
||||||
General
|
|
||||||
* Added oneofs(unions) feature. Fields in the same oneof will share
|
|
||||||
memory and at most one field can be set at the same time. Use the
|
|
||||||
oneof keyword to define a oneof like:
|
|
||||||
message SampleMessage {
|
|
||||||
oneof test_oneof {
|
|
||||||
string name = 4;
|
|
||||||
YourMessage sub_message = 9;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
* Files, services, enums, messages, methods and enum values can be marked
|
|
||||||
as deprecated now.
|
|
||||||
* Added Support for list values, including lists of mesaages, when
|
|
||||||
parsing text-formatted protos in C++ and Java.
|
|
||||||
For example: foo: [1, 2, 3]
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Enhanced customization on TestFormat printing.
|
|
||||||
* Added SwapFields() in reflection API to swap a subset of fields.
|
|
||||||
Added SetAllocatedMessage() in reflection API.
|
|
||||||
* Repeated primitive extensions are now packable. The
|
|
||||||
[packed=true] option only affects serializers. Therefore, it is
|
|
||||||
possible to switch a repeated extension field to packed format
|
|
||||||
without breaking backwards-compatibility.
|
|
||||||
* Various speed optimizations.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* writeTo() method in ByteString can now write a substring to an
|
|
||||||
output stream. Added endWith() method for ByteString.
|
|
||||||
* ByteString and ByteBuffer are now supported in CodedInputStream
|
|
||||||
and CodedOutputStream.
|
|
||||||
* java_generate_equals_and_hash can now be used with the LITE_RUNTIME.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* A new C++-backed extension module (aka "cpp api v2") that replaces the
|
|
||||||
old ("cpp api v1") one. Much faster than the pure Python code. This one
|
|
||||||
resolves many bugs and is recommended for general use over the
|
|
||||||
pure Python when possible.
|
|
||||||
* Descriptors now have enum_types_by_name and extension_types_by_name dict
|
|
||||||
attributes.
|
|
||||||
* Support for Python 3.
|
|
||||||
|
|
||||||
2013-02-27 version 2.5.0:
|
|
||||||
|
|
||||||
General
|
|
||||||
* New notion "import public" that allows a proto file to forward the content
|
|
||||||
it imports to its importers. For example,
|
|
||||||
// foo.proto
|
|
||||||
import public "bar.proto";
|
|
||||||
import "baz.proto";
|
|
||||||
|
|
||||||
// qux.proto
|
|
||||||
import "foo.proto";
|
|
||||||
// Stuff defined in bar.proto may be used in this file, but stuff from
|
|
||||||
// baz.proto may NOT be used without importing it explicitly.
|
|
||||||
This is useful for moving proto files. To move a proto file, just leave
|
|
||||||
a single "import public" in the old proto file.
|
|
||||||
* New enum option "allow_alias" that specifies whether different symbols can
|
|
||||||
be assigned the same numeric value. Default value is "true". Setting it to
|
|
||||||
false causes the compiler to reject enum definitions where multiple symbols
|
|
||||||
have the same numeric value.
|
|
||||||
Note: We plan to flip the default value to "false" in a future release.
|
|
||||||
Projects using enum aliases should set the option to "true" in their .proto
|
|
||||||
files.
|
|
||||||
|
|
||||||
C++
|
|
||||||
* New generated method set_allocated_foo(Type* foo) for message and string
|
|
||||||
fields. This method allows you to set the field to a pre-allocated object
|
|
||||||
and the containing message takes the ownership of that object.
|
|
||||||
* Added SetAllocatedExtension() and ReleaseExtension() to extensions API.
|
|
||||||
* Custom options are now formatted correctly when descriptors are printed in
|
|
||||||
text format.
|
|
||||||
* Various speed optimizations.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Comments in proto files are now collected and put into generated code as
|
|
||||||
comments for corresponding classes and data members.
|
|
||||||
* Added Parser to parse directly into messages without a Builder. For
|
|
||||||
example,
|
|
||||||
Foo foo = Foo.PARSER.ParseFrom(input);
|
|
||||||
Using Parser is ~25% faster than using Builder to parse messages.
|
|
||||||
* Added getters/setters to access the underlying ByteString of a string field
|
|
||||||
directly.
|
|
||||||
* ByteString now supports more operations: substring(), prepend(), and
|
|
||||||
append(). The implementation of ByteString uses a binary tree structure
|
|
||||||
to support these operations efficiently.
|
|
||||||
* New method findInitializationErrors() that lists all missing required
|
|
||||||
fields.
|
|
||||||
* Various code size and speed optimizations.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Added support for dynamic message creation. DescriptorDatabase,
|
|
||||||
DescriptorPool, and MessageFactory work like their C++ couterparts to
|
|
||||||
simplify Descriptor construction from *DescriptorProtos, and MessageFactory
|
|
||||||
provides a message instance from a Descriptor.
|
|
||||||
* Added pickle support for protobuf messages.
|
|
||||||
* Unknown fields are now preserved after parsing.
|
|
||||||
* Fixed bug where custom options were not correctly populated. Custom
|
|
||||||
options can be accessed now.
|
|
||||||
* Added EnumTypeWrapper that provides better accessibility to enum types.
|
|
||||||
* Added ParseMessage(descriptor, bytes) to generate a new Message instance
|
|
||||||
from a descriptor and a byte string.
|
|
||||||
|
|
||||||
2011-05-01 version 2.4.1:
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Fixed the frendship problem for old compilers to make the library now gcc 3
|
|
||||||
compatible again.
|
|
||||||
* Fixed vcprojects/extract_includes.bat to extract compiler/plugin.h.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Removed usages of JDK 1.6 only features to make the library now JDK 1.5
|
|
||||||
compatible again.
|
|
||||||
* Fixed a bug about negative enum values.
|
|
||||||
* serialVersionUID is now defined in generated messages for java serializing.
|
|
||||||
* Fixed protoc to use java.lang.Object, which makes "Object" now a valid
|
|
||||||
message name again.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Experimental C++ implementation now requires C++ protobuf library installed.
|
|
||||||
See the README.txt in the python directory for details.
|
|
||||||
|
|
||||||
2011-02-02 version 2.4.0:
|
|
||||||
|
|
||||||
General
|
|
||||||
* The RPC (cc|java|py)_generic_services default value is now false instead of
|
|
||||||
true.
|
|
||||||
* Custom options can have aggregate types. For example,
|
|
||||||
message MyOption {
|
|
||||||
optional string comment = 1;
|
|
||||||
optional string author = 2;
|
|
||||||
}
|
|
||||||
extend google.protobuf.FieldOptions {
|
|
||||||
optional MyOption myoption = 12345;
|
|
||||||
}
|
|
||||||
This option can now be set as follows:
|
|
||||||
message SomeType {
|
|
||||||
optional int32 field = 1 [(myoption) = { comment:'x' author:'y' }];
|
|
||||||
}
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Various speed and code size optimizations.
|
|
||||||
* Added a release_foo() method on string and message fields.
|
|
||||||
* Fixed gzip_output_stream sub-stream handling.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Builders now maintain sub-builders for sub-messages. Use getFooBuilder() to
|
|
||||||
get the builder for the sub-message "foo". This allows you to repeatedly
|
|
||||||
modify deeply-nested sub-messages without rebuilding them.
|
|
||||||
* Builder.build() no longer invalidates the Builder for generated messages
|
|
||||||
(You may continue to modify it and then build another message).
|
|
||||||
* Code generator will generate efficient equals() and hashCode()
|
|
||||||
implementations if new option java_generate_equals_and_hash is enabled.
|
|
||||||
(Otherwise, reflection-based implementations are used.)
|
|
||||||
* Generated messages now implement Serializable.
|
|
||||||
* Fields with [deprecated=true] will be marked with @Deprecated in Java.
|
|
||||||
* Added lazy conversion of UTF-8 encoded strings to String objects to improve
|
|
||||||
performance.
|
|
||||||
* Various optimizations.
|
|
||||||
* Enum value can be accessed directly, instead of calling getNumber() on the
|
|
||||||
enum member.
|
|
||||||
* For each enum value, an integer constant is also generated with the suffix
|
|
||||||
_VALUE.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Added an experimental C++ implementation for Python messages via a Python
|
|
||||||
extension. Implementation type is controlled by an environment variable
|
|
||||||
PROTOCOL_BUFFERS_PYTHON_IMPLEMENTATION (valid values: "cpp" and "python")
|
|
||||||
The default value is currently "python" but will be changed to "cpp" in
|
|
||||||
future release.
|
|
||||||
* Improved performance on message instantiation significantly.
|
|
||||||
Most of the work on message instantiation is done just once per message
|
|
||||||
class, instead of once per message instance.
|
|
||||||
* Improved performance on text message parsing.
|
|
||||||
* Allow add() to forward keyword arguments to the concrete class.
|
|
||||||
E.g. instead of
|
|
||||||
item = repeated_field.add()
|
|
||||||
item.foo = bar
|
|
||||||
item.baz = quux
|
|
||||||
You can do:
|
|
||||||
repeated_field.add(foo=bar, baz=quux)
|
|
||||||
* Added a sort() interface to the BaseContainer.
|
|
||||||
* Added an extend() method to repeated composite fields.
|
|
||||||
* Added UTF8 debug string support.
|
|
||||||
|
|
||||||
2010-01-08 version 2.3.0:
|
|
||||||
|
|
||||||
General
|
|
||||||
* Parsers for repeated numeric fields now always accept both packed and
|
|
||||||
unpacked input. The [packed=true] option only affects serializers.
|
|
||||||
Therefore, it is possible to switch a field to packed format without
|
|
||||||
breaking backwards-compatibility -- as long as all parties are using
|
|
||||||
protobuf 2.3.0 or above, at least.
|
|
||||||
* The generic RPC service code generated by the C++, Java, and Python
|
|
||||||
generators can be disabled via file options:
|
|
||||||
option cc_generic_services = false;
|
|
||||||
option java_generic_services = false;
|
|
||||||
option py_generic_services = false;
|
|
||||||
This allows plugins to generate alternative code, possibly specific to some
|
|
||||||
particular RPC implementation.
|
|
||||||
|
|
||||||
protoc
|
|
||||||
* Now supports a plugin system for code generators. Plugins can generate
|
|
||||||
code for new languages or inject additional code into the output of other
|
|
||||||
code generators. Plugins are just binaries which accept a protocol buffer
|
|
||||||
on stdin and write a protocol buffer to stdout, so they may be written in
|
|
||||||
any language. See src/google/protobuf/compiler/plugin.proto.
|
|
||||||
**WARNING**: Plugins are experimental. The interface may change in a
|
|
||||||
future version.
|
|
||||||
* If the output location ends in .zip or .jar, protoc will write its output
|
|
||||||
to a zip/jar archive instead of a directory. For example:
|
|
||||||
protoc --java_out=myproto_srcs.jar --python_out=myproto.zip myproto.proto
|
|
||||||
Currently the archive contents are not compressed, though this could change
|
|
||||||
in the future.
|
|
||||||
* inf, -inf, and nan can now be used as default values for float and double
|
|
||||||
fields.
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Various speed and code size optimizations.
|
|
||||||
* DynamicMessageFactory is now fully thread-safe.
|
|
||||||
* Message::Utf8DebugString() method is like DebugString() but avoids escaping
|
|
||||||
UTF-8 bytes.
|
|
||||||
* Compiled-in message types can now contain dynamic extensions, through use
|
|
||||||
of CodedInputStream::SetExtensionRegistry().
|
|
||||||
* Now compiles shared libraries (DLLs) by default on Cygwin and MinGW, to
|
|
||||||
match other platforms. Use --disable-shared to avoid this.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* parseDelimitedFrom() and mergeDelimitedFrom() now detect EOF and return
|
|
||||||
false/null instead of throwing an exception.
|
|
||||||
* Fixed some initialization ordering bugs.
|
|
||||||
* Fixes for OpenJDK 7.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* 10-25 times faster than 2.2.0, still pure-Python.
|
|
||||||
* Calling a mutating method on a sub-message always instantiates the message
|
|
||||||
in its parent even if the mutating method doesn't actually mutate anything
|
|
||||||
(e.g. parsing from an empty string).
|
|
||||||
* Expanded descriptors a bit.
|
|
||||||
|
|
||||||
2009-08-11 version 2.2.0:
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Lite mode: The "optimize_for = LITE_RUNTIME" option causes the compiler
|
|
||||||
to generate code which only depends libprotobuf-lite, which is much smaller
|
|
||||||
than libprotobuf but lacks descriptors, reflection, and some other features.
|
|
||||||
* Fixed bug where Message.Swap(Message) was only implemented for
|
|
||||||
optimize_for_speed. Swap now properly implemented in both modes
|
|
||||||
(Issue 91).
|
|
||||||
* Added RemoveLast and SwapElements(index1, index2) to Reflection
|
|
||||||
interface for repeated elements.
|
|
||||||
* Added Swap(Message) to Reflection interface.
|
|
||||||
* Floating-point literals in generated code that are intended to be
|
|
||||||
single-precision now explicitly have 'f' suffix to avoid pedantic warnings
|
|
||||||
produced by some compilers.
|
|
||||||
* The [deprecated=true] option now causes the C++ code generator to generate
|
|
||||||
a GCC-style deprecation annotation (no-op on other compilers).
|
|
||||||
* google::protobuf::GetEnumDescriptor<SomeGeneratedEnumType>() returns the
|
|
||||||
EnumDescriptor for that type -- useful for templates which cannot call
|
|
||||||
SomeGeneratedEnumType_descriptor().
|
|
||||||
* Various optimizations and obscure bug fixes.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Lite mode: The "optimize_for = LITE_RUNTIME" option causes the compiler
|
|
||||||
to generate code which only depends libprotobuf-lite, which is much smaller
|
|
||||||
than libprotobuf but lacks descriptors, reflection, and some other features.
|
|
||||||
* Lots of style cleanups.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Fixed endianness bug with floats and doubles.
|
|
||||||
* Text format parsing support.
|
|
||||||
* Fix bug with parsing packed repeated fields in embedded messages.
|
|
||||||
* Ability to initialize fields by passing keyword args to constructor.
|
|
||||||
* Support iterators in extend and __setslice__ for containers.
|
|
||||||
|
|
||||||
2009-05-13 version 2.1.0:
|
|
||||||
|
|
||||||
General
|
|
||||||
* Repeated fields of primitive types (types other that string, group, and
|
|
||||||
nested messages) may now use the option [packed = true] to get a more
|
|
||||||
efficient encoding. In the new encoding, the entire list is written
|
|
||||||
as a single byte blob using the "length-delimited" wire type. Within
|
|
||||||
this blob, the individual values are encoded the same way they would
|
|
||||||
be normally except without a tag before each value (thus, they are
|
|
||||||
tightly "packed").
|
|
||||||
* For each field, the generated code contains an integer constant assigned
|
|
||||||
to the field number. For example, the .proto file:
|
|
||||||
message Foo { optional int bar_baz = 123; }
|
|
||||||
would generate the following constants, all with the integer value 123:
|
|
||||||
C++: Foo::kBarBazFieldNumber
|
|
||||||
Java: Foo.BAR_BAZ_FIELD_NUMBER
|
|
||||||
Python: Foo.BAR_BAZ_FIELD_NUMBER
|
|
||||||
Constants are also generated for extensions, with the same naming scheme.
|
|
||||||
These constants may be used as switch cases.
|
|
||||||
* Updated bundled Google Test to version 1.3.0. Google Test is now bundled
|
|
||||||
in its verbatim form as a nested autoconf package, so you can drop in any
|
|
||||||
other version of Google Test if needed.
|
|
||||||
* optimize_for = SPEED is now the default, by popular demand. Use
|
|
||||||
optimize_for = CODE_SIZE if code size is more important in your app.
|
|
||||||
* It is now an error to define a default value for a repeated field.
|
|
||||||
Previously, this was silently ignored (it had no effect on the generated
|
|
||||||
code).
|
|
||||||
* Fields can now be marked deprecated like:
|
|
||||||
optional int32 foo = 1 [deprecated = true];
|
|
||||||
Currently this does not have any actual effect, but in the future the code
|
|
||||||
generators may generate deprecation annotations in each language.
|
|
||||||
* Cross-compiling should now be possible using the --with-protoc option to
|
|
||||||
configure. See README.txt for more info.
|
|
||||||
|
|
||||||
protoc
|
|
||||||
* --error_format=msvs option causes errors to be printed in Visual Studio
|
|
||||||
format, which should allow them to be clicked on in the build log to go
|
|
||||||
directly to the error location.
|
|
||||||
* The type name resolver will no longer resolve type names to fields. For
|
|
||||||
example, this now works:
|
|
||||||
message Foo {}
|
|
||||||
message Bar {
|
|
||||||
optional int32 Foo = 1;
|
|
||||||
optional Foo baz = 2;
|
|
||||||
}
|
|
||||||
Previously, the type of "baz" would resolve to "Bar.Foo", and you'd get
|
|
||||||
an error because Bar.Foo is a field, not a type. Now the type of "baz"
|
|
||||||
resolves to the message type Foo. This change is unlikely to make a
|
|
||||||
difference to anyone who follows the Protocol Buffers style guide.
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Several optimizations, including but not limited to:
|
|
||||||
- Serialization, especially to flat arrays, is 10%-50% faster, possibly
|
|
||||||
more for small objects.
|
|
||||||
- Several descriptor operations which previously required locking no longer
|
|
||||||
do.
|
|
||||||
- Descriptors are now constructed lazily on first use, rather than at
|
|
||||||
process startup time. This should save memory in programs which do not
|
|
||||||
use descriptors or reflection.
|
|
||||||
- UnknownFieldSet completely redesigned to be more efficient (especially in
|
|
||||||
terms of memory usage).
|
|
||||||
- Various optimizations to reduce code size (though the serialization speed
|
|
||||||
optimizations increased code size).
|
|
||||||
* Message interface has method ParseFromBoundedZeroCopyStream() which parses
|
|
||||||
a limited number of bytes from an input stream rather than parsing until
|
|
||||||
EOF.
|
|
||||||
* GzipInputStream and GzipOutputStream support reading/writing gzip- or
|
|
||||||
zlib-compressed streams if zlib is available.
|
|
||||||
(google/protobuf/io/gzip_stream.h)
|
|
||||||
* DescriptorPool::FindAllExtensions() and corresponding
|
|
||||||
DescriptorDatabase::FindAllExtensions() can be used to enumerate all
|
|
||||||
extensions of a given type.
|
|
||||||
* For each enum type Foo, protoc will generate functions:
|
|
||||||
const string& Foo_Name(Foo value);
|
|
||||||
bool Foo_Parse(const string& name, Foo* result);
|
|
||||||
The former returns the name of the enum constant corresponding to the given
|
|
||||||
value while the latter finds the value corresponding to a name.
|
|
||||||
* RepeatedField and RepeatedPtrField now have back-insertion iterators.
|
|
||||||
* String fields now have setters that take a char* and a size, in addition
|
|
||||||
to the existing ones that took char* or const string&.
|
|
||||||
* DescriptorPool::AllowUnknownDependencies() may be used to tell
|
|
||||||
DescriptorPool to create placeholder descriptors for unknown entities
|
|
||||||
referenced in a FileDescriptorProto. This can allow you to parse a .proto
|
|
||||||
file without having access to other .proto files that it imports, for
|
|
||||||
example.
|
|
||||||
* Updated gtest to latest version. The gtest package is now included as a
|
|
||||||
nested autoconf package, so it should be able to drop new versions into the
|
|
||||||
"gtest" subdirectory without modification.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Fixed bug where Message.mergeFrom(Message) failed to merge extensions.
|
|
||||||
* Message interface has new method toBuilder() which is equivalent to
|
|
||||||
newBuilderForType().mergeFrom(this).
|
|
||||||
* All enums now implement the ProtocolMessageEnum interface.
|
|
||||||
* Setting a field to null now throws NullPointerException.
|
|
||||||
* Fixed tendency for TextFormat's parsing to overflow the stack when
|
|
||||||
parsing large string values. The underlying problem is with Java's
|
|
||||||
regex implementation (which unfortunately uses recursive backtracking
|
|
||||||
rather than building an NFA). Worked around by making use of possesive
|
|
||||||
quantifiers.
|
|
||||||
* Generated service classes now also generate pure interfaces. For a service
|
|
||||||
Foo, Foo.Interface is a pure interface containing all of the service's
|
|
||||||
defined methods. Foo.newReflectiveService() can be called to wrap an
|
|
||||||
instance of this interface in a class that implements the generic
|
|
||||||
RpcService interface, which provides reflection support that is usually
|
|
||||||
needed by RPC server implementations.
|
|
||||||
* RPC interfaces now support blocking operation in addition to non-blocking.
|
|
||||||
The protocol compiler generates separate blocking and non-blocking stubs
|
|
||||||
which operate against separate blocking and non-blocking RPC interfaces.
|
|
||||||
RPC implementations will have to implement the new interfaces in order to
|
|
||||||
support blocking mode.
|
|
||||||
* New I/O methods parseDelimitedFrom(), mergeDelimitedFrom(), and
|
|
||||||
writeDelimitedTo() read and write "delemited" messages from/to a stream,
|
|
||||||
meaning that the message size precedes the data. This way, you can write
|
|
||||||
multiple messages to a stream without having to worry about delimiting
|
|
||||||
them yourself.
|
|
||||||
* Throw a more descriptive exception when build() is double-called.
|
|
||||||
* Add a method to query whether CodedInputStream is at the end of the input
|
|
||||||
stream.
|
|
||||||
* Add a method to reset a CodedInputStream's size counter; useful when
|
|
||||||
reading many messages with the same stream.
|
|
||||||
* equals() and hashCode() now account for unknown fields.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Added slicing support for repeated scalar fields. Added slice retrieval and
|
|
||||||
removal of repeated composite fields.
|
|
||||||
* Updated RPC interfaces to allow for blocking operation. A client may
|
|
||||||
now pass None for a callback when making an RPC, in which case the
|
|
||||||
call will block until the response is received, and the response
|
|
||||||
object will be returned directly to the caller. This interface change
|
|
||||||
cannot be used in practice until RPC implementations are updated to
|
|
||||||
implement it.
|
|
||||||
* Changes to input_stream.py should make protobuf compatible with appengine.
|
|
||||||
|
|
||||||
2008-11-25 version 2.0.3:
|
|
||||||
|
|
||||||
protoc
|
|
||||||
* Enum values may now have custom options, using syntax similar to field
|
|
||||||
options.
|
|
||||||
* Fixed bug where .proto files which use custom options but don't actually
|
|
||||||
define them (i.e. they import another .proto file defining the options)
|
|
||||||
had to explicitly import descriptor.proto.
|
|
||||||
* Adjacent string literals in .proto files will now be concatenated, like in
|
|
||||||
C.
|
|
||||||
* If an input file is a Windows absolute path (e.g. "C:\foo\bar.proto") and
|
|
||||||
the import path only contains "." (or contains "." but does not contain
|
|
||||||
the file), protoc incorrectly thought that the file was under ".", because
|
|
||||||
it thought that the path was relative (since it didn't start with a slash).
|
|
||||||
This has been fixed.
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Generated message classes now have a Swap() method which efficiently swaps
|
|
||||||
the contents of two objects.
|
|
||||||
* All message classes now have a SpaceUsed() method which returns an estimate
|
|
||||||
of the number of bytes of allocated memory currently owned by the object.
|
|
||||||
This is particularly useful when you are reusing a single message object
|
|
||||||
to improve performance but want to make sure it doesn't bloat up too large.
|
|
||||||
* New method Message::SerializeAsString() returns a string containing the
|
|
||||||
serialized data. May be more convenient than calling
|
|
||||||
SerializeToString(string*).
|
|
||||||
* In debug mode, log error messages when string-type fields are found to
|
|
||||||
contain bytes that are not valid UTF-8.
|
|
||||||
* Fixed bug where a message with multiple extension ranges couldn't parse
|
|
||||||
extensions.
|
|
||||||
* Fixed bug where MergeFrom(const Message&) didn't do anything if invoked on
|
|
||||||
a message that contained no fields (but possibly contained extensions).
|
|
||||||
* Fixed ShortDebugString() to not be O(n^2). Durr.
|
|
||||||
* Fixed crash in TextFormat parsing if the first token in the input caused a
|
|
||||||
tokenization error.
|
|
||||||
* Fixed obscure bugs in zero_copy_stream_impl.cc.
|
|
||||||
* Added support for HP C++ on Tru64.
|
|
||||||
* Only build tests on "make check", not "make".
|
|
||||||
* Fixed alignment issue that caused crashes when using DynamicMessage on
|
|
||||||
64-bit Sparc machines.
|
|
||||||
* Simplify template usage to work with MSVC 2003.
|
|
||||||
* Work around GCC 4.3.x x86_64 compiler bug that caused crashes on startup.
|
|
||||||
(This affected Fedora 9 in particular.)
|
|
||||||
* Now works on "Solaris 10 using recent Sun Studio".
|
|
||||||
|
|
||||||
Java
|
|
||||||
* New overload of mergeFrom() which parses a slice of a byte array instead
|
|
||||||
of the whole thing.
|
|
||||||
* New method ByteString.asReadOnlyByteBuffer() does what it sounds like.
|
|
||||||
* Improved performance of isInitialized() when optimizing for code size.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Corrected ListFields() signature in Message base class to match what
|
|
||||||
subclasses actually implement.
|
|
||||||
* Some minor refactoring.
|
|
||||||
* Don't pass self as first argument to superclass constructor (no longer
|
|
||||||
allowed in Python 2.6).
|
|
||||||
|
|
||||||
2008-09-29 version 2.0.2:
|
|
||||||
|
|
||||||
General
|
|
||||||
* License changed from Apache 2.0 to New BSD.
|
|
||||||
* It is now possible to define custom "options", which are basically
|
|
||||||
annotations which may be placed on definitions in a .proto file.
|
|
||||||
For example, you might define a field option called "foo" like so:
|
|
||||||
import "google/protobuf/descriptor.proto"
|
|
||||||
extend google.protobuf.FieldOptions {
|
|
||||||
optional string foo = 12345;
|
|
||||||
}
|
|
||||||
Then you annotate a field using the "foo" option:
|
|
||||||
message MyMessage {
|
|
||||||
optional int32 some_field = 1 [(foo) = "bar"]
|
|
||||||
}
|
|
||||||
The value of this option is then visible via the message's
|
|
||||||
Descriptor:
|
|
||||||
const FieldDescriptor* field =
|
|
||||||
MyMessage::descriptor()->FindFieldByName("some_field");
|
|
||||||
assert(field->options().GetExtension(foo) == "bar");
|
|
||||||
This feature has been implemented and tested in C++ and Java.
|
|
||||||
Other languages may or may not need to do extra work to support
|
|
||||||
custom options, depending on how they construct descriptors.
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Fixed some GCC warnings that only occur when using -pedantic.
|
|
||||||
* Improved static initialization code, making ordering more
|
|
||||||
predictable among other things.
|
|
||||||
* TextFormat will no longer accept messages which contain multiple
|
|
||||||
instances of a singular field. Previously, the latter instance
|
|
||||||
would overwrite the former.
|
|
||||||
* Now works on systems that don't have hash_map.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Print @Override annotation in generated code where appropriate.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* Strings now use the "unicode" type rather than the "str" type.
|
|
||||||
String fields may still be assigned ASCII "str" values; they will
|
|
||||||
automatically be converted.
|
|
||||||
* Adding a property to an object representing a repeated field now
|
|
||||||
raises an exception. For example:
|
|
||||||
# No longer works (and never should have).
|
|
||||||
message.some_repeated_field.foo = 1
|
|
||||||
|
|
||||||
Windows
|
|
||||||
* We now build static libraries rather than DLLs by default on MSVC.
|
|
||||||
See vsprojects/readme.txt for more information.
|
|
||||||
|
|
||||||
2008-08-15 version 2.0.1:
|
|
||||||
|
|
||||||
protoc
|
|
||||||
* New flags --encode and --decode can be used to convert between protobuf text
|
|
||||||
format and binary format from the command-line.
|
|
||||||
* New flag --descriptor_set_out can be used to write FileDescriptorProtos for
|
|
||||||
all parsed files directly into a single output file. This is particularly
|
|
||||||
useful if you wish to parse .proto files from programs written in languages
|
|
||||||
other than C++: just run protoc as a background process and have it output
|
|
||||||
a FileDescriptorList, then parse that natively.
|
|
||||||
* Improved error message when an enum value's name conflicts with another
|
|
||||||
symbol defined in the enum type's scope, e.g. if two enum types declared
|
|
||||||
in the same scope have values with the same name. This is disallowed for
|
|
||||||
compatibility with C++, but this wasn't clear from the error.
|
|
||||||
* Fixed absolute output paths on Windows.
|
|
||||||
* Allow trailing slashes in --proto_path mappings.
|
|
||||||
|
|
||||||
C++
|
|
||||||
* Reflection objects are now per-class rather than per-instance. To make this
|
|
||||||
possible, the Reflection interface had to be changed such that all methods
|
|
||||||
take the Message instance as a parameter. This change improves performance
|
|
||||||
significantly in memory-bandwidth-limited use cases, since it makes the
|
|
||||||
message objects smaller. Note that source-incompatible interface changes
|
|
||||||
like this will not be made again after the library leaves beta.
|
|
||||||
* Heuristically detect sub-messages when printing unknown fields.
|
|
||||||
* Fix static initialization ordering bug that caused crashes at startup when
|
|
||||||
compiling on Mac with static linking.
|
|
||||||
* Fixed TokenizerTest when compiling with -DNDEBUG on Linux.
|
|
||||||
* Fixed incorrect definition of kint32min.
|
|
||||||
* Fix bytes type setter to work with byte sequences with embedded NULLs.
|
|
||||||
* Other irrelevant tweaks.
|
|
||||||
|
|
||||||
Java
|
|
||||||
* Fixed UnknownFieldSet's parsing of varints larger than 32 bits.
|
|
||||||
* Fixed TextFormat's parsing of "inf" and "nan".
|
|
||||||
* Fixed TextFormat's parsing of comments.
|
|
||||||
* Added info to Java POM that will be required when we upload the
|
|
||||||
package to a Maven repo.
|
|
||||||
|
|
||||||
Python
|
|
||||||
* MergeFrom(message) and CopyFrom(message) are now implemented.
|
|
||||||
* SerializeToString() raises an exception if the message is missing required
|
|
||||||
fields.
|
|
||||||
* Code organization improvements.
|
|
||||||
* Fixed doc comments for RpcController and RpcChannel, which had somehow been
|
|
||||||
swapped.
|
|
||||||
* Fixed text_format_test on Windows where floating-point exponents sometimes
|
|
||||||
contain extra zeros.
|
|
||||||
* Fix Python service CallMethod() implementation.
|
|
||||||
|
|
||||||
Other
|
|
||||||
* Improved readmes.
|
|
||||||
* VIM syntax highlighting improvements.
|
|
||||||
|
|
||||||
2008-07-07 version 2.0.0:
|
|
||||||
|
|
||||||
* First public release.
|
|
@ -1,237 +0,0 @@
|
|||||||
This file contains detailed but generic information on building and
|
|
||||||
installing the C++ part of this project. For shorter instructions,
|
|
||||||
as well as instructions for compiling and installing the Java or
|
|
||||||
Python parts, see README.
|
|
||||||
|
|
||||||
======================================================================
|
|
||||||
|
|
||||||
Copyright 1994, 1995, 1996, 1999, 2000, 2001, 2002 Free Software
|
|
||||||
Foundation, Inc.
|
|
||||||
|
|
||||||
This file is free documentation; the Free Software Foundation gives
|
|
||||||
unlimited permission to copy, distribute and modify it.
|
|
||||||
|
|
||||||
|
|
||||||
Basic Installation
|
|
||||||
==================
|
|
||||||
|
|
||||||
These are generic installation instructions.
|
|
||||||
|
|
||||||
The `configure' shell script attempts to guess correct values for
|
|
||||||
various system-dependent variables used during compilation. It uses
|
|
||||||
those values to create a `Makefile' in each directory of the package.
|
|
||||||
It may also create one or more `.h' files containing system-dependent
|
|
||||||
definitions. Finally, it creates a shell script `config.status' that
|
|
||||||
you can run in the future to recreate the current configuration, and a
|
|
||||||
file `config.log' containing compiler output (useful mainly for
|
|
||||||
debugging `configure').
|
|
||||||
|
|
||||||
It can also use an optional file (typically called `config.cache'
|
|
||||||
and enabled with `--cache-file=config.cache' or simply `-C') that saves
|
|
||||||
the results of its tests to speed up reconfiguring. (Caching is
|
|
||||||
disabled by default to prevent problems with accidental use of stale
|
|
||||||
cache files.)
|
|
||||||
|
|
||||||
If you need to do unusual things to compile the package, please try
|
|
||||||
to figure out how `configure' could check whether to do them, and mail
|
|
||||||
diffs or instructions to the address given in the `README' so they can
|
|
||||||
be considered for the next release. If you are using the cache, and at
|
|
||||||
some point `config.cache' contains results you don't want to keep, you
|
|
||||||
may remove or edit it.
|
|
||||||
|
|
||||||
The file `configure.ac' (or `configure.in') is used to create
|
|
||||||
`configure' by a program called `autoconf'. You only need
|
|
||||||
`configure.ac' if you want to change it or regenerate `configure' using
|
|
||||||
a newer version of `autoconf'.
|
|
||||||
|
|
||||||
The simplest way to compile this package is:
|
|
||||||
|
|
||||||
1. `cd' to the directory containing the package's source code and type
|
|
||||||
`./configure' to configure the package for your system. If you're
|
|
||||||
using `csh' on an old version of System V, you might need to type
|
|
||||||
`sh ./configure' instead to prevent `csh' from trying to execute
|
|
||||||
`configure' itself.
|
|
||||||
|
|
||||||
Running `configure' takes awhile. While running, it prints some
|
|
||||||
messages telling which features it is checking for.
|
|
||||||
|
|
||||||
2. Type `make' to compile the package.
|
|
||||||
|
|
||||||
3. Optionally, type `make check' to run any self-tests that come with
|
|
||||||
the package.
|
|
||||||
|
|
||||||
4. Type `make install' to install the programs and any data files and
|
|
||||||
documentation.
|
|
||||||
|
|
||||||
5. You can remove the program binaries and object files from the
|
|
||||||
source code directory by typing `make clean'. To also remove the
|
|
||||||
files that `configure' created (so you can compile the package for
|
|
||||||
a different kind of computer), type `make distclean'. There is
|
|
||||||
also a `make maintainer-clean' target, but that is intended mainly
|
|
||||||
for the package's developers. If you use it, you may have to get
|
|
||||||
all sorts of other programs in order to regenerate files that came
|
|
||||||
with the distribution.
|
|
||||||
|
|
||||||
Compilers and Options
|
|
||||||
=====================
|
|
||||||
|
|
||||||
Some systems require unusual options for compilation or linking that
|
|
||||||
the `configure' script does not know about. Run `./configure --help'
|
|
||||||
for details on some of the pertinent environment variables.
|
|
||||||
|
|
||||||
You can give `configure' initial values for configuration parameters
|
|
||||||
by setting variables in the command line or in the environment. Here
|
|
||||||
is an example:
|
|
||||||
|
|
||||||
./configure CC=c89 CFLAGS=-O2 LIBS=-lposix
|
|
||||||
|
|
||||||
*Note Defining Variables::, for more details.
|
|
||||||
|
|
||||||
Compiling For Multiple Architectures
|
|
||||||
====================================
|
|
||||||
|
|
||||||
You can compile the package for more than one kind of computer at the
|
|
||||||
same time, by placing the object files for each architecture in their
|
|
||||||
own directory. To do this, you must use a version of `make' that
|
|
||||||
supports the `VPATH' variable, such as GNU `make'. `cd' to the
|
|
||||||
directory where you want the object files and executables to go and run
|
|
||||||
the `configure' script. `configure' automatically checks for the
|
|
||||||
source code in the directory that `configure' is in and in `..'.
|
|
||||||
|
|
||||||
If you have to use a `make' that does not support the `VPATH'
|
|
||||||
variable, you have to compile the package for one architecture at a
|
|
||||||
time in the source code directory. After you have installed the
|
|
||||||
package for one architecture, use `make distclean' before reconfiguring
|
|
||||||
for another architecture.
|
|
||||||
|
|
||||||
Installation Names
|
|
||||||
==================
|
|
||||||
|
|
||||||
By default, `make install' will install the package's files in
|
|
||||||
`/usr/local/bin', `/usr/local/man', etc. You can specify an
|
|
||||||
installation prefix other than `/usr/local' by giving `configure' the
|
|
||||||
option `--prefix=PATH'.
|
|
||||||
|
|
||||||
You can specify separate installation prefixes for
|
|
||||||
architecture-specific files and architecture-independent files. If you
|
|
||||||
give `configure' the option `--exec-prefix=PATH', the package will use
|
|
||||||
PATH as the prefix for installing programs and libraries.
|
|
||||||
Documentation and other data files will still use the regular prefix.
|
|
||||||
|
|
||||||
In addition, if you use an unusual directory layout you can give
|
|
||||||
options like `--bindir=PATH' to specify different values for particular
|
|
||||||
kinds of files. Run `configure --help' for a list of the directories
|
|
||||||
you can set and what kinds of files go in them.
|
|
||||||
|
|
||||||
If the package supports it, you can cause programs to be installed
|
|
||||||
with an extra prefix or suffix on their names by giving `configure' the
|
|
||||||
option `--program-prefix=PREFIX' or `--program-suffix=SUFFIX'.
|
|
||||||
|
|
||||||
Optional Features
|
|
||||||
=================
|
|
||||||
|
|
||||||
Some packages pay attention to `--enable-FEATURE' options to
|
|
||||||
`configure', where FEATURE indicates an optional part of the package.
|
|
||||||
They may also pay attention to `--with-PACKAGE' options, where PACKAGE
|
|
||||||
is something like `gnu-as' or `x' (for the X Window System). The
|
|
||||||
`README' should mention any `--enable-' and `--with-' options that the
|
|
||||||
package recognizes.
|
|
||||||
|
|
||||||
For packages that use the X Window System, `configure' can usually
|
|
||||||
find the X include and library files automatically, but if it doesn't,
|
|
||||||
you can use the `configure' options `--x-includes=DIR' and
|
|
||||||
`--x-libraries=DIR' to specify their locations.
|
|
||||||
|
|
||||||
Specifying the System Type
|
|
||||||
==========================
|
|
||||||
|
|
||||||
There may be some features `configure' cannot figure out
|
|
||||||
automatically, but needs to determine by the type of machine the package
|
|
||||||
will run on. Usually, assuming the package is built to be run on the
|
|
||||||
_same_ architectures, `configure' can figure that out, but if it prints
|
|
||||||
a message saying it cannot guess the machine type, give it the
|
|
||||||
`--build=TYPE' option. TYPE can either be a short name for the system
|
|
||||||
type, such as `sun4', or a canonical name which has the form:
|
|
||||||
|
|
||||||
CPU-COMPANY-SYSTEM
|
|
||||||
|
|
||||||
where SYSTEM can have one of these forms:
|
|
||||||
|
|
||||||
OS KERNEL-OS
|
|
||||||
|
|
||||||
See the file `config.sub' for the possible values of each field. If
|
|
||||||
`config.sub' isn't included in this package, then this package doesn't
|
|
||||||
need to know the machine type.
|
|
||||||
|
|
||||||
If you are _building_ compiler tools for cross-compiling, you should
|
|
||||||
use the `--target=TYPE' option to select the type of system they will
|
|
||||||
produce code for.
|
|
||||||
|
|
||||||
If you want to _use_ a cross compiler, that generates code for a
|
|
||||||
platform different from the build platform, you should specify the
|
|
||||||
"host" platform (i.e., that on which the generated programs will
|
|
||||||
eventually be run) with `--host=TYPE'.
|
|
||||||
|
|
||||||
Sharing Defaults
|
|
||||||
================
|
|
||||||
|
|
||||||
If you want to set default values for `configure' scripts to share,
|
|
||||||
you can create a site shell script called `config.site' that gives
|
|
||||||
default values for variables like `CC', `cache_file', and `prefix'.
|
|
||||||
`configure' looks for `PREFIX/share/config.site' if it exists, then
|
|
||||||
`PREFIX/etc/config.site' if it exists. Or, you can set the
|
|
||||||
`CONFIG_SITE' environment variable to the location of the site script.
|
|
||||||
A warning: not all `configure' scripts look for a site script.
|
|
||||||
|
|
||||||
Defining Variables
|
|
||||||
==================
|
|
||||||
|
|
||||||
Variables not defined in a site shell script can be set in the
|
|
||||||
environment passed to `configure'. However, some packages may run
|
|
||||||
configure again during the build, and the customized values of these
|
|
||||||
variables may be lost. In order to avoid this problem, you should set
|
|
||||||
them in the `configure' command line, using `VAR=value'. For example:
|
|
||||||
|
|
||||||
./configure CC=/usr/local2/bin/gcc
|
|
||||||
|
|
||||||
will cause the specified gcc to be used as the C compiler (unless it is
|
|
||||||
overridden in the site shell script).
|
|
||||||
|
|
||||||
`configure' Invocation
|
|
||||||
======================
|
|
||||||
|
|
||||||
`configure' recognizes the following options to control how it
|
|
||||||
operates.
|
|
||||||
|
|
||||||
`--help'
|
|
||||||
`-h'
|
|
||||||
Print a summary of the options to `configure', and exit.
|
|
||||||
|
|
||||||
`--version'
|
|
||||||
`-V'
|
|
||||||
Print the version of Autoconf used to generate the `configure'
|
|
||||||
script, and exit.
|
|
||||||
|
|
||||||
`--cache-file=FILE'
|
|
||||||
Enable the cache: use and save the results of the tests in FILE,
|
|
||||||
traditionally `config.cache'. FILE defaults to `/dev/null' to
|
|
||||||
disable caching.
|
|
||||||
|
|
||||||
`--config-cache'
|
|
||||||
`-C'
|
|
||||||
Alias for `--cache-file=config.cache'.
|
|
||||||
|
|
||||||
`--quiet'
|
|
||||||
`--silent'
|
|
||||||
`-q'
|
|
||||||
Do not print messages saying which checks are being made. To
|
|
||||||
suppress all normal output, redirect it to `/dev/null' (any error
|
|
||||||
messages will still be shown).
|
|
||||||
|
|
||||||
`--srcdir=DIR'
|
|
||||||
Look for the package's source code in directory DIR. Usually
|
|
||||||
`configure' can determine that directory automatically.
|
|
||||||
|
|
||||||
`configure' also accepts some other, not widely useful, options. Run
|
|
||||||
`configure --help' for more details.
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
|||||||
Copyright 2008, Google Inc.
|
|
||||||
All rights reserved.
|
|
||||||
|
|
||||||
Redistribution and use in source and binary forms, with or without
|
|
||||||
modification, are permitted provided that the following conditions are
|
|
||||||
met:
|
|
||||||
|
|
||||||
* Redistributions of source code must retain the above copyright
|
|
||||||
notice, this list of conditions and the following disclaimer.
|
|
||||||
* Redistributions in binary form must reproduce the above
|
|
||||||
copyright notice, this list of conditions and the following disclaimer
|
|
||||||
in the documentation and/or other materials provided with the
|
|
||||||
distribution.
|
|
||||||
* Neither the name of Google Inc. nor the names of its
|
|
||||||
contributors may be used to endorse or promote products derived from
|
|
||||||
this software without specific prior written permission.
|
|
||||||
|
|
||||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
Code generated by the Protocol Buffer compiler is owned by the owner
|
|
||||||
of the input file used when generating it. This code is not
|
|
||||||
standalone and requires a support library to be linked with it. This
|
|
||||||
support library is itself covered by the above license.
|
|
@ -1,267 +0,0 @@
|
|||||||
## Process this file with automake to produce Makefile.in
|
|
||||||
|
|
||||||
ACLOCAL_AMFLAGS = -I m4
|
|
||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign
|
|
||||||
|
|
||||||
# Build . before src so that our all-local and clean-local hooks kicks in at
|
|
||||||
# the right time.
|
|
||||||
SUBDIRS = . src
|
|
||||||
|
|
||||||
# Always include gtest in distributions.
|
|
||||||
DIST_SUBDIRS = $(subdirs) src
|
|
||||||
|
|
||||||
# Build gtest before we build protobuf tests. We don't add gtest to SUBDIRS
|
|
||||||
# because then "make check" would also build and run all of gtest's own tests,
|
|
||||||
# which takes a lot of time and is generally not useful to us. Also, we don't
|
|
||||||
# want "make install" to recurse into gtest since we don't want to overwrite
|
|
||||||
# the installed version of gtest if there is one.
|
|
||||||
check-local:
|
|
||||||
@echo "Making lib/libgtest.a lib/libgtest_main.a in gtest"
|
|
||||||
@cd gtest && $(MAKE) $(AM_MAKEFLAGS) lib/libgtest.la lib/libgtest_main.la
|
|
||||||
|
|
||||||
# We would like to clean gtest when "make clean" is invoked. But we have to
|
|
||||||
# be careful because clean-local is also invoked during "make distclean", but
|
|
||||||
# "make distclean" already recurses into gtest because it's listed among the
|
|
||||||
# DIST_SUBDIRS. distclean will delete gtest/Makefile, so if we then try to
|
|
||||||
# cd to the directory again and "make clean" it will fail. So, check that the
|
|
||||||
# Makefile exists before recursing.
|
|
||||||
clean-local:
|
|
||||||
@if test -e gtest/Makefile; then \
|
|
||||||
echo "Making clean in gtest"; \
|
|
||||||
cd gtest && $(MAKE) $(AM_MAKEFLAGS) clean; \
|
|
||||||
fi
|
|
||||||
|
|
||||||
pkgconfigdir = $(libdir)/pkgconfig
|
|
||||||
pkgconfig_DATA = protobuf.pc protobuf-lite.pc
|
|
||||||
|
|
||||||
EXTRA_DIST = \
|
|
||||||
autogen.sh \
|
|
||||||
generate_descriptor_proto.sh \
|
|
||||||
README.md \
|
|
||||||
INSTALL.txt \
|
|
||||||
LICENSE \
|
|
||||||
CONTRIBUTORS.txt \
|
|
||||||
CHANGES.txt \
|
|
||||||
editors/README.txt \
|
|
||||||
editors/proto.vim \
|
|
||||||
editors/protobuf-mode.el \
|
|
||||||
vsprojects/config.h \
|
|
||||||
vsprojects/extract_includes.bat \
|
|
||||||
vsprojects/libprotobuf.vcproj \
|
|
||||||
vsprojects/libprotobuf-lite.vcproj \
|
|
||||||
vsprojects/libprotoc.vcproj \
|
|
||||||
vsprojects/protobuf.sln \
|
|
||||||
vsprojects/protoc.vcproj \
|
|
||||||
vsprojects/readme.txt \
|
|
||||||
vsprojects/test_plugin.vcproj \
|
|
||||||
vsprojects/tests.vcproj \
|
|
||||||
vsprojects/lite-test.vcproj \
|
|
||||||
vsprojects/convert2008to2005.sh \
|
|
||||||
examples/README.txt \
|
|
||||||
examples/Makefile \
|
|
||||||
examples/addressbook.proto \
|
|
||||||
examples/add_person.cc \
|
|
||||||
examples/list_people.cc \
|
|
||||||
examples/AddPerson.java \
|
|
||||||
examples/ListPeople.java \
|
|
||||||
examples/add_person.py \
|
|
||||||
examples/list_people.py \
|
|
||||||
java/src/main/java/com/google/protobuf/AbstractMessage.java \
|
|
||||||
java/src/main/java/com/google/protobuf/AbstractMessageLite.java \
|
|
||||||
java/src/main/java/com/google/protobuf/AbstractParser.java \
|
|
||||||
java/src/main/java/com/google/protobuf/BlockingRpcChannel.java \
|
|
||||||
java/src/main/java/com/google/protobuf/BlockingService.java \
|
|
||||||
java/src/main/java/com/google/protobuf/BoundedByteString.java \
|
|
||||||
java/src/main/java/com/google/protobuf/ByteString.java \
|
|
||||||
java/src/main/java/com/google/protobuf/CodedInputStream.java \
|
|
||||||
java/src/main/java/com/google/protobuf/CodedOutputStream.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Descriptors.java \
|
|
||||||
java/src/main/java/com/google/protobuf/DynamicMessage.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Extension.java \
|
|
||||||
java/src/main/java/com/google/protobuf/ExtensionRegistry.java \
|
|
||||||
java/src/main/java/com/google/protobuf/ExtensionRegistryLite.java \
|
|
||||||
java/src/main/java/com/google/protobuf/FieldSet.java \
|
|
||||||
java/src/main/java/com/google/protobuf/GeneratedMessage.java \
|
|
||||||
java/src/main/java/com/google/protobuf/GeneratedMessageLite.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Internal.java \
|
|
||||||
java/src/main/java/com/google/protobuf/InvalidProtocolBufferException.java \
|
|
||||||
java/src/main/java/com/google/protobuf/LazyField.java \
|
|
||||||
java/src/main/java/com/google/protobuf/LazyFieldLite.java \
|
|
||||||
java/src/main/java/com/google/protobuf/LazyStringArrayList.java \
|
|
||||||
java/src/main/java/com/google/protobuf/LazyStringList.java \
|
|
||||||
java/src/main/java/com/google/protobuf/LiteralByteString.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Message.java \
|
|
||||||
java/src/main/java/com/google/protobuf/MessageLite.java \
|
|
||||||
java/src/main/java/com/google/protobuf/MessageLiteOrBuilder.java \
|
|
||||||
java/src/main/java/com/google/protobuf/MessageOrBuilder.java \
|
|
||||||
java/src/main/java/com/google/protobuf/MessageReflection.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Parser.java \
|
|
||||||
java/src/main/java/com/google/protobuf/ProtocolMessageEnum.java \
|
|
||||||
java/src/main/java/com/google/protobuf/ProtocolStringList.java \
|
|
||||||
java/src/main/java/com/google/protobuf/RepeatedFieldBuilder.java \
|
|
||||||
java/src/main/java/com/google/protobuf/RopeByteString.java \
|
|
||||||
java/src/main/java/com/google/protobuf/RpcCallback.java \
|
|
||||||
java/src/main/java/com/google/protobuf/RpcChannel.java \
|
|
||||||
java/src/main/java/com/google/protobuf/RpcController.java \
|
|
||||||
java/src/main/java/com/google/protobuf/RpcUtil.java \
|
|
||||||
java/src/main/java/com/google/protobuf/ServiceException.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Service.java \
|
|
||||||
java/src/main/java/com/google/protobuf/SingleFieldBuilder.java \
|
|
||||||
java/src/main/java/com/google/protobuf/SmallSortedMap.java \
|
|
||||||
java/src/main/java/com/google/protobuf/TextFormat.java \
|
|
||||||
java/src/main/java/com/google/protobuf/UninitializedMessageException.java \
|
|
||||||
java/src/main/java/com/google/protobuf/UnknownFieldSet.java \
|
|
||||||
java/src/main/java/com/google/protobuf/UnmodifiableLazyStringList.java \
|
|
||||||
java/src/main/java/com/google/protobuf/Utf8.java \
|
|
||||||
java/src/main/java/com/google/protobuf/WireFormat.java \
|
|
||||||
java/src/test/java/com/google/protobuf/AbstractMessageTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/BoundedByteStringTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/ByteStringTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/CheckUtf8Test.java \
|
|
||||||
java/src/test/java/com/google/protobuf/CodedInputStreamTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/CodedOutputStreamTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/DeprecatedFieldTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/DescriptorsTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/DynamicMessageTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/ForceFieldBuildersPreRun.java \
|
|
||||||
java/src/test/java/com/google/protobuf/GeneratedMessageTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/IsValidUtf8Test.java \
|
|
||||||
java/src/test/java/com/google/protobuf/IsValidUtf8TestUtil.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LazyFieldTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LazyFieldLiteTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LazyMessageLiteTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LazyStringArrayListTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LazyStringEndToEndTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LiteEqualsAndHashTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LiteralByteStringTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/LiteTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/MessageTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/NestedBuildersTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/ParserTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/RepeatedFieldBuilderTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/RopeByteStringSubstringTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/RopeByteStringTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/ServiceTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/SingleFieldBuilderTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/SmallSortedMapTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/TestBadIdentifiers.java \
|
|
||||||
java/src/test/java/com/google/protobuf/TestUtil.java \
|
|
||||||
java/src/test/java/com/google/protobuf/TextFormatTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/UnknownFieldSetTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/UnmodifiableLazyStringListTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/WireFormatTest.java \
|
|
||||||
java/src/test/java/com/google/protobuf/lazy_fields_lite.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/lite_equals_and_hash.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/multiple_files_test.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/nested_builders_test.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/nested_extension_lite.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/nested_extension.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/non_nested_extension_lite.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/non_nested_extension.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/outer_class_name_test.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/outer_class_name_test2.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/outer_class_name_test3.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/test_bad_identifiers.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/test_check_utf8.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/test_check_utf8_size.proto \
|
|
||||||
java/src/test/java/com/google/protobuf/test_custom_options.proto \
|
|
||||||
java/pom.xml \
|
|
||||||
java/README.txt \
|
|
||||||
python/google/protobuf/internal/api_implementation.cc \
|
|
||||||
python/google/protobuf/internal/api_implementation.py \
|
|
||||||
python/google/protobuf/internal/api_implementation_default_test.py \
|
|
||||||
python/google/protobuf/internal/containers.py \
|
|
||||||
python/google/protobuf/internal/cpp_message.py \
|
|
||||||
python/google/protobuf/internal/decoder.py \
|
|
||||||
python/google/protobuf/internal/descriptor_database_test.py \
|
|
||||||
python/google/protobuf/internal/descriptor_pool_test.py \
|
|
||||||
python/google/protobuf/internal/descriptor_pool_test1.proto \
|
|
||||||
python/google/protobuf/internal/descriptor_pool_test2.proto \
|
|
||||||
python/google/protobuf/internal/descriptor_python_test.py \
|
|
||||||
python/google/protobuf/internal/descriptor_test.py \
|
|
||||||
python/google/protobuf/internal/encoder.py \
|
|
||||||
python/google/protobuf/internal/enum_type_wrapper.py \
|
|
||||||
python/google/protobuf/internal/factory_test1.proto \
|
|
||||||
python/google/protobuf/internal/factory_test2.proto \
|
|
||||||
python/google/protobuf/internal/generator_test.py \
|
|
||||||
python/google/protobuf/internal/message_factory_python_test.py \
|
|
||||||
python/google/protobuf/internal/message_factory_test.py \
|
|
||||||
python/google/protobuf/internal/message_listener.py \
|
|
||||||
python/google/protobuf/internal/message_python_test.py \
|
|
||||||
python/google/protobuf/internal/message_test.py \
|
|
||||||
python/google/protobuf/internal/missing_enum_values.proto \
|
|
||||||
python/google/protobuf/internal/more_extensions.proto \
|
|
||||||
python/google/protobuf/internal/more_extensions_dynamic.proto \
|
|
||||||
python/google/protobuf/internal/more_messages.proto \
|
|
||||||
python/google/protobuf/internal/python_message.py \
|
|
||||||
python/google/protobuf/internal/reflection_test.py \
|
|
||||||
python/google/protobuf/internal/service_reflection_test.py \
|
|
||||||
python/google/protobuf/internal/symbol_database_test.py \
|
|
||||||
python/google/protobuf/internal/test_bad_identifiers.proto \
|
|
||||||
python/google/protobuf/internal/test_util.py \
|
|
||||||
python/google/protobuf/internal/text_encoding_test.py \
|
|
||||||
python/google/protobuf/internal/text_format_test.py \
|
|
||||||
python/google/protobuf/internal/type_checkers.py \
|
|
||||||
python/google/protobuf/internal/unknown_fields_test.py \
|
|
||||||
python/google/protobuf/internal/wire_format.py \
|
|
||||||
python/google/protobuf/internal/wire_format_test.py \
|
|
||||||
python/google/protobuf/internal/__init__.py \
|
|
||||||
python/google/protobuf/pyext/README \
|
|
||||||
python/google/protobuf/pyext/cpp_message.py \
|
|
||||||
python/google/protobuf/pyext/descriptor.h \
|
|
||||||
python/google/protobuf/pyext/descriptor.cc \
|
|
||||||
python/google/protobuf/pyext/descriptor_cpp2_test.py \
|
|
||||||
python/google/protobuf/pyext/extension_dict.h \
|
|
||||||
python/google/protobuf/pyext/extension_dict.cc \
|
|
||||||
python/google/protobuf/pyext/message.h \
|
|
||||||
python/google/protobuf/pyext/message.cc \
|
|
||||||
python/google/protobuf/pyext/message_factory_cpp2_test.py \
|
|
||||||
python/google/protobuf/pyext/proto2_api_test.proto \
|
|
||||||
python/google/protobuf/pyext/python.proto \
|
|
||||||
python/google/protobuf/pyext/python_protobuf.h \
|
|
||||||
python/google/protobuf/pyext/reflection_cpp2_generated_test.py \
|
|
||||||
python/google/protobuf/pyext/repeated_composite_container.h \
|
|
||||||
python/google/protobuf/pyext/repeated_composite_container.cc \
|
|
||||||
python/google/protobuf/pyext/repeated_scalar_container.h \
|
|
||||||
python/google/protobuf/pyext/repeated_scalar_container.cc \
|
|
||||||
python/google/protobuf/pyext/scoped_pyobject_ptr.h \
|
|
||||||
python/google/protobuf/pyext/__init__.py \
|
|
||||||
python/google/protobuf/descriptor.py \
|
|
||||||
python/google/protobuf/descriptor_database.py \
|
|
||||||
python/google/protobuf/descriptor_pool.py \
|
|
||||||
python/google/protobuf/message.py \
|
|
||||||
python/google/protobuf/message_factory.py \
|
|
||||||
python/google/protobuf/reflection.py \
|
|
||||||
python/google/protobuf/service.py \
|
|
||||||
python/google/protobuf/service_reflection.py \
|
|
||||||
python/google/protobuf/symbol_database.py \
|
|
||||||
python/google/protobuf/text_encoding.py \
|
|
||||||
python/google/protobuf/text_format.py \
|
|
||||||
python/google/protobuf/__init__.py \
|
|
||||||
python/google/__init__.py \
|
|
||||||
python/ez_setup.py \
|
|
||||||
python/setup.py \
|
|
||||||
python/mox.py \
|
|
||||||
python/stubout.py \
|
|
||||||
python/README.txt
|
|
||||||
|
|
||||||
# Deletes all the files generated by autogen.sh.
|
|
||||||
MAINTAINERCLEANFILES = \
|
|
||||||
aclocal.m4 \
|
|
||||||
config.guess \
|
|
||||||
config.sub \
|
|
||||||
configure \
|
|
||||||
depcomp \
|
|
||||||
install-sh \
|
|
||||||
ltmain.sh \
|
|
||||||
Makefile.in \
|
|
||||||
missing \
|
|
||||||
mkinstalldirs \
|
|
||||||
config.h.in \
|
|
||||||
stamp.h.in \
|
|
||||||
m4/ltsugar.m4 \
|
|
||||||
m4/libtool.m4 \
|
|
||||||
m4/ltversion.m4 \
|
|
||||||
m4/lt~obsolete.m4 \
|
|
||||||
m4/ltoptions.m4
|
|
File diff suppressed because it is too large
Load Diff
@ -1,167 +0,0 @@
|
|||||||
Protocol Buffers - Google's data interchange format
|
|
||||||
===================================================
|
|
||||||
|
|
||||||
Copyright 2008 Google Inc.
|
|
||||||
|
|
||||||
https://developers.google.com/protocol-buffers/
|
|
||||||
|
|
||||||
C++ Installation - Unix
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
If you get the source from github, you need to generate the configure script
|
|
||||||
first:
|
|
||||||
|
|
||||||
$ ./autogen.sh
|
|
||||||
|
|
||||||
This will download gtest source (which is used for C++ Protocol Buffer
|
|
||||||
unit-tests) to the current directory and run automake, autoconf, etc.
|
|
||||||
to generate the configure script and various template makefiles.
|
|
||||||
|
|
||||||
You can skip this step if you are using a release package (which already
|
|
||||||
contains gtest and the configure script).
|
|
||||||
|
|
||||||
To build and install the C++ Protocol Buffer runtime and the Protocol
|
|
||||||
Buffer compiler (protoc) execute the following:
|
|
||||||
|
|
||||||
$ ./configure
|
|
||||||
$ make
|
|
||||||
$ make check
|
|
||||||
$ make install
|
|
||||||
|
|
||||||
If "make check" fails, you can still install, but it is likely that
|
|
||||||
some features of this library will not work correctly on your system.
|
|
||||||
Proceed at your own risk.
|
|
||||||
|
|
||||||
"make install" may require superuser privileges.
|
|
||||||
|
|
||||||
For advanced usage information on configure and make, see INSTALL.txt.
|
|
||||||
|
|
||||||
**Hint on install location**
|
|
||||||
|
|
||||||
By default, the package will be installed to /usr/local. However,
|
|
||||||
on many platforms, /usr/local/lib is not part of LD_LIBRARY_PATH.
|
|
||||||
You can add it, but it may be easier to just install to /usr
|
|
||||||
instead. To do this, invoke configure as follows:
|
|
||||||
|
|
||||||
./configure --prefix=/usr
|
|
||||||
|
|
||||||
If you already built the package with a different prefix, make sure
|
|
||||||
to run "make clean" before building again.
|
|
||||||
|
|
||||||
**Compiling dependent packages**
|
|
||||||
|
|
||||||
To compile a package that uses Protocol Buffers, you need to pass
|
|
||||||
various flags to your compiler and linker. As of version 2.2.0,
|
|
||||||
Protocol Buffers integrates with pkg-config to manage this. If you
|
|
||||||
have pkg-config installed, then you can invoke it to get a list of
|
|
||||||
flags like so:
|
|
||||||
|
|
||||||
pkg-config --cflags protobuf # print compiler flags
|
|
||||||
pkg-config --libs protobuf # print linker flags
|
|
||||||
pkg-config --cflags --libs protobuf # print both
|
|
||||||
|
|
||||||
For example:
|
|
||||||
|
|
||||||
c++ my_program.cc my_proto.pb.cc `pkg-config --cflags --libs protobuf`
|
|
||||||
|
|
||||||
Note that packages written prior to the 2.2.0 release of Protocol
|
|
||||||
Buffers may not yet integrate with pkg-config to get flags, and may
|
|
||||||
not pass the correct set of flags to correctly link against
|
|
||||||
libprotobuf. If the package in question uses autoconf, you can
|
|
||||||
often fix the problem by invoking its configure script like:
|
|
||||||
|
|
||||||
configure CXXFLAGS="$(pkg-config --cflags protobuf)" \
|
|
||||||
LIBS="$(pkg-config --libs protobuf)"
|
|
||||||
|
|
||||||
This will force it to use the correct flags.
|
|
||||||
|
|
||||||
If you are writing an autoconf-based package that uses Protocol
|
|
||||||
Buffers, you should probably use the PKG_CHECK_MODULES macro in your
|
|
||||||
configure script like:
|
|
||||||
|
|
||||||
PKG_CHECK_MODULES([protobuf], [protobuf])
|
|
||||||
|
|
||||||
See the pkg-config man page for more info.
|
|
||||||
|
|
||||||
If you only want protobuf-lite, substitute "protobuf-lite" in place
|
|
||||||
of "protobuf" in these examples.
|
|
||||||
|
|
||||||
**Note for cross-compiling**
|
|
||||||
|
|
||||||
The makefiles normally invoke the protoc executable that they just
|
|
||||||
built in order to build tests. When cross-compiling, the protoc
|
|
||||||
executable may not be executable on the host machine. In this case,
|
|
||||||
you must build a copy of protoc for the host machine first, then use
|
|
||||||
the --with-protoc option to tell configure to use it instead. For
|
|
||||||
example:
|
|
||||||
|
|
||||||
./configure --with-protoc=protoc
|
|
||||||
|
|
||||||
This will use the installed protoc (found in your $PATH) instead of
|
|
||||||
trying to execute the one built during the build process. You can
|
|
||||||
also use an executable that hasn't been installed. For example, if
|
|
||||||
you built the protobuf package for your host machine in ../host,
|
|
||||||
you might do:
|
|
||||||
|
|
||||||
./configure --with-protoc=../host/src/protoc
|
|
||||||
|
|
||||||
Either way, you must make sure that the protoc executable you use
|
|
||||||
has the same version as the protobuf source code you are trying to
|
|
||||||
use it with.
|
|
||||||
|
|
||||||
**Note for Solaris users**
|
|
||||||
|
|
||||||
Solaris 10 x86 has a bug that will make linking fail, complaining
|
|
||||||
about libstdc++.la being invalid. We have included a work-around
|
|
||||||
in this package. To use the work-around, run configure as follows:
|
|
||||||
|
|
||||||
./configure LDFLAGS=-L$PWD/src/solaris
|
|
||||||
|
|
||||||
See src/solaris/libstdc++.la for more info on this bug.
|
|
||||||
|
|
||||||
**Note for HP C++ Tru64 users**
|
|
||||||
|
|
||||||
To compile invoke configure as follows:
|
|
||||||
|
|
||||||
./configure CXXFLAGS="-O -std ansi -ieee -D__USE_STD_IOSTREAM"
|
|
||||||
|
|
||||||
Also, you will need to use gmake instead of make.
|
|
||||||
|
|
||||||
C++ Installation - Windows
|
|
||||||
--------------------------
|
|
||||||
|
|
||||||
If you are using Microsoft Visual C++, see vsprojects/readme.txt.
|
|
||||||
|
|
||||||
If you are using Cygwin or MinGW, follow the Unix installation
|
|
||||||
instructions, above.
|
|
||||||
|
|
||||||
Binary Compatibility Warning
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
Due to the nature of C++, it is unlikely that any two versions of the
|
|
||||||
Protocol Buffers C++ runtime libraries will have compatible ABIs.
|
|
||||||
That is, if you linked an executable against an older version of
|
|
||||||
libprotobuf, it is unlikely to work with a newer version without
|
|
||||||
re-compiling. This problem, when it occurs, will normally be detected
|
|
||||||
immediately on startup of your app. Still, you may want to consider
|
|
||||||
using static linkage. You can configure this package to install
|
|
||||||
static libraries only using:
|
|
||||||
|
|
||||||
./configure --disable-shared
|
|
||||||
|
|
||||||
Java and Python Installation
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
The Java and Python runtime libraries for Protocol Buffers are located
|
|
||||||
in the java and python directories. See the README file in each
|
|
||||||
directory for more information on how to compile and install them.
|
|
||||||
Note that both of them require you to first install the Protocol
|
|
||||||
Buffer compiler (protoc), which is part of the C++ package.
|
|
||||||
|
|
||||||
Usage
|
|
||||||
-----
|
|
||||||
|
|
||||||
The complete documentation for Protocol Buffers is available via the
|
|
||||||
web at:
|
|
||||||
|
|
||||||
https://developers.google.com/protocol-buffers/
|
|
1194
common/protobuf-2.6.1/aclocal.m4
vendored
1194
common/protobuf-2.6.1/aclocal.m4
vendored
File diff suppressed because it is too large
Load Diff
@ -1,41 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Run this script to generate the configure script and other files that will
|
|
||||||
# be included in the distribution. These files are not checked in because they
|
|
||||||
# are automatically generated.
|
|
||||||
|
|
||||||
set -e
|
|
||||||
|
|
||||||
# Check that we're being run from the right directory.
|
|
||||||
if test ! -f src/google/protobuf/stubs/common.h; then
|
|
||||||
cat >&2 << __EOF__
|
|
||||||
Could not find source code. Make sure you are running this script from the
|
|
||||||
root of the distribution tree.
|
|
||||||
__EOF__
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check that gtest is present. Usually it is already there since the
|
|
||||||
# directory is set up as an SVN external.
|
|
||||||
if test ! -e gtest; then
|
|
||||||
echo "Google Test not present. Fetching gtest-1.5.0 from the web..."
|
|
||||||
curl http://googletest.googlecode.com/files/gtest-1.5.0.tar.bz2 | tar jx
|
|
||||||
mv gtest-1.5.0 gtest
|
|
||||||
fi
|
|
||||||
|
|
||||||
set -ex
|
|
||||||
|
|
||||||
# Temporary hack: Must change C runtime library to "multi-threaded DLL",
|
|
||||||
# otherwise it will be set to "multi-threaded static" when MSVC upgrades
|
|
||||||
# the project file to MSVC 2005/2008. vladl of Google Test says gtest will
|
|
||||||
# probably change their default to match, then this will be unnecessary.
|
|
||||||
# One of these mappings converts the debug configuration and the other
|
|
||||||
# converts the release configuration. I don't know which is which.
|
|
||||||
sed -i -e 's/RuntimeLibrary="5"/RuntimeLibrary="3"/g;
|
|
||||||
s/RuntimeLibrary="4"/RuntimeLibrary="2"/g;' gtest/msvc/*.vcproj
|
|
||||||
|
|
||||||
# TODO(kenton): Remove the ",no-obsolete" part and fix the resulting warnings.
|
|
||||||
autoreconf -f -i -Wall,no-obsolete
|
|
||||||
|
|
||||||
rm -rf autom4te.cache config.h.in~
|
|
||||||
exit 0
|
|
@ -1,347 +0,0 @@
|
|||||||
#! /bin/sh
|
|
||||||
# Wrapper for compilers which do not understand '-c -o'.
|
|
||||||
|
|
||||||
scriptversion=2012-10-14.11; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1999-2013 Free Software Foundation, Inc.
|
|
||||||
# Written by Tom Tromey <tromey@cygnus.com>.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# This file is maintained in Automake, please report
|
|
||||||
# bugs to <bug-automake@gnu.org> or send patches to
|
|
||||||
# <automake-patches@gnu.org>.
|
|
||||||
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
|
|
||||||
# We need space, tab and new line, in precisely that order. Quoting is
|
|
||||||
# there to prevent tools from complaining about whitespace usage.
|
|
||||||
IFS=" "" $nl"
|
|
||||||
|
|
||||||
file_conv=
|
|
||||||
|
|
||||||
# func_file_conv build_file lazy
|
|
||||||
# Convert a $build file to $host form and store it in $file
|
|
||||||
# Currently only supports Windows hosts. If the determined conversion
|
|
||||||
# type is listed in (the comma separated) LAZY, no conversion will
|
|
||||||
# take place.
|
|
||||||
func_file_conv ()
|
|
||||||
{
|
|
||||||
file=$1
|
|
||||||
case $file in
|
|
||||||
/ | /[!/]*) # absolute file, and not a UNC file
|
|
||||||
if test -z "$file_conv"; then
|
|
||||||
# lazily determine how to convert abs files
|
|
||||||
case `uname -s` in
|
|
||||||
MINGW*)
|
|
||||||
file_conv=mingw
|
|
||||||
;;
|
|
||||||
CYGWIN*)
|
|
||||||
file_conv=cygwin
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
file_conv=wine
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
case $file_conv/,$2, in
|
|
||||||
*,$file_conv,*)
|
|
||||||
;;
|
|
||||||
mingw/*)
|
|
||||||
file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'`
|
|
||||||
;;
|
|
||||||
cygwin/*)
|
|
||||||
file=`cygpath -m "$file" || echo "$file"`
|
|
||||||
;;
|
|
||||||
wine/*)
|
|
||||||
file=`winepath -w "$file" || echo "$file"`
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# func_cl_dashL linkdir
|
|
||||||
# Make cl look for libraries in LINKDIR
|
|
||||||
func_cl_dashL ()
|
|
||||||
{
|
|
||||||
func_file_conv "$1"
|
|
||||||
if test -z "$lib_path"; then
|
|
||||||
lib_path=$file
|
|
||||||
else
|
|
||||||
lib_path="$lib_path;$file"
|
|
||||||
fi
|
|
||||||
linker_opts="$linker_opts -LIBPATH:$file"
|
|
||||||
}
|
|
||||||
|
|
||||||
# func_cl_dashl library
|
|
||||||
# Do a library search-path lookup for cl
|
|
||||||
func_cl_dashl ()
|
|
||||||
{
|
|
||||||
lib=$1
|
|
||||||
found=no
|
|
||||||
save_IFS=$IFS
|
|
||||||
IFS=';'
|
|
||||||
for dir in $lib_path $LIB
|
|
||||||
do
|
|
||||||
IFS=$save_IFS
|
|
||||||
if $shared && test -f "$dir/$lib.dll.lib"; then
|
|
||||||
found=yes
|
|
||||||
lib=$dir/$lib.dll.lib
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
if test -f "$dir/$lib.lib"; then
|
|
||||||
found=yes
|
|
||||||
lib=$dir/$lib.lib
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
if test -f "$dir/lib$lib.a"; then
|
|
||||||
found=yes
|
|
||||||
lib=$dir/lib$lib.a
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS=$save_IFS
|
|
||||||
|
|
||||||
if test "$found" != yes; then
|
|
||||||
lib=$lib.lib
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# func_cl_wrapper cl arg...
|
|
||||||
# Adjust compile command to suit cl
|
|
||||||
func_cl_wrapper ()
|
|
||||||
{
|
|
||||||
# Assume a capable shell
|
|
||||||
lib_path=
|
|
||||||
shared=:
|
|
||||||
linker_opts=
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$eat"; then
|
|
||||||
eat=
|
|
||||||
else
|
|
||||||
case $1 in
|
|
||||||
-o)
|
|
||||||
# configure might choose to run compile as 'compile cc -o foo foo.c'.
|
|
||||||
eat=1
|
|
||||||
case $2 in
|
|
||||||
*.o | *.[oO][bB][jJ])
|
|
||||||
func_file_conv "$2"
|
|
||||||
set x "$@" -Fo"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
func_file_conv "$2"
|
|
||||||
set x "$@" -Fe"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
-I)
|
|
||||||
eat=1
|
|
||||||
func_file_conv "$2" mingw
|
|
||||||
set x "$@" -I"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-I*)
|
|
||||||
func_file_conv "${1#-I}" mingw
|
|
||||||
set x "$@" -I"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-l)
|
|
||||||
eat=1
|
|
||||||
func_cl_dashl "$2"
|
|
||||||
set x "$@" "$lib"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-l*)
|
|
||||||
func_cl_dashl "${1#-l}"
|
|
||||||
set x "$@" "$lib"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-L)
|
|
||||||
eat=1
|
|
||||||
func_cl_dashL "$2"
|
|
||||||
;;
|
|
||||||
-L*)
|
|
||||||
func_cl_dashL "${1#-L}"
|
|
||||||
;;
|
|
||||||
-static)
|
|
||||||
shared=false
|
|
||||||
;;
|
|
||||||
-Wl,*)
|
|
||||||
arg=${1#-Wl,}
|
|
||||||
save_ifs="$IFS"; IFS=','
|
|
||||||
for flag in $arg; do
|
|
||||||
IFS="$save_ifs"
|
|
||||||
linker_opts="$linker_opts $flag"
|
|
||||||
done
|
|
||||||
IFS="$save_ifs"
|
|
||||||
;;
|
|
||||||
-Xlinker)
|
|
||||||
eat=1
|
|
||||||
linker_opts="$linker_opts $2"
|
|
||||||
;;
|
|
||||||
-*)
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*.cc | *.CC | *.cxx | *.CXX | *.[cC]++)
|
|
||||||
func_file_conv "$1"
|
|
||||||
set x "$@" -Tp"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO])
|
|
||||||
func_file_conv "$1" mingw
|
|
||||||
set x "$@" "$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
if test -n "$linker_opts"; then
|
|
||||||
linker_opts="-link$linker_opts"
|
|
||||||
fi
|
|
||||||
exec "$@" $linker_opts
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
eat=
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: compile [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Wrapper for compilers which do not understand '-c -o'.
|
|
||||||
Remove '-o dest.o' from ARGS, run PROGRAM with the remaining
|
|
||||||
arguments, and rename the output as expected.
|
|
||||||
|
|
||||||
If you are trying to build a whole package this is not the
|
|
||||||
right script to run: please start by reading the file 'INSTALL'.
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "compile $scriptversion"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe )
|
|
||||||
func_cl_wrapper "$@" # Doesn't return...
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
ofile=
|
|
||||||
cfile=
|
|
||||||
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$eat"; then
|
|
||||||
eat=
|
|
||||||
else
|
|
||||||
case $1 in
|
|
||||||
-o)
|
|
||||||
# configure might choose to run compile as 'compile cc -o foo foo.c'.
|
|
||||||
# So we strip '-o arg' only if arg is an object.
|
|
||||||
eat=1
|
|
||||||
case $2 in
|
|
||||||
*.o | *.obj)
|
|
||||||
ofile=$2
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set x "$@" -o "$2"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
*.c)
|
|
||||||
cfile=$1
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
if test -z "$ofile" || test -z "$cfile"; then
|
|
||||||
# If no '-o' option was seen then we might have been invoked from a
|
|
||||||
# pattern rule where we don't need one. That is ok -- this is a
|
|
||||||
# normal compilation that the losing compiler can handle. If no
|
|
||||||
# '.c' file was seen then we are probably linking. That is also
|
|
||||||
# ok.
|
|
||||||
exec "$@"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Name of file we expect compiler to create.
|
|
||||||
cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'`
|
|
||||||
|
|
||||||
# Create the lock directory.
|
|
||||||
# Note: use '[/\\:.-]' here to ensure that we don't use the same name
|
|
||||||
# that we are using for the .o file. Also, base the name on the expected
|
|
||||||
# object file name, since that is what matters with a parallel build.
|
|
||||||
lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d
|
|
||||||
while true; do
|
|
||||||
if mkdir "$lockdir" >/dev/null 2>&1; then
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
sleep 1
|
|
||||||
done
|
|
||||||
# FIXME: race condition here if user kills between mkdir and trap.
|
|
||||||
trap "rmdir '$lockdir'; exit 1" 1 2 15
|
|
||||||
|
|
||||||
# Run the compile.
|
|
||||||
"$@"
|
|
||||||
ret=$?
|
|
||||||
|
|
||||||
if test -f "$cofile"; then
|
|
||||||
test "$cofile" = "$ofile" || mv "$cofile" "$ofile"
|
|
||||||
elif test -f "${cofile}bj"; then
|
|
||||||
test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile"
|
|
||||||
fi
|
|
||||||
|
|
||||||
rmdir "$lockdir"
|
|
||||||
exit $ret
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
1558
common/protobuf-2.6.1/config.guess
vendored
1558
common/protobuf-2.6.1/config.guess
vendored
File diff suppressed because it is too large
Load Diff
@ -1,152 +0,0 @@
|
|||||||
/* config.h.in. Generated from configure.ac by autoheader. */
|
|
||||||
|
|
||||||
/* the name of <hash_map> */
|
|
||||||
#undef HASH_MAP_CLASS
|
|
||||||
|
|
||||||
/* the location of <unordered_map> or <hash_map> */
|
|
||||||
#undef HASH_MAP_H
|
|
||||||
|
|
||||||
/* the namespace of hash_map/hash_set */
|
|
||||||
#undef HASH_NAMESPACE
|
|
||||||
|
|
||||||
/* the name of <hash_set> */
|
|
||||||
#undef HASH_SET_CLASS
|
|
||||||
|
|
||||||
/* the location of <unordered_set> or <hash_set> */
|
|
||||||
#undef HASH_SET_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <dlfcn.h> header file. */
|
|
||||||
#undef HAVE_DLFCN_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <fcntl.h> header file. */
|
|
||||||
#undef HAVE_FCNTL_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `ftruncate' function. */
|
|
||||||
#undef HAVE_FTRUNCATE
|
|
||||||
|
|
||||||
/* define if the compiler has hash_map */
|
|
||||||
#undef HAVE_HASH_MAP
|
|
||||||
|
|
||||||
/* define if the compiler has hash_set */
|
|
||||||
#undef HAVE_HASH_SET
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <inttypes.h> header file. */
|
|
||||||
#undef HAVE_INTTYPES_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <limits.h> header file. */
|
|
||||||
#undef HAVE_LIMITS_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <memory.h> header file. */
|
|
||||||
#undef HAVE_MEMORY_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `memset' function. */
|
|
||||||
#undef HAVE_MEMSET
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `mkdir' function. */
|
|
||||||
#undef HAVE_MKDIR
|
|
||||||
|
|
||||||
/* Define if you have POSIX threads libraries and header files. */
|
|
||||||
#undef HAVE_PTHREAD
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdint.h> header file. */
|
|
||||||
#undef HAVE_STDINT_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdlib.h> header file. */
|
|
||||||
#undef HAVE_STDLIB_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strchr' function. */
|
|
||||||
#undef HAVE_STRCHR
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strerror' function. */
|
|
||||||
#undef HAVE_STRERROR
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <strings.h> header file. */
|
|
||||||
#undef HAVE_STRINGS_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <string.h> header file. */
|
|
||||||
#undef HAVE_STRING_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `strtol' function. */
|
|
||||||
#undef HAVE_STRTOL
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/stat.h> header file. */
|
|
||||||
#undef HAVE_SYS_STAT_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/types.h> header file. */
|
|
||||||
#undef HAVE_SYS_TYPES_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <unistd.h> header file. */
|
|
||||||
#undef HAVE_UNISTD_H
|
|
||||||
|
|
||||||
/* Enable classes using zlib compression. */
|
|
||||||
#undef HAVE_ZLIB
|
|
||||||
|
|
||||||
/* Define to the sub-directory in which libtool stores uninstalled libraries.
|
|
||||||
*/
|
|
||||||
#undef LT_OBJDIR
|
|
||||||
|
|
||||||
/* Name of package */
|
|
||||||
#undef PACKAGE
|
|
||||||
|
|
||||||
/* Define to the address where bug reports for this package should be sent. */
|
|
||||||
#undef PACKAGE_BUGREPORT
|
|
||||||
|
|
||||||
/* Define to the full name of this package. */
|
|
||||||
#undef PACKAGE_NAME
|
|
||||||
|
|
||||||
/* Define to the full name and version of this package. */
|
|
||||||
#undef PACKAGE_STRING
|
|
||||||
|
|
||||||
/* Define to the one symbol short name of this package. */
|
|
||||||
#undef PACKAGE_TARNAME
|
|
||||||
|
|
||||||
/* Define to the home page for this package. */
|
|
||||||
#undef PACKAGE_URL
|
|
||||||
|
|
||||||
/* Define to the version of this package. */
|
|
||||||
#undef PACKAGE_VERSION
|
|
||||||
|
|
||||||
/* Define to necessary symbol if this constant uses a non-standard name on
|
|
||||||
your system. */
|
|
||||||
#undef PTHREAD_CREATE_JOINABLE
|
|
||||||
|
|
||||||
/* 64bit enabled */
|
|
||||||
#undef SOLARIS_64BIT_ENABLED
|
|
||||||
|
|
||||||
/* Define to 1 if you have the ANSI C header files. */
|
|
||||||
#undef STDC_HEADERS
|
|
||||||
|
|
||||||
/* Enable extensions on AIX 3, Interix. */
|
|
||||||
#ifndef _ALL_SOURCE
|
|
||||||
# undef _ALL_SOURCE
|
|
||||||
#endif
|
|
||||||
/* Enable GNU extensions on systems that have them. */
|
|
||||||
#ifndef _GNU_SOURCE
|
|
||||||
# undef _GNU_SOURCE
|
|
||||||
#endif
|
|
||||||
/* Enable threading extensions on Solaris. */
|
|
||||||
#ifndef _POSIX_PTHREAD_SEMANTICS
|
|
||||||
# undef _POSIX_PTHREAD_SEMANTICS
|
|
||||||
#endif
|
|
||||||
/* Enable extensions on HP NonStop. */
|
|
||||||
#ifndef _TANDEM_SOURCE
|
|
||||||
# undef _TANDEM_SOURCE
|
|
||||||
#endif
|
|
||||||
/* Enable general extensions on Solaris. */
|
|
||||||
#ifndef __EXTENSIONS__
|
|
||||||
# undef __EXTENSIONS__
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* Version number of package */
|
|
||||||
#undef VERSION
|
|
||||||
|
|
||||||
/* Define to 1 if on MINIX. */
|
|
||||||
#undef _MINIX
|
|
||||||
|
|
||||||
/* Define to 2 if the system does not provide POSIX.1 features except with
|
|
||||||
this defined. */
|
|
||||||
#undef _POSIX_1_SOURCE
|
|
||||||
|
|
||||||
/* Define to 1 if you need to in order for `stat' and other things to work. */
|
|
||||||
#undef _POSIX_SOURCE
|
|
1791
common/protobuf-2.6.1/config.sub
vendored
1791
common/protobuf-2.6.1/config.sub
vendored
File diff suppressed because it is too large
Load Diff
19726
common/protobuf-2.6.1/configure
vendored
19726
common/protobuf-2.6.1/configure
vendored
File diff suppressed because it is too large
Load Diff
@ -1,159 +0,0 @@
|
|||||||
## Process this file with autoconf to produce configure.
|
|
||||||
## In general, the safest way to proceed is to run ./autogen.sh
|
|
||||||
|
|
||||||
AC_PREREQ(2.59)
|
|
||||||
|
|
||||||
# Note: If you change the version, you must also update it in:
|
|
||||||
# * java/pom.xml
|
|
||||||
# * python/setup.py
|
|
||||||
# * src/google/protobuf/stubs/common.h
|
|
||||||
# * src/Makefile.am (Update -version-info for LDFLAGS if needed)
|
|
||||||
#
|
|
||||||
# In the SVN trunk, the version should always be the next anticipated release
|
|
||||||
# version with the "-pre" suffix. (We used to use "-SNAPSHOT" but this pushed
|
|
||||||
# the size of one file name in the dist tarfile over the 99-char limit.)
|
|
||||||
AC_INIT([Protocol Buffers],[2.6.1],[protobuf@googlegroups.com],[protobuf])
|
|
||||||
|
|
||||||
AM_MAINTAINER_MODE([enable])
|
|
||||||
|
|
||||||
AC_CONFIG_SRCDIR(src/google/protobuf/message.cc)
|
|
||||||
AC_CONFIG_HEADERS([config.h])
|
|
||||||
AC_CONFIG_MACRO_DIR([m4])
|
|
||||||
|
|
||||||
# autoconf's default CXXFLAGS are usually "-g -O2". These aren't necessarily
|
|
||||||
# the best choice for libprotobuf.
|
|
||||||
AS_IF([test "x${ac_cv_env_CFLAGS_set}" = "x"],
|
|
||||||
[CFLAGS=""])
|
|
||||||
AS_IF([test "x${ac_cv_env_CXXFLAGS_set}" = "x"],
|
|
||||||
[CXXFLAGS=""])
|
|
||||||
|
|
||||||
AC_CANONICAL_TARGET
|
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE([subdir-objects])
|
|
||||||
|
|
||||||
AC_ARG_WITH([zlib],
|
|
||||||
[AS_HELP_STRING([--with-zlib],
|
|
||||||
[include classes for streaming compressed data in and out @<:@default=check@:>@])],
|
|
||||||
[],[with_zlib=check])
|
|
||||||
|
|
||||||
AC_ARG_WITH([protoc],
|
|
||||||
[AS_HELP_STRING([--with-protoc=COMMAND],
|
|
||||||
[use the given protoc command instead of building a new one when building tests (useful for cross-compiling)])],
|
|
||||||
[],[with_protoc=no])
|
|
||||||
|
|
||||||
# Checks for programs.
|
|
||||||
AC_PROG_CC
|
|
||||||
AC_PROG_CXX
|
|
||||||
AC_LANG([C++])
|
|
||||||
ACX_USE_SYSTEM_EXTENSIONS
|
|
||||||
AM_CONDITIONAL(GCC, test "$GCC" = yes) # let the Makefile know if we're gcc
|
|
||||||
|
|
||||||
# test_util.cc takes forever to compile with GCC and optimization turned on.
|
|
||||||
AC_MSG_CHECKING([C++ compiler flags...])
|
|
||||||
AS_IF([test "x${ac_cv_env_CXXFLAGS_set}" = "x"],[
|
|
||||||
AS_IF([test "$GCC" = "yes"],[
|
|
||||||
PROTOBUF_OPT_FLAG="-O2"
|
|
||||||
CXXFLAGS="${CXXFLAGS} -g"
|
|
||||||
])
|
|
||||||
|
|
||||||
# Protocol Buffers contains several checks that are intended to be used only
|
|
||||||
# for debugging and which might hurt performance. Most users are probably
|
|
||||||
# end users who don't want these checks, so add -DNDEBUG by default.
|
|
||||||
CXXFLAGS="$CXXFLAGS -DNDEBUG"
|
|
||||||
|
|
||||||
AC_MSG_RESULT([use default: $PROTOBUF_OPT_FLAG $CXXFLAGS])
|
|
||||||
],[
|
|
||||||
AC_MSG_RESULT([use user-supplied: $CXXFLAGS])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_SUBST(PROTOBUF_OPT_FLAG)
|
|
||||||
|
|
||||||
ACX_CHECK_SUNCC
|
|
||||||
|
|
||||||
# Have to do libtool after SUNCC, other wise it "helpfully" adds Crun Cstd
|
|
||||||
# to the link
|
|
||||||
AC_PROG_LIBTOOL
|
|
||||||
|
|
||||||
# Checks for header files.
|
|
||||||
AC_HEADER_STDC
|
|
||||||
AC_CHECK_HEADERS([fcntl.h inttypes.h limits.h stdlib.h unistd.h])
|
|
||||||
|
|
||||||
# Checks for library functions.
|
|
||||||
AC_FUNC_MEMCMP
|
|
||||||
AC_FUNC_STRTOD
|
|
||||||
AC_CHECK_FUNCS([ftruncate memset mkdir strchr strerror strtol])
|
|
||||||
|
|
||||||
# Check for zlib.
|
|
||||||
HAVE_ZLIB=0
|
|
||||||
AS_IF([test "$with_zlib" != no], [
|
|
||||||
AC_MSG_CHECKING([zlib version])
|
|
||||||
|
|
||||||
# First check the zlib header version.
|
|
||||||
AC_COMPILE_IFELSE(
|
|
||||||
[AC_LANG_PROGRAM([[
|
|
||||||
#include <zlib.h>
|
|
||||||
#if !defined(ZLIB_VERNUM) || (ZLIB_VERNUM < 0x1204)
|
|
||||||
# error zlib version too old
|
|
||||||
#endif
|
|
||||||
]], [])], [
|
|
||||||
AC_MSG_RESULT([ok (1.2.0.4 or later)])
|
|
||||||
|
|
||||||
# Also need to add -lz to the linker flags and make sure this succeeds.
|
|
||||||
AC_SEARCH_LIBS([zlibVersion], [z], [
|
|
||||||
AC_DEFINE([HAVE_ZLIB], [1], [Enable classes using zlib compression.])
|
|
||||||
HAVE_ZLIB=1
|
|
||||||
], [
|
|
||||||
AS_IF([test "$with_zlib" != check], [
|
|
||||||
AC_MSG_FAILURE([--with-zlib was given, but no working zlib library was found])
|
|
||||||
])
|
|
||||||
])
|
|
||||||
], [
|
|
||||||
AS_IF([test "$with_zlib" = check], [
|
|
||||||
AC_MSG_RESULT([headers missing or too old (requires 1.2.0.4)])
|
|
||||||
], [
|
|
||||||
AC_MSG_FAILURE([--with-zlib was given, but zlib headers were not present or were too old (requires 1.2.0.4)])
|
|
||||||
])
|
|
||||||
])
|
|
||||||
])
|
|
||||||
AM_CONDITIONAL([HAVE_ZLIB], [test $HAVE_ZLIB = 1])
|
|
||||||
|
|
||||||
AS_IF([test "$with_protoc" != "no"], [
|
|
||||||
PROTOC=$with_protoc
|
|
||||||
AS_IF([test "$with_protoc" = "yes"], [
|
|
||||||
# No argument given. Use system protoc.
|
|
||||||
PROTOC=protoc
|
|
||||||
])
|
|
||||||
AS_IF([echo "$PROTOC" | grep -q '^@<:@^/@:>@.*/'], [
|
|
||||||
# Does not start with a slash, but contains a slash. So, it's a relative
|
|
||||||
# path (as opposed to an absolute path or an executable in $PATH).
|
|
||||||
# Since it will actually be executed from the src directory, prefix with
|
|
||||||
# the current directory. We also insert $ac_top_build_prefix in case this
|
|
||||||
# is a nested package and --with-protoc was actually given on the outer
|
|
||||||
# package's configure script.
|
|
||||||
PROTOC=`pwd`/${ac_top_build_prefix}$PROTOC
|
|
||||||
])
|
|
||||||
AC_SUBST([PROTOC])
|
|
||||||
])
|
|
||||||
AM_CONDITIONAL([USE_EXTERNAL_PROTOC], [test "$with_protoc" != "no"])
|
|
||||||
|
|
||||||
ACX_PTHREAD
|
|
||||||
AC_CXX_STL_HASH
|
|
||||||
|
|
||||||
case "$target_os" in
|
|
||||||
mingw* | cygwin* | win*)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
# Need to link against rt on Solaris
|
|
||||||
AC_SEARCH_LIBS([sched_yield], [rt], [], [AC_MSG_FAILURE([sched_yield was not found on your system])])
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# HACK: Make gtest's configure script pick up our copy of CFLAGS and CXXFLAGS,
|
|
||||||
# since the flags added by ACX_CHECK_SUNCC must be used when compiling gtest
|
|
||||||
# too.
|
|
||||||
export CFLAGS
|
|
||||||
export CXXFLAGS
|
|
||||||
AC_CONFIG_SUBDIRS([gtest])
|
|
||||||
|
|
||||||
AC_CONFIG_FILES([Makefile src/Makefile protobuf.pc protobuf-lite.pc])
|
|
||||||
AC_OUTPUT
|
|
@ -1,791 +0,0 @@
|
|||||||
#! /bin/sh
|
|
||||||
# depcomp - compile a program generating dependencies as side-effects
|
|
||||||
|
|
||||||
scriptversion=2013-05-30.07; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1999-2013 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: depcomp [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Run PROGRAMS ARGS to compile a file, generating dependencies
|
|
||||||
as side-effects.
|
|
||||||
|
|
||||||
Environment variables:
|
|
||||||
depmode Dependency tracking mode.
|
|
||||||
source Source file read by 'PROGRAMS ARGS'.
|
|
||||||
object Object file output by 'PROGRAMS ARGS'.
|
|
||||||
DEPDIR directory where to store dependencies.
|
|
||||||
depfile Dependency file to output.
|
|
||||||
tmpdepfile Temporary file to use when outputting dependencies.
|
|
||||||
libtool Whether libtool is used (yes/no).
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "depcomp $scriptversion"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Get the directory component of the given path, and save it in the
|
|
||||||
# global variables '$dir'. Note that this directory component will
|
|
||||||
# be either empty or ending with a '/' character. This is deliberate.
|
|
||||||
set_dir_from ()
|
|
||||||
{
|
|
||||||
case $1 in
|
|
||||||
*/*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;;
|
|
||||||
*) dir=;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# Get the suffix-stripped basename of the given path, and save it the
|
|
||||||
# global variable '$base'.
|
|
||||||
set_base_from ()
|
|
||||||
{
|
|
||||||
base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'`
|
|
||||||
}
|
|
||||||
|
|
||||||
# If no dependency file was actually created by the compiler invocation,
|
|
||||||
# we still have to create a dummy depfile, to avoid errors with the
|
|
||||||
# Makefile "include basename.Plo" scheme.
|
|
||||||
make_dummy_depfile ()
|
|
||||||
{
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Factor out some common post-processing of the generated depfile.
|
|
||||||
# Requires the auxiliary global variable '$tmpdepfile' to be set.
|
|
||||||
aix_post_process_depfile ()
|
|
||||||
{
|
|
||||||
# If the compiler actually managed to produce a dependency file,
|
|
||||||
# post-process it.
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
# Each line is of the form 'foo.o: dependency.h'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# $object: dependency.h
|
|
||||||
# and one to simply output
|
|
||||||
# dependency.h:
|
|
||||||
# which is needed to avoid the deleted-header problem.
|
|
||||||
{ sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile"
|
|
||||||
sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile"
|
|
||||||
} > "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# A tabulation character.
|
|
||||||
tab=' '
|
|
||||||
# A newline character.
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
# Character ranges might be problematic outside the C locale.
|
|
||||||
# These definitions help.
|
|
||||||
upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
|
||||||
lower=abcdefghijklmnopqrstuvwxyz
|
|
||||||
digits=0123456789
|
|
||||||
alpha=${upper}${lower}
|
|
||||||
|
|
||||||
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
|
||||||
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
|
|
||||||
depfile=${depfile-`echo "$object" |
|
|
||||||
sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
|
|
||||||
tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
|
||||||
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
|
|
||||||
# Avoid interferences from the environment.
|
|
||||||
gccflag= dashmflag=
|
|
||||||
|
|
||||||
# Some modes work just like other modes, but use different flags. We
|
|
||||||
# parameterize here, but still list the modes in the big case below,
|
|
||||||
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
|
||||||
# here, because this file can only contain one case statement.
|
|
||||||
if test "$depmode" = hp; then
|
|
||||||
# HP compiler uses -M and no extra arg.
|
|
||||||
gccflag=-M
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = dashXmstdout; then
|
|
||||||
# This is just like dashmstdout with a different argument.
|
|
||||||
dashmflag=-xM
|
|
||||||
depmode=dashmstdout
|
|
||||||
fi
|
|
||||||
|
|
||||||
cygpath_u="cygpath -u -f -"
|
|
||||||
if test "$depmode" = msvcmsys; then
|
|
||||||
# This is just like msvisualcpp but w/o cygpath translation.
|
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
|
||||||
# slashes to satisfy depend.m4
|
|
||||||
cygpath_u='sed s,\\\\,/,g'
|
|
||||||
depmode=msvisualcpp
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = msvc7msys; then
|
|
||||||
# This is just like msvc7 but w/o cygpath translation.
|
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
|
||||||
# slashes to satisfy depend.m4
|
|
||||||
cygpath_u='sed s,\\\\,/,g'
|
|
||||||
depmode=msvc7
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = xlc; then
|
|
||||||
# IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information.
|
|
||||||
gccflag=-qmakedep=gcc,-MF
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$depmode" in
|
|
||||||
gcc3)
|
|
||||||
## gcc 3 implements dependency tracking that does exactly what
|
|
||||||
## we want. Yay! Note: for some reason libtool 1.4 doesn't like
|
|
||||||
## it if -MD -MP comes after the -MF stuff. Hmm.
|
|
||||||
## Unfortunately, FreeBSD c89 acceptance of flags depends upon
|
|
||||||
## the command line argument order; so add the flags where they
|
|
||||||
## appear in depend2.am. Note that the slowdown incurred here
|
|
||||||
## affects only configure: in makefiles, %FASTDEP% shortcuts this.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;;
|
|
||||||
*) set fnord "$@" "$arg" ;;
|
|
||||||
esac
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
done
|
|
||||||
"$@"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
mv "$tmpdepfile" "$depfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
gcc)
|
|
||||||
## Note that this doesn't just cater to obsosete pre-3.x GCC compilers.
|
|
||||||
## but also to in-use compilers like IMB xlc/xlC and the HP C compiler.
|
|
||||||
## (see the conditional assignment to $gccflag above).
|
|
||||||
## There are various ways to get dependency output from gcc. Here's
|
|
||||||
## why we pick this rather obscure method:
|
|
||||||
## - Don't want to use -MD because we'd like the dependencies to end
|
|
||||||
## up in a subdir. Having to rename by hand is ugly.
|
|
||||||
## (We might end up doing this anyway to support other compilers.)
|
|
||||||
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
|
||||||
## -MM, not -M (despite what the docs say). Also, it might not be
|
|
||||||
## supported by the other compilers which use the 'gcc' depmode.
|
|
||||||
## - Using -M directly means running the compiler twice (even worse
|
|
||||||
## than renaming).
|
|
||||||
if test -z "$gccflag"; then
|
|
||||||
gccflag=-MD,
|
|
||||||
fi
|
|
||||||
"$@" -Wp,"$gccflag$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# The second -e expression handles DOS-style file names with drive
|
|
||||||
# letters.
|
|
||||||
sed -e 's/^[^:]*: / /' \
|
|
||||||
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
|
||||||
## This next piece of magic avoids the "deleted header file" problem.
|
|
||||||
## The problem is that when a header file which appears in a .P file
|
|
||||||
## is deleted, the dependency causes make to die (because there is
|
|
||||||
## typically no way to rebuild the header). We avoid this by adding
|
|
||||||
## dummy dependencies for each header file. Too bad gcc doesn't do
|
|
||||||
## this for us directly.
|
|
||||||
## Some versions of gcc put a space before the ':'. On the theory
|
|
||||||
## that the space means something, we add a space to the output as
|
|
||||||
## well. hp depmode also adds that space, but also prefixes the VPATH
|
|
||||||
## to the object. Take care to not repeat it in the output.
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
sgi)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" "-Wp,-MDupdate,$tmpdepfile"
|
|
||||||
else
|
|
||||||
"$@" -MDupdate "$tmpdepfile"
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# Clip off the initial element (the dependent). Don't try to be
|
|
||||||
# clever and replace this with sed code, as IRIX sed won't handle
|
|
||||||
# lines with more than a fixed number of characters (4096 in
|
|
||||||
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
|
||||||
# the IRIX cc adds comments like '#:fec' to the end of the
|
|
||||||
# dependency line.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \
|
|
||||||
| tr "$nl" ' ' >> "$depfile"
|
|
||||||
echo >> "$depfile"
|
|
||||||
# The second pass generates a dummy entry for each header file.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
|
||||||
>> "$depfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
xlc)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
aix)
|
|
||||||
# The C for AIX Compiler uses -M and outputs the dependencies
|
|
||||||
# in a .u file. In older versions, this file always lives in the
|
|
||||||
# current directory. Also, the AIX compiler puts '$object:' at the
|
|
||||||
# start of each line; $object doesn't have directory information.
|
|
||||||
# Version 6 uses the directory in both cases.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
tmpdepfile1=$dir$base.u
|
|
||||||
tmpdepfile2=$base.u
|
|
||||||
tmpdepfile3=$dir.libs/$base.u
|
|
||||||
"$@" -Wc,-M
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.u
|
|
||||||
tmpdepfile2=$dir$base.u
|
|
||||||
tmpdepfile3=$dir$base.u
|
|
||||||
"$@" -M
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
aix_post_process_depfile
|
|
||||||
;;
|
|
||||||
|
|
||||||
tcc)
|
|
||||||
# tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26
|
|
||||||
# FIXME: That version still under development at the moment of writing.
|
|
||||||
# Make that this statement remains true also for stable, released
|
|
||||||
# versions.
|
|
||||||
# It will wrap lines (doesn't matter whether long or short) with a
|
|
||||||
# trailing '\', as in:
|
|
||||||
#
|
|
||||||
# foo.o : \
|
|
||||||
# foo.c \
|
|
||||||
# foo.h \
|
|
||||||
#
|
|
||||||
# It will put a trailing '\' even on the last line, and will use leading
|
|
||||||
# spaces rather than leading tabs (at least since its commit 0394caf7
|
|
||||||
# "Emit spaces for -MD").
|
|
||||||
"$@" -MD -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each non-empty line is of the form 'foo.o : \' or ' dep.h \'.
|
|
||||||
# We have to change lines of the first kind to '$object: \'.
|
|
||||||
sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile"
|
|
||||||
# And for each line of the second kind, we have to emit a 'dep.h:'
|
|
||||||
# dummy dependency, to avoid the deleted-header problem.
|
|
||||||
sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
## The order of this option in the case statement is important, since the
|
|
||||||
## shell code in configure will try each of these formats in the order
|
|
||||||
## listed in this file. A plain '-MD' option would be understood by many
|
|
||||||
## compilers, so we must ensure this comes after the gcc and icc options.
|
|
||||||
pgcc)
|
|
||||||
# Portland's C compiler understands '-MD'.
|
|
||||||
# Will always output deps to 'file.d' where file is the root name of the
|
|
||||||
# source file under compilation, even if file resides in a subdirectory.
|
|
||||||
# The object file name does not affect the name of the '.d' file.
|
|
||||||
# pgcc 10.2 will output
|
|
||||||
# foo.o: sub/foo.c sub/foo.h
|
|
||||||
# and will wrap long lines using '\' :
|
|
||||||
# foo.o: sub/foo.c ... \
|
|
||||||
# sub/foo.h ... \
|
|
||||||
# ...
|
|
||||||
set_dir_from "$object"
|
|
||||||
# Use the source, not the object, to determine the base name, since
|
|
||||||
# that's sadly what pgcc will do too.
|
|
||||||
set_base_from "$source"
|
|
||||||
tmpdepfile=$base.d
|
|
||||||
|
|
||||||
# For projects that build the same source file twice into different object
|
|
||||||
# files, the pgcc approach of using the *source* file root name can cause
|
|
||||||
# problems in parallel builds. Use a locking strategy to avoid stomping on
|
|
||||||
# the same $tmpdepfile.
|
|
||||||
lockdir=$base.d-lock
|
|
||||||
trap "
|
|
||||||
echo '$0: caught signal, cleaning up...' >&2
|
|
||||||
rmdir '$lockdir'
|
|
||||||
exit 1
|
|
||||||
" 1 2 13 15
|
|
||||||
numtries=100
|
|
||||||
i=$numtries
|
|
||||||
while test $i -gt 0; do
|
|
||||||
# mkdir is a portable test-and-set.
|
|
||||||
if mkdir "$lockdir" 2>/dev/null; then
|
|
||||||
# This process acquired the lock.
|
|
||||||
"$@" -MD
|
|
||||||
stat=$?
|
|
||||||
# Release the lock.
|
|
||||||
rmdir "$lockdir"
|
|
||||||
break
|
|
||||||
else
|
|
||||||
# If the lock is being held by a different process, wait
|
|
||||||
# until the winning process is done or we timeout.
|
|
||||||
while test -d "$lockdir" && test $i -gt 0; do
|
|
||||||
sleep 1
|
|
||||||
i=`expr $i - 1`
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
i=`expr $i - 1`
|
|
||||||
done
|
|
||||||
trap - 1 2 13 15
|
|
||||||
if test $i -le 0; then
|
|
||||||
echo "$0: failed to acquire lock after $numtries attempts" >&2
|
|
||||||
echo "$0: check lockdir '$lockdir'" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each line is of the form `foo.o: dependent.h',
|
|
||||||
# or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp2)
|
|
||||||
# The "hp" stanza above does not work with aCC (C++) and HP's ia64
|
|
||||||
# compilers, which have integrated preprocessors. The correct option
|
|
||||||
# to use with these is +Maked; it writes dependencies to a file named
|
|
||||||
# 'foo.d', which lands next to the object file, wherever that
|
|
||||||
# happens to be.
|
|
||||||
# Much of this is similar to the tru64 case; see comments there.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir.libs/$base.d
|
|
||||||
"$@" -Wc,+Maked
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
"$@" +Maked
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile"
|
|
||||||
# Add 'dependent.h:' lines.
|
|
||||||
sed -ne '2,${
|
|
||||||
s/^ *//
|
|
||||||
s/ \\*$//
|
|
||||||
s/$/:/
|
|
||||||
p
|
|
||||||
}' "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile2"
|
|
||||||
;;
|
|
||||||
|
|
||||||
tru64)
|
|
||||||
# The Tru64 compiler uses -MD to generate dependencies as a side
|
|
||||||
# effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'.
|
|
||||||
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
|
||||||
# dependencies in 'foo.d' instead, so we check for that too.
|
|
||||||
# Subdirectories are respected.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
# Libtool generates 2 separate objects for the 2 libraries. These
|
|
||||||
# two compilations output dependencies in $dir.libs/$base.o.d and
|
|
||||||
# in $dir$base.o.d. We have to check for both files, because
|
|
||||||
# one of the two compilations can be disabled. We should prefer
|
|
||||||
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
|
||||||
# automatically cleaned when .libs/ is deleted, while ignoring
|
|
||||||
# the former would cause a distcleancheck panic.
|
|
||||||
tmpdepfile1=$dir$base.o.d # libtool 1.5
|
|
||||||
tmpdepfile2=$dir.libs/$base.o.d # Likewise.
|
|
||||||
tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504
|
|
||||||
"$@" -Wc,-MD
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
tmpdepfile3=$dir$base.d
|
|
||||||
"$@" -MD
|
|
||||||
fi
|
|
||||||
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
# Same post-processing that is required for AIX mode.
|
|
||||||
aix_post_process_depfile
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvc7)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
showIncludes=-Wc,-showIncludes
|
|
||||||
else
|
|
||||||
showIncludes=-showIncludes
|
|
||||||
fi
|
|
||||||
"$@" $showIncludes > "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
grep -v '^Note: including file: ' "$tmpdepfile"
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# The first sed program below extracts the file names and escapes
|
|
||||||
# backslashes for cygpath. The second sed program outputs the file
|
|
||||||
# name when reading, but also accumulates all include files in the
|
|
||||||
# hold buffer in order to output them again at the end. This only
|
|
||||||
# works with sed implementations that can handle large buffers.
|
|
||||||
sed < "$tmpdepfile" -n '
|
|
||||||
/^Note: including file: *\(.*\)/ {
|
|
||||||
s//\1/
|
|
||||||
s/\\/\\\\/g
|
|
||||||
p
|
|
||||||
}' | $cygpath_u | sort -u | sed -n '
|
|
||||||
s/ /\\ /g
|
|
||||||
s/\(.*\)/'"$tab"'\1 \\/p
|
|
||||||
s/.\(.*\) \\/\1:/
|
|
||||||
H
|
|
||||||
$ {
|
|
||||||
s/.*/'"$tab"'/
|
|
||||||
G
|
|
||||||
p
|
|
||||||
}' >> "$depfile"
|
|
||||||
echo >> "$depfile" # make sure the fragment doesn't end with a backslash
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvc7msys)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
#nosideeffect)
|
|
||||||
# This comment above is used by automake to tell side-effect
|
|
||||||
# dependency tracking mechanisms from slower ones.
|
|
||||||
|
|
||||||
dashmstdout)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove '-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
test -z "$dashmflag" && dashmflag=-M
|
|
||||||
# Require at least two characters before searching for ':'
|
|
||||||
# in the target name. This is to cope with DOS-style filenames:
|
|
||||||
# a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise.
|
|
||||||
"$@" $dashmflag |
|
|
||||||
sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this sed invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
dashXmstdout)
|
|
||||||
# This case only exists to satisfy depend.m4. It is never actually
|
|
||||||
# run, as this mode is specially recognized in the preamble.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
makedepend)
|
|
||||||
"$@" || exit $?
|
|
||||||
# Remove any Libtool call
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
# X makedepend
|
|
||||||
shift
|
|
||||||
cleared=no eat=no
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $cleared in
|
|
||||||
no)
|
|
||||||
set ""; shift
|
|
||||||
cleared=yes ;;
|
|
||||||
esac
|
|
||||||
if test $eat = yes; then
|
|
||||||
eat=no
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
case "$arg" in
|
|
||||||
-D*|-I*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
# Strip any option that makedepend may not understand. Remove
|
|
||||||
# the object too, otherwise makedepend will parse it as a source file.
|
|
||||||
-arch)
|
|
||||||
eat=yes ;;
|
|
||||||
-*|$object)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
obj_suffix=`echo "$object" | sed 's/^.*\././'`
|
|
||||||
touch "$tmpdepfile"
|
|
||||||
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
|
||||||
rm -f "$depfile"
|
|
||||||
# makedepend may prepend the VPATH from the source file name to the object.
|
|
||||||
# No need to regex-escape $object, excess matching of '.' is harmless.
|
|
||||||
sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process the last invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed '1,2d' "$tmpdepfile" \
|
|
||||||
| tr ' ' "$nl" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
|
||||||
;;
|
|
||||||
|
|
||||||
cpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove '-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
"$@" -E \
|
|
||||||
| sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
| sed '$ s: \\$::' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
cat < "$tmpdepfile" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvisualcpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case "$arg" in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
"-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
|
|
||||||
set fnord "$@"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
"$@" -E 2>/dev/null |
|
|
||||||
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile"
|
|
||||||
echo "$tab" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvcmsys)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
none)
|
|
||||||
exec "$@"
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Unknown depmode $depmode" 1>&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
@ -1,58 +0,0 @@
|
|||||||
# See README.txt.
|
|
||||||
|
|
||||||
.PHONY: all cpp java python clean
|
|
||||||
|
|
||||||
all: cpp java python
|
|
||||||
|
|
||||||
cpp: add_person_cpp list_people_cpp
|
|
||||||
java: add_person_java list_people_java
|
|
||||||
python: add_person_python list_people_python
|
|
||||||
|
|
||||||
clean:
|
|
||||||
rm -f add_person_cpp list_people_cpp add_person_java list_people_java add_person_python list_people_python
|
|
||||||
rm -f javac_middleman AddPerson*.class ListPeople*.class com/example/tutorial/*.class
|
|
||||||
rm -f protoc_middleman addressbook.pb.cc addressbook.pb.h addressbook_pb2.py com/example/tutorial/AddressBookProtos.java
|
|
||||||
rm -f *.pyc
|
|
||||||
rmdir com/example/tutorial 2>/dev/null || true
|
|
||||||
rmdir com/example 2>/dev/null || true
|
|
||||||
rmdir com 2>/dev/null || true
|
|
||||||
|
|
||||||
protoc_middleman: addressbook.proto
|
|
||||||
protoc --cpp_out=. --java_out=. --python_out=. addressbook.proto
|
|
||||||
@touch protoc_middleman
|
|
||||||
|
|
||||||
add_person_cpp: add_person.cc protoc_middleman
|
|
||||||
pkg-config --cflags protobuf # fails if protobuf is not installed
|
|
||||||
c++ add_person.cc addressbook.pb.cc -o add_person_cpp `pkg-config --cflags --libs protobuf`
|
|
||||||
|
|
||||||
list_people_cpp: list_people.cc protoc_middleman
|
|
||||||
pkg-config --cflags protobuf # fails if protobuf is not installed
|
|
||||||
c++ list_people.cc addressbook.pb.cc -o list_people_cpp `pkg-config --cflags --libs protobuf`
|
|
||||||
|
|
||||||
javac_middleman: AddPerson.java ListPeople.java protoc_middleman
|
|
||||||
javac AddPerson.java ListPeople.java com/example/tutorial/AddressBookProtos.java
|
|
||||||
@touch javac_middleman
|
|
||||||
|
|
||||||
add_person_java: javac_middleman
|
|
||||||
@echo "Writing shortcut script add_person_java..."
|
|
||||||
@echo '#! /bin/sh' > add_person_java
|
|
||||||
@echo 'java -classpath .:$$CLASSPATH AddPerson "$$@"' >> add_person_java
|
|
||||||
@chmod +x add_person_java
|
|
||||||
|
|
||||||
list_people_java: javac_middleman
|
|
||||||
@echo "Writing shortcut script list_people_java..."
|
|
||||||
@echo '#! /bin/sh' > list_people_java
|
|
||||||
@echo 'java -classpath .:$$CLASSPATH ListPeople "$$@"' >> list_people_java
|
|
||||||
@chmod +x list_people_java
|
|
||||||
|
|
||||||
add_person_python: add_person.py protoc_middleman
|
|
||||||
@echo "Writing shortcut script add_person_python..."
|
|
||||||
@echo '#! /bin/sh' > add_person_python
|
|
||||||
@echo './add_person.py "$$@"' >> add_person_python
|
|
||||||
@chmod +x add_person_python
|
|
||||||
|
|
||||||
list_people_python: list_people.py protoc_middleman
|
|
||||||
@echo "Writing shortcut script list_people_python..."
|
|
||||||
@echo '#! /bin/sh' > list_people_python
|
|
||||||
@echo './list_people.py "$$@"' >> list_people_python
|
|
||||||
@chmod +x list_people_python
|
|
@ -1,29 +0,0 @@
|
|||||||
This directory contains example code that uses Protocol Buffers to manage an
|
|
||||||
address book. Two programs are provided, each with three different
|
|
||||||
implementations, one written in each of C++, Java, and Python. The add_person
|
|
||||||
example adds a new person to an address book, prompting the user to input
|
|
||||||
the person's information. The list_people example lists people already in the
|
|
||||||
address book. The examples use the exact same format in all three languages,
|
|
||||||
so you can, for example, use add_person_java to create an address book and then
|
|
||||||
use list_people_python to read it.
|
|
||||||
|
|
||||||
You must install the protobuf package before you can build these.
|
|
||||||
|
|
||||||
To build all the examples (on a unix-like system), simply run "make". This
|
|
||||||
creates the following executable files in the current directory:
|
|
||||||
add_person_cpp list_people_cpp
|
|
||||||
add_person_java list_people_java
|
|
||||||
add_person_python list_people_python
|
|
||||||
|
|
||||||
If you only want to compile examples in one language, use "make cpp"*,
|
|
||||||
"make java", or "make python".
|
|
||||||
|
|
||||||
All of these programs simply take an address book file as their parameter.
|
|
||||||
The add_person programs will create the file if it doesn't already exist.
|
|
||||||
|
|
||||||
These examples are part of the Protocol Buffers tutorial, located at:
|
|
||||||
https://developers.google.com/protocol-buffers/docs/tutorials
|
|
||||||
|
|
||||||
* Note that on some platforms you may have to edit the Makefile and remove
|
|
||||||
"-lpthread" from the linker commands (perhaps replacing it with something else).
|
|
||||||
We didn't do this automatically because we wanted to keep the example simple.
|
|
@ -1,58 +0,0 @@
|
|||||||
#! /usr/bin/python
|
|
||||||
|
|
||||||
# See README.txt for information and build instructions.
|
|
||||||
|
|
||||||
import addressbook_pb2
|
|
||||||
import sys
|
|
||||||
|
|
||||||
# This function fills in a Person message based on user input.
|
|
||||||
def PromptForAddress(person):
|
|
||||||
person.id = int(raw_input("Enter person ID number: "))
|
|
||||||
person.name = raw_input("Enter name: ")
|
|
||||||
|
|
||||||
email = raw_input("Enter email address (blank for none): ")
|
|
||||||
if email != "":
|
|
||||||
person.email = email
|
|
||||||
|
|
||||||
while True:
|
|
||||||
number = raw_input("Enter a phone number (or leave blank to finish): ")
|
|
||||||
if number == "":
|
|
||||||
break
|
|
||||||
|
|
||||||
phone_number = person.phone.add()
|
|
||||||
phone_number.number = number
|
|
||||||
|
|
||||||
type = raw_input("Is this a mobile, home, or work phone? ")
|
|
||||||
if type == "mobile":
|
|
||||||
phone_number.type = addressbook_pb2.Person.MOBILE
|
|
||||||
elif type == "home":
|
|
||||||
phone_number.type = addressbook_pb2.Person.HOME
|
|
||||||
elif type == "work":
|
|
||||||
phone_number.type = addressbook_pb2.Person.WORK
|
|
||||||
else:
|
|
||||||
print "Unknown phone type; leaving as default value."
|
|
||||||
|
|
||||||
# Main procedure: Reads the entire address book from a file,
|
|
||||||
# adds one person based on user input, then writes it back out to the same
|
|
||||||
# file.
|
|
||||||
if len(sys.argv) != 2:
|
|
||||||
print "Usage:", sys.argv[0], "ADDRESS_BOOK_FILE"
|
|
||||||
sys.exit(-1)
|
|
||||||
|
|
||||||
address_book = addressbook_pb2.AddressBook()
|
|
||||||
|
|
||||||
# Read the existing address book.
|
|
||||||
try:
|
|
||||||
f = open(sys.argv[1], "rb")
|
|
||||||
address_book.ParseFromString(f.read())
|
|
||||||
f.close()
|
|
||||||
except IOError:
|
|
||||||
print sys.argv[1] + ": File not found. Creating a new file."
|
|
||||||
|
|
||||||
# Add an address.
|
|
||||||
PromptForAddress(address_book.person.add())
|
|
||||||
|
|
||||||
# Write the new address book back to disk.
|
|
||||||
f = open(sys.argv[1], "wb")
|
|
||||||
f.write(address_book.SerializeToString())
|
|
||||||
f.close()
|
|
@ -1,30 +0,0 @@
|
|||||||
// See README.txt for information and build instructions.
|
|
||||||
|
|
||||||
package tutorial;
|
|
||||||
|
|
||||||
option java_package = "com.example.tutorial";
|
|
||||||
option java_outer_classname = "AddressBookProtos";
|
|
||||||
|
|
||||||
message Person {
|
|
||||||
required string name = 1;
|
|
||||||
required int32 id = 2; // Unique ID number for this person.
|
|
||||||
optional string email = 3;
|
|
||||||
|
|
||||||
enum PhoneType {
|
|
||||||
MOBILE = 0;
|
|
||||||
HOME = 1;
|
|
||||||
WORK = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
message PhoneNumber {
|
|
||||||
required string number = 1;
|
|
||||||
optional PhoneType type = 2 [default = HOME];
|
|
||||||
}
|
|
||||||
|
|
||||||
repeated PhoneNumber phone = 4;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Our address book file is just one of these.
|
|
||||||
message AddressBook {
|
|
||||||
repeated Person person = 1;
|
|
||||||
}
|
|
@ -1,38 +0,0 @@
|
|||||||
#! /usr/bin/python
|
|
||||||
|
|
||||||
# See README.txt for information and build instructions.
|
|
||||||
|
|
||||||
import addressbook_pb2
|
|
||||||
import sys
|
|
||||||
|
|
||||||
# Iterates though all people in the AddressBook and prints info about them.
|
|
||||||
def ListPeople(address_book):
|
|
||||||
for person in address_book.person:
|
|
||||||
print "Person ID:", person.id
|
|
||||||
print " Name:", person.name
|
|
||||||
if person.HasField('email'):
|
|
||||||
print " E-mail address:", person.email
|
|
||||||
|
|
||||||
for phone_number in person.phone:
|
|
||||||
if phone_number.type == addressbook_pb2.Person.MOBILE:
|
|
||||||
print " Mobile phone #:",
|
|
||||||
elif phone_number.type == addressbook_pb2.Person.HOME:
|
|
||||||
print " Home phone #:",
|
|
||||||
elif phone_number.type == addressbook_pb2.Person.WORK:
|
|
||||||
print " Work phone #:",
|
|
||||||
print phone_number.number
|
|
||||||
|
|
||||||
# Main procedure: Reads the entire address book from a file and prints all
|
|
||||||
# the information inside.
|
|
||||||
if len(sys.argv) != 2:
|
|
||||||
print "Usage:", sys.argv[0], "ADDRESS_BOOK_FILE"
|
|
||||||
sys.exit(-1)
|
|
||||||
|
|
||||||
address_book = addressbook_pb2.AddressBook()
|
|
||||||
|
|
||||||
# Read the existing address book.
|
|
||||||
f = open(sys.argv[1], "rb")
|
|
||||||
address_book.ParseFromString(f.read())
|
|
||||||
f.close()
|
|
||||||
|
|
||||||
ListPeople(address_book)
|
|
@ -1,33 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Run this script to regenerate descriptor.pb.{h,cc} after the protocol
|
|
||||||
# compiler changes. Since these files are compiled into the protocol compiler
|
|
||||||
# itself, they cannot be generated automatically by a make rule. "make check"
|
|
||||||
# will fail if these files do not match what the protocol compiler would
|
|
||||||
# generate.
|
|
||||||
#
|
|
||||||
# HINT: Flags passed to generate_descriptor_proto.sh will be passed directly
|
|
||||||
# to make when building protoc. This is particularly useful for passing
|
|
||||||
# -j4 to run 4 jobs simultaneously.
|
|
||||||
|
|
||||||
if test ! -e src/google/protobuf/stubs/common.h; then
|
|
||||||
cat >&2 << __EOF__
|
|
||||||
Could not find source code. Make sure you are running this script from the
|
|
||||||
root of the distribution tree.
|
|
||||||
__EOF__
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test ! -e src/Makefile; then
|
|
||||||
cat >&2 << __EOF__
|
|
||||||
Could not find src/Makefile. You must run ./configure (and perhaps
|
|
||||||
./autogen.sh) first.
|
|
||||||
__EOF__
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
cd src
|
|
||||||
make $@ protoc &&
|
|
||||||
./protoc --cpp_out=dllexport_decl=LIBPROTOBUF_EXPORT:. google/protobuf/descriptor.proto && \
|
|
||||||
./protoc --cpp_out=dllexport_decl=LIBPROTOC_EXPORT:. google/protobuf/compiler/plugin.proto
|
|
||||||
cd ..
|
|
@ -1,130 +0,0 @@
|
|||||||
Changes for 1.6.0:
|
|
||||||
|
|
||||||
* New feature: ADD_FAILURE_AT() for reporting a test failure at the
|
|
||||||
given source location -- useful for writing testing utilities.
|
|
||||||
* New feature: the universal value printer is moved from Google Mock
|
|
||||||
to Google Test.
|
|
||||||
* New feature: type parameters and value parameters are reported in
|
|
||||||
the XML report now.
|
|
||||||
* A gtest_disable_pthreads CMake option.
|
|
||||||
* Colored output works in GNU Screen sessions now.
|
|
||||||
* Parameters of value-parameterized tests are now printed in the
|
|
||||||
textual output.
|
|
||||||
* Failures from ad hoc test assertions run before RUN_ALL_TESTS() are
|
|
||||||
now correctly reported.
|
|
||||||
* Arguments of ASSERT_XY and EXPECT_XY no longer need to support << to
|
|
||||||
ostream.
|
|
||||||
* More complete handling of exceptions.
|
|
||||||
* GTEST_ASSERT_XY can be used instead of ASSERT_XY in case the latter
|
|
||||||
name is already used by another library.
|
|
||||||
* --gtest_catch_exceptions is now true by default, allowing a test
|
|
||||||
program to continue after an exception is thrown.
|
|
||||||
* Value-parameterized test fixtures can now derive from Test and
|
|
||||||
WithParamInterface<T> separately, easing conversion of legacy tests.
|
|
||||||
* Death test messages are clearly marked to make them more
|
|
||||||
distinguishable from other messages.
|
|
||||||
* Compatibility fixes for Android, Google Native Client, MinGW, HP UX,
|
|
||||||
PowerPC, Lucid autotools, libCStd, Sun C++, Borland C++ Builder (Code Gear),
|
|
||||||
IBM XL C++ (Visual Age C++), and C++0x.
|
|
||||||
* Bug fixes and implementation clean-ups.
|
|
||||||
* Potentially incompatible changes: disables the harmful 'make install'
|
|
||||||
command in autotools.
|
|
||||||
|
|
||||||
Changes for 1.5.0:
|
|
||||||
|
|
||||||
* New feature: assertions can be safely called in multiple threads
|
|
||||||
where the pthreads library is available.
|
|
||||||
* New feature: predicates used inside EXPECT_TRUE() and friends
|
|
||||||
can now generate custom failure messages.
|
|
||||||
* New feature: Google Test can now be compiled as a DLL.
|
|
||||||
* New feature: fused source files are included.
|
|
||||||
* New feature: prints help when encountering unrecognized Google Test flags.
|
|
||||||
* Experimental feature: CMake build script (requires CMake 2.6.4+).
|
|
||||||
* Experimental feature: the Pump script for meta programming.
|
|
||||||
* double values streamed to an assertion are printed with enough precision
|
|
||||||
to differentiate any two different values.
|
|
||||||
* Google Test now works on Solaris and AIX.
|
|
||||||
* Build and test script improvements.
|
|
||||||
* Bug fixes and implementation clean-ups.
|
|
||||||
|
|
||||||
Potentially breaking changes:
|
|
||||||
|
|
||||||
* Stopped supporting VC++ 7.1 with exceptions disabled.
|
|
||||||
* Dropped support for 'make install'.
|
|
||||||
|
|
||||||
Changes for 1.4.0:
|
|
||||||
|
|
||||||
* New feature: the event listener API
|
|
||||||
* New feature: test shuffling
|
|
||||||
* New feature: the XML report format is closer to junitreport and can
|
|
||||||
be parsed by Hudson now.
|
|
||||||
* New feature: when a test runs under Visual Studio, its failures are
|
|
||||||
integrated in the IDE.
|
|
||||||
* New feature: /MD(d) versions of VC++ projects.
|
|
||||||
* New feature: elapsed time for the tests is printed by default.
|
|
||||||
* New feature: comes with a TR1 tuple implementation such that Boost
|
|
||||||
is no longer needed for Combine().
|
|
||||||
* New feature: EXPECT_DEATH_IF_SUPPORTED macro and friends.
|
|
||||||
* New feature: the Xcode project can now produce static gtest
|
|
||||||
libraries in addition to a framework.
|
|
||||||
* Compatibility fixes for Solaris, Cygwin, minGW, Windows Mobile,
|
|
||||||
Symbian, gcc, and C++Builder.
|
|
||||||
* Bug fixes and implementation clean-ups.
|
|
||||||
|
|
||||||
Changes for 1.3.0:
|
|
||||||
|
|
||||||
* New feature: death tests on Windows, Cygwin, and Mac.
|
|
||||||
* New feature: ability to use Google Test assertions in other testing
|
|
||||||
frameworks.
|
|
||||||
* New feature: ability to run disabled test via
|
|
||||||
--gtest_also_run_disabled_tests.
|
|
||||||
* New feature: the --help flag for printing the usage.
|
|
||||||
* New feature: access to Google Test flag values in user code.
|
|
||||||
* New feature: a script that packs Google Test into one .h and one
|
|
||||||
.cc file for easy deployment.
|
|
||||||
* New feature: support for distributing test functions to multiple
|
|
||||||
machines (requires support from the test runner).
|
|
||||||
* Bug fixes and implementation clean-ups.
|
|
||||||
|
|
||||||
Changes for 1.2.1:
|
|
||||||
|
|
||||||
* Compatibility fixes for Linux IA-64 and IBM z/OS.
|
|
||||||
* Added support for using Boost and other TR1 implementations.
|
|
||||||
* Changes to the build scripts to support upcoming release of Google C++
|
|
||||||
Mocking Framework.
|
|
||||||
* Added Makefile to the distribution package.
|
|
||||||
* Improved build instructions in README.
|
|
||||||
|
|
||||||
Changes for 1.2.0:
|
|
||||||
|
|
||||||
* New feature: value-parameterized tests.
|
|
||||||
* New feature: the ASSERT/EXPECT_(NON)FATAL_FAILURE(_ON_ALL_THREADS)
|
|
||||||
macros.
|
|
||||||
* Changed the XML report format to match JUnit/Ant's.
|
|
||||||
* Added tests to the Xcode project.
|
|
||||||
* Added scons/SConscript for building with SCons.
|
|
||||||
* Added src/gtest-all.cc for building Google Test from a single file.
|
|
||||||
* Fixed compatibility with Solaris and z/OS.
|
|
||||||
* Enabled running Python tests on systems with python 2.3 installed,
|
|
||||||
e.g. Mac OS X 10.4.
|
|
||||||
* Bug fixes.
|
|
||||||
|
|
||||||
Changes for 1.1.0:
|
|
||||||
|
|
||||||
* New feature: type-parameterized tests.
|
|
||||||
* New feature: exception assertions.
|
|
||||||
* New feature: printing elapsed time of tests.
|
|
||||||
* Improved the robustness of death tests.
|
|
||||||
* Added an Xcode project and samples.
|
|
||||||
* Adjusted the output format on Windows to be understandable by Visual Studio.
|
|
||||||
* Minor bug fixes.
|
|
||||||
|
|
||||||
Changes for 1.0.1:
|
|
||||||
|
|
||||||
* Added project files for Visual Studio 7.1.
|
|
||||||
* Fixed issues with compiling on Mac OS X.
|
|
||||||
* Fixed issues with compiling on Cygwin.
|
|
||||||
|
|
||||||
Changes for 1.0.0:
|
|
||||||
|
|
||||||
* Initial Open Source release of Google Test
|
|
@ -1,250 +0,0 @@
|
|||||||
########################################################################
|
|
||||||
# CMake build script for Google Test.
|
|
||||||
#
|
|
||||||
# To run the tests for Google Test itself on Linux, use 'make test' or
|
|
||||||
# ctest. You can select which tests to run using 'ctest -R regex'.
|
|
||||||
# For more options, run 'ctest --help'.
|
|
||||||
|
|
||||||
# BUILD_SHARED_LIBS is a standard CMake variable, but we declare it here to
|
|
||||||
# make it prominent in the GUI.
|
|
||||||
option(BUILD_SHARED_LIBS "Build shared libraries (DLLs)." OFF)
|
|
||||||
|
|
||||||
# When other libraries are using a shared version of runtime libraries,
|
|
||||||
# Google Test also has to use one.
|
|
||||||
option(
|
|
||||||
gtest_force_shared_crt
|
|
||||||
"Use shared (DLL) run-time lib even when Google Test is built as static lib."
|
|
||||||
OFF)
|
|
||||||
|
|
||||||
option(gtest_build_tests "Build all of gtest's own tests." OFF)
|
|
||||||
|
|
||||||
option(gtest_build_samples "Build gtest's sample programs." OFF)
|
|
||||||
|
|
||||||
option(gtest_disable_pthreads "Disable uses of pthreads in gtest." OFF)
|
|
||||||
|
|
||||||
# Defines pre_project_set_up_hermetic_build() and set_up_hermetic_build().
|
|
||||||
include(cmake/hermetic_build.cmake OPTIONAL)
|
|
||||||
|
|
||||||
if (COMMAND pre_project_set_up_hermetic_build)
|
|
||||||
pre_project_set_up_hermetic_build()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
########################################################################
|
|
||||||
#
|
|
||||||
# Project-wide settings
|
|
||||||
|
|
||||||
# Name of the project.
|
|
||||||
#
|
|
||||||
# CMake files in this project can refer to the root source directory
|
|
||||||
# as ${gtest_SOURCE_DIR} and to the root binary directory as
|
|
||||||
# ${gtest_BINARY_DIR}.
|
|
||||||
# Language "C" is required for find_package(Threads).
|
|
||||||
project(gtest CXX C)
|
|
||||||
cmake_minimum_required(VERSION 2.6.2)
|
|
||||||
|
|
||||||
if (COMMAND set_up_hermetic_build)
|
|
||||||
set_up_hermetic_build()
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Define helper functions and macros used by Google Test.
|
|
||||||
include(cmake/internal_utils.cmake)
|
|
||||||
|
|
||||||
config_compiler_and_linker() # Defined in internal_utils.cmake.
|
|
||||||
|
|
||||||
# Where Google Test's .h files can be found.
|
|
||||||
include_directories(
|
|
||||||
${gtest_SOURCE_DIR}/include
|
|
||||||
${gtest_SOURCE_DIR})
|
|
||||||
|
|
||||||
# Where Google Test's libraries can be found.
|
|
||||||
link_directories(${gtest_BINARY_DIR}/src)
|
|
||||||
|
|
||||||
########################################################################
|
|
||||||
#
|
|
||||||
# Defines the gtest & gtest_main libraries. User tests should link
|
|
||||||
# with one of them.
|
|
||||||
|
|
||||||
# Google Test libraries. We build them using more strict warnings than what
|
|
||||||
# are used for other targets, to ensure that gtest can be compiled by a user
|
|
||||||
# aggressive about warnings.
|
|
||||||
cxx_library(gtest "${cxx_strict}" src/gtest-all.cc)
|
|
||||||
cxx_library(gtest_main "${cxx_strict}" src/gtest_main.cc)
|
|
||||||
target_link_libraries(gtest_main gtest)
|
|
||||||
|
|
||||||
########################################################################
|
|
||||||
#
|
|
||||||
# Samples on how to link user tests with gtest or gtest_main.
|
|
||||||
#
|
|
||||||
# They are not built by default. To build them, set the
|
|
||||||
# gtest_build_samples option to ON. You can do it by running ccmake
|
|
||||||
# or specifying the -Dbuild_gtest_samples=ON flag when running cmake.
|
|
||||||
|
|
||||||
if (gtest_build_samples)
|
|
||||||
cxx_executable(sample1_unittest samples gtest_main samples/sample1.cc)
|
|
||||||
cxx_executable(sample2_unittest samples gtest_main samples/sample2.cc)
|
|
||||||
cxx_executable(sample3_unittest samples gtest_main)
|
|
||||||
cxx_executable(sample4_unittest samples gtest_main samples/sample4.cc)
|
|
||||||
cxx_executable(sample5_unittest samples gtest_main samples/sample1.cc)
|
|
||||||
cxx_executable(sample6_unittest samples gtest_main)
|
|
||||||
cxx_executable(sample7_unittest samples gtest_main)
|
|
||||||
cxx_executable(sample8_unittest samples gtest_main)
|
|
||||||
cxx_executable(sample9_unittest samples gtest)
|
|
||||||
cxx_executable(sample10_unittest samples gtest)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
########################################################################
|
|
||||||
#
|
|
||||||
# Google Test's own tests.
|
|
||||||
#
|
|
||||||
# You can skip this section if you aren't interested in testing
|
|
||||||
# Google Test itself.
|
|
||||||
#
|
|
||||||
# The tests are not built by default. To build them, set the
|
|
||||||
# gtest_build_tests option to ON. You can do it by running ccmake
|
|
||||||
# or specifying the -Dgtest_build_tests=ON flag when running cmake.
|
|
||||||
|
|
||||||
if (gtest_build_tests)
|
|
||||||
# This must be set in the root directory for the tests to be run by
|
|
||||||
# 'make test' or ctest.
|
|
||||||
enable_testing()
|
|
||||||
|
|
||||||
############################################################
|
|
||||||
# C++ tests built with standard compiler flags.
|
|
||||||
|
|
||||||
cxx_test(gtest-death-test_test gtest_main)
|
|
||||||
cxx_test(gtest_environment_test gtest)
|
|
||||||
cxx_test(gtest-filepath_test gtest_main)
|
|
||||||
cxx_test(gtest-linked_ptr_test gtest_main)
|
|
||||||
cxx_test(gtest-listener_test gtest_main)
|
|
||||||
cxx_test(gtest_main_unittest gtest_main)
|
|
||||||
cxx_test(gtest-message_test gtest_main)
|
|
||||||
cxx_test(gtest_no_test_unittest gtest)
|
|
||||||
cxx_test(gtest-options_test gtest_main)
|
|
||||||
cxx_test(gtest-param-test_test gtest
|
|
||||||
test/gtest-param-test2_test.cc)
|
|
||||||
cxx_test(gtest-port_test gtest_main)
|
|
||||||
cxx_test(gtest_pred_impl_unittest gtest_main)
|
|
||||||
cxx_test(gtest-printers_test gtest_main)
|
|
||||||
cxx_test(gtest_prod_test gtest_main
|
|
||||||
test/production.cc)
|
|
||||||
cxx_test(gtest_repeat_test gtest)
|
|
||||||
cxx_test(gtest_sole_header_test gtest_main)
|
|
||||||
cxx_test(gtest_stress_test gtest)
|
|
||||||
cxx_test(gtest-test-part_test gtest_main)
|
|
||||||
cxx_test(gtest_throw_on_failure_ex_test gtest)
|
|
||||||
cxx_test(gtest-typed-test_test gtest_main
|
|
||||||
test/gtest-typed-test2_test.cc)
|
|
||||||
cxx_test(gtest_unittest gtest_main)
|
|
||||||
cxx_test(gtest-unittest-api_test gtest)
|
|
||||||
|
|
||||||
############################################################
|
|
||||||
# C++ tests built with non-standard compiler flags.
|
|
||||||
|
|
||||||
# MSVC 7.1 does not support STL with exceptions disabled.
|
|
||||||
if (NOT MSVC OR MSVC_VERSION GREATER 1310)
|
|
||||||
cxx_library(gtest_no_exception "${cxx_no_exception}"
|
|
||||||
src/gtest-all.cc)
|
|
||||||
cxx_library(gtest_main_no_exception "${cxx_no_exception}"
|
|
||||||
src/gtest-all.cc src/gtest_main.cc)
|
|
||||||
endif()
|
|
||||||
cxx_library(gtest_main_no_rtti "${cxx_no_rtti}"
|
|
||||||
src/gtest-all.cc src/gtest_main.cc)
|
|
||||||
|
|
||||||
cxx_test_with_flags(gtest-death-test_ex_nocatch_test
|
|
||||||
"${cxx_exception} -DGTEST_ENABLE_CATCH_EXCEPTIONS_=0"
|
|
||||||
gtest test/gtest-death-test_ex_test.cc)
|
|
||||||
cxx_test_with_flags(gtest-death-test_ex_catch_test
|
|
||||||
"${cxx_exception} -DGTEST_ENABLE_CATCH_EXCEPTIONS_=1"
|
|
||||||
gtest test/gtest-death-test_ex_test.cc)
|
|
||||||
|
|
||||||
cxx_test_with_flags(gtest_no_rtti_unittest "${cxx_no_rtti}"
|
|
||||||
gtest_main_no_rtti test/gtest_unittest.cc)
|
|
||||||
|
|
||||||
cxx_shared_library(gtest_dll "${cxx_default}"
|
|
||||||
src/gtest-all.cc src/gtest_main.cc)
|
|
||||||
|
|
||||||
cxx_executable_with_flags(gtest_dll_test_ "${cxx_default}"
|
|
||||||
gtest_dll test/gtest_all_test.cc)
|
|
||||||
set_target_properties(gtest_dll_test_
|
|
||||||
PROPERTIES
|
|
||||||
COMPILE_DEFINITIONS "GTEST_LINKED_AS_SHARED_LIBRARY=1")
|
|
||||||
|
|
||||||
if (NOT MSVC OR NOT MSVC_VERSION EQUAL 1600)
|
|
||||||
# The C++ Standard specifies tuple_element<int, class>.
|
|
||||||
# Yet MSVC 10's <utility> declares tuple_element<size_t, class>.
|
|
||||||
# That declaration conflicts with our own standard-conforming
|
|
||||||
# tuple implementation. Therefore using our own tuple with
|
|
||||||
# MSVC 10 doesn't compile.
|
|
||||||
cxx_library(gtest_main_use_own_tuple "${cxx_use_own_tuple}"
|
|
||||||
src/gtest-all.cc src/gtest_main.cc)
|
|
||||||
|
|
||||||
cxx_test_with_flags(gtest-tuple_test "${cxx_use_own_tuple}"
|
|
||||||
gtest_main_use_own_tuple test/gtest-tuple_test.cc)
|
|
||||||
|
|
||||||
cxx_test_with_flags(gtest_use_own_tuple_test "${cxx_use_own_tuple}"
|
|
||||||
gtest_main_use_own_tuple
|
|
||||||
test/gtest-param-test_test.cc test/gtest-param-test2_test.cc)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
############################################################
|
|
||||||
# Python tests.
|
|
||||||
|
|
||||||
cxx_executable(gtest_break_on_failure_unittest_ test gtest)
|
|
||||||
py_test(gtest_break_on_failure_unittest)
|
|
||||||
|
|
||||||
# MSVC 7.1 does not support STL with exceptions disabled.
|
|
||||||
if (NOT MSVC OR MSVC_VERSION GREATER 1310)
|
|
||||||
cxx_executable_with_flags(
|
|
||||||
gtest_catch_exceptions_no_ex_test_
|
|
||||||
"${cxx_no_exception}"
|
|
||||||
gtest_main_no_exception
|
|
||||||
test/gtest_catch_exceptions_test_.cc)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
cxx_executable_with_flags(
|
|
||||||
gtest_catch_exceptions_ex_test_
|
|
||||||
"${cxx_exception}"
|
|
||||||
gtest_main
|
|
||||||
test/gtest_catch_exceptions_test_.cc)
|
|
||||||
py_test(gtest_catch_exceptions_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_color_test_ test gtest)
|
|
||||||
py_test(gtest_color_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_env_var_test_ test gtest)
|
|
||||||
py_test(gtest_env_var_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_filter_unittest_ test gtest)
|
|
||||||
py_test(gtest_filter_unittest)
|
|
||||||
|
|
||||||
cxx_executable(gtest_help_test_ test gtest_main)
|
|
||||||
py_test(gtest_help_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_list_tests_unittest_ test gtest)
|
|
||||||
py_test(gtest_list_tests_unittest)
|
|
||||||
|
|
||||||
cxx_executable(gtest_output_test_ test gtest)
|
|
||||||
py_test(gtest_output_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_shuffle_test_ test gtest)
|
|
||||||
py_test(gtest_shuffle_test)
|
|
||||||
|
|
||||||
# MSVC 7.1 does not support STL with exceptions disabled.
|
|
||||||
if (NOT MSVC OR MSVC_VERSION GREATER 1310)
|
|
||||||
cxx_executable(gtest_throw_on_failure_test_ test gtest_no_exception)
|
|
||||||
set_target_properties(gtest_throw_on_failure_test_
|
|
||||||
PROPERTIES
|
|
||||||
COMPILE_FLAGS "${cxx_no_exception}")
|
|
||||||
py_test(gtest_throw_on_failure_test)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
cxx_executable(gtest_uninitialized_test_ test gtest)
|
|
||||||
py_test(gtest_uninitialized_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_xml_outfile1_test_ test gtest_main)
|
|
||||||
cxx_executable(gtest_xml_outfile2_test_ test gtest_main)
|
|
||||||
py_test(gtest_xml_outfiles_test)
|
|
||||||
|
|
||||||
cxx_executable(gtest_xml_output_unittest_ test gtest)
|
|
||||||
py_test(gtest_xml_output_unittest)
|
|
||||||
endif()
|
|
@ -1,305 +0,0 @@
|
|||||||
# Automake file
|
|
||||||
|
|
||||||
ACLOCAL_AMFLAGS = -I m4
|
|
||||||
|
|
||||||
# Nonstandard package files for distribution
|
|
||||||
EXTRA_DIST = \
|
|
||||||
CHANGES \
|
|
||||||
CONTRIBUTORS \
|
|
||||||
LICENSE \
|
|
||||||
include/gtest/gtest-param-test.h.pump \
|
|
||||||
include/gtest/internal/gtest-param-util-generated.h.pump \
|
|
||||||
include/gtest/internal/gtest-tuple.h.pump \
|
|
||||||
include/gtest/internal/gtest-type-util.h.pump \
|
|
||||||
make/Makefile \
|
|
||||||
scripts/fuse_gtest_files.py \
|
|
||||||
scripts/gen_gtest_pred_impl.py \
|
|
||||||
scripts/pump.py \
|
|
||||||
scripts/test/Makefile
|
|
||||||
|
|
||||||
# gtest source files that we don't compile directly. They are
|
|
||||||
# #included by gtest-all.cc.
|
|
||||||
GTEST_SRC = \
|
|
||||||
src/gtest-death-test.cc \
|
|
||||||
src/gtest-filepath.cc \
|
|
||||||
src/gtest-internal-inl.h \
|
|
||||||
src/gtest-port.cc \
|
|
||||||
src/gtest-printers.cc \
|
|
||||||
src/gtest-test-part.cc \
|
|
||||||
src/gtest-typed-test.cc \
|
|
||||||
src/gtest.cc
|
|
||||||
|
|
||||||
EXTRA_DIST += $(GTEST_SRC)
|
|
||||||
|
|
||||||
# Sample files that we don't compile.
|
|
||||||
EXTRA_DIST += \
|
|
||||||
samples/prime_tables.h \
|
|
||||||
samples/sample2_unittest.cc \
|
|
||||||
samples/sample3_unittest.cc \
|
|
||||||
samples/sample4_unittest.cc \
|
|
||||||
samples/sample5_unittest.cc \
|
|
||||||
samples/sample6_unittest.cc \
|
|
||||||
samples/sample7_unittest.cc \
|
|
||||||
samples/sample8_unittest.cc \
|
|
||||||
samples/sample9_unittest.cc
|
|
||||||
|
|
||||||
# C++ test files that we don't compile directly.
|
|
||||||
EXTRA_DIST += \
|
|
||||||
test/gtest-death-test_ex_test.cc \
|
|
||||||
test/gtest-death-test_test.cc \
|
|
||||||
test/gtest-filepath_test.cc \
|
|
||||||
test/gtest-linked_ptr_test.cc \
|
|
||||||
test/gtest-listener_test.cc \
|
|
||||||
test/gtest-message_test.cc \
|
|
||||||
test/gtest-options_test.cc \
|
|
||||||
test/gtest-param-test2_test.cc \
|
|
||||||
test/gtest-param-test2_test.cc \
|
|
||||||
test/gtest-param-test_test.cc \
|
|
||||||
test/gtest-param-test_test.cc \
|
|
||||||
test/gtest-param-test_test.h \
|
|
||||||
test/gtest-port_test.cc \
|
|
||||||
test/gtest-printers_test.cc \
|
|
||||||
test/gtest-test-part_test.cc \
|
|
||||||
test/gtest-tuple_test.cc \
|
|
||||||
test/gtest-typed-test2_test.cc \
|
|
||||||
test/gtest-typed-test_test.cc \
|
|
||||||
test/gtest-typed-test_test.h \
|
|
||||||
test/gtest-unittest-api_test.cc \
|
|
||||||
test/gtest_break_on_failure_unittest_.cc \
|
|
||||||
test/gtest_catch_exceptions_test_.cc \
|
|
||||||
test/gtest_color_test_.cc \
|
|
||||||
test/gtest_env_var_test_.cc \
|
|
||||||
test/gtest_environment_test.cc \
|
|
||||||
test/gtest_filter_unittest_.cc \
|
|
||||||
test/gtest_help_test_.cc \
|
|
||||||
test/gtest_list_tests_unittest_.cc \
|
|
||||||
test/gtest_main_unittest.cc \
|
|
||||||
test/gtest_no_test_unittest.cc \
|
|
||||||
test/gtest_output_test_.cc \
|
|
||||||
test/gtest_pred_impl_unittest.cc \
|
|
||||||
test/gtest_prod_test.cc \
|
|
||||||
test/gtest_repeat_test.cc \
|
|
||||||
test/gtest_shuffle_test_.cc \
|
|
||||||
test/gtest_sole_header_test.cc \
|
|
||||||
test/gtest_stress_test.cc \
|
|
||||||
test/gtest_throw_on_failure_ex_test.cc \
|
|
||||||
test/gtest_throw_on_failure_test_.cc \
|
|
||||||
test/gtest_uninitialized_test_.cc \
|
|
||||||
test/gtest_unittest.cc \
|
|
||||||
test/gtest_unittest.cc \
|
|
||||||
test/gtest_xml_outfile1_test_.cc \
|
|
||||||
test/gtest_xml_outfile2_test_.cc \
|
|
||||||
test/gtest_xml_output_unittest_.cc \
|
|
||||||
test/production.cc \
|
|
||||||
test/production.h
|
|
||||||
|
|
||||||
# Python tests that we don't run.
|
|
||||||
EXTRA_DIST += \
|
|
||||||
test/gtest_break_on_failure_unittest.py \
|
|
||||||
test/gtest_catch_exceptions_test.py \
|
|
||||||
test/gtest_color_test.py \
|
|
||||||
test/gtest_env_var_test.py \
|
|
||||||
test/gtest_filter_unittest.py \
|
|
||||||
test/gtest_help_test.py \
|
|
||||||
test/gtest_list_tests_unittest.py \
|
|
||||||
test/gtest_output_test.py \
|
|
||||||
test/gtest_output_test_golden_lin.txt \
|
|
||||||
test/gtest_shuffle_test.py \
|
|
||||||
test/gtest_test_utils.py \
|
|
||||||
test/gtest_throw_on_failure_test.py \
|
|
||||||
test/gtest_uninitialized_test.py \
|
|
||||||
test/gtest_xml_outfiles_test.py \
|
|
||||||
test/gtest_xml_output_unittest.py \
|
|
||||||
test/gtest_xml_test_utils.py
|
|
||||||
|
|
||||||
# CMake script
|
|
||||||
EXTRA_DIST += \
|
|
||||||
CMakeLists.txt \
|
|
||||||
cmake/internal_utils.cmake
|
|
||||||
|
|
||||||
# MSVC project files
|
|
||||||
EXTRA_DIST += \
|
|
||||||
msvc/gtest-md.sln \
|
|
||||||
msvc/gtest-md.vcproj \
|
|
||||||
msvc/gtest.sln \
|
|
||||||
msvc/gtest.vcproj \
|
|
||||||
msvc/gtest_main-md.vcproj \
|
|
||||||
msvc/gtest_main.vcproj \
|
|
||||||
msvc/gtest_prod_test-md.vcproj \
|
|
||||||
msvc/gtest_prod_test.vcproj \
|
|
||||||
msvc/gtest_unittest-md.vcproj \
|
|
||||||
msvc/gtest_unittest.vcproj
|
|
||||||
|
|
||||||
# xcode project files
|
|
||||||
EXTRA_DIST += \
|
|
||||||
xcode/Config/DebugProject.xcconfig \
|
|
||||||
xcode/Config/FrameworkTarget.xcconfig \
|
|
||||||
xcode/Config/General.xcconfig \
|
|
||||||
xcode/Config/ReleaseProject.xcconfig \
|
|
||||||
xcode/Config/StaticLibraryTarget.xcconfig \
|
|
||||||
xcode/Config/TestTarget.xcconfig \
|
|
||||||
xcode/Resources/Info.plist \
|
|
||||||
xcode/Scripts/runtests.sh \
|
|
||||||
xcode/Scripts/versiongenerate.py \
|
|
||||||
xcode/gtest.xcodeproj/project.pbxproj
|
|
||||||
|
|
||||||
# xcode sample files
|
|
||||||
EXTRA_DIST += \
|
|
||||||
xcode/Samples/FrameworkSample/Info.plist \
|
|
||||||
xcode/Samples/FrameworkSample/WidgetFramework.xcodeproj/project.pbxproj \
|
|
||||||
xcode/Samples/FrameworkSample/runtests.sh \
|
|
||||||
xcode/Samples/FrameworkSample/widget.cc \
|
|
||||||
xcode/Samples/FrameworkSample/widget.h \
|
|
||||||
xcode/Samples/FrameworkSample/widget_test.cc
|
|
||||||
|
|
||||||
# C++Builder project files
|
|
||||||
EXTRA_DIST += \
|
|
||||||
codegear/gtest.cbproj \
|
|
||||||
codegear/gtest.groupproj \
|
|
||||||
codegear/gtest_all.cc \
|
|
||||||
codegear/gtest_link.cc \
|
|
||||||
codegear/gtest_main.cbproj \
|
|
||||||
codegear/gtest_unittest.cbproj
|
|
||||||
|
|
||||||
# Distribute and install M4 macro
|
|
||||||
m4datadir = $(datadir)/aclocal
|
|
||||||
m4data_DATA = m4/gtest.m4
|
|
||||||
EXTRA_DIST += $(m4data_DATA)
|
|
||||||
|
|
||||||
# We define the global AM_CPPFLAGS as everything we compile includes from these
|
|
||||||
# directories.
|
|
||||||
AM_CPPFLAGS = -I$(srcdir) -I$(srcdir)/include
|
|
||||||
|
|
||||||
# Modifies compiler and linker flags for pthreads compatibility.
|
|
||||||
if HAVE_PTHREADS
|
|
||||||
AM_CXXFLAGS = @PTHREAD_CFLAGS@ -DGTEST_HAS_PTHREAD=1
|
|
||||||
AM_LIBS = @PTHREAD_LIBS@
|
|
||||||
else
|
|
||||||
AM_CXXFLAGS = -DGTEST_HAS_PTHREAD=0
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Build rules for libraries.
|
|
||||||
lib_LTLIBRARIES = lib/libgtest.la lib/libgtest_main.la
|
|
||||||
|
|
||||||
lib_libgtest_la_SOURCES = src/gtest-all.cc
|
|
||||||
|
|
||||||
pkginclude_HEADERS = \
|
|
||||||
include/gtest/gtest-death-test.h \
|
|
||||||
include/gtest/gtest-message.h \
|
|
||||||
include/gtest/gtest-param-test.h \
|
|
||||||
include/gtest/gtest-printers.h \
|
|
||||||
include/gtest/gtest-spi.h \
|
|
||||||
include/gtest/gtest-test-part.h \
|
|
||||||
include/gtest/gtest-typed-test.h \
|
|
||||||
include/gtest/gtest.h \
|
|
||||||
include/gtest/gtest_pred_impl.h \
|
|
||||||
include/gtest/gtest_prod.h
|
|
||||||
|
|
||||||
pkginclude_internaldir = $(pkgincludedir)/internal
|
|
||||||
pkginclude_internal_HEADERS = \
|
|
||||||
include/gtest/internal/gtest-death-test-internal.h \
|
|
||||||
include/gtest/internal/gtest-filepath.h \
|
|
||||||
include/gtest/internal/gtest-internal.h \
|
|
||||||
include/gtest/internal/gtest-linked_ptr.h \
|
|
||||||
include/gtest/internal/gtest-param-util-generated.h \
|
|
||||||
include/gtest/internal/gtest-param-util.h \
|
|
||||||
include/gtest/internal/gtest-port.h \
|
|
||||||
include/gtest/internal/gtest-string.h \
|
|
||||||
include/gtest/internal/gtest-tuple.h \
|
|
||||||
include/gtest/internal/gtest-type-util.h
|
|
||||||
|
|
||||||
lib_libgtest_main_la_SOURCES = src/gtest_main.cc
|
|
||||||
lib_libgtest_main_la_LIBADD = lib/libgtest.la
|
|
||||||
|
|
||||||
# Bulid rules for samples and tests. Automake's naming for some of
|
|
||||||
# these variables isn't terribly obvious, so this is a brief
|
|
||||||
# reference:
|
|
||||||
#
|
|
||||||
# TESTS -- Programs run automatically by "make check"
|
|
||||||
# check_PROGRAMS -- Programs built by "make check" but not necessarily run
|
|
||||||
|
|
||||||
noinst_LTLIBRARIES = samples/libsamples.la
|
|
||||||
|
|
||||||
samples_libsamples_la_SOURCES = \
|
|
||||||
samples/sample1.cc \
|
|
||||||
samples/sample1.h \
|
|
||||||
samples/sample2.cc \
|
|
||||||
samples/sample2.h \
|
|
||||||
samples/sample3-inl.h \
|
|
||||||
samples/sample4.cc \
|
|
||||||
samples/sample4.h
|
|
||||||
|
|
||||||
TESTS=
|
|
||||||
TESTS_ENVIRONMENT = GTEST_SOURCE_DIR="$(srcdir)/test" \
|
|
||||||
GTEST_BUILD_DIR="$(top_builddir)/test"
|
|
||||||
check_PROGRAMS=
|
|
||||||
|
|
||||||
# A simple sample on using gtest.
|
|
||||||
TESTS += samples/sample1_unittest
|
|
||||||
check_PROGRAMS += samples/sample1_unittest
|
|
||||||
samples_sample1_unittest_SOURCES = samples/sample1_unittest.cc
|
|
||||||
samples_sample1_unittest_LDADD = lib/libgtest_main.la \
|
|
||||||
lib/libgtest.la \
|
|
||||||
samples/libsamples.la
|
|
||||||
|
|
||||||
# Another sample. It also verifies that libgtest works.
|
|
||||||
TESTS += samples/sample10_unittest
|
|
||||||
check_PROGRAMS += samples/sample10_unittest
|
|
||||||
samples_sample10_unittest_SOURCES = samples/sample10_unittest.cc
|
|
||||||
samples_sample10_unittest_LDADD = lib/libgtest.la
|
|
||||||
|
|
||||||
# This tests most constructs of gtest and verifies that libgtest_main
|
|
||||||
# and libgtest work.
|
|
||||||
TESTS += test/gtest_all_test
|
|
||||||
check_PROGRAMS += test/gtest_all_test
|
|
||||||
test_gtest_all_test_SOURCES = test/gtest_all_test.cc
|
|
||||||
test_gtest_all_test_LDADD = lib/libgtest_main.la \
|
|
||||||
lib/libgtest.la
|
|
||||||
|
|
||||||
# Tests that fused gtest files compile and work.
|
|
||||||
FUSED_GTEST_SRC = \
|
|
||||||
fused-src/gtest/gtest-all.cc \
|
|
||||||
fused-src/gtest/gtest.h \
|
|
||||||
fused-src/gtest/gtest_main.cc
|
|
||||||
|
|
||||||
if HAVE_PYTHON
|
|
||||||
TESTS += test/fused_gtest_test
|
|
||||||
check_PROGRAMS += test/fused_gtest_test
|
|
||||||
test_fused_gtest_test_SOURCES = $(FUSED_GTEST_SRC) \
|
|
||||||
samples/sample1.cc samples/sample1_unittest.cc
|
|
||||||
test_fused_gtest_test_CPPFLAGS = -I"$(srcdir)/fused-src"
|
|
||||||
|
|
||||||
# Build rules for putting fused Google Test files into the distribution
|
|
||||||
# package. The user can also create those files by manually running
|
|
||||||
# scripts/fuse_gtest_files.py.
|
|
||||||
$(test_fused_gtest_test_SOURCES): fused-gtest
|
|
||||||
|
|
||||||
fused-gtest: $(pkginclude_HEADERS) $(pkginclude_internal_HEADERS) \
|
|
||||||
$(GTEST_SRC) src/gtest-all.cc src/gtest_main.cc \
|
|
||||||
scripts/fuse_gtest_files.py
|
|
||||||
mkdir -p "$(srcdir)/fused-src"
|
|
||||||
chmod -R u+w "$(srcdir)/fused-src"
|
|
||||||
rm -f "$(srcdir)/fused-src/gtest/gtest-all.cc"
|
|
||||||
rm -f "$(srcdir)/fused-src/gtest/gtest.h"
|
|
||||||
"$(srcdir)/scripts/fuse_gtest_files.py" "$(srcdir)/fused-src"
|
|
||||||
cp -f "$(srcdir)/src/gtest_main.cc" "$(srcdir)/fused-src/gtest/"
|
|
||||||
|
|
||||||
maintainer-clean-local:
|
|
||||||
rm -rf "$(srcdir)/fused-src"
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Death tests may produce core dumps in the build directory. In case
|
|
||||||
# this happens, clean them to keep distcleancheck happy.
|
|
||||||
CLEANFILES = core
|
|
||||||
|
|
||||||
# Disables 'make install' as installing a compiled version of Google
|
|
||||||
# Test can lead to undefined behavior due to violation of the
|
|
||||||
# One-Definition Rule.
|
|
||||||
|
|
||||||
install-exec-local:
|
|
||||||
echo "'make install' is dangerous and not supported. Instead, see README for how to integrate Google Test into your build system."
|
|
||||||
false
|
|
||||||
|
|
||||||
install-data-local:
|
|
||||||
echo "'make install' is dangerous and not supported. Instead, see README for how to integrate Google Test into your build system."
|
|
||||||
false
|
|
File diff suppressed because it is too large
Load Diff
@ -1,434 +0,0 @@
|
|||||||
Google C++ Testing Framework
|
|
||||||
============================
|
|
||||||
|
|
||||||
http://code.google.com/p/googletest/
|
|
||||||
|
|
||||||
Overview
|
|
||||||
--------
|
|
||||||
|
|
||||||
Google's framework for writing C++ tests on a variety of platforms
|
|
||||||
(Linux, Mac OS X, Windows, Windows CE, Symbian, etc). Based on the
|
|
||||||
xUnit architecture. Supports automatic test discovery, a rich set of
|
|
||||||
assertions, user-defined assertions, death tests, fatal and non-fatal
|
|
||||||
failures, various options for running the tests, and XML test report
|
|
||||||
generation.
|
|
||||||
|
|
||||||
Please see the project page above for more information as well as the
|
|
||||||
mailing list for questions, discussions, and development. There is
|
|
||||||
also an IRC channel on OFTC (irc.oftc.net) #gtest available. Please
|
|
||||||
join us!
|
|
||||||
|
|
||||||
Requirements for End Users
|
|
||||||
--------------------------
|
|
||||||
|
|
||||||
Google Test is designed to have fairly minimal requirements to build
|
|
||||||
and use with your projects, but there are some. Currently, we support
|
|
||||||
Linux, Windows, Mac OS X, and Cygwin. We will also make our best
|
|
||||||
effort to support other platforms (e.g. Solaris, AIX, and z/OS).
|
|
||||||
However, since core members of the Google Test project have no access
|
|
||||||
to these platforms, Google Test may have outstanding issues there. If
|
|
||||||
you notice any problems on your platform, please notify
|
|
||||||
googletestframework@googlegroups.com. Patches for fixing them are
|
|
||||||
even more welcome!
|
|
||||||
|
|
||||||
### Linux Requirements ###
|
|
||||||
|
|
||||||
These are the base requirements to build and use Google Test from a source
|
|
||||||
package (as described below):
|
|
||||||
* GNU-compatible Make or gmake
|
|
||||||
* POSIX-standard shell
|
|
||||||
* POSIX(-2) Regular Expressions (regex.h)
|
|
||||||
* A C++98-standard-compliant compiler
|
|
||||||
|
|
||||||
### Windows Requirements ###
|
|
||||||
|
|
||||||
* Microsoft Visual C++ 7.1 or newer
|
|
||||||
|
|
||||||
### Cygwin Requirements ###
|
|
||||||
|
|
||||||
* Cygwin 1.5.25-14 or newer
|
|
||||||
|
|
||||||
### Mac OS X Requirements ###
|
|
||||||
|
|
||||||
* Mac OS X 10.4 Tiger or newer
|
|
||||||
* Developer Tools Installed
|
|
||||||
|
|
||||||
Also, you'll need CMake 2.6.4 or higher if you want to build the
|
|
||||||
samples using the provided CMake script, regardless of the platform.
|
|
||||||
|
|
||||||
Requirements for Contributors
|
|
||||||
-----------------------------
|
|
||||||
|
|
||||||
We welcome patches. If you plan to contribute a patch, you need to
|
|
||||||
build Google Test and its own tests from an SVN checkout (described
|
|
||||||
below), which has further requirements:
|
|
||||||
|
|
||||||
* Python version 2.3 or newer (for running some of the tests and
|
|
||||||
re-generating certain source files from templates)
|
|
||||||
* CMake 2.6.4 or newer
|
|
||||||
|
|
||||||
Getting the Source
|
|
||||||
------------------
|
|
||||||
|
|
||||||
There are two primary ways of getting Google Test's source code: you
|
|
||||||
can download a stable source release in your preferred archive format,
|
|
||||||
or directly check out the source from our Subversion (SVN) repositary.
|
|
||||||
The SVN checkout requires a few extra steps and some extra software
|
|
||||||
packages on your system, but lets you track the latest development and
|
|
||||||
make patches much more easily, so we highly encourage it.
|
|
||||||
|
|
||||||
### Source Package ###
|
|
||||||
|
|
||||||
Google Test is released in versioned source packages which can be
|
|
||||||
downloaded from the download page [1]. Several different archive
|
|
||||||
formats are provided, but the only difference is the tools used to
|
|
||||||
manipulate them, and the size of the resulting file. Download
|
|
||||||
whichever you are most comfortable with.
|
|
||||||
|
|
||||||
[1] http://code.google.com/p/googletest/downloads/list
|
|
||||||
|
|
||||||
Once the package is downloaded, expand it using whichever tools you
|
|
||||||
prefer for that type. This will result in a new directory with the
|
|
||||||
name "gtest-X.Y.Z" which contains all of the source code. Here are
|
|
||||||
some examples on Linux:
|
|
||||||
|
|
||||||
tar -xvzf gtest-X.Y.Z.tar.gz
|
|
||||||
tar -xvjf gtest-X.Y.Z.tar.bz2
|
|
||||||
unzip gtest-X.Y.Z.zip
|
|
||||||
|
|
||||||
### SVN Checkout ###
|
|
||||||
|
|
||||||
To check out the main branch (also known as the "trunk") of Google
|
|
||||||
Test, run the following Subversion command:
|
|
||||||
|
|
||||||
svn checkout http://googletest.googlecode.com/svn/trunk/ gtest-svn
|
|
||||||
|
|
||||||
Setting up the Build
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
To build Google Test and your tests that use it, you need to tell your
|
|
||||||
build system where to find its headers and source files. The exact
|
|
||||||
way to do it depends on which build system you use, and is usually
|
|
||||||
straightforward.
|
|
||||||
|
|
||||||
### Generic Build Instructions ###
|
|
||||||
|
|
||||||
Suppose you put Google Test in directory ${GTEST_DIR}. To build it,
|
|
||||||
create a library build target (or a project as called by Visual Studio
|
|
||||||
and Xcode) to compile
|
|
||||||
|
|
||||||
${GTEST_DIR}/src/gtest-all.cc
|
|
||||||
|
|
||||||
with
|
|
||||||
|
|
||||||
${GTEST_DIR}/include and ${GTEST_DIR}
|
|
||||||
|
|
||||||
in the header search path. Assuming a Linux-like system and gcc,
|
|
||||||
something like the following will do:
|
|
||||||
|
|
||||||
g++ -I${GTEST_DIR}/include -I${GTEST_DIR} -c ${GTEST_DIR}/src/gtest-all.cc
|
|
||||||
ar -rv libgtest.a gtest-all.o
|
|
||||||
|
|
||||||
Next, you should compile your test source file with
|
|
||||||
${GTEST_DIR}/include in the header search path, and link it with gtest
|
|
||||||
and any other necessary libraries:
|
|
||||||
|
|
||||||
g++ -I${GTEST_DIR}/include path/to/your_test.cc libgtest.a -o your_test
|
|
||||||
|
|
||||||
As an example, the make/ directory contains a Makefile that you can
|
|
||||||
use to build Google Test on systems where GNU make is available
|
|
||||||
(e.g. Linux, Mac OS X, and Cygwin). It doesn't try to build Google
|
|
||||||
Test's own tests. Instead, it just builds the Google Test library and
|
|
||||||
a sample test. You can use it as a starting point for your own build
|
|
||||||
script.
|
|
||||||
|
|
||||||
If the default settings are correct for your environment, the
|
|
||||||
following commands should succeed:
|
|
||||||
|
|
||||||
cd ${GTEST_DIR}/make
|
|
||||||
make
|
|
||||||
./sample1_unittest
|
|
||||||
|
|
||||||
If you see errors, try to tweak the contents of make/Makefile to make
|
|
||||||
them go away. There are instructions in make/Makefile on how to do
|
|
||||||
it.
|
|
||||||
|
|
||||||
### Using CMake ###
|
|
||||||
|
|
||||||
Google Test comes with a CMake build script (CMakeLists.txt) that can
|
|
||||||
be used on a wide range of platforms ("C" stands for cross-platofrm.).
|
|
||||||
If you don't have CMake installed already, you can download it for
|
|
||||||
free from http://www.cmake.org/.
|
|
||||||
|
|
||||||
CMake works by generating native makefiles or build projects that can
|
|
||||||
be used in the compiler environment of your choice. The typical
|
|
||||||
workflow starts with:
|
|
||||||
|
|
||||||
mkdir mybuild # Create a directory to hold the build output.
|
|
||||||
cd mybuild
|
|
||||||
cmake ${GTEST_DIR} # Generate native build scripts.
|
|
||||||
|
|
||||||
If you want to build Google Test's samples, you should replace the
|
|
||||||
last command with
|
|
||||||
|
|
||||||
cmake -Dgtest_build_samples=ON ${GTEST_DIR}
|
|
||||||
|
|
||||||
If you are on a *nix system, you should now see a Makefile in the
|
|
||||||
current directory. Just type 'make' to build gtest.
|
|
||||||
|
|
||||||
If you use Windows and have Vistual Studio installed, a gtest.sln file
|
|
||||||
and several .vcproj files will be created. You can then build them
|
|
||||||
using Visual Studio.
|
|
||||||
|
|
||||||
On Mac OS X with Xcode installed, a .xcodeproj file will be generated.
|
|
||||||
|
|
||||||
### Legacy Build Scripts ###
|
|
||||||
|
|
||||||
Before settling on CMake, we have been providing hand-maintained build
|
|
||||||
projects/scripts for Visual Studio, Xcode, and Autotools. While we
|
|
||||||
continue to provide them for convenience, they are not actively
|
|
||||||
maintained any more. We highly recommend that you follow the
|
|
||||||
instructions in the previous two sections to integrate Google Test
|
|
||||||
with your existing build system.
|
|
||||||
|
|
||||||
If you still need to use the legacy build scripts, here's how:
|
|
||||||
|
|
||||||
The msvc\ folder contains two solutions with Visual C++ projects.
|
|
||||||
Open the gtest.sln or gtest-md.sln file using Visual Studio, and you
|
|
||||||
are ready to build Google Test the same way you build any Visual
|
|
||||||
Studio project. Files that have names ending with -md use DLL
|
|
||||||
versions of Microsoft runtime libraries (the /MD or the /MDd compiler
|
|
||||||
option). Files without that suffix use static versions of the runtime
|
|
||||||
libraries (the /MT or the /MTd option). Please note that one must use
|
|
||||||
the same option to compile both gtest and the test code. If you use
|
|
||||||
Visual Studio 2005 or above, we recommend the -md version as /MD is
|
|
||||||
the default for new projects in these versions of Visual Studio.
|
|
||||||
|
|
||||||
On Mac OS X, open the gtest.xcodeproj in the xcode/ folder using
|
|
||||||
Xcode. Build the "gtest" target. The universal binary framework will
|
|
||||||
end up in your selected build directory (selected in the Xcode
|
|
||||||
"Preferences..." -> "Building" pane and defaults to xcode/build).
|
|
||||||
Alternatively, at the command line, enter:
|
|
||||||
|
|
||||||
xcodebuild
|
|
||||||
|
|
||||||
This will build the "Release" configuration of gtest.framework in your
|
|
||||||
default build location. See the "xcodebuild" man page for more
|
|
||||||
information about building different configurations and building in
|
|
||||||
different locations.
|
|
||||||
|
|
||||||
If you wish to use the Google Test Xcode project with Xcode 4.x and
|
|
||||||
above, you need to either:
|
|
||||||
* update the SDK configuration options in xcode/Config/General.xconfig.
|
|
||||||
Comment options SDKROOT, MACOS_DEPLOYMENT_TARGET, and GCC_VERSION. If
|
|
||||||
you choose this route you lose the ability to target earlier versions
|
|
||||||
of MacOS X.
|
|
||||||
* Install an SDK for an earlier version. This doesn't appear to be
|
|
||||||
supported by Apple, but has been reported to work
|
|
||||||
(http://stackoverflow.com/questions/5378518).
|
|
||||||
|
|
||||||
Tweaking Google Test
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
Google Test can be used in diverse environments. The default
|
|
||||||
configuration may not work (or may not work well) out of the box in
|
|
||||||
some environments. However, you can easily tweak Google Test by
|
|
||||||
defining control macros on the compiler command line. Generally,
|
|
||||||
these macros are named like GTEST_XYZ and you define them to either 1
|
|
||||||
or 0 to enable or disable a certain feature.
|
|
||||||
|
|
||||||
We list the most frequently used macros below. For a complete list,
|
|
||||||
see file include/gtest/internal/gtest-port.h.
|
|
||||||
|
|
||||||
### Choosing a TR1 Tuple Library ###
|
|
||||||
|
|
||||||
Some Google Test features require the C++ Technical Report 1 (TR1)
|
|
||||||
tuple library, which is not yet available with all compilers. The
|
|
||||||
good news is that Google Test implements a subset of TR1 tuple that's
|
|
||||||
enough for its own need, and will automatically use this when the
|
|
||||||
compiler doesn't provide TR1 tuple.
|
|
||||||
|
|
||||||
Usually you don't need to care about which tuple library Google Test
|
|
||||||
uses. However, if your project already uses TR1 tuple, you need to
|
|
||||||
tell Google Test to use the same TR1 tuple library the rest of your
|
|
||||||
project uses, or the two tuple implementations will clash. To do
|
|
||||||
that, add
|
|
||||||
|
|
||||||
-DGTEST_USE_OWN_TR1_TUPLE=0
|
|
||||||
|
|
||||||
to the compiler flags while compiling Google Test and your tests. If
|
|
||||||
you want to force Google Test to use its own tuple library, just add
|
|
||||||
|
|
||||||
-DGTEST_USE_OWN_TR1_TUPLE=1
|
|
||||||
|
|
||||||
to the compiler flags instead.
|
|
||||||
|
|
||||||
If you don't want Google Test to use tuple at all, add
|
|
||||||
|
|
||||||
-DGTEST_HAS_TR1_TUPLE=0
|
|
||||||
|
|
||||||
and all features using tuple will be disabled.
|
|
||||||
|
|
||||||
### Multi-threaded Tests ###
|
|
||||||
|
|
||||||
Google Test is thread-safe where the pthread library is available.
|
|
||||||
After #include "gtest/gtest.h", you can check the GTEST_IS_THREADSAFE
|
|
||||||
macro to see whether this is the case (yes if the macro is #defined to
|
|
||||||
1, no if it's undefined.).
|
|
||||||
|
|
||||||
If Google Test doesn't correctly detect whether pthread is available
|
|
||||||
in your environment, you can force it with
|
|
||||||
|
|
||||||
-DGTEST_HAS_PTHREAD=1
|
|
||||||
|
|
||||||
or
|
|
||||||
|
|
||||||
-DGTEST_HAS_PTHREAD=0
|
|
||||||
|
|
||||||
When Google Test uses pthread, you may need to add flags to your
|
|
||||||
compiler and/or linker to select the pthread library, or you'll get
|
|
||||||
link errors. If you use the CMake script or the deprecated Autotools
|
|
||||||
script, this is taken care of for you. If you use your own build
|
|
||||||
script, you'll need to read your compiler and linker's manual to
|
|
||||||
figure out what flags to add.
|
|
||||||
|
|
||||||
### As a Shared Library (DLL) ###
|
|
||||||
|
|
||||||
Google Test is compact, so most users can build and link it as a
|
|
||||||
static library for the simplicity. You can choose to use Google Test
|
|
||||||
as a shared library (known as a DLL on Windows) if you prefer.
|
|
||||||
|
|
||||||
To compile *gtest* as a shared library, add
|
|
||||||
|
|
||||||
-DGTEST_CREATE_SHARED_LIBRARY=1
|
|
||||||
|
|
||||||
to the compiler flags. You'll also need to tell the linker to produce
|
|
||||||
a shared library instead - consult your linker's manual for how to do
|
|
||||||
it.
|
|
||||||
|
|
||||||
To compile your *tests* that use the gtest shared library, add
|
|
||||||
|
|
||||||
-DGTEST_LINKED_AS_SHARED_LIBRARY=1
|
|
||||||
|
|
||||||
to the compiler flags.
|
|
||||||
|
|
||||||
Note: while the above steps aren't technically necessary today when
|
|
||||||
using some compilers (e.g. GCC), they may become necessary in the
|
|
||||||
future, if we decide to improve the speed of loading the library (see
|
|
||||||
http://gcc.gnu.org/wiki/Visibility for details). Therefore you are
|
|
||||||
recommended to always add the above flags when using Google Test as a
|
|
||||||
shared library. Otherwise a future release of Google Test may break
|
|
||||||
your build script.
|
|
||||||
|
|
||||||
### Avoiding Macro Name Clashes ###
|
|
||||||
|
|
||||||
In C++, macros don't obey namespaces. Therefore two libraries that
|
|
||||||
both define a macro of the same name will clash if you #include both
|
|
||||||
definitions. In case a Google Test macro clashes with another
|
|
||||||
library, you can force Google Test to rename its macro to avoid the
|
|
||||||
conflict.
|
|
||||||
|
|
||||||
Specifically, if both Google Test and some other code define macro
|
|
||||||
FOO, you can add
|
|
||||||
|
|
||||||
-DGTEST_DONT_DEFINE_FOO=1
|
|
||||||
|
|
||||||
to the compiler flags to tell Google Test to change the macro's name
|
|
||||||
from FOO to GTEST_FOO. Currently FOO can be FAIL, SUCCEED, or TEST.
|
|
||||||
For example, with -DGTEST_DONT_DEFINE_TEST=1, you'll need to write
|
|
||||||
|
|
||||||
GTEST_TEST(SomeTest, DoesThis) { ... }
|
|
||||||
|
|
||||||
instead of
|
|
||||||
|
|
||||||
TEST(SomeTest, DoesThis) { ... }
|
|
||||||
|
|
||||||
in order to define a test.
|
|
||||||
|
|
||||||
Upgrating from an Earlier Version
|
|
||||||
---------------------------------
|
|
||||||
|
|
||||||
We strive to keep Google Test releases backward compatible.
|
|
||||||
Sometimes, though, we have to make some breaking changes for the
|
|
||||||
users' long-term benefits. This section describes what you'll need to
|
|
||||||
do if you are upgrading from an earlier version of Google Test.
|
|
||||||
|
|
||||||
### Upgrading from 1.3.0 or Earlier ###
|
|
||||||
|
|
||||||
You may need to explicitly enable or disable Google Test's own TR1
|
|
||||||
tuple library. See the instructions in section "Choosing a TR1 Tuple
|
|
||||||
Library".
|
|
||||||
|
|
||||||
### Upgrading from 1.4.0 or Earlier ###
|
|
||||||
|
|
||||||
The Autotools build script (configure + make) is no longer officially
|
|
||||||
supportted. You are encouraged to migrate to your own build system or
|
|
||||||
use CMake. If you still need to use Autotools, you can find
|
|
||||||
instructions in the README file from Google Test 1.4.0.
|
|
||||||
|
|
||||||
On platforms where the pthread library is available, Google Test uses
|
|
||||||
it in order to be thread-safe. See the "Multi-threaded Tests" section
|
|
||||||
for what this means to your build script.
|
|
||||||
|
|
||||||
If you use Microsoft Visual C++ 7.1 with exceptions disabled, Google
|
|
||||||
Test will no longer compile. This should affect very few people, as a
|
|
||||||
large portion of STL (including <string>) doesn't compile in this mode
|
|
||||||
anyway. We decided to stop supporting it in order to greatly simplify
|
|
||||||
Google Test's implementation.
|
|
||||||
|
|
||||||
Developing Google Test
|
|
||||||
----------------------
|
|
||||||
|
|
||||||
This section discusses how to make your own changes to Google Test.
|
|
||||||
|
|
||||||
### Testing Google Test Itself ###
|
|
||||||
|
|
||||||
To make sure your changes work as intended and don't break existing
|
|
||||||
functionality, you'll want to compile and run Google Test's own tests.
|
|
||||||
For that you can use CMake:
|
|
||||||
|
|
||||||
mkdir mybuild
|
|
||||||
cd mybuild
|
|
||||||
cmake -Dgtest_build_tests=ON ${GTEST_DIR}
|
|
||||||
|
|
||||||
Make sure you have Python installed, as some of Google Test's tests
|
|
||||||
are written in Python. If the cmake command complains about not being
|
|
||||||
able to find Python ("Could NOT find PythonInterp (missing:
|
|
||||||
PYTHON_EXECUTABLE)"), try telling it explicitly where your Python
|
|
||||||
executable can be found:
|
|
||||||
|
|
||||||
cmake -DPYTHON_EXECUTABLE=path/to/python -Dgtest_build_tests=ON ${GTEST_DIR}
|
|
||||||
|
|
||||||
Next, you can build Google Test and all of its own tests. On *nix,
|
|
||||||
this is usually done by 'make'. To run the tests, do
|
|
||||||
|
|
||||||
make test
|
|
||||||
|
|
||||||
All tests should pass.
|
|
||||||
|
|
||||||
### Regenerating Source Files ###
|
|
||||||
|
|
||||||
Some of Google Test's source files are generated from templates (not
|
|
||||||
in the C++ sense) using a script. A template file is named FOO.pump,
|
|
||||||
where FOO is the name of the file it will generate. For example, the
|
|
||||||
file include/gtest/internal/gtest-type-util.h.pump is used to generate
|
|
||||||
gtest-type-util.h in the same directory.
|
|
||||||
|
|
||||||
Normally you don't need to worry about regenerating the source files,
|
|
||||||
unless you need to modify them. In that case, you should modify the
|
|
||||||
corresponding .pump files instead and run the pump.py Python script to
|
|
||||||
regenerate them. You can find pump.py in the scripts/ directory.
|
|
||||||
Read the Pump manual [2] for how to use it.
|
|
||||||
|
|
||||||
[2] http://code.google.com/p/googletest/wiki/PumpManual
|
|
||||||
|
|
||||||
### Contributing a Patch ###
|
|
||||||
|
|
||||||
We welcome patches. Please read the Google Test developer's guide [3]
|
|
||||||
for how you can contribute. In particular, make sure you have signed
|
|
||||||
the Contributor License Agreement, or we won't be able to accept the
|
|
||||||
patch.
|
|
||||||
|
|
||||||
[3] http://code.google.com/p/googletest/wiki/GoogleTestDevGuide
|
|
||||||
|
|
||||||
Happy testing!
|
|
1389
common/protobuf-2.6.1/gtest/aclocal.m4
vendored
1389
common/protobuf-2.6.1/gtest/aclocal.m4
vendored
File diff suppressed because it is too large
Load Diff
@ -1,347 +0,0 @@
|
|||||||
#! /bin/sh
|
|
||||||
# Wrapper for compilers which do not understand '-c -o'.
|
|
||||||
|
|
||||||
scriptversion=2012-10-14.11; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1999-2013 Free Software Foundation, Inc.
|
|
||||||
# Written by Tom Tromey <tromey@cygnus.com>.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# This file is maintained in Automake, please report
|
|
||||||
# bugs to <bug-automake@gnu.org> or send patches to
|
|
||||||
# <automake-patches@gnu.org>.
|
|
||||||
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
|
|
||||||
# We need space, tab and new line, in precisely that order. Quoting is
|
|
||||||
# there to prevent tools from complaining about whitespace usage.
|
|
||||||
IFS=" "" $nl"
|
|
||||||
|
|
||||||
file_conv=
|
|
||||||
|
|
||||||
# func_file_conv build_file lazy
|
|
||||||
# Convert a $build file to $host form and store it in $file
|
|
||||||
# Currently only supports Windows hosts. If the determined conversion
|
|
||||||
# type is listed in (the comma separated) LAZY, no conversion will
|
|
||||||
# take place.
|
|
||||||
func_file_conv ()
|
|
||||||
{
|
|
||||||
file=$1
|
|
||||||
case $file in
|
|
||||||
/ | /[!/]*) # absolute file, and not a UNC file
|
|
||||||
if test -z "$file_conv"; then
|
|
||||||
# lazily determine how to convert abs files
|
|
||||||
case `uname -s` in
|
|
||||||
MINGW*)
|
|
||||||
file_conv=mingw
|
|
||||||
;;
|
|
||||||
CYGWIN*)
|
|
||||||
file_conv=cygwin
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
file_conv=wine
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
case $file_conv/,$2, in
|
|
||||||
*,$file_conv,*)
|
|
||||||
;;
|
|
||||||
mingw/*)
|
|
||||||
file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'`
|
|
||||||
;;
|
|
||||||
cygwin/*)
|
|
||||||
file=`cygpath -m "$file" || echo "$file"`
|
|
||||||
;;
|
|
||||||
wine/*)
|
|
||||||
file=`winepath -w "$file" || echo "$file"`
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# func_cl_dashL linkdir
|
|
||||||
# Make cl look for libraries in LINKDIR
|
|
||||||
func_cl_dashL ()
|
|
||||||
{
|
|
||||||
func_file_conv "$1"
|
|
||||||
if test -z "$lib_path"; then
|
|
||||||
lib_path=$file
|
|
||||||
else
|
|
||||||
lib_path="$lib_path;$file"
|
|
||||||
fi
|
|
||||||
linker_opts="$linker_opts -LIBPATH:$file"
|
|
||||||
}
|
|
||||||
|
|
||||||
# func_cl_dashl library
|
|
||||||
# Do a library search-path lookup for cl
|
|
||||||
func_cl_dashl ()
|
|
||||||
{
|
|
||||||
lib=$1
|
|
||||||
found=no
|
|
||||||
save_IFS=$IFS
|
|
||||||
IFS=';'
|
|
||||||
for dir in $lib_path $LIB
|
|
||||||
do
|
|
||||||
IFS=$save_IFS
|
|
||||||
if $shared && test -f "$dir/$lib.dll.lib"; then
|
|
||||||
found=yes
|
|
||||||
lib=$dir/$lib.dll.lib
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
if test -f "$dir/$lib.lib"; then
|
|
||||||
found=yes
|
|
||||||
lib=$dir/$lib.lib
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
if test -f "$dir/lib$lib.a"; then
|
|
||||||
found=yes
|
|
||||||
lib=$dir/lib$lib.a
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS=$save_IFS
|
|
||||||
|
|
||||||
if test "$found" != yes; then
|
|
||||||
lib=$lib.lib
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# func_cl_wrapper cl arg...
|
|
||||||
# Adjust compile command to suit cl
|
|
||||||
func_cl_wrapper ()
|
|
||||||
{
|
|
||||||
# Assume a capable shell
|
|
||||||
lib_path=
|
|
||||||
shared=:
|
|
||||||
linker_opts=
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$eat"; then
|
|
||||||
eat=
|
|
||||||
else
|
|
||||||
case $1 in
|
|
||||||
-o)
|
|
||||||
# configure might choose to run compile as 'compile cc -o foo foo.c'.
|
|
||||||
eat=1
|
|
||||||
case $2 in
|
|
||||||
*.o | *.[oO][bB][jJ])
|
|
||||||
func_file_conv "$2"
|
|
||||||
set x "$@" -Fo"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
func_file_conv "$2"
|
|
||||||
set x "$@" -Fe"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
-I)
|
|
||||||
eat=1
|
|
||||||
func_file_conv "$2" mingw
|
|
||||||
set x "$@" -I"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-I*)
|
|
||||||
func_file_conv "${1#-I}" mingw
|
|
||||||
set x "$@" -I"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-l)
|
|
||||||
eat=1
|
|
||||||
func_cl_dashl "$2"
|
|
||||||
set x "$@" "$lib"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-l*)
|
|
||||||
func_cl_dashl "${1#-l}"
|
|
||||||
set x "$@" "$lib"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
-L)
|
|
||||||
eat=1
|
|
||||||
func_cl_dashL "$2"
|
|
||||||
;;
|
|
||||||
-L*)
|
|
||||||
func_cl_dashL "${1#-L}"
|
|
||||||
;;
|
|
||||||
-static)
|
|
||||||
shared=false
|
|
||||||
;;
|
|
||||||
-Wl,*)
|
|
||||||
arg=${1#-Wl,}
|
|
||||||
save_ifs="$IFS"; IFS=','
|
|
||||||
for flag in $arg; do
|
|
||||||
IFS="$save_ifs"
|
|
||||||
linker_opts="$linker_opts $flag"
|
|
||||||
done
|
|
||||||
IFS="$save_ifs"
|
|
||||||
;;
|
|
||||||
-Xlinker)
|
|
||||||
eat=1
|
|
||||||
linker_opts="$linker_opts $2"
|
|
||||||
;;
|
|
||||||
-*)
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*.cc | *.CC | *.cxx | *.CXX | *.[cC]++)
|
|
||||||
func_file_conv "$1"
|
|
||||||
set x "$@" -Tp"$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO])
|
|
||||||
func_file_conv "$1" mingw
|
|
||||||
set x "$@" "$file"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
if test -n "$linker_opts"; then
|
|
||||||
linker_opts="-link$linker_opts"
|
|
||||||
fi
|
|
||||||
exec "$@" $linker_opts
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
eat=
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: compile [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Wrapper for compilers which do not understand '-c -o'.
|
|
||||||
Remove '-o dest.o' from ARGS, run PROGRAM with the remaining
|
|
||||||
arguments, and rename the output as expected.
|
|
||||||
|
|
||||||
If you are trying to build a whole package this is not the
|
|
||||||
right script to run: please start by reading the file 'INSTALL'.
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "compile $scriptversion"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
cl | *[/\\]cl | cl.exe | *[/\\]cl.exe )
|
|
||||||
func_cl_wrapper "$@" # Doesn't return...
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
ofile=
|
|
||||||
cfile=
|
|
||||||
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$eat"; then
|
|
||||||
eat=
|
|
||||||
else
|
|
||||||
case $1 in
|
|
||||||
-o)
|
|
||||||
# configure might choose to run compile as 'compile cc -o foo foo.c'.
|
|
||||||
# So we strip '-o arg' only if arg is an object.
|
|
||||||
eat=1
|
|
||||||
case $2 in
|
|
||||||
*.o | *.obj)
|
|
||||||
ofile=$2
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set x "$@" -o "$2"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
*.c)
|
|
||||||
cfile=$1
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set x "$@" "$1"
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
if test -z "$ofile" || test -z "$cfile"; then
|
|
||||||
# If no '-o' option was seen then we might have been invoked from a
|
|
||||||
# pattern rule where we don't need one. That is ok -- this is a
|
|
||||||
# normal compilation that the losing compiler can handle. If no
|
|
||||||
# '.c' file was seen then we are probably linking. That is also
|
|
||||||
# ok.
|
|
||||||
exec "$@"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Name of file we expect compiler to create.
|
|
||||||
cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'`
|
|
||||||
|
|
||||||
# Create the lock directory.
|
|
||||||
# Note: use '[/\\:.-]' here to ensure that we don't use the same name
|
|
||||||
# that we are using for the .o file. Also, base the name on the expected
|
|
||||||
# object file name, since that is what matters with a parallel build.
|
|
||||||
lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d
|
|
||||||
while true; do
|
|
||||||
if mkdir "$lockdir" >/dev/null 2>&1; then
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
sleep 1
|
|
||||||
done
|
|
||||||
# FIXME: race condition here if user kills between mkdir and trap.
|
|
||||||
trap "rmdir '$lockdir'; exit 1" 1 2 15
|
|
||||||
|
|
||||||
# Run the compile.
|
|
||||||
"$@"
|
|
||||||
ret=$?
|
|
||||||
|
|
||||||
if test -f "$cofile"; then
|
|
||||||
test "$cofile" = "$ofile" || mv "$cofile" "$ofile"
|
|
||||||
elif test -f "${cofile}bj"; then
|
|
||||||
test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile"
|
|
||||||
fi
|
|
||||||
|
|
||||||
rmdir "$lockdir"
|
|
||||||
exit $ret
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
1558
common/protobuf-2.6.1/gtest/build-aux/config.guess
vendored
1558
common/protobuf-2.6.1/gtest/build-aux/config.guess
vendored
File diff suppressed because it is too large
Load Diff
@ -1,69 +0,0 @@
|
|||||||
/* build-aux/config.h.in. Generated from configure.ac by autoheader. */
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <dlfcn.h> header file. */
|
|
||||||
#undef HAVE_DLFCN_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <inttypes.h> header file. */
|
|
||||||
#undef HAVE_INTTYPES_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <memory.h> header file. */
|
|
||||||
#undef HAVE_MEMORY_H
|
|
||||||
|
|
||||||
/* Define if you have POSIX threads libraries and header files. */
|
|
||||||
#undef HAVE_PTHREAD
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdint.h> header file. */
|
|
||||||
#undef HAVE_STDINT_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stdlib.h> header file. */
|
|
||||||
#undef HAVE_STDLIB_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <strings.h> header file. */
|
|
||||||
#undef HAVE_STRINGS_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <string.h> header file. */
|
|
||||||
#undef HAVE_STRING_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/stat.h> header file. */
|
|
||||||
#undef HAVE_SYS_STAT_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/types.h> header file. */
|
|
||||||
#undef HAVE_SYS_TYPES_H
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <unistd.h> header file. */
|
|
||||||
#undef HAVE_UNISTD_H
|
|
||||||
|
|
||||||
/* Define to the sub-directory in which libtool stores uninstalled libraries.
|
|
||||||
*/
|
|
||||||
#undef LT_OBJDIR
|
|
||||||
|
|
||||||
/* Name of package */
|
|
||||||
#undef PACKAGE
|
|
||||||
|
|
||||||
/* Define to the address where bug reports for this package should be sent. */
|
|
||||||
#undef PACKAGE_BUGREPORT
|
|
||||||
|
|
||||||
/* Define to the full name of this package. */
|
|
||||||
#undef PACKAGE_NAME
|
|
||||||
|
|
||||||
/* Define to the full name and version of this package. */
|
|
||||||
#undef PACKAGE_STRING
|
|
||||||
|
|
||||||
/* Define to the one symbol short name of this package. */
|
|
||||||
#undef PACKAGE_TARNAME
|
|
||||||
|
|
||||||
/* Define to the home page for this package. */
|
|
||||||
#undef PACKAGE_URL
|
|
||||||
|
|
||||||
/* Define to the version of this package. */
|
|
||||||
#undef PACKAGE_VERSION
|
|
||||||
|
|
||||||
/* Define to necessary symbol if this constant uses a non-standard name on
|
|
||||||
your system. */
|
|
||||||
#undef PTHREAD_CREATE_JOINABLE
|
|
||||||
|
|
||||||
/* Define to 1 if you have the ANSI C header files. */
|
|
||||||
#undef STDC_HEADERS
|
|
||||||
|
|
||||||
/* Version number of package */
|
|
||||||
#undef VERSION
|
|
1791
common/protobuf-2.6.1/gtest/build-aux/config.sub
vendored
1791
common/protobuf-2.6.1/gtest/build-aux/config.sub
vendored
File diff suppressed because it is too large
Load Diff
@ -1,791 +0,0 @@
|
|||||||
#! /bin/sh
|
|
||||||
# depcomp - compile a program generating dependencies as side-effects
|
|
||||||
|
|
||||||
scriptversion=2013-05-30.07; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1999-2013 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: depcomp [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Run PROGRAMS ARGS to compile a file, generating dependencies
|
|
||||||
as side-effects.
|
|
||||||
|
|
||||||
Environment variables:
|
|
||||||
depmode Dependency tracking mode.
|
|
||||||
source Source file read by 'PROGRAMS ARGS'.
|
|
||||||
object Object file output by 'PROGRAMS ARGS'.
|
|
||||||
DEPDIR directory where to store dependencies.
|
|
||||||
depfile Dependency file to output.
|
|
||||||
tmpdepfile Temporary file to use when outputting dependencies.
|
|
||||||
libtool Whether libtool is used (yes/no).
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "depcomp $scriptversion"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Get the directory component of the given path, and save it in the
|
|
||||||
# global variables '$dir'. Note that this directory component will
|
|
||||||
# be either empty or ending with a '/' character. This is deliberate.
|
|
||||||
set_dir_from ()
|
|
||||||
{
|
|
||||||
case $1 in
|
|
||||||
*/*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;;
|
|
||||||
*) dir=;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
# Get the suffix-stripped basename of the given path, and save it the
|
|
||||||
# global variable '$base'.
|
|
||||||
set_base_from ()
|
|
||||||
{
|
|
||||||
base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'`
|
|
||||||
}
|
|
||||||
|
|
||||||
# If no dependency file was actually created by the compiler invocation,
|
|
||||||
# we still have to create a dummy depfile, to avoid errors with the
|
|
||||||
# Makefile "include basename.Plo" scheme.
|
|
||||||
make_dummy_depfile ()
|
|
||||||
{
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Factor out some common post-processing of the generated depfile.
|
|
||||||
# Requires the auxiliary global variable '$tmpdepfile' to be set.
|
|
||||||
aix_post_process_depfile ()
|
|
||||||
{
|
|
||||||
# If the compiler actually managed to produce a dependency file,
|
|
||||||
# post-process it.
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
# Each line is of the form 'foo.o: dependency.h'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# $object: dependency.h
|
|
||||||
# and one to simply output
|
|
||||||
# dependency.h:
|
|
||||||
# which is needed to avoid the deleted-header problem.
|
|
||||||
{ sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile"
|
|
||||||
sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile"
|
|
||||||
} > "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# A tabulation character.
|
|
||||||
tab=' '
|
|
||||||
# A newline character.
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
# Character ranges might be problematic outside the C locale.
|
|
||||||
# These definitions help.
|
|
||||||
upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
|
||||||
lower=abcdefghijklmnopqrstuvwxyz
|
|
||||||
digits=0123456789
|
|
||||||
alpha=${upper}${lower}
|
|
||||||
|
|
||||||
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
|
||||||
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
|
|
||||||
depfile=${depfile-`echo "$object" |
|
|
||||||
sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
|
|
||||||
tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
|
||||||
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
|
|
||||||
# Avoid interferences from the environment.
|
|
||||||
gccflag= dashmflag=
|
|
||||||
|
|
||||||
# Some modes work just like other modes, but use different flags. We
|
|
||||||
# parameterize here, but still list the modes in the big case below,
|
|
||||||
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
|
||||||
# here, because this file can only contain one case statement.
|
|
||||||
if test "$depmode" = hp; then
|
|
||||||
# HP compiler uses -M and no extra arg.
|
|
||||||
gccflag=-M
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = dashXmstdout; then
|
|
||||||
# This is just like dashmstdout with a different argument.
|
|
||||||
dashmflag=-xM
|
|
||||||
depmode=dashmstdout
|
|
||||||
fi
|
|
||||||
|
|
||||||
cygpath_u="cygpath -u -f -"
|
|
||||||
if test "$depmode" = msvcmsys; then
|
|
||||||
# This is just like msvisualcpp but w/o cygpath translation.
|
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
|
||||||
# slashes to satisfy depend.m4
|
|
||||||
cygpath_u='sed s,\\\\,/,g'
|
|
||||||
depmode=msvisualcpp
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = msvc7msys; then
|
|
||||||
# This is just like msvc7 but w/o cygpath translation.
|
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
|
||||||
# slashes to satisfy depend.m4
|
|
||||||
cygpath_u='sed s,\\\\,/,g'
|
|
||||||
depmode=msvc7
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = xlc; then
|
|
||||||
# IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information.
|
|
||||||
gccflag=-qmakedep=gcc,-MF
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$depmode" in
|
|
||||||
gcc3)
|
|
||||||
## gcc 3 implements dependency tracking that does exactly what
|
|
||||||
## we want. Yay! Note: for some reason libtool 1.4 doesn't like
|
|
||||||
## it if -MD -MP comes after the -MF stuff. Hmm.
|
|
||||||
## Unfortunately, FreeBSD c89 acceptance of flags depends upon
|
|
||||||
## the command line argument order; so add the flags where they
|
|
||||||
## appear in depend2.am. Note that the slowdown incurred here
|
|
||||||
## affects only configure: in makefiles, %FASTDEP% shortcuts this.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;;
|
|
||||||
*) set fnord "$@" "$arg" ;;
|
|
||||||
esac
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
done
|
|
||||||
"$@"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
mv "$tmpdepfile" "$depfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
gcc)
|
|
||||||
## Note that this doesn't just cater to obsosete pre-3.x GCC compilers.
|
|
||||||
## but also to in-use compilers like IMB xlc/xlC and the HP C compiler.
|
|
||||||
## (see the conditional assignment to $gccflag above).
|
|
||||||
## There are various ways to get dependency output from gcc. Here's
|
|
||||||
## why we pick this rather obscure method:
|
|
||||||
## - Don't want to use -MD because we'd like the dependencies to end
|
|
||||||
## up in a subdir. Having to rename by hand is ugly.
|
|
||||||
## (We might end up doing this anyway to support other compilers.)
|
|
||||||
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
|
||||||
## -MM, not -M (despite what the docs say). Also, it might not be
|
|
||||||
## supported by the other compilers which use the 'gcc' depmode.
|
|
||||||
## - Using -M directly means running the compiler twice (even worse
|
|
||||||
## than renaming).
|
|
||||||
if test -z "$gccflag"; then
|
|
||||||
gccflag=-MD,
|
|
||||||
fi
|
|
||||||
"$@" -Wp,"$gccflag$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# The second -e expression handles DOS-style file names with drive
|
|
||||||
# letters.
|
|
||||||
sed -e 's/^[^:]*: / /' \
|
|
||||||
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
|
||||||
## This next piece of magic avoids the "deleted header file" problem.
|
|
||||||
## The problem is that when a header file which appears in a .P file
|
|
||||||
## is deleted, the dependency causes make to die (because there is
|
|
||||||
## typically no way to rebuild the header). We avoid this by adding
|
|
||||||
## dummy dependencies for each header file. Too bad gcc doesn't do
|
|
||||||
## this for us directly.
|
|
||||||
## Some versions of gcc put a space before the ':'. On the theory
|
|
||||||
## that the space means something, we add a space to the output as
|
|
||||||
## well. hp depmode also adds that space, but also prefixes the VPATH
|
|
||||||
## to the object. Take care to not repeat it in the output.
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
sgi)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" "-Wp,-MDupdate,$tmpdepfile"
|
|
||||||
else
|
|
||||||
"$@" -MDupdate "$tmpdepfile"
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# Clip off the initial element (the dependent). Don't try to be
|
|
||||||
# clever and replace this with sed code, as IRIX sed won't handle
|
|
||||||
# lines with more than a fixed number of characters (4096 in
|
|
||||||
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
|
||||||
# the IRIX cc adds comments like '#:fec' to the end of the
|
|
||||||
# dependency line.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \
|
|
||||||
| tr "$nl" ' ' >> "$depfile"
|
|
||||||
echo >> "$depfile"
|
|
||||||
# The second pass generates a dummy entry for each header file.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
|
||||||
>> "$depfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
xlc)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
aix)
|
|
||||||
# The C for AIX Compiler uses -M and outputs the dependencies
|
|
||||||
# in a .u file. In older versions, this file always lives in the
|
|
||||||
# current directory. Also, the AIX compiler puts '$object:' at the
|
|
||||||
# start of each line; $object doesn't have directory information.
|
|
||||||
# Version 6 uses the directory in both cases.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
tmpdepfile1=$dir$base.u
|
|
||||||
tmpdepfile2=$base.u
|
|
||||||
tmpdepfile3=$dir.libs/$base.u
|
|
||||||
"$@" -Wc,-M
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.u
|
|
||||||
tmpdepfile2=$dir$base.u
|
|
||||||
tmpdepfile3=$dir$base.u
|
|
||||||
"$@" -M
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
aix_post_process_depfile
|
|
||||||
;;
|
|
||||||
|
|
||||||
tcc)
|
|
||||||
# tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26
|
|
||||||
# FIXME: That version still under development at the moment of writing.
|
|
||||||
# Make that this statement remains true also for stable, released
|
|
||||||
# versions.
|
|
||||||
# It will wrap lines (doesn't matter whether long or short) with a
|
|
||||||
# trailing '\', as in:
|
|
||||||
#
|
|
||||||
# foo.o : \
|
|
||||||
# foo.c \
|
|
||||||
# foo.h \
|
|
||||||
#
|
|
||||||
# It will put a trailing '\' even on the last line, and will use leading
|
|
||||||
# spaces rather than leading tabs (at least since its commit 0394caf7
|
|
||||||
# "Emit spaces for -MD").
|
|
||||||
"$@" -MD -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each non-empty line is of the form 'foo.o : \' or ' dep.h \'.
|
|
||||||
# We have to change lines of the first kind to '$object: \'.
|
|
||||||
sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile"
|
|
||||||
# And for each line of the second kind, we have to emit a 'dep.h:'
|
|
||||||
# dummy dependency, to avoid the deleted-header problem.
|
|
||||||
sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
## The order of this option in the case statement is important, since the
|
|
||||||
## shell code in configure will try each of these formats in the order
|
|
||||||
## listed in this file. A plain '-MD' option would be understood by many
|
|
||||||
## compilers, so we must ensure this comes after the gcc and icc options.
|
|
||||||
pgcc)
|
|
||||||
# Portland's C compiler understands '-MD'.
|
|
||||||
# Will always output deps to 'file.d' where file is the root name of the
|
|
||||||
# source file under compilation, even if file resides in a subdirectory.
|
|
||||||
# The object file name does not affect the name of the '.d' file.
|
|
||||||
# pgcc 10.2 will output
|
|
||||||
# foo.o: sub/foo.c sub/foo.h
|
|
||||||
# and will wrap long lines using '\' :
|
|
||||||
# foo.o: sub/foo.c ... \
|
|
||||||
# sub/foo.h ... \
|
|
||||||
# ...
|
|
||||||
set_dir_from "$object"
|
|
||||||
# Use the source, not the object, to determine the base name, since
|
|
||||||
# that's sadly what pgcc will do too.
|
|
||||||
set_base_from "$source"
|
|
||||||
tmpdepfile=$base.d
|
|
||||||
|
|
||||||
# For projects that build the same source file twice into different object
|
|
||||||
# files, the pgcc approach of using the *source* file root name can cause
|
|
||||||
# problems in parallel builds. Use a locking strategy to avoid stomping on
|
|
||||||
# the same $tmpdepfile.
|
|
||||||
lockdir=$base.d-lock
|
|
||||||
trap "
|
|
||||||
echo '$0: caught signal, cleaning up...' >&2
|
|
||||||
rmdir '$lockdir'
|
|
||||||
exit 1
|
|
||||||
" 1 2 13 15
|
|
||||||
numtries=100
|
|
||||||
i=$numtries
|
|
||||||
while test $i -gt 0; do
|
|
||||||
# mkdir is a portable test-and-set.
|
|
||||||
if mkdir "$lockdir" 2>/dev/null; then
|
|
||||||
# This process acquired the lock.
|
|
||||||
"$@" -MD
|
|
||||||
stat=$?
|
|
||||||
# Release the lock.
|
|
||||||
rmdir "$lockdir"
|
|
||||||
break
|
|
||||||
else
|
|
||||||
# If the lock is being held by a different process, wait
|
|
||||||
# until the winning process is done or we timeout.
|
|
||||||
while test -d "$lockdir" && test $i -gt 0; do
|
|
||||||
sleep 1
|
|
||||||
i=`expr $i - 1`
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
i=`expr $i - 1`
|
|
||||||
done
|
|
||||||
trap - 1 2 13 15
|
|
||||||
if test $i -le 0; then
|
|
||||||
echo "$0: failed to acquire lock after $numtries attempts" >&2
|
|
||||||
echo "$0: check lockdir '$lockdir'" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each line is of the form `foo.o: dependent.h',
|
|
||||||
# or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp2)
|
|
||||||
# The "hp" stanza above does not work with aCC (C++) and HP's ia64
|
|
||||||
# compilers, which have integrated preprocessors. The correct option
|
|
||||||
# to use with these is +Maked; it writes dependencies to a file named
|
|
||||||
# 'foo.d', which lands next to the object file, wherever that
|
|
||||||
# happens to be.
|
|
||||||
# Much of this is similar to the tru64 case; see comments there.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir.libs/$base.d
|
|
||||||
"$@" -Wc,+Maked
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
"$@" +Maked
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile"
|
|
||||||
# Add 'dependent.h:' lines.
|
|
||||||
sed -ne '2,${
|
|
||||||
s/^ *//
|
|
||||||
s/ \\*$//
|
|
||||||
s/$/:/
|
|
||||||
p
|
|
||||||
}' "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
make_dummy_depfile
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile2"
|
|
||||||
;;
|
|
||||||
|
|
||||||
tru64)
|
|
||||||
# The Tru64 compiler uses -MD to generate dependencies as a side
|
|
||||||
# effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'.
|
|
||||||
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
|
||||||
# dependencies in 'foo.d' instead, so we check for that too.
|
|
||||||
# Subdirectories are respected.
|
|
||||||
set_dir_from "$object"
|
|
||||||
set_base_from "$object"
|
|
||||||
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
# Libtool generates 2 separate objects for the 2 libraries. These
|
|
||||||
# two compilations output dependencies in $dir.libs/$base.o.d and
|
|
||||||
# in $dir$base.o.d. We have to check for both files, because
|
|
||||||
# one of the two compilations can be disabled. We should prefer
|
|
||||||
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
|
||||||
# automatically cleaned when .libs/ is deleted, while ignoring
|
|
||||||
# the former would cause a distcleancheck panic.
|
|
||||||
tmpdepfile1=$dir$base.o.d # libtool 1.5
|
|
||||||
tmpdepfile2=$dir.libs/$base.o.d # Likewise.
|
|
||||||
tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504
|
|
||||||
"$@" -Wc,-MD
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
tmpdepfile3=$dir$base.d
|
|
||||||
"$@" -MD
|
|
||||||
fi
|
|
||||||
|
|
||||||
stat=$?
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
# Same post-processing that is required for AIX mode.
|
|
||||||
aix_post_process_depfile
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvc7)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
showIncludes=-Wc,-showIncludes
|
|
||||||
else
|
|
||||||
showIncludes=-showIncludes
|
|
||||||
fi
|
|
||||||
"$@" $showIncludes > "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
grep -v '^Note: including file: ' "$tmpdepfile"
|
|
||||||
if test $stat -ne 0; then
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
# The first sed program below extracts the file names and escapes
|
|
||||||
# backslashes for cygpath. The second sed program outputs the file
|
|
||||||
# name when reading, but also accumulates all include files in the
|
|
||||||
# hold buffer in order to output them again at the end. This only
|
|
||||||
# works with sed implementations that can handle large buffers.
|
|
||||||
sed < "$tmpdepfile" -n '
|
|
||||||
/^Note: including file: *\(.*\)/ {
|
|
||||||
s//\1/
|
|
||||||
s/\\/\\\\/g
|
|
||||||
p
|
|
||||||
}' | $cygpath_u | sort -u | sed -n '
|
|
||||||
s/ /\\ /g
|
|
||||||
s/\(.*\)/'"$tab"'\1 \\/p
|
|
||||||
s/.\(.*\) \\/\1:/
|
|
||||||
H
|
|
||||||
$ {
|
|
||||||
s/.*/'"$tab"'/
|
|
||||||
G
|
|
||||||
p
|
|
||||||
}' >> "$depfile"
|
|
||||||
echo >> "$depfile" # make sure the fragment doesn't end with a backslash
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvc7msys)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
#nosideeffect)
|
|
||||||
# This comment above is used by automake to tell side-effect
|
|
||||||
# dependency tracking mechanisms from slower ones.
|
|
||||||
|
|
||||||
dashmstdout)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove '-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
test -z "$dashmflag" && dashmflag=-M
|
|
||||||
# Require at least two characters before searching for ':'
|
|
||||||
# in the target name. This is to cope with DOS-style filenames:
|
|
||||||
# a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise.
|
|
||||||
"$@" $dashmflag |
|
|
||||||
sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this sed invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
tr ' ' "$nl" < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
dashXmstdout)
|
|
||||||
# This case only exists to satisfy depend.m4. It is never actually
|
|
||||||
# run, as this mode is specially recognized in the preamble.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
makedepend)
|
|
||||||
"$@" || exit $?
|
|
||||||
# Remove any Libtool call
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
# X makedepend
|
|
||||||
shift
|
|
||||||
cleared=no eat=no
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $cleared in
|
|
||||||
no)
|
|
||||||
set ""; shift
|
|
||||||
cleared=yes ;;
|
|
||||||
esac
|
|
||||||
if test $eat = yes; then
|
|
||||||
eat=no
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
case "$arg" in
|
|
||||||
-D*|-I*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
# Strip any option that makedepend may not understand. Remove
|
|
||||||
# the object too, otherwise makedepend will parse it as a source file.
|
|
||||||
-arch)
|
|
||||||
eat=yes ;;
|
|
||||||
-*|$object)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
obj_suffix=`echo "$object" | sed 's/^.*\././'`
|
|
||||||
touch "$tmpdepfile"
|
|
||||||
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
|
||||||
rm -f "$depfile"
|
|
||||||
# makedepend may prepend the VPATH from the source file name to the object.
|
|
||||||
# No need to regex-escape $object, excess matching of '.' is harmless.
|
|
||||||
sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process the last invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed '1,2d' "$tmpdepfile" \
|
|
||||||
| tr ' ' "$nl" \
|
|
||||||
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
|
||||||
| sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
|
||||||
;;
|
|
||||||
|
|
||||||
cpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove '-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
"$@" -E \
|
|
||||||
| sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
| sed '$ s: \\$::' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
cat < "$tmpdepfile" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvisualcpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test "X$1" != 'X--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case "$arg" in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
"-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
|
|
||||||
set fnord "$@"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
"$@" -E 2>/dev/null |
|
|
||||||
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile"
|
|
||||||
echo "$tab" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvcmsys)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
none)
|
|
||||||
exec "$@"
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Unknown depmode $depmode" 1>&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
@ -1,527 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
# install - install a program, script, or datafile
|
|
||||||
|
|
||||||
scriptversion=2011-11-20.07; # UTC
|
|
||||||
|
|
||||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
|
||||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
|
||||||
# following copyright and license.
|
|
||||||
#
|
|
||||||
# Copyright (C) 1994 X Consortium
|
|
||||||
#
|
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
# of this software and associated documentation files (the "Software"), to
|
|
||||||
# deal in the Software without restriction, including without limitation the
|
|
||||||
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
||||||
# sell copies of the Software, and to permit persons to whom the Software is
|
|
||||||
# furnished to do so, subject to the following conditions:
|
|
||||||
#
|
|
||||||
# The above copyright notice and this permission notice shall be included in
|
|
||||||
# all copies or substantial portions of the Software.
|
|
||||||
#
|
|
||||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
||||||
# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
|
|
||||||
# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
#
|
|
||||||
# Except as contained in this notice, the name of the X Consortium shall not
|
|
||||||
# be used in advertising or otherwise to promote the sale, use or other deal-
|
|
||||||
# ings in this Software without prior written authorization from the X Consor-
|
|
||||||
# tium.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# FSF changes to this file are in the public domain.
|
|
||||||
#
|
|
||||||
# Calling this script install-sh is preferred over install.sh, to prevent
|
|
||||||
# 'make' implicit rules from creating a file called install from it
|
|
||||||
# when there is no Makefile.
|
|
||||||
#
|
|
||||||
# This script is compatible with the BSD install script, but was written
|
|
||||||
# from scratch.
|
|
||||||
|
|
||||||
nl='
|
|
||||||
'
|
|
||||||
IFS=" "" $nl"
|
|
||||||
|
|
||||||
# set DOITPROG to echo to test this script
|
|
||||||
|
|
||||||
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
|
||||||
doit=${DOITPROG-}
|
|
||||||
if test -z "$doit"; then
|
|
||||||
doit_exec=exec
|
|
||||||
else
|
|
||||||
doit_exec=$doit
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Put in absolute file names if you don't have them in your path;
|
|
||||||
# or use environment vars.
|
|
||||||
|
|
||||||
chgrpprog=${CHGRPPROG-chgrp}
|
|
||||||
chmodprog=${CHMODPROG-chmod}
|
|
||||||
chownprog=${CHOWNPROG-chown}
|
|
||||||
cmpprog=${CMPPROG-cmp}
|
|
||||||
cpprog=${CPPROG-cp}
|
|
||||||
mkdirprog=${MKDIRPROG-mkdir}
|
|
||||||
mvprog=${MVPROG-mv}
|
|
||||||
rmprog=${RMPROG-rm}
|
|
||||||
stripprog=${STRIPPROG-strip}
|
|
||||||
|
|
||||||
posix_glob='?'
|
|
||||||
initialize_posix_glob='
|
|
||||||
test "$posix_glob" != "?" || {
|
|
||||||
if (set -f) 2>/dev/null; then
|
|
||||||
posix_glob=
|
|
||||||
else
|
|
||||||
posix_glob=:
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
'
|
|
||||||
|
|
||||||
posix_mkdir=
|
|
||||||
|
|
||||||
# Desired mode of installed file.
|
|
||||||
mode=0755
|
|
||||||
|
|
||||||
chgrpcmd=
|
|
||||||
chmodcmd=$chmodprog
|
|
||||||
chowncmd=
|
|
||||||
mvcmd=$mvprog
|
|
||||||
rmcmd="$rmprog -f"
|
|
||||||
stripcmd=
|
|
||||||
|
|
||||||
src=
|
|
||||||
dst=
|
|
||||||
dir_arg=
|
|
||||||
dst_arg=
|
|
||||||
|
|
||||||
copy_on_change=false
|
|
||||||
no_target_directory=
|
|
||||||
|
|
||||||
usage="\
|
|
||||||
Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
|
|
||||||
or: $0 [OPTION]... SRCFILES... DIRECTORY
|
|
||||||
or: $0 [OPTION]... -t DIRECTORY SRCFILES...
|
|
||||||
or: $0 [OPTION]... -d DIRECTORIES...
|
|
||||||
|
|
||||||
In the 1st form, copy SRCFILE to DSTFILE.
|
|
||||||
In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
|
|
||||||
In the 4th, create DIRECTORIES.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
--help display this help and exit.
|
|
||||||
--version display version info and exit.
|
|
||||||
|
|
||||||
-c (ignored)
|
|
||||||
-C install only if different (preserve the last data modification time)
|
|
||||||
-d create directories instead of installing files.
|
|
||||||
-g GROUP $chgrpprog installed files to GROUP.
|
|
||||||
-m MODE $chmodprog installed files to MODE.
|
|
||||||
-o USER $chownprog installed files to USER.
|
|
||||||
-s $stripprog installed files.
|
|
||||||
-t DIRECTORY install into DIRECTORY.
|
|
||||||
-T report an error if DSTFILE is a directory.
|
|
||||||
|
|
||||||
Environment variables override the default commands:
|
|
||||||
CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG
|
|
||||||
RMPROG STRIPPROG
|
|
||||||
"
|
|
||||||
|
|
||||||
while test $# -ne 0; do
|
|
||||||
case $1 in
|
|
||||||
-c) ;;
|
|
||||||
|
|
||||||
-C) copy_on_change=true;;
|
|
||||||
|
|
||||||
-d) dir_arg=true;;
|
|
||||||
|
|
||||||
-g) chgrpcmd="$chgrpprog $2"
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
--help) echo "$usage"; exit $?;;
|
|
||||||
|
|
||||||
-m) mode=$2
|
|
||||||
case $mode in
|
|
||||||
*' '* | *' '* | *'
|
|
||||||
'* | *'*'* | *'?'* | *'['*)
|
|
||||||
echo "$0: invalid mode: $mode" >&2
|
|
||||||
exit 1;;
|
|
||||||
esac
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
-o) chowncmd="$chownprog $2"
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
-s) stripcmd=$stripprog;;
|
|
||||||
|
|
||||||
-t) dst_arg=$2
|
|
||||||
# Protect names problematic for 'test' and other utilities.
|
|
||||||
case $dst_arg in
|
|
||||||
-* | [=\(\)!]) dst_arg=./$dst_arg;;
|
|
||||||
esac
|
|
||||||
shift;;
|
|
||||||
|
|
||||||
-T) no_target_directory=true;;
|
|
||||||
|
|
||||||
--version) echo "$0 $scriptversion"; exit $?;;
|
|
||||||
|
|
||||||
--) shift
|
|
||||||
break;;
|
|
||||||
|
|
||||||
-*) echo "$0: invalid option: $1" >&2
|
|
||||||
exit 1;;
|
|
||||||
|
|
||||||
*) break;;
|
|
||||||
esac
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
|
|
||||||
# When -d is used, all remaining arguments are directories to create.
|
|
||||||
# When -t is used, the destination is already specified.
|
|
||||||
# Otherwise, the last argument is the destination. Remove it from $@.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$dst_arg"; then
|
|
||||||
# $@ is not empty: it contains at least $arg.
|
|
||||||
set fnord "$@" "$dst_arg"
|
|
||||||
shift # fnord
|
|
||||||
fi
|
|
||||||
shift # arg
|
|
||||||
dst_arg=$arg
|
|
||||||
# Protect names problematic for 'test' and other utilities.
|
|
||||||
case $dst_arg in
|
|
||||||
-* | [=\(\)!]) dst_arg=./$dst_arg;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $# -eq 0; then
|
|
||||||
if test -z "$dir_arg"; then
|
|
||||||
echo "$0: no input file specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
# It's OK to call 'install-sh -d' without argument.
|
|
||||||
# This can happen when creating conditional directories.
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$dir_arg"; then
|
|
||||||
do_exit='(exit $ret); exit $ret'
|
|
||||||
trap "ret=129; $do_exit" 1
|
|
||||||
trap "ret=130; $do_exit" 2
|
|
||||||
trap "ret=141; $do_exit" 13
|
|
||||||
trap "ret=143; $do_exit" 15
|
|
||||||
|
|
||||||
# Set umask so as not to create temps with too-generous modes.
|
|
||||||
# However, 'strip' requires both read and write access to temps.
|
|
||||||
case $mode in
|
|
||||||
# Optimize common cases.
|
|
||||||
*644) cp_umask=133;;
|
|
||||||
*755) cp_umask=22;;
|
|
||||||
|
|
||||||
*[0-7])
|
|
||||||
if test -z "$stripcmd"; then
|
|
||||||
u_plus_rw=
|
|
||||||
else
|
|
||||||
u_plus_rw='% 200'
|
|
||||||
fi
|
|
||||||
cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
|
|
||||||
*)
|
|
||||||
if test -z "$stripcmd"; then
|
|
||||||
u_plus_rw=
|
|
||||||
else
|
|
||||||
u_plus_rw=,u+rw
|
|
||||||
fi
|
|
||||||
cp_umask=$mode$u_plus_rw;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
for src
|
|
||||||
do
|
|
||||||
# Protect names problematic for 'test' and other utilities.
|
|
||||||
case $src in
|
|
||||||
-* | [=\(\)!]) src=./$src;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
dst=$src
|
|
||||||
dstdir=$dst
|
|
||||||
test -d "$dstdir"
|
|
||||||
dstdir_status=$?
|
|
||||||
else
|
|
||||||
|
|
||||||
# Waiting for this to be detected by the "$cpprog $src $dsttmp" command
|
|
||||||
# might cause directories to be created, which would be especially bad
|
|
||||||
# if $src (and thus $dsttmp) contains '*'.
|
|
||||||
if test ! -f "$src" && test ! -d "$src"; then
|
|
||||||
echo "$0: $src does not exist." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$dst_arg"; then
|
|
||||||
echo "$0: no destination specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
dst=$dst_arg
|
|
||||||
|
|
||||||
# If destination is a directory, append the input filename; won't work
|
|
||||||
# if double slashes aren't ignored.
|
|
||||||
if test -d "$dst"; then
|
|
||||||
if test -n "$no_target_directory"; then
|
|
||||||
echo "$0: $dst_arg: Is a directory" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
dstdir=$dst
|
|
||||||
dst=$dstdir/`basename "$src"`
|
|
||||||
dstdir_status=0
|
|
||||||
else
|
|
||||||
# Prefer dirname, but fall back on a substitute if dirname fails.
|
|
||||||
dstdir=`
|
|
||||||
(dirname "$dst") 2>/dev/null ||
|
|
||||||
expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
|
|
||||||
X"$dst" : 'X\(//\)[^/]' \| \
|
|
||||||
X"$dst" : 'X\(//\)$' \| \
|
|
||||||
X"$dst" : 'X\(/\)' \| . 2>/dev/null ||
|
|
||||||
echo X"$dst" |
|
|
||||||
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
/^X\(\/\/\)[^/].*/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
/^X\(\/\/\)$/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
/^X\(\/\).*/{
|
|
||||||
s//\1/
|
|
||||||
q
|
|
||||||
}
|
|
||||||
s/.*/./; q'
|
|
||||||
`
|
|
||||||
|
|
||||||
test -d "$dstdir"
|
|
||||||
dstdir_status=$?
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
obsolete_mkdir_used=false
|
|
||||||
|
|
||||||
if test $dstdir_status != 0; then
|
|
||||||
case $posix_mkdir in
|
|
||||||
'')
|
|
||||||
# Create intermediate dirs using mode 755 as modified by the umask.
|
|
||||||
# This is like FreeBSD 'install' as of 1997-10-28.
|
|
||||||
umask=`umask`
|
|
||||||
case $stripcmd.$umask in
|
|
||||||
# Optimize common cases.
|
|
||||||
*[2367][2367]) mkdir_umask=$umask;;
|
|
||||||
.*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
|
|
||||||
|
|
||||||
*[0-7])
|
|
||||||
mkdir_umask=`expr $umask + 22 \
|
|
||||||
- $umask % 100 % 40 + $umask % 20 \
|
|
||||||
- $umask % 10 % 4 + $umask % 2
|
|
||||||
`;;
|
|
||||||
*) mkdir_umask=$umask,go-w;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# With -d, create the new directory with the user-specified mode.
|
|
||||||
# Otherwise, rely on $mkdir_umask.
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
mkdir_mode=-m$mode
|
|
||||||
else
|
|
||||||
mkdir_mode=
|
|
||||||
fi
|
|
||||||
|
|
||||||
posix_mkdir=false
|
|
||||||
case $umask in
|
|
||||||
*[123567][0-7][0-7])
|
|
||||||
# POSIX mkdir -p sets u+wx bits regardless of umask, which
|
|
||||||
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
|
|
||||||
trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
|
|
||||||
|
|
||||||
if (umask $mkdir_umask &&
|
|
||||||
exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
if test -z "$dir_arg" || {
|
|
||||||
# Check for POSIX incompatibilities with -m.
|
|
||||||
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
|
|
||||||
# other-writable bit of parent directory when it shouldn't.
|
|
||||||
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
|
|
||||||
ls_ld_tmpdir=`ls -ld "$tmpdir"`
|
|
||||||
case $ls_ld_tmpdir in
|
|
||||||
d????-?r-*) different_mode=700;;
|
|
||||||
d????-?--*) different_mode=755;;
|
|
||||||
*) false;;
|
|
||||||
esac &&
|
|
||||||
$mkdirprog -m$different_mode -p -- "$tmpdir" && {
|
|
||||||
ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
|
|
||||||
test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
then posix_mkdir=:
|
|
||||||
fi
|
|
||||||
rmdir "$tmpdir/d" "$tmpdir"
|
|
||||||
else
|
|
||||||
# Remove any dirs left behind by ancient mkdir implementations.
|
|
||||||
rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
|
|
||||||
fi
|
|
||||||
trap '' 0;;
|
|
||||||
esac;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if
|
|
||||||
$posix_mkdir && (
|
|
||||||
umask $mkdir_umask &&
|
|
||||||
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
|
|
||||||
)
|
|
||||||
then :
|
|
||||||
else
|
|
||||||
|
|
||||||
# The umask is ridiculous, or mkdir does not conform to POSIX,
|
|
||||||
# or it failed possibly due to a race condition. Create the
|
|
||||||
# directory the slow way, step by step, checking for races as we go.
|
|
||||||
|
|
||||||
case $dstdir in
|
|
||||||
/*) prefix='/';;
|
|
||||||
[-=\(\)!]*) prefix='./';;
|
|
||||||
*) prefix='';;
|
|
||||||
esac
|
|
||||||
|
|
||||||
eval "$initialize_posix_glob"
|
|
||||||
|
|
||||||
oIFS=$IFS
|
|
||||||
IFS=/
|
|
||||||
$posix_glob set -f
|
|
||||||
set fnord $dstdir
|
|
||||||
shift
|
|
||||||
$posix_glob set +f
|
|
||||||
IFS=$oIFS
|
|
||||||
|
|
||||||
prefixes=
|
|
||||||
|
|
||||||
for d
|
|
||||||
do
|
|
||||||
test X"$d" = X && continue
|
|
||||||
|
|
||||||
prefix=$prefix$d
|
|
||||||
if test -d "$prefix"; then
|
|
||||||
prefixes=
|
|
||||||
else
|
|
||||||
if $posix_mkdir; then
|
|
||||||
(umask=$mkdir_umask &&
|
|
||||||
$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
|
|
||||||
# Don't fail if two instances are running concurrently.
|
|
||||||
test -d "$prefix" || exit 1
|
|
||||||
else
|
|
||||||
case $prefix in
|
|
||||||
*\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
|
|
||||||
*) qprefix=$prefix;;
|
|
||||||
esac
|
|
||||||
prefixes="$prefixes '$qprefix'"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
prefix=$prefix/
|
|
||||||
done
|
|
||||||
|
|
||||||
if test -n "$prefixes"; then
|
|
||||||
# Don't fail if two instances are running concurrently.
|
|
||||||
(umask $mkdir_umask &&
|
|
||||||
eval "\$doit_exec \$mkdirprog $prefixes") ||
|
|
||||||
test -d "$dstdir" || exit 1
|
|
||||||
obsolete_mkdir_used=true
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
{ test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
|
|
||||||
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
|
|
||||||
{ test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
|
|
||||||
test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
|
|
||||||
else
|
|
||||||
|
|
||||||
# Make a couple of temp file names in the proper directory.
|
|
||||||
dsttmp=$dstdir/_inst.$$_
|
|
||||||
rmtmp=$dstdir/_rm.$$_
|
|
||||||
|
|
||||||
# Trap to clean up those temp files at exit.
|
|
||||||
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
|
||||||
|
|
||||||
# Copy the file name to the temp name.
|
|
||||||
(umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") &&
|
|
||||||
|
|
||||||
# and set any options; do chmod last to preserve setuid bits.
|
|
||||||
#
|
|
||||||
# If any of these fail, we abort the whole thing. If we want to
|
|
||||||
# ignore errors from any of these, just make sure not to ignore
|
|
||||||
# errors from the above "$doit $cpprog $src $dsttmp" command.
|
|
||||||
#
|
|
||||||
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } &&
|
|
||||||
{ test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } &&
|
|
||||||
{ test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } &&
|
|
||||||
{ test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
|
|
||||||
|
|
||||||
# If -C, don't bother to copy if it wouldn't change the file.
|
|
||||||
if $copy_on_change &&
|
|
||||||
old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` &&
|
|
||||||
new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` &&
|
|
||||||
|
|
||||||
eval "$initialize_posix_glob" &&
|
|
||||||
$posix_glob set -f &&
|
|
||||||
set X $old && old=:$2:$4:$5:$6 &&
|
|
||||||
set X $new && new=:$2:$4:$5:$6 &&
|
|
||||||
$posix_glob set +f &&
|
|
||||||
|
|
||||||
test "$old" = "$new" &&
|
|
||||||
$cmpprog "$dst" "$dsttmp" >/dev/null 2>&1
|
|
||||||
then
|
|
||||||
rm -f "$dsttmp"
|
|
||||||
else
|
|
||||||
# Rename the file to the real destination.
|
|
||||||
$doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null ||
|
|
||||||
|
|
||||||
# The rename failed, perhaps because mv can't rename something else
|
|
||||||
# to itself, or perhaps because mv is so ancient that it does not
|
|
||||||
# support -f.
|
|
||||||
{
|
|
||||||
# Now remove or move aside any old file at destination location.
|
|
||||||
# We try this two ways since rm can't unlink itself on some
|
|
||||||
# systems and the destination file might be busy for other
|
|
||||||
# reasons. In this case, the final cleanup might fail but the new
|
|
||||||
# file should still install successfully.
|
|
||||||
{
|
|
||||||
test ! -f "$dst" ||
|
|
||||||
$doit $rmcmd -f "$dst" 2>/dev/null ||
|
|
||||||
{ $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null &&
|
|
||||||
{ $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }
|
|
||||||
} ||
|
|
||||||
{ echo "$0: cannot unlink or rename $dst" >&2
|
|
||||||
(exit 1); exit 1
|
|
||||||
}
|
|
||||||
} &&
|
|
||||||
|
|
||||||
# Now rename the file to the real destination.
|
|
||||||
$doit $mvcmd "$dsttmp" "$dst"
|
|
||||||
}
|
|
||||||
fi || exit 1
|
|
||||||
|
|
||||||
trap '' 0
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
File diff suppressed because it is too large
Load Diff
@ -1,215 +0,0 @@
|
|||||||
#! /bin/sh
|
|
||||||
# Common wrapper for a few potentially missing GNU programs.
|
|
||||||
|
|
||||||
scriptversion=2013-10-28.13; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 1996-2013 Free Software Foundation, Inc.
|
|
||||||
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
if test $# -eq 0; then
|
|
||||||
echo 1>&2 "Try '$0 --help' for more information"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
|
|
||||||
--is-lightweight)
|
|
||||||
# Used by our autoconf macros to check whether the available missing
|
|
||||||
# script is modern enough.
|
|
||||||
exit 0
|
|
||||||
;;
|
|
||||||
|
|
||||||
--run)
|
|
||||||
# Back-compat with the calling convention used by older automake.
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
|
|
||||||
-h|--h|--he|--hel|--help)
|
|
||||||
echo "\
|
|
||||||
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
|
||||||
|
|
||||||
Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due
|
|
||||||
to PROGRAM being missing or too old.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
-h, --help display this help and exit
|
|
||||||
-v, --version output version information and exit
|
|
||||||
|
|
||||||
Supported PROGRAM values:
|
|
||||||
aclocal autoconf autoheader autom4te automake makeinfo
|
|
||||||
bison yacc flex lex help2man
|
|
||||||
|
|
||||||
Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and
|
|
||||||
'g' are ignored when checking the name.
|
|
||||||
|
|
||||||
Send bug reports to <bug-automake@gnu.org>."
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
|
|
||||||
-v|--v|--ve|--ver|--vers|--versi|--versio|--version)
|
|
||||||
echo "missing $scriptversion (GNU Automake)"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
|
|
||||||
-*)
|
|
||||||
echo 1>&2 "$0: unknown '$1' option"
|
|
||||||
echo 1>&2 "Try '$0 --help' for more information"
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Run the given program, remember its exit status.
|
|
||||||
"$@"; st=$?
|
|
||||||
|
|
||||||
# If it succeeded, we are done.
|
|
||||||
test $st -eq 0 && exit 0
|
|
||||||
|
|
||||||
# Also exit now if we it failed (or wasn't found), and '--version' was
|
|
||||||
# passed; such an option is passed most likely to detect whether the
|
|
||||||
# program is present and works.
|
|
||||||
case $2 in --version|--help) exit $st;; esac
|
|
||||||
|
|
||||||
# Exit code 63 means version mismatch. This often happens when the user
|
|
||||||
# tries to use an ancient version of a tool on a file that requires a
|
|
||||||
# minimum version.
|
|
||||||
if test $st -eq 63; then
|
|
||||||
msg="probably too old"
|
|
||||||
elif test $st -eq 127; then
|
|
||||||
# Program was missing.
|
|
||||||
msg="missing on your system"
|
|
||||||
else
|
|
||||||
# Program was found and executed, but failed. Give up.
|
|
||||||
exit $st
|
|
||||||
fi
|
|
||||||
|
|
||||||
perl_URL=http://www.perl.org/
|
|
||||||
flex_URL=http://flex.sourceforge.net/
|
|
||||||
gnu_software_URL=http://www.gnu.org/software
|
|
||||||
|
|
||||||
program_details ()
|
|
||||||
{
|
|
||||||
case $1 in
|
|
||||||
aclocal|automake)
|
|
||||||
echo "The '$1' program is part of the GNU Automake package:"
|
|
||||||
echo "<$gnu_software_URL/automake>"
|
|
||||||
echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:"
|
|
||||||
echo "<$gnu_software_URL/autoconf>"
|
|
||||||
echo "<$gnu_software_URL/m4/>"
|
|
||||||
echo "<$perl_URL>"
|
|
||||||
;;
|
|
||||||
autoconf|autom4te|autoheader)
|
|
||||||
echo "The '$1' program is part of the GNU Autoconf package:"
|
|
||||||
echo "<$gnu_software_URL/autoconf/>"
|
|
||||||
echo "It also requires GNU m4 and Perl in order to run:"
|
|
||||||
echo "<$gnu_software_URL/m4/>"
|
|
||||||
echo "<$perl_URL>"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
give_advice ()
|
|
||||||
{
|
|
||||||
# Normalize program name to check for.
|
|
||||||
normalized_program=`echo "$1" | sed '
|
|
||||||
s/^gnu-//; t
|
|
||||||
s/^gnu//; t
|
|
||||||
s/^g//; t'`
|
|
||||||
|
|
||||||
printf '%s\n' "'$1' is $msg."
|
|
||||||
|
|
||||||
configure_deps="'configure.ac' or m4 files included by 'configure.ac'"
|
|
||||||
case $normalized_program in
|
|
||||||
autoconf*)
|
|
||||||
echo "You should only need it if you modified 'configure.ac',"
|
|
||||||
echo "or m4 files included by it."
|
|
||||||
program_details 'autoconf'
|
|
||||||
;;
|
|
||||||
autoheader*)
|
|
||||||
echo "You should only need it if you modified 'acconfig.h' or"
|
|
||||||
echo "$configure_deps."
|
|
||||||
program_details 'autoheader'
|
|
||||||
;;
|
|
||||||
automake*)
|
|
||||||
echo "You should only need it if you modified 'Makefile.am' or"
|
|
||||||
echo "$configure_deps."
|
|
||||||
program_details 'automake'
|
|
||||||
;;
|
|
||||||
aclocal*)
|
|
||||||
echo "You should only need it if you modified 'acinclude.m4' or"
|
|
||||||
echo "$configure_deps."
|
|
||||||
program_details 'aclocal'
|
|
||||||
;;
|
|
||||||
autom4te*)
|
|
||||||
echo "You might have modified some maintainer files that require"
|
|
||||||
echo "the 'autom4te' program to be rebuilt."
|
|
||||||
program_details 'autom4te'
|
|
||||||
;;
|
|
||||||
bison*|yacc*)
|
|
||||||
echo "You should only need it if you modified a '.y' file."
|
|
||||||
echo "You may want to install the GNU Bison package:"
|
|
||||||
echo "<$gnu_software_URL/bison/>"
|
|
||||||
;;
|
|
||||||
lex*|flex*)
|
|
||||||
echo "You should only need it if you modified a '.l' file."
|
|
||||||
echo "You may want to install the Fast Lexical Analyzer package:"
|
|
||||||
echo "<$flex_URL>"
|
|
||||||
;;
|
|
||||||
help2man*)
|
|
||||||
echo "You should only need it if you modified a dependency" \
|
|
||||||
"of a man page."
|
|
||||||
echo "You may want to install the GNU Help2man package:"
|
|
||||||
echo "<$gnu_software_URL/help2man/>"
|
|
||||||
;;
|
|
||||||
makeinfo*)
|
|
||||||
echo "You should only need it if you modified a '.texi' file, or"
|
|
||||||
echo "any other file indirectly affecting the aspect of the manual."
|
|
||||||
echo "You might want to install the Texinfo package:"
|
|
||||||
echo "<$gnu_software_URL/texinfo/>"
|
|
||||||
echo "The spurious makeinfo call might also be the consequence of"
|
|
||||||
echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might"
|
|
||||||
echo "want to install GNU make:"
|
|
||||||
echo "<$gnu_software_URL/make/>"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "You might have modified some files without having the proper"
|
|
||||||
echo "tools for further handling them. Check the 'README' file, it"
|
|
||||||
echo "often tells you about the needed prerequisites for installing"
|
|
||||||
echo "this package. You may also peek at any GNU archive site, in"
|
|
||||||
echo "case some other package contains this missing '$1' program."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
give_advice "$1" | sed -e '1s/^/WARNING: /' \
|
|
||||||
-e '2,$s/^/ /' >&2
|
|
||||||
|
|
||||||
# Propagate the correct exit status (expected to be 127 for a program
|
|
||||||
# not found, 63 for a program that failed due to version mismatch).
|
|
||||||
exit $st
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
@ -1,139 +0,0 @@
|
|||||||
#! /bin/sh
|
|
||||||
# test-driver - basic testsuite driver script.
|
|
||||||
|
|
||||||
scriptversion=2013-07-13.22; # UTC
|
|
||||||
|
|
||||||
# Copyright (C) 2011-2013 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
#
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# This file is maintained in Automake, please report
|
|
||||||
# bugs to <bug-automake@gnu.org> or send patches to
|
|
||||||
# <automake-patches@gnu.org>.
|
|
||||||
|
|
||||||
# Make unconditional expansion of undefined variables an error. This
|
|
||||||
# helps a lot in preventing typo-related bugs.
|
|
||||||
set -u
|
|
||||||
|
|
||||||
usage_error ()
|
|
||||||
{
|
|
||||||
echo "$0: $*" >&2
|
|
||||||
print_usage >&2
|
|
||||||
exit 2
|
|
||||||
}
|
|
||||||
|
|
||||||
print_usage ()
|
|
||||||
{
|
|
||||||
cat <<END
|
|
||||||
Usage:
|
|
||||||
test-driver --test-name=NAME --log-file=PATH --trs-file=PATH
|
|
||||||
[--expect-failure={yes|no}] [--color-tests={yes|no}]
|
|
||||||
[--enable-hard-errors={yes|no}] [--]
|
|
||||||
TEST-SCRIPT [TEST-SCRIPT-ARGUMENTS]
|
|
||||||
The '--test-name', '--log-file' and '--trs-file' options are mandatory.
|
|
||||||
END
|
|
||||||
}
|
|
||||||
|
|
||||||
test_name= # Used for reporting.
|
|
||||||
log_file= # Where to save the output of the test script.
|
|
||||||
trs_file= # Where to save the metadata of the test run.
|
|
||||||
expect_failure=no
|
|
||||||
color_tests=no
|
|
||||||
enable_hard_errors=yes
|
|
||||||
while test $# -gt 0; do
|
|
||||||
case $1 in
|
|
||||||
--help) print_usage; exit $?;;
|
|
||||||
--version) echo "test-driver $scriptversion"; exit $?;;
|
|
||||||
--test-name) test_name=$2; shift;;
|
|
||||||
--log-file) log_file=$2; shift;;
|
|
||||||
--trs-file) trs_file=$2; shift;;
|
|
||||||
--color-tests) color_tests=$2; shift;;
|
|
||||||
--expect-failure) expect_failure=$2; shift;;
|
|
||||||
--enable-hard-errors) enable_hard_errors=$2; shift;;
|
|
||||||
--) shift; break;;
|
|
||||||
-*) usage_error "invalid option: '$1'";;
|
|
||||||
*) break;;
|
|
||||||
esac
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
missing_opts=
|
|
||||||
test x"$test_name" = x && missing_opts="$missing_opts --test-name"
|
|
||||||
test x"$log_file" = x && missing_opts="$missing_opts --log-file"
|
|
||||||
test x"$trs_file" = x && missing_opts="$missing_opts --trs-file"
|
|
||||||
if test x"$missing_opts" != x; then
|
|
||||||
usage_error "the following mandatory options are missing:$missing_opts"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $# -eq 0; then
|
|
||||||
usage_error "missing argument"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $color_tests = yes; then
|
|
||||||
# Keep this in sync with 'lib/am/check.am:$(am__tty_colors)'.
|
|
||||||
red='[0;31m' # Red.
|
|
||||||
grn='[0;32m' # Green.
|
|
||||||
lgn='[1;32m' # Light green.
|
|
||||||
blu='[1;34m' # Blue.
|
|
||||||
mgn='[0;35m' # Magenta.
|
|
||||||
std='[m' # No color.
|
|
||||||
else
|
|
||||||
red= grn= lgn= blu= mgn= std=
|
|
||||||
fi
|
|
||||||
|
|
||||||
do_exit='rm -f $log_file $trs_file; (exit $st); exit $st'
|
|
||||||
trap "st=129; $do_exit" 1
|
|
||||||
trap "st=130; $do_exit" 2
|
|
||||||
trap "st=141; $do_exit" 13
|
|
||||||
trap "st=143; $do_exit" 15
|
|
||||||
|
|
||||||
# Test script is run here.
|
|
||||||
"$@" >$log_file 2>&1
|
|
||||||
estatus=$?
|
|
||||||
if test $enable_hard_errors = no && test $estatus -eq 99; then
|
|
||||||
estatus=1
|
|
||||||
fi
|
|
||||||
|
|
||||||
case $estatus:$expect_failure in
|
|
||||||
0:yes) col=$red res=XPASS recheck=yes gcopy=yes;;
|
|
||||||
0:*) col=$grn res=PASS recheck=no gcopy=no;;
|
|
||||||
77:*) col=$blu res=SKIP recheck=no gcopy=yes;;
|
|
||||||
99:*) col=$mgn res=ERROR recheck=yes gcopy=yes;;
|
|
||||||
*:yes) col=$lgn res=XFAIL recheck=no gcopy=yes;;
|
|
||||||
*:*) col=$red res=FAIL recheck=yes gcopy=yes;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Report outcome to console.
|
|
||||||
echo "${col}${res}${std}: $test_name"
|
|
||||||
|
|
||||||
# Register the test result, and other relevant metadata.
|
|
||||||
echo ":test-result: $res" > $trs_file
|
|
||||||
echo ":global-test-result: $res" >> $trs_file
|
|
||||||
echo ":recheck: $recheck" >> $trs_file
|
|
||||||
echo ":copy-in-global-log: $gcopy" >> $trs_file
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-time-zone: "UTC"
|
|
||||||
# time-stamp-end: "; # UTC"
|
|
||||||
# End:
|
|
@ -1,227 +0,0 @@
|
|||||||
# Defines functions and macros useful for building Google Test and
|
|
||||||
# Google Mock.
|
|
||||||
#
|
|
||||||
# Note:
|
|
||||||
#
|
|
||||||
# - This file will be run twice when building Google Mock (once via
|
|
||||||
# Google Test's CMakeLists.txt, and once via Google Mock's).
|
|
||||||
# Therefore it shouldn't have any side effects other than defining
|
|
||||||
# the functions and macros.
|
|
||||||
#
|
|
||||||
# - The functions/macros defined in this file may depend on Google
|
|
||||||
# Test and Google Mock's option() definitions, and thus must be
|
|
||||||
# called *after* the options have been defined.
|
|
||||||
|
|
||||||
# Tweaks CMake's default compiler/linker settings to suit Google Test's needs.
|
|
||||||
#
|
|
||||||
# This must be a macro(), as inside a function string() can only
|
|
||||||
# update variables in the function scope.
|
|
||||||
macro(fix_default_compiler_settings_)
|
|
||||||
if (MSVC)
|
|
||||||
# For MSVC, CMake sets certain flags to defaults we want to override.
|
|
||||||
# This replacement code is taken from sample in the CMake Wiki at
|
|
||||||
# http://www.cmake.org/Wiki/CMake_FAQ#Dynamic_Replace.
|
|
||||||
foreach (flag_var
|
|
||||||
CMAKE_CXX_FLAGS CMAKE_CXX_FLAGS_DEBUG CMAKE_CXX_FLAGS_RELEASE
|
|
||||||
CMAKE_CXX_FLAGS_MINSIZEREL CMAKE_CXX_FLAGS_RELWITHDEBINFO)
|
|
||||||
if (NOT BUILD_SHARED_LIBS AND NOT gtest_force_shared_crt)
|
|
||||||
# When Google Test is built as a shared library, it should also use
|
|
||||||
# shared runtime libraries. Otherwise, it may end up with multiple
|
|
||||||
# copies of runtime library data in different modules, resulting in
|
|
||||||
# hard-to-find crashes. When it is built as a static library, it is
|
|
||||||
# preferable to use CRT as static libraries, as we don't have to rely
|
|
||||||
# on CRT DLLs being available. CMake always defaults to using shared
|
|
||||||
# CRT libraries, so we override that default here.
|
|
||||||
string(REPLACE "/MD" "-MT" ${flag_var} "${${flag_var}}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# We prefer more strict warning checking for building Google Test.
|
|
||||||
# Replaces /W3 with /W4 in defaults.
|
|
||||||
string(REPLACE "/W3" "-W4" ${flag_var} "${${flag_var}}")
|
|
||||||
endforeach()
|
|
||||||
endif()
|
|
||||||
endmacro()
|
|
||||||
|
|
||||||
# Defines the compiler/linker flags used to build Google Test and
|
|
||||||
# Google Mock. You can tweak these definitions to suit your need. A
|
|
||||||
# variable's value is empty before it's explicitly assigned to.
|
|
||||||
macro(config_compiler_and_linker)
|
|
||||||
if (NOT gtest_disable_pthreads)
|
|
||||||
# Defines CMAKE_USE_PTHREADS_INIT and CMAKE_THREAD_LIBS_INIT.
|
|
||||||
find_package(Threads)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
fix_default_compiler_settings_()
|
|
||||||
if (MSVC)
|
|
||||||
# Newlines inside flags variables break CMake's NMake generator.
|
|
||||||
# TODO(vladl@google.com): Add -RTCs and -RTCu to debug builds.
|
|
||||||
set(cxx_base_flags "-GS -W4 -WX -wd4127 -wd4251 -wd4275 -nologo -J -Zi")
|
|
||||||
if (MSVC_VERSION LESS 1400)
|
|
||||||
# Suppress spurious warnings MSVC 7.1 sometimes issues.
|
|
||||||
# Forcing value to bool.
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -wd4800")
|
|
||||||
# Copy constructor and assignment operator could not be generated.
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -wd4511 -wd4512")
|
|
||||||
# Compatibility warnings not applicable to Google Test.
|
|
||||||
# Resolved overload was found by argument-dependent lookup.
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -wd4675")
|
|
||||||
endif()
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -D_UNICODE -DUNICODE -DWIN32 -D_WIN32")
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -DSTRICT -DWIN32_LEAN_AND_MEAN")
|
|
||||||
set(cxx_exception_flags "-EHsc -D_HAS_EXCEPTIONS=1")
|
|
||||||
set(cxx_no_exception_flags "-D_HAS_EXCEPTIONS=0")
|
|
||||||
set(cxx_no_rtti_flags "-GR-")
|
|
||||||
elseif (CMAKE_COMPILER_IS_GNUCXX)
|
|
||||||
set(cxx_base_flags "-Wall -Wshadow")
|
|
||||||
set(cxx_exception_flags "-fexceptions")
|
|
||||||
set(cxx_no_exception_flags "-fno-exceptions")
|
|
||||||
# Until version 4.3.2, GCC doesn't define a macro to indicate
|
|
||||||
# whether RTTI is enabled. Therefore we define GTEST_HAS_RTTI
|
|
||||||
# explicitly.
|
|
||||||
set(cxx_no_rtti_flags "-fno-rtti -DGTEST_HAS_RTTI=0")
|
|
||||||
set(cxx_strict_flags
|
|
||||||
"-Wextra -Wno-unused-parameter -Wno-missing-field-initializers")
|
|
||||||
elseif (CMAKE_CXX_COMPILER_ID STREQUAL "SunPro")
|
|
||||||
set(cxx_exception_flags "-features=except")
|
|
||||||
# Sun Pro doesn't provide macros to indicate whether exceptions and
|
|
||||||
# RTTI are enabled, so we define GTEST_HAS_* explicitly.
|
|
||||||
set(cxx_no_exception_flags "-features=no%except -DGTEST_HAS_EXCEPTIONS=0")
|
|
||||||
set(cxx_no_rtti_flags "-features=no%rtti -DGTEST_HAS_RTTI=0")
|
|
||||||
elseif (CMAKE_CXX_COMPILER_ID STREQUAL "VisualAge" OR
|
|
||||||
CMAKE_CXX_COMPILER_ID STREQUAL "XL")
|
|
||||||
# CMake 2.8 changes Visual Age's compiler ID to "XL".
|
|
||||||
set(cxx_exception_flags "-qeh")
|
|
||||||
set(cxx_no_exception_flags "-qnoeh")
|
|
||||||
# Until version 9.0, Visual Age doesn't define a macro to indicate
|
|
||||||
# whether RTTI is enabled. Therefore we define GTEST_HAS_RTTI
|
|
||||||
# explicitly.
|
|
||||||
set(cxx_no_rtti_flags "-qnortti -DGTEST_HAS_RTTI=0")
|
|
||||||
elseif (CMAKE_CXX_COMPILER_ID STREQUAL "HP")
|
|
||||||
set(cxx_base_flags "-AA -mt")
|
|
||||||
set(cxx_exception_flags "-DGTEST_HAS_EXCEPTIONS=1")
|
|
||||||
set(cxx_no_exception_flags "+noeh -DGTEST_HAS_EXCEPTIONS=0")
|
|
||||||
# RTTI can not be disabled in HP aCC compiler.
|
|
||||||
set(cxx_no_rtti_flags "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if (CMAKE_USE_PTHREADS_INIT) # The pthreads library is available and allowed.
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -DGTEST_HAS_PTHREAD=1")
|
|
||||||
else()
|
|
||||||
set(cxx_base_flags "${cxx_base_flags} -DGTEST_HAS_PTHREAD=0")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# For building gtest's own tests and samples.
|
|
||||||
set(cxx_exception "${CMAKE_CXX_FLAGS} ${cxx_base_flags} ${cxx_exception_flags}")
|
|
||||||
set(cxx_no_exception
|
|
||||||
"${CMAKE_CXX_FLAGS} ${cxx_base_flags} ${cxx_no_exception_flags}")
|
|
||||||
set(cxx_default "${cxx_exception}")
|
|
||||||
set(cxx_no_rtti "${cxx_default} ${cxx_no_rtti_flags}")
|
|
||||||
set(cxx_use_own_tuple "${cxx_default} -DGTEST_USE_OWN_TR1_TUPLE=1")
|
|
||||||
|
|
||||||
# For building the gtest libraries.
|
|
||||||
set(cxx_strict "${cxx_default} ${cxx_strict_flags}")
|
|
||||||
endmacro()
|
|
||||||
|
|
||||||
# Defines the gtest & gtest_main libraries. User tests should link
|
|
||||||
# with one of them.
|
|
||||||
function(cxx_library_with_type name type cxx_flags)
|
|
||||||
# type can be either STATIC or SHARED to denote a static or shared library.
|
|
||||||
# ARGN refers to additional arguments after 'cxx_flags'.
|
|
||||||
add_library(${name} ${type} ${ARGN})
|
|
||||||
set_target_properties(${name}
|
|
||||||
PROPERTIES
|
|
||||||
COMPILE_FLAGS "${cxx_flags}")
|
|
||||||
if (BUILD_SHARED_LIBS OR type STREQUAL "SHARED")
|
|
||||||
set_target_properties(${name}
|
|
||||||
PROPERTIES
|
|
||||||
COMPILE_DEFINITIONS "GTEST_CREATE_SHARED_LIBRARY=1")
|
|
||||||
endif()
|
|
||||||
if (CMAKE_USE_PTHREADS_INIT)
|
|
||||||
target_link_libraries(${name} ${CMAKE_THREAD_LIBS_INIT})
|
|
||||||
endif()
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
########################################################################
|
|
||||||
#
|
|
||||||
# Helper functions for creating build targets.
|
|
||||||
|
|
||||||
function(cxx_shared_library name cxx_flags)
|
|
||||||
cxx_library_with_type(${name} SHARED "${cxx_flags}" ${ARGN})
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
function(cxx_library name cxx_flags)
|
|
||||||
cxx_library_with_type(${name} "" "${cxx_flags}" ${ARGN})
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# cxx_executable_with_flags(name cxx_flags libs srcs...)
|
|
||||||
#
|
|
||||||
# creates a named C++ executable that depends on the given libraries and
|
|
||||||
# is built from the given source files with the given compiler flags.
|
|
||||||
function(cxx_executable_with_flags name cxx_flags libs)
|
|
||||||
add_executable(${name} ${ARGN})
|
|
||||||
if (cxx_flags)
|
|
||||||
set_target_properties(${name}
|
|
||||||
PROPERTIES
|
|
||||||
COMPILE_FLAGS "${cxx_flags}")
|
|
||||||
endif()
|
|
||||||
if (BUILD_SHARED_LIBS)
|
|
||||||
set_target_properties(${name}
|
|
||||||
PROPERTIES
|
|
||||||
COMPILE_DEFINITIONS "GTEST_LINKED_AS_SHARED_LIBRARY=1")
|
|
||||||
endif()
|
|
||||||
# To support mixing linking in static and dynamic libraries, link each
|
|
||||||
# library in with an extra call to target_link_libraries.
|
|
||||||
foreach (lib "${libs}")
|
|
||||||
target_link_libraries(${name} ${lib})
|
|
||||||
endforeach()
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# cxx_executable(name dir lib srcs...)
|
|
||||||
#
|
|
||||||
# creates a named target that depends on the given libs and is built
|
|
||||||
# from the given source files. dir/name.cc is implicitly included in
|
|
||||||
# the source file list.
|
|
||||||
function(cxx_executable name dir libs)
|
|
||||||
cxx_executable_with_flags(
|
|
||||||
${name} "${cxx_default}" "${libs}" "${dir}/${name}.cc" ${ARGN})
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# Sets PYTHONINTERP_FOUND and PYTHON_EXECUTABLE.
|
|
||||||
find_package(PythonInterp)
|
|
||||||
|
|
||||||
# cxx_test_with_flags(name cxx_flags libs srcs...)
|
|
||||||
#
|
|
||||||
# creates a named C++ test that depends on the given libs and is built
|
|
||||||
# from the given source files with the given compiler flags.
|
|
||||||
function(cxx_test_with_flags name cxx_flags libs)
|
|
||||||
cxx_executable_with_flags(${name} "${cxx_flags}" "${libs}" ${ARGN})
|
|
||||||
add_test(${name} ${name})
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# cxx_test(name libs srcs...)
|
|
||||||
#
|
|
||||||
# creates a named test target that depends on the given libs and is
|
|
||||||
# built from the given source files. Unlike cxx_test_with_flags,
|
|
||||||
# test/name.cc is already implicitly included in the source file list.
|
|
||||||
function(cxx_test name libs)
|
|
||||||
cxx_test_with_flags("${name}" "${cxx_default}" "${libs}"
|
|
||||||
"test/${name}.cc" ${ARGN})
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# py_test(name)
|
|
||||||
#
|
|
||||||
# creates a Python test with the given name whose main module is in
|
|
||||||
# test/name.py. It does nothing if Python is not installed.
|
|
||||||
function(py_test name)
|
|
||||||
# We are not supporting Python tests on Linux yet as they consider
|
|
||||||
# all Linux environments to be google3 and try to use google3 features.
|
|
||||||
if (PYTHONINTERP_FOUND)
|
|
||||||
# ${CMAKE_BINARY_DIR} is known at configuration time, so we can
|
|
||||||
# directly bind it from cmake. ${CTEST_CONFIGURATION_TYPE} is known
|
|
||||||
# only at ctest runtime (by calling ctest -c <Configuration>), so
|
|
||||||
# we have to escape $ to delay variable substitution here.
|
|
||||||
add_test(${name}
|
|
||||||
${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/test/${name}.py
|
|
||||||
--build_dir=${CMAKE_CURRENT_BINARY_DIR}/\${CTEST_CONFIGURATION_TYPE})
|
|
||||||
endif()
|
|
||||||
endfunction()
|
|
18386
common/protobuf-2.6.1/gtest/configure
vendored
18386
common/protobuf-2.6.1/gtest/configure
vendored
File diff suppressed because it is too large
Load Diff
@ -1,68 +0,0 @@
|
|||||||
m4_include(m4/acx_pthread.m4)
|
|
||||||
|
|
||||||
# At this point, the Xcode project assumes the version string will be three
|
|
||||||
# integers separated by periods and surrounded by square brackets (e.g.
|
|
||||||
# "[1.0.1]"). It also asumes that there won't be any closing parenthesis
|
|
||||||
# between "AC_INIT(" and the closing ")" including comments and strings.
|
|
||||||
AC_INIT([Google C++ Testing Framework],
|
|
||||||
[1.6.0],
|
|
||||||
[googletestframework@googlegroups.com],
|
|
||||||
[gtest])
|
|
||||||
|
|
||||||
# Provide various options to initialize the Autoconf and configure processes.
|
|
||||||
AC_PREREQ([2.59])
|
|
||||||
AC_CONFIG_SRCDIR([./LICENSE])
|
|
||||||
AC_CONFIG_MACRO_DIR([m4])
|
|
||||||
AC_CONFIG_AUX_DIR([build-aux])
|
|
||||||
AC_CONFIG_HEADERS([build-aux/config.h])
|
|
||||||
AC_CONFIG_FILES([Makefile])
|
|
||||||
AC_CONFIG_FILES([scripts/gtest-config], [chmod +x scripts/gtest-config])
|
|
||||||
|
|
||||||
# Initialize Automake with various options. We require at least v1.9, prevent
|
|
||||||
# pedantic complaints about package files, and enable various distribution
|
|
||||||
# targets.
|
|
||||||
AM_INIT_AUTOMAKE([1.9 dist-bzip2 dist-zip foreign subdir-objects])
|
|
||||||
|
|
||||||
# Check for programs used in building Google Test.
|
|
||||||
AC_PROG_CC
|
|
||||||
AC_PROG_CXX
|
|
||||||
AC_LANG([C++])
|
|
||||||
AC_PROG_LIBTOOL
|
|
||||||
|
|
||||||
# TODO(chandlerc@google.com): Currently we aren't running the Python tests
|
|
||||||
# against the interpreter detected by AM_PATH_PYTHON, and so we condition
|
|
||||||
# HAVE_PYTHON by requiring "python" to be in the PATH, and that interpreter's
|
|
||||||
# version to be >= 2.3. This will allow the scripts to use a "/usr/bin/env"
|
|
||||||
# hashbang.
|
|
||||||
PYTHON= # We *do not* allow the user to specify a python interpreter
|
|
||||||
AC_PATH_PROG([PYTHON],[python],[:])
|
|
||||||
AS_IF([test "$PYTHON" != ":"],
|
|
||||||
[AM_PYTHON_CHECK_VERSION([$PYTHON],[2.3],[:],[PYTHON=":"])])
|
|
||||||
AM_CONDITIONAL([HAVE_PYTHON],[test "$PYTHON" != ":"])
|
|
||||||
|
|
||||||
# Configure pthreads.
|
|
||||||
AC_ARG_WITH([pthreads],
|
|
||||||
[AS_HELP_STRING([--with-pthreads],
|
|
||||||
[use pthreads (default is yes)])],
|
|
||||||
[with_pthreads=$withval],
|
|
||||||
[with_pthreads=check])
|
|
||||||
|
|
||||||
have_pthreads=no
|
|
||||||
AS_IF([test "x$with_pthreads" != "xno"],
|
|
||||||
[ACX_PTHREAD(
|
|
||||||
[],
|
|
||||||
[AS_IF([test "x$with_pthreads" != "xcheck"],
|
|
||||||
[AC_MSG_FAILURE(
|
|
||||||
[--with-pthreads was specified, but unable to be used])])])
|
|
||||||
have_pthreads="$acx_pthread_ok"])
|
|
||||||
AM_CONDITIONAL([HAVE_PTHREADS],[test "x$have_pthreads" == "xyes"])
|
|
||||||
AC_SUBST(PTHREAD_CFLAGS)
|
|
||||||
AC_SUBST(PTHREAD_LIBS)
|
|
||||||
|
|
||||||
# TODO(chandlerc@google.com) Check for the necessary system headers.
|
|
||||||
|
|
||||||
# TODO(chandlerc@google.com) Check the types, structures, and other compiler
|
|
||||||
# and architecture characteristics.
|
|
||||||
|
|
||||||
# Output the generated files. No further autoconf macros may be used.
|
|
||||||
AC_OUTPUT
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,38 +0,0 @@
|
|||||||
// Copyright 2006, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
GTEST_API_ int main(int argc, char **argv) {
|
|
||||||
printf("Running main() from gtest_main.cc\n");
|
|
||||||
testing::InitGoogleTest(&argc, argv);
|
|
||||||
return RUN_ALL_TESTS();
|
|
||||||
}
|
|
@ -1,230 +0,0 @@
|
|||||||
// Copyright 2005, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
//
|
|
||||||
// The Google C++ Testing Framework (Google Test)
|
|
||||||
//
|
|
||||||
// This header file defines the Message class.
|
|
||||||
//
|
|
||||||
// IMPORTANT NOTE: Due to limitation of the C++ language, we have to
|
|
||||||
// leave some internal implementation details in this header file.
|
|
||||||
// They are clearly marked by comments like this:
|
|
||||||
//
|
|
||||||
// // INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
|
|
||||||
//
|
|
||||||
// Such code is NOT meant to be used by a user directly, and is subject
|
|
||||||
// to CHANGE WITHOUT NOTICE. Therefore DO NOT DEPEND ON IT in a user
|
|
||||||
// program!
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_GTEST_MESSAGE_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_GTEST_MESSAGE_H_
|
|
||||||
|
|
||||||
#include <limits>
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-string.h"
|
|
||||||
#include "gtest/internal/gtest-internal.h"
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
|
|
||||||
// The Message class works like an ostream repeater.
|
|
||||||
//
|
|
||||||
// Typical usage:
|
|
||||||
//
|
|
||||||
// 1. You stream a bunch of values to a Message object.
|
|
||||||
// It will remember the text in a stringstream.
|
|
||||||
// 2. Then you stream the Message object to an ostream.
|
|
||||||
// This causes the text in the Message to be streamed
|
|
||||||
// to the ostream.
|
|
||||||
//
|
|
||||||
// For example;
|
|
||||||
//
|
|
||||||
// testing::Message foo;
|
|
||||||
// foo << 1 << " != " << 2;
|
|
||||||
// std::cout << foo;
|
|
||||||
//
|
|
||||||
// will print "1 != 2".
|
|
||||||
//
|
|
||||||
// Message is not intended to be inherited from. In particular, its
|
|
||||||
// destructor is not virtual.
|
|
||||||
//
|
|
||||||
// Note that stringstream behaves differently in gcc and in MSVC. You
|
|
||||||
// can stream a NULL char pointer to it in the former, but not in the
|
|
||||||
// latter (it causes an access violation if you do). The Message
|
|
||||||
// class hides this difference by treating a NULL char pointer as
|
|
||||||
// "(null)".
|
|
||||||
class GTEST_API_ Message {
|
|
||||||
private:
|
|
||||||
// The type of basic IO manipulators (endl, ends, and flush) for
|
|
||||||
// narrow streams.
|
|
||||||
typedef std::ostream& (*BasicNarrowIoManip)(std::ostream&);
|
|
||||||
|
|
||||||
public:
|
|
||||||
// Constructs an empty Message.
|
|
||||||
// We allocate the stringstream separately because otherwise each use of
|
|
||||||
// ASSERT/EXPECT in a procedure adds over 200 bytes to the procedure's
|
|
||||||
// stack frame leading to huge stack frames in some cases; gcc does not reuse
|
|
||||||
// the stack space.
|
|
||||||
Message() : ss_(new ::std::stringstream) {
|
|
||||||
// By default, we want there to be enough precision when printing
|
|
||||||
// a double to a Message.
|
|
||||||
*ss_ << std::setprecision(std::numeric_limits<double>::digits10 + 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Copy constructor.
|
|
||||||
Message(const Message& msg) : ss_(new ::std::stringstream) { // NOLINT
|
|
||||||
*ss_ << msg.GetString();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Constructs a Message from a C-string.
|
|
||||||
explicit Message(const char* str) : ss_(new ::std::stringstream) {
|
|
||||||
*ss_ << str;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_OS_SYMBIAN
|
|
||||||
// Streams a value (either a pointer or not) to this object.
|
|
||||||
template <typename T>
|
|
||||||
inline Message& operator <<(const T& value) {
|
|
||||||
StreamHelper(typename internal::is_pointer<T>::type(), value);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
// Streams a non-pointer value to this object.
|
|
||||||
template <typename T>
|
|
||||||
inline Message& operator <<(const T& val) {
|
|
||||||
::GTestStreamToHelper(ss_.get(), val);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Streams a pointer value to this object.
|
|
||||||
//
|
|
||||||
// This function is an overload of the previous one. When you
|
|
||||||
// stream a pointer to a Message, this definition will be used as it
|
|
||||||
// is more specialized. (The C++ Standard, section
|
|
||||||
// [temp.func.order].) If you stream a non-pointer, then the
|
|
||||||
// previous definition will be used.
|
|
||||||
//
|
|
||||||
// The reason for this overload is that streaming a NULL pointer to
|
|
||||||
// ostream is undefined behavior. Depending on the compiler, you
|
|
||||||
// may get "0", "(nil)", "(null)", or an access violation. To
|
|
||||||
// ensure consistent result across compilers, we always treat NULL
|
|
||||||
// as "(null)".
|
|
||||||
template <typename T>
|
|
||||||
inline Message& operator <<(T* const& pointer) { // NOLINT
|
|
||||||
if (pointer == NULL) {
|
|
||||||
*ss_ << "(null)";
|
|
||||||
} else {
|
|
||||||
::GTestStreamToHelper(ss_.get(), pointer);
|
|
||||||
}
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
#endif // GTEST_OS_SYMBIAN
|
|
||||||
|
|
||||||
// Since the basic IO manipulators are overloaded for both narrow
|
|
||||||
// and wide streams, we have to provide this specialized definition
|
|
||||||
// of operator <<, even though its body is the same as the
|
|
||||||
// templatized version above. Without this definition, streaming
|
|
||||||
// endl or other basic IO manipulators to Message will confuse the
|
|
||||||
// compiler.
|
|
||||||
Message& operator <<(BasicNarrowIoManip val) {
|
|
||||||
*ss_ << val;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Instead of 1/0, we want to see true/false for bool values.
|
|
||||||
Message& operator <<(bool b) {
|
|
||||||
return *this << (b ? "true" : "false");
|
|
||||||
}
|
|
||||||
|
|
||||||
// These two overloads allow streaming a wide C string to a Message
|
|
||||||
// using the UTF-8 encoding.
|
|
||||||
Message& operator <<(const wchar_t* wide_c_str) {
|
|
||||||
return *this << internal::String::ShowWideCString(wide_c_str);
|
|
||||||
}
|
|
||||||
Message& operator <<(wchar_t* wide_c_str) {
|
|
||||||
return *this << internal::String::ShowWideCString(wide_c_str);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_HAS_STD_WSTRING
|
|
||||||
// Converts the given wide string to a narrow string using the UTF-8
|
|
||||||
// encoding, and streams the result to this Message object.
|
|
||||||
Message& operator <<(const ::std::wstring& wstr);
|
|
||||||
#endif // GTEST_HAS_STD_WSTRING
|
|
||||||
|
|
||||||
#if GTEST_HAS_GLOBAL_WSTRING
|
|
||||||
// Converts the given wide string to a narrow string using the UTF-8
|
|
||||||
// encoding, and streams the result to this Message object.
|
|
||||||
Message& operator <<(const ::wstring& wstr);
|
|
||||||
#endif // GTEST_HAS_GLOBAL_WSTRING
|
|
||||||
|
|
||||||
// Gets the text streamed to this object so far as an std::string.
|
|
||||||
// Each '\0' character in the buffer is replaced with "\\0".
|
|
||||||
//
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
|
|
||||||
std::string GetString() const {
|
|
||||||
return internal::StringStreamToString(ss_.get());
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
#if GTEST_OS_SYMBIAN
|
|
||||||
// These are needed as the Nokia Symbian Compiler cannot decide between
|
|
||||||
// const T& and const T* in a function template. The Nokia compiler _can_
|
|
||||||
// decide between class template specializations for T and T*, so a
|
|
||||||
// tr1::type_traits-like is_pointer works, and we can overload on that.
|
|
||||||
template <typename T>
|
|
||||||
inline void StreamHelper(internal::true_type /*dummy*/, T* pointer) {
|
|
||||||
if (pointer == NULL) {
|
|
||||||
*ss_ << "(null)";
|
|
||||||
} else {
|
|
||||||
::GTestStreamToHelper(ss_.get(), pointer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
template <typename T>
|
|
||||||
inline void StreamHelper(internal::false_type /*dummy*/, const T& value) {
|
|
||||||
::GTestStreamToHelper(ss_.get(), value);
|
|
||||||
}
|
|
||||||
#endif // GTEST_OS_SYMBIAN
|
|
||||||
|
|
||||||
// We'll hold the text streamed to this object here.
|
|
||||||
const internal::scoped_ptr< ::std::stringstream> ss_;
|
|
||||||
|
|
||||||
// We declare (but don't implement) this to prevent the compiler
|
|
||||||
// from implementing the assignment operator.
|
|
||||||
void operator=(const Message&);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Streams a Message to an ostream.
|
|
||||||
inline std::ostream& operator <<(std::ostream& os, const Message& sb) {
|
|
||||||
return os << sb.GetString();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_GTEST_MESSAGE_H_
|
|
File diff suppressed because it is too large
Load Diff
@ -1,487 +0,0 @@
|
|||||||
$$ -*- mode: c++; -*-
|
|
||||||
$var n = 50 $$ Maximum length of Values arguments we want to support.
|
|
||||||
$var maxtuple = 10 $$ Maximum number of Combine arguments we want to support.
|
|
||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: vladl@google.com (Vlad Losev)
|
|
||||||
//
|
|
||||||
// Macros and functions for implementing parameterized tests
|
|
||||||
// in Google C++ Testing Framework (Google Test)
|
|
||||||
//
|
|
||||||
// This file is generated by a SCRIPT. DO NOT EDIT BY HAND!
|
|
||||||
//
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_GTEST_PARAM_TEST_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_GTEST_PARAM_TEST_H_
|
|
||||||
|
|
||||||
|
|
||||||
// Value-parameterized tests allow you to test your code with different
|
|
||||||
// parameters without writing multiple copies of the same test.
|
|
||||||
//
|
|
||||||
// Here is how you use value-parameterized tests:
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
// To write value-parameterized tests, first you should define a fixture
|
|
||||||
// class. It is usually derived from testing::TestWithParam<T> (see below for
|
|
||||||
// another inheritance scheme that's sometimes useful in more complicated
|
|
||||||
// class hierarchies), where the type of your parameter values.
|
|
||||||
// TestWithParam<T> is itself derived from testing::Test. T can be any
|
|
||||||
// copyable type. If it's a raw pointer, you are responsible for managing the
|
|
||||||
// lifespan of the pointed values.
|
|
||||||
|
|
||||||
class FooTest : public ::testing::TestWithParam<const char*> {
|
|
||||||
// You can implement all the usual class fixture members here.
|
|
||||||
};
|
|
||||||
|
|
||||||
// Then, use the TEST_P macro to define as many parameterized tests
|
|
||||||
// for this fixture as you want. The _P suffix is for "parameterized"
|
|
||||||
// or "pattern", whichever you prefer to think.
|
|
||||||
|
|
||||||
TEST_P(FooTest, DoesBlah) {
|
|
||||||
// Inside a test, access the test parameter with the GetParam() method
|
|
||||||
// of the TestWithParam<T> class:
|
|
||||||
EXPECT_TRUE(foo.Blah(GetParam()));
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_P(FooTest, HasBlahBlah) {
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
// Finally, you can use INSTANTIATE_TEST_CASE_P to instantiate the test
|
|
||||||
// case with any set of parameters you want. Google Test defines a number
|
|
||||||
// of functions for generating test parameters. They return what we call
|
|
||||||
// (surprise!) parameter generators. Here is a summary of them, which
|
|
||||||
// are all in the testing namespace:
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// Range(begin, end [, step]) - Yields values {begin, begin+step,
|
|
||||||
// begin+step+step, ...}. The values do not
|
|
||||||
// include end. step defaults to 1.
|
|
||||||
// Values(v1, v2, ..., vN) - Yields values {v1, v2, ..., vN}.
|
|
||||||
// ValuesIn(container) - Yields values from a C-style array, an STL
|
|
||||||
// ValuesIn(begin,end) container, or an iterator range [begin, end).
|
|
||||||
// Bool() - Yields sequence {false, true}.
|
|
||||||
// Combine(g1, g2, ..., gN) - Yields all combinations (the Cartesian product
|
|
||||||
// for the math savvy) of the values generated
|
|
||||||
// by the N generators.
|
|
||||||
//
|
|
||||||
// For more details, see comments at the definitions of these functions below
|
|
||||||
// in this file.
|
|
||||||
//
|
|
||||||
// The following statement will instantiate tests from the FooTest test case
|
|
||||||
// each with parameter values "meeny", "miny", and "moe".
|
|
||||||
|
|
||||||
INSTANTIATE_TEST_CASE_P(InstantiationName,
|
|
||||||
FooTest,
|
|
||||||
Values("meeny", "miny", "moe"));
|
|
||||||
|
|
||||||
// To distinguish different instances of the pattern, (yes, you
|
|
||||||
// can instantiate it more then once) the first argument to the
|
|
||||||
// INSTANTIATE_TEST_CASE_P macro is a prefix that will be added to the
|
|
||||||
// actual test case name. Remember to pick unique prefixes for different
|
|
||||||
// instantiations. The tests from the instantiation above will have
|
|
||||||
// these names:
|
|
||||||
//
|
|
||||||
// * InstantiationName/FooTest.DoesBlah/0 for "meeny"
|
|
||||||
// * InstantiationName/FooTest.DoesBlah/1 for "miny"
|
|
||||||
// * InstantiationName/FooTest.DoesBlah/2 for "moe"
|
|
||||||
// * InstantiationName/FooTest.HasBlahBlah/0 for "meeny"
|
|
||||||
// * InstantiationName/FooTest.HasBlahBlah/1 for "miny"
|
|
||||||
// * InstantiationName/FooTest.HasBlahBlah/2 for "moe"
|
|
||||||
//
|
|
||||||
// You can use these names in --gtest_filter.
|
|
||||||
//
|
|
||||||
// This statement will instantiate all tests from FooTest again, each
|
|
||||||
// with parameter values "cat" and "dog":
|
|
||||||
|
|
||||||
const char* pets[] = {"cat", "dog"};
|
|
||||||
INSTANTIATE_TEST_CASE_P(AnotherInstantiationName, FooTest, ValuesIn(pets));
|
|
||||||
|
|
||||||
// The tests from the instantiation above will have these names:
|
|
||||||
//
|
|
||||||
// * AnotherInstantiationName/FooTest.DoesBlah/0 for "cat"
|
|
||||||
// * AnotherInstantiationName/FooTest.DoesBlah/1 for "dog"
|
|
||||||
// * AnotherInstantiationName/FooTest.HasBlahBlah/0 for "cat"
|
|
||||||
// * AnotherInstantiationName/FooTest.HasBlahBlah/1 for "dog"
|
|
||||||
//
|
|
||||||
// Please note that INSTANTIATE_TEST_CASE_P will instantiate all tests
|
|
||||||
// in the given test case, whether their definitions come before or
|
|
||||||
// AFTER the INSTANTIATE_TEST_CASE_P statement.
|
|
||||||
//
|
|
||||||
// Please also note that generator expressions (including parameters to the
|
|
||||||
// generators) are evaluated in InitGoogleTest(), after main() has started.
|
|
||||||
// This allows the user on one hand, to adjust generator parameters in order
|
|
||||||
// to dynamically determine a set of tests to run and on the other hand,
|
|
||||||
// give the user a chance to inspect the generated tests with Google Test
|
|
||||||
// reflection API before RUN_ALL_TESTS() is executed.
|
|
||||||
//
|
|
||||||
// You can see samples/sample7_unittest.cc and samples/sample8_unittest.cc
|
|
||||||
// for more examples.
|
|
||||||
//
|
|
||||||
// In the future, we plan to publish the API for defining new parameter
|
|
||||||
// generators. But for now this interface remains part of the internal
|
|
||||||
// implementation and is subject to change.
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// A parameterized test fixture must be derived from testing::Test and from
|
|
||||||
// testing::WithParamInterface<T>, where T is the type of the parameter
|
|
||||||
// values. Inheriting from TestWithParam<T> satisfies that requirement because
|
|
||||||
// TestWithParam<T> inherits from both Test and WithParamInterface. In more
|
|
||||||
// complicated hierarchies, however, it is occasionally useful to inherit
|
|
||||||
// separately from Test and WithParamInterface. For example:
|
|
||||||
|
|
||||||
class BaseTest : public ::testing::Test {
|
|
||||||
// You can inherit all the usual members for a non-parameterized test
|
|
||||||
// fixture here.
|
|
||||||
};
|
|
||||||
|
|
||||||
class DerivedTest : public BaseTest, public ::testing::WithParamInterface<int> {
|
|
||||||
// The usual test fixture members go here too.
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST_F(BaseTest, HasFoo) {
|
|
||||||
// This is an ordinary non-parameterized test.
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_P(DerivedTest, DoesBlah) {
|
|
||||||
// GetParam works just the same here as if you inherit from TestWithParam.
|
|
||||||
EXPECT_TRUE(foo.Blah(GetParam()));
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // 0
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
|
|
||||||
#if !GTEST_OS_SYMBIAN
|
|
||||||
# include <utility>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// scripts/fuse_gtest.py depends on gtest's own header being #included
|
|
||||||
// *unconditionally*. Therefore these #includes cannot be moved
|
|
||||||
// inside #if GTEST_HAS_PARAM_TEST.
|
|
||||||
#include "gtest/internal/gtest-internal.h"
|
|
||||||
#include "gtest/internal/gtest-param-util.h"
|
|
||||||
#include "gtest/internal/gtest-param-util-generated.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
|
|
||||||
// Functions producing parameter generators.
|
|
||||||
//
|
|
||||||
// Google Test uses these generators to produce parameters for value-
|
|
||||||
// parameterized tests. When a parameterized test case is instantiated
|
|
||||||
// with a particular generator, Google Test creates and runs tests
|
|
||||||
// for each element in the sequence produced by the generator.
|
|
||||||
//
|
|
||||||
// In the following sample, tests from test case FooTest are instantiated
|
|
||||||
// each three times with parameter values 3, 5, and 8:
|
|
||||||
//
|
|
||||||
// class FooTest : public TestWithParam<int> { ... };
|
|
||||||
//
|
|
||||||
// TEST_P(FooTest, TestThis) {
|
|
||||||
// }
|
|
||||||
// TEST_P(FooTest, TestThat) {
|
|
||||||
// }
|
|
||||||
// INSTANTIATE_TEST_CASE_P(TestSequence, FooTest, Values(3, 5, 8));
|
|
||||||
//
|
|
||||||
|
|
||||||
// Range() returns generators providing sequences of values in a range.
|
|
||||||
//
|
|
||||||
// Synopsis:
|
|
||||||
// Range(start, end)
|
|
||||||
// - returns a generator producing a sequence of values {start, start+1,
|
|
||||||
// start+2, ..., }.
|
|
||||||
// Range(start, end, step)
|
|
||||||
// - returns a generator producing a sequence of values {start, start+step,
|
|
||||||
// start+step+step, ..., }.
|
|
||||||
// Notes:
|
|
||||||
// * The generated sequences never include end. For example, Range(1, 5)
|
|
||||||
// returns a generator producing a sequence {1, 2, 3, 4}. Range(1, 9, 2)
|
|
||||||
// returns a generator producing {1, 3, 5, 7}.
|
|
||||||
// * start and end must have the same type. That type may be any integral or
|
|
||||||
// floating-point type or a user defined type satisfying these conditions:
|
|
||||||
// * It must be assignable (have operator=() defined).
|
|
||||||
// * It must have operator+() (operator+(int-compatible type) for
|
|
||||||
// two-operand version).
|
|
||||||
// * It must have operator<() defined.
|
|
||||||
// Elements in the resulting sequences will also have that type.
|
|
||||||
// * Condition start < end must be satisfied in order for resulting sequences
|
|
||||||
// to contain any elements.
|
|
||||||
//
|
|
||||||
template <typename T, typename IncrementT>
|
|
||||||
internal::ParamGenerator<T> Range(T start, T end, IncrementT step) {
|
|
||||||
return internal::ParamGenerator<T>(
|
|
||||||
new internal::RangeGenerator<T, IncrementT>(start, end, step));
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
internal::ParamGenerator<T> Range(T start, T end) {
|
|
||||||
return Range(start, end, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// ValuesIn() function allows generation of tests with parameters coming from
|
|
||||||
// a container.
|
|
||||||
//
|
|
||||||
// Synopsis:
|
|
||||||
// ValuesIn(const T (&array)[N])
|
|
||||||
// - returns a generator producing sequences with elements from
|
|
||||||
// a C-style array.
|
|
||||||
// ValuesIn(const Container& container)
|
|
||||||
// - returns a generator producing sequences with elements from
|
|
||||||
// an STL-style container.
|
|
||||||
// ValuesIn(Iterator begin, Iterator end)
|
|
||||||
// - returns a generator producing sequences with elements from
|
|
||||||
// a range [begin, end) defined by a pair of STL-style iterators. These
|
|
||||||
// iterators can also be plain C pointers.
|
|
||||||
//
|
|
||||||
// Please note that ValuesIn copies the values from the containers
|
|
||||||
// passed in and keeps them to generate tests in RUN_ALL_TESTS().
|
|
||||||
//
|
|
||||||
// Examples:
|
|
||||||
//
|
|
||||||
// This instantiates tests from test case StringTest
|
|
||||||
// each with C-string values of "foo", "bar", and "baz":
|
|
||||||
//
|
|
||||||
// const char* strings[] = {"foo", "bar", "baz"};
|
|
||||||
// INSTANTIATE_TEST_CASE_P(StringSequence, SrtingTest, ValuesIn(strings));
|
|
||||||
//
|
|
||||||
// This instantiates tests from test case StlStringTest
|
|
||||||
// each with STL strings with values "a" and "b":
|
|
||||||
//
|
|
||||||
// ::std::vector< ::std::string> GetParameterStrings() {
|
|
||||||
// ::std::vector< ::std::string> v;
|
|
||||||
// v.push_back("a");
|
|
||||||
// v.push_back("b");
|
|
||||||
// return v;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// INSTANTIATE_TEST_CASE_P(CharSequence,
|
|
||||||
// StlStringTest,
|
|
||||||
// ValuesIn(GetParameterStrings()));
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// This will also instantiate tests from CharTest
|
|
||||||
// each with parameter values 'a' and 'b':
|
|
||||||
//
|
|
||||||
// ::std::list<char> GetParameterChars() {
|
|
||||||
// ::std::list<char> list;
|
|
||||||
// list.push_back('a');
|
|
||||||
// list.push_back('b');
|
|
||||||
// return list;
|
|
||||||
// }
|
|
||||||
// ::std::list<char> l = GetParameterChars();
|
|
||||||
// INSTANTIATE_TEST_CASE_P(CharSequence2,
|
|
||||||
// CharTest,
|
|
||||||
// ValuesIn(l.begin(), l.end()));
|
|
||||||
//
|
|
||||||
template <typename ForwardIterator>
|
|
||||||
internal::ParamGenerator<
|
|
||||||
typename ::testing::internal::IteratorTraits<ForwardIterator>::value_type>
|
|
||||||
ValuesIn(ForwardIterator begin, ForwardIterator end) {
|
|
||||||
typedef typename ::testing::internal::IteratorTraits<ForwardIterator>
|
|
||||||
::value_type ParamType;
|
|
||||||
return internal::ParamGenerator<ParamType>(
|
|
||||||
new internal::ValuesInIteratorRangeGenerator<ParamType>(begin, end));
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T, size_t N>
|
|
||||||
internal::ParamGenerator<T> ValuesIn(const T (&array)[N]) {
|
|
||||||
return ValuesIn(array, array + N);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class Container>
|
|
||||||
internal::ParamGenerator<typename Container::value_type> ValuesIn(
|
|
||||||
const Container& container) {
|
|
||||||
return ValuesIn(container.begin(), container.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Values() allows generating tests from explicitly specified list of
|
|
||||||
// parameters.
|
|
||||||
//
|
|
||||||
// Synopsis:
|
|
||||||
// Values(T v1, T v2, ..., T vN)
|
|
||||||
// - returns a generator producing sequences with elements v1, v2, ..., vN.
|
|
||||||
//
|
|
||||||
// For example, this instantiates tests from test case BarTest each
|
|
||||||
// with values "one", "two", and "three":
|
|
||||||
//
|
|
||||||
// INSTANTIATE_TEST_CASE_P(NumSequence, BarTest, Values("one", "two", "three"));
|
|
||||||
//
|
|
||||||
// This instantiates tests from test case BazTest each with values 1, 2, 3.5.
|
|
||||||
// The exact type of values will depend on the type of parameter in BazTest.
|
|
||||||
//
|
|
||||||
// INSTANTIATE_TEST_CASE_P(FloatingNumbers, BazTest, Values(1, 2, 3.5));
|
|
||||||
//
|
|
||||||
// Currently, Values() supports from 1 to $n parameters.
|
|
||||||
//
|
|
||||||
$range i 1..n
|
|
||||||
$for i [[
|
|
||||||
$range j 1..i
|
|
||||||
|
|
||||||
template <$for j, [[typename T$j]]>
|
|
||||||
internal::ValueArray$i<$for j, [[T$j]]> Values($for j, [[T$j v$j]]) {
|
|
||||||
return internal::ValueArray$i<$for j, [[T$j]]>($for j, [[v$j]]);
|
|
||||||
}
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
// Bool() allows generating tests with parameters in a set of (false, true).
|
|
||||||
//
|
|
||||||
// Synopsis:
|
|
||||||
// Bool()
|
|
||||||
// - returns a generator producing sequences with elements {false, true}.
|
|
||||||
//
|
|
||||||
// It is useful when testing code that depends on Boolean flags. Combinations
|
|
||||||
// of multiple flags can be tested when several Bool()'s are combined using
|
|
||||||
// Combine() function.
|
|
||||||
//
|
|
||||||
// In the following example all tests in the test case FlagDependentTest
|
|
||||||
// will be instantiated twice with parameters false and true.
|
|
||||||
//
|
|
||||||
// class FlagDependentTest : public testing::TestWithParam<bool> {
|
|
||||||
// virtual void SetUp() {
|
|
||||||
// external_flag = GetParam();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// INSTANTIATE_TEST_CASE_P(BoolSequence, FlagDependentTest, Bool());
|
|
||||||
//
|
|
||||||
inline internal::ParamGenerator<bool> Bool() {
|
|
||||||
return Values(false, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
# if GTEST_HAS_COMBINE
|
|
||||||
// Combine() allows the user to combine two or more sequences to produce
|
|
||||||
// values of a Cartesian product of those sequences' elements.
|
|
||||||
//
|
|
||||||
// Synopsis:
|
|
||||||
// Combine(gen1, gen2, ..., genN)
|
|
||||||
// - returns a generator producing sequences with elements coming from
|
|
||||||
// the Cartesian product of elements from the sequences generated by
|
|
||||||
// gen1, gen2, ..., genN. The sequence elements will have a type of
|
|
||||||
// tuple<T1, T2, ..., TN> where T1, T2, ..., TN are the types
|
|
||||||
// of elements from sequences produces by gen1, gen2, ..., genN.
|
|
||||||
//
|
|
||||||
// Combine can have up to $maxtuple arguments. This number is currently limited
|
|
||||||
// by the maximum number of elements in the tuple implementation used by Google
|
|
||||||
// Test.
|
|
||||||
//
|
|
||||||
// Example:
|
|
||||||
//
|
|
||||||
// This will instantiate tests in test case AnimalTest each one with
|
|
||||||
// the parameter values tuple("cat", BLACK), tuple("cat", WHITE),
|
|
||||||
// tuple("dog", BLACK), and tuple("dog", WHITE):
|
|
||||||
//
|
|
||||||
// enum Color { BLACK, GRAY, WHITE };
|
|
||||||
// class AnimalTest
|
|
||||||
// : public testing::TestWithParam<tuple<const char*, Color> > {...};
|
|
||||||
//
|
|
||||||
// TEST_P(AnimalTest, AnimalLooksNice) {...}
|
|
||||||
//
|
|
||||||
// INSTANTIATE_TEST_CASE_P(AnimalVariations, AnimalTest,
|
|
||||||
// Combine(Values("cat", "dog"),
|
|
||||||
// Values(BLACK, WHITE)));
|
|
||||||
//
|
|
||||||
// This will instantiate tests in FlagDependentTest with all variations of two
|
|
||||||
// Boolean flags:
|
|
||||||
//
|
|
||||||
// class FlagDependentTest
|
|
||||||
// : public testing::TestWithParam<tuple<bool, bool> > {
|
|
||||||
// virtual void SetUp() {
|
|
||||||
// // Assigns external_flag_1 and external_flag_2 values from the tuple.
|
|
||||||
// tie(external_flag_1, external_flag_2) = GetParam();
|
|
||||||
// }
|
|
||||||
// };
|
|
||||||
//
|
|
||||||
// TEST_P(FlagDependentTest, TestFeature1) {
|
|
||||||
// // Test your code using external_flag_1 and external_flag_2 here.
|
|
||||||
// }
|
|
||||||
// INSTANTIATE_TEST_CASE_P(TwoBoolSequence, FlagDependentTest,
|
|
||||||
// Combine(Bool(), Bool()));
|
|
||||||
//
|
|
||||||
$range i 2..maxtuple
|
|
||||||
$for i [[
|
|
||||||
$range j 1..i
|
|
||||||
|
|
||||||
template <$for j, [[typename Generator$j]]>
|
|
||||||
internal::CartesianProductHolder$i<$for j, [[Generator$j]]> Combine(
|
|
||||||
$for j, [[const Generator$j& g$j]]) {
|
|
||||||
return internal::CartesianProductHolder$i<$for j, [[Generator$j]]>(
|
|
||||||
$for j, [[g$j]]);
|
|
||||||
}
|
|
||||||
|
|
||||||
]]
|
|
||||||
# endif // GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# define TEST_P(test_case_name, test_name) \
|
|
||||||
class GTEST_TEST_CLASS_NAME_(test_case_name, test_name) \
|
|
||||||
: public test_case_name { \
|
|
||||||
public: \
|
|
||||||
GTEST_TEST_CLASS_NAME_(test_case_name, test_name)() {} \
|
|
||||||
virtual void TestBody(); \
|
|
||||||
private: \
|
|
||||||
static int AddToRegistry() { \
|
|
||||||
::testing::UnitTest::GetInstance()->parameterized_test_registry(). \
|
|
||||||
GetTestCasePatternHolder<test_case_name>(\
|
|
||||||
#test_case_name, __FILE__, __LINE__)->AddTestPattern(\
|
|
||||||
#test_case_name, \
|
|
||||||
#test_name, \
|
|
||||||
new ::testing::internal::TestMetaFactory< \
|
|
||||||
GTEST_TEST_CLASS_NAME_(test_case_name, test_name)>()); \
|
|
||||||
return 0; \
|
|
||||||
} \
|
|
||||||
static int gtest_registering_dummy_; \
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(\
|
|
||||||
GTEST_TEST_CLASS_NAME_(test_case_name, test_name)); \
|
|
||||||
}; \
|
|
||||||
int GTEST_TEST_CLASS_NAME_(test_case_name, \
|
|
||||||
test_name)::gtest_registering_dummy_ = \
|
|
||||||
GTEST_TEST_CLASS_NAME_(test_case_name, test_name)::AddToRegistry(); \
|
|
||||||
void GTEST_TEST_CLASS_NAME_(test_case_name, test_name)::TestBody()
|
|
||||||
|
|
||||||
# define INSTANTIATE_TEST_CASE_P(prefix, test_case_name, generator) \
|
|
||||||
::testing::internal::ParamGenerator<test_case_name::ParamType> \
|
|
||||||
gtest_##prefix##test_case_name##_EvalGenerator_() { return generator; } \
|
|
||||||
int gtest_##prefix##test_case_name##_dummy_ = \
|
|
||||||
::testing::UnitTest::GetInstance()->parameterized_test_registry(). \
|
|
||||||
GetTestCasePatternHolder<test_case_name>(\
|
|
||||||
#test_case_name, __FILE__, __LINE__)->AddTestCaseInstantiation(\
|
|
||||||
#prefix, \
|
|
||||||
>est_##prefix##test_case_name##_EvalGenerator_, \
|
|
||||||
__FILE__, __LINE__)
|
|
||||||
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_GTEST_PARAM_TEST_H_
|
|
@ -1,855 +0,0 @@
|
|||||||
// Copyright 2007, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
|
|
||||||
// Google Test - The Google C++ Testing Framework
|
|
||||||
//
|
|
||||||
// This file implements a universal value printer that can print a
|
|
||||||
// value of any type T:
|
|
||||||
//
|
|
||||||
// void ::testing::internal::UniversalPrinter<T>::Print(value, ostream_ptr);
|
|
||||||
//
|
|
||||||
// A user can teach this function how to print a class type T by
|
|
||||||
// defining either operator<<() or PrintTo() in the namespace that
|
|
||||||
// defines T. More specifically, the FIRST defined function in the
|
|
||||||
// following list will be used (assuming T is defined in namespace
|
|
||||||
// foo):
|
|
||||||
//
|
|
||||||
// 1. foo::PrintTo(const T&, ostream*)
|
|
||||||
// 2. operator<<(ostream&, const T&) defined in either foo or the
|
|
||||||
// global namespace.
|
|
||||||
//
|
|
||||||
// If none of the above is defined, it will print the debug string of
|
|
||||||
// the value if it is a protocol buffer, or print the raw bytes in the
|
|
||||||
// value otherwise.
|
|
||||||
//
|
|
||||||
// To aid debugging: when T is a reference type, the address of the
|
|
||||||
// value is also printed; when T is a (const) char pointer, both the
|
|
||||||
// pointer value and the NUL-terminated string it points to are
|
|
||||||
// printed.
|
|
||||||
//
|
|
||||||
// We also provide some convenient wrappers:
|
|
||||||
//
|
|
||||||
// // Prints a value to a string. For a (const or not) char
|
|
||||||
// // pointer, the NUL-terminated string (but not the pointer) is
|
|
||||||
// // printed.
|
|
||||||
// std::string ::testing::PrintToString(const T& value);
|
|
||||||
//
|
|
||||||
// // Prints a value tersely: for a reference type, the referenced
|
|
||||||
// // value (but not the address) is printed; for a (const or not) char
|
|
||||||
// // pointer, the NUL-terminated string (but not the pointer) is
|
|
||||||
// // printed.
|
|
||||||
// void ::testing::internal::UniversalTersePrint(const T& value, ostream*);
|
|
||||||
//
|
|
||||||
// // Prints value using the type inferred by the compiler. The difference
|
|
||||||
// // from UniversalTersePrint() is that this function prints both the
|
|
||||||
// // pointer and the NUL-terminated string for a (const or not) char pointer.
|
|
||||||
// void ::testing::internal::UniversalPrint(const T& value, ostream*);
|
|
||||||
//
|
|
||||||
// // Prints the fields of a tuple tersely to a string vector, one
|
|
||||||
// // element for each field. Tuple support must be enabled in
|
|
||||||
// // gtest-port.h.
|
|
||||||
// std::vector<string> UniversalTersePrintTupleFieldsToStrings(
|
|
||||||
// const Tuple& value);
|
|
||||||
//
|
|
||||||
// Known limitation:
|
|
||||||
//
|
|
||||||
// The print primitives print the elements of an STL-style container
|
|
||||||
// using the compiler-inferred type of *iter where iter is a
|
|
||||||
// const_iterator of the container. When const_iterator is an input
|
|
||||||
// iterator but not a forward iterator, this inferred type may not
|
|
||||||
// match value_type, and the print output may be incorrect. In
|
|
||||||
// practice, this is rarely a problem as for most containers
|
|
||||||
// const_iterator is a forward iterator. We'll fix this if there's an
|
|
||||||
// actual need for it. Note that this fix cannot rely on value_type
|
|
||||||
// being defined as many user-defined container types don't have
|
|
||||||
// value_type.
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_GTEST_PRINTERS_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_GTEST_PRINTERS_H_
|
|
||||||
|
|
||||||
#include <ostream> // NOLINT
|
|
||||||
#include <sstream>
|
|
||||||
#include <string>
|
|
||||||
#include <utility>
|
|
||||||
#include <vector>
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
#include "gtest/internal/gtest-internal.h"
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
|
|
||||||
// Definitions in the 'internal' and 'internal2' name spaces are
|
|
||||||
// subject to change without notice. DO NOT USE THEM IN USER CODE!
|
|
||||||
namespace internal2 {
|
|
||||||
|
|
||||||
// Prints the given number of bytes in the given object to the given
|
|
||||||
// ostream.
|
|
||||||
GTEST_API_ void PrintBytesInObjectTo(const unsigned char* obj_bytes,
|
|
||||||
size_t count,
|
|
||||||
::std::ostream* os);
|
|
||||||
|
|
||||||
// For selecting which printer to use when a given type has neither <<
|
|
||||||
// nor PrintTo().
|
|
||||||
enum TypeKind {
|
|
||||||
kProtobuf, // a protobuf type
|
|
||||||
kConvertibleToInteger, // a type implicitly convertible to BiggestInt
|
|
||||||
// (e.g. a named or unnamed enum type)
|
|
||||||
kOtherType // anything else
|
|
||||||
};
|
|
||||||
|
|
||||||
// TypeWithoutFormatter<T, kTypeKind>::PrintValue(value, os) is called
|
|
||||||
// by the universal printer to print a value of type T when neither
|
|
||||||
// operator<< nor PrintTo() is defined for T, where kTypeKind is the
|
|
||||||
// "kind" of T as defined by enum TypeKind.
|
|
||||||
template <typename T, TypeKind kTypeKind>
|
|
||||||
class TypeWithoutFormatter {
|
|
||||||
public:
|
|
||||||
// This default version is called when kTypeKind is kOtherType.
|
|
||||||
static void PrintValue(const T& value, ::std::ostream* os) {
|
|
||||||
PrintBytesInObjectTo(reinterpret_cast<const unsigned char*>(&value),
|
|
||||||
sizeof(value), os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// We print a protobuf using its ShortDebugString() when the string
|
|
||||||
// doesn't exceed this many characters; otherwise we print it using
|
|
||||||
// DebugString() for better readability.
|
|
||||||
const size_t kProtobufOneLinerMaxLength = 50;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
class TypeWithoutFormatter<T, kProtobuf> {
|
|
||||||
public:
|
|
||||||
static void PrintValue(const T& value, ::std::ostream* os) {
|
|
||||||
const ::testing::internal::string short_str = value.ShortDebugString();
|
|
||||||
const ::testing::internal::string pretty_str =
|
|
||||||
short_str.length() <= kProtobufOneLinerMaxLength ?
|
|
||||||
short_str : ("\n" + value.DebugString());
|
|
||||||
*os << ("<" + pretty_str + ">");
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
class TypeWithoutFormatter<T, kConvertibleToInteger> {
|
|
||||||
public:
|
|
||||||
// Since T has no << operator or PrintTo() but can be implicitly
|
|
||||||
// converted to BiggestInt, we print it as a BiggestInt.
|
|
||||||
//
|
|
||||||
// Most likely T is an enum type (either named or unnamed), in which
|
|
||||||
// case printing it as an integer is the desired behavior. In case
|
|
||||||
// T is not an enum, printing it as an integer is the best we can do
|
|
||||||
// given that it has no user-defined printer.
|
|
||||||
static void PrintValue(const T& value, ::std::ostream* os) {
|
|
||||||
const internal::BiggestInt kBigInt = value;
|
|
||||||
*os << kBigInt;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Prints the given value to the given ostream. If the value is a
|
|
||||||
// protocol message, its debug string is printed; if it's an enum or
|
|
||||||
// of a type implicitly convertible to BiggestInt, it's printed as an
|
|
||||||
// integer; otherwise the bytes in the value are printed. This is
|
|
||||||
// what UniversalPrinter<T>::Print() does when it knows nothing about
|
|
||||||
// type T and T has neither << operator nor PrintTo().
|
|
||||||
//
|
|
||||||
// A user can override this behavior for a class type Foo by defining
|
|
||||||
// a << operator in the namespace where Foo is defined.
|
|
||||||
//
|
|
||||||
// We put this operator in namespace 'internal2' instead of 'internal'
|
|
||||||
// to simplify the implementation, as much code in 'internal' needs to
|
|
||||||
// use << in STL, which would conflict with our own << were it defined
|
|
||||||
// in 'internal'.
|
|
||||||
//
|
|
||||||
// Note that this operator<< takes a generic std::basic_ostream<Char,
|
|
||||||
// CharTraits> type instead of the more restricted std::ostream. If
|
|
||||||
// we define it to take an std::ostream instead, we'll get an
|
|
||||||
// "ambiguous overloads" compiler error when trying to print a type
|
|
||||||
// Foo that supports streaming to std::basic_ostream<Char,
|
|
||||||
// CharTraits>, as the compiler cannot tell whether
|
|
||||||
// operator<<(std::ostream&, const T&) or
|
|
||||||
// operator<<(std::basic_stream<Char, CharTraits>, const Foo&) is more
|
|
||||||
// specific.
|
|
||||||
template <typename Char, typename CharTraits, typename T>
|
|
||||||
::std::basic_ostream<Char, CharTraits>& operator<<(
|
|
||||||
::std::basic_ostream<Char, CharTraits>& os, const T& x) {
|
|
||||||
TypeWithoutFormatter<T,
|
|
||||||
(internal::IsAProtocolMessage<T>::value ? kProtobuf :
|
|
||||||
internal::ImplicitlyConvertible<const T&, internal::BiggestInt>::value ?
|
|
||||||
kConvertibleToInteger : kOtherType)>::PrintValue(x, &os);
|
|
||||||
return os;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace internal2
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
// This namespace MUST NOT BE NESTED IN ::testing, or the name look-up
|
|
||||||
// magic needed for implementing UniversalPrinter won't work.
|
|
||||||
namespace testing_internal {
|
|
||||||
|
|
||||||
// Used to print a value that is not an STL-style container when the
|
|
||||||
// user doesn't define PrintTo() for it.
|
|
||||||
template <typename T>
|
|
||||||
void DefaultPrintNonContainerTo(const T& value, ::std::ostream* os) {
|
|
||||||
// With the following statement, during unqualified name lookup,
|
|
||||||
// testing::internal2::operator<< appears as if it was declared in
|
|
||||||
// the nearest enclosing namespace that contains both
|
|
||||||
// ::testing_internal and ::testing::internal2, i.e. the global
|
|
||||||
// namespace. For more details, refer to the C++ Standard section
|
|
||||||
// 7.3.4-1 [namespace.udir]. This allows us to fall back onto
|
|
||||||
// testing::internal2::operator<< in case T doesn't come with a <<
|
|
||||||
// operator.
|
|
||||||
//
|
|
||||||
// We cannot write 'using ::testing::internal2::operator<<;', which
|
|
||||||
// gcc 3.3 fails to compile due to a compiler bug.
|
|
||||||
using namespace ::testing::internal2; // NOLINT
|
|
||||||
|
|
||||||
// Assuming T is defined in namespace foo, in the next statement,
|
|
||||||
// the compiler will consider all of:
|
|
||||||
//
|
|
||||||
// 1. foo::operator<< (thanks to Koenig look-up),
|
|
||||||
// 2. ::operator<< (as the current namespace is enclosed in ::),
|
|
||||||
// 3. testing::internal2::operator<< (thanks to the using statement above).
|
|
||||||
//
|
|
||||||
// The operator<< whose type matches T best will be picked.
|
|
||||||
//
|
|
||||||
// We deliberately allow #2 to be a candidate, as sometimes it's
|
|
||||||
// impossible to define #1 (e.g. when foo is ::std, defining
|
|
||||||
// anything in it is undefined behavior unless you are a compiler
|
|
||||||
// vendor.).
|
|
||||||
*os << value;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace testing_internal
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// UniversalPrinter<T>::Print(value, ostream_ptr) prints the given
|
|
||||||
// value to the given ostream. The caller must ensure that
|
|
||||||
// 'ostream_ptr' is not NULL, or the behavior is undefined.
|
|
||||||
//
|
|
||||||
// We define UniversalPrinter as a class template (as opposed to a
|
|
||||||
// function template), as we need to partially specialize it for
|
|
||||||
// reference types, which cannot be done with function templates.
|
|
||||||
template <typename T>
|
|
||||||
class UniversalPrinter;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
void UniversalPrint(const T& value, ::std::ostream* os);
|
|
||||||
|
|
||||||
// Used to print an STL-style container when the user doesn't define
|
|
||||||
// a PrintTo() for it.
|
|
||||||
template <typename C>
|
|
||||||
void DefaultPrintTo(IsContainer /* dummy */,
|
|
||||||
false_type /* is not a pointer */,
|
|
||||||
const C& container, ::std::ostream* os) {
|
|
||||||
const size_t kMaxCount = 32; // The maximum number of elements to print.
|
|
||||||
*os << '{';
|
|
||||||
size_t count = 0;
|
|
||||||
for (typename C::const_iterator it = container.begin();
|
|
||||||
it != container.end(); ++it, ++count) {
|
|
||||||
if (count > 0) {
|
|
||||||
*os << ',';
|
|
||||||
if (count == kMaxCount) { // Enough has been printed.
|
|
||||||
*os << " ...";
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*os << ' ';
|
|
||||||
// We cannot call PrintTo(*it, os) here as PrintTo() doesn't
|
|
||||||
// handle *it being a native array.
|
|
||||||
internal::UniversalPrint(*it, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (count > 0) {
|
|
||||||
*os << ' ';
|
|
||||||
}
|
|
||||||
*os << '}';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Used to print a pointer that is neither a char pointer nor a member
|
|
||||||
// pointer, when the user doesn't define PrintTo() for it. (A member
|
|
||||||
// variable pointer or member function pointer doesn't really point to
|
|
||||||
// a location in the address space. Their representation is
|
|
||||||
// implementation-defined. Therefore they will be printed as raw
|
|
||||||
// bytes.)
|
|
||||||
template <typename T>
|
|
||||||
void DefaultPrintTo(IsNotContainer /* dummy */,
|
|
||||||
true_type /* is a pointer */,
|
|
||||||
T* p, ::std::ostream* os) {
|
|
||||||
if (p == NULL) {
|
|
||||||
*os << "NULL";
|
|
||||||
} else {
|
|
||||||
// C++ doesn't allow casting from a function pointer to any object
|
|
||||||
// pointer.
|
|
||||||
//
|
|
||||||
// IsTrue() silences warnings: "Condition is always true",
|
|
||||||
// "unreachable code".
|
|
||||||
if (IsTrue(ImplicitlyConvertible<T*, const void*>::value)) {
|
|
||||||
// T is not a function type. We just call << to print p,
|
|
||||||
// relying on ADL to pick up user-defined << for their pointer
|
|
||||||
// types, if any.
|
|
||||||
*os << p;
|
|
||||||
} else {
|
|
||||||
// T is a function type, so '*os << p' doesn't do what we want
|
|
||||||
// (it just prints p as bool). We want to print p as a const
|
|
||||||
// void*. However, we cannot cast it to const void* directly,
|
|
||||||
// even using reinterpret_cast, as earlier versions of gcc
|
|
||||||
// (e.g. 3.4.5) cannot compile the cast when p is a function
|
|
||||||
// pointer. Casting to UInt64 first solves the problem.
|
|
||||||
*os << reinterpret_cast<const void*>(
|
|
||||||
reinterpret_cast<internal::UInt64>(p));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Used to print a non-container, non-pointer value when the user
|
|
||||||
// doesn't define PrintTo() for it.
|
|
||||||
template <typename T>
|
|
||||||
void DefaultPrintTo(IsNotContainer /* dummy */,
|
|
||||||
false_type /* is not a pointer */,
|
|
||||||
const T& value, ::std::ostream* os) {
|
|
||||||
::testing_internal::DefaultPrintNonContainerTo(value, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prints the given value using the << operator if it has one;
|
|
||||||
// otherwise prints the bytes in it. This is what
|
|
||||||
// UniversalPrinter<T>::Print() does when PrintTo() is not specialized
|
|
||||||
// or overloaded for type T.
|
|
||||||
//
|
|
||||||
// A user can override this behavior for a class type Foo by defining
|
|
||||||
// an overload of PrintTo() in the namespace where Foo is defined. We
|
|
||||||
// give the user this option as sometimes defining a << operator for
|
|
||||||
// Foo is not desirable (e.g. the coding style may prevent doing it,
|
|
||||||
// or there is already a << operator but it doesn't do what the user
|
|
||||||
// wants).
|
|
||||||
template <typename T>
|
|
||||||
void PrintTo(const T& value, ::std::ostream* os) {
|
|
||||||
// DefaultPrintTo() is overloaded. The type of its first two
|
|
||||||
// arguments determine which version will be picked. If T is an
|
|
||||||
// STL-style container, the version for container will be called; if
|
|
||||||
// T is a pointer, the pointer version will be called; otherwise the
|
|
||||||
// generic version will be called.
|
|
||||||
//
|
|
||||||
// Note that we check for container types here, prior to we check
|
|
||||||
// for protocol message types in our operator<<. The rationale is:
|
|
||||||
//
|
|
||||||
// For protocol messages, we want to give people a chance to
|
|
||||||
// override Google Mock's format by defining a PrintTo() or
|
|
||||||
// operator<<. For STL containers, other formats can be
|
|
||||||
// incompatible with Google Mock's format for the container
|
|
||||||
// elements; therefore we check for container types here to ensure
|
|
||||||
// that our format is used.
|
|
||||||
//
|
|
||||||
// The second argument of DefaultPrintTo() is needed to bypass a bug
|
|
||||||
// in Symbian's C++ compiler that prevents it from picking the right
|
|
||||||
// overload between:
|
|
||||||
//
|
|
||||||
// PrintTo(const T& x, ...);
|
|
||||||
// PrintTo(T* x, ...);
|
|
||||||
DefaultPrintTo(IsContainerTest<T>(0), is_pointer<T>(), value, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// The following list of PrintTo() overloads tells
|
|
||||||
// UniversalPrinter<T>::Print() how to print standard types (built-in
|
|
||||||
// types, strings, plain arrays, and pointers).
|
|
||||||
|
|
||||||
// Overloads for various char types.
|
|
||||||
GTEST_API_ void PrintTo(unsigned char c, ::std::ostream* os);
|
|
||||||
GTEST_API_ void PrintTo(signed char c, ::std::ostream* os);
|
|
||||||
inline void PrintTo(char c, ::std::ostream* os) {
|
|
||||||
// When printing a plain char, we always treat it as unsigned. This
|
|
||||||
// way, the output won't be affected by whether the compiler thinks
|
|
||||||
// char is signed or not.
|
|
||||||
PrintTo(static_cast<unsigned char>(c), os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Overloads for other simple built-in types.
|
|
||||||
inline void PrintTo(bool x, ::std::ostream* os) {
|
|
||||||
*os << (x ? "true" : "false");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Overload for wchar_t type.
|
|
||||||
// Prints a wchar_t as a symbol if it is printable or as its internal
|
|
||||||
// code otherwise and also as its decimal code (except for L'\0').
|
|
||||||
// The L'\0' char is printed as "L'\\0'". The decimal code is printed
|
|
||||||
// as signed integer when wchar_t is implemented by the compiler
|
|
||||||
// as a signed type and is printed as an unsigned integer when wchar_t
|
|
||||||
// is implemented as an unsigned type.
|
|
||||||
GTEST_API_ void PrintTo(wchar_t wc, ::std::ostream* os);
|
|
||||||
|
|
||||||
// Overloads for C strings.
|
|
||||||
GTEST_API_ void PrintTo(const char* s, ::std::ostream* os);
|
|
||||||
inline void PrintTo(char* s, ::std::ostream* os) {
|
|
||||||
PrintTo(ImplicitCast_<const char*>(s), os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// signed/unsigned char is often used for representing binary data, so
|
|
||||||
// we print pointers to it as void* to be safe.
|
|
||||||
inline void PrintTo(const signed char* s, ::std::ostream* os) {
|
|
||||||
PrintTo(ImplicitCast_<const void*>(s), os);
|
|
||||||
}
|
|
||||||
inline void PrintTo(signed char* s, ::std::ostream* os) {
|
|
||||||
PrintTo(ImplicitCast_<const void*>(s), os);
|
|
||||||
}
|
|
||||||
inline void PrintTo(const unsigned char* s, ::std::ostream* os) {
|
|
||||||
PrintTo(ImplicitCast_<const void*>(s), os);
|
|
||||||
}
|
|
||||||
inline void PrintTo(unsigned char* s, ::std::ostream* os) {
|
|
||||||
PrintTo(ImplicitCast_<const void*>(s), os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// MSVC can be configured to define wchar_t as a typedef of unsigned
|
|
||||||
// short. It defines _NATIVE_WCHAR_T_DEFINED when wchar_t is a native
|
|
||||||
// type. When wchar_t is a typedef, defining an overload for const
|
|
||||||
// wchar_t* would cause unsigned short* be printed as a wide string,
|
|
||||||
// possibly causing invalid memory accesses.
|
|
||||||
#if !defined(_MSC_VER) || defined(_NATIVE_WCHAR_T_DEFINED)
|
|
||||||
// Overloads for wide C strings
|
|
||||||
GTEST_API_ void PrintTo(const wchar_t* s, ::std::ostream* os);
|
|
||||||
inline void PrintTo(wchar_t* s, ::std::ostream* os) {
|
|
||||||
PrintTo(ImplicitCast_<const wchar_t*>(s), os);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Overload for C arrays. Multi-dimensional arrays are printed
|
|
||||||
// properly.
|
|
||||||
|
|
||||||
// Prints the given number of elements in an array, without printing
|
|
||||||
// the curly braces.
|
|
||||||
template <typename T>
|
|
||||||
void PrintRawArrayTo(const T a[], size_t count, ::std::ostream* os) {
|
|
||||||
UniversalPrint(a[0], os);
|
|
||||||
for (size_t i = 1; i != count; i++) {
|
|
||||||
*os << ", ";
|
|
||||||
UniversalPrint(a[i], os);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Overloads for ::string and ::std::string.
|
|
||||||
#if GTEST_HAS_GLOBAL_STRING
|
|
||||||
GTEST_API_ void PrintStringTo(const ::string&s, ::std::ostream* os);
|
|
||||||
inline void PrintTo(const ::string& s, ::std::ostream* os) {
|
|
||||||
PrintStringTo(s, os);
|
|
||||||
}
|
|
||||||
#endif // GTEST_HAS_GLOBAL_STRING
|
|
||||||
|
|
||||||
GTEST_API_ void PrintStringTo(const ::std::string&s, ::std::ostream* os);
|
|
||||||
inline void PrintTo(const ::std::string& s, ::std::ostream* os) {
|
|
||||||
PrintStringTo(s, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Overloads for ::wstring and ::std::wstring.
|
|
||||||
#if GTEST_HAS_GLOBAL_WSTRING
|
|
||||||
GTEST_API_ void PrintWideStringTo(const ::wstring&s, ::std::ostream* os);
|
|
||||||
inline void PrintTo(const ::wstring& s, ::std::ostream* os) {
|
|
||||||
PrintWideStringTo(s, os);
|
|
||||||
}
|
|
||||||
#endif // GTEST_HAS_GLOBAL_WSTRING
|
|
||||||
|
|
||||||
#if GTEST_HAS_STD_WSTRING
|
|
||||||
GTEST_API_ void PrintWideStringTo(const ::std::wstring&s, ::std::ostream* os);
|
|
||||||
inline void PrintTo(const ::std::wstring& s, ::std::ostream* os) {
|
|
||||||
PrintWideStringTo(s, os);
|
|
||||||
}
|
|
||||||
#endif // GTEST_HAS_STD_WSTRING
|
|
||||||
|
|
||||||
#if GTEST_HAS_TR1_TUPLE
|
|
||||||
// Overload for ::std::tr1::tuple. Needed for printing function arguments,
|
|
||||||
// which are packed as tuples.
|
|
||||||
|
|
||||||
// Helper function for printing a tuple. T must be instantiated with
|
|
||||||
// a tuple type.
|
|
||||||
template <typename T>
|
|
||||||
void PrintTupleTo(const T& t, ::std::ostream* os);
|
|
||||||
|
|
||||||
// Overloaded PrintTo() for tuples of various arities. We support
|
|
||||||
// tuples of up-to 10 fields. The following implementation works
|
|
||||||
// regardless of whether tr1::tuple is implemented using the
|
|
||||||
// non-standard variadic template feature or not.
|
|
||||||
|
|
||||||
inline void PrintTo(const ::std::tr1::tuple<>& t, ::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1>& t, ::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2>& t, ::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3>& t, ::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4>& t, ::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5>& t,
|
|
||||||
::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
|
||||||
typename T6>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6>& t,
|
|
||||||
::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
|
||||||
typename T6, typename T7>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7>& t,
|
|
||||||
::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
|
||||||
typename T6, typename T7, typename T8>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8>& t,
|
|
||||||
::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
|
||||||
typename T6, typename T7, typename T8, typename T9>
|
|
||||||
void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9>& t,
|
|
||||||
::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
|
||||||
typename T6, typename T7, typename T8, typename T9, typename T10>
|
|
||||||
void PrintTo(
|
|
||||||
const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>& t,
|
|
||||||
::std::ostream* os) {
|
|
||||||
PrintTupleTo(t, os);
|
|
||||||
}
|
|
||||||
#endif // GTEST_HAS_TR1_TUPLE
|
|
||||||
|
|
||||||
// Overload for std::pair.
|
|
||||||
template <typename T1, typename T2>
|
|
||||||
void PrintTo(const ::std::pair<T1, T2>& value, ::std::ostream* os) {
|
|
||||||
*os << '(';
|
|
||||||
// We cannot use UniversalPrint(value.first, os) here, as T1 may be
|
|
||||||
// a reference type. The same for printing value.second.
|
|
||||||
UniversalPrinter<T1>::Print(value.first, os);
|
|
||||||
*os << ", ";
|
|
||||||
UniversalPrinter<T2>::Print(value.second, os);
|
|
||||||
*os << ')';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Implements printing a non-reference type T by letting the compiler
|
|
||||||
// pick the right overload of PrintTo() for T.
|
|
||||||
template <typename T>
|
|
||||||
class UniversalPrinter {
|
|
||||||
public:
|
|
||||||
// MSVC warns about adding const to a function type, so we want to
|
|
||||||
// disable the warning.
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
# pragma warning(push) // Saves the current warning state.
|
|
||||||
# pragma warning(disable:4180) // Temporarily disables warning 4180.
|
|
||||||
#endif // _MSC_VER
|
|
||||||
|
|
||||||
// Note: we deliberately don't call this PrintTo(), as that name
|
|
||||||
// conflicts with ::testing::internal::PrintTo in the body of the
|
|
||||||
// function.
|
|
||||||
static void Print(const T& value, ::std::ostream* os) {
|
|
||||||
// By default, ::testing::internal::PrintTo() is used for printing
|
|
||||||
// the value.
|
|
||||||
//
|
|
||||||
// Thanks to Koenig look-up, if T is a class and has its own
|
|
||||||
// PrintTo() function defined in its namespace, that function will
|
|
||||||
// be visible here. Since it is more specific than the generic ones
|
|
||||||
// in ::testing::internal, it will be picked by the compiler in the
|
|
||||||
// following statement - exactly what we want.
|
|
||||||
PrintTo(value, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
# pragma warning(pop) // Restores the warning state.
|
|
||||||
#endif // _MSC_VER
|
|
||||||
};
|
|
||||||
|
|
||||||
// UniversalPrintArray(begin, len, os) prints an array of 'len'
|
|
||||||
// elements, starting at address 'begin'.
|
|
||||||
template <typename T>
|
|
||||||
void UniversalPrintArray(const T* begin, size_t len, ::std::ostream* os) {
|
|
||||||
if (len == 0) {
|
|
||||||
*os << "{}";
|
|
||||||
} else {
|
|
||||||
*os << "{ ";
|
|
||||||
const size_t kThreshold = 18;
|
|
||||||
const size_t kChunkSize = 8;
|
|
||||||
// If the array has more than kThreshold elements, we'll have to
|
|
||||||
// omit some details by printing only the first and the last
|
|
||||||
// kChunkSize elements.
|
|
||||||
// TODO(wan@google.com): let the user control the threshold using a flag.
|
|
||||||
if (len <= kThreshold) {
|
|
||||||
PrintRawArrayTo(begin, len, os);
|
|
||||||
} else {
|
|
||||||
PrintRawArrayTo(begin, kChunkSize, os);
|
|
||||||
*os << ", ..., ";
|
|
||||||
PrintRawArrayTo(begin + len - kChunkSize, kChunkSize, os);
|
|
||||||
}
|
|
||||||
*os << " }";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// This overload prints a (const) char array compactly.
|
|
||||||
GTEST_API_ void UniversalPrintArray(
|
|
||||||
const char* begin, size_t len, ::std::ostream* os);
|
|
||||||
|
|
||||||
// This overload prints a (const) wchar_t array compactly.
|
|
||||||
GTEST_API_ void UniversalPrintArray(
|
|
||||||
const wchar_t* begin, size_t len, ::std::ostream* os);
|
|
||||||
|
|
||||||
// Implements printing an array type T[N].
|
|
||||||
template <typename T, size_t N>
|
|
||||||
class UniversalPrinter<T[N]> {
|
|
||||||
public:
|
|
||||||
// Prints the given array, omitting some elements when there are too
|
|
||||||
// many.
|
|
||||||
static void Print(const T (&a)[N], ::std::ostream* os) {
|
|
||||||
UniversalPrintArray(a, N, os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Implements printing a reference type T&.
|
|
||||||
template <typename T>
|
|
||||||
class UniversalPrinter<T&> {
|
|
||||||
public:
|
|
||||||
// MSVC warns about adding const to a function type, so we want to
|
|
||||||
// disable the warning.
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
# pragma warning(push) // Saves the current warning state.
|
|
||||||
# pragma warning(disable:4180) // Temporarily disables warning 4180.
|
|
||||||
#endif // _MSC_VER
|
|
||||||
|
|
||||||
static void Print(const T& value, ::std::ostream* os) {
|
|
||||||
// Prints the address of the value. We use reinterpret_cast here
|
|
||||||
// as static_cast doesn't compile when T is a function type.
|
|
||||||
*os << "@" << reinterpret_cast<const void*>(&value) << " ";
|
|
||||||
|
|
||||||
// Then prints the value itself.
|
|
||||||
UniversalPrint(value, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
# pragma warning(pop) // Restores the warning state.
|
|
||||||
#endif // _MSC_VER
|
|
||||||
};
|
|
||||||
|
|
||||||
// Prints a value tersely: for a reference type, the referenced value
|
|
||||||
// (but not the address) is printed; for a (const) char pointer, the
|
|
||||||
// NUL-terminated string (but not the pointer) is printed.
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
class UniversalTersePrinter {
|
|
||||||
public:
|
|
||||||
static void Print(const T& value, ::std::ostream* os) {
|
|
||||||
UniversalPrint(value, os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
template <typename T>
|
|
||||||
class UniversalTersePrinter<T&> {
|
|
||||||
public:
|
|
||||||
static void Print(const T& value, ::std::ostream* os) {
|
|
||||||
UniversalPrint(value, os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
template <typename T, size_t N>
|
|
||||||
class UniversalTersePrinter<T[N]> {
|
|
||||||
public:
|
|
||||||
static void Print(const T (&value)[N], ::std::ostream* os) {
|
|
||||||
UniversalPrinter<T[N]>::Print(value, os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
template <>
|
|
||||||
class UniversalTersePrinter<const char*> {
|
|
||||||
public:
|
|
||||||
static void Print(const char* str, ::std::ostream* os) {
|
|
||||||
if (str == NULL) {
|
|
||||||
*os << "NULL";
|
|
||||||
} else {
|
|
||||||
UniversalPrint(string(str), os);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
template <>
|
|
||||||
class UniversalTersePrinter<char*> {
|
|
||||||
public:
|
|
||||||
static void Print(char* str, ::std::ostream* os) {
|
|
||||||
UniversalTersePrinter<const char*>::Print(str, os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
#if GTEST_HAS_STD_WSTRING
|
|
||||||
template <>
|
|
||||||
class UniversalTersePrinter<const wchar_t*> {
|
|
||||||
public:
|
|
||||||
static void Print(const wchar_t* str, ::std::ostream* os) {
|
|
||||||
if (str == NULL) {
|
|
||||||
*os << "NULL";
|
|
||||||
} else {
|
|
||||||
UniversalPrint(::std::wstring(str), os);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
template <>
|
|
||||||
class UniversalTersePrinter<wchar_t*> {
|
|
||||||
public:
|
|
||||||
static void Print(wchar_t* str, ::std::ostream* os) {
|
|
||||||
UniversalTersePrinter<const wchar_t*>::Print(str, os);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
void UniversalTersePrint(const T& value, ::std::ostream* os) {
|
|
||||||
UniversalTersePrinter<T>::Print(value, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prints a value using the type inferred by the compiler. The
|
|
||||||
// difference between this and UniversalTersePrint() is that for a
|
|
||||||
// (const) char pointer, this prints both the pointer and the
|
|
||||||
// NUL-terminated string.
|
|
||||||
template <typename T>
|
|
||||||
void UniversalPrint(const T& value, ::std::ostream* os) {
|
|
||||||
// A workarond for the bug in VC++ 7.1 that prevents us from instantiating
|
|
||||||
// UniversalPrinter with T directly.
|
|
||||||
typedef T T1;
|
|
||||||
UniversalPrinter<T1>::Print(value, os);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_HAS_TR1_TUPLE
|
|
||||||
typedef ::std::vector<string> Strings;
|
|
||||||
|
|
||||||
// This helper template allows PrintTo() for tuples and
|
|
||||||
// UniversalTersePrintTupleFieldsToStrings() to be defined by
|
|
||||||
// induction on the number of tuple fields. The idea is that
|
|
||||||
// TuplePrefixPrinter<N>::PrintPrefixTo(t, os) prints the first N
|
|
||||||
// fields in tuple t, and can be defined in terms of
|
|
||||||
// TuplePrefixPrinter<N - 1>.
|
|
||||||
|
|
||||||
// The inductive case.
|
|
||||||
template <size_t N>
|
|
||||||
struct TuplePrefixPrinter {
|
|
||||||
// Prints the first N fields of a tuple.
|
|
||||||
template <typename Tuple>
|
|
||||||
static void PrintPrefixTo(const Tuple& t, ::std::ostream* os) {
|
|
||||||
TuplePrefixPrinter<N - 1>::PrintPrefixTo(t, os);
|
|
||||||
*os << ", ";
|
|
||||||
UniversalPrinter<typename ::std::tr1::tuple_element<N - 1, Tuple>::type>
|
|
||||||
::Print(::std::tr1::get<N - 1>(t), os);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tersely prints the first N fields of a tuple to a string vector,
|
|
||||||
// one element for each field.
|
|
||||||
template <typename Tuple>
|
|
||||||
static void TersePrintPrefixToStrings(const Tuple& t, Strings* strings) {
|
|
||||||
TuplePrefixPrinter<N - 1>::TersePrintPrefixToStrings(t, strings);
|
|
||||||
::std::stringstream ss;
|
|
||||||
UniversalTersePrint(::std::tr1::get<N - 1>(t), &ss);
|
|
||||||
strings->push_back(ss.str());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Base cases.
|
|
||||||
template <>
|
|
||||||
struct TuplePrefixPrinter<0> {
|
|
||||||
template <typename Tuple>
|
|
||||||
static void PrintPrefixTo(const Tuple&, ::std::ostream*) {}
|
|
||||||
|
|
||||||
template <typename Tuple>
|
|
||||||
static void TersePrintPrefixToStrings(const Tuple&, Strings*) {}
|
|
||||||
};
|
|
||||||
// We have to specialize the entire TuplePrefixPrinter<> class
|
|
||||||
// template here, even though the definition of
|
|
||||||
// TersePrintPrefixToStrings() is the same as the generic version, as
|
|
||||||
// Embarcadero (formerly CodeGear, formerly Borland) C++ doesn't
|
|
||||||
// support specializing a method template of a class template.
|
|
||||||
template <>
|
|
||||||
struct TuplePrefixPrinter<1> {
|
|
||||||
template <typename Tuple>
|
|
||||||
static void PrintPrefixTo(const Tuple& t, ::std::ostream* os) {
|
|
||||||
UniversalPrinter<typename ::std::tr1::tuple_element<0, Tuple>::type>::
|
|
||||||
Print(::std::tr1::get<0>(t), os);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename Tuple>
|
|
||||||
static void TersePrintPrefixToStrings(const Tuple& t, Strings* strings) {
|
|
||||||
::std::stringstream ss;
|
|
||||||
UniversalTersePrint(::std::tr1::get<0>(t), &ss);
|
|
||||||
strings->push_back(ss.str());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Helper function for printing a tuple. T must be instantiated with
|
|
||||||
// a tuple type.
|
|
||||||
template <typename T>
|
|
||||||
void PrintTupleTo(const T& t, ::std::ostream* os) {
|
|
||||||
*os << "(";
|
|
||||||
TuplePrefixPrinter< ::std::tr1::tuple_size<T>::value>::
|
|
||||||
PrintPrefixTo(t, os);
|
|
||||||
*os << ")";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prints the fields of a tuple tersely to a string vector, one
|
|
||||||
// element for each field. See the comment before
|
|
||||||
// UniversalTersePrint() for how we define "tersely".
|
|
||||||
template <typename Tuple>
|
|
||||||
Strings UniversalTersePrintTupleFieldsToStrings(const Tuple& value) {
|
|
||||||
Strings result;
|
|
||||||
TuplePrefixPrinter< ::std::tr1::tuple_size<Tuple>::value>::
|
|
||||||
TersePrintPrefixToStrings(value, &result);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
#endif // GTEST_HAS_TR1_TUPLE
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
::std::string PrintToString(const T& value) {
|
|
||||||
::std::stringstream ss;
|
|
||||||
internal::UniversalTersePrinter<T>::Print(value, &ss);
|
|
||||||
return ss.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_GTEST_PRINTERS_H_
|
|
@ -1,259 +0,0 @@
|
|||||||
// Copyright 2008 Google Inc.
|
|
||||||
// All Rights Reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_
|
|
||||||
|
|
||||||
// This header implements typed tests and type-parameterized tests.
|
|
||||||
|
|
||||||
// Typed (aka type-driven) tests repeat the same test for types in a
|
|
||||||
// list. You must know which types you want to test with when writing
|
|
||||||
// typed tests. Here's how you do it:
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
// First, define a fixture class template. It should be parameterized
|
|
||||||
// by a type. Remember to derive it from testing::Test.
|
|
||||||
template <typename T>
|
|
||||||
class FooTest : public testing::Test {
|
|
||||||
public:
|
|
||||||
...
|
|
||||||
typedef std::list<T> List;
|
|
||||||
static T shared_;
|
|
||||||
T value_;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Next, associate a list of types with the test case, which will be
|
|
||||||
// repeated for each type in the list. The typedef is necessary for
|
|
||||||
// the macro to parse correctly.
|
|
||||||
typedef testing::Types<char, int, unsigned int> MyTypes;
|
|
||||||
TYPED_TEST_CASE(FooTest, MyTypes);
|
|
||||||
|
|
||||||
// If the type list contains only one type, you can write that type
|
|
||||||
// directly without Types<...>:
|
|
||||||
// TYPED_TEST_CASE(FooTest, int);
|
|
||||||
|
|
||||||
// Then, use TYPED_TEST() instead of TEST_F() to define as many typed
|
|
||||||
// tests for this test case as you want.
|
|
||||||
TYPED_TEST(FooTest, DoesBlah) {
|
|
||||||
// Inside a test, refer to TypeParam to get the type parameter.
|
|
||||||
// Since we are inside a derived class template, C++ requires use to
|
|
||||||
// visit the members of FooTest via 'this'.
|
|
||||||
TypeParam n = this->value_;
|
|
||||||
|
|
||||||
// To visit static members of the fixture, add the TestFixture::
|
|
||||||
// prefix.
|
|
||||||
n += TestFixture::shared_;
|
|
||||||
|
|
||||||
// To refer to typedefs in the fixture, add the "typename
|
|
||||||
// TestFixture::" prefix.
|
|
||||||
typename TestFixture::List values;
|
|
||||||
values.push_back(n);
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
TYPED_TEST(FooTest, HasPropertyA) { ... }
|
|
||||||
|
|
||||||
#endif // 0
|
|
||||||
|
|
||||||
// Type-parameterized tests are abstract test patterns parameterized
|
|
||||||
// by a type. Compared with typed tests, type-parameterized tests
|
|
||||||
// allow you to define the test pattern without knowing what the type
|
|
||||||
// parameters are. The defined pattern can be instantiated with
|
|
||||||
// different types any number of times, in any number of translation
|
|
||||||
// units.
|
|
||||||
//
|
|
||||||
// If you are designing an interface or concept, you can define a
|
|
||||||
// suite of type-parameterized tests to verify properties that any
|
|
||||||
// valid implementation of the interface/concept should have. Then,
|
|
||||||
// each implementation can easily instantiate the test suite to verify
|
|
||||||
// that it conforms to the requirements, without having to write
|
|
||||||
// similar tests repeatedly. Here's an example:
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
// First, define a fixture class template. It should be parameterized
|
|
||||||
// by a type. Remember to derive it from testing::Test.
|
|
||||||
template <typename T>
|
|
||||||
class FooTest : public testing::Test {
|
|
||||||
...
|
|
||||||
};
|
|
||||||
|
|
||||||
// Next, declare that you will define a type-parameterized test case
|
|
||||||
// (the _P suffix is for "parameterized" or "pattern", whichever you
|
|
||||||
// prefer):
|
|
||||||
TYPED_TEST_CASE_P(FooTest);
|
|
||||||
|
|
||||||
// Then, use TYPED_TEST_P() to define as many type-parameterized tests
|
|
||||||
// for this type-parameterized test case as you want.
|
|
||||||
TYPED_TEST_P(FooTest, DoesBlah) {
|
|
||||||
// Inside a test, refer to TypeParam to get the type parameter.
|
|
||||||
TypeParam n = 0;
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
TYPED_TEST_P(FooTest, HasPropertyA) { ... }
|
|
||||||
|
|
||||||
// Now the tricky part: you need to register all test patterns before
|
|
||||||
// you can instantiate them. The first argument of the macro is the
|
|
||||||
// test case name; the rest are the names of the tests in this test
|
|
||||||
// case.
|
|
||||||
REGISTER_TYPED_TEST_CASE_P(FooTest,
|
|
||||||
DoesBlah, HasPropertyA);
|
|
||||||
|
|
||||||
// Finally, you are free to instantiate the pattern with the types you
|
|
||||||
// want. If you put the above code in a header file, you can #include
|
|
||||||
// it in multiple C++ source files and instantiate it multiple times.
|
|
||||||
//
|
|
||||||
// To distinguish different instances of the pattern, the first
|
|
||||||
// argument to the INSTANTIATE_* macro is a prefix that will be added
|
|
||||||
// to the actual test case name. Remember to pick unique prefixes for
|
|
||||||
// different instances.
|
|
||||||
typedef testing::Types<char, int, unsigned int> MyTypes;
|
|
||||||
INSTANTIATE_TYPED_TEST_CASE_P(My, FooTest, MyTypes);
|
|
||||||
|
|
||||||
// If the type list contains only one type, you can write that type
|
|
||||||
// directly without Types<...>:
|
|
||||||
// INSTANTIATE_TYPED_TEST_CASE_P(My, FooTest, int);
|
|
||||||
|
|
||||||
#endif // 0
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
#include "gtest/internal/gtest-type-util.h"
|
|
||||||
|
|
||||||
// Implements typed tests.
|
|
||||||
|
|
||||||
#if GTEST_HAS_TYPED_TEST
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Expands to the name of the typedef for the type parameters of the
|
|
||||||
// given test case.
|
|
||||||
# define GTEST_TYPE_PARAMS_(TestCaseName) gtest_type_params_##TestCaseName##_
|
|
||||||
|
|
||||||
// The 'Types' template argument below must have spaces around it
|
|
||||||
// since some compilers may choke on '>>' when passing a template
|
|
||||||
// instance (e.g. Types<int>)
|
|
||||||
# define TYPED_TEST_CASE(CaseName, Types) \
|
|
||||||
typedef ::testing::internal::TypeList< Types >::type \
|
|
||||||
GTEST_TYPE_PARAMS_(CaseName)
|
|
||||||
|
|
||||||
# define TYPED_TEST(CaseName, TestName) \
|
|
||||||
template <typename gtest_TypeParam_> \
|
|
||||||
class GTEST_TEST_CLASS_NAME_(CaseName, TestName) \
|
|
||||||
: public CaseName<gtest_TypeParam_> { \
|
|
||||||
private: \
|
|
||||||
typedef CaseName<gtest_TypeParam_> TestFixture; \
|
|
||||||
typedef gtest_TypeParam_ TypeParam; \
|
|
||||||
virtual void TestBody(); \
|
|
||||||
}; \
|
|
||||||
bool gtest_##CaseName##_##TestName##_registered_ GTEST_ATTRIBUTE_UNUSED_ = \
|
|
||||||
::testing::internal::TypeParameterizedTest< \
|
|
||||||
CaseName, \
|
|
||||||
::testing::internal::TemplateSel< \
|
|
||||||
GTEST_TEST_CLASS_NAME_(CaseName, TestName)>, \
|
|
||||||
GTEST_TYPE_PARAMS_(CaseName)>::Register(\
|
|
||||||
"", #CaseName, #TestName, 0); \
|
|
||||||
template <typename gtest_TypeParam_> \
|
|
||||||
void GTEST_TEST_CLASS_NAME_(CaseName, TestName)<gtest_TypeParam_>::TestBody()
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_TYPED_TEST
|
|
||||||
|
|
||||||
// Implements type-parameterized tests.
|
|
||||||
|
|
||||||
#if GTEST_HAS_TYPED_TEST_P
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Expands to the namespace name that the type-parameterized tests for
|
|
||||||
// the given type-parameterized test case are defined in. The exact
|
|
||||||
// name of the namespace is subject to change without notice.
|
|
||||||
# define GTEST_CASE_NAMESPACE_(TestCaseName) \
|
|
||||||
gtest_case_##TestCaseName##_
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Expands to the name of the variable used to remember the names of
|
|
||||||
// the defined tests in the given test case.
|
|
||||||
# define GTEST_TYPED_TEST_CASE_P_STATE_(TestCaseName) \
|
|
||||||
gtest_typed_test_case_p_state_##TestCaseName##_
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE DIRECTLY.
|
|
||||||
//
|
|
||||||
// Expands to the name of the variable used to remember the names of
|
|
||||||
// the registered tests in the given test case.
|
|
||||||
# define GTEST_REGISTERED_TEST_NAMES_(TestCaseName) \
|
|
||||||
gtest_registered_test_names_##TestCaseName##_
|
|
||||||
|
|
||||||
// The variables defined in the type-parameterized test macros are
|
|
||||||
// static as typically these macros are used in a .h file that can be
|
|
||||||
// #included in multiple translation units linked together.
|
|
||||||
# define TYPED_TEST_CASE_P(CaseName) \
|
|
||||||
static ::testing::internal::TypedTestCasePState \
|
|
||||||
GTEST_TYPED_TEST_CASE_P_STATE_(CaseName)
|
|
||||||
|
|
||||||
# define TYPED_TEST_P(CaseName, TestName) \
|
|
||||||
namespace GTEST_CASE_NAMESPACE_(CaseName) { \
|
|
||||||
template <typename gtest_TypeParam_> \
|
|
||||||
class TestName : public CaseName<gtest_TypeParam_> { \
|
|
||||||
private: \
|
|
||||||
typedef CaseName<gtest_TypeParam_> TestFixture; \
|
|
||||||
typedef gtest_TypeParam_ TypeParam; \
|
|
||||||
virtual void TestBody(); \
|
|
||||||
}; \
|
|
||||||
static bool gtest_##TestName##_defined_ GTEST_ATTRIBUTE_UNUSED_ = \
|
|
||||||
GTEST_TYPED_TEST_CASE_P_STATE_(CaseName).AddTestName(\
|
|
||||||
__FILE__, __LINE__, #CaseName, #TestName); \
|
|
||||||
} \
|
|
||||||
template <typename gtest_TypeParam_> \
|
|
||||||
void GTEST_CASE_NAMESPACE_(CaseName)::TestName<gtest_TypeParam_>::TestBody()
|
|
||||||
|
|
||||||
# define REGISTER_TYPED_TEST_CASE_P(CaseName, ...) \
|
|
||||||
namespace GTEST_CASE_NAMESPACE_(CaseName) { \
|
|
||||||
typedef ::testing::internal::Templates<__VA_ARGS__>::type gtest_AllTests_; \
|
|
||||||
} \
|
|
||||||
static const char* const GTEST_REGISTERED_TEST_NAMES_(CaseName) = \
|
|
||||||
GTEST_TYPED_TEST_CASE_P_STATE_(CaseName).VerifyRegisteredTestNames(\
|
|
||||||
__FILE__, __LINE__, #__VA_ARGS__)
|
|
||||||
|
|
||||||
// The 'Types' template argument below must have spaces around it
|
|
||||||
// since some compilers may choke on '>>' when passing a template
|
|
||||||
// instance (e.g. Types<int>)
|
|
||||||
# define INSTANTIATE_TYPED_TEST_CASE_P(Prefix, CaseName, Types) \
|
|
||||||
bool gtest_##Prefix##_##CaseName GTEST_ATTRIBUTE_UNUSED_ = \
|
|
||||||
::testing::internal::TypeParameterizedTestCase<CaseName, \
|
|
||||||
GTEST_CASE_NAMESPACE_(CaseName)::gtest_AllTests_, \
|
|
||||||
::testing::internal::TypeList< Types >::type>::Register(\
|
|
||||||
#Prefix, #CaseName, GTEST_REGISTERED_TEST_NAMES_(CaseName))
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_TYPED_TEST_P
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_GTEST_TYPED_TEST_H_
|
|
File diff suppressed because it is too large
Load Diff
@ -1,319 +0,0 @@
|
|||||||
// Copyright 2005, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: wan@google.com (Zhanyong Wan), eefacm@gmail.com (Sean Mcafee)
|
|
||||||
//
|
|
||||||
// The Google C++ Testing Framework (Google Test)
|
|
||||||
//
|
|
||||||
// This header file defines internal utilities needed for implementing
|
|
||||||
// death tests. They are subject to change without notice.
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_DEATH_TEST_INTERNAL_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_DEATH_TEST_INTERNAL_H_
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-internal.h"
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
GTEST_DECLARE_string_(internal_run_death_test);
|
|
||||||
|
|
||||||
// Names of the flags (needed for parsing Google Test flags).
|
|
||||||
const char kDeathTestStyleFlag[] = "death_test_style";
|
|
||||||
const char kDeathTestUseFork[] = "death_test_use_fork";
|
|
||||||
const char kInternalRunDeathTestFlag[] = "internal_run_death_test";
|
|
||||||
|
|
||||||
#if GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
// DeathTest is a class that hides much of the complexity of the
|
|
||||||
// GTEST_DEATH_TEST_ macro. It is abstract; its static Create method
|
|
||||||
// returns a concrete class that depends on the prevailing death test
|
|
||||||
// style, as defined by the --gtest_death_test_style and/or
|
|
||||||
// --gtest_internal_run_death_test flags.
|
|
||||||
|
|
||||||
// In describing the results of death tests, these terms are used with
|
|
||||||
// the corresponding definitions:
|
|
||||||
//
|
|
||||||
// exit status: The integer exit information in the format specified
|
|
||||||
// by wait(2)
|
|
||||||
// exit code: The integer code passed to exit(3), _exit(2), or
|
|
||||||
// returned from main()
|
|
||||||
class GTEST_API_ DeathTest {
|
|
||||||
public:
|
|
||||||
// Create returns false if there was an error determining the
|
|
||||||
// appropriate action to take for the current death test; for example,
|
|
||||||
// if the gtest_death_test_style flag is set to an invalid value.
|
|
||||||
// The LastMessage method will return a more detailed message in that
|
|
||||||
// case. Otherwise, the DeathTest pointer pointed to by the "test"
|
|
||||||
// argument is set. If the death test should be skipped, the pointer
|
|
||||||
// is set to NULL; otherwise, it is set to the address of a new concrete
|
|
||||||
// DeathTest object that controls the execution of the current test.
|
|
||||||
static bool Create(const char* statement, const RE* regex,
|
|
||||||
const char* file, int line, DeathTest** test);
|
|
||||||
DeathTest();
|
|
||||||
virtual ~DeathTest() { }
|
|
||||||
|
|
||||||
// A helper class that aborts a death test when it's deleted.
|
|
||||||
class ReturnSentinel {
|
|
||||||
public:
|
|
||||||
explicit ReturnSentinel(DeathTest* test) : test_(test) { }
|
|
||||||
~ReturnSentinel() { test_->Abort(TEST_ENCOUNTERED_RETURN_STATEMENT); }
|
|
||||||
private:
|
|
||||||
DeathTest* const test_;
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(ReturnSentinel);
|
|
||||||
} GTEST_ATTRIBUTE_UNUSED_;
|
|
||||||
|
|
||||||
// An enumeration of possible roles that may be taken when a death
|
|
||||||
// test is encountered. EXECUTE means that the death test logic should
|
|
||||||
// be executed immediately. OVERSEE means that the program should prepare
|
|
||||||
// the appropriate environment for a child process to execute the death
|
|
||||||
// test, then wait for it to complete.
|
|
||||||
enum TestRole { OVERSEE_TEST, EXECUTE_TEST };
|
|
||||||
|
|
||||||
// An enumeration of the three reasons that a test might be aborted.
|
|
||||||
enum AbortReason {
|
|
||||||
TEST_ENCOUNTERED_RETURN_STATEMENT,
|
|
||||||
TEST_THREW_EXCEPTION,
|
|
||||||
TEST_DID_NOT_DIE
|
|
||||||
};
|
|
||||||
|
|
||||||
// Assumes one of the above roles.
|
|
||||||
virtual TestRole AssumeRole() = 0;
|
|
||||||
|
|
||||||
// Waits for the death test to finish and returns its status.
|
|
||||||
virtual int Wait() = 0;
|
|
||||||
|
|
||||||
// Returns true if the death test passed; that is, the test process
|
|
||||||
// exited during the test, its exit status matches a user-supplied
|
|
||||||
// predicate, and its stderr output matches a user-supplied regular
|
|
||||||
// expression.
|
|
||||||
// The user-supplied predicate may be a macro expression rather
|
|
||||||
// than a function pointer or functor, or else Wait and Passed could
|
|
||||||
// be combined.
|
|
||||||
virtual bool Passed(bool exit_status_ok) = 0;
|
|
||||||
|
|
||||||
// Signals that the death test did not die as expected.
|
|
||||||
virtual void Abort(AbortReason reason) = 0;
|
|
||||||
|
|
||||||
// Returns a human-readable outcome message regarding the outcome of
|
|
||||||
// the last death test.
|
|
||||||
static const char* LastMessage();
|
|
||||||
|
|
||||||
static void set_last_death_test_message(const std::string& message);
|
|
||||||
|
|
||||||
private:
|
|
||||||
// A string containing a description of the outcome of the last death test.
|
|
||||||
static std::string last_death_test_message_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(DeathTest);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Factory interface for death tests. May be mocked out for testing.
|
|
||||||
class DeathTestFactory {
|
|
||||||
public:
|
|
||||||
virtual ~DeathTestFactory() { }
|
|
||||||
virtual bool Create(const char* statement, const RE* regex,
|
|
||||||
const char* file, int line, DeathTest** test) = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
// A concrete DeathTestFactory implementation for normal use.
|
|
||||||
class DefaultDeathTestFactory : public DeathTestFactory {
|
|
||||||
public:
|
|
||||||
virtual bool Create(const char* statement, const RE* regex,
|
|
||||||
const char* file, int line, DeathTest** test);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Returns true if exit_status describes a process that was terminated
|
|
||||||
// by a signal, or exited normally with a nonzero exit code.
|
|
||||||
GTEST_API_ bool ExitedUnsuccessfully(int exit_status);
|
|
||||||
|
|
||||||
// Traps C++ exceptions escaping statement and reports them as test
|
|
||||||
// failures. Note that trapping SEH exceptions is not implemented here.
|
|
||||||
# if GTEST_HAS_EXCEPTIONS
|
|
||||||
# define GTEST_EXECUTE_DEATH_TEST_STATEMENT_(statement, death_test) \
|
|
||||||
try { \
|
|
||||||
GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
|
|
||||||
} catch (const ::std::exception& gtest_exception) { \
|
|
||||||
fprintf(\
|
|
||||||
stderr, \
|
|
||||||
"\n%s: Caught std::exception-derived exception escaping the " \
|
|
||||||
"death test statement. Exception message: %s\n", \
|
|
||||||
::testing::internal::FormatFileLocation(__FILE__, __LINE__).c_str(), \
|
|
||||||
gtest_exception.what()); \
|
|
||||||
fflush(stderr); \
|
|
||||||
death_test->Abort(::testing::internal::DeathTest::TEST_THREW_EXCEPTION); \
|
|
||||||
} catch (...) { \
|
|
||||||
death_test->Abort(::testing::internal::DeathTest::TEST_THREW_EXCEPTION); \
|
|
||||||
}
|
|
||||||
|
|
||||||
# else
|
|
||||||
# define GTEST_EXECUTE_DEATH_TEST_STATEMENT_(statement, death_test) \
|
|
||||||
GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement)
|
|
||||||
|
|
||||||
# endif
|
|
||||||
|
|
||||||
// This macro is for implementing ASSERT_DEATH*, EXPECT_DEATH*,
|
|
||||||
// ASSERT_EXIT*, and EXPECT_EXIT*.
|
|
||||||
# define GTEST_DEATH_TEST_(statement, predicate, regex, fail) \
|
|
||||||
GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
|
|
||||||
if (::testing::internal::AlwaysTrue()) { \
|
|
||||||
const ::testing::internal::RE& gtest_regex = (regex); \
|
|
||||||
::testing::internal::DeathTest* gtest_dt; \
|
|
||||||
if (!::testing::internal::DeathTest::Create(#statement, >est_regex, \
|
|
||||||
__FILE__, __LINE__, >est_dt)) { \
|
|
||||||
goto GTEST_CONCAT_TOKEN_(gtest_label_, __LINE__); \
|
|
||||||
} \
|
|
||||||
if (gtest_dt != NULL) { \
|
|
||||||
::testing::internal::scoped_ptr< ::testing::internal::DeathTest> \
|
|
||||||
gtest_dt_ptr(gtest_dt); \
|
|
||||||
switch (gtest_dt->AssumeRole()) { \
|
|
||||||
case ::testing::internal::DeathTest::OVERSEE_TEST: \
|
|
||||||
if (!gtest_dt->Passed(predicate(gtest_dt->Wait()))) { \
|
|
||||||
goto GTEST_CONCAT_TOKEN_(gtest_label_, __LINE__); \
|
|
||||||
} \
|
|
||||||
break; \
|
|
||||||
case ::testing::internal::DeathTest::EXECUTE_TEST: { \
|
|
||||||
::testing::internal::DeathTest::ReturnSentinel \
|
|
||||||
gtest_sentinel(gtest_dt); \
|
|
||||||
GTEST_EXECUTE_DEATH_TEST_STATEMENT_(statement, gtest_dt); \
|
|
||||||
gtest_dt->Abort(::testing::internal::DeathTest::TEST_DID_NOT_DIE); \
|
|
||||||
break; \
|
|
||||||
} \
|
|
||||||
default: \
|
|
||||||
break; \
|
|
||||||
} \
|
|
||||||
} \
|
|
||||||
} else \
|
|
||||||
GTEST_CONCAT_TOKEN_(gtest_label_, __LINE__): \
|
|
||||||
fail(::testing::internal::DeathTest::LastMessage())
|
|
||||||
// The symbol "fail" here expands to something into which a message
|
|
||||||
// can be streamed.
|
|
||||||
|
|
||||||
// This macro is for implementing ASSERT/EXPECT_DEBUG_DEATH when compiled in
|
|
||||||
// NDEBUG mode. In this case we need the statements to be executed, the regex is
|
|
||||||
// ignored, and the macro must accept a streamed message even though the message
|
|
||||||
// is never printed.
|
|
||||||
# define GTEST_EXECUTE_STATEMENT_(statement, regex) \
|
|
||||||
GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
|
|
||||||
if (::testing::internal::AlwaysTrue()) { \
|
|
||||||
GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
|
|
||||||
} else \
|
|
||||||
::testing::Message()
|
|
||||||
|
|
||||||
// A class representing the parsed contents of the
|
|
||||||
// --gtest_internal_run_death_test flag, as it existed when
|
|
||||||
// RUN_ALL_TESTS was called.
|
|
||||||
class InternalRunDeathTestFlag {
|
|
||||||
public:
|
|
||||||
InternalRunDeathTestFlag(const std::string& a_file,
|
|
||||||
int a_line,
|
|
||||||
int an_index,
|
|
||||||
int a_write_fd)
|
|
||||||
: file_(a_file), line_(a_line), index_(an_index),
|
|
||||||
write_fd_(a_write_fd) {}
|
|
||||||
|
|
||||||
~InternalRunDeathTestFlag() {
|
|
||||||
if (write_fd_ >= 0)
|
|
||||||
posix::Close(write_fd_);
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::string& file() const { return file_; }
|
|
||||||
int line() const { return line_; }
|
|
||||||
int index() const { return index_; }
|
|
||||||
int write_fd() const { return write_fd_; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::string file_;
|
|
||||||
int line_;
|
|
||||||
int index_;
|
|
||||||
int write_fd_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(InternalRunDeathTestFlag);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Returns a newly created InternalRunDeathTestFlag object with fields
|
|
||||||
// initialized from the GTEST_FLAG(internal_run_death_test) flag if
|
|
||||||
// the flag is specified; otherwise returns NULL.
|
|
||||||
InternalRunDeathTestFlag* ParseInternalRunDeathTestFlag();
|
|
||||||
|
|
||||||
#else // GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
// This macro is used for implementing macros such as
|
|
||||||
// EXPECT_DEATH_IF_SUPPORTED and ASSERT_DEATH_IF_SUPPORTED on systems where
|
|
||||||
// death tests are not supported. Those macros must compile on such systems
|
|
||||||
// iff EXPECT_DEATH and ASSERT_DEATH compile with the same parameters on
|
|
||||||
// systems that support death tests. This allows one to write such a macro
|
|
||||||
// on a system that does not support death tests and be sure that it will
|
|
||||||
// compile on a death-test supporting system.
|
|
||||||
//
|
|
||||||
// Parameters:
|
|
||||||
// statement - A statement that a macro such as EXPECT_DEATH would test
|
|
||||||
// for program termination. This macro has to make sure this
|
|
||||||
// statement is compiled but not executed, to ensure that
|
|
||||||
// EXPECT_DEATH_IF_SUPPORTED compiles with a certain
|
|
||||||
// parameter iff EXPECT_DEATH compiles with it.
|
|
||||||
// regex - A regex that a macro such as EXPECT_DEATH would use to test
|
|
||||||
// the output of statement. This parameter has to be
|
|
||||||
// compiled but not evaluated by this macro, to ensure that
|
|
||||||
// this macro only accepts expressions that a macro such as
|
|
||||||
// EXPECT_DEATH would accept.
|
|
||||||
// terminator - Must be an empty statement for EXPECT_DEATH_IF_SUPPORTED
|
|
||||||
// and a return statement for ASSERT_DEATH_IF_SUPPORTED.
|
|
||||||
// This ensures that ASSERT_DEATH_IF_SUPPORTED will not
|
|
||||||
// compile inside functions where ASSERT_DEATH doesn't
|
|
||||||
// compile.
|
|
||||||
//
|
|
||||||
// The branch that has an always false condition is used to ensure that
|
|
||||||
// statement and regex are compiled (and thus syntactically correct) but
|
|
||||||
// never executed. The unreachable code macro protects the terminator
|
|
||||||
// statement from generating an 'unreachable code' warning in case
|
|
||||||
// statement unconditionally returns or throws. The Message constructor at
|
|
||||||
// the end allows the syntax of streaming additional messages into the
|
|
||||||
// macro, for compilational compatibility with EXPECT_DEATH/ASSERT_DEATH.
|
|
||||||
# define GTEST_UNSUPPORTED_DEATH_TEST_(statement, regex, terminator) \
|
|
||||||
GTEST_AMBIGUOUS_ELSE_BLOCKER_ \
|
|
||||||
if (::testing::internal::AlwaysTrue()) { \
|
|
||||||
GTEST_LOG_(WARNING) \
|
|
||||||
<< "Death tests are not supported on this platform.\n" \
|
|
||||||
<< "Statement '" #statement "' cannot be verified."; \
|
|
||||||
} else if (::testing::internal::AlwaysFalse()) { \
|
|
||||||
::testing::internal::RE::PartialMatch(".*", (regex)); \
|
|
||||||
GTEST_SUPPRESS_UNREACHABLE_CODE_WARNING_BELOW_(statement); \
|
|
||||||
terminator; \
|
|
||||||
} else \
|
|
||||||
::testing::Message()
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_DEATH_TEST_INTERNAL_H_
|
|
File diff suppressed because it is too large
Load Diff
@ -1,233 +0,0 @@
|
|||||||
// Copyright 2003 Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: Dan Egnor (egnor@google.com)
|
|
||||||
//
|
|
||||||
// A "smart" pointer type with reference tracking. Every pointer to a
|
|
||||||
// particular object is kept on a circular linked list. When the last pointer
|
|
||||||
// to an object is destroyed or reassigned, the object is deleted.
|
|
||||||
//
|
|
||||||
// Used properly, this deletes the object when the last reference goes away.
|
|
||||||
// There are several caveats:
|
|
||||||
// - Like all reference counting schemes, cycles lead to leaks.
|
|
||||||
// - Each smart pointer is actually two pointers (8 bytes instead of 4).
|
|
||||||
// - Every time a pointer is assigned, the entire list of pointers to that
|
|
||||||
// object is traversed. This class is therefore NOT SUITABLE when there
|
|
||||||
// will often be more than two or three pointers to a particular object.
|
|
||||||
// - References are only tracked as long as linked_ptr<> objects are copied.
|
|
||||||
// If a linked_ptr<> is converted to a raw pointer and back, BAD THINGS
|
|
||||||
// will happen (double deletion).
|
|
||||||
//
|
|
||||||
// A good use of this class is storing object references in STL containers.
|
|
||||||
// You can safely put linked_ptr<> in a vector<>.
|
|
||||||
// Other uses may not be as good.
|
|
||||||
//
|
|
||||||
// Note: If you use an incomplete type with linked_ptr<>, the class
|
|
||||||
// *containing* linked_ptr<> must have a constructor and destructor (even
|
|
||||||
// if they do nothing!).
|
|
||||||
//
|
|
||||||
// Bill Gibbons suggested we use something like this.
|
|
||||||
//
|
|
||||||
// Thread Safety:
|
|
||||||
// Unlike other linked_ptr implementations, in this implementation
|
|
||||||
// a linked_ptr object is thread-safe in the sense that:
|
|
||||||
// - it's safe to copy linked_ptr objects concurrently,
|
|
||||||
// - it's safe to copy *from* a linked_ptr and read its underlying
|
|
||||||
// raw pointer (e.g. via get()) concurrently, and
|
|
||||||
// - it's safe to write to two linked_ptrs that point to the same
|
|
||||||
// shared object concurrently.
|
|
||||||
// TODO(wan@google.com): rename this to safe_linked_ptr to avoid
|
|
||||||
// confusion with normal linked_ptr.
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_LINKED_PTR_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_LINKED_PTR_H_
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <assert.h>
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// Protects copying of all linked_ptr objects.
|
|
||||||
GTEST_API_ GTEST_DECLARE_STATIC_MUTEX_(g_linked_ptr_mutex);
|
|
||||||
|
|
||||||
// This is used internally by all instances of linked_ptr<>. It needs to be
|
|
||||||
// a non-template class because different types of linked_ptr<> can refer to
|
|
||||||
// the same object (linked_ptr<Superclass>(obj) vs linked_ptr<Subclass>(obj)).
|
|
||||||
// So, it needs to be possible for different types of linked_ptr to participate
|
|
||||||
// in the same circular linked list, so we need a single class type here.
|
|
||||||
//
|
|
||||||
// DO NOT USE THIS CLASS DIRECTLY YOURSELF. Use linked_ptr<T>.
|
|
||||||
class linked_ptr_internal {
|
|
||||||
public:
|
|
||||||
// Create a new circle that includes only this instance.
|
|
||||||
void join_new() {
|
|
||||||
next_ = this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Many linked_ptr operations may change p.link_ for some linked_ptr
|
|
||||||
// variable p in the same circle as this object. Therefore we need
|
|
||||||
// to prevent two such operations from occurring concurrently.
|
|
||||||
//
|
|
||||||
// Note that different types of linked_ptr objects can coexist in a
|
|
||||||
// circle (e.g. linked_ptr<Base>, linked_ptr<Derived1>, and
|
|
||||||
// linked_ptr<Derived2>). Therefore we must use a single mutex to
|
|
||||||
// protect all linked_ptr objects. This can create serious
|
|
||||||
// contention in production code, but is acceptable in a testing
|
|
||||||
// framework.
|
|
||||||
|
|
||||||
// Join an existing circle.
|
|
||||||
void join(linked_ptr_internal const* ptr)
|
|
||||||
GTEST_LOCK_EXCLUDED_(g_linked_ptr_mutex) {
|
|
||||||
MutexLock lock(&g_linked_ptr_mutex);
|
|
||||||
|
|
||||||
linked_ptr_internal const* p = ptr;
|
|
||||||
while (p->next_ != ptr) p = p->next_;
|
|
||||||
p->next_ = this;
|
|
||||||
next_ = ptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Leave whatever circle we're part of. Returns true if we were the
|
|
||||||
// last member of the circle. Once this is done, you can join() another.
|
|
||||||
bool depart()
|
|
||||||
GTEST_LOCK_EXCLUDED_(g_linked_ptr_mutex) {
|
|
||||||
MutexLock lock(&g_linked_ptr_mutex);
|
|
||||||
|
|
||||||
if (next_ == this) return true;
|
|
||||||
linked_ptr_internal const* p = next_;
|
|
||||||
while (p->next_ != this) p = p->next_;
|
|
||||||
p->next_ = next_;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
mutable linked_ptr_internal const* next_;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
class linked_ptr {
|
|
||||||
public:
|
|
||||||
typedef T element_type;
|
|
||||||
|
|
||||||
// Take over ownership of a raw pointer. This should happen as soon as
|
|
||||||
// possible after the object is created.
|
|
||||||
explicit linked_ptr(T* ptr = NULL) { capture(ptr); }
|
|
||||||
~linked_ptr() { depart(); }
|
|
||||||
|
|
||||||
// Copy an existing linked_ptr<>, adding ourselves to the list of references.
|
|
||||||
template <typename U> linked_ptr(linked_ptr<U> const& ptr) { copy(&ptr); }
|
|
||||||
linked_ptr(linked_ptr const& ptr) { // NOLINT
|
|
||||||
assert(&ptr != this);
|
|
||||||
copy(&ptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Assignment releases the old value and acquires the new.
|
|
||||||
template <typename U> linked_ptr& operator=(linked_ptr<U> const& ptr) {
|
|
||||||
depart();
|
|
||||||
copy(&ptr);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
linked_ptr& operator=(linked_ptr const& ptr) {
|
|
||||||
if (&ptr != this) {
|
|
||||||
depart();
|
|
||||||
copy(&ptr);
|
|
||||||
}
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Smart pointer members.
|
|
||||||
void reset(T* ptr = NULL) {
|
|
||||||
depart();
|
|
||||||
capture(ptr);
|
|
||||||
}
|
|
||||||
T* get() const { return value_; }
|
|
||||||
T* operator->() const { return value_; }
|
|
||||||
T& operator*() const { return *value_; }
|
|
||||||
|
|
||||||
bool operator==(T* p) const { return value_ == p; }
|
|
||||||
bool operator!=(T* p) const { return value_ != p; }
|
|
||||||
template <typename U>
|
|
||||||
bool operator==(linked_ptr<U> const& ptr) const {
|
|
||||||
return value_ == ptr.get();
|
|
||||||
}
|
|
||||||
template <typename U>
|
|
||||||
bool operator!=(linked_ptr<U> const& ptr) const {
|
|
||||||
return value_ != ptr.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
template <typename U>
|
|
||||||
friend class linked_ptr;
|
|
||||||
|
|
||||||
T* value_;
|
|
||||||
linked_ptr_internal link_;
|
|
||||||
|
|
||||||
void depart() {
|
|
||||||
if (link_.depart()) delete value_;
|
|
||||||
}
|
|
||||||
|
|
||||||
void capture(T* ptr) {
|
|
||||||
value_ = ptr;
|
|
||||||
link_.join_new();
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename U> void copy(linked_ptr<U> const* ptr) {
|
|
||||||
value_ = ptr->get();
|
|
||||||
if (value_)
|
|
||||||
link_.join(&ptr->link_);
|
|
||||||
else
|
|
||||||
link_.join_new();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template<typename T> inline
|
|
||||||
bool operator==(T* ptr, const linked_ptr<T>& x) {
|
|
||||||
return ptr == x.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename T> inline
|
|
||||||
bool operator!=(T* ptr, const linked_ptr<T>& x) {
|
|
||||||
return ptr != x.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
// A function to convert T* into linked_ptr<T>
|
|
||||||
// Doing e.g. make_linked_ptr(new FooBarBaz<type>(arg)) is a shorter notation
|
|
||||||
// for linked_ptr<FooBarBaz<type> >(new FooBarBaz<type>(arg))
|
|
||||||
template <typename T>
|
|
||||||
linked_ptr<T> make_linked_ptr(T* ptr) {
|
|
||||||
return linked_ptr<T>(ptr);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_LINKED_PTR_H_
|
|
File diff suppressed because it is too large
Load Diff
@ -1,301 +0,0 @@
|
|||||||
$$ -*- mode: c++; -*-
|
|
||||||
$var n = 50 $$ Maximum length of Values arguments we want to support.
|
|
||||||
$var maxtuple = 10 $$ Maximum number of Combine arguments we want to support.
|
|
||||||
// Copyright 2008 Google Inc.
|
|
||||||
// All Rights Reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: vladl@google.com (Vlad Losev)
|
|
||||||
|
|
||||||
// Type and function utilities for implementing parameterized tests.
|
|
||||||
// This file is generated by a SCRIPT. DO NOT EDIT BY HAND!
|
|
||||||
//
|
|
||||||
// Currently Google Test supports at most $n arguments in Values,
|
|
||||||
// and at most $maxtuple arguments in Combine. Please contact
|
|
||||||
// googletestframework@googlegroups.com if you need more.
|
|
||||||
// Please note that the number of arguments to Combine is limited
|
|
||||||
// by the maximum arity of the implementation of tr1::tuple which is
|
|
||||||
// currently set at $maxtuple.
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PARAM_UTIL_GENERATED_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PARAM_UTIL_GENERATED_H_
|
|
||||||
|
|
||||||
// scripts/fuse_gtest.py depends on gtest's own header being #included
|
|
||||||
// *unconditionally*. Therefore these #includes cannot be moved
|
|
||||||
// inside #if GTEST_HAS_PARAM_TEST.
|
|
||||||
#include "gtest/internal/gtest-param-util.h"
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
|
|
||||||
// Forward declarations of ValuesIn(), which is implemented in
|
|
||||||
// include/gtest/gtest-param-test.h.
|
|
||||||
template <typename ForwardIterator>
|
|
||||||
internal::ParamGenerator<
|
|
||||||
typename ::testing::internal::IteratorTraits<ForwardIterator>::value_type>
|
|
||||||
ValuesIn(ForwardIterator begin, ForwardIterator end);
|
|
||||||
|
|
||||||
template <typename T, size_t N>
|
|
||||||
internal::ParamGenerator<T> ValuesIn(const T (&array)[N]);
|
|
||||||
|
|
||||||
template <class Container>
|
|
||||||
internal::ParamGenerator<typename Container::value_type> ValuesIn(
|
|
||||||
const Container& container);
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// Used in the Values() function to provide polymorphic capabilities.
|
|
||||||
template <typename T1>
|
|
||||||
class ValueArray1 {
|
|
||||||
public:
|
|
||||||
explicit ValueArray1(T1 v1) : v1_(v1) {}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
operator ParamGenerator<T>() const { return ValuesIn(&v1_, &v1_ + 1); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const ValueArray1& other);
|
|
||||||
|
|
||||||
const T1 v1_;
|
|
||||||
};
|
|
||||||
|
|
||||||
$range i 2..n
|
|
||||||
$for i [[
|
|
||||||
$range j 1..i
|
|
||||||
|
|
||||||
template <$for j, [[typename T$j]]>
|
|
||||||
class ValueArray$i {
|
|
||||||
public:
|
|
||||||
ValueArray$i($for j, [[T$j v$j]]) : $for j, [[v$(j)_(v$j)]] {}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
operator ParamGenerator<T>() const {
|
|
||||||
const T array[] = {$for j, [[static_cast<T>(v$(j)_)]]};
|
|
||||||
return ValuesIn(array);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const ValueArray$i& other);
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
|
|
||||||
const T$j v$(j)_;
|
|
||||||
]]
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
# if GTEST_HAS_COMBINE
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Generates values from the Cartesian product of values produced
|
|
||||||
// by the argument generators.
|
|
||||||
//
|
|
||||||
$range i 2..maxtuple
|
|
||||||
$for i [[
|
|
||||||
$range j 1..i
|
|
||||||
$range k 2..i
|
|
||||||
|
|
||||||
template <$for j, [[typename T$j]]>
|
|
||||||
class CartesianProductGenerator$i
|
|
||||||
: public ParamGeneratorInterface< ::std::tr1::tuple<$for j, [[T$j]]> > {
|
|
||||||
public:
|
|
||||||
typedef ::std::tr1::tuple<$for j, [[T$j]]> ParamType;
|
|
||||||
|
|
||||||
CartesianProductGenerator$i($for j, [[const ParamGenerator<T$j>& g$j]])
|
|
||||||
: $for j, [[g$(j)_(g$j)]] {}
|
|
||||||
virtual ~CartesianProductGenerator$i() {}
|
|
||||||
|
|
||||||
virtual ParamIteratorInterface<ParamType>* Begin() const {
|
|
||||||
return new Iterator(this, $for j, [[g$(j)_, g$(j)_.begin()]]);
|
|
||||||
}
|
|
||||||
virtual ParamIteratorInterface<ParamType>* End() const {
|
|
||||||
return new Iterator(this, $for j, [[g$(j)_, g$(j)_.end()]]);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
class Iterator : public ParamIteratorInterface<ParamType> {
|
|
||||||
public:
|
|
||||||
Iterator(const ParamGeneratorInterface<ParamType>* base, $for j, [[
|
|
||||||
|
|
||||||
const ParamGenerator<T$j>& g$j,
|
|
||||||
const typename ParamGenerator<T$j>::iterator& current$(j)]])
|
|
||||||
: base_(base),
|
|
||||||
$for j, [[
|
|
||||||
|
|
||||||
begin$(j)_(g$j.begin()), end$(j)_(g$j.end()), current$(j)_(current$j)
|
|
||||||
]] {
|
|
||||||
ComputeCurrentValue();
|
|
||||||
}
|
|
||||||
virtual ~Iterator() {}
|
|
||||||
|
|
||||||
virtual const ParamGeneratorInterface<ParamType>* BaseGenerator() const {
|
|
||||||
return base_;
|
|
||||||
}
|
|
||||||
// Advance should not be called on beyond-of-range iterators
|
|
||||||
// so no component iterators must be beyond end of range, either.
|
|
||||||
virtual void Advance() {
|
|
||||||
assert(!AtEnd());
|
|
||||||
++current$(i)_;
|
|
||||||
|
|
||||||
$for k [[
|
|
||||||
if (current$(i+2-k)_ == end$(i+2-k)_) {
|
|
||||||
current$(i+2-k)_ = begin$(i+2-k)_;
|
|
||||||
++current$(i+2-k-1)_;
|
|
||||||
}
|
|
||||||
|
|
||||||
]]
|
|
||||||
ComputeCurrentValue();
|
|
||||||
}
|
|
||||||
virtual ParamIteratorInterface<ParamType>* Clone() const {
|
|
||||||
return new Iterator(*this);
|
|
||||||
}
|
|
||||||
virtual const ParamType* Current() const { return ¤t_value_; }
|
|
||||||
virtual bool Equals(const ParamIteratorInterface<ParamType>& other) const {
|
|
||||||
// Having the same base generator guarantees that the other
|
|
||||||
// iterator is of the same type and we can downcast.
|
|
||||||
GTEST_CHECK_(BaseGenerator() == other.BaseGenerator())
|
|
||||||
<< "The program attempted to compare iterators "
|
|
||||||
<< "from different generators." << std::endl;
|
|
||||||
const Iterator* typed_other =
|
|
||||||
CheckedDowncastToActualType<const Iterator>(&other);
|
|
||||||
// We must report iterators equal if they both point beyond their
|
|
||||||
// respective ranges. That can happen in a variety of fashions,
|
|
||||||
// so we have to consult AtEnd().
|
|
||||||
return (AtEnd() && typed_other->AtEnd()) ||
|
|
||||||
($for j && [[
|
|
||||||
|
|
||||||
current$(j)_ == typed_other->current$(j)_
|
|
||||||
]]);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Iterator(const Iterator& other)
|
|
||||||
: base_(other.base_), $for j, [[
|
|
||||||
|
|
||||||
begin$(j)_(other.begin$(j)_),
|
|
||||||
end$(j)_(other.end$(j)_),
|
|
||||||
current$(j)_(other.current$(j)_)
|
|
||||||
]] {
|
|
||||||
ComputeCurrentValue();
|
|
||||||
}
|
|
||||||
|
|
||||||
void ComputeCurrentValue() {
|
|
||||||
if (!AtEnd())
|
|
||||||
current_value_ = ParamType($for j, [[*current$(j)_]]);
|
|
||||||
}
|
|
||||||
bool AtEnd() const {
|
|
||||||
// We must report iterator past the end of the range when either of the
|
|
||||||
// component iterators has reached the end of its range.
|
|
||||||
return
|
|
||||||
$for j || [[
|
|
||||||
|
|
||||||
current$(j)_ == end$(j)_
|
|
||||||
]];
|
|
||||||
}
|
|
||||||
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const Iterator& other);
|
|
||||||
|
|
||||||
const ParamGeneratorInterface<ParamType>* const base_;
|
|
||||||
// begin[i]_ and end[i]_ define the i-th range that Iterator traverses.
|
|
||||||
// current[i]_ is the actual traversing iterator.
|
|
||||||
$for j [[
|
|
||||||
|
|
||||||
const typename ParamGenerator<T$j>::iterator begin$(j)_;
|
|
||||||
const typename ParamGenerator<T$j>::iterator end$(j)_;
|
|
||||||
typename ParamGenerator<T$j>::iterator current$(j)_;
|
|
||||||
]]
|
|
||||||
|
|
||||||
ParamType current_value_;
|
|
||||||
}; // class CartesianProductGenerator$i::Iterator
|
|
||||||
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const CartesianProductGenerator$i& other);
|
|
||||||
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
const ParamGenerator<T$j> g$(j)_;
|
|
||||||
|
|
||||||
]]
|
|
||||||
}; // class CartesianProductGenerator$i
|
|
||||||
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Helper classes providing Combine() with polymorphic features. They allow
|
|
||||||
// casting CartesianProductGeneratorN<T> to ParamGenerator<U> if T is
|
|
||||||
// convertible to U.
|
|
||||||
//
|
|
||||||
$range i 2..maxtuple
|
|
||||||
$for i [[
|
|
||||||
$range j 1..i
|
|
||||||
|
|
||||||
template <$for j, [[class Generator$j]]>
|
|
||||||
class CartesianProductHolder$i {
|
|
||||||
public:
|
|
||||||
CartesianProductHolder$i($for j, [[const Generator$j& g$j]])
|
|
||||||
: $for j, [[g$(j)_(g$j)]] {}
|
|
||||||
template <$for j, [[typename T$j]]>
|
|
||||||
operator ParamGenerator< ::std::tr1::tuple<$for j, [[T$j]]> >() const {
|
|
||||||
return ParamGenerator< ::std::tr1::tuple<$for j, [[T$j]]> >(
|
|
||||||
new CartesianProductGenerator$i<$for j, [[T$j]]>(
|
|
||||||
$for j,[[
|
|
||||||
|
|
||||||
static_cast<ParamGenerator<T$j> >(g$(j)_)
|
|
||||||
]]));
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const CartesianProductHolder$i& other);
|
|
||||||
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
const Generator$j g$(j)_;
|
|
||||||
|
|
||||||
]]
|
|
||||||
}; // class CartesianProductHolder$i
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
# endif // GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PARAM_UTIL_GENERATED_H_
|
|
@ -1,619 +0,0 @@
|
|||||||
// Copyright 2008 Google Inc.
|
|
||||||
// All Rights Reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: vladl@google.com (Vlad Losev)
|
|
||||||
|
|
||||||
// Type and function utilities for implementing parameterized tests.
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PARAM_UTIL_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PARAM_UTIL_H_
|
|
||||||
|
|
||||||
#include <iterator>
|
|
||||||
#include <utility>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
// scripts/fuse_gtest.py depends on gtest's own header being #included
|
|
||||||
// *unconditionally*. Therefore these #includes cannot be moved
|
|
||||||
// inside #if GTEST_HAS_PARAM_TEST.
|
|
||||||
#include "gtest/internal/gtest-internal.h"
|
|
||||||
#include "gtest/internal/gtest-linked_ptr.h"
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
#include "gtest/gtest-printers.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Outputs a message explaining invalid registration of different
|
|
||||||
// fixture class for the same test case. This may happen when
|
|
||||||
// TEST_P macro is used to define two tests with the same name
|
|
||||||
// but in different namespaces.
|
|
||||||
GTEST_API_ void ReportInvalidTestCaseType(const char* test_case_name,
|
|
||||||
const char* file, int line);
|
|
||||||
|
|
||||||
template <typename> class ParamGeneratorInterface;
|
|
||||||
template <typename> class ParamGenerator;
|
|
||||||
|
|
||||||
// Interface for iterating over elements provided by an implementation
|
|
||||||
// of ParamGeneratorInterface<T>.
|
|
||||||
template <typename T>
|
|
||||||
class ParamIteratorInterface {
|
|
||||||
public:
|
|
||||||
virtual ~ParamIteratorInterface() {}
|
|
||||||
// A pointer to the base generator instance.
|
|
||||||
// Used only for the purposes of iterator comparison
|
|
||||||
// to make sure that two iterators belong to the same generator.
|
|
||||||
virtual const ParamGeneratorInterface<T>* BaseGenerator() const = 0;
|
|
||||||
// Advances iterator to point to the next element
|
|
||||||
// provided by the generator. The caller is responsible
|
|
||||||
// for not calling Advance() on an iterator equal to
|
|
||||||
// BaseGenerator()->End().
|
|
||||||
virtual void Advance() = 0;
|
|
||||||
// Clones the iterator object. Used for implementing copy semantics
|
|
||||||
// of ParamIterator<T>.
|
|
||||||
virtual ParamIteratorInterface* Clone() const = 0;
|
|
||||||
// Dereferences the current iterator and provides (read-only) access
|
|
||||||
// to the pointed value. It is the caller's responsibility not to call
|
|
||||||
// Current() on an iterator equal to BaseGenerator()->End().
|
|
||||||
// Used for implementing ParamGenerator<T>::operator*().
|
|
||||||
virtual const T* Current() const = 0;
|
|
||||||
// Determines whether the given iterator and other point to the same
|
|
||||||
// element in the sequence generated by the generator.
|
|
||||||
// Used for implementing ParamGenerator<T>::operator==().
|
|
||||||
virtual bool Equals(const ParamIteratorInterface& other) const = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Class iterating over elements provided by an implementation of
|
|
||||||
// ParamGeneratorInterface<T>. It wraps ParamIteratorInterface<T>
|
|
||||||
// and implements the const forward iterator concept.
|
|
||||||
template <typename T>
|
|
||||||
class ParamIterator {
|
|
||||||
public:
|
|
||||||
typedef T value_type;
|
|
||||||
typedef const T& reference;
|
|
||||||
typedef ptrdiff_t difference_type;
|
|
||||||
|
|
||||||
// ParamIterator assumes ownership of the impl_ pointer.
|
|
||||||
ParamIterator(const ParamIterator& other) : impl_(other.impl_->Clone()) {}
|
|
||||||
ParamIterator& operator=(const ParamIterator& other) {
|
|
||||||
if (this != &other)
|
|
||||||
impl_.reset(other.impl_->Clone());
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
const T& operator*() const { return *impl_->Current(); }
|
|
||||||
const T* operator->() const { return impl_->Current(); }
|
|
||||||
// Prefix version of operator++.
|
|
||||||
ParamIterator& operator++() {
|
|
||||||
impl_->Advance();
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
// Postfix version of operator++.
|
|
||||||
ParamIterator operator++(int /*unused*/) {
|
|
||||||
ParamIteratorInterface<T>* clone = impl_->Clone();
|
|
||||||
impl_->Advance();
|
|
||||||
return ParamIterator(clone);
|
|
||||||
}
|
|
||||||
bool operator==(const ParamIterator& other) const {
|
|
||||||
return impl_.get() == other.impl_.get() || impl_->Equals(*other.impl_);
|
|
||||||
}
|
|
||||||
bool operator!=(const ParamIterator& other) const {
|
|
||||||
return !(*this == other);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
friend class ParamGenerator<T>;
|
|
||||||
explicit ParamIterator(ParamIteratorInterface<T>* impl) : impl_(impl) {}
|
|
||||||
scoped_ptr<ParamIteratorInterface<T> > impl_;
|
|
||||||
};
|
|
||||||
|
|
||||||
// ParamGeneratorInterface<T> is the binary interface to access generators
|
|
||||||
// defined in other translation units.
|
|
||||||
template <typename T>
|
|
||||||
class ParamGeneratorInterface {
|
|
||||||
public:
|
|
||||||
typedef T ParamType;
|
|
||||||
|
|
||||||
virtual ~ParamGeneratorInterface() {}
|
|
||||||
|
|
||||||
// Generator interface definition
|
|
||||||
virtual ParamIteratorInterface<T>* Begin() const = 0;
|
|
||||||
virtual ParamIteratorInterface<T>* End() const = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Wraps ParamGeneratorInterface<T> and provides general generator syntax
|
|
||||||
// compatible with the STL Container concept.
|
|
||||||
// This class implements copy initialization semantics and the contained
|
|
||||||
// ParamGeneratorInterface<T> instance is shared among all copies
|
|
||||||
// of the original object. This is possible because that instance is immutable.
|
|
||||||
template<typename T>
|
|
||||||
class ParamGenerator {
|
|
||||||
public:
|
|
||||||
typedef ParamIterator<T> iterator;
|
|
||||||
|
|
||||||
explicit ParamGenerator(ParamGeneratorInterface<T>* impl) : impl_(impl) {}
|
|
||||||
ParamGenerator(const ParamGenerator& other) : impl_(other.impl_) {}
|
|
||||||
|
|
||||||
ParamGenerator& operator=(const ParamGenerator& other) {
|
|
||||||
impl_ = other.impl_;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
iterator begin() const { return iterator(impl_->Begin()); }
|
|
||||||
iterator end() const { return iterator(impl_->End()); }
|
|
||||||
|
|
||||||
private:
|
|
||||||
linked_ptr<const ParamGeneratorInterface<T> > impl_;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Generates values from a range of two comparable values. Can be used to
|
|
||||||
// generate sequences of user-defined types that implement operator+() and
|
|
||||||
// operator<().
|
|
||||||
// This class is used in the Range() function.
|
|
||||||
template <typename T, typename IncrementT>
|
|
||||||
class RangeGenerator : public ParamGeneratorInterface<T> {
|
|
||||||
public:
|
|
||||||
RangeGenerator(T begin, T end, IncrementT step)
|
|
||||||
: begin_(begin), end_(end),
|
|
||||||
step_(step), end_index_(CalculateEndIndex(begin, end, step)) {}
|
|
||||||
virtual ~RangeGenerator() {}
|
|
||||||
|
|
||||||
virtual ParamIteratorInterface<T>* Begin() const {
|
|
||||||
return new Iterator(this, begin_, 0, step_);
|
|
||||||
}
|
|
||||||
virtual ParamIteratorInterface<T>* End() const {
|
|
||||||
return new Iterator(this, end_, end_index_, step_);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
class Iterator : public ParamIteratorInterface<T> {
|
|
||||||
public:
|
|
||||||
Iterator(const ParamGeneratorInterface<T>* base, T value, int index,
|
|
||||||
IncrementT step)
|
|
||||||
: base_(base), value_(value), index_(index), step_(step) {}
|
|
||||||
virtual ~Iterator() {}
|
|
||||||
|
|
||||||
virtual const ParamGeneratorInterface<T>* BaseGenerator() const {
|
|
||||||
return base_;
|
|
||||||
}
|
|
||||||
virtual void Advance() {
|
|
||||||
value_ = value_ + step_;
|
|
||||||
index_++;
|
|
||||||
}
|
|
||||||
virtual ParamIteratorInterface<T>* Clone() const {
|
|
||||||
return new Iterator(*this);
|
|
||||||
}
|
|
||||||
virtual const T* Current() const { return &value_; }
|
|
||||||
virtual bool Equals(const ParamIteratorInterface<T>& other) const {
|
|
||||||
// Having the same base generator guarantees that the other
|
|
||||||
// iterator is of the same type and we can downcast.
|
|
||||||
GTEST_CHECK_(BaseGenerator() == other.BaseGenerator())
|
|
||||||
<< "The program attempted to compare iterators "
|
|
||||||
<< "from different generators." << std::endl;
|
|
||||||
const int other_index =
|
|
||||||
CheckedDowncastToActualType<const Iterator>(&other)->index_;
|
|
||||||
return index_ == other_index;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Iterator(const Iterator& other)
|
|
||||||
: ParamIteratorInterface<T>(),
|
|
||||||
base_(other.base_), value_(other.value_), index_(other.index_),
|
|
||||||
step_(other.step_) {}
|
|
||||||
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const Iterator& other);
|
|
||||||
|
|
||||||
const ParamGeneratorInterface<T>* const base_;
|
|
||||||
T value_;
|
|
||||||
int index_;
|
|
||||||
const IncrementT step_;
|
|
||||||
}; // class RangeGenerator::Iterator
|
|
||||||
|
|
||||||
static int CalculateEndIndex(const T& begin,
|
|
||||||
const T& end,
|
|
||||||
const IncrementT& step) {
|
|
||||||
int end_index = 0;
|
|
||||||
for (T i = begin; i < end; i = i + step)
|
|
||||||
end_index++;
|
|
||||||
return end_index;
|
|
||||||
}
|
|
||||||
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const RangeGenerator& other);
|
|
||||||
|
|
||||||
const T begin_;
|
|
||||||
const T end_;
|
|
||||||
const IncrementT step_;
|
|
||||||
// The index for the end() iterator. All the elements in the generated
|
|
||||||
// sequence are indexed (0-based) to aid iterator comparison.
|
|
||||||
const int end_index_;
|
|
||||||
}; // class RangeGenerator
|
|
||||||
|
|
||||||
|
|
||||||
// Generates values from a pair of STL-style iterators. Used in the
|
|
||||||
// ValuesIn() function. The elements are copied from the source range
|
|
||||||
// since the source can be located on the stack, and the generator
|
|
||||||
// is likely to persist beyond that stack frame.
|
|
||||||
template <typename T>
|
|
||||||
class ValuesInIteratorRangeGenerator : public ParamGeneratorInterface<T> {
|
|
||||||
public:
|
|
||||||
template <typename ForwardIterator>
|
|
||||||
ValuesInIteratorRangeGenerator(ForwardIterator begin, ForwardIterator end)
|
|
||||||
: container_(begin, end) {}
|
|
||||||
virtual ~ValuesInIteratorRangeGenerator() {}
|
|
||||||
|
|
||||||
virtual ParamIteratorInterface<T>* Begin() const {
|
|
||||||
return new Iterator(this, container_.begin());
|
|
||||||
}
|
|
||||||
virtual ParamIteratorInterface<T>* End() const {
|
|
||||||
return new Iterator(this, container_.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
typedef typename ::std::vector<T> ContainerType;
|
|
||||||
|
|
||||||
class Iterator : public ParamIteratorInterface<T> {
|
|
||||||
public:
|
|
||||||
Iterator(const ParamGeneratorInterface<T>* base,
|
|
||||||
typename ContainerType::const_iterator iterator)
|
|
||||||
: base_(base), iterator_(iterator) {}
|
|
||||||
virtual ~Iterator() {}
|
|
||||||
|
|
||||||
virtual const ParamGeneratorInterface<T>* BaseGenerator() const {
|
|
||||||
return base_;
|
|
||||||
}
|
|
||||||
virtual void Advance() {
|
|
||||||
++iterator_;
|
|
||||||
value_.reset();
|
|
||||||
}
|
|
||||||
virtual ParamIteratorInterface<T>* Clone() const {
|
|
||||||
return new Iterator(*this);
|
|
||||||
}
|
|
||||||
// We need to use cached value referenced by iterator_ because *iterator_
|
|
||||||
// can return a temporary object (and of type other then T), so just
|
|
||||||
// having "return &*iterator_;" doesn't work.
|
|
||||||
// value_ is updated here and not in Advance() because Advance()
|
|
||||||
// can advance iterator_ beyond the end of the range, and we cannot
|
|
||||||
// detect that fact. The client code, on the other hand, is
|
|
||||||
// responsible for not calling Current() on an out-of-range iterator.
|
|
||||||
virtual const T* Current() const {
|
|
||||||
if (value_.get() == NULL)
|
|
||||||
value_.reset(new T(*iterator_));
|
|
||||||
return value_.get();
|
|
||||||
}
|
|
||||||
virtual bool Equals(const ParamIteratorInterface<T>& other) const {
|
|
||||||
// Having the same base generator guarantees that the other
|
|
||||||
// iterator is of the same type and we can downcast.
|
|
||||||
GTEST_CHECK_(BaseGenerator() == other.BaseGenerator())
|
|
||||||
<< "The program attempted to compare iterators "
|
|
||||||
<< "from different generators." << std::endl;
|
|
||||||
return iterator_ ==
|
|
||||||
CheckedDowncastToActualType<const Iterator>(&other)->iterator_;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
Iterator(const Iterator& other)
|
|
||||||
// The explicit constructor call suppresses a false warning
|
|
||||||
// emitted by gcc when supplied with the -Wextra option.
|
|
||||||
: ParamIteratorInterface<T>(),
|
|
||||||
base_(other.base_),
|
|
||||||
iterator_(other.iterator_) {}
|
|
||||||
|
|
||||||
const ParamGeneratorInterface<T>* const base_;
|
|
||||||
typename ContainerType::const_iterator iterator_;
|
|
||||||
// A cached value of *iterator_. We keep it here to allow access by
|
|
||||||
// pointer in the wrapping iterator's operator->().
|
|
||||||
// value_ needs to be mutable to be accessed in Current().
|
|
||||||
// Use of scoped_ptr helps manage cached value's lifetime,
|
|
||||||
// which is bound by the lifespan of the iterator itself.
|
|
||||||
mutable scoped_ptr<const T> value_;
|
|
||||||
}; // class ValuesInIteratorRangeGenerator::Iterator
|
|
||||||
|
|
||||||
// No implementation - assignment is unsupported.
|
|
||||||
void operator=(const ValuesInIteratorRangeGenerator& other);
|
|
||||||
|
|
||||||
const ContainerType container_;
|
|
||||||
}; // class ValuesInIteratorRangeGenerator
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// Stores a parameter value and later creates tests parameterized with that
|
|
||||||
// value.
|
|
||||||
template <class TestClass>
|
|
||||||
class ParameterizedTestFactory : public TestFactoryBase {
|
|
||||||
public:
|
|
||||||
typedef typename TestClass::ParamType ParamType;
|
|
||||||
explicit ParameterizedTestFactory(ParamType parameter) :
|
|
||||||
parameter_(parameter) {}
|
|
||||||
virtual Test* CreateTest() {
|
|
||||||
TestClass::SetParam(¶meter_);
|
|
||||||
return new TestClass();
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
const ParamType parameter_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(ParameterizedTestFactory);
|
|
||||||
};
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// TestMetaFactoryBase is a base class for meta-factories that create
|
|
||||||
// test factories for passing into MakeAndRegisterTestInfo function.
|
|
||||||
template <class ParamType>
|
|
||||||
class TestMetaFactoryBase {
|
|
||||||
public:
|
|
||||||
virtual ~TestMetaFactoryBase() {}
|
|
||||||
|
|
||||||
virtual TestFactoryBase* CreateTestFactory(ParamType parameter) = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// TestMetaFactory creates test factories for passing into
|
|
||||||
// MakeAndRegisterTestInfo function. Since MakeAndRegisterTestInfo receives
|
|
||||||
// ownership of test factory pointer, same factory object cannot be passed
|
|
||||||
// into that method twice. But ParameterizedTestCaseInfo is going to call
|
|
||||||
// it for each Test/Parameter value combination. Thus it needs meta factory
|
|
||||||
// creator class.
|
|
||||||
template <class TestCase>
|
|
||||||
class TestMetaFactory
|
|
||||||
: public TestMetaFactoryBase<typename TestCase::ParamType> {
|
|
||||||
public:
|
|
||||||
typedef typename TestCase::ParamType ParamType;
|
|
||||||
|
|
||||||
TestMetaFactory() {}
|
|
||||||
|
|
||||||
virtual TestFactoryBase* CreateTestFactory(ParamType parameter) {
|
|
||||||
return new ParameterizedTestFactory<TestCase>(parameter);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(TestMetaFactory);
|
|
||||||
};
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// ParameterizedTestCaseInfoBase is a generic interface
|
|
||||||
// to ParameterizedTestCaseInfo classes. ParameterizedTestCaseInfoBase
|
|
||||||
// accumulates test information provided by TEST_P macro invocations
|
|
||||||
// and generators provided by INSTANTIATE_TEST_CASE_P macro invocations
|
|
||||||
// and uses that information to register all resulting test instances
|
|
||||||
// in RegisterTests method. The ParameterizeTestCaseRegistry class holds
|
|
||||||
// a collection of pointers to the ParameterizedTestCaseInfo objects
|
|
||||||
// and calls RegisterTests() on each of them when asked.
|
|
||||||
class ParameterizedTestCaseInfoBase {
|
|
||||||
public:
|
|
||||||
virtual ~ParameterizedTestCaseInfoBase() {}
|
|
||||||
|
|
||||||
// Base part of test case name for display purposes.
|
|
||||||
virtual const string& GetTestCaseName() const = 0;
|
|
||||||
// Test case id to verify identity.
|
|
||||||
virtual TypeId GetTestCaseTypeId() const = 0;
|
|
||||||
// UnitTest class invokes this method to register tests in this
|
|
||||||
// test case right before running them in RUN_ALL_TESTS macro.
|
|
||||||
// This method should not be called more then once on any single
|
|
||||||
// instance of a ParameterizedTestCaseInfoBase derived class.
|
|
||||||
virtual void RegisterTests() = 0;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
ParameterizedTestCaseInfoBase() {}
|
|
||||||
|
|
||||||
private:
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(ParameterizedTestCaseInfoBase);
|
|
||||||
};
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// ParameterizedTestCaseInfo accumulates tests obtained from TEST_P
|
|
||||||
// macro invocations for a particular test case and generators
|
|
||||||
// obtained from INSTANTIATE_TEST_CASE_P macro invocations for that
|
|
||||||
// test case. It registers tests with all values generated by all
|
|
||||||
// generators when asked.
|
|
||||||
template <class TestCase>
|
|
||||||
class ParameterizedTestCaseInfo : public ParameterizedTestCaseInfoBase {
|
|
||||||
public:
|
|
||||||
// ParamType and GeneratorCreationFunc are private types but are required
|
|
||||||
// for declarations of public methods AddTestPattern() and
|
|
||||||
// AddTestCaseInstantiation().
|
|
||||||
typedef typename TestCase::ParamType ParamType;
|
|
||||||
// A function that returns an instance of appropriate generator type.
|
|
||||||
typedef ParamGenerator<ParamType>(GeneratorCreationFunc)();
|
|
||||||
|
|
||||||
explicit ParameterizedTestCaseInfo(const char* name)
|
|
||||||
: test_case_name_(name) {}
|
|
||||||
|
|
||||||
// Test case base name for display purposes.
|
|
||||||
virtual const string& GetTestCaseName() const { return test_case_name_; }
|
|
||||||
// Test case id to verify identity.
|
|
||||||
virtual TypeId GetTestCaseTypeId() const { return GetTypeId<TestCase>(); }
|
|
||||||
// TEST_P macro uses AddTestPattern() to record information
|
|
||||||
// about a single test in a LocalTestInfo structure.
|
|
||||||
// test_case_name is the base name of the test case (without invocation
|
|
||||||
// prefix). test_base_name is the name of an individual test without
|
|
||||||
// parameter index. For the test SequenceA/FooTest.DoBar/1 FooTest is
|
|
||||||
// test case base name and DoBar is test base name.
|
|
||||||
void AddTestPattern(const char* test_case_name,
|
|
||||||
const char* test_base_name,
|
|
||||||
TestMetaFactoryBase<ParamType>* meta_factory) {
|
|
||||||
tests_.push_back(linked_ptr<TestInfo>(new TestInfo(test_case_name,
|
|
||||||
test_base_name,
|
|
||||||
meta_factory)));
|
|
||||||
}
|
|
||||||
// INSTANTIATE_TEST_CASE_P macro uses AddGenerator() to record information
|
|
||||||
// about a generator.
|
|
||||||
int AddTestCaseInstantiation(const string& instantiation_name,
|
|
||||||
GeneratorCreationFunc* func,
|
|
||||||
const char* /* file */,
|
|
||||||
int /* line */) {
|
|
||||||
instantiations_.push_back(::std::make_pair(instantiation_name, func));
|
|
||||||
return 0; // Return value used only to run this method in namespace scope.
|
|
||||||
}
|
|
||||||
// UnitTest class invokes this method to register tests in this test case
|
|
||||||
// test cases right before running tests in RUN_ALL_TESTS macro.
|
|
||||||
// This method should not be called more then once on any single
|
|
||||||
// instance of a ParameterizedTestCaseInfoBase derived class.
|
|
||||||
// UnitTest has a guard to prevent from calling this method more then once.
|
|
||||||
virtual void RegisterTests() {
|
|
||||||
for (typename TestInfoContainer::iterator test_it = tests_.begin();
|
|
||||||
test_it != tests_.end(); ++test_it) {
|
|
||||||
linked_ptr<TestInfo> test_info = *test_it;
|
|
||||||
for (typename InstantiationContainer::iterator gen_it =
|
|
||||||
instantiations_.begin(); gen_it != instantiations_.end();
|
|
||||||
++gen_it) {
|
|
||||||
const string& instantiation_name = gen_it->first;
|
|
||||||
ParamGenerator<ParamType> generator((*gen_it->second)());
|
|
||||||
|
|
||||||
Message test_case_name_stream;
|
|
||||||
if ( !instantiation_name.empty() )
|
|
||||||
test_case_name_stream << instantiation_name << "/";
|
|
||||||
test_case_name_stream << test_info->test_case_base_name;
|
|
||||||
|
|
||||||
int i = 0;
|
|
||||||
for (typename ParamGenerator<ParamType>::iterator param_it =
|
|
||||||
generator.begin();
|
|
||||||
param_it != generator.end(); ++param_it, ++i) {
|
|
||||||
Message test_name_stream;
|
|
||||||
test_name_stream << test_info->test_base_name << "/" << i;
|
|
||||||
MakeAndRegisterTestInfo(
|
|
||||||
test_case_name_stream.GetString().c_str(),
|
|
||||||
test_name_stream.GetString().c_str(),
|
|
||||||
NULL, // No type parameter.
|
|
||||||
PrintToString(*param_it).c_str(),
|
|
||||||
GetTestCaseTypeId(),
|
|
||||||
TestCase::SetUpTestCase,
|
|
||||||
TestCase::TearDownTestCase,
|
|
||||||
test_info->test_meta_factory->CreateTestFactory(*param_it));
|
|
||||||
} // for param_it
|
|
||||||
} // for gen_it
|
|
||||||
} // for test_it
|
|
||||||
} // RegisterTests
|
|
||||||
|
|
||||||
private:
|
|
||||||
// LocalTestInfo structure keeps information about a single test registered
|
|
||||||
// with TEST_P macro.
|
|
||||||
struct TestInfo {
|
|
||||||
TestInfo(const char* a_test_case_base_name,
|
|
||||||
const char* a_test_base_name,
|
|
||||||
TestMetaFactoryBase<ParamType>* a_test_meta_factory) :
|
|
||||||
test_case_base_name(a_test_case_base_name),
|
|
||||||
test_base_name(a_test_base_name),
|
|
||||||
test_meta_factory(a_test_meta_factory) {}
|
|
||||||
|
|
||||||
const string test_case_base_name;
|
|
||||||
const string test_base_name;
|
|
||||||
const scoped_ptr<TestMetaFactoryBase<ParamType> > test_meta_factory;
|
|
||||||
};
|
|
||||||
typedef ::std::vector<linked_ptr<TestInfo> > TestInfoContainer;
|
|
||||||
// Keeps pairs of <Instantiation name, Sequence generator creation function>
|
|
||||||
// received from INSTANTIATE_TEST_CASE_P macros.
|
|
||||||
typedef ::std::vector<std::pair<string, GeneratorCreationFunc*> >
|
|
||||||
InstantiationContainer;
|
|
||||||
|
|
||||||
const string test_case_name_;
|
|
||||||
TestInfoContainer tests_;
|
|
||||||
InstantiationContainer instantiations_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(ParameterizedTestCaseInfo);
|
|
||||||
}; // class ParameterizedTestCaseInfo
|
|
||||||
|
|
||||||
// INTERNAL IMPLEMENTATION - DO NOT USE IN USER CODE.
|
|
||||||
//
|
|
||||||
// ParameterizedTestCaseRegistry contains a map of ParameterizedTestCaseInfoBase
|
|
||||||
// classes accessed by test case names. TEST_P and INSTANTIATE_TEST_CASE_P
|
|
||||||
// macros use it to locate their corresponding ParameterizedTestCaseInfo
|
|
||||||
// descriptors.
|
|
||||||
class ParameterizedTestCaseRegistry {
|
|
||||||
public:
|
|
||||||
ParameterizedTestCaseRegistry() {}
|
|
||||||
~ParameterizedTestCaseRegistry() {
|
|
||||||
for (TestCaseInfoContainer::iterator it = test_case_infos_.begin();
|
|
||||||
it != test_case_infos_.end(); ++it) {
|
|
||||||
delete *it;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Looks up or creates and returns a structure containing information about
|
|
||||||
// tests and instantiations of a particular test case.
|
|
||||||
template <class TestCase>
|
|
||||||
ParameterizedTestCaseInfo<TestCase>* GetTestCasePatternHolder(
|
|
||||||
const char* test_case_name,
|
|
||||||
const char* file,
|
|
||||||
int line) {
|
|
||||||
ParameterizedTestCaseInfo<TestCase>* typed_test_info = NULL;
|
|
||||||
for (TestCaseInfoContainer::iterator it = test_case_infos_.begin();
|
|
||||||
it != test_case_infos_.end(); ++it) {
|
|
||||||
if ((*it)->GetTestCaseName() == test_case_name) {
|
|
||||||
if ((*it)->GetTestCaseTypeId() != GetTypeId<TestCase>()) {
|
|
||||||
// Complain about incorrect usage of Google Test facilities
|
|
||||||
// and terminate the program since we cannot guaranty correct
|
|
||||||
// test case setup and tear-down in this case.
|
|
||||||
ReportInvalidTestCaseType(test_case_name, file, line);
|
|
||||||
posix::Abort();
|
|
||||||
} else {
|
|
||||||
// At this point we are sure that the object we found is of the same
|
|
||||||
// type we are looking for, so we downcast it to that type
|
|
||||||
// without further checks.
|
|
||||||
typed_test_info = CheckedDowncastToActualType<
|
|
||||||
ParameterizedTestCaseInfo<TestCase> >(*it);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (typed_test_info == NULL) {
|
|
||||||
typed_test_info = new ParameterizedTestCaseInfo<TestCase>(test_case_name);
|
|
||||||
test_case_infos_.push_back(typed_test_info);
|
|
||||||
}
|
|
||||||
return typed_test_info;
|
|
||||||
}
|
|
||||||
void RegisterTests() {
|
|
||||||
for (TestCaseInfoContainer::iterator it = test_case_infos_.begin();
|
|
||||||
it != test_case_infos_.end(); ++it) {
|
|
||||||
(*it)->RegisterTests();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
typedef ::std::vector<ParameterizedTestCaseInfoBase*> TestCaseInfoContainer;
|
|
||||||
|
|
||||||
TestCaseInfoContainer test_case_infos_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(ParameterizedTestCaseRegistry);
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_PARAM_UTIL_H_
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,339 +0,0 @@
|
|||||||
$$ -*- mode: c++; -*-
|
|
||||||
$var n = 10 $$ Maximum number of tuple fields we want to support.
|
|
||||||
$$ This meta comment fixes auto-indentation in Emacs. }}
|
|
||||||
// Copyright 2009 Google Inc.
|
|
||||||
// All Rights Reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
|
|
||||||
// Implements a subset of TR1 tuple needed by Google Test and Google Mock.
|
|
||||||
|
|
||||||
#ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_TUPLE_H_
|
|
||||||
#define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_TUPLE_H_
|
|
||||||
|
|
||||||
#include <utility> // For ::std::pair.
|
|
||||||
|
|
||||||
// The compiler used in Symbian has a bug that prevents us from declaring the
|
|
||||||
// tuple template as a friend (it complains that tuple is redefined). This
|
|
||||||
// hack bypasses the bug by declaring the members that should otherwise be
|
|
||||||
// private as public.
|
|
||||||
// Sun Studio versions < 12 also have the above bug.
|
|
||||||
#if defined(__SYMBIAN32__) || (defined(__SUNPRO_CC) && __SUNPRO_CC < 0x590)
|
|
||||||
# define GTEST_DECLARE_TUPLE_AS_FRIEND_ public:
|
|
||||||
#else
|
|
||||||
# define GTEST_DECLARE_TUPLE_AS_FRIEND_ \
|
|
||||||
template <GTEST_$(n)_TYPENAMES_(U)> friend class tuple; \
|
|
||||||
private:
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
$range i 0..n-1
|
|
||||||
$range j 0..n
|
|
||||||
$range k 1..n
|
|
||||||
// GTEST_n_TUPLE_(T) is the type of an n-tuple.
|
|
||||||
#define GTEST_0_TUPLE_(T) tuple<>
|
|
||||||
|
|
||||||
$for k [[
|
|
||||||
$range m 0..k-1
|
|
||||||
$range m2 k..n-1
|
|
||||||
#define GTEST_$(k)_TUPLE_(T) tuple<$for m, [[T##$m]]$for m2 [[, void]]>
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
// GTEST_n_TYPENAMES_(T) declares a list of n typenames.
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
$range m 0..j-1
|
|
||||||
#define GTEST_$(j)_TYPENAMES_(T) $for m, [[typename T##$m]]
|
|
||||||
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
// In theory, defining stuff in the ::std namespace is undefined
|
|
||||||
// behavior. We can do this as we are playing the role of a standard
|
|
||||||
// library vendor.
|
|
||||||
namespace std {
|
|
||||||
namespace tr1 {
|
|
||||||
|
|
||||||
template <$for i, [[typename T$i = void]]>
|
|
||||||
class tuple;
|
|
||||||
|
|
||||||
// Anything in namespace gtest_internal is Google Test's INTERNAL
|
|
||||||
// IMPLEMENTATION DETAIL and MUST NOT BE USED DIRECTLY in user code.
|
|
||||||
namespace gtest_internal {
|
|
||||||
|
|
||||||
// ByRef<T>::type is T if T is a reference; otherwise it's const T&.
|
|
||||||
template <typename T>
|
|
||||||
struct ByRef { typedef const T& type; }; // NOLINT
|
|
||||||
template <typename T>
|
|
||||||
struct ByRef<T&> { typedef T& type; }; // NOLINT
|
|
||||||
|
|
||||||
// A handy wrapper for ByRef.
|
|
||||||
#define GTEST_BY_REF_(T) typename ::std::tr1::gtest_internal::ByRef<T>::type
|
|
||||||
|
|
||||||
// AddRef<T>::type is T if T is a reference; otherwise it's T&. This
|
|
||||||
// is the same as tr1::add_reference<T>::type.
|
|
||||||
template <typename T>
|
|
||||||
struct AddRef { typedef T& type; }; // NOLINT
|
|
||||||
template <typename T>
|
|
||||||
struct AddRef<T&> { typedef T& type; }; // NOLINT
|
|
||||||
|
|
||||||
// A handy wrapper for AddRef.
|
|
||||||
#define GTEST_ADD_REF_(T) typename ::std::tr1::gtest_internal::AddRef<T>::type
|
|
||||||
|
|
||||||
// A helper for implementing get<k>().
|
|
||||||
template <int k> class Get;
|
|
||||||
|
|
||||||
// A helper for implementing tuple_element<k, T>. kIndexValid is true
|
|
||||||
// iff k < the number of fields in tuple type T.
|
|
||||||
template <bool kIndexValid, int kIndex, class Tuple>
|
|
||||||
struct TupleElement;
|
|
||||||
|
|
||||||
|
|
||||||
$for i [[
|
|
||||||
template <GTEST_$(n)_TYPENAMES_(T)>
|
|
||||||
struct TupleElement<true, $i, GTEST_$(n)_TUPLE_(T) > {
|
|
||||||
typedef T$i type;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
]]
|
|
||||||
} // namespace gtest_internal
|
|
||||||
|
|
||||||
template <>
|
|
||||||
class tuple<> {
|
|
||||||
public:
|
|
||||||
tuple() {}
|
|
||||||
tuple(const tuple& /* t */) {}
|
|
||||||
tuple& operator=(const tuple& /* t */) { return *this; }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
$for k [[
|
|
||||||
$range m 0..k-1
|
|
||||||
template <GTEST_$(k)_TYPENAMES_(T)>
|
|
||||||
class $if k < n [[GTEST_$(k)_TUPLE_(T)]] $else [[tuple]] {
|
|
||||||
public:
|
|
||||||
template <int k> friend class gtest_internal::Get;
|
|
||||||
|
|
||||||
tuple() : $for m, [[f$(m)_()]] {}
|
|
||||||
|
|
||||||
explicit tuple($for m, [[GTEST_BY_REF_(T$m) f$m]]) : [[]]
|
|
||||||
$for m, [[f$(m)_(f$m)]] {}
|
|
||||||
|
|
||||||
tuple(const tuple& t) : $for m, [[f$(m)_(t.f$(m)_)]] {}
|
|
||||||
|
|
||||||
template <GTEST_$(k)_TYPENAMES_(U)>
|
|
||||||
tuple(const GTEST_$(k)_TUPLE_(U)& t) : $for m, [[f$(m)_(t.f$(m)_)]] {}
|
|
||||||
|
|
||||||
$if k == 2 [[
|
|
||||||
template <typename U0, typename U1>
|
|
||||||
tuple(const ::std::pair<U0, U1>& p) : f0_(p.first), f1_(p.second) {}
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
tuple& operator=(const tuple& t) { return CopyFrom(t); }
|
|
||||||
|
|
||||||
template <GTEST_$(k)_TYPENAMES_(U)>
|
|
||||||
tuple& operator=(const GTEST_$(k)_TUPLE_(U)& t) {
|
|
||||||
return CopyFrom(t);
|
|
||||||
}
|
|
||||||
|
|
||||||
$if k == 2 [[
|
|
||||||
template <typename U0, typename U1>
|
|
||||||
tuple& operator=(const ::std::pair<U0, U1>& p) {
|
|
||||||
f0_ = p.first;
|
|
||||||
f1_ = p.second;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
GTEST_DECLARE_TUPLE_AS_FRIEND_
|
|
||||||
|
|
||||||
template <GTEST_$(k)_TYPENAMES_(U)>
|
|
||||||
tuple& CopyFrom(const GTEST_$(k)_TUPLE_(U)& t) {
|
|
||||||
|
|
||||||
$for m [[
|
|
||||||
f$(m)_ = t.f$(m)_;
|
|
||||||
|
|
||||||
]]
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
$for m [[
|
|
||||||
T$m f$(m)_;
|
|
||||||
|
|
||||||
]]
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
]]
|
|
||||||
// 6.1.3.2 Tuple creation functions.
|
|
||||||
|
|
||||||
// Known limitations: we don't support passing an
|
|
||||||
// std::tr1::reference_wrapper<T> to make_tuple(). And we don't
|
|
||||||
// implement tie().
|
|
||||||
|
|
||||||
inline tuple<> make_tuple() { return tuple<>(); }
|
|
||||||
|
|
||||||
$for k [[
|
|
||||||
$range m 0..k-1
|
|
||||||
|
|
||||||
template <GTEST_$(k)_TYPENAMES_(T)>
|
|
||||||
inline GTEST_$(k)_TUPLE_(T) make_tuple($for m, [[const T$m& f$m]]) {
|
|
||||||
return GTEST_$(k)_TUPLE_(T)($for m, [[f$m]]);
|
|
||||||
}
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
// 6.1.3.3 Tuple helper classes.
|
|
||||||
|
|
||||||
template <typename Tuple> struct tuple_size;
|
|
||||||
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
template <GTEST_$(j)_TYPENAMES_(T)>
|
|
||||||
struct tuple_size<GTEST_$(j)_TUPLE_(T) > {
|
|
||||||
static const int value = $j;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
]]
|
|
||||||
template <int k, class Tuple>
|
|
||||||
struct tuple_element {
|
|
||||||
typedef typename gtest_internal::TupleElement<
|
|
||||||
k < (tuple_size<Tuple>::value), k, Tuple>::type type;
|
|
||||||
};
|
|
||||||
|
|
||||||
#define GTEST_TUPLE_ELEMENT_(k, Tuple) typename tuple_element<k, Tuple >::type
|
|
||||||
|
|
||||||
// 6.1.3.4 Element access.
|
|
||||||
|
|
||||||
namespace gtest_internal {
|
|
||||||
|
|
||||||
|
|
||||||
$for i [[
|
|
||||||
template <>
|
|
||||||
class Get<$i> {
|
|
||||||
public:
|
|
||||||
template <class Tuple>
|
|
||||||
static GTEST_ADD_REF_(GTEST_TUPLE_ELEMENT_($i, Tuple))
|
|
||||||
Field(Tuple& t) { return t.f$(i)_; } // NOLINT
|
|
||||||
|
|
||||||
template <class Tuple>
|
|
||||||
static GTEST_BY_REF_(GTEST_TUPLE_ELEMENT_($i, Tuple))
|
|
||||||
ConstField(const Tuple& t) { return t.f$(i)_; }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
]]
|
|
||||||
} // namespace gtest_internal
|
|
||||||
|
|
||||||
template <int k, GTEST_$(n)_TYPENAMES_(T)>
|
|
||||||
GTEST_ADD_REF_(GTEST_TUPLE_ELEMENT_(k, GTEST_$(n)_TUPLE_(T)))
|
|
||||||
get(GTEST_$(n)_TUPLE_(T)& t) {
|
|
||||||
return gtest_internal::Get<k>::Field(t);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <int k, GTEST_$(n)_TYPENAMES_(T)>
|
|
||||||
GTEST_BY_REF_(GTEST_TUPLE_ELEMENT_(k, GTEST_$(n)_TUPLE_(T)))
|
|
||||||
get(const GTEST_$(n)_TUPLE_(T)& t) {
|
|
||||||
return gtest_internal::Get<k>::ConstField(t);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 6.1.3.5 Relational operators
|
|
||||||
|
|
||||||
// We only implement == and !=, as we don't have a need for the rest yet.
|
|
||||||
|
|
||||||
namespace gtest_internal {
|
|
||||||
|
|
||||||
// SameSizeTuplePrefixComparator<k, k>::Eq(t1, t2) returns true if the
|
|
||||||
// first k fields of t1 equals the first k fields of t2.
|
|
||||||
// SameSizeTuplePrefixComparator(k1, k2) would be a compiler error if
|
|
||||||
// k1 != k2.
|
|
||||||
template <int kSize1, int kSize2>
|
|
||||||
struct SameSizeTuplePrefixComparator;
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct SameSizeTuplePrefixComparator<0, 0> {
|
|
||||||
template <class Tuple1, class Tuple2>
|
|
||||||
static bool Eq(const Tuple1& /* t1 */, const Tuple2& /* t2 */) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <int k>
|
|
||||||
struct SameSizeTuplePrefixComparator<k, k> {
|
|
||||||
template <class Tuple1, class Tuple2>
|
|
||||||
static bool Eq(const Tuple1& t1, const Tuple2& t2) {
|
|
||||||
return SameSizeTuplePrefixComparator<k - 1, k - 1>::Eq(t1, t2) &&
|
|
||||||
::std::tr1::get<k - 1>(t1) == ::std::tr1::get<k - 1>(t2);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace gtest_internal
|
|
||||||
|
|
||||||
template <GTEST_$(n)_TYPENAMES_(T), GTEST_$(n)_TYPENAMES_(U)>
|
|
||||||
inline bool operator==(const GTEST_$(n)_TUPLE_(T)& t,
|
|
||||||
const GTEST_$(n)_TUPLE_(U)& u) {
|
|
||||||
return gtest_internal::SameSizeTuplePrefixComparator<
|
|
||||||
tuple_size<GTEST_$(n)_TUPLE_(T) >::value,
|
|
||||||
tuple_size<GTEST_$(n)_TUPLE_(U) >::value>::Eq(t, u);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <GTEST_$(n)_TYPENAMES_(T), GTEST_$(n)_TYPENAMES_(U)>
|
|
||||||
inline bool operator!=(const GTEST_$(n)_TUPLE_(T)& t,
|
|
||||||
const GTEST_$(n)_TUPLE_(U)& u) { return !(t == u); }
|
|
||||||
|
|
||||||
// 6.1.4 Pairs.
|
|
||||||
// Unimplemented.
|
|
||||||
|
|
||||||
} // namespace tr1
|
|
||||||
} // namespace std
|
|
||||||
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
#undef GTEST_$(j)_TUPLE_
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
|
|
||||||
$for j [[
|
|
||||||
#undef GTEST_$(j)_TYPENAMES_
|
|
||||||
|
|
||||||
]]
|
|
||||||
|
|
||||||
#undef GTEST_DECLARE_TUPLE_AS_FRIEND_
|
|
||||||
#undef GTEST_BY_REF_
|
|
||||||
#undef GTEST_ADD_REF_
|
|
||||||
#undef GTEST_TUPLE_ELEMENT_
|
|
||||||
|
|
||||||
#endif // GTEST_INCLUDE_GTEST_INTERNAL_GTEST_TUPLE_H_
|
|
7997
common/protobuf-2.6.1/gtest/m4/libtool.m4
vendored
7997
common/protobuf-2.6.1/gtest/m4/libtool.m4
vendored
File diff suppressed because it is too large
Load Diff
384
common/protobuf-2.6.1/gtest/m4/ltoptions.m4
vendored
384
common/protobuf-2.6.1/gtest/m4/ltoptions.m4
vendored
@ -1,384 +0,0 @@
|
|||||||
# Helper functions for option handling. -*- Autoconf -*-
|
|
||||||
#
|
|
||||||
# Copyright (C) 2004, 2005, 2007, 2008, 2009 Free Software Foundation,
|
|
||||||
# Inc.
|
|
||||||
# Written by Gary V. Vaughan, 2004
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation gives
|
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
|
||||||
# modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 7 ltoptions.m4
|
|
||||||
|
|
||||||
# This is to help aclocal find these macros, as it can't see m4_define.
|
|
||||||
AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME)
|
|
||||||
# ------------------------------------------
|
|
||||||
m4_define([_LT_MANGLE_OPTION],
|
|
||||||
[[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_SET_OPTION(MACRO-NAME, OPTION-NAME)
|
|
||||||
# ---------------------------------------
|
|
||||||
# Set option OPTION-NAME for macro MACRO-NAME, and if there is a
|
|
||||||
# matching handler defined, dispatch to it. Other OPTION-NAMEs are
|
|
||||||
# saved as a flag.
|
|
||||||
m4_define([_LT_SET_OPTION],
|
|
||||||
[m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl
|
|
||||||
m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]),
|
|
||||||
_LT_MANGLE_DEFUN([$1], [$2]),
|
|
||||||
[m4_warning([Unknown $1 option `$2'])])[]dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET])
|
|
||||||
# ------------------------------------------------------------
|
|
||||||
# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
|
|
||||||
m4_define([_LT_IF_OPTION],
|
|
||||||
[m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET)
|
|
||||||
# -------------------------------------------------------
|
|
||||||
# Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME
|
|
||||||
# are set.
|
|
||||||
m4_define([_LT_UNLESS_OPTIONS],
|
|
||||||
[m4_foreach([_LT_Option], m4_split(m4_normalize([$2])),
|
|
||||||
[m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option),
|
|
||||||
[m4_define([$0_found])])])[]dnl
|
|
||||||
m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3
|
|
||||||
])[]dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST)
|
|
||||||
# ----------------------------------------
|
|
||||||
# OPTION-LIST is a space-separated list of Libtool options associated
|
|
||||||
# with MACRO-NAME. If any OPTION has a matching handler declared with
|
|
||||||
# LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about
|
|
||||||
# the unknown option and exit.
|
|
||||||
m4_defun([_LT_SET_OPTIONS],
|
|
||||||
[# Set options
|
|
||||||
m4_foreach([_LT_Option], m4_split(m4_normalize([$2])),
|
|
||||||
[_LT_SET_OPTION([$1], _LT_Option)])
|
|
||||||
|
|
||||||
m4_if([$1],[LT_INIT],[
|
|
||||||
dnl
|
|
||||||
dnl Simply set some default values (i.e off) if boolean options were not
|
|
||||||
dnl specified:
|
|
||||||
_LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no
|
|
||||||
])
|
|
||||||
_LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no
|
|
||||||
])
|
|
||||||
dnl
|
|
||||||
dnl If no reference was made to various pairs of opposing options, then
|
|
||||||
dnl we run the default mode handler for the pair. For example, if neither
|
|
||||||
dnl `shared' nor `disable-shared' was passed, we enable building of shared
|
|
||||||
dnl archives by default:
|
|
||||||
_LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED])
|
|
||||||
_LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC])
|
|
||||||
_LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC])
|
|
||||||
_LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install],
|
|
||||||
[_LT_ENABLE_FAST_INSTALL])
|
|
||||||
])
|
|
||||||
])# _LT_SET_OPTIONS
|
|
||||||
|
|
||||||
|
|
||||||
## --------------------------------- ##
|
|
||||||
## Macros to handle LT_INIT options. ##
|
|
||||||
## --------------------------------- ##
|
|
||||||
|
|
||||||
# _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME)
|
|
||||||
# -----------------------------------------
|
|
||||||
m4_define([_LT_MANGLE_DEFUN],
|
|
||||||
[[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])])
|
|
||||||
|
|
||||||
|
|
||||||
# LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE)
|
|
||||||
# -----------------------------------------------
|
|
||||||
m4_define([LT_OPTION_DEFINE],
|
|
||||||
[m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl
|
|
||||||
])# LT_OPTION_DEFINE
|
|
||||||
|
|
||||||
|
|
||||||
# dlopen
|
|
||||||
# ------
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes
|
|
||||||
])
|
|
||||||
|
|
||||||
AU_DEFUN([AC_LIBTOOL_DLOPEN],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], [dlopen])
|
|
||||||
AC_DIAGNOSE([obsolete],
|
|
||||||
[$0: Remove this warning and the call to _LT_SET_OPTION when you
|
|
||||||
put the `dlopen' option into LT_INIT's first parameter.])
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl aclocal-1.4 backwards compatibility:
|
|
||||||
dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], [])
|
|
||||||
|
|
||||||
|
|
||||||
# win32-dll
|
|
||||||
# ---------
|
|
||||||
# Declare package support for building win32 dll's.
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [win32-dll],
|
|
||||||
[enable_win32_dll=yes
|
|
||||||
|
|
||||||
case $host in
|
|
||||||
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*)
|
|
||||||
AC_CHECK_TOOL(AS, as, false)
|
|
||||||
AC_CHECK_TOOL(DLLTOOL, dlltool, false)
|
|
||||||
AC_CHECK_TOOL(OBJDUMP, objdump, false)
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
test -z "$AS" && AS=as
|
|
||||||
_LT_DECL([], [AS], [1], [Assembler program])dnl
|
|
||||||
|
|
||||||
test -z "$DLLTOOL" && DLLTOOL=dlltool
|
|
||||||
_LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl
|
|
||||||
|
|
||||||
test -z "$OBJDUMP" && OBJDUMP=objdump
|
|
||||||
_LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl
|
|
||||||
])# win32-dll
|
|
||||||
|
|
||||||
AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
|
|
||||||
[AC_REQUIRE([AC_CANONICAL_HOST])dnl
|
|
||||||
_LT_SET_OPTION([LT_INIT], [win32-dll])
|
|
||||||
AC_DIAGNOSE([obsolete],
|
|
||||||
[$0: Remove this warning and the call to _LT_SET_OPTION when you
|
|
||||||
put the `win32-dll' option into LT_INIT's first parameter.])
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl aclocal-1.4 backwards compatibility:
|
|
||||||
dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], [])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_ENABLE_SHARED([DEFAULT])
|
|
||||||
# ----------------------------
|
|
||||||
# implement the --enable-shared flag, and supports the `shared' and
|
|
||||||
# `disable-shared' LT_INIT options.
|
|
||||||
# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
|
|
||||||
m4_define([_LT_ENABLE_SHARED],
|
|
||||||
[m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl
|
|
||||||
AC_ARG_ENABLE([shared],
|
|
||||||
[AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@],
|
|
||||||
[build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])],
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case $enableval in
|
|
||||||
yes) enable_shared=yes ;;
|
|
||||||
no) enable_shared=no ;;
|
|
||||||
*)
|
|
||||||
enable_shared=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_shared=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
[enable_shared=]_LT_ENABLE_SHARED_DEFAULT)
|
|
||||||
|
|
||||||
_LT_DECL([build_libtool_libs], [enable_shared], [0],
|
|
||||||
[Whether or not to build shared libraries])
|
|
||||||
])# _LT_ENABLE_SHARED
|
|
||||||
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])])
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])])
|
|
||||||
|
|
||||||
# Old names:
|
|
||||||
AC_DEFUN([AC_ENABLE_SHARED],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN([AC_DISABLE_SHARED],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], [disable-shared])
|
|
||||||
])
|
|
||||||
|
|
||||||
AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)])
|
|
||||||
AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)])
|
|
||||||
|
|
||||||
dnl aclocal-1.4 backwards compatibility:
|
|
||||||
dnl AC_DEFUN([AM_ENABLE_SHARED], [])
|
|
||||||
dnl AC_DEFUN([AM_DISABLE_SHARED], [])
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_ENABLE_STATIC([DEFAULT])
|
|
||||||
# ----------------------------
|
|
||||||
# implement the --enable-static flag, and support the `static' and
|
|
||||||
# `disable-static' LT_INIT options.
|
|
||||||
# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
|
|
||||||
m4_define([_LT_ENABLE_STATIC],
|
|
||||||
[m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl
|
|
||||||
AC_ARG_ENABLE([static],
|
|
||||||
[AS_HELP_STRING([--enable-static@<:@=PKGS@:>@],
|
|
||||||
[build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])],
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case $enableval in
|
|
||||||
yes) enable_static=yes ;;
|
|
||||||
no) enable_static=no ;;
|
|
||||||
*)
|
|
||||||
enable_static=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_static=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
[enable_static=]_LT_ENABLE_STATIC_DEFAULT)
|
|
||||||
|
|
||||||
_LT_DECL([build_old_libs], [enable_static], [0],
|
|
||||||
[Whether or not to build static libraries])
|
|
||||||
])# _LT_ENABLE_STATIC
|
|
||||||
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])])
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])])
|
|
||||||
|
|
||||||
# Old names:
|
|
||||||
AC_DEFUN([AC_ENABLE_STATIC],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN([AC_DISABLE_STATIC],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], [disable-static])
|
|
||||||
])
|
|
||||||
|
|
||||||
AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)])
|
|
||||||
AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)])
|
|
||||||
|
|
||||||
dnl aclocal-1.4 backwards compatibility:
|
|
||||||
dnl AC_DEFUN([AM_ENABLE_STATIC], [])
|
|
||||||
dnl AC_DEFUN([AM_DISABLE_STATIC], [])
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_ENABLE_FAST_INSTALL([DEFAULT])
|
|
||||||
# ----------------------------------
|
|
||||||
# implement the --enable-fast-install flag, and support the `fast-install'
|
|
||||||
# and `disable-fast-install' LT_INIT options.
|
|
||||||
# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
|
|
||||||
m4_define([_LT_ENABLE_FAST_INSTALL],
|
|
||||||
[m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl
|
|
||||||
AC_ARG_ENABLE([fast-install],
|
|
||||||
[AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@],
|
|
||||||
[optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])],
|
|
||||||
[p=${PACKAGE-default}
|
|
||||||
case $enableval in
|
|
||||||
yes) enable_fast_install=yes ;;
|
|
||||||
no) enable_fast_install=no ;;
|
|
||||||
*)
|
|
||||||
enable_fast_install=no
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
|
||||||
for pkg in $enableval; do
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
if test "X$pkg" = "X$p"; then
|
|
||||||
enable_fast_install=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
[enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT)
|
|
||||||
|
|
||||||
_LT_DECL([fast_install], [enable_fast_install], [0],
|
|
||||||
[Whether or not to optimize for fast installation])dnl
|
|
||||||
])# _LT_ENABLE_FAST_INSTALL
|
|
||||||
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])])
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])])
|
|
||||||
|
|
||||||
# Old names:
|
|
||||||
AU_DEFUN([AC_ENABLE_FAST_INSTALL],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install])
|
|
||||||
AC_DIAGNOSE([obsolete],
|
|
||||||
[$0: Remove this warning and the call to _LT_SET_OPTION when you put
|
|
||||||
the `fast-install' option into LT_INIT's first parameter.])
|
|
||||||
])
|
|
||||||
|
|
||||||
AU_DEFUN([AC_DISABLE_FAST_INSTALL],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], [disable-fast-install])
|
|
||||||
AC_DIAGNOSE([obsolete],
|
|
||||||
[$0: Remove this warning and the call to _LT_SET_OPTION when you put
|
|
||||||
the `disable-fast-install' option into LT_INIT's first parameter.])
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl aclocal-1.4 backwards compatibility:
|
|
||||||
dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], [])
|
|
||||||
dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], [])
|
|
||||||
|
|
||||||
|
|
||||||
# _LT_WITH_PIC([MODE])
|
|
||||||
# --------------------
|
|
||||||
# implement the --with-pic flag, and support the `pic-only' and `no-pic'
|
|
||||||
# LT_INIT options.
|
|
||||||
# MODE is either `yes' or `no'. If omitted, it defaults to `both'.
|
|
||||||
m4_define([_LT_WITH_PIC],
|
|
||||||
[AC_ARG_WITH([pic],
|
|
||||||
[AS_HELP_STRING([--with-pic@<:@=PKGS@:>@],
|
|
||||||
[try to use only PIC/non-PIC objects @<:@default=use both@:>@])],
|
|
||||||
[lt_p=${PACKAGE-default}
|
|
||||||
case $withval in
|
|
||||||
yes|no) pic_mode=$withval ;;
|
|
||||||
*)
|
|
||||||
pic_mode=default
|
|
||||||
# Look at the argument we got. We use all the common list separators.
|
|
||||||
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
|
||||||
for lt_pkg in $withval; do
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
if test "X$lt_pkg" = "X$lt_p"; then
|
|
||||||
pic_mode=yes
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
IFS="$lt_save_ifs"
|
|
||||||
;;
|
|
||||||
esac],
|
|
||||||
[pic_mode=default])
|
|
||||||
|
|
||||||
test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
|
|
||||||
|
|
||||||
_LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl
|
|
||||||
])# _LT_WITH_PIC
|
|
||||||
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])])
|
|
||||||
LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])])
|
|
||||||
|
|
||||||
# Old name:
|
|
||||||
AU_DEFUN([AC_LIBTOOL_PICMODE],
|
|
||||||
[_LT_SET_OPTION([LT_INIT], [pic-only])
|
|
||||||
AC_DIAGNOSE([obsolete],
|
|
||||||
[$0: Remove this warning and the call to _LT_SET_OPTION when you
|
|
||||||
put the `pic-only' option into LT_INIT's first parameter.])
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl aclocal-1.4 backwards compatibility:
|
|
||||||
dnl AC_DEFUN([AC_LIBTOOL_PICMODE], [])
|
|
||||||
|
|
||||||
## ----------------- ##
|
|
||||||
## LTDL_INIT Options ##
|
|
||||||
## ----------------- ##
|
|
||||||
|
|
||||||
m4_define([_LTDL_MODE], [])
|
|
||||||
LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive],
|
|
||||||
[m4_define([_LTDL_MODE], [nonrecursive])])
|
|
||||||
LT_OPTION_DEFINE([LTDL_INIT], [recursive],
|
|
||||||
[m4_define([_LTDL_MODE], [recursive])])
|
|
||||||
LT_OPTION_DEFINE([LTDL_INIT], [subproject],
|
|
||||||
[m4_define([_LTDL_MODE], [subproject])])
|
|
||||||
|
|
||||||
m4_define([_LTDL_TYPE], [])
|
|
||||||
LT_OPTION_DEFINE([LTDL_INIT], [installable],
|
|
||||||
[m4_define([_LTDL_TYPE], [installable])])
|
|
||||||
LT_OPTION_DEFINE([LTDL_INIT], [convenience],
|
|
||||||
[m4_define([_LTDL_TYPE], [convenience])])
|
|
123
common/protobuf-2.6.1/gtest/m4/ltsugar.m4
vendored
123
common/protobuf-2.6.1/gtest/m4/ltsugar.m4
vendored
@ -1,123 +0,0 @@
|
|||||||
# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*-
|
|
||||||
#
|
|
||||||
# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
|
|
||||||
# Written by Gary V. Vaughan, 2004
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation gives
|
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
|
||||||
# modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 6 ltsugar.m4
|
|
||||||
|
|
||||||
# This is to help aclocal find these macros, as it can't see m4_define.
|
|
||||||
AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_join(SEP, ARG1, [ARG2...])
|
|
||||||
# -----------------------------
|
|
||||||
# Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their
|
|
||||||
# associated separator.
|
|
||||||
# Needed until we can rely on m4_join from Autoconf 2.62, since all earlier
|
|
||||||
# versions in m4sugar had bugs.
|
|
||||||
m4_define([lt_join],
|
|
||||||
[m4_if([$#], [1], [],
|
|
||||||
[$#], [2], [[$2]],
|
|
||||||
[m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])])
|
|
||||||
m4_define([_lt_join],
|
|
||||||
[m4_if([$#$2], [2], [],
|
|
||||||
[m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_car(LIST)
|
|
||||||
# lt_cdr(LIST)
|
|
||||||
# ------------
|
|
||||||
# Manipulate m4 lists.
|
|
||||||
# These macros are necessary as long as will still need to support
|
|
||||||
# Autoconf-2.59 which quotes differently.
|
|
||||||
m4_define([lt_car], [[$1]])
|
|
||||||
m4_define([lt_cdr],
|
|
||||||
[m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])],
|
|
||||||
[$#], 1, [],
|
|
||||||
[m4_dquote(m4_shift($@))])])
|
|
||||||
m4_define([lt_unquote], $1)
|
|
||||||
|
|
||||||
|
|
||||||
# lt_append(MACRO-NAME, STRING, [SEPARATOR])
|
|
||||||
# ------------------------------------------
|
|
||||||
# Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'.
|
|
||||||
# Note that neither SEPARATOR nor STRING are expanded; they are appended
|
|
||||||
# to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked).
|
|
||||||
# No SEPARATOR is output if MACRO-NAME was previously undefined (different
|
|
||||||
# than defined and empty).
|
|
||||||
#
|
|
||||||
# This macro is needed until we can rely on Autoconf 2.62, since earlier
|
|
||||||
# versions of m4sugar mistakenly expanded SEPARATOR but not STRING.
|
|
||||||
m4_define([lt_append],
|
|
||||||
[m4_define([$1],
|
|
||||||
m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])])
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...])
|
|
||||||
# ----------------------------------------------------------
|
|
||||||
# Produce a SEP delimited list of all paired combinations of elements of
|
|
||||||
# PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list
|
|
||||||
# has the form PREFIXmINFIXSUFFIXn.
|
|
||||||
# Needed until we can rely on m4_combine added in Autoconf 2.62.
|
|
||||||
m4_define([lt_combine],
|
|
||||||
[m4_if(m4_eval([$# > 3]), [1],
|
|
||||||
[m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl
|
|
||||||
[[m4_foreach([_Lt_prefix], [$2],
|
|
||||||
[m4_foreach([_Lt_suffix],
|
|
||||||
]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[,
|
|
||||||
[_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ])
|
|
||||||
# -----------------------------------------------------------------------
|
|
||||||
# Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited
|
|
||||||
# by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ.
|
|
||||||
m4_define([lt_if_append_uniq],
|
|
||||||
[m4_ifdef([$1],
|
|
||||||
[m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1],
|
|
||||||
[lt_append([$1], [$2], [$3])$4],
|
|
||||||
[$5])],
|
|
||||||
[lt_append([$1], [$2], [$3])$4])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_dict_add(DICT, KEY, VALUE)
|
|
||||||
# -----------------------------
|
|
||||||
m4_define([lt_dict_add],
|
|
||||||
[m4_define([$1($2)], [$3])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE)
|
|
||||||
# --------------------------------------------
|
|
||||||
m4_define([lt_dict_add_subkey],
|
|
||||||
[m4_define([$1($2:$3)], [$4])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_dict_fetch(DICT, KEY, [SUBKEY])
|
|
||||||
# ----------------------------------
|
|
||||||
m4_define([lt_dict_fetch],
|
|
||||||
[m4_ifval([$3],
|
|
||||||
m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]),
|
|
||||||
m4_ifdef([$1($2)], [m4_defn([$1($2)])]))])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE])
|
|
||||||
# -----------------------------------------------------------------
|
|
||||||
m4_define([lt_if_dict_fetch],
|
|
||||||
[m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4],
|
|
||||||
[$5],
|
|
||||||
[$6])])
|
|
||||||
|
|
||||||
|
|
||||||
# lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...])
|
|
||||||
# --------------------------------------------------------------
|
|
||||||
m4_define([lt_dict_filter],
|
|
||||||
[m4_if([$5], [], [],
|
|
||||||
[lt_join(m4_quote(m4_default([$4], [[, ]])),
|
|
||||||
lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]),
|
|
||||||
[lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl
|
|
||||||
])
|
|
23
common/protobuf-2.6.1/gtest/m4/ltversion.m4
vendored
23
common/protobuf-2.6.1/gtest/m4/ltversion.m4
vendored
@ -1,23 +0,0 @@
|
|||||||
# ltversion.m4 -- version numbers -*- Autoconf -*-
|
|
||||||
#
|
|
||||||
# Copyright (C) 2004 Free Software Foundation, Inc.
|
|
||||||
# Written by Scott James Remnant, 2004
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation gives
|
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
|
||||||
# modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# @configure_input@
|
|
||||||
|
|
||||||
# serial 3337 ltversion.m4
|
|
||||||
# This file is part of GNU Libtool
|
|
||||||
|
|
||||||
m4_define([LT_PACKAGE_VERSION], [2.4.2])
|
|
||||||
m4_define([LT_PACKAGE_REVISION], [1.3337])
|
|
||||||
|
|
||||||
AC_DEFUN([LTVERSION_VERSION],
|
|
||||||
[macro_version='2.4.2'
|
|
||||||
macro_revision='1.3337'
|
|
||||||
_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
|
|
||||||
_LT_DECL(, macro_revision, 0)
|
|
||||||
])
|
|
98
common/protobuf-2.6.1/gtest/m4/lt~obsolete.m4
vendored
98
common/protobuf-2.6.1/gtest/m4/lt~obsolete.m4
vendored
@ -1,98 +0,0 @@
|
|||||||
# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*-
|
|
||||||
#
|
|
||||||
# Copyright (C) 2004, 2005, 2007, 2009 Free Software Foundation, Inc.
|
|
||||||
# Written by Scott James Remnant, 2004.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation gives
|
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
|
||||||
# modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 5 lt~obsolete.m4
|
|
||||||
|
|
||||||
# These exist entirely to fool aclocal when bootstrapping libtool.
|
|
||||||
#
|
|
||||||
# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN)
|
|
||||||
# which have later been changed to m4_define as they aren't part of the
|
|
||||||
# exported API, or moved to Autoconf or Automake where they belong.
|
|
||||||
#
|
|
||||||
# The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN
|
|
||||||
# in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us
|
|
||||||
# using a macro with the same name in our local m4/libtool.m4 it'll
|
|
||||||
# pull the old libtool.m4 in (it doesn't see our shiny new m4_define
|
|
||||||
# and doesn't know about Autoconf macros at all.)
|
|
||||||
#
|
|
||||||
# So we provide this file, which has a silly filename so it's always
|
|
||||||
# included after everything else. This provides aclocal with the
|
|
||||||
# AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything
|
|
||||||
# because those macros already exist, or will be overwritten later.
|
|
||||||
# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6.
|
|
||||||
#
|
|
||||||
# Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here.
|
|
||||||
# Yes, that means every name once taken will need to remain here until
|
|
||||||
# we give up compatibility with versions before 1.7, at which point
|
|
||||||
# we need to keep only those names which we still refer to.
|
|
||||||
|
|
||||||
# This is to help aclocal find these macros, as it can't see m4_define.
|
|
||||||
AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])])
|
|
||||||
|
|
||||||
m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])])
|
|
||||||
m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])])
|
|
||||||
m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])])
|
|
||||||
m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])])
|
|
||||||
m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])])
|
|
||||||
m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])])
|
|
||||||
m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])])
|
|
||||||
m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])])
|
|
||||||
m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])])
|
|
||||||
m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])])
|
|
||||||
m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])])
|
|
||||||
m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])])
|
|
||||||
m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])])
|
|
||||||
m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])])
|
|
||||||
m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])])
|
|
||||||
m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])])
|
|
||||||
m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])])
|
|
||||||
m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])])
|
|
||||||
m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])])
|
|
||||||
m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])])
|
|
||||||
m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])])
|
|
||||||
m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])])
|
|
||||||
m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])])
|
|
||||||
m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])])
|
|
||||||
m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])])
|
|
||||||
m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])])
|
|
||||||
m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])])
|
|
||||||
m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])])
|
|
||||||
m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])])
|
|
||||||
m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])])
|
|
||||||
m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])])
|
|
||||||
m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])])
|
|
||||||
m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])])
|
|
||||||
m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])])
|
|
||||||
m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])])
|
|
@ -1,80 +0,0 @@
|
|||||||
# A sample Makefile for building Google Test and using it in user
|
|
||||||
# tests. Please tweak it to suit your environment and project. You
|
|
||||||
# may want to move it to your project's root directory.
|
|
||||||
#
|
|
||||||
# SYNOPSIS:
|
|
||||||
#
|
|
||||||
# make [all] - makes everything.
|
|
||||||
# make TARGET - makes the given target.
|
|
||||||
# make clean - removes all files generated by make.
|
|
||||||
|
|
||||||
# Please tweak the following variable definitions as needed by your
|
|
||||||
# project, except GTEST_HEADERS, which you can use in your own targets
|
|
||||||
# but shouldn't modify.
|
|
||||||
|
|
||||||
# Points to the root of Google Test, relative to where this file is.
|
|
||||||
# Remember to tweak this if you move this file.
|
|
||||||
GTEST_DIR = ..
|
|
||||||
|
|
||||||
# Where to find user code.
|
|
||||||
USER_DIR = ../samples
|
|
||||||
|
|
||||||
# Flags passed to the preprocessor.
|
|
||||||
CPPFLAGS += -I$(GTEST_DIR)/include
|
|
||||||
|
|
||||||
# Flags passed to the C++ compiler.
|
|
||||||
CXXFLAGS += -g -Wall -Wextra
|
|
||||||
|
|
||||||
# All tests produced by this Makefile. Remember to add new tests you
|
|
||||||
# created to the list.
|
|
||||||
TESTS = sample1_unittest
|
|
||||||
|
|
||||||
# All Google Test headers. Usually you shouldn't change this
|
|
||||||
# definition.
|
|
||||||
GTEST_HEADERS = $(GTEST_DIR)/include/gtest/*.h \
|
|
||||||
$(GTEST_DIR)/include/gtest/internal/*.h
|
|
||||||
|
|
||||||
# House-keeping build targets.
|
|
||||||
|
|
||||||
all : $(TESTS)
|
|
||||||
|
|
||||||
clean :
|
|
||||||
rm -f $(TESTS) gtest.a gtest_main.a *.o
|
|
||||||
|
|
||||||
# Builds gtest.a and gtest_main.a.
|
|
||||||
|
|
||||||
# Usually you shouldn't tweak such internal variables, indicated by a
|
|
||||||
# trailing _.
|
|
||||||
GTEST_SRCS_ = $(GTEST_DIR)/src/*.cc $(GTEST_DIR)/src/*.h $(GTEST_HEADERS)
|
|
||||||
|
|
||||||
# For simplicity and to avoid depending on Google Test's
|
|
||||||
# implementation details, the dependencies specified below are
|
|
||||||
# conservative and not optimized. This is fine as Google Test
|
|
||||||
# compiles fast and for ordinary users its source rarely changes.
|
|
||||||
gtest-all.o : $(GTEST_SRCS_)
|
|
||||||
$(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) -c \
|
|
||||||
$(GTEST_DIR)/src/gtest-all.cc
|
|
||||||
|
|
||||||
gtest_main.o : $(GTEST_SRCS_)
|
|
||||||
$(CXX) $(CPPFLAGS) -I$(GTEST_DIR) $(CXXFLAGS) -c \
|
|
||||||
$(GTEST_DIR)/src/gtest_main.cc
|
|
||||||
|
|
||||||
gtest.a : gtest-all.o
|
|
||||||
$(AR) $(ARFLAGS) $@ $^
|
|
||||||
|
|
||||||
gtest_main.a : gtest-all.o gtest_main.o
|
|
||||||
$(AR) $(ARFLAGS) $@ $^
|
|
||||||
|
|
||||||
# Builds a sample test. A test should link with either gtest.a or
|
|
||||||
# gtest_main.a, depending on whether it defines its own main()
|
|
||||||
# function.
|
|
||||||
|
|
||||||
sample1.o : $(USER_DIR)/sample1.cc $(USER_DIR)/sample1.h $(GTEST_HEADERS)
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(USER_DIR)/sample1.cc
|
|
||||||
|
|
||||||
sample1_unittest.o : $(USER_DIR)/sample1_unittest.cc \
|
|
||||||
$(USER_DIR)/sample1.h $(GTEST_HEADERS)
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(USER_DIR)/sample1_unittest.cc
|
|
||||||
|
|
||||||
sample1_unittest : sample1.o sample1_unittest.o gtest_main.a
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -lpthread $^ -o $@
|
|
@ -1,45 +0,0 @@
|
|||||||
Microsoft Visual Studio Solution File, Format Version 8.00
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest-md", "gtest-md.vcproj", "{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest_main-md", "gtest_main-md.vcproj", "{3AF54C8A-10BF-4332-9147-F68ED9862033}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest_prod_test-md", "gtest_prod_test-md.vcproj", "{24848551-EF4F-47E8-9A9D-EA4D49BC3ECB}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest_unittest-md", "gtest_unittest-md.vcproj", "{4D9FDFB5-986A-4139-823C-F4EE0ED481A2}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Global
|
|
||||||
GlobalSection(SolutionConfiguration) = preSolution
|
|
||||||
Debug = Debug
|
|
||||||
Release = Release
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ProjectConfiguration) = postSolution
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}.Debug.Build.0 = Debug|Win32
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}.Release.ActiveCfg = Release|Win32
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}.Release.Build.0 = Release|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862033}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862033}.Debug.Build.0 = Debug|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862033}.Release.ActiveCfg = Release|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862033}.Release.Build.0 = Release|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECB}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECB}.Debug.Build.0 = Debug|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECB}.Release.ActiveCfg = Release|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECB}.Release.Build.0 = Release|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A2}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A2}.Debug.Build.0 = Debug|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A2}.Release.ActiveCfg = Release|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A2}.Release.Build.0 = Release|Win32
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ExtensibilityAddIns) = postSolution
|
|
||||||
EndGlobalSection
|
|
||||||
EndGlobal
|
|
@ -1,126 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest-md"
|
|
||||||
ProjectGUID="{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath="">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_LIB"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/gtestd.lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath=""..\include";".."">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_LIB"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/gtest.lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\src\gtest-all.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,45 +0,0 @@
|
|||||||
Microsoft Visual Studio Solution File, Format Version 8.00
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest", "gtest.vcproj", "{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest_main", "gtest_main.vcproj", "{3AF54C8A-10BF-4332-9147-F68ED9862032}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest_unittest", "gtest_unittest.vcproj", "{4D9FDFB5-986A-4139-823C-F4EE0ED481A1}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "gtest_prod_test", "gtest_prod_test.vcproj", "{24848551-EF4F-47E8-9A9D-EA4D49BC3ECA}"
|
|
||||||
ProjectSection(ProjectDependencies) = postProject
|
|
||||||
EndProjectSection
|
|
||||||
EndProject
|
|
||||||
Global
|
|
||||||
GlobalSection(SolutionConfiguration) = preSolution
|
|
||||||
Debug = Debug
|
|
||||||
Release = Release
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ProjectConfiguration) = postSolution
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}.Debug.Build.0 = Debug|Win32
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}.Release.ActiveCfg = Release|Win32
|
|
||||||
{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}.Release.Build.0 = Release|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862032}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862032}.Debug.Build.0 = Debug|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862032}.Release.ActiveCfg = Release|Win32
|
|
||||||
{3AF54C8A-10BF-4332-9147-F68ED9862032}.Release.Build.0 = Release|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A1}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A1}.Debug.Build.0 = Debug|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A1}.Release.ActiveCfg = Release|Win32
|
|
||||||
{4D9FDFB5-986A-4139-823C-F4EE0ED481A1}.Release.Build.0 = Release|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECA}.Debug.ActiveCfg = Debug|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECA}.Debug.Build.0 = Debug|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECA}.Release.ActiveCfg = Release|Win32
|
|
||||||
{24848551-EF4F-47E8-9A9D-EA4D49BC3ECA}.Release.Build.0 = Release|Win32
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
|
||||||
EndGlobalSection
|
|
||||||
GlobalSection(ExtensibilityAddIns) = postSolution
|
|
||||||
EndGlobalSection
|
|
||||||
EndGlobal
|
|
@ -1,126 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest"
|
|
||||||
ProjectGUID="{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath="">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_LIB"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/gtestd.lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath=""..\include";".."">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_LIB"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/gtest.lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\src\gtest-all.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,129 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest_main-md"
|
|
||||||
ProjectGUID="{3AF54C8A-10BF-4332-9147-F68ED9862033}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath="">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_LIB"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/$(ProjectName)d.lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath=""..\include";".."">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_LIB"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/$(ProjectName).lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
<ProjectReference
|
|
||||||
ReferencedProjectIdentifier="{C8F6C172-56F2-4E76-B5FA-C3B423B31BE8}"
|
|
||||||
Name="gtest-md"/>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\src\gtest_main.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,129 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest_main"
|
|
||||||
ProjectGUID="{3AF54C8A-10BF-4332-9147-F68ED9862032}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath="">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_LIB"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/$(ProjectName)d.lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="4"
|
|
||||||
CharacterSet="2"
|
|
||||||
ReferencesPath=""..\include";".."">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_LIB"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLibrarianTool"
|
|
||||||
OutputFile="$(OutDir)/$(ProjectName).lib"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
<ProjectReference
|
|
||||||
ReferencedProjectIdentifier="{C8F6C172-56F2-4E76-B5FA-C3B423B31BE7}"
|
|
||||||
Name="gtest"/>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\src\gtest_main.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,164 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest_prod_test-md"
|
|
||||||
ProjectGUID="{24848551-EF4F-47E8-9A9D-EA4D49BC3ECB}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_CONSOLE"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_prod_test.exe"
|
|
||||||
LinkIncremental="2"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
ProgramDatabaseFile="$(OutDir)/gtest_prod_test.pdb"
|
|
||||||
SubSystem="1"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_CONSOLE"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_prod_test.exe"
|
|
||||||
LinkIncremental="1"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
SubSystem="1"
|
|
||||||
OptimizeReferences="2"
|
|
||||||
EnableCOMDATFolding="2"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
<ProjectReference
|
|
||||||
ReferencedProjectIdentifier="{3AF54C8A-10BF-4332-9147-F68ED9862033}"
|
|
||||||
Name="gtest_main-md"/>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\gtest_prod_test.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\production.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\production.h">
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,164 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest_prod_test"
|
|
||||||
ProjectGUID="{24848551-EF4F-47E8-9A9D-EA4D49BC3ECA}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_CONSOLE"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_prod_test.exe"
|
|
||||||
LinkIncremental="2"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
ProgramDatabaseFile="$(OutDir)/gtest_prod_test.pdb"
|
|
||||||
SubSystem="1"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_CONSOLE"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_prod_test.exe"
|
|
||||||
LinkIncremental="1"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
SubSystem="1"
|
|
||||||
OptimizeReferences="2"
|
|
||||||
EnableCOMDATFolding="2"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
<ProjectReference
|
|
||||||
ReferencedProjectIdentifier="{3AF54C8A-10BF-4332-9147-F68ED9862032}"
|
|
||||||
Name="gtest_main"/>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\gtest_prod_test.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\production.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\production.h">
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,147 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest_unittest-md"
|
|
||||||
ProjectGUID="{4D9FDFB5-986A-4139-823C-F4EE0ED481A2}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_CONSOLE"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_unittest.exe"
|
|
||||||
LinkIncremental="2"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
ProgramDatabaseFile="$(OutDir)/gtest_unittest.pdb"
|
|
||||||
SubSystem="1"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_CONSOLE"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_unittest.exe"
|
|
||||||
LinkIncremental="1"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
SubSystem="1"
|
|
||||||
OptimizeReferences="2"
|
|
||||||
EnableCOMDATFolding="2"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
<ProjectReference
|
|
||||||
ReferencedProjectIdentifier="{3AF54C8A-10BF-4332-9147-F68ED9862033}"
|
|
||||||
Name="gtest_main-md"/>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\gtest_unittest.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="1"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
BasicRuntimeChecks="0"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,147 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="Windows-1252"?>
|
|
||||||
<VisualStudioProject
|
|
||||||
ProjectType="Visual C++"
|
|
||||||
Version="7.10"
|
|
||||||
Name="gtest_unittest"
|
|
||||||
ProjectGUID="{4D9FDFB5-986A-4139-823C-F4EE0ED481A1}"
|
|
||||||
Keyword="Win32Proj">
|
|
||||||
<Platforms>
|
|
||||||
<Platform
|
|
||||||
Name="Win32"/>
|
|
||||||
</Platforms>
|
|
||||||
<Configurations>
|
|
||||||
<Configuration
|
|
||||||
Name="Debug|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="0"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;_DEBUG;_CONSOLE"
|
|
||||||
MinimalRebuild="TRUE"
|
|
||||||
BasicRuntimeChecks="3"
|
|
||||||
RuntimeLibrary="3"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="4"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_unittest.exe"
|
|
||||||
LinkIncremental="2"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
ProgramDatabaseFile="$(OutDir)/gtest_unittest.pdb"
|
|
||||||
SubSystem="1"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
<Configuration
|
|
||||||
Name="Release|Win32"
|
|
||||||
OutputDirectory="$(SolutionName)/$(ConfigurationName)"
|
|
||||||
IntermediateDirectory="$(OutDir)/$(ProjectName)"
|
|
||||||
ConfigurationType="1"
|
|
||||||
CharacterSet="2">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
PreprocessorDefinitions="_VARIADIC_MAX=10;WIN32;NDEBUG;_CONSOLE"
|
|
||||||
RuntimeLibrary="2"
|
|
||||||
UsePrecompiledHeader="3"
|
|
||||||
WarningLevel="3"
|
|
||||||
Detect64BitPortabilityProblems="FALSE"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCCustomBuildTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCLinkerTool"
|
|
||||||
OutputFile="$(OutDir)/gtest_unittest.exe"
|
|
||||||
LinkIncremental="1"
|
|
||||||
GenerateDebugInformation="TRUE"
|
|
||||||
SubSystem="1"
|
|
||||||
OptimizeReferences="2"
|
|
||||||
EnableCOMDATFolding="2"
|
|
||||||
TargetMachine="1"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCMIDLTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPostBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreBuildEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCPreLinkEventTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCResourceCompilerTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebServiceProxyGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCXMLDataGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCWebDeploymentTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCManagedWrapperGeneratorTool"/>
|
|
||||||
<Tool
|
|
||||||
Name="VCAuxiliaryManagedWrapperGeneratorTool"/>
|
|
||||||
</Configuration>
|
|
||||||
</Configurations>
|
|
||||||
<References>
|
|
||||||
<ProjectReference
|
|
||||||
ReferencedProjectIdentifier="{3AF54C8A-10BF-4332-9147-F68ED9862032}"
|
|
||||||
Name="gtest_main"/>
|
|
||||||
</References>
|
|
||||||
<Files>
|
|
||||||
<Filter
|
|
||||||
Name="Source Files"
|
|
||||||
Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx"
|
|
||||||
UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}">
|
|
||||||
<File
|
|
||||||
RelativePath="..\test\gtest_unittest.cc">
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Debug|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
Optimization="1"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
BasicRuntimeChecks="0"
|
|
||||||
UsePrecompiledHeader="0"
|
|
||||||
DebugInformationFormat="3"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
<FileConfiguration
|
|
||||||
Name="Release|Win32">
|
|
||||||
<Tool
|
|
||||||
Name="VCCLCompilerTool"
|
|
||||||
AdditionalIncludeDirectories=""..";"..\include""
|
|
||||||
UsePrecompiledHeader="0"/>
|
|
||||||
</FileConfiguration>
|
|
||||||
</File>
|
|
||||||
</Filter>
|
|
||||||
<Filter
|
|
||||||
Name="Header Files"
|
|
||||||
Filter="h;hpp;hxx;hm;inl;inc;xsd"
|
|
||||||
UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}">
|
|
||||||
</Filter>
|
|
||||||
</Files>
|
|
||||||
<Globals>
|
|
||||||
</Globals>
|
|
||||||
</VisualStudioProject>
|
|
@ -1,59 +0,0 @@
|
|||||||
# A Makefile for fusing Google Test and building a sample test against it.
|
|
||||||
#
|
|
||||||
# SYNOPSIS:
|
|
||||||
#
|
|
||||||
# make [all] - makes everything.
|
|
||||||
# make TARGET - makes the given target.
|
|
||||||
# make check - makes everything and runs the built sample test.
|
|
||||||
# make clean - removes all files generated by make.
|
|
||||||
|
|
||||||
# Points to the root of fused Google Test, relative to where this file is.
|
|
||||||
FUSED_GTEST_DIR = output
|
|
||||||
|
|
||||||
# Paths to the fused gtest files.
|
|
||||||
FUSED_GTEST_H = $(FUSED_GTEST_DIR)/gtest/gtest.h
|
|
||||||
FUSED_GTEST_ALL_CC = $(FUSED_GTEST_DIR)/gtest/gtest-all.cc
|
|
||||||
|
|
||||||
# Where to find the sample test.
|
|
||||||
SAMPLE_DIR = ../../samples
|
|
||||||
|
|
||||||
# Where to find gtest_main.cc.
|
|
||||||
GTEST_MAIN_CC = ../../src/gtest_main.cc
|
|
||||||
|
|
||||||
# Flags passed to the preprocessor.
|
|
||||||
# We have no idea here whether pthreads is available in the system, so
|
|
||||||
# disable its use.
|
|
||||||
CPPFLAGS += -I$(FUSED_GTEST_DIR) -DGTEST_HAS_PTHREAD=0
|
|
||||||
|
|
||||||
# Flags passed to the C++ compiler.
|
|
||||||
CXXFLAGS += -g
|
|
||||||
|
|
||||||
all : sample1_unittest
|
|
||||||
|
|
||||||
check : all
|
|
||||||
./sample1_unittest
|
|
||||||
|
|
||||||
clean :
|
|
||||||
rm -rf $(FUSED_GTEST_DIR) sample1_unittest *.o
|
|
||||||
|
|
||||||
$(FUSED_GTEST_H) :
|
|
||||||
../fuse_gtest_files.py $(FUSED_GTEST_DIR)
|
|
||||||
|
|
||||||
$(FUSED_GTEST_ALL_CC) :
|
|
||||||
../fuse_gtest_files.py $(FUSED_GTEST_DIR)
|
|
||||||
|
|
||||||
gtest-all.o : $(FUSED_GTEST_H) $(FUSED_GTEST_ALL_CC)
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(FUSED_GTEST_DIR)/gtest/gtest-all.cc
|
|
||||||
|
|
||||||
gtest_main.o : $(FUSED_GTEST_H) $(GTEST_MAIN_CC)
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(GTEST_MAIN_CC)
|
|
||||||
|
|
||||||
sample1.o : $(SAMPLE_DIR)/sample1.cc $(SAMPLE_DIR)/sample1.h
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(SAMPLE_DIR)/sample1.cc
|
|
||||||
|
|
||||||
sample1_unittest.o : $(SAMPLE_DIR)/sample1_unittest.cc \
|
|
||||||
$(SAMPLE_DIR)/sample1.h $(FUSED_GTEST_H)
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) -c $(SAMPLE_DIR)/sample1_unittest.cc
|
|
||||||
|
|
||||||
sample1_unittest : sample1.o sample1_unittest.o gtest-all.o gtest_main.o
|
|
||||||
$(CXX) $(CPPFLAGS) $(CXXFLAGS) $^ -o $@
|
|
@ -1,48 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: mheule@google.com (Markus Heule)
|
|
||||||
//
|
|
||||||
// Google C++ Testing Framework (Google Test)
|
|
||||||
//
|
|
||||||
// Sometimes it's desirable to build Google Test by compiling a single file.
|
|
||||||
// This file serves this purpose.
|
|
||||||
|
|
||||||
// This line ensures that gtest.h can be compiled on its own, even
|
|
||||||
// when it's fused.
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
// The following lines pull in the real gtest *.cc files.
|
|
||||||
#include "src/gtest.cc"
|
|
||||||
#include "src/gtest-death-test.cc"
|
|
||||||
#include "src/gtest-filepath.cc"
|
|
||||||
#include "src/gtest-port.cc"
|
|
||||||
#include "src/gtest-printers.cc"
|
|
||||||
#include "src/gtest-test-part.cc"
|
|
||||||
#include "src/gtest-typed-test.cc"
|
|
File diff suppressed because it is too large
Load Diff
@ -1,805 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-port.h"
|
|
||||||
|
|
||||||
#include <limits.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
# include <windows.h> // For TerminateProcess()
|
|
||||||
#elif GTEST_OS_WINDOWS
|
|
||||||
# include <io.h>
|
|
||||||
# include <sys/stat.h>
|
|
||||||
#else
|
|
||||||
# include <unistd.h>
|
|
||||||
#endif // GTEST_OS_WINDOWS_MOBILE
|
|
||||||
|
|
||||||
#if GTEST_OS_MAC
|
|
||||||
# include <mach/mach_init.h>
|
|
||||||
# include <mach/task.h>
|
|
||||||
# include <mach/vm_map.h>
|
|
||||||
#endif // GTEST_OS_MAC
|
|
||||||
|
|
||||||
#if GTEST_OS_QNX
|
|
||||||
# include <devctl.h>
|
|
||||||
# include <sys/procfs.h>
|
|
||||||
#endif // GTEST_OS_QNX
|
|
||||||
|
|
||||||
#include "gtest/gtest-spi.h"
|
|
||||||
#include "gtest/gtest-message.h"
|
|
||||||
#include "gtest/internal/gtest-internal.h"
|
|
||||||
#include "gtest/internal/gtest-string.h"
|
|
||||||
|
|
||||||
// Indicates that this translation unit is part of Google Test's
|
|
||||||
// implementation. It must come before gtest-internal-inl.h is
|
|
||||||
// included, or there will be a compiler error. This trick is to
|
|
||||||
// prevent a user from accidentally including gtest-internal-inl.h in
|
|
||||||
// his code.
|
|
||||||
#define GTEST_IMPLEMENTATION_ 1
|
|
||||||
#include "src/gtest-internal-inl.h"
|
|
||||||
#undef GTEST_IMPLEMENTATION_
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
#if defined(_MSC_VER) || defined(__BORLANDC__)
|
|
||||||
// MSVC and C++Builder do not provide a definition of STDERR_FILENO.
|
|
||||||
const int kStdOutFileno = 1;
|
|
||||||
const int kStdErrFileno = 2;
|
|
||||||
#else
|
|
||||||
const int kStdOutFileno = STDOUT_FILENO;
|
|
||||||
const int kStdErrFileno = STDERR_FILENO;
|
|
||||||
#endif // _MSC_VER
|
|
||||||
|
|
||||||
#if GTEST_OS_MAC
|
|
||||||
|
|
||||||
// Returns the number of threads running in the process, or 0 to indicate that
|
|
||||||
// we cannot detect it.
|
|
||||||
size_t GetThreadCount() {
|
|
||||||
const task_t task = mach_task_self();
|
|
||||||
mach_msg_type_number_t thread_count;
|
|
||||||
thread_act_array_t thread_list;
|
|
||||||
const kern_return_t status = task_threads(task, &thread_list, &thread_count);
|
|
||||||
if (status == KERN_SUCCESS) {
|
|
||||||
// task_threads allocates resources in thread_list and we need to free them
|
|
||||||
// to avoid leaks.
|
|
||||||
vm_deallocate(task,
|
|
||||||
reinterpret_cast<vm_address_t>(thread_list),
|
|
||||||
sizeof(thread_t) * thread_count);
|
|
||||||
return static_cast<size_t>(thread_count);
|
|
||||||
} else {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif GTEST_OS_QNX
|
|
||||||
|
|
||||||
// Returns the number of threads running in the process, or 0 to indicate that
|
|
||||||
// we cannot detect it.
|
|
||||||
size_t GetThreadCount() {
|
|
||||||
const int fd = open("/proc/self/as", O_RDONLY);
|
|
||||||
if (fd < 0) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
procfs_info process_info;
|
|
||||||
const int status =
|
|
||||||
devctl(fd, DCMD_PROC_INFO, &process_info, sizeof(process_info), NULL);
|
|
||||||
close(fd);
|
|
||||||
if (status == EOK) {
|
|
||||||
return static_cast<size_t>(process_info.num_threads);
|
|
||||||
} else {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
size_t GetThreadCount() {
|
|
||||||
// There's no portable way to detect the number of threads, so we just
|
|
||||||
// return 0 to indicate that we cannot detect it.
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // GTEST_OS_MAC
|
|
||||||
|
|
||||||
#if GTEST_USES_POSIX_RE
|
|
||||||
|
|
||||||
// Implements RE. Currently only needed for death tests.
|
|
||||||
|
|
||||||
RE::~RE() {
|
|
||||||
if (is_valid_) {
|
|
||||||
// regfree'ing an invalid regex might crash because the content
|
|
||||||
// of the regex is undefined. Since the regex's are essentially
|
|
||||||
// the same, one cannot be valid (or invalid) without the other
|
|
||||||
// being so too.
|
|
||||||
regfree(&partial_regex_);
|
|
||||||
regfree(&full_regex_);
|
|
||||||
}
|
|
||||||
free(const_cast<char*>(pattern_));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff regular expression re matches the entire str.
|
|
||||||
bool RE::FullMatch(const char* str, const RE& re) {
|
|
||||||
if (!re.is_valid_) return false;
|
|
||||||
|
|
||||||
regmatch_t match;
|
|
||||||
return regexec(&re.full_regex_, str, 1, &match, 0) == 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff regular expression re matches a substring of str
|
|
||||||
// (including str itself).
|
|
||||||
bool RE::PartialMatch(const char* str, const RE& re) {
|
|
||||||
if (!re.is_valid_) return false;
|
|
||||||
|
|
||||||
regmatch_t match;
|
|
||||||
return regexec(&re.partial_regex_, str, 1, &match, 0) == 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initializes an RE from its string representation.
|
|
||||||
void RE::Init(const char* regex) {
|
|
||||||
pattern_ = posix::StrDup(regex);
|
|
||||||
|
|
||||||
// Reserves enough bytes to hold the regular expression used for a
|
|
||||||
// full match.
|
|
||||||
const size_t full_regex_len = strlen(regex) + 10;
|
|
||||||
char* const full_pattern = new char[full_regex_len];
|
|
||||||
|
|
||||||
snprintf(full_pattern, full_regex_len, "^(%s)$", regex);
|
|
||||||
is_valid_ = regcomp(&full_regex_, full_pattern, REG_EXTENDED) == 0;
|
|
||||||
// We want to call regcomp(&partial_regex_, ...) even if the
|
|
||||||
// previous expression returns false. Otherwise partial_regex_ may
|
|
||||||
// not be properly initialized can may cause trouble when it's
|
|
||||||
// freed.
|
|
||||||
//
|
|
||||||
// Some implementation of POSIX regex (e.g. on at least some
|
|
||||||
// versions of Cygwin) doesn't accept the empty string as a valid
|
|
||||||
// regex. We change it to an equivalent form "()" to be safe.
|
|
||||||
if (is_valid_) {
|
|
||||||
const char* const partial_regex = (*regex == '\0') ? "()" : regex;
|
|
||||||
is_valid_ = regcomp(&partial_regex_, partial_regex, REG_EXTENDED) == 0;
|
|
||||||
}
|
|
||||||
EXPECT_TRUE(is_valid_)
|
|
||||||
<< "Regular expression \"" << regex
|
|
||||||
<< "\" is not a valid POSIX Extended regular expression.";
|
|
||||||
|
|
||||||
delete[] full_pattern;
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif GTEST_USES_SIMPLE_RE
|
|
||||||
|
|
||||||
// Returns true iff ch appears anywhere in str (excluding the
|
|
||||||
// terminating '\0' character).
|
|
||||||
bool IsInSet(char ch, const char* str) {
|
|
||||||
return ch != '\0' && strchr(str, ch) != NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff ch belongs to the given classification. Unlike
|
|
||||||
// similar functions in <ctype.h>, these aren't affected by the
|
|
||||||
// current locale.
|
|
||||||
bool IsAsciiDigit(char ch) { return '0' <= ch && ch <= '9'; }
|
|
||||||
bool IsAsciiPunct(char ch) {
|
|
||||||
return IsInSet(ch, "^-!\"#$%&'()*+,./:;<=>?@[\\]_`{|}~");
|
|
||||||
}
|
|
||||||
bool IsRepeat(char ch) { return IsInSet(ch, "?*+"); }
|
|
||||||
bool IsAsciiWhiteSpace(char ch) { return IsInSet(ch, " \f\n\r\t\v"); }
|
|
||||||
bool IsAsciiWordChar(char ch) {
|
|
||||||
return ('a' <= ch && ch <= 'z') || ('A' <= ch && ch <= 'Z') ||
|
|
||||||
('0' <= ch && ch <= '9') || ch == '_';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff "\\c" is a supported escape sequence.
|
|
||||||
bool IsValidEscape(char c) {
|
|
||||||
return (IsAsciiPunct(c) || IsInSet(c, "dDfnrsStvwW"));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff the given atom (specified by escaped and pattern)
|
|
||||||
// matches ch. The result is undefined if the atom is invalid.
|
|
||||||
bool AtomMatchesChar(bool escaped, char pattern_char, char ch) {
|
|
||||||
if (escaped) { // "\\p" where p is pattern_char.
|
|
||||||
switch (pattern_char) {
|
|
||||||
case 'd': return IsAsciiDigit(ch);
|
|
||||||
case 'D': return !IsAsciiDigit(ch);
|
|
||||||
case 'f': return ch == '\f';
|
|
||||||
case 'n': return ch == '\n';
|
|
||||||
case 'r': return ch == '\r';
|
|
||||||
case 's': return IsAsciiWhiteSpace(ch);
|
|
||||||
case 'S': return !IsAsciiWhiteSpace(ch);
|
|
||||||
case 't': return ch == '\t';
|
|
||||||
case 'v': return ch == '\v';
|
|
||||||
case 'w': return IsAsciiWordChar(ch);
|
|
||||||
case 'W': return !IsAsciiWordChar(ch);
|
|
||||||
}
|
|
||||||
return IsAsciiPunct(pattern_char) && pattern_char == ch;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (pattern_char == '.' && ch != '\n') || pattern_char == ch;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helper function used by ValidateRegex() to format error messages.
|
|
||||||
std::string FormatRegexSyntaxError(const char* regex, int index) {
|
|
||||||
return (Message() << "Syntax error at index " << index
|
|
||||||
<< " in simple regular expression \"" << regex << "\": ").GetString();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Generates non-fatal failures and returns false if regex is invalid;
|
|
||||||
// otherwise returns true.
|
|
||||||
bool ValidateRegex(const char* regex) {
|
|
||||||
if (regex == NULL) {
|
|
||||||
// TODO(wan@google.com): fix the source file location in the
|
|
||||||
// assertion failures to match where the regex is used in user
|
|
||||||
// code.
|
|
||||||
ADD_FAILURE() << "NULL is not a valid simple regular expression.";
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool is_valid = true;
|
|
||||||
|
|
||||||
// True iff ?, *, or + can follow the previous atom.
|
|
||||||
bool prev_repeatable = false;
|
|
||||||
for (int i = 0; regex[i]; i++) {
|
|
||||||
if (regex[i] == '\\') { // An escape sequence
|
|
||||||
i++;
|
|
||||||
if (regex[i] == '\0') {
|
|
||||||
ADD_FAILURE() << FormatRegexSyntaxError(regex, i - 1)
|
|
||||||
<< "'\\' cannot appear at the end.";
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!IsValidEscape(regex[i])) {
|
|
||||||
ADD_FAILURE() << FormatRegexSyntaxError(regex, i - 1)
|
|
||||||
<< "invalid escape sequence \"\\" << regex[i] << "\".";
|
|
||||||
is_valid = false;
|
|
||||||
}
|
|
||||||
prev_repeatable = true;
|
|
||||||
} else { // Not an escape sequence.
|
|
||||||
const char ch = regex[i];
|
|
||||||
|
|
||||||
if (ch == '^' && i > 0) {
|
|
||||||
ADD_FAILURE() << FormatRegexSyntaxError(regex, i)
|
|
||||||
<< "'^' can only appear at the beginning.";
|
|
||||||
is_valid = false;
|
|
||||||
} else if (ch == '$' && regex[i + 1] != '\0') {
|
|
||||||
ADD_FAILURE() << FormatRegexSyntaxError(regex, i)
|
|
||||||
<< "'$' can only appear at the end.";
|
|
||||||
is_valid = false;
|
|
||||||
} else if (IsInSet(ch, "()[]{}|")) {
|
|
||||||
ADD_FAILURE() << FormatRegexSyntaxError(regex, i)
|
|
||||||
<< "'" << ch << "' is unsupported.";
|
|
||||||
is_valid = false;
|
|
||||||
} else if (IsRepeat(ch) && !prev_repeatable) {
|
|
||||||
ADD_FAILURE() << FormatRegexSyntaxError(regex, i)
|
|
||||||
<< "'" << ch << "' can only follow a repeatable token.";
|
|
||||||
is_valid = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
prev_repeatable = !IsInSet(ch, "^$?*+");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return is_valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Matches a repeated regex atom followed by a valid simple regular
|
|
||||||
// expression. The regex atom is defined as c if escaped is false,
|
|
||||||
// or \c otherwise. repeat is the repetition meta character (?, *,
|
|
||||||
// or +). The behavior is undefined if str contains too many
|
|
||||||
// characters to be indexable by size_t, in which case the test will
|
|
||||||
// probably time out anyway. We are fine with this limitation as
|
|
||||||
// std::string has it too.
|
|
||||||
bool MatchRepetitionAndRegexAtHead(
|
|
||||||
bool escaped, char c, char repeat, const char* regex,
|
|
||||||
const char* str) {
|
|
||||||
const size_t min_count = (repeat == '+') ? 1 : 0;
|
|
||||||
const size_t max_count = (repeat == '?') ? 1 :
|
|
||||||
static_cast<size_t>(-1) - 1;
|
|
||||||
// We cannot call numeric_limits::max() as it conflicts with the
|
|
||||||
// max() macro on Windows.
|
|
||||||
|
|
||||||
for (size_t i = 0; i <= max_count; ++i) {
|
|
||||||
// We know that the atom matches each of the first i characters in str.
|
|
||||||
if (i >= min_count && MatchRegexAtHead(regex, str + i)) {
|
|
||||||
// We have enough matches at the head, and the tail matches too.
|
|
||||||
// Since we only care about *whether* the pattern matches str
|
|
||||||
// (as opposed to *how* it matches), there is no need to find a
|
|
||||||
// greedy match.
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (str[i] == '\0' || !AtomMatchesChar(escaped, c, str[i]))
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff regex matches a prefix of str. regex must be a
|
|
||||||
// valid simple regular expression and not start with "^", or the
|
|
||||||
// result is undefined.
|
|
||||||
bool MatchRegexAtHead(const char* regex, const char* str) {
|
|
||||||
if (*regex == '\0') // An empty regex matches a prefix of anything.
|
|
||||||
return true;
|
|
||||||
|
|
||||||
// "$" only matches the end of a string. Note that regex being
|
|
||||||
// valid guarantees that there's nothing after "$" in it.
|
|
||||||
if (*regex == '$')
|
|
||||||
return *str == '\0';
|
|
||||||
|
|
||||||
// Is the first thing in regex an escape sequence?
|
|
||||||
const bool escaped = *regex == '\\';
|
|
||||||
if (escaped)
|
|
||||||
++regex;
|
|
||||||
if (IsRepeat(regex[1])) {
|
|
||||||
// MatchRepetitionAndRegexAtHead() calls MatchRegexAtHead(), so
|
|
||||||
// here's an indirect recursion. It terminates as the regex gets
|
|
||||||
// shorter in each recursion.
|
|
||||||
return MatchRepetitionAndRegexAtHead(
|
|
||||||
escaped, regex[0], regex[1], regex + 2, str);
|
|
||||||
} else {
|
|
||||||
// regex isn't empty, isn't "$", and doesn't start with a
|
|
||||||
// repetition. We match the first atom of regex with the first
|
|
||||||
// character of str and recurse.
|
|
||||||
return (*str != '\0') && AtomMatchesChar(escaped, *regex, *str) &&
|
|
||||||
MatchRegexAtHead(regex + 1, str + 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff regex matches any substring of str. regex must be
|
|
||||||
// a valid simple regular expression, or the result is undefined.
|
|
||||||
//
|
|
||||||
// The algorithm is recursive, but the recursion depth doesn't exceed
|
|
||||||
// the regex length, so we won't need to worry about running out of
|
|
||||||
// stack space normally. In rare cases the time complexity can be
|
|
||||||
// exponential with respect to the regex length + the string length,
|
|
||||||
// but usually it's must faster (often close to linear).
|
|
||||||
bool MatchRegexAnywhere(const char* regex, const char* str) {
|
|
||||||
if (regex == NULL || str == NULL)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (*regex == '^')
|
|
||||||
return MatchRegexAtHead(regex + 1, str);
|
|
||||||
|
|
||||||
// A successful match can be anywhere in str.
|
|
||||||
do {
|
|
||||||
if (MatchRegexAtHead(regex, str))
|
|
||||||
return true;
|
|
||||||
} while (*str++ != '\0');
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Implements the RE class.
|
|
||||||
|
|
||||||
RE::~RE() {
|
|
||||||
free(const_cast<char*>(pattern_));
|
|
||||||
free(const_cast<char*>(full_pattern_));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff regular expression re matches the entire str.
|
|
||||||
bool RE::FullMatch(const char* str, const RE& re) {
|
|
||||||
return re.is_valid_ && MatchRegexAnywhere(re.full_pattern_, str);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Returns true iff regular expression re matches a substring of str
|
|
||||||
// (including str itself).
|
|
||||||
bool RE::PartialMatch(const char* str, const RE& re) {
|
|
||||||
return re.is_valid_ && MatchRegexAnywhere(re.pattern_, str);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initializes an RE from its string representation.
|
|
||||||
void RE::Init(const char* regex) {
|
|
||||||
pattern_ = full_pattern_ = NULL;
|
|
||||||
if (regex != NULL) {
|
|
||||||
pattern_ = posix::StrDup(regex);
|
|
||||||
}
|
|
||||||
|
|
||||||
is_valid_ = ValidateRegex(regex);
|
|
||||||
if (!is_valid_) {
|
|
||||||
// No need to calculate the full pattern when the regex is invalid.
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const size_t len = strlen(regex);
|
|
||||||
// Reserves enough bytes to hold the regular expression used for a
|
|
||||||
// full match: we need space to prepend a '^', append a '$', and
|
|
||||||
// terminate the string with '\0'.
|
|
||||||
char* buffer = static_cast<char*>(malloc(len + 3));
|
|
||||||
full_pattern_ = buffer;
|
|
||||||
|
|
||||||
if (*regex != '^')
|
|
||||||
*buffer++ = '^'; // Makes sure full_pattern_ starts with '^'.
|
|
||||||
|
|
||||||
// We don't use snprintf or strncpy, as they trigger a warning when
|
|
||||||
// compiled with VC++ 8.0.
|
|
||||||
memcpy(buffer, regex, len);
|
|
||||||
buffer += len;
|
|
||||||
|
|
||||||
if (len == 0 || regex[len - 1] != '$')
|
|
||||||
*buffer++ = '$'; // Makes sure full_pattern_ ends with '$'.
|
|
||||||
|
|
||||||
*buffer = '\0';
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // GTEST_USES_POSIX_RE
|
|
||||||
|
|
||||||
const char kUnknownFile[] = "unknown file";
|
|
||||||
|
|
||||||
// Formats a source file path and a line number as they would appear
|
|
||||||
// in an error message from the compiler used to compile this code.
|
|
||||||
GTEST_API_ ::std::string FormatFileLocation(const char* file, int line) {
|
|
||||||
const char* const file_name = file == NULL ? kUnknownFile : file;
|
|
||||||
|
|
||||||
if (line < 0) {
|
|
||||||
return String::Format("%s:", file_name).c_str();
|
|
||||||
}
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
return String::Format("%s(%d):", file_name, line).c_str();
|
|
||||||
#else
|
|
||||||
return String::Format("%s:%d:", file_name, line).c_str();
|
|
||||||
#endif // _MSC_VER
|
|
||||||
}
|
|
||||||
|
|
||||||
// Formats a file location for compiler-independent XML output.
|
|
||||||
// Although this function is not platform dependent, we put it next to
|
|
||||||
// FormatFileLocation in order to contrast the two functions.
|
|
||||||
// Note that FormatCompilerIndependentFileLocation() does NOT append colon
|
|
||||||
// to the file location it produces, unlike FormatFileLocation().
|
|
||||||
GTEST_API_ ::std::string FormatCompilerIndependentFileLocation(
|
|
||||||
const char* file, int line) {
|
|
||||||
const char* const file_name = file == NULL ? kUnknownFile : file;
|
|
||||||
|
|
||||||
if (line < 0)
|
|
||||||
return file_name;
|
|
||||||
else
|
|
||||||
return String::Format("%s:%d", file_name, line).c_str();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
GTestLog::GTestLog(GTestLogSeverity severity, const char* file, int line)
|
|
||||||
: severity_(severity) {
|
|
||||||
const char* const marker =
|
|
||||||
severity == GTEST_INFO ? "[ INFO ]" :
|
|
||||||
severity == GTEST_WARNING ? "[WARNING]" :
|
|
||||||
severity == GTEST_ERROR ? "[ ERROR ]" : "[ FATAL ]";
|
|
||||||
GetStream() << ::std::endl << marker << " "
|
|
||||||
<< FormatFileLocation(file, line).c_str() << ": ";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Flushes the buffers and, if severity is GTEST_FATAL, aborts the program.
|
|
||||||
GTestLog::~GTestLog() {
|
|
||||||
GetStream() << ::std::endl;
|
|
||||||
if (severity_ == GTEST_FATAL) {
|
|
||||||
fflush(stderr);
|
|
||||||
posix::Abort();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Disable Microsoft deprecation warnings for POSIX functions called from
|
|
||||||
// this class (creat, dup, dup2, and close)
|
|
||||||
#ifdef _MSC_VER
|
|
||||||
# pragma warning(push)
|
|
||||||
# pragma warning(disable: 4996)
|
|
||||||
#endif // _MSC_VER
|
|
||||||
|
|
||||||
#if GTEST_HAS_STREAM_REDIRECTION
|
|
||||||
|
|
||||||
// Object that captures an output stream (stdout/stderr).
|
|
||||||
class CapturedStream {
|
|
||||||
public:
|
|
||||||
// The ctor redirects the stream to a temporary file.
|
|
||||||
explicit CapturedStream(int fd) : fd_(fd), uncaptured_fd_(dup(fd)) {
|
|
||||||
# if GTEST_OS_WINDOWS
|
|
||||||
char temp_dir_path[MAX_PATH + 1] = { '\0' }; // NOLINT
|
|
||||||
char temp_file_path[MAX_PATH + 1] = { '\0' }; // NOLINT
|
|
||||||
|
|
||||||
::GetTempPathA(sizeof(temp_dir_path), temp_dir_path);
|
|
||||||
const UINT success = ::GetTempFileNameA(temp_dir_path,
|
|
||||||
"gtest_redir",
|
|
||||||
0, // Generate unique file name.
|
|
||||||
temp_file_path);
|
|
||||||
GTEST_CHECK_(success != 0)
|
|
||||||
<< "Unable to create a temporary file in " << temp_dir_path;
|
|
||||||
const int captured_fd = creat(temp_file_path, _S_IREAD | _S_IWRITE);
|
|
||||||
GTEST_CHECK_(captured_fd != -1) << "Unable to open temporary file "
|
|
||||||
<< temp_file_path;
|
|
||||||
filename_ = temp_file_path;
|
|
||||||
# else
|
|
||||||
// There's no guarantee that a test has write access to the current
|
|
||||||
// directory, so we create the temporary file in the /tmp directory
|
|
||||||
// instead. We use /tmp on most systems, and /sdcard on Android.
|
|
||||||
// That's because Android doesn't have /tmp.
|
|
||||||
# if GTEST_OS_LINUX_ANDROID
|
|
||||||
// Note: Android applications are expected to call the framework's
|
|
||||||
// Context.getExternalStorageDirectory() method through JNI to get
|
|
||||||
// the location of the world-writable SD Card directory. However,
|
|
||||||
// this requires a Context handle, which cannot be retrieved
|
|
||||||
// globally from native code. Doing so also precludes running the
|
|
||||||
// code as part of a regular standalone executable, which doesn't
|
|
||||||
// run in a Dalvik process (e.g. when running it through 'adb shell').
|
|
||||||
//
|
|
||||||
// The location /sdcard is directly accessible from native code
|
|
||||||
// and is the only location (unofficially) supported by the Android
|
|
||||||
// team. It's generally a symlink to the real SD Card mount point
|
|
||||||
// which can be /mnt/sdcard, /mnt/sdcard0, /system/media/sdcard, or
|
|
||||||
// other OEM-customized locations. Never rely on these, and always
|
|
||||||
// use /sdcard.
|
|
||||||
char name_template[] = "/sdcard/gtest_captured_stream.XXXXXX";
|
|
||||||
# else
|
|
||||||
char name_template[] = "/tmp/captured_stream.XXXXXX";
|
|
||||||
# endif // GTEST_OS_LINUX_ANDROID
|
|
||||||
const int captured_fd = mkstemp(name_template);
|
|
||||||
filename_ = name_template;
|
|
||||||
# endif // GTEST_OS_WINDOWS
|
|
||||||
fflush(NULL);
|
|
||||||
dup2(captured_fd, fd_);
|
|
||||||
close(captured_fd);
|
|
||||||
}
|
|
||||||
|
|
||||||
~CapturedStream() {
|
|
||||||
remove(filename_.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string GetCapturedString() {
|
|
||||||
if (uncaptured_fd_ != -1) {
|
|
||||||
// Restores the original stream.
|
|
||||||
fflush(NULL);
|
|
||||||
dup2(uncaptured_fd_, fd_);
|
|
||||||
close(uncaptured_fd_);
|
|
||||||
uncaptured_fd_ = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
FILE* const file = posix::FOpen(filename_.c_str(), "r");
|
|
||||||
const std::string content = ReadEntireFile(file);
|
|
||||||
posix::FClose(file);
|
|
||||||
return content;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
// Reads the entire content of a file as an std::string.
|
|
||||||
static std::string ReadEntireFile(FILE* file);
|
|
||||||
|
|
||||||
// Returns the size (in bytes) of a file.
|
|
||||||
static size_t GetFileSize(FILE* file);
|
|
||||||
|
|
||||||
const int fd_; // A stream to capture.
|
|
||||||
int uncaptured_fd_;
|
|
||||||
// Name of the temporary file holding the stderr output.
|
|
||||||
::std::string filename_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(CapturedStream);
|
|
||||||
};
|
|
||||||
|
|
||||||
// Returns the size (in bytes) of a file.
|
|
||||||
size_t CapturedStream::GetFileSize(FILE* file) {
|
|
||||||
fseek(file, 0, SEEK_END);
|
|
||||||
return static_cast<size_t>(ftell(file));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reads the entire content of a file as a string.
|
|
||||||
std::string CapturedStream::ReadEntireFile(FILE* file) {
|
|
||||||
const size_t file_size = GetFileSize(file);
|
|
||||||
char* const buffer = new char[file_size];
|
|
||||||
|
|
||||||
size_t bytes_last_read = 0; // # of bytes read in the last fread()
|
|
||||||
size_t bytes_read = 0; // # of bytes read so far
|
|
||||||
|
|
||||||
fseek(file, 0, SEEK_SET);
|
|
||||||
|
|
||||||
// Keeps reading the file until we cannot read further or the
|
|
||||||
// pre-determined file size is reached.
|
|
||||||
do {
|
|
||||||
bytes_last_read = fread(buffer+bytes_read, 1, file_size-bytes_read, file);
|
|
||||||
bytes_read += bytes_last_read;
|
|
||||||
} while (bytes_last_read > 0 && bytes_read < file_size);
|
|
||||||
|
|
||||||
const std::string content(buffer, bytes_read);
|
|
||||||
delete[] buffer;
|
|
||||||
|
|
||||||
return content;
|
|
||||||
}
|
|
||||||
|
|
||||||
# ifdef _MSC_VER
|
|
||||||
# pragma warning(pop)
|
|
||||||
# endif // _MSC_VER
|
|
||||||
|
|
||||||
static CapturedStream* g_captured_stderr = NULL;
|
|
||||||
static CapturedStream* g_captured_stdout = NULL;
|
|
||||||
|
|
||||||
// Starts capturing an output stream (stdout/stderr).
|
|
||||||
void CaptureStream(int fd, const char* stream_name, CapturedStream** stream) {
|
|
||||||
if (*stream != NULL) {
|
|
||||||
GTEST_LOG_(FATAL) << "Only one " << stream_name
|
|
||||||
<< " capturer can exist at a time.";
|
|
||||||
}
|
|
||||||
*stream = new CapturedStream(fd);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Stops capturing the output stream and returns the captured string.
|
|
||||||
std::string GetCapturedStream(CapturedStream** captured_stream) {
|
|
||||||
const std::string content = (*captured_stream)->GetCapturedString();
|
|
||||||
|
|
||||||
delete *captured_stream;
|
|
||||||
*captured_stream = NULL;
|
|
||||||
|
|
||||||
return content;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Starts capturing stdout.
|
|
||||||
void CaptureStdout() {
|
|
||||||
CaptureStream(kStdOutFileno, "stdout", &g_captured_stdout);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Starts capturing stderr.
|
|
||||||
void CaptureStderr() {
|
|
||||||
CaptureStream(kStdErrFileno, "stderr", &g_captured_stderr);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Stops capturing stdout and returns the captured string.
|
|
||||||
std::string GetCapturedStdout() {
|
|
||||||
return GetCapturedStream(&g_captured_stdout);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Stops capturing stderr and returns the captured string.
|
|
||||||
std::string GetCapturedStderr() {
|
|
||||||
return GetCapturedStream(&g_captured_stderr);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_STREAM_REDIRECTION
|
|
||||||
|
|
||||||
#if GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
// A copy of all command line arguments. Set by InitGoogleTest().
|
|
||||||
::std::vector<testing::internal::string> g_argvs;
|
|
||||||
|
|
||||||
static const ::std::vector<testing::internal::string>* g_injected_test_argvs =
|
|
||||||
NULL; // Owned.
|
|
||||||
|
|
||||||
void SetInjectableArgvs(const ::std::vector<testing::internal::string>* argvs) {
|
|
||||||
if (g_injected_test_argvs != argvs)
|
|
||||||
delete g_injected_test_argvs;
|
|
||||||
g_injected_test_argvs = argvs;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ::std::vector<testing::internal::string>& GetInjectableArgvs() {
|
|
||||||
if (g_injected_test_argvs != NULL) {
|
|
||||||
return *g_injected_test_argvs;
|
|
||||||
}
|
|
||||||
return g_argvs;
|
|
||||||
}
|
|
||||||
#endif // GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
namespace posix {
|
|
||||||
void Abort() {
|
|
||||||
DebugBreak();
|
|
||||||
TerminateProcess(GetCurrentProcess(), 1);
|
|
||||||
}
|
|
||||||
} // namespace posix
|
|
||||||
#endif // GTEST_OS_WINDOWS_MOBILE
|
|
||||||
|
|
||||||
// Returns the name of the environment variable corresponding to the
|
|
||||||
// given flag. For example, FlagToEnvVar("foo") will return
|
|
||||||
// "GTEST_FOO" in the open-source version.
|
|
||||||
static std::string FlagToEnvVar(const char* flag) {
|
|
||||||
const std::string full_flag =
|
|
||||||
(Message() << GTEST_FLAG_PREFIX_ << flag).GetString();
|
|
||||||
|
|
||||||
Message env_var;
|
|
||||||
for (size_t i = 0; i != full_flag.length(); i++) {
|
|
||||||
env_var << ToUpper(full_flag.c_str()[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return env_var.GetString();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Parses 'str' for a 32-bit signed integer. If successful, writes
|
|
||||||
// the result to *value and returns true; otherwise leaves *value
|
|
||||||
// unchanged and returns false.
|
|
||||||
bool ParseInt32(const Message& src_text, const char* str, Int32* value) {
|
|
||||||
// Parses the environment variable as a decimal integer.
|
|
||||||
char* end = NULL;
|
|
||||||
const long long_value = strtol(str, &end, 10); // NOLINT
|
|
||||||
|
|
||||||
// Has strtol() consumed all characters in the string?
|
|
||||||
if (*end != '\0') {
|
|
||||||
// No - an invalid character was encountered.
|
|
||||||
Message msg;
|
|
||||||
msg << "WARNING: " << src_text
|
|
||||||
<< " is expected to be a 32-bit integer, but actually"
|
|
||||||
<< " has value \"" << str << "\".\n";
|
|
||||||
printf("%s", msg.GetString().c_str());
|
|
||||||
fflush(stdout);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Is the parsed value in the range of an Int32?
|
|
||||||
const Int32 result = static_cast<Int32>(long_value);
|
|
||||||
if (long_value == LONG_MAX || long_value == LONG_MIN ||
|
|
||||||
// The parsed value overflows as a long. (strtol() returns
|
|
||||||
// LONG_MAX or LONG_MIN when the input overflows.)
|
|
||||||
result != long_value
|
|
||||||
// The parsed value overflows as an Int32.
|
|
||||||
) {
|
|
||||||
Message msg;
|
|
||||||
msg << "WARNING: " << src_text
|
|
||||||
<< " is expected to be a 32-bit integer, but actually"
|
|
||||||
<< " has value " << str << ", which overflows.\n";
|
|
||||||
printf("%s", msg.GetString().c_str());
|
|
||||||
fflush(stdout);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
*value = result;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reads and returns the Boolean environment variable corresponding to
|
|
||||||
// the given flag; if it's not set, returns default_value.
|
|
||||||
//
|
|
||||||
// The value is considered true iff it's not "0".
|
|
||||||
bool BoolFromGTestEnv(const char* flag, bool default_value) {
|
|
||||||
const std::string env_var = FlagToEnvVar(flag);
|
|
||||||
const char* const string_value = posix::GetEnv(env_var.c_str());
|
|
||||||
return string_value == NULL ?
|
|
||||||
default_value : strcmp(string_value, "0") != 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reads and returns a 32-bit integer stored in the environment
|
|
||||||
// variable corresponding to the given flag; if it isn't set or
|
|
||||||
// doesn't represent a valid 32-bit integer, returns default_value.
|
|
||||||
Int32 Int32FromGTestEnv(const char* flag, Int32 default_value) {
|
|
||||||
const std::string env_var = FlagToEnvVar(flag);
|
|
||||||
const char* const string_value = posix::GetEnv(env_var.c_str());
|
|
||||||
if (string_value == NULL) {
|
|
||||||
// The environment variable is not set.
|
|
||||||
return default_value;
|
|
||||||
}
|
|
||||||
|
|
||||||
Int32 result = default_value;
|
|
||||||
if (!ParseInt32(Message() << "Environment variable " << env_var,
|
|
||||||
string_value, &result)) {
|
|
||||||
printf("The default value %s is used.\n",
|
|
||||||
(Message() << default_value).GetString().c_str());
|
|
||||||
fflush(stdout);
|
|
||||||
return default_value;
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Reads and returns the string environment variable corresponding to
|
|
||||||
// the given flag; if it's not set, returns default_value.
|
|
||||||
const char* StringFromGTestEnv(const char* flag, const char* default_value) {
|
|
||||||
const std::string env_var = FlagToEnvVar(flag);
|
|
||||||
const char* const value = posix::GetEnv(env_var.c_str());
|
|
||||||
return value == NULL ? default_value : value;
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
@ -1,110 +0,0 @@
|
|||||||
// Copyright 2008 Google Inc.
|
|
||||||
// All Rights Reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
|
|
||||||
#include "gtest/gtest-typed-test.h"
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
#if GTEST_HAS_TYPED_TEST_P
|
|
||||||
|
|
||||||
// Skips to the first non-space char in str. Returns an empty string if str
|
|
||||||
// contains only whitespace characters.
|
|
||||||
static const char* SkipSpaces(const char* str) {
|
|
||||||
while (IsSpace(*str))
|
|
||||||
str++;
|
|
||||||
return str;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verifies that registered_tests match the test names in
|
|
||||||
// defined_test_names_; returns registered_tests if successful, or
|
|
||||||
// aborts the program otherwise.
|
|
||||||
const char* TypedTestCasePState::VerifyRegisteredTestNames(
|
|
||||||
const char* file, int line, const char* registered_tests) {
|
|
||||||
typedef ::std::set<const char*>::const_iterator DefinedTestIter;
|
|
||||||
registered_ = true;
|
|
||||||
|
|
||||||
// Skip initial whitespace in registered_tests since some
|
|
||||||
// preprocessors prefix stringizied literals with whitespace.
|
|
||||||
registered_tests = SkipSpaces(registered_tests);
|
|
||||||
|
|
||||||
Message errors;
|
|
||||||
::std::set<std::string> tests;
|
|
||||||
for (const char* names = registered_tests; names != NULL;
|
|
||||||
names = SkipComma(names)) {
|
|
||||||
const std::string name = GetPrefixUntilComma(names);
|
|
||||||
if (tests.count(name) != 0) {
|
|
||||||
errors << "Test " << name << " is listed more than once.\n";
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool found = false;
|
|
||||||
for (DefinedTestIter it = defined_test_names_.begin();
|
|
||||||
it != defined_test_names_.end();
|
|
||||||
++it) {
|
|
||||||
if (name == *it) {
|
|
||||||
found = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (found) {
|
|
||||||
tests.insert(name);
|
|
||||||
} else {
|
|
||||||
errors << "No test named " << name
|
|
||||||
<< " can be found in this test case.\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (DefinedTestIter it = defined_test_names_.begin();
|
|
||||||
it != defined_test_names_.end();
|
|
||||||
++it) {
|
|
||||||
if (tests.count(*it) == 0) {
|
|
||||||
errors << "You forgot to list test " << *it << ".\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::string& errors_str = errors.GetString();
|
|
||||||
if (errors_str != "") {
|
|
||||||
fprintf(stderr, "%s %s", FormatFileLocation(file, line).c_str(),
|
|
||||||
errors_str.c_str());
|
|
||||||
fflush(stderr);
|
|
||||||
posix::Abort();
|
|
||||||
}
|
|
||||||
|
|
||||||
return registered_tests;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_TYPED_TEST_P
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
File diff suppressed because it is too large
Load Diff
@ -1,38 +0,0 @@
|
|||||||
// Copyright 2006, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
GTEST_API_ int main(int argc, char **argv) {
|
|
||||||
printf("Running main() from gtest_main.cc\n");
|
|
||||||
testing::InitGoogleTest(&argc, argv);
|
|
||||||
return RUN_ALL_TESTS();
|
|
||||||
}
|
|
@ -1,93 +0,0 @@
|
|||||||
// Copyright 2010, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: vladl@google.com (Vlad Losev)
|
|
||||||
//
|
|
||||||
// Tests that verify interaction of exceptions and death tests.
|
|
||||||
|
|
||||||
#include "gtest/gtest-death-test.h"
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
# if GTEST_HAS_SEH
|
|
||||||
# include <windows.h> // For RaiseException().
|
|
||||||
# endif
|
|
||||||
|
|
||||||
# include "gtest/gtest-spi.h"
|
|
||||||
|
|
||||||
# if GTEST_HAS_EXCEPTIONS
|
|
||||||
|
|
||||||
# include <exception> // For std::exception.
|
|
||||||
|
|
||||||
// Tests that death tests report thrown exceptions as failures and that the
|
|
||||||
// exceptions do not escape death test macros.
|
|
||||||
TEST(CxxExceptionDeathTest, ExceptionIsFailure) {
|
|
||||||
try {
|
|
||||||
EXPECT_NONFATAL_FAILURE(EXPECT_DEATH(throw 1, ""), "threw an exception");
|
|
||||||
} catch (...) { // NOLINT
|
|
||||||
FAIL() << "An exception escaped a death test macro invocation "
|
|
||||||
<< "with catch_exceptions "
|
|
||||||
<< (testing::GTEST_FLAG(catch_exceptions) ? "enabled" : "disabled");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class TestException : public std::exception {
|
|
||||||
public:
|
|
||||||
virtual const char* what() const throw() { return "exceptional message"; }
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(CxxExceptionDeathTest, PrintsMessageForStdExceptions) {
|
|
||||||
// Verifies that the exception message is quoted in the failure text.
|
|
||||||
EXPECT_NONFATAL_FAILURE(EXPECT_DEATH(throw TestException(), ""),
|
|
||||||
"exceptional message");
|
|
||||||
// Verifies that the location is mentioned in the failure text.
|
|
||||||
EXPECT_NONFATAL_FAILURE(EXPECT_DEATH(throw TestException(), ""),
|
|
||||||
"gtest-death-test_ex_test.cc");
|
|
||||||
}
|
|
||||||
# endif // GTEST_HAS_EXCEPTIONS
|
|
||||||
|
|
||||||
# if GTEST_HAS_SEH
|
|
||||||
// Tests that enabling interception of SEH exceptions with the
|
|
||||||
// catch_exceptions flag does not interfere with SEH exceptions being
|
|
||||||
// treated as death by death tests.
|
|
||||||
TEST(SehExceptionDeasTest, CatchExceptionsDoesNotInterfere) {
|
|
||||||
EXPECT_DEATH(RaiseException(42, 0x0, 0, NULL), "")
|
|
||||||
<< "with catch_exceptions "
|
|
||||||
<< (testing::GTEST_FLAG(catch_exceptions) ? "enabled" : "disabled");
|
|
||||||
}
|
|
||||||
# endif
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_DEATH_TEST
|
|
||||||
|
|
||||||
int main(int argc, char** argv) {
|
|
||||||
testing::InitGoogleTest(&argc, argv);
|
|
||||||
testing::GTEST_FLAG(catch_exceptions) = GTEST_ENABLE_CATCH_EXCEPTIONS_ != 0;
|
|
||||||
return RUN_ALL_TESTS();
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
@ -1,680 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: keith.ray@gmail.com (Keith Ray)
|
|
||||||
//
|
|
||||||
// Google Test filepath utilities
|
|
||||||
//
|
|
||||||
// This file tests classes and functions used internally by
|
|
||||||
// Google Test. They are subject to change without notice.
|
|
||||||
//
|
|
||||||
// This file is #included from gtest_unittest.cc, to avoid changing
|
|
||||||
// build or make-files for some existing Google Test clients. Do not
|
|
||||||
// #include this file anywhere else!
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-filepath.h"
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
// Indicates that this translation unit is part of Google Test's
|
|
||||||
// implementation. It must come before gtest-internal-inl.h is
|
|
||||||
// included, or there will be a compiler error. This trick is to
|
|
||||||
// prevent a user from accidentally including gtest-internal-inl.h in
|
|
||||||
// his code.
|
|
||||||
#define GTEST_IMPLEMENTATION_ 1
|
|
||||||
#include "src/gtest-internal-inl.h"
|
|
||||||
#undef GTEST_IMPLEMENTATION_
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
# include <windows.h> // NOLINT
|
|
||||||
#elif GTEST_OS_WINDOWS
|
|
||||||
# include <direct.h> // NOLINT
|
|
||||||
#endif // GTEST_OS_WINDOWS_MOBILE
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
// TODO(wan@google.com): Move these to the POSIX adapter section in
|
|
||||||
// gtest-port.h.
|
|
||||||
|
|
||||||
// Windows CE doesn't have the remove C function.
|
|
||||||
int remove(const char* path) {
|
|
||||||
LPCWSTR wpath = String::AnsiToUtf16(path);
|
|
||||||
int ret = DeleteFile(wpath) ? 0 : -1;
|
|
||||||
delete [] wpath;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
// Windows CE doesn't have the _rmdir C function.
|
|
||||||
int _rmdir(const char* path) {
|
|
||||||
FilePath filepath(path);
|
|
||||||
LPCWSTR wpath = String::AnsiToUtf16(
|
|
||||||
filepath.RemoveTrailingPathSeparator().c_str());
|
|
||||||
int ret = RemoveDirectory(wpath) ? 0 : -1;
|
|
||||||
delete [] wpath;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
TEST(GetCurrentDirTest, ReturnsCurrentDir) {
|
|
||||||
const FilePath original_dir = FilePath::GetCurrentDir();
|
|
||||||
EXPECT_FALSE(original_dir.IsEmpty());
|
|
||||||
|
|
||||||
posix::ChDir(GTEST_PATH_SEP_);
|
|
||||||
const FilePath cwd = FilePath::GetCurrentDir();
|
|
||||||
posix::ChDir(original_dir.c_str());
|
|
||||||
|
|
||||||
# if GTEST_OS_WINDOWS
|
|
||||||
|
|
||||||
// Skips the ":".
|
|
||||||
const char* const cwd_without_drive = strchr(cwd.c_str(), ':');
|
|
||||||
ASSERT_TRUE(cwd_without_drive != NULL);
|
|
||||||
EXPECT_STREQ(GTEST_PATH_SEP_, cwd_without_drive + 1);
|
|
||||||
|
|
||||||
# else
|
|
||||||
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_, cwd.string());
|
|
||||||
|
|
||||||
# endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // GTEST_OS_WINDOWS_MOBILE
|
|
||||||
|
|
||||||
TEST(IsEmptyTest, ReturnsTrueForEmptyPath) {
|
|
||||||
EXPECT_TRUE(FilePath("").IsEmpty());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(IsEmptyTest, ReturnsFalseForNonEmptyPath) {
|
|
||||||
EXPECT_FALSE(FilePath("a").IsEmpty());
|
|
||||||
EXPECT_FALSE(FilePath(".").IsEmpty());
|
|
||||||
EXPECT_FALSE(FilePath("a/b").IsEmpty());
|
|
||||||
EXPECT_FALSE(FilePath("a\\b\\").IsEmpty());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName "" -> ""
|
|
||||||
TEST(RemoveDirectoryNameTest, WhenEmptyName) {
|
|
||||||
EXPECT_EQ("", FilePath("").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName "afile" -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, ButNoDirectory) {
|
|
||||||
EXPECT_EQ("afile",
|
|
||||||
FilePath("afile").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName "/afile" -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, RootFileShouldGiveFileName) {
|
|
||||||
EXPECT_EQ("afile",
|
|
||||||
FilePath(GTEST_PATH_SEP_ "afile").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName "adir/" -> ""
|
|
||||||
TEST(RemoveDirectoryNameTest, WhereThereIsNoFileName) {
|
|
||||||
EXPECT_EQ("",
|
|
||||||
FilePath("adir" GTEST_PATH_SEP_).RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName "adir/afile" -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, ShouldGiveFileName) {
|
|
||||||
EXPECT_EQ("afile",
|
|
||||||
FilePath("adir" GTEST_PATH_SEP_ "afile").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName "adir/subdir/afile" -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, ShouldAlsoGiveFileName) {
|
|
||||||
EXPECT_EQ("afile",
|
|
||||||
FilePath("adir" GTEST_PATH_SEP_ "subdir" GTEST_PATH_SEP_ "afile")
|
|
||||||
.RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_HAS_ALT_PATH_SEP_
|
|
||||||
|
|
||||||
// Tests that RemoveDirectoryName() works with the alternate separator
|
|
||||||
// on Windows.
|
|
||||||
|
|
||||||
// RemoveDirectoryName("/afile") -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, RootFileShouldGiveFileNameForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("afile", FilePath("/afile").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName("adir/") -> ""
|
|
||||||
TEST(RemoveDirectoryNameTest, WhereThereIsNoFileNameForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("", FilePath("adir/").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName("adir/afile") -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, ShouldGiveFileNameForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("afile", FilePath("adir/afile").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveDirectoryName("adir/subdir/afile") -> "afile"
|
|
||||||
TEST(RemoveDirectoryNameTest, ShouldAlsoGiveFileNameForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("afile",
|
|
||||||
FilePath("adir/subdir/afile").RemoveDirectoryName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// RemoveFileName "" -> "./"
|
|
||||||
TEST(RemoveFileNameTest, EmptyName) {
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
// On Windows CE, we use the root as the current directory.
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_, FilePath("").RemoveFileName().string());
|
|
||||||
#else
|
|
||||||
EXPECT_EQ("." GTEST_PATH_SEP_, FilePath("").RemoveFileName().string());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName "adir/" -> "adir/"
|
|
||||||
TEST(RemoveFileNameTest, ButNoFile) {
|
|
||||||
EXPECT_EQ("adir" GTEST_PATH_SEP_,
|
|
||||||
FilePath("adir" GTEST_PATH_SEP_).RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName "adir/afile" -> "adir/"
|
|
||||||
TEST(RemoveFileNameTest, GivesDirName) {
|
|
||||||
EXPECT_EQ("adir" GTEST_PATH_SEP_,
|
|
||||||
FilePath("adir" GTEST_PATH_SEP_ "afile").RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName "adir/subdir/afile" -> "adir/subdir/"
|
|
||||||
TEST(RemoveFileNameTest, GivesDirAndSubDirName) {
|
|
||||||
EXPECT_EQ("adir" GTEST_PATH_SEP_ "subdir" GTEST_PATH_SEP_,
|
|
||||||
FilePath("adir" GTEST_PATH_SEP_ "subdir" GTEST_PATH_SEP_ "afile")
|
|
||||||
.RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName "/afile" -> "/"
|
|
||||||
TEST(RemoveFileNameTest, GivesRootDir) {
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_,
|
|
||||||
FilePath(GTEST_PATH_SEP_ "afile").RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_HAS_ALT_PATH_SEP_
|
|
||||||
|
|
||||||
// Tests that RemoveFileName() works with the alternate separator on
|
|
||||||
// Windows.
|
|
||||||
|
|
||||||
// RemoveFileName("adir/") -> "adir/"
|
|
||||||
TEST(RemoveFileNameTest, ButNoFileForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("adir" GTEST_PATH_SEP_,
|
|
||||||
FilePath("adir/").RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName("adir/afile") -> "adir/"
|
|
||||||
TEST(RemoveFileNameTest, GivesDirNameForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("adir" GTEST_PATH_SEP_,
|
|
||||||
FilePath("adir/afile").RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName("adir/subdir/afile") -> "adir/subdir/"
|
|
||||||
TEST(RemoveFileNameTest, GivesDirAndSubDirNameForAlternateSeparator) {
|
|
||||||
EXPECT_EQ("adir" GTEST_PATH_SEP_ "subdir" GTEST_PATH_SEP_,
|
|
||||||
FilePath("adir/subdir/afile").RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveFileName("/afile") -> "\"
|
|
||||||
TEST(RemoveFileNameTest, GivesRootDirForAlternateSeparator) {
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_, FilePath("/afile").RemoveFileName().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
TEST(MakeFileNameTest, GenerateWhenNumberIsZero) {
|
|
||||||
FilePath actual = FilePath::MakeFileName(FilePath("foo"), FilePath("bar"),
|
|
||||||
0, "xml");
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeFileNameTest, GenerateFileNameNumberGtZero) {
|
|
||||||
FilePath actual = FilePath::MakeFileName(FilePath("foo"), FilePath("bar"),
|
|
||||||
12, "xml");
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar_12.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeFileNameTest, GenerateFileNameWithSlashNumberIsZero) {
|
|
||||||
FilePath actual = FilePath::MakeFileName(FilePath("foo" GTEST_PATH_SEP_),
|
|
||||||
FilePath("bar"), 0, "xml");
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeFileNameTest, GenerateFileNameWithSlashNumberGtZero) {
|
|
||||||
FilePath actual = FilePath::MakeFileName(FilePath("foo" GTEST_PATH_SEP_),
|
|
||||||
FilePath("bar"), 12, "xml");
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar_12.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeFileNameTest, GenerateWhenNumberIsZeroAndDirIsEmpty) {
|
|
||||||
FilePath actual = FilePath::MakeFileName(FilePath(""), FilePath("bar"),
|
|
||||||
0, "xml");
|
|
||||||
EXPECT_EQ("bar.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeFileNameTest, GenerateWhenNumberIsNotZeroAndDirIsEmpty) {
|
|
||||||
FilePath actual = FilePath::MakeFileName(FilePath(""), FilePath("bar"),
|
|
||||||
14, "xml");
|
|
||||||
EXPECT_EQ("bar_14.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, WorksWhenDirDoesNotEndWithPathSep) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath("foo"),
|
|
||||||
FilePath("bar.xml"));
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, WorksWhenPath1EndsWithPathSep) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath("foo" GTEST_PATH_SEP_),
|
|
||||||
FilePath("bar.xml"));
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, Path1BeingEmpty) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath(""),
|
|
||||||
FilePath("bar.xml"));
|
|
||||||
EXPECT_EQ("bar.xml", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, Path2BeingEmpty) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath("foo"), FilePath(""));
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_, actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, BothPathBeingEmpty) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath(""),
|
|
||||||
FilePath(""));
|
|
||||||
EXPECT_EQ("", actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, Path1ContainsPathSep) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath("foo" GTEST_PATH_SEP_ "bar"),
|
|
||||||
FilePath("foobar.xml"));
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar" GTEST_PATH_SEP_ "foobar.xml",
|
|
||||||
actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, Path2ContainsPathSep) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_),
|
|
||||||
FilePath("bar" GTEST_PATH_SEP_ "bar.xml"));
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar" GTEST_PATH_SEP_ "bar.xml",
|
|
||||||
actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ConcatPathsTest, Path2EndsWithPathSep) {
|
|
||||||
FilePath actual = FilePath::ConcatPaths(FilePath("foo"),
|
|
||||||
FilePath("bar" GTEST_PATH_SEP_));
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar" GTEST_PATH_SEP_, actual.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveTrailingPathSeparator "" -> ""
|
|
||||||
TEST(RemoveTrailingPathSeparatorTest, EmptyString) {
|
|
||||||
EXPECT_EQ("", FilePath("").RemoveTrailingPathSeparator().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveTrailingPathSeparator "foo" -> "foo"
|
|
||||||
TEST(RemoveTrailingPathSeparatorTest, FileNoSlashString) {
|
|
||||||
EXPECT_EQ("foo", FilePath("foo").RemoveTrailingPathSeparator().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveTrailingPathSeparator "foo/" -> "foo"
|
|
||||||
TEST(RemoveTrailingPathSeparatorTest, ShouldRemoveTrailingSeparator) {
|
|
||||||
EXPECT_EQ("foo",
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_).RemoveTrailingPathSeparator().string());
|
|
||||||
#if GTEST_HAS_ALT_PATH_SEP_
|
|
||||||
EXPECT_EQ("foo", FilePath("foo/").RemoveTrailingPathSeparator().string());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveTrailingPathSeparator "foo/bar/" -> "foo/bar/"
|
|
||||||
TEST(RemoveTrailingPathSeparatorTest, ShouldRemoveLastSeparator) {
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ "bar" GTEST_PATH_SEP_)
|
|
||||||
.RemoveTrailingPathSeparator().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// RemoveTrailingPathSeparator "foo/bar" -> "foo/bar"
|
|
||||||
TEST(RemoveTrailingPathSeparatorTest, ShouldReturnUnmodified) {
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ "bar")
|
|
||||||
.RemoveTrailingPathSeparator().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(DirectoryTest, RootDirectoryExists) {
|
|
||||||
#if GTEST_OS_WINDOWS // We are on Windows.
|
|
||||||
char current_drive[_MAX_PATH]; // NOLINT
|
|
||||||
current_drive[0] = static_cast<char>(_getdrive() + 'A' - 1);
|
|
||||||
current_drive[1] = ':';
|
|
||||||
current_drive[2] = '\\';
|
|
||||||
current_drive[3] = '\0';
|
|
||||||
EXPECT_TRUE(FilePath(current_drive).DirectoryExists());
|
|
||||||
#else
|
|
||||||
EXPECT_TRUE(FilePath("/").DirectoryExists());
|
|
||||||
#endif // GTEST_OS_WINDOWS
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
TEST(DirectoryTest, RootOfWrongDriveDoesNotExists) {
|
|
||||||
const int saved_drive_ = _getdrive();
|
|
||||||
// Find a drive that doesn't exist. Start with 'Z' to avoid common ones.
|
|
||||||
for (char drive = 'Z'; drive >= 'A'; drive--)
|
|
||||||
if (_chdrive(drive - 'A' + 1) == -1) {
|
|
||||||
char non_drive[_MAX_PATH]; // NOLINT
|
|
||||||
non_drive[0] = drive;
|
|
||||||
non_drive[1] = ':';
|
|
||||||
non_drive[2] = '\\';
|
|
||||||
non_drive[3] = '\0';
|
|
||||||
EXPECT_FALSE(FilePath(non_drive).DirectoryExists());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
_chdrive(saved_drive_);
|
|
||||||
}
|
|
||||||
#endif // GTEST_OS_WINDOWS
|
|
||||||
|
|
||||||
#if !GTEST_OS_WINDOWS_MOBILE
|
|
||||||
// Windows CE _does_ consider an empty directory to exist.
|
|
||||||
TEST(DirectoryTest, EmptyPathDirectoryDoesNotExist) {
|
|
||||||
EXPECT_FALSE(FilePath("").DirectoryExists());
|
|
||||||
}
|
|
||||||
#endif // !GTEST_OS_WINDOWS_MOBILE
|
|
||||||
|
|
||||||
TEST(DirectoryTest, CurrentDirectoryExists) {
|
|
||||||
#if GTEST_OS_WINDOWS // We are on Windows.
|
|
||||||
# ifndef _WIN32_CE // Windows CE doesn't have a current directory.
|
|
||||||
|
|
||||||
EXPECT_TRUE(FilePath(".").DirectoryExists());
|
|
||||||
EXPECT_TRUE(FilePath(".\\").DirectoryExists());
|
|
||||||
|
|
||||||
# endif // _WIN32_CE
|
|
||||||
#else
|
|
||||||
EXPECT_TRUE(FilePath(".").DirectoryExists());
|
|
||||||
EXPECT_TRUE(FilePath("./").DirectoryExists());
|
|
||||||
#endif // GTEST_OS_WINDOWS
|
|
||||||
}
|
|
||||||
|
|
||||||
// "foo/bar" == foo//bar" == "foo///bar"
|
|
||||||
TEST(NormalizeTest, MultipleConsecutiveSepaparatorsInMidstring) {
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ "bar").string());
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ GTEST_PATH_SEP_ "bar").string());
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ GTEST_PATH_SEP_
|
|
||||||
GTEST_PATH_SEP_ "bar").string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// "/bar" == //bar" == "///bar"
|
|
||||||
TEST(NormalizeTest, MultipleConsecutiveSepaparatorsAtStringStart) {
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath(GTEST_PATH_SEP_ "bar").string());
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath(GTEST_PATH_SEP_ GTEST_PATH_SEP_ "bar").string());
|
|
||||||
EXPECT_EQ(GTEST_PATH_SEP_ "bar",
|
|
||||||
FilePath(GTEST_PATH_SEP_ GTEST_PATH_SEP_ GTEST_PATH_SEP_ "bar").string());
|
|
||||||
}
|
|
||||||
|
|
||||||
// "foo/" == foo//" == "foo///"
|
|
||||||
TEST(NormalizeTest, MultipleConsecutiveSepaparatorsAtStringEnd) {
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_,
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_).string());
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_,
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ GTEST_PATH_SEP_).string());
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_,
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ GTEST_PATH_SEP_ GTEST_PATH_SEP_).string());
|
|
||||||
}
|
|
||||||
|
|
||||||
#if GTEST_HAS_ALT_PATH_SEP_
|
|
||||||
|
|
||||||
// Tests that separators at the end of the string are normalized
|
|
||||||
// regardless of their combination (e.g. "foo\" =="foo/\" ==
|
|
||||||
// "foo\\/").
|
|
||||||
TEST(NormalizeTest, MixAlternateSeparatorAtStringEnd) {
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_,
|
|
||||||
FilePath("foo/").string());
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_,
|
|
||||||
FilePath("foo" GTEST_PATH_SEP_ "/").string());
|
|
||||||
EXPECT_EQ("foo" GTEST_PATH_SEP_,
|
|
||||||
FilePath("foo//" GTEST_PATH_SEP_).string());
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
TEST(AssignmentOperatorTest, DefaultAssignedToNonDefault) {
|
|
||||||
FilePath default_path;
|
|
||||||
FilePath non_default_path("path");
|
|
||||||
non_default_path = default_path;
|
|
||||||
EXPECT_EQ("", non_default_path.string());
|
|
||||||
EXPECT_EQ("", default_path.string()); // RHS var is unchanged.
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(AssignmentOperatorTest, NonDefaultAssignedToDefault) {
|
|
||||||
FilePath non_default_path("path");
|
|
||||||
FilePath default_path;
|
|
||||||
default_path = non_default_path;
|
|
||||||
EXPECT_EQ("path", default_path.string());
|
|
||||||
EXPECT_EQ("path", non_default_path.string()); // RHS var is unchanged.
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(AssignmentOperatorTest, ConstAssignedToNonConst) {
|
|
||||||
const FilePath const_default_path("const_path");
|
|
||||||
FilePath non_default_path("path");
|
|
||||||
non_default_path = const_default_path;
|
|
||||||
EXPECT_EQ("const_path", non_default_path.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
class DirectoryCreationTest : public Test {
|
|
||||||
protected:
|
|
||||||
virtual void SetUp() {
|
|
||||||
testdata_path_.Set(FilePath(
|
|
||||||
TempDir() + GetCurrentExecutableName().string() +
|
|
||||||
"_directory_creation" GTEST_PATH_SEP_ "test" GTEST_PATH_SEP_));
|
|
||||||
testdata_file_.Set(testdata_path_.RemoveTrailingPathSeparator());
|
|
||||||
|
|
||||||
unique_file0_.Set(FilePath::MakeFileName(testdata_path_, FilePath("unique"),
|
|
||||||
0, "txt"));
|
|
||||||
unique_file1_.Set(FilePath::MakeFileName(testdata_path_, FilePath("unique"),
|
|
||||||
1, "txt"));
|
|
||||||
|
|
||||||
remove(testdata_file_.c_str());
|
|
||||||
remove(unique_file0_.c_str());
|
|
||||||
remove(unique_file1_.c_str());
|
|
||||||
posix::RmDir(testdata_path_.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void TearDown() {
|
|
||||||
remove(testdata_file_.c_str());
|
|
||||||
remove(unique_file0_.c_str());
|
|
||||||
remove(unique_file1_.c_str());
|
|
||||||
posix::RmDir(testdata_path_.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string TempDir() const {
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
return "\\temp\\";
|
|
||||||
#elif GTEST_OS_WINDOWS
|
|
||||||
const char* temp_dir = posix::GetEnv("TEMP");
|
|
||||||
if (temp_dir == NULL || temp_dir[0] == '\0')
|
|
||||||
return "\\temp\\";
|
|
||||||
else if (temp_dir[strlen(temp_dir) - 1] == '\\')
|
|
||||||
return temp_dir;
|
|
||||||
else
|
|
||||||
return std::string(temp_dir) + "\\";
|
|
||||||
#elif GTEST_OS_LINUX_ANDROID
|
|
||||||
return "/sdcard/";
|
|
||||||
#else
|
|
||||||
return "/tmp/";
|
|
||||||
#endif // GTEST_OS_WINDOWS_MOBILE
|
|
||||||
}
|
|
||||||
|
|
||||||
void CreateTextFile(const char* filename) {
|
|
||||||
FILE* f = posix::FOpen(filename, "w");
|
|
||||||
fprintf(f, "text\n");
|
|
||||||
fclose(f);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Strings representing a directory and a file, with identical paths
|
|
||||||
// except for the trailing separator character that distinquishes
|
|
||||||
// a directory named 'test' from a file named 'test'. Example names:
|
|
||||||
FilePath testdata_path_; // "/tmp/directory_creation/test/"
|
|
||||||
FilePath testdata_file_; // "/tmp/directory_creation/test"
|
|
||||||
FilePath unique_file0_; // "/tmp/directory_creation/test/unique.txt"
|
|
||||||
FilePath unique_file1_; // "/tmp/directory_creation/test/unique_1.txt"
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST_F(DirectoryCreationTest, CreateDirectoriesRecursively) {
|
|
||||||
EXPECT_FALSE(testdata_path_.DirectoryExists()) << testdata_path_.string();
|
|
||||||
EXPECT_TRUE(testdata_path_.CreateDirectoriesRecursively());
|
|
||||||
EXPECT_TRUE(testdata_path_.DirectoryExists());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(DirectoryCreationTest, CreateDirectoriesForAlreadyExistingPath) {
|
|
||||||
EXPECT_FALSE(testdata_path_.DirectoryExists()) << testdata_path_.string();
|
|
||||||
EXPECT_TRUE(testdata_path_.CreateDirectoriesRecursively());
|
|
||||||
// Call 'create' again... should still succeed.
|
|
||||||
EXPECT_TRUE(testdata_path_.CreateDirectoriesRecursively());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(DirectoryCreationTest, CreateDirectoriesAndUniqueFilename) {
|
|
||||||
FilePath file_path(FilePath::GenerateUniqueFileName(testdata_path_,
|
|
||||||
FilePath("unique"), "txt"));
|
|
||||||
EXPECT_EQ(unique_file0_.string(), file_path.string());
|
|
||||||
EXPECT_FALSE(file_path.FileOrDirectoryExists()); // file not there
|
|
||||||
|
|
||||||
testdata_path_.CreateDirectoriesRecursively();
|
|
||||||
EXPECT_FALSE(file_path.FileOrDirectoryExists()); // file still not there
|
|
||||||
CreateTextFile(file_path.c_str());
|
|
||||||
EXPECT_TRUE(file_path.FileOrDirectoryExists());
|
|
||||||
|
|
||||||
FilePath file_path2(FilePath::GenerateUniqueFileName(testdata_path_,
|
|
||||||
FilePath("unique"), "txt"));
|
|
||||||
EXPECT_EQ(unique_file1_.string(), file_path2.string());
|
|
||||||
EXPECT_FALSE(file_path2.FileOrDirectoryExists()); // file not there
|
|
||||||
CreateTextFile(file_path2.c_str());
|
|
||||||
EXPECT_TRUE(file_path2.FileOrDirectoryExists());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(DirectoryCreationTest, CreateDirectoriesFail) {
|
|
||||||
// force a failure by putting a file where we will try to create a directory.
|
|
||||||
CreateTextFile(testdata_file_.c_str());
|
|
||||||
EXPECT_TRUE(testdata_file_.FileOrDirectoryExists());
|
|
||||||
EXPECT_FALSE(testdata_file_.DirectoryExists());
|
|
||||||
EXPECT_FALSE(testdata_file_.CreateDirectoriesRecursively());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(NoDirectoryCreationTest, CreateNoDirectoriesForDefaultXmlFile) {
|
|
||||||
const FilePath test_detail_xml("test_detail.xml");
|
|
||||||
EXPECT_FALSE(test_detail_xml.CreateDirectoriesRecursively());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, DefaultConstructor) {
|
|
||||||
FilePath fp;
|
|
||||||
EXPECT_EQ("", fp.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, CharAndCopyConstructors) {
|
|
||||||
const FilePath fp("spicy");
|
|
||||||
EXPECT_EQ("spicy", fp.string());
|
|
||||||
|
|
||||||
const FilePath fp_copy(fp);
|
|
||||||
EXPECT_EQ("spicy", fp_copy.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, StringConstructor) {
|
|
||||||
const FilePath fp(std::string("cider"));
|
|
||||||
EXPECT_EQ("cider", fp.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, Set) {
|
|
||||||
const FilePath apple("apple");
|
|
||||||
FilePath mac("mac");
|
|
||||||
mac.Set(apple); // Implement Set() since overloading operator= is forbidden.
|
|
||||||
EXPECT_EQ("apple", mac.string());
|
|
||||||
EXPECT_EQ("apple", apple.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, ToString) {
|
|
||||||
const FilePath file("drink");
|
|
||||||
EXPECT_EQ("drink", file.string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, RemoveExtension) {
|
|
||||||
EXPECT_EQ("app", FilePath("app.cc").RemoveExtension("cc").string());
|
|
||||||
EXPECT_EQ("app", FilePath("app.exe").RemoveExtension("exe").string());
|
|
||||||
EXPECT_EQ("APP", FilePath("APP.EXE").RemoveExtension("exe").string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, RemoveExtensionWhenThereIsNoExtension) {
|
|
||||||
EXPECT_EQ("app", FilePath("app").RemoveExtension("exe").string());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, IsDirectory) {
|
|
||||||
EXPECT_FALSE(FilePath("cola").IsDirectory());
|
|
||||||
EXPECT_TRUE(FilePath("koala" GTEST_PATH_SEP_).IsDirectory());
|
|
||||||
#if GTEST_HAS_ALT_PATH_SEP_
|
|
||||||
EXPECT_TRUE(FilePath("koala/").IsDirectory());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, IsAbsolutePath) {
|
|
||||||
EXPECT_FALSE(FilePath("is" GTEST_PATH_SEP_ "relative").IsAbsolutePath());
|
|
||||||
EXPECT_FALSE(FilePath("").IsAbsolutePath());
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
EXPECT_TRUE(FilePath("c:\\" GTEST_PATH_SEP_ "is_not"
|
|
||||||
GTEST_PATH_SEP_ "relative").IsAbsolutePath());
|
|
||||||
EXPECT_FALSE(FilePath("c:foo" GTEST_PATH_SEP_ "bar").IsAbsolutePath());
|
|
||||||
EXPECT_TRUE(FilePath("c:/" GTEST_PATH_SEP_ "is_not"
|
|
||||||
GTEST_PATH_SEP_ "relative").IsAbsolutePath());
|
|
||||||
#else
|
|
||||||
EXPECT_TRUE(FilePath(GTEST_PATH_SEP_ "is_not" GTEST_PATH_SEP_ "relative")
|
|
||||||
.IsAbsolutePath());
|
|
||||||
#endif // GTEST_OS_WINDOWS
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(FilePathTest, IsRootDirectory) {
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
EXPECT_TRUE(FilePath("a:\\").IsRootDirectory());
|
|
||||||
EXPECT_TRUE(FilePath("Z:/").IsRootDirectory());
|
|
||||||
EXPECT_TRUE(FilePath("e://").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("b:").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("b:a").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("8:/").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("c|/").IsRootDirectory());
|
|
||||||
#else
|
|
||||||
EXPECT_TRUE(FilePath("/").IsRootDirectory());
|
|
||||||
EXPECT_TRUE(FilePath("//").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("\\").IsRootDirectory());
|
|
||||||
EXPECT_FALSE(FilePath("/x").IsRootDirectory());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
@ -1,154 +0,0 @@
|
|||||||
// Copyright 2003, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: Dan Egnor (egnor@google.com)
|
|
||||||
// Ported to Windows: Vadim Berman (vadimb@google.com)
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-linked_ptr.h"
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
using testing::Message;
|
|
||||||
using testing::internal::linked_ptr;
|
|
||||||
|
|
||||||
int num;
|
|
||||||
Message* history = NULL;
|
|
||||||
|
|
||||||
// Class which tracks allocation/deallocation
|
|
||||||
class A {
|
|
||||||
public:
|
|
||||||
A(): mynum(num++) { *history << "A" << mynum << " ctor\n"; }
|
|
||||||
virtual ~A() { *history << "A" << mynum << " dtor\n"; }
|
|
||||||
virtual void Use() { *history << "A" << mynum << " use\n"; }
|
|
||||||
protected:
|
|
||||||
int mynum;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Subclass
|
|
||||||
class B : public A {
|
|
||||||
public:
|
|
||||||
B() { *history << "B" << mynum << " ctor\n"; }
|
|
||||||
~B() { *history << "B" << mynum << " dtor\n"; }
|
|
||||||
virtual void Use() { *history << "B" << mynum << " use\n"; }
|
|
||||||
};
|
|
||||||
|
|
||||||
class LinkedPtrTest : public testing::Test {
|
|
||||||
public:
|
|
||||||
LinkedPtrTest() {
|
|
||||||
num = 0;
|
|
||||||
history = new Message;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ~LinkedPtrTest() {
|
|
||||||
delete history;
|
|
||||||
history = NULL;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST_F(LinkedPtrTest, GeneralTest) {
|
|
||||||
{
|
|
||||||
linked_ptr<A> a0, a1, a2;
|
|
||||||
// Use explicit function call notation here to suppress self-assign warning.
|
|
||||||
a0.operator=(a0);
|
|
||||||
a1 = a2;
|
|
||||||
ASSERT_EQ(a0.get(), static_cast<A*>(NULL));
|
|
||||||
ASSERT_EQ(a1.get(), static_cast<A*>(NULL));
|
|
||||||
ASSERT_EQ(a2.get(), static_cast<A*>(NULL));
|
|
||||||
ASSERT_TRUE(a0 == NULL);
|
|
||||||
ASSERT_TRUE(a1 == NULL);
|
|
||||||
ASSERT_TRUE(a2 == NULL);
|
|
||||||
|
|
||||||
{
|
|
||||||
linked_ptr<A> a3(new A);
|
|
||||||
a0 = a3;
|
|
||||||
ASSERT_TRUE(a0 == a3);
|
|
||||||
ASSERT_TRUE(a0 != NULL);
|
|
||||||
ASSERT_TRUE(a0.get() == a3);
|
|
||||||
ASSERT_TRUE(a0 == a3.get());
|
|
||||||
linked_ptr<A> a4(a0);
|
|
||||||
a1 = a4;
|
|
||||||
linked_ptr<A> a5(new A);
|
|
||||||
ASSERT_TRUE(a5.get() != a3);
|
|
||||||
ASSERT_TRUE(a5 != a3.get());
|
|
||||||
a2 = a5;
|
|
||||||
linked_ptr<B> b0(new B);
|
|
||||||
linked_ptr<A> a6(b0);
|
|
||||||
ASSERT_TRUE(b0 == a6);
|
|
||||||
ASSERT_TRUE(a6 == b0);
|
|
||||||
ASSERT_TRUE(b0 != NULL);
|
|
||||||
a5 = b0;
|
|
||||||
a5 = b0;
|
|
||||||
a3->Use();
|
|
||||||
a4->Use();
|
|
||||||
a5->Use();
|
|
||||||
a6->Use();
|
|
||||||
b0->Use();
|
|
||||||
(*b0).Use();
|
|
||||||
b0.get()->Use();
|
|
||||||
}
|
|
||||||
|
|
||||||
a0->Use();
|
|
||||||
a1->Use();
|
|
||||||
a2->Use();
|
|
||||||
|
|
||||||
a1 = a2;
|
|
||||||
a2.reset(new A);
|
|
||||||
a0.reset();
|
|
||||||
|
|
||||||
linked_ptr<A> a7;
|
|
||||||
}
|
|
||||||
|
|
||||||
ASSERT_STREQ(
|
|
||||||
"A0 ctor\n"
|
|
||||||
"A1 ctor\n"
|
|
||||||
"A2 ctor\n"
|
|
||||||
"B2 ctor\n"
|
|
||||||
"A0 use\n"
|
|
||||||
"A0 use\n"
|
|
||||||
"B2 use\n"
|
|
||||||
"B2 use\n"
|
|
||||||
"B2 use\n"
|
|
||||||
"B2 use\n"
|
|
||||||
"B2 use\n"
|
|
||||||
"B2 dtor\n"
|
|
||||||
"A2 dtor\n"
|
|
||||||
"A0 use\n"
|
|
||||||
"A0 use\n"
|
|
||||||
"A1 use\n"
|
|
||||||
"A3 ctor\n"
|
|
||||||
"A0 dtor\n"
|
|
||||||
"A3 dtor\n"
|
|
||||||
"A1 dtor\n",
|
|
||||||
history->GetString().c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
} // Unnamed namespace
|
|
@ -1,310 +0,0 @@
|
|||||||
// Copyright 2009 Google Inc. All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: vladl@google.com (Vlad Losev)
|
|
||||||
//
|
|
||||||
// The Google C++ Testing Framework (Google Test)
|
|
||||||
//
|
|
||||||
// This file verifies Google Test event listeners receive events at the
|
|
||||||
// right times.
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
using ::testing::AddGlobalTestEnvironment;
|
|
||||||
using ::testing::Environment;
|
|
||||||
using ::testing::InitGoogleTest;
|
|
||||||
using ::testing::Test;
|
|
||||||
using ::testing::TestCase;
|
|
||||||
using ::testing::TestEventListener;
|
|
||||||
using ::testing::TestInfo;
|
|
||||||
using ::testing::TestPartResult;
|
|
||||||
using ::testing::UnitTest;
|
|
||||||
|
|
||||||
// Used by tests to register their events.
|
|
||||||
std::vector<std::string>* g_events = NULL;
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
class EventRecordingListener : public TestEventListener {
|
|
||||||
public:
|
|
||||||
explicit EventRecordingListener(const char* name) : name_(name) {}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual void OnTestProgramStart(const UnitTest& /*unit_test*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestProgramStart"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestIterationStart(const UnitTest& /*unit_test*/,
|
|
||||||
int iteration) {
|
|
||||||
Message message;
|
|
||||||
message << GetFullMethodName("OnTestIterationStart")
|
|
||||||
<< "(" << iteration << ")";
|
|
||||||
g_events->push_back(message.GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnEnvironmentsSetUpStart(const UnitTest& /*unit_test*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnEnvironmentsSetUpStart"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnEnvironmentsSetUpEnd(const UnitTest& /*unit_test*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnEnvironmentsSetUpEnd"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestCaseStart(const TestCase& /*test_case*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestCaseStart"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestStart(const TestInfo& /*test_info*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestStart"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestPartResult(const TestPartResult& /*test_part_result*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestPartResult"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestEnd(const TestInfo& /*test_info*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestEnd"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestCaseEnd(const TestCase& /*test_case*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestCaseEnd"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnEnvironmentsTearDownStart(const UnitTest& /*unit_test*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnEnvironmentsTearDownStart"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnEnvironmentsTearDownEnd(const UnitTest& /*unit_test*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnEnvironmentsTearDownEnd"));
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestIterationEnd(const UnitTest& /*unit_test*/,
|
|
||||||
int iteration) {
|
|
||||||
Message message;
|
|
||||||
message << GetFullMethodName("OnTestIterationEnd")
|
|
||||||
<< "(" << iteration << ")";
|
|
||||||
g_events->push_back(message.GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void OnTestProgramEnd(const UnitTest& /*unit_test*/) {
|
|
||||||
g_events->push_back(GetFullMethodName("OnTestProgramEnd"));
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::string GetFullMethodName(const char* name) {
|
|
||||||
return name_ + "." + name;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string name_;
|
|
||||||
};
|
|
||||||
|
|
||||||
class EnvironmentInvocationCatcher : public Environment {
|
|
||||||
protected:
|
|
||||||
virtual void SetUp() {
|
|
||||||
g_events->push_back("Environment::SetUp");
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void TearDown() {
|
|
||||||
g_events->push_back("Environment::TearDown");
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
class ListenerTest : public Test {
|
|
||||||
protected:
|
|
||||||
static void SetUpTestCase() {
|
|
||||||
g_events->push_back("ListenerTest::SetUpTestCase");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void TearDownTestCase() {
|
|
||||||
g_events->push_back("ListenerTest::TearDownTestCase");
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void SetUp() {
|
|
||||||
g_events->push_back("ListenerTest::SetUp");
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void TearDown() {
|
|
||||||
g_events->push_back("ListenerTest::TearDown");
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST_F(ListenerTest, DoesFoo) {
|
|
||||||
// Test execution order within a test case is not guaranteed so we are not
|
|
||||||
// recording the test name.
|
|
||||||
g_events->push_back("ListenerTest::* Test Body");
|
|
||||||
SUCCEED(); // Triggers OnTestPartResult.
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(ListenerTest, DoesBar) {
|
|
||||||
g_events->push_back("ListenerTest::* Test Body");
|
|
||||||
SUCCEED(); // Triggers OnTestPartResult.
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
} // namespace testing
|
|
||||||
|
|
||||||
using ::testing::internal::EnvironmentInvocationCatcher;
|
|
||||||
using ::testing::internal::EventRecordingListener;
|
|
||||||
|
|
||||||
void VerifyResults(const std::vector<std::string>& data,
|
|
||||||
const char* const* expected_data,
|
|
||||||
int expected_data_size) {
|
|
||||||
const int actual_size = data.size();
|
|
||||||
// If the following assertion fails, a new entry will be appended to
|
|
||||||
// data. Hence we save data.size() first.
|
|
||||||
EXPECT_EQ(expected_data_size, actual_size);
|
|
||||||
|
|
||||||
// Compares the common prefix.
|
|
||||||
const int shorter_size = expected_data_size <= actual_size ?
|
|
||||||
expected_data_size : actual_size;
|
|
||||||
int i = 0;
|
|
||||||
for (; i < shorter_size; ++i) {
|
|
||||||
ASSERT_STREQ(expected_data[i], data[i].c_str())
|
|
||||||
<< "at position " << i;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prints extra elements in the actual data.
|
|
||||||
for (; i < actual_size; ++i) {
|
|
||||||
printf(" Actual event #%d: %s\n", i, data[i].c_str());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
|
||||||
std::vector<std::string> events;
|
|
||||||
g_events = &events;
|
|
||||||
InitGoogleTest(&argc, argv);
|
|
||||||
|
|
||||||
UnitTest::GetInstance()->listeners().Append(
|
|
||||||
new EventRecordingListener("1st"));
|
|
||||||
UnitTest::GetInstance()->listeners().Append(
|
|
||||||
new EventRecordingListener("2nd"));
|
|
||||||
|
|
||||||
AddGlobalTestEnvironment(new EnvironmentInvocationCatcher);
|
|
||||||
|
|
||||||
GTEST_CHECK_(events.size() == 0)
|
|
||||||
<< "AddGlobalTestEnvironment should not generate any events itself.";
|
|
||||||
|
|
||||||
::testing::GTEST_FLAG(repeat) = 2;
|
|
||||||
int ret_val = RUN_ALL_TESTS();
|
|
||||||
|
|
||||||
const char* const expected_events[] = {
|
|
||||||
"1st.OnTestProgramStart",
|
|
||||||
"2nd.OnTestProgramStart",
|
|
||||||
"1st.OnTestIterationStart(0)",
|
|
||||||
"2nd.OnTestIterationStart(0)",
|
|
||||||
"1st.OnEnvironmentsSetUpStart",
|
|
||||||
"2nd.OnEnvironmentsSetUpStart",
|
|
||||||
"Environment::SetUp",
|
|
||||||
"2nd.OnEnvironmentsSetUpEnd",
|
|
||||||
"1st.OnEnvironmentsSetUpEnd",
|
|
||||||
"1st.OnTestCaseStart",
|
|
||||||
"2nd.OnTestCaseStart",
|
|
||||||
"ListenerTest::SetUpTestCase",
|
|
||||||
"1st.OnTestStart",
|
|
||||||
"2nd.OnTestStart",
|
|
||||||
"ListenerTest::SetUp",
|
|
||||||
"ListenerTest::* Test Body",
|
|
||||||
"1st.OnTestPartResult",
|
|
||||||
"2nd.OnTestPartResult",
|
|
||||||
"ListenerTest::TearDown",
|
|
||||||
"2nd.OnTestEnd",
|
|
||||||
"1st.OnTestEnd",
|
|
||||||
"1st.OnTestStart",
|
|
||||||
"2nd.OnTestStart",
|
|
||||||
"ListenerTest::SetUp",
|
|
||||||
"ListenerTest::* Test Body",
|
|
||||||
"1st.OnTestPartResult",
|
|
||||||
"2nd.OnTestPartResult",
|
|
||||||
"ListenerTest::TearDown",
|
|
||||||
"2nd.OnTestEnd",
|
|
||||||
"1st.OnTestEnd",
|
|
||||||
"ListenerTest::TearDownTestCase",
|
|
||||||
"2nd.OnTestCaseEnd",
|
|
||||||
"1st.OnTestCaseEnd",
|
|
||||||
"1st.OnEnvironmentsTearDownStart",
|
|
||||||
"2nd.OnEnvironmentsTearDownStart",
|
|
||||||
"Environment::TearDown",
|
|
||||||
"2nd.OnEnvironmentsTearDownEnd",
|
|
||||||
"1st.OnEnvironmentsTearDownEnd",
|
|
||||||
"2nd.OnTestIterationEnd(0)",
|
|
||||||
"1st.OnTestIterationEnd(0)",
|
|
||||||
"1st.OnTestIterationStart(1)",
|
|
||||||
"2nd.OnTestIterationStart(1)",
|
|
||||||
"1st.OnEnvironmentsSetUpStart",
|
|
||||||
"2nd.OnEnvironmentsSetUpStart",
|
|
||||||
"Environment::SetUp",
|
|
||||||
"2nd.OnEnvironmentsSetUpEnd",
|
|
||||||
"1st.OnEnvironmentsSetUpEnd",
|
|
||||||
"1st.OnTestCaseStart",
|
|
||||||
"2nd.OnTestCaseStart",
|
|
||||||
"ListenerTest::SetUpTestCase",
|
|
||||||
"1st.OnTestStart",
|
|
||||||
"2nd.OnTestStart",
|
|
||||||
"ListenerTest::SetUp",
|
|
||||||
"ListenerTest::* Test Body",
|
|
||||||
"1st.OnTestPartResult",
|
|
||||||
"2nd.OnTestPartResult",
|
|
||||||
"ListenerTest::TearDown",
|
|
||||||
"2nd.OnTestEnd",
|
|
||||||
"1st.OnTestEnd",
|
|
||||||
"1st.OnTestStart",
|
|
||||||
"2nd.OnTestStart",
|
|
||||||
"ListenerTest::SetUp",
|
|
||||||
"ListenerTest::* Test Body",
|
|
||||||
"1st.OnTestPartResult",
|
|
||||||
"2nd.OnTestPartResult",
|
|
||||||
"ListenerTest::TearDown",
|
|
||||||
"2nd.OnTestEnd",
|
|
||||||
"1st.OnTestEnd",
|
|
||||||
"ListenerTest::TearDownTestCase",
|
|
||||||
"2nd.OnTestCaseEnd",
|
|
||||||
"1st.OnTestCaseEnd",
|
|
||||||
"1st.OnEnvironmentsTearDownStart",
|
|
||||||
"2nd.OnEnvironmentsTearDownStart",
|
|
||||||
"Environment::TearDown",
|
|
||||||
"2nd.OnEnvironmentsTearDownEnd",
|
|
||||||
"1st.OnEnvironmentsTearDownEnd",
|
|
||||||
"2nd.OnTestIterationEnd(1)",
|
|
||||||
"1st.OnTestIterationEnd(1)",
|
|
||||||
"2nd.OnTestProgramEnd",
|
|
||||||
"1st.OnTestProgramEnd"
|
|
||||||
};
|
|
||||||
VerifyResults(events,
|
|
||||||
expected_events,
|
|
||||||
sizeof(expected_events)/sizeof(expected_events[0]));
|
|
||||||
|
|
||||||
// We need to check manually for ad hoc test failures that happen after
|
|
||||||
// RUN_ALL_TESTS finishes.
|
|
||||||
if (UnitTest::GetInstance()->Failed())
|
|
||||||
ret_val = 1;
|
|
||||||
|
|
||||||
return ret_val;
|
|
||||||
}
|
|
@ -1,159 +0,0 @@
|
|||||||
// Copyright 2005, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
//
|
|
||||||
// Tests for the Message class.
|
|
||||||
|
|
||||||
#include "gtest/gtest-message.h"
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
using ::testing::Message;
|
|
||||||
|
|
||||||
// Tests the testing::Message class
|
|
||||||
|
|
||||||
// Tests the default constructor.
|
|
||||||
TEST(MessageTest, DefaultConstructor) {
|
|
||||||
const Message msg;
|
|
||||||
EXPECT_EQ("", msg.GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests the copy constructor.
|
|
||||||
TEST(MessageTest, CopyConstructor) {
|
|
||||||
const Message msg1("Hello");
|
|
||||||
const Message msg2(msg1);
|
|
||||||
EXPECT_EQ("Hello", msg2.GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests constructing a Message from a C-string.
|
|
||||||
TEST(MessageTest, ConstructsFromCString) {
|
|
||||||
Message msg("Hello");
|
|
||||||
EXPECT_EQ("Hello", msg.GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a float.
|
|
||||||
TEST(MessageTest, StreamsFloat) {
|
|
||||||
const std::string s = (Message() << 1.23456F << " " << 2.34567F).GetString();
|
|
||||||
// Both numbers should be printed with enough precision.
|
|
||||||
EXPECT_PRED_FORMAT2(testing::IsSubstring, "1.234560", s.c_str());
|
|
||||||
EXPECT_PRED_FORMAT2(testing::IsSubstring, " 2.345669", s.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a double.
|
|
||||||
TEST(MessageTest, StreamsDouble) {
|
|
||||||
const std::string s = (Message() << 1260570880.4555497 << " "
|
|
||||||
<< 1260572265.1954534).GetString();
|
|
||||||
// Both numbers should be printed with enough precision.
|
|
||||||
EXPECT_PRED_FORMAT2(testing::IsSubstring, "1260570880.45", s.c_str());
|
|
||||||
EXPECT_PRED_FORMAT2(testing::IsSubstring, " 1260572265.19", s.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a non-char pointer.
|
|
||||||
TEST(MessageTest, StreamsPointer) {
|
|
||||||
int n = 0;
|
|
||||||
int* p = &n;
|
|
||||||
EXPECT_NE("(null)", (Message() << p).GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a NULL non-char pointer.
|
|
||||||
TEST(MessageTest, StreamsNullPointer) {
|
|
||||||
int* p = NULL;
|
|
||||||
EXPECT_EQ("(null)", (Message() << p).GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a C string.
|
|
||||||
TEST(MessageTest, StreamsCString) {
|
|
||||||
EXPECT_EQ("Foo", (Message() << "Foo").GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a NULL C string.
|
|
||||||
TEST(MessageTest, StreamsNullCString) {
|
|
||||||
char* p = NULL;
|
|
||||||
EXPECT_EQ("(null)", (Message() << p).GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming std::string.
|
|
||||||
TEST(MessageTest, StreamsString) {
|
|
||||||
const ::std::string str("Hello");
|
|
||||||
EXPECT_EQ("Hello", (Message() << str).GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that we can output strings containing embedded NULs.
|
|
||||||
TEST(MessageTest, StreamsStringWithEmbeddedNUL) {
|
|
||||||
const char char_array_with_nul[] =
|
|
||||||
"Here's a NUL\0 and some more string";
|
|
||||||
const ::std::string string_with_nul(char_array_with_nul,
|
|
||||||
sizeof(char_array_with_nul) - 1);
|
|
||||||
EXPECT_EQ("Here's a NUL\\0 and some more string",
|
|
||||||
(Message() << string_with_nul).GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a NUL char.
|
|
||||||
TEST(MessageTest, StreamsNULChar) {
|
|
||||||
EXPECT_EQ("\\0", (Message() << '\0').GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming int.
|
|
||||||
TEST(MessageTest, StreamsInt) {
|
|
||||||
EXPECT_EQ("123", (Message() << 123).GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that basic IO manipulators (endl, ends, and flush) can be
|
|
||||||
// streamed to Message.
|
|
||||||
TEST(MessageTest, StreamsBasicIoManip) {
|
|
||||||
EXPECT_EQ("Line 1.\nA NUL char \\0 in line 2.",
|
|
||||||
(Message() << "Line 1." << std::endl
|
|
||||||
<< "A NUL char " << std::ends << std::flush
|
|
||||||
<< " in line 2.").GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests Message::GetString()
|
|
||||||
TEST(MessageTest, GetString) {
|
|
||||||
Message msg;
|
|
||||||
msg << 1 << " lamb";
|
|
||||||
EXPECT_EQ("1 lamb", msg.GetString());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests streaming a Message object to an ostream.
|
|
||||||
TEST(MessageTest, StreamsToOStream) {
|
|
||||||
Message msg("Hello");
|
|
||||||
::std::stringstream ss;
|
|
||||||
ss << msg;
|
|
||||||
EXPECT_EQ("Hello", testing::internal::StringStreamToString(&ss));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that a Message object doesn't take up too much stack space.
|
|
||||||
TEST(MessageTest, DoesNotTakeUpMuchStackSpace) {
|
|
||||||
EXPECT_LE(sizeof(Message), 16U);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
|
@ -1,215 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: keith.ray@gmail.com (Keith Ray)
|
|
||||||
//
|
|
||||||
// Google Test UnitTestOptions tests
|
|
||||||
//
|
|
||||||
// This file tests classes and functions used internally by
|
|
||||||
// Google Test. They are subject to change without notice.
|
|
||||||
//
|
|
||||||
// This file is #included from gtest.cc, to avoid changing build or
|
|
||||||
// make-files on Windows and other platforms. Do not #include this file
|
|
||||||
// anywhere else!
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS_MOBILE
|
|
||||||
# include <windows.h>
|
|
||||||
#elif GTEST_OS_WINDOWS
|
|
||||||
# include <direct.h>
|
|
||||||
#endif // GTEST_OS_WINDOWS_MOBILE
|
|
||||||
|
|
||||||
// Indicates that this translation unit is part of Google Test's
|
|
||||||
// implementation. It must come before gtest-internal-inl.h is
|
|
||||||
// included, or there will be a compiler error. This trick is to
|
|
||||||
// prevent a user from accidentally including gtest-internal-inl.h in
|
|
||||||
// his code.
|
|
||||||
#define GTEST_IMPLEMENTATION_ 1
|
|
||||||
#include "src/gtest-internal-inl.h"
|
|
||||||
#undef GTEST_IMPLEMENTATION_
|
|
||||||
|
|
||||||
namespace testing {
|
|
||||||
namespace internal {
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
// Turns the given relative path into an absolute path.
|
|
||||||
FilePath GetAbsolutePathOf(const FilePath& relative_path) {
|
|
||||||
return FilePath::ConcatPaths(FilePath::GetCurrentDir(), relative_path);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Testing UnitTestOptions::GetOutputFormat/GetOutputFile.
|
|
||||||
|
|
||||||
TEST(XmlOutputTest, GetOutputFormatDefault) {
|
|
||||||
GTEST_FLAG(output) = "";
|
|
||||||
EXPECT_STREQ("", UnitTestOptions::GetOutputFormat().c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(XmlOutputTest, GetOutputFormat) {
|
|
||||||
GTEST_FLAG(output) = "xml:filename";
|
|
||||||
EXPECT_STREQ("xml", UnitTestOptions::GetOutputFormat().c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(XmlOutputTest, GetOutputFileDefault) {
|
|
||||||
GTEST_FLAG(output) = "";
|
|
||||||
EXPECT_EQ(GetAbsolutePathOf(FilePath("test_detail.xml")).string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(XmlOutputTest, GetOutputFileSingleFile) {
|
|
||||||
GTEST_FLAG(output) = "xml:filename.abc";
|
|
||||||
EXPECT_EQ(GetAbsolutePathOf(FilePath("filename.abc")).string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(XmlOutputTest, GetOutputFileFromDirectoryPath) {
|
|
||||||
GTEST_FLAG(output) = "xml:path" GTEST_PATH_SEP_;
|
|
||||||
const std::string expected_output_file =
|
|
||||||
GetAbsolutePathOf(
|
|
||||||
FilePath(std::string("path") + GTEST_PATH_SEP_ +
|
|
||||||
GetCurrentExecutableName().string() + ".xml")).string();
|
|
||||||
const std::string& output_file =
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile();
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
EXPECT_STRCASEEQ(expected_output_file.c_str(), output_file.c_str());
|
|
||||||
#else
|
|
||||||
EXPECT_EQ(expected_output_file, output_file.c_str());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(OutputFileHelpersTest, GetCurrentExecutableName) {
|
|
||||||
const std::string exe_str = GetCurrentExecutableName().string();
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
const bool success =
|
|
||||||
_strcmpi("gtest-options_test", exe_str.c_str()) == 0 ||
|
|
||||||
_strcmpi("gtest-options-ex_test", exe_str.c_str()) == 0 ||
|
|
||||||
_strcmpi("gtest_all_test", exe_str.c_str()) == 0 ||
|
|
||||||
_strcmpi("gtest_dll_test", exe_str.c_str()) == 0;
|
|
||||||
#else
|
|
||||||
// TODO(wan@google.com): remove the hard-coded "lt-" prefix when
|
|
||||||
// Chandler Carruth's libtool replacement is ready.
|
|
||||||
const bool success =
|
|
||||||
exe_str == "gtest-options_test" ||
|
|
||||||
exe_str == "gtest_all_test" ||
|
|
||||||
exe_str == "lt-gtest_all_test" ||
|
|
||||||
exe_str == "gtest_dll_test";
|
|
||||||
#endif // GTEST_OS_WINDOWS
|
|
||||||
if (!success)
|
|
||||||
FAIL() << "GetCurrentExecutableName() returns " << exe_str;
|
|
||||||
}
|
|
||||||
|
|
||||||
class XmlOutputChangeDirTest : public Test {
|
|
||||||
protected:
|
|
||||||
virtual void SetUp() {
|
|
||||||
original_working_dir_ = FilePath::GetCurrentDir();
|
|
||||||
posix::ChDir("..");
|
|
||||||
// This will make the test fail if run from the root directory.
|
|
||||||
EXPECT_NE(original_working_dir_.string(),
|
|
||||||
FilePath::GetCurrentDir().string());
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void TearDown() {
|
|
||||||
posix::ChDir(original_working_dir_.string().c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
FilePath original_working_dir_;
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST_F(XmlOutputChangeDirTest, PreserveOriginalWorkingDirWithDefault) {
|
|
||||||
GTEST_FLAG(output) = "";
|
|
||||||
EXPECT_EQ(FilePath::ConcatPaths(original_working_dir_,
|
|
||||||
FilePath("test_detail.xml")).string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(XmlOutputChangeDirTest, PreserveOriginalWorkingDirWithDefaultXML) {
|
|
||||||
GTEST_FLAG(output) = "xml";
|
|
||||||
EXPECT_EQ(FilePath::ConcatPaths(original_working_dir_,
|
|
||||||
FilePath("test_detail.xml")).string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(XmlOutputChangeDirTest, PreserveOriginalWorkingDirWithRelativeFile) {
|
|
||||||
GTEST_FLAG(output) = "xml:filename.abc";
|
|
||||||
EXPECT_EQ(FilePath::ConcatPaths(original_working_dir_,
|
|
||||||
FilePath("filename.abc")).string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(XmlOutputChangeDirTest, PreserveOriginalWorkingDirWithRelativePath) {
|
|
||||||
GTEST_FLAG(output) = "xml:path" GTEST_PATH_SEP_;
|
|
||||||
const std::string expected_output_file =
|
|
||||||
FilePath::ConcatPaths(
|
|
||||||
original_working_dir_,
|
|
||||||
FilePath(std::string("path") + GTEST_PATH_SEP_ +
|
|
||||||
GetCurrentExecutableName().string() + ".xml")).string();
|
|
||||||
const std::string& output_file =
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile();
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
EXPECT_STRCASEEQ(expected_output_file.c_str(), output_file.c_str());
|
|
||||||
#else
|
|
||||||
EXPECT_EQ(expected_output_file, output_file.c_str());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(XmlOutputChangeDirTest, PreserveOriginalWorkingDirWithAbsoluteFile) {
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
GTEST_FLAG(output) = "xml:c:\\tmp\\filename.abc";
|
|
||||||
EXPECT_EQ(FilePath("c:\\tmp\\filename.abc").string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
#else
|
|
||||||
GTEST_FLAG(output) ="xml:/tmp/filename.abc";
|
|
||||||
EXPECT_EQ(FilePath("/tmp/filename.abc").string(),
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(XmlOutputChangeDirTest, PreserveOriginalWorkingDirWithAbsolutePath) {
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
const std::string path = "c:\\tmp\\";
|
|
||||||
#else
|
|
||||||
const std::string path = "/tmp/";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
GTEST_FLAG(output) = "xml:" + path;
|
|
||||||
const std::string expected_output_file =
|
|
||||||
path + GetCurrentExecutableName().string() + ".xml";
|
|
||||||
const std::string& output_file =
|
|
||||||
UnitTestOptions::GetAbsolutePathToOutputFile();
|
|
||||||
|
|
||||||
#if GTEST_OS_WINDOWS
|
|
||||||
EXPECT_STRCASEEQ(expected_output_file.c_str(), output_file.c_str());
|
|
||||||
#else
|
|
||||||
EXPECT_EQ(expected_output_file, output_file.c_str());
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
|
||||||
} // namespace internal
|
|
||||||
} // namespace testing
|
|
@ -1,65 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: vladl@google.com (Vlad Losev)
|
|
||||||
//
|
|
||||||
// Tests for Google Test itself. This verifies that the basic constructs of
|
|
||||||
// Google Test work.
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
#include "test/gtest-param-test_test.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
using ::testing::Values;
|
|
||||||
using ::testing::internal::ParamGenerator;
|
|
||||||
|
|
||||||
// Tests that generators defined in a different translation unit
|
|
||||||
// are functional. The test using extern_gen is defined
|
|
||||||
// in gtest-param-test_test.cc.
|
|
||||||
ParamGenerator<int> extern_gen = Values(33);
|
|
||||||
|
|
||||||
// Tests that a parameterized test case can be defined in one translation unit
|
|
||||||
// and instantiated in another. The test is defined in gtest-param-test_test.cc
|
|
||||||
// and ExternalInstantiationTest fixture class is defined in
|
|
||||||
// gtest-param-test_test.h.
|
|
||||||
INSTANTIATE_TEST_CASE_P(MultiplesOf33,
|
|
||||||
ExternalInstantiationTest,
|
|
||||||
Values(33, 66));
|
|
||||||
|
|
||||||
// Tests that a parameterized test case can be instantiated
|
|
||||||
// in multiple translation units. Another instantiation is defined
|
|
||||||
// in gtest-param-test_test.cc and InstantiationInMultipleTranslaionUnitsTest
|
|
||||||
// fixture is defined in gtest-param-test_test.h
|
|
||||||
INSTANTIATE_TEST_CASE_P(Sequence2,
|
|
||||||
InstantiationInMultipleTranslaionUnitsTest,
|
|
||||||
Values(42*3, 42*4, 42*5));
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
@ -1,897 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: vladl@google.com (Vlad Losev)
|
|
||||||
//
|
|
||||||
// Tests for Google Test itself. This file verifies that the parameter
|
|
||||||
// generators objects produce correct parameter sequences and that
|
|
||||||
// Google Test runtime instantiates correct tests from those sequences.
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
# include <algorithm>
|
|
||||||
# include <iostream>
|
|
||||||
# include <list>
|
|
||||||
# include <sstream>
|
|
||||||
# include <string>
|
|
||||||
# include <vector>
|
|
||||||
|
|
||||||
// To include gtest-internal-inl.h.
|
|
||||||
# define GTEST_IMPLEMENTATION_ 1
|
|
||||||
# include "src/gtest-internal-inl.h" // for UnitTestOptions
|
|
||||||
# undef GTEST_IMPLEMENTATION_
|
|
||||||
|
|
||||||
# include "test/gtest-param-test_test.h"
|
|
||||||
|
|
||||||
using ::std::vector;
|
|
||||||
using ::std::sort;
|
|
||||||
|
|
||||||
using ::testing::AddGlobalTestEnvironment;
|
|
||||||
using ::testing::Bool;
|
|
||||||
using ::testing::Message;
|
|
||||||
using ::testing::Range;
|
|
||||||
using ::testing::TestWithParam;
|
|
||||||
using ::testing::Values;
|
|
||||||
using ::testing::ValuesIn;
|
|
||||||
|
|
||||||
# if GTEST_HAS_COMBINE
|
|
||||||
using ::testing::Combine;
|
|
||||||
using ::std::tr1::get;
|
|
||||||
using ::std::tr1::make_tuple;
|
|
||||||
using ::std::tr1::tuple;
|
|
||||||
# endif // GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
using ::testing::internal::ParamGenerator;
|
|
||||||
using ::testing::internal::UnitTestOptions;
|
|
||||||
|
|
||||||
// Prints a value to a string.
|
|
||||||
//
|
|
||||||
// TODO(wan@google.com): remove PrintValue() when we move matchers and
|
|
||||||
// EXPECT_THAT() from Google Mock to Google Test. At that time, we
|
|
||||||
// can write EXPECT_THAT(x, Eq(y)) to compare two tuples x and y, as
|
|
||||||
// EXPECT_THAT() and the matchers know how to print tuples.
|
|
||||||
template <typename T>
|
|
||||||
::std::string PrintValue(const T& value) {
|
|
||||||
::std::stringstream stream;
|
|
||||||
stream << value;
|
|
||||||
return stream.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
# if GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
// These overloads allow printing tuples in our tests. We cannot
|
|
||||||
// define an operator<< for tuples, as that definition needs to be in
|
|
||||||
// the std namespace in order to be picked up by Google Test via
|
|
||||||
// Argument-Dependent Lookup, yet defining anything in the std
|
|
||||||
// namespace in non-STL code is undefined behavior.
|
|
||||||
|
|
||||||
template <typename T1, typename T2>
|
|
||||||
::std::string PrintValue(const tuple<T1, T2>& value) {
|
|
||||||
::std::stringstream stream;
|
|
||||||
stream << "(" << get<0>(value) << ", " << get<1>(value) << ")";
|
|
||||||
return stream.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3>
|
|
||||||
::std::string PrintValue(const tuple<T1, T2, T3>& value) {
|
|
||||||
::std::stringstream stream;
|
|
||||||
stream << "(" << get<0>(value) << ", " << get<1>(value)
|
|
||||||
<< ", "<< get<2>(value) << ")";
|
|
||||||
return stream.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T1, typename T2, typename T3, typename T4, typename T5,
|
|
||||||
typename T6, typename T7, typename T8, typename T9, typename T10>
|
|
||||||
::std::string PrintValue(
|
|
||||||
const tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>& value) {
|
|
||||||
::std::stringstream stream;
|
|
||||||
stream << "(" << get<0>(value) << ", " << get<1>(value)
|
|
||||||
<< ", "<< get<2>(value) << ", " << get<3>(value)
|
|
||||||
<< ", "<< get<4>(value) << ", " << get<5>(value)
|
|
||||||
<< ", "<< get<6>(value) << ", " << get<7>(value)
|
|
||||||
<< ", "<< get<8>(value) << ", " << get<9>(value) << ")";
|
|
||||||
return stream.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif // GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
// Verifies that a sequence generated by the generator and accessed
|
|
||||||
// via the iterator object matches the expected one using Google Test
|
|
||||||
// assertions.
|
|
||||||
template <typename T, size_t N>
|
|
||||||
void VerifyGenerator(const ParamGenerator<T>& generator,
|
|
||||||
const T (&expected_values)[N]) {
|
|
||||||
typename ParamGenerator<T>::iterator it = generator.begin();
|
|
||||||
for (size_t i = 0; i < N; ++i) {
|
|
||||||
ASSERT_FALSE(it == generator.end())
|
|
||||||
<< "At element " << i << " when accessing via an iterator "
|
|
||||||
<< "created with the copy constructor.\n";
|
|
||||||
// We cannot use EXPECT_EQ() here as the values may be tuples,
|
|
||||||
// which don't support <<.
|
|
||||||
EXPECT_TRUE(expected_values[i] == *it)
|
|
||||||
<< "where i is " << i
|
|
||||||
<< ", expected_values[i] is " << PrintValue(expected_values[i])
|
|
||||||
<< ", *it is " << PrintValue(*it)
|
|
||||||
<< ", and 'it' is an iterator created with the copy constructor.\n";
|
|
||||||
it++;
|
|
||||||
}
|
|
||||||
EXPECT_TRUE(it == generator.end())
|
|
||||||
<< "At the presumed end of sequence when accessing via an iterator "
|
|
||||||
<< "created with the copy constructor.\n";
|
|
||||||
|
|
||||||
// Test the iterator assignment. The following lines verify that
|
|
||||||
// the sequence accessed via an iterator initialized via the
|
|
||||||
// assignment operator (as opposed to a copy constructor) matches
|
|
||||||
// just the same.
|
|
||||||
it = generator.begin();
|
|
||||||
for (size_t i = 0; i < N; ++i) {
|
|
||||||
ASSERT_FALSE(it == generator.end())
|
|
||||||
<< "At element " << i << " when accessing via an iterator "
|
|
||||||
<< "created with the assignment operator.\n";
|
|
||||||
EXPECT_TRUE(expected_values[i] == *it)
|
|
||||||
<< "where i is " << i
|
|
||||||
<< ", expected_values[i] is " << PrintValue(expected_values[i])
|
|
||||||
<< ", *it is " << PrintValue(*it)
|
|
||||||
<< ", and 'it' is an iterator created with the copy constructor.\n";
|
|
||||||
it++;
|
|
||||||
}
|
|
||||||
EXPECT_TRUE(it == generator.end())
|
|
||||||
<< "At the presumed end of sequence when accessing via an iterator "
|
|
||||||
<< "created with the assignment operator.\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
void VerifyGeneratorIsEmpty(const ParamGenerator<T>& generator) {
|
|
||||||
typename ParamGenerator<T>::iterator it = generator.begin();
|
|
||||||
EXPECT_TRUE(it == generator.end());
|
|
||||||
|
|
||||||
it = generator.begin();
|
|
||||||
EXPECT_TRUE(it == generator.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Generator tests. They test that each of the provided generator functions
|
|
||||||
// generates an expected sequence of values. The general test pattern
|
|
||||||
// instantiates a generator using one of the generator functions,
|
|
||||||
// checks the sequence produced by the generator using its iterator API,
|
|
||||||
// and then resets the iterator back to the beginning of the sequence
|
|
||||||
// and checks the sequence again.
|
|
||||||
|
|
||||||
// Tests that iterators produced by generator functions conform to the
|
|
||||||
// ForwardIterator concept.
|
|
||||||
TEST(IteratorTest, ParamIteratorConformsToForwardIteratorConcept) {
|
|
||||||
const ParamGenerator<int> gen = Range(0, 10);
|
|
||||||
ParamGenerator<int>::iterator it = gen.begin();
|
|
||||||
|
|
||||||
// Verifies that iterator initialization works as expected.
|
|
||||||
ParamGenerator<int>::iterator it2 = it;
|
|
||||||
EXPECT_TRUE(*it == *it2) << "Initialized iterators must point to the "
|
|
||||||
<< "element same as its source points to";
|
|
||||||
|
|
||||||
// Verifies that iterator assignment works as expected.
|
|
||||||
it++;
|
|
||||||
EXPECT_FALSE(*it == *it2);
|
|
||||||
it2 = it;
|
|
||||||
EXPECT_TRUE(*it == *it2) << "Assigned iterators must point to the "
|
|
||||||
<< "element same as its source points to";
|
|
||||||
|
|
||||||
// Verifies that prefix operator++() returns *this.
|
|
||||||
EXPECT_EQ(&it, &(++it)) << "Result of the prefix operator++ must be "
|
|
||||||
<< "refer to the original object";
|
|
||||||
|
|
||||||
// Verifies that the result of the postfix operator++ points to the value
|
|
||||||
// pointed to by the original iterator.
|
|
||||||
int original_value = *it; // Have to compute it outside of macro call to be
|
|
||||||
// unaffected by the parameter evaluation order.
|
|
||||||
EXPECT_EQ(original_value, *(it++));
|
|
||||||
|
|
||||||
// Verifies that prefix and postfix operator++() advance an iterator
|
|
||||||
// all the same.
|
|
||||||
it2 = it;
|
|
||||||
it++;
|
|
||||||
++it2;
|
|
||||||
EXPECT_TRUE(*it == *it2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that Range() generates the expected sequence.
|
|
||||||
TEST(RangeTest, IntRangeWithDefaultStep) {
|
|
||||||
const ParamGenerator<int> gen = Range(0, 3);
|
|
||||||
const int expected_values[] = {0, 1, 2};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case. Tests that Range() generates the single element sequence
|
|
||||||
// as expected when provided with range limits that are equal.
|
|
||||||
TEST(RangeTest, IntRangeSingleValue) {
|
|
||||||
const ParamGenerator<int> gen = Range(0, 1);
|
|
||||||
const int expected_values[] = {0};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case. Tests that Range() with generates empty sequence when
|
|
||||||
// supplied with an empty range.
|
|
||||||
TEST(RangeTest, IntRangeEmpty) {
|
|
||||||
const ParamGenerator<int> gen = Range(0, 0);
|
|
||||||
VerifyGeneratorIsEmpty(gen);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that Range() with custom step (greater then one) generates
|
|
||||||
// the expected sequence.
|
|
||||||
TEST(RangeTest, IntRangeWithCustomStep) {
|
|
||||||
const ParamGenerator<int> gen = Range(0, 9, 3);
|
|
||||||
const int expected_values[] = {0, 3, 6};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that Range() with custom step (greater then one) generates
|
|
||||||
// the expected sequence when the last element does not fall on the
|
|
||||||
// upper range limit. Sequences generated by Range() must not have
|
|
||||||
// elements beyond the range limits.
|
|
||||||
TEST(RangeTest, IntRangeWithCustomStepOverUpperBound) {
|
|
||||||
const ParamGenerator<int> gen = Range(0, 4, 3);
|
|
||||||
const int expected_values[] = {0, 3};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verifies that Range works with user-defined types that define
|
|
||||||
// copy constructor, operator=(), operator+(), and operator<().
|
|
||||||
class DogAdder {
|
|
||||||
public:
|
|
||||||
explicit DogAdder(const char* a_value) : value_(a_value) {}
|
|
||||||
DogAdder(const DogAdder& other) : value_(other.value_.c_str()) {}
|
|
||||||
|
|
||||||
DogAdder operator=(const DogAdder& other) {
|
|
||||||
if (this != &other)
|
|
||||||
value_ = other.value_;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
DogAdder operator+(const DogAdder& other) const {
|
|
||||||
Message msg;
|
|
||||||
msg << value_.c_str() << other.value_.c_str();
|
|
||||||
return DogAdder(msg.GetString().c_str());
|
|
||||||
}
|
|
||||||
bool operator<(const DogAdder& other) const {
|
|
||||||
return value_ < other.value_;
|
|
||||||
}
|
|
||||||
const std::string& value() const { return value_; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::string value_;
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(RangeTest, WorksWithACustomType) {
|
|
||||||
const ParamGenerator<DogAdder> gen =
|
|
||||||
Range(DogAdder("cat"), DogAdder("catdogdog"), DogAdder("dog"));
|
|
||||||
ParamGenerator<DogAdder>::iterator it = gen.begin();
|
|
||||||
|
|
||||||
ASSERT_FALSE(it == gen.end());
|
|
||||||
EXPECT_STREQ("cat", it->value().c_str());
|
|
||||||
|
|
||||||
ASSERT_FALSE(++it == gen.end());
|
|
||||||
EXPECT_STREQ("catdog", it->value().c_str());
|
|
||||||
|
|
||||||
EXPECT_TRUE(++it == gen.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
class IntWrapper {
|
|
||||||
public:
|
|
||||||
explicit IntWrapper(int a_value) : value_(a_value) {}
|
|
||||||
IntWrapper(const IntWrapper& other) : value_(other.value_) {}
|
|
||||||
|
|
||||||
IntWrapper operator=(const IntWrapper& other) {
|
|
||||||
value_ = other.value_;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
// operator+() adds a different type.
|
|
||||||
IntWrapper operator+(int other) const { return IntWrapper(value_ + other); }
|
|
||||||
bool operator<(const IntWrapper& other) const {
|
|
||||||
return value_ < other.value_;
|
|
||||||
}
|
|
||||||
int value() const { return value_; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
int value_;
|
|
||||||
};
|
|
||||||
|
|
||||||
TEST(RangeTest, WorksWithACustomTypeWithDifferentIncrementType) {
|
|
||||||
const ParamGenerator<IntWrapper> gen = Range(IntWrapper(0), IntWrapper(2));
|
|
||||||
ParamGenerator<IntWrapper>::iterator it = gen.begin();
|
|
||||||
|
|
||||||
ASSERT_FALSE(it == gen.end());
|
|
||||||
EXPECT_EQ(0, it->value());
|
|
||||||
|
|
||||||
ASSERT_FALSE(++it == gen.end());
|
|
||||||
EXPECT_EQ(1, it->value());
|
|
||||||
|
|
||||||
EXPECT_TRUE(++it == gen.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that ValuesIn() with an array parameter generates
|
|
||||||
// the expected sequence.
|
|
||||||
TEST(ValuesInTest, ValuesInArray) {
|
|
||||||
int array[] = {3, 5, 8};
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(array);
|
|
||||||
VerifyGenerator(gen, array);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that ValuesIn() with a const array parameter generates
|
|
||||||
// the expected sequence.
|
|
||||||
TEST(ValuesInTest, ValuesInConstArray) {
|
|
||||||
const int array[] = {3, 5, 8};
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(array);
|
|
||||||
VerifyGenerator(gen, array);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case. Tests that ValuesIn() with an array parameter containing a
|
|
||||||
// single element generates the single element sequence.
|
|
||||||
TEST(ValuesInTest, ValuesInSingleElementArray) {
|
|
||||||
int array[] = {42};
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(array);
|
|
||||||
VerifyGenerator(gen, array);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that ValuesIn() generates the expected sequence for an STL
|
|
||||||
// container (vector).
|
|
||||||
TEST(ValuesInTest, ValuesInVector) {
|
|
||||||
typedef ::std::vector<int> ContainerType;
|
|
||||||
ContainerType values;
|
|
||||||
values.push_back(3);
|
|
||||||
values.push_back(5);
|
|
||||||
values.push_back(8);
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(values);
|
|
||||||
|
|
||||||
const int expected_values[] = {3, 5, 8};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that ValuesIn() generates the expected sequence.
|
|
||||||
TEST(ValuesInTest, ValuesInIteratorRange) {
|
|
||||||
typedef ::std::vector<int> ContainerType;
|
|
||||||
ContainerType values;
|
|
||||||
values.push_back(3);
|
|
||||||
values.push_back(5);
|
|
||||||
values.push_back(8);
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(values.begin(), values.end());
|
|
||||||
|
|
||||||
const int expected_values[] = {3, 5, 8};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case. Tests that ValuesIn() provided with an iterator range specifying a
|
|
||||||
// single value generates a single-element sequence.
|
|
||||||
TEST(ValuesInTest, ValuesInSingleElementIteratorRange) {
|
|
||||||
typedef ::std::vector<int> ContainerType;
|
|
||||||
ContainerType values;
|
|
||||||
values.push_back(42);
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(values.begin(), values.end());
|
|
||||||
|
|
||||||
const int expected_values[] = {42};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case. Tests that ValuesIn() provided with an empty iterator range
|
|
||||||
// generates an empty sequence.
|
|
||||||
TEST(ValuesInTest, ValuesInEmptyIteratorRange) {
|
|
||||||
typedef ::std::vector<int> ContainerType;
|
|
||||||
ContainerType values;
|
|
||||||
const ParamGenerator<int> gen = ValuesIn(values.begin(), values.end());
|
|
||||||
|
|
||||||
VerifyGeneratorIsEmpty(gen);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that the Values() generates the expected sequence.
|
|
||||||
TEST(ValuesTest, ValuesWorks) {
|
|
||||||
const ParamGenerator<int> gen = Values(3, 5, 8);
|
|
||||||
|
|
||||||
const int expected_values[] = {3, 5, 8};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that Values() generates the expected sequences from elements of
|
|
||||||
// different types convertible to ParamGenerator's parameter type.
|
|
||||||
TEST(ValuesTest, ValuesWorksForValuesOfCompatibleTypes) {
|
|
||||||
const ParamGenerator<double> gen = Values(3, 5.0f, 8.0);
|
|
||||||
|
|
||||||
const double expected_values[] = {3.0, 5.0, 8.0};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(ValuesTest, ValuesWorksForMaxLengthList) {
|
|
||||||
const ParamGenerator<int> gen = Values(
|
|
||||||
10, 20, 30, 40, 50, 60, 70, 80, 90, 100,
|
|
||||||
110, 120, 130, 140, 150, 160, 170, 180, 190, 200,
|
|
||||||
210, 220, 230, 240, 250, 260, 270, 280, 290, 300,
|
|
||||||
310, 320, 330, 340, 350, 360, 370, 380, 390, 400,
|
|
||||||
410, 420, 430, 440, 450, 460, 470, 480, 490, 500);
|
|
||||||
|
|
||||||
const int expected_values[] = {
|
|
||||||
10, 20, 30, 40, 50, 60, 70, 80, 90, 100,
|
|
||||||
110, 120, 130, 140, 150, 160, 170, 180, 190, 200,
|
|
||||||
210, 220, 230, 240, 250, 260, 270, 280, 290, 300,
|
|
||||||
310, 320, 330, 340, 350, 360, 370, 380, 390, 400,
|
|
||||||
410, 420, 430, 440, 450, 460, 470, 480, 490, 500};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case test. Tests that single-parameter Values() generates the sequence
|
|
||||||
// with the single value.
|
|
||||||
TEST(ValuesTest, ValuesWithSingleParameter) {
|
|
||||||
const ParamGenerator<int> gen = Values(42);
|
|
||||||
|
|
||||||
const int expected_values[] = {42};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that Bool() generates sequence (false, true).
|
|
||||||
TEST(BoolTest, BoolWorks) {
|
|
||||||
const ParamGenerator<bool> gen = Bool();
|
|
||||||
|
|
||||||
const bool expected_values[] = {false, true};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
# if GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
// Tests that Combine() with two parameters generates the expected sequence.
|
|
||||||
TEST(CombineTest, CombineWithTwoParameters) {
|
|
||||||
const char* foo = "foo";
|
|
||||||
const char* bar = "bar";
|
|
||||||
const ParamGenerator<tuple<const char*, int> > gen =
|
|
||||||
Combine(Values(foo, bar), Values(3, 4));
|
|
||||||
|
|
||||||
tuple<const char*, int> expected_values[] = {
|
|
||||||
make_tuple(foo, 3), make_tuple(foo, 4),
|
|
||||||
make_tuple(bar, 3), make_tuple(bar, 4)};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that Combine() with three parameters generates the expected sequence.
|
|
||||||
TEST(CombineTest, CombineWithThreeParameters) {
|
|
||||||
const ParamGenerator<tuple<int, int, int> > gen = Combine(Values(0, 1),
|
|
||||||
Values(3, 4),
|
|
||||||
Values(5, 6));
|
|
||||||
tuple<int, int, int> expected_values[] = {
|
|
||||||
make_tuple(0, 3, 5), make_tuple(0, 3, 6),
|
|
||||||
make_tuple(0, 4, 5), make_tuple(0, 4, 6),
|
|
||||||
make_tuple(1, 3, 5), make_tuple(1, 3, 6),
|
|
||||||
make_tuple(1, 4, 5), make_tuple(1, 4, 6)};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that the Combine() with the first parameter generating a single value
|
|
||||||
// sequence generates a sequence with the number of elements equal to the
|
|
||||||
// number of elements in the sequence generated by the second parameter.
|
|
||||||
TEST(CombineTest, CombineWithFirstParameterSingleValue) {
|
|
||||||
const ParamGenerator<tuple<int, int> > gen = Combine(Values(42),
|
|
||||||
Values(0, 1));
|
|
||||||
|
|
||||||
tuple<int, int> expected_values[] = {make_tuple(42, 0), make_tuple(42, 1)};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that the Combine() with the second parameter generating a single value
|
|
||||||
// sequence generates a sequence with the number of elements equal to the
|
|
||||||
// number of elements in the sequence generated by the first parameter.
|
|
||||||
TEST(CombineTest, CombineWithSecondParameterSingleValue) {
|
|
||||||
const ParamGenerator<tuple<int, int> > gen = Combine(Values(0, 1),
|
|
||||||
Values(42));
|
|
||||||
|
|
||||||
tuple<int, int> expected_values[] = {make_tuple(0, 42), make_tuple(1, 42)};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that when the first parameter produces an empty sequence,
|
|
||||||
// Combine() produces an empty sequence, too.
|
|
||||||
TEST(CombineTest, CombineWithFirstParameterEmptyRange) {
|
|
||||||
const ParamGenerator<tuple<int, int> > gen = Combine(Range(0, 0),
|
|
||||||
Values(0, 1));
|
|
||||||
VerifyGeneratorIsEmpty(gen);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that when the second parameter produces an empty sequence,
|
|
||||||
// Combine() produces an empty sequence, too.
|
|
||||||
TEST(CombineTest, CombineWithSecondParameterEmptyRange) {
|
|
||||||
const ParamGenerator<tuple<int, int> > gen = Combine(Values(0, 1),
|
|
||||||
Range(1, 1));
|
|
||||||
VerifyGeneratorIsEmpty(gen);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Edge case. Tests that combine works with the maximum number
|
|
||||||
// of parameters supported by Google Test (currently 10).
|
|
||||||
TEST(CombineTest, CombineWithMaxNumberOfParameters) {
|
|
||||||
const char* foo = "foo";
|
|
||||||
const char* bar = "bar";
|
|
||||||
const ParamGenerator<tuple<const char*, int, int, int, int, int, int, int,
|
|
||||||
int, int> > gen = Combine(Values(foo, bar),
|
|
||||||
Values(1), Values(2),
|
|
||||||
Values(3), Values(4),
|
|
||||||
Values(5), Values(6),
|
|
||||||
Values(7), Values(8),
|
|
||||||
Values(9));
|
|
||||||
|
|
||||||
tuple<const char*, int, int, int, int, int, int, int, int, int>
|
|
||||||
expected_values[] = {make_tuple(foo, 1, 2, 3, 4, 5, 6, 7, 8, 9),
|
|
||||||
make_tuple(bar, 1, 2, 3, 4, 5, 6, 7, 8, 9)};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
# endif // GTEST_HAS_COMBINE
|
|
||||||
|
|
||||||
// Tests that an generator produces correct sequence after being
|
|
||||||
// assigned from another generator.
|
|
||||||
TEST(ParamGeneratorTest, AssignmentWorks) {
|
|
||||||
ParamGenerator<int> gen = Values(1, 2);
|
|
||||||
const ParamGenerator<int> gen2 = Values(3, 4);
|
|
||||||
gen = gen2;
|
|
||||||
|
|
||||||
const int expected_values[] = {3, 4};
|
|
||||||
VerifyGenerator(gen, expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
// This test verifies that the tests are expanded and run as specified:
|
|
||||||
// one test per element from the sequence produced by the generator
|
|
||||||
// specified in INSTANTIATE_TEST_CASE_P. It also verifies that the test's
|
|
||||||
// fixture constructor, SetUp(), and TearDown() have run and have been
|
|
||||||
// supplied with the correct parameters.
|
|
||||||
|
|
||||||
// The use of environment object allows detection of the case where no test
|
|
||||||
// case functionality is run at all. In this case TestCaseTearDown will not
|
|
||||||
// be able to detect missing tests, naturally.
|
|
||||||
template <int kExpectedCalls>
|
|
||||||
class TestGenerationEnvironment : public ::testing::Environment {
|
|
||||||
public:
|
|
||||||
static TestGenerationEnvironment* Instance() {
|
|
||||||
static TestGenerationEnvironment* instance = new TestGenerationEnvironment;
|
|
||||||
return instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
void FixtureConstructorExecuted() { fixture_constructor_count_++; }
|
|
||||||
void SetUpExecuted() { set_up_count_++; }
|
|
||||||
void TearDownExecuted() { tear_down_count_++; }
|
|
||||||
void TestBodyExecuted() { test_body_count_++; }
|
|
||||||
|
|
||||||
virtual void TearDown() {
|
|
||||||
// If all MultipleTestGenerationTest tests have been de-selected
|
|
||||||
// by the filter flag, the following checks make no sense.
|
|
||||||
bool perform_check = false;
|
|
||||||
|
|
||||||
for (int i = 0; i < kExpectedCalls; ++i) {
|
|
||||||
Message msg;
|
|
||||||
msg << "TestsExpandedAndRun/" << i;
|
|
||||||
if (UnitTestOptions::FilterMatchesTest(
|
|
||||||
"TestExpansionModule/MultipleTestGenerationTest",
|
|
||||||
msg.GetString().c_str())) {
|
|
||||||
perform_check = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (perform_check) {
|
|
||||||
EXPECT_EQ(kExpectedCalls, fixture_constructor_count_)
|
|
||||||
<< "Fixture constructor of ParamTestGenerationTest test case "
|
|
||||||
<< "has not been run as expected.";
|
|
||||||
EXPECT_EQ(kExpectedCalls, set_up_count_)
|
|
||||||
<< "Fixture SetUp method of ParamTestGenerationTest test case "
|
|
||||||
<< "has not been run as expected.";
|
|
||||||
EXPECT_EQ(kExpectedCalls, tear_down_count_)
|
|
||||||
<< "Fixture TearDown method of ParamTestGenerationTest test case "
|
|
||||||
<< "has not been run as expected.";
|
|
||||||
EXPECT_EQ(kExpectedCalls, test_body_count_)
|
|
||||||
<< "Test in ParamTestGenerationTest test case "
|
|
||||||
<< "has not been run as expected.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
TestGenerationEnvironment() : fixture_constructor_count_(0), set_up_count_(0),
|
|
||||||
tear_down_count_(0), test_body_count_(0) {}
|
|
||||||
|
|
||||||
int fixture_constructor_count_;
|
|
||||||
int set_up_count_;
|
|
||||||
int tear_down_count_;
|
|
||||||
int test_body_count_;
|
|
||||||
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(TestGenerationEnvironment);
|
|
||||||
};
|
|
||||||
|
|
||||||
const int test_generation_params[] = {36, 42, 72};
|
|
||||||
|
|
||||||
class TestGenerationTest : public TestWithParam<int> {
|
|
||||||
public:
|
|
||||||
enum {
|
|
||||||
PARAMETER_COUNT =
|
|
||||||
sizeof(test_generation_params)/sizeof(test_generation_params[0])
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef TestGenerationEnvironment<PARAMETER_COUNT> Environment;
|
|
||||||
|
|
||||||
TestGenerationTest() {
|
|
||||||
Environment::Instance()->FixtureConstructorExecuted();
|
|
||||||
current_parameter_ = GetParam();
|
|
||||||
}
|
|
||||||
virtual void SetUp() {
|
|
||||||
Environment::Instance()->SetUpExecuted();
|
|
||||||
EXPECT_EQ(current_parameter_, GetParam());
|
|
||||||
}
|
|
||||||
virtual void TearDown() {
|
|
||||||
Environment::Instance()->TearDownExecuted();
|
|
||||||
EXPECT_EQ(current_parameter_, GetParam());
|
|
||||||
}
|
|
||||||
|
|
||||||
static void SetUpTestCase() {
|
|
||||||
bool all_tests_in_test_case_selected = true;
|
|
||||||
|
|
||||||
for (int i = 0; i < PARAMETER_COUNT; ++i) {
|
|
||||||
Message test_name;
|
|
||||||
test_name << "TestsExpandedAndRun/" << i;
|
|
||||||
if ( !UnitTestOptions::FilterMatchesTest(
|
|
||||||
"TestExpansionModule/MultipleTestGenerationTest",
|
|
||||||
test_name.GetString())) {
|
|
||||||
all_tests_in_test_case_selected = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
EXPECT_TRUE(all_tests_in_test_case_selected)
|
|
||||||
<< "When running the TestGenerationTest test case all of its tests\n"
|
|
||||||
<< "must be selected by the filter flag for the test case to pass.\n"
|
|
||||||
<< "If not all of them are enabled, we can't reliably conclude\n"
|
|
||||||
<< "that the correct number of tests have been generated.";
|
|
||||||
|
|
||||||
collected_parameters_.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
static void TearDownTestCase() {
|
|
||||||
vector<int> expected_values(test_generation_params,
|
|
||||||
test_generation_params + PARAMETER_COUNT);
|
|
||||||
// Test execution order is not guaranteed by Google Test,
|
|
||||||
// so the order of values in collected_parameters_ can be
|
|
||||||
// different and we have to sort to compare.
|
|
||||||
sort(expected_values.begin(), expected_values.end());
|
|
||||||
sort(collected_parameters_.begin(), collected_parameters_.end());
|
|
||||||
|
|
||||||
EXPECT_TRUE(collected_parameters_ == expected_values);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
int current_parameter_;
|
|
||||||
static vector<int> collected_parameters_;
|
|
||||||
|
|
||||||
private:
|
|
||||||
GTEST_DISALLOW_COPY_AND_ASSIGN_(TestGenerationTest);
|
|
||||||
};
|
|
||||||
vector<int> TestGenerationTest::collected_parameters_;
|
|
||||||
|
|
||||||
TEST_P(TestGenerationTest, TestsExpandedAndRun) {
|
|
||||||
Environment::Instance()->TestBodyExecuted();
|
|
||||||
EXPECT_EQ(current_parameter_, GetParam());
|
|
||||||
collected_parameters_.push_back(GetParam());
|
|
||||||
}
|
|
||||||
INSTANTIATE_TEST_CASE_P(TestExpansionModule, TestGenerationTest,
|
|
||||||
ValuesIn(test_generation_params));
|
|
||||||
|
|
||||||
// This test verifies that the element sequence (third parameter of
|
|
||||||
// INSTANTIATE_TEST_CASE_P) is evaluated in InitGoogleTest() and neither at
|
|
||||||
// the call site of INSTANTIATE_TEST_CASE_P nor in RUN_ALL_TESTS(). For
|
|
||||||
// that, we declare param_value_ to be a static member of
|
|
||||||
// GeneratorEvaluationTest and initialize it to 0. We set it to 1 in
|
|
||||||
// main(), just before invocation of InitGoogleTest(). After calling
|
|
||||||
// InitGoogleTest(), we set the value to 2. If the sequence is evaluated
|
|
||||||
// before or after InitGoogleTest, INSTANTIATE_TEST_CASE_P will create a
|
|
||||||
// test with parameter other than 1, and the test body will fail the
|
|
||||||
// assertion.
|
|
||||||
class GeneratorEvaluationTest : public TestWithParam<int> {
|
|
||||||
public:
|
|
||||||
static int param_value() { return param_value_; }
|
|
||||||
static void set_param_value(int param_value) { param_value_ = param_value; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
static int param_value_;
|
|
||||||
};
|
|
||||||
int GeneratorEvaluationTest::param_value_ = 0;
|
|
||||||
|
|
||||||
TEST_P(GeneratorEvaluationTest, GeneratorsEvaluatedInMain) {
|
|
||||||
EXPECT_EQ(1, GetParam());
|
|
||||||
}
|
|
||||||
INSTANTIATE_TEST_CASE_P(GenEvalModule,
|
|
||||||
GeneratorEvaluationTest,
|
|
||||||
Values(GeneratorEvaluationTest::param_value()));
|
|
||||||
|
|
||||||
// Tests that generators defined in a different translation unit are
|
|
||||||
// functional. Generator extern_gen is defined in gtest-param-test_test2.cc.
|
|
||||||
extern ParamGenerator<int> extern_gen;
|
|
||||||
class ExternalGeneratorTest : public TestWithParam<int> {};
|
|
||||||
TEST_P(ExternalGeneratorTest, ExternalGenerator) {
|
|
||||||
// Sequence produced by extern_gen contains only a single value
|
|
||||||
// which we verify here.
|
|
||||||
EXPECT_EQ(GetParam(), 33);
|
|
||||||
}
|
|
||||||
INSTANTIATE_TEST_CASE_P(ExternalGeneratorModule,
|
|
||||||
ExternalGeneratorTest,
|
|
||||||
extern_gen);
|
|
||||||
|
|
||||||
// Tests that a parameterized test case can be defined in one translation
|
|
||||||
// unit and instantiated in another. This test will be instantiated in
|
|
||||||
// gtest-param-test_test2.cc. ExternalInstantiationTest fixture class is
|
|
||||||
// defined in gtest-param-test_test.h.
|
|
||||||
TEST_P(ExternalInstantiationTest, IsMultipleOf33) {
|
|
||||||
EXPECT_EQ(0, GetParam() % 33);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that a parameterized test case can be instantiated with multiple
|
|
||||||
// generators.
|
|
||||||
class MultipleInstantiationTest : public TestWithParam<int> {};
|
|
||||||
TEST_P(MultipleInstantiationTest, AllowsMultipleInstances) {
|
|
||||||
}
|
|
||||||
INSTANTIATE_TEST_CASE_P(Sequence1, MultipleInstantiationTest, Values(1, 2));
|
|
||||||
INSTANTIATE_TEST_CASE_P(Sequence2, MultipleInstantiationTest, Range(3, 5));
|
|
||||||
|
|
||||||
// Tests that a parameterized test case can be instantiated
|
|
||||||
// in multiple translation units. This test will be instantiated
|
|
||||||
// here and in gtest-param-test_test2.cc.
|
|
||||||
// InstantiationInMultipleTranslationUnitsTest fixture class
|
|
||||||
// is defined in gtest-param-test_test.h.
|
|
||||||
TEST_P(InstantiationInMultipleTranslaionUnitsTest, IsMultipleOf42) {
|
|
||||||
EXPECT_EQ(0, GetParam() % 42);
|
|
||||||
}
|
|
||||||
INSTANTIATE_TEST_CASE_P(Sequence1,
|
|
||||||
InstantiationInMultipleTranslaionUnitsTest,
|
|
||||||
Values(42, 42*2));
|
|
||||||
|
|
||||||
// Tests that each iteration of parameterized test runs in a separate test
|
|
||||||
// object.
|
|
||||||
class SeparateInstanceTest : public TestWithParam<int> {
|
|
||||||
public:
|
|
||||||
SeparateInstanceTest() : count_(0) {}
|
|
||||||
|
|
||||||
static void TearDownTestCase() {
|
|
||||||
EXPECT_GE(global_count_, 2)
|
|
||||||
<< "If some (but not all) SeparateInstanceTest tests have been "
|
|
||||||
<< "filtered out this test will fail. Make sure that all "
|
|
||||||
<< "GeneratorEvaluationTest are selected or de-selected together "
|
|
||||||
<< "by the test filter.";
|
|
||||||
}
|
|
||||||
|
|
||||||
protected:
|
|
||||||
int count_;
|
|
||||||
static int global_count_;
|
|
||||||
};
|
|
||||||
int SeparateInstanceTest::global_count_ = 0;
|
|
||||||
|
|
||||||
TEST_P(SeparateInstanceTest, TestsRunInSeparateInstances) {
|
|
||||||
EXPECT_EQ(0, count_++);
|
|
||||||
global_count_++;
|
|
||||||
}
|
|
||||||
INSTANTIATE_TEST_CASE_P(FourElemSequence, SeparateInstanceTest, Range(1, 4));
|
|
||||||
|
|
||||||
// Tests that all instantiations of a test have named appropriately. Test
|
|
||||||
// defined with TEST_P(TestCaseName, TestName) and instantiated with
|
|
||||||
// INSTANTIATE_TEST_CASE_P(SequenceName, TestCaseName, generator) must be named
|
|
||||||
// SequenceName/TestCaseName.TestName/i, where i is the 0-based index of the
|
|
||||||
// sequence element used to instantiate the test.
|
|
||||||
class NamingTest : public TestWithParam<int> {};
|
|
||||||
|
|
||||||
TEST_P(NamingTest, TestsReportCorrectNamesAndParameters) {
|
|
||||||
const ::testing::TestInfo* const test_info =
|
|
||||||
::testing::UnitTest::GetInstance()->current_test_info();
|
|
||||||
|
|
||||||
EXPECT_STREQ("ZeroToFiveSequence/NamingTest", test_info->test_case_name());
|
|
||||||
|
|
||||||
Message index_stream;
|
|
||||||
index_stream << "TestsReportCorrectNamesAndParameters/" << GetParam();
|
|
||||||
EXPECT_STREQ(index_stream.GetString().c_str(), test_info->name());
|
|
||||||
|
|
||||||
EXPECT_EQ(::testing::PrintToString(GetParam()), test_info->value_param());
|
|
||||||
}
|
|
||||||
|
|
||||||
INSTANTIATE_TEST_CASE_P(ZeroToFiveSequence, NamingTest, Range(0, 5));
|
|
||||||
|
|
||||||
// Class that cannot be streamed into an ostream. It needs to be copyable
|
|
||||||
// (and, in case of MSVC, also assignable) in order to be a test parameter
|
|
||||||
// type. Its default copy constructor and assignment operator do exactly
|
|
||||||
// what we need.
|
|
||||||
class Unstreamable {
|
|
||||||
public:
|
|
||||||
explicit Unstreamable(int value) : value_(value) {}
|
|
||||||
|
|
||||||
private:
|
|
||||||
int value_;
|
|
||||||
};
|
|
||||||
|
|
||||||
class CommentTest : public TestWithParam<Unstreamable> {};
|
|
||||||
|
|
||||||
TEST_P(CommentTest, TestsCorrectlyReportUnstreamableParams) {
|
|
||||||
const ::testing::TestInfo* const test_info =
|
|
||||||
::testing::UnitTest::GetInstance()->current_test_info();
|
|
||||||
|
|
||||||
EXPECT_EQ(::testing::PrintToString(GetParam()), test_info->value_param());
|
|
||||||
}
|
|
||||||
|
|
||||||
INSTANTIATE_TEST_CASE_P(InstantiationWithComments,
|
|
||||||
CommentTest,
|
|
||||||
Values(Unstreamable(1)));
|
|
||||||
|
|
||||||
// Verify that we can create a hierarchy of test fixtures, where the base
|
|
||||||
// class fixture is not parameterized and the derived class is. In this case
|
|
||||||
// ParameterizedDerivedTest inherits from NonParameterizedBaseTest. We
|
|
||||||
// perform simple tests on both.
|
|
||||||
class NonParameterizedBaseTest : public ::testing::Test {
|
|
||||||
public:
|
|
||||||
NonParameterizedBaseTest() : n_(17) { }
|
|
||||||
protected:
|
|
||||||
int n_;
|
|
||||||
};
|
|
||||||
|
|
||||||
class ParameterizedDerivedTest : public NonParameterizedBaseTest,
|
|
||||||
public ::testing::WithParamInterface<int> {
|
|
||||||
protected:
|
|
||||||
ParameterizedDerivedTest() : count_(0) { }
|
|
||||||
int count_;
|
|
||||||
static int global_count_;
|
|
||||||
};
|
|
||||||
|
|
||||||
int ParameterizedDerivedTest::global_count_ = 0;
|
|
||||||
|
|
||||||
TEST_F(NonParameterizedBaseTest, FixtureIsInitialized) {
|
|
||||||
EXPECT_EQ(17, n_);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_P(ParameterizedDerivedTest, SeesSequence) {
|
|
||||||
EXPECT_EQ(17, n_);
|
|
||||||
EXPECT_EQ(0, count_++);
|
|
||||||
EXPECT_EQ(GetParam(), global_count_++);
|
|
||||||
}
|
|
||||||
|
|
||||||
INSTANTIATE_TEST_CASE_P(RangeZeroToFive, ParameterizedDerivedTest, Range(0, 5));
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
TEST(CompileTest, CombineIsDefinedOnlyWhenGtestHasParamTestIsDefined) {
|
|
||||||
#if GTEST_HAS_COMBINE && !GTEST_HAS_PARAM_TEST
|
|
||||||
FAIL() << "GTEST_HAS_COMBINE is defined while GTEST_HAS_PARAM_TEST is not\n"
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
// Used in TestGenerationTest test case.
|
|
||||||
AddGlobalTestEnvironment(TestGenerationTest::Environment::Instance());
|
|
||||||
// Used in GeneratorEvaluationTest test case. Tests that the updated value
|
|
||||||
// will be picked up for instantiating tests in GeneratorEvaluationTest.
|
|
||||||
GeneratorEvaluationTest::set_param_value(1);
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
::testing::InitGoogleTest(&argc, argv);
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
// Used in GeneratorEvaluationTest test case. Tests that value updated
|
|
||||||
// here will NOT be used for instantiating tests in
|
|
||||||
// GeneratorEvaluationTest.
|
|
||||||
GeneratorEvaluationTest::set_param_value(2);
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
return RUN_ALL_TESTS();
|
|
||||||
}
|
|
@ -1,57 +0,0 @@
|
|||||||
// Copyright 2008, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Authors: vladl@google.com (Vlad Losev)
|
|
||||||
//
|
|
||||||
// The Google C++ Testing Framework (Google Test)
|
|
||||||
//
|
|
||||||
// This header file provides classes and functions used internally
|
|
||||||
// for testing Google Test itself.
|
|
||||||
|
|
||||||
#ifndef GTEST_TEST_GTEST_PARAM_TEST_TEST_H_
|
|
||||||
#define GTEST_TEST_GTEST_PARAM_TEST_TEST_H_
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
#if GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
// Test fixture for testing definition and instantiation of a test
|
|
||||||
// in separate translation units.
|
|
||||||
class ExternalInstantiationTest : public ::testing::TestWithParam<int> {
|
|
||||||
};
|
|
||||||
|
|
||||||
// Test fixture for testing instantiation of a test in multiple
|
|
||||||
// translation units.
|
|
||||||
class InstantiationInMultipleTranslaionUnitsTest
|
|
||||||
: public ::testing::TestWithParam<int> {
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif // GTEST_HAS_PARAM_TEST
|
|
||||||
|
|
||||||
#endif // GTEST_TEST_GTEST_PARAM_TEST_TEST_H_
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,208 +0,0 @@
|
|||||||
// Copyright 2008 Google Inc.
|
|
||||||
// All Rights Reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: mheule@google.com (Markus Heule)
|
|
||||||
//
|
|
||||||
|
|
||||||
#include "gtest/gtest-test-part.h"
|
|
||||||
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
using testing::Message;
|
|
||||||
using testing::Test;
|
|
||||||
using testing::TestPartResult;
|
|
||||||
using testing::TestPartResultArray;
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
// Tests the TestPartResult class.
|
|
||||||
|
|
||||||
// The test fixture for testing TestPartResult.
|
|
||||||
class TestPartResultTest : public Test {
|
|
||||||
protected:
|
|
||||||
TestPartResultTest()
|
|
||||||
: r1_(TestPartResult::kSuccess, "foo/bar.cc", 10, "Success!"),
|
|
||||||
r2_(TestPartResult::kNonFatalFailure, "foo/bar.cc", -1, "Failure!"),
|
|
||||||
r3_(TestPartResult::kFatalFailure, NULL, -1, "Failure!") {}
|
|
||||||
|
|
||||||
TestPartResult r1_, r2_, r3_;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
TEST_F(TestPartResultTest, ConstructorWorks) {
|
|
||||||
Message message;
|
|
||||||
message << "something is terribly wrong";
|
|
||||||
message << static_cast<const char*>(testing::internal::kStackTraceMarker);
|
|
||||||
message << "some unimportant stack trace";
|
|
||||||
|
|
||||||
const TestPartResult result(TestPartResult::kNonFatalFailure,
|
|
||||||
"some_file.cc",
|
|
||||||
42,
|
|
||||||
message.GetString().c_str());
|
|
||||||
|
|
||||||
EXPECT_EQ(TestPartResult::kNonFatalFailure, result.type());
|
|
||||||
EXPECT_STREQ("some_file.cc", result.file_name());
|
|
||||||
EXPECT_EQ(42, result.line_number());
|
|
||||||
EXPECT_STREQ(message.GetString().c_str(), result.message());
|
|
||||||
EXPECT_STREQ("something is terribly wrong", result.summary());
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST_F(TestPartResultTest, ResultAccessorsWork) {
|
|
||||||
const TestPartResult success(TestPartResult::kSuccess,
|
|
||||||
"file.cc",
|
|
||||||
42,
|
|
||||||
"message");
|
|
||||||
EXPECT_TRUE(success.passed());
|
|
||||||
EXPECT_FALSE(success.failed());
|
|
||||||
EXPECT_FALSE(success.nonfatally_failed());
|
|
||||||
EXPECT_FALSE(success.fatally_failed());
|
|
||||||
|
|
||||||
const TestPartResult nonfatal_failure(TestPartResult::kNonFatalFailure,
|
|
||||||
"file.cc",
|
|
||||||
42,
|
|
||||||
"message");
|
|
||||||
EXPECT_FALSE(nonfatal_failure.passed());
|
|
||||||
EXPECT_TRUE(nonfatal_failure.failed());
|
|
||||||
EXPECT_TRUE(nonfatal_failure.nonfatally_failed());
|
|
||||||
EXPECT_FALSE(nonfatal_failure.fatally_failed());
|
|
||||||
|
|
||||||
const TestPartResult fatal_failure(TestPartResult::kFatalFailure,
|
|
||||||
"file.cc",
|
|
||||||
42,
|
|
||||||
"message");
|
|
||||||
EXPECT_FALSE(fatal_failure.passed());
|
|
||||||
EXPECT_TRUE(fatal_failure.failed());
|
|
||||||
EXPECT_FALSE(fatal_failure.nonfatally_failed());
|
|
||||||
EXPECT_TRUE(fatal_failure.fatally_failed());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::type().
|
|
||||||
TEST_F(TestPartResultTest, type) {
|
|
||||||
EXPECT_EQ(TestPartResult::kSuccess, r1_.type());
|
|
||||||
EXPECT_EQ(TestPartResult::kNonFatalFailure, r2_.type());
|
|
||||||
EXPECT_EQ(TestPartResult::kFatalFailure, r3_.type());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::file_name().
|
|
||||||
TEST_F(TestPartResultTest, file_name) {
|
|
||||||
EXPECT_STREQ("foo/bar.cc", r1_.file_name());
|
|
||||||
EXPECT_STREQ(NULL, r3_.file_name());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::line_number().
|
|
||||||
TEST_F(TestPartResultTest, line_number) {
|
|
||||||
EXPECT_EQ(10, r1_.line_number());
|
|
||||||
EXPECT_EQ(-1, r2_.line_number());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::message().
|
|
||||||
TEST_F(TestPartResultTest, message) {
|
|
||||||
EXPECT_STREQ("Success!", r1_.message());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::passed().
|
|
||||||
TEST_F(TestPartResultTest, Passed) {
|
|
||||||
EXPECT_TRUE(r1_.passed());
|
|
||||||
EXPECT_FALSE(r2_.passed());
|
|
||||||
EXPECT_FALSE(r3_.passed());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::failed().
|
|
||||||
TEST_F(TestPartResultTest, Failed) {
|
|
||||||
EXPECT_FALSE(r1_.failed());
|
|
||||||
EXPECT_TRUE(r2_.failed());
|
|
||||||
EXPECT_TRUE(r3_.failed());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::fatally_failed().
|
|
||||||
TEST_F(TestPartResultTest, FatallyFailed) {
|
|
||||||
EXPECT_FALSE(r1_.fatally_failed());
|
|
||||||
EXPECT_FALSE(r2_.fatally_failed());
|
|
||||||
EXPECT_TRUE(r3_.fatally_failed());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests TestPartResult::nonfatally_failed().
|
|
||||||
TEST_F(TestPartResultTest, NonfatallyFailed) {
|
|
||||||
EXPECT_FALSE(r1_.nonfatally_failed());
|
|
||||||
EXPECT_TRUE(r2_.nonfatally_failed());
|
|
||||||
EXPECT_FALSE(r3_.nonfatally_failed());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests the TestPartResultArray class.
|
|
||||||
|
|
||||||
class TestPartResultArrayTest : public Test {
|
|
||||||
protected:
|
|
||||||
TestPartResultArrayTest()
|
|
||||||
: r1_(TestPartResult::kNonFatalFailure, "foo/bar.cc", -1, "Failure 1"),
|
|
||||||
r2_(TestPartResult::kFatalFailure, "foo/bar.cc", -1, "Failure 2") {}
|
|
||||||
|
|
||||||
const TestPartResult r1_, r2_;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Tests that TestPartResultArray initially has size 0.
|
|
||||||
TEST_F(TestPartResultArrayTest, InitialSizeIsZero) {
|
|
||||||
TestPartResultArray results;
|
|
||||||
EXPECT_EQ(0, results.size());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that TestPartResultArray contains the given TestPartResult
|
|
||||||
// after one Append() operation.
|
|
||||||
TEST_F(TestPartResultArrayTest, ContainsGivenResultAfterAppend) {
|
|
||||||
TestPartResultArray results;
|
|
||||||
results.Append(r1_);
|
|
||||||
EXPECT_EQ(1, results.size());
|
|
||||||
EXPECT_STREQ("Failure 1", results.GetTestPartResult(0).message());
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that TestPartResultArray contains the given TestPartResults
|
|
||||||
// after two Append() operations.
|
|
||||||
TEST_F(TestPartResultArrayTest, ContainsGivenResultsAfterTwoAppends) {
|
|
||||||
TestPartResultArray results;
|
|
||||||
results.Append(r1_);
|
|
||||||
results.Append(r2_);
|
|
||||||
EXPECT_EQ(2, results.size());
|
|
||||||
EXPECT_STREQ("Failure 1", results.GetTestPartResult(0).message());
|
|
||||||
EXPECT_STREQ("Failure 2", results.GetTestPartResult(1).message());
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef TestPartResultArrayTest TestPartResultArrayDeathTest;
|
|
||||||
|
|
||||||
// Tests that the program dies when GetTestPartResult() is called with
|
|
||||||
// an invalid index.
|
|
||||||
TEST_F(TestPartResultArrayDeathTest, DiesWhenIndexIsOutOfBound) {
|
|
||||||
TestPartResultArray results;
|
|
||||||
results.Append(r1_);
|
|
||||||
|
|
||||||
EXPECT_DEATH_IF_SUPPORTED(results.GetTestPartResult(-1), "");
|
|
||||||
EXPECT_DEATH_IF_SUPPORTED(results.GetTestPartResult(1), "");
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO(mheule@google.com): Add a test for the class HasNewFatalFailureHelper.
|
|
||||||
|
|
||||||
} // namespace
|
|
@ -1,320 +0,0 @@
|
|||||||
// Copyright 2007, Google Inc.
|
|
||||||
// All rights reserved.
|
|
||||||
//
|
|
||||||
// Redistribution and use in source and binary forms, with or without
|
|
||||||
// modification, are permitted provided that the following conditions are
|
|
||||||
// met:
|
|
||||||
//
|
|
||||||
// * Redistributions of source code must retain the above copyright
|
|
||||||
// notice, this list of conditions and the following disclaimer.
|
|
||||||
// * Redistributions in binary form must reproduce the above
|
|
||||||
// copyright notice, this list of conditions and the following disclaimer
|
|
||||||
// in the documentation and/or other materials provided with the
|
|
||||||
// distribution.
|
|
||||||
// * Neither the name of Google Inc. nor the names of its
|
|
||||||
// contributors may be used to endorse or promote products derived from
|
|
||||||
// this software without specific prior written permission.
|
|
||||||
//
|
|
||||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
||||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
||||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
||||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
||||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
||||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
||||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
||||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
||||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
//
|
|
||||||
// Author: wan@google.com (Zhanyong Wan)
|
|
||||||
|
|
||||||
#include "gtest/internal/gtest-tuple.h"
|
|
||||||
#include <utility>
|
|
||||||
#include "gtest/gtest.h"
|
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
using ::std::tr1::get;
|
|
||||||
using ::std::tr1::make_tuple;
|
|
||||||
using ::std::tr1::tuple;
|
|
||||||
using ::std::tr1::tuple_element;
|
|
||||||
using ::std::tr1::tuple_size;
|
|
||||||
using ::testing::StaticAssertTypeEq;
|
|
||||||
|
|
||||||
// Tests that tuple_element<K, tuple<T0, T1, ..., TN> >::type returns TK.
|
|
||||||
TEST(tuple_element_Test, ReturnsElementType) {
|
|
||||||
StaticAssertTypeEq<int, tuple_element<0, tuple<int, char> >::type>();
|
|
||||||
StaticAssertTypeEq<int&, tuple_element<1, tuple<double, int&> >::type>();
|
|
||||||
StaticAssertTypeEq<bool, tuple_element<2, tuple<double, int, bool> >::type>();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that tuple_size<T>::value gives the number of fields in tuple
|
|
||||||
// type T.
|
|
||||||
TEST(tuple_size_Test, ReturnsNumberOfFields) {
|
|
||||||
EXPECT_EQ(0, +tuple_size<tuple<> >::value);
|
|
||||||
EXPECT_EQ(1, +tuple_size<tuple<void*> >::value);
|
|
||||||
EXPECT_EQ(1, +tuple_size<tuple<char> >::value);
|
|
||||||
EXPECT_EQ(1, +(tuple_size<tuple<tuple<int, double> > >::value));
|
|
||||||
EXPECT_EQ(2, +(tuple_size<tuple<int&, const char> >::value));
|
|
||||||
EXPECT_EQ(3, +(tuple_size<tuple<char*, void, const bool&> >::value));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests comparing a tuple with itself.
|
|
||||||
TEST(ComparisonTest, ComparesWithSelf) {
|
|
||||||
const tuple<int, char, bool> a(5, 'a', false);
|
|
||||||
|
|
||||||
EXPECT_TRUE(a == a);
|
|
||||||
EXPECT_FALSE(a != a);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests comparing two tuples with the same value.
|
|
||||||
TEST(ComparisonTest, ComparesEqualTuples) {
|
|
||||||
const tuple<int, bool> a(5, true), b(5, true);
|
|
||||||
|
|
||||||
EXPECT_TRUE(a == b);
|
|
||||||
EXPECT_FALSE(a != b);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests comparing two different tuples that have no reference fields.
|
|
||||||
TEST(ComparisonTest, ComparesUnequalTuplesWithoutReferenceFields) {
|
|
||||||
typedef tuple<const int, char> FooTuple;
|
|
||||||
|
|
||||||
const FooTuple a(0, 'x');
|
|
||||||
const FooTuple b(1, 'a');
|
|
||||||
|
|
||||||
EXPECT_TRUE(a != b);
|
|
||||||
EXPECT_FALSE(a == b);
|
|
||||||
|
|
||||||
const FooTuple c(1, 'b');
|
|
||||||
|
|
||||||
EXPECT_TRUE(b != c);
|
|
||||||
EXPECT_FALSE(b == c);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests comparing two different tuples that have reference fields.
|
|
||||||
TEST(ComparisonTest, ComparesUnequalTuplesWithReferenceFields) {
|
|
||||||
typedef tuple<int&, const char&> FooTuple;
|
|
||||||
|
|
||||||
int i = 5;
|
|
||||||
const char ch = 'a';
|
|
||||||
const FooTuple a(i, ch);
|
|
||||||
|
|
||||||
int j = 6;
|
|
||||||
const FooTuple b(j, ch);
|
|
||||||
|
|
||||||
EXPECT_TRUE(a != b);
|
|
||||||
EXPECT_FALSE(a == b);
|
|
||||||
|
|
||||||
j = 5;
|
|
||||||
const char ch2 = 'b';
|
|
||||||
const FooTuple c(j, ch2);
|
|
||||||
|
|
||||||
EXPECT_TRUE(b != c);
|
|
||||||
EXPECT_FALSE(b == c);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that a tuple field with a reference type is an alias of the
|
|
||||||
// variable it's supposed to reference.
|
|
||||||
TEST(ReferenceFieldTest, IsAliasOfReferencedVariable) {
|
|
||||||
int n = 0;
|
|
||||||
tuple<bool, int&> t(true, n);
|
|
||||||
|
|
||||||
n = 1;
|
|
||||||
EXPECT_EQ(n, get<1>(t))
|
|
||||||
<< "Changing a underlying variable should update the reference field.";
|
|
||||||
|
|
||||||
// Makes sure that the implementation doesn't do anything funny with
|
|
||||||
// the & operator for the return type of get<>().
|
|
||||||
EXPECT_EQ(&n, &(get<1>(t)))
|
|
||||||
<< "The address of a reference field should equal the address of "
|
|
||||||
<< "the underlying variable.";
|
|
||||||
|
|
||||||
get<1>(t) = 2;
|
|
||||||
EXPECT_EQ(2, n)
|
|
||||||
<< "Changing a reference field should update the underlying variable.";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that tuple's default constructor default initializes each field.
|
|
||||||
// This test needs to compile without generating warnings.
|
|
||||||
TEST(TupleConstructorTest, DefaultConstructorDefaultInitializesEachField) {
|
|
||||||
// The TR1 report requires that tuple's default constructor default
|
|
||||||
// initializes each field, even if it's a primitive type. If the
|
|
||||||
// implementation forgets to do this, this test will catch it by
|
|
||||||
// generating warnings about using uninitialized variables (assuming
|
|
||||||
// a decent compiler).
|
|
||||||
|
|
||||||
tuple<> empty;
|
|
||||||
|
|
||||||
tuple<int> a1, b1;
|
|
||||||
b1 = a1;
|
|
||||||
EXPECT_EQ(0, get<0>(b1));
|
|
||||||
|
|
||||||
tuple<int, double> a2, b2;
|
|
||||||
b2 = a2;
|
|
||||||
EXPECT_EQ(0, get<0>(b2));
|
|
||||||
EXPECT_EQ(0.0, get<1>(b2));
|
|
||||||
|
|
||||||
tuple<double, char, bool*> a3, b3;
|
|
||||||
b3 = a3;
|
|
||||||
EXPECT_EQ(0.0, get<0>(b3));
|
|
||||||
EXPECT_EQ('\0', get<1>(b3));
|
|
||||||
EXPECT_TRUE(get<2>(b3) == NULL);
|
|
||||||
|
|
||||||
tuple<int, int, int, int, int, int, int, int, int, int> a10, b10;
|
|
||||||
b10 = a10;
|
|
||||||
EXPECT_EQ(0, get<0>(b10));
|
|
||||||
EXPECT_EQ(0, get<1>(b10));
|
|
||||||
EXPECT_EQ(0, get<2>(b10));
|
|
||||||
EXPECT_EQ(0, get<3>(b10));
|
|
||||||
EXPECT_EQ(0, get<4>(b10));
|
|
||||||
EXPECT_EQ(0, get<5>(b10));
|
|
||||||
EXPECT_EQ(0, get<6>(b10));
|
|
||||||
EXPECT_EQ(0, get<7>(b10));
|
|
||||||
EXPECT_EQ(0, get<8>(b10));
|
|
||||||
EXPECT_EQ(0, get<9>(b10));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests constructing a tuple from its fields.
|
|
||||||
TEST(TupleConstructorTest, ConstructsFromFields) {
|
|
||||||
int n = 1;
|
|
||||||
// Reference field.
|
|
||||||
tuple<int&> a(n);
|
|
||||||
EXPECT_EQ(&n, &(get<0>(a)));
|
|
||||||
|
|
||||||
// Non-reference fields.
|
|
||||||
tuple<int, char> b(5, 'a');
|
|
||||||
EXPECT_EQ(5, get<0>(b));
|
|
||||||
EXPECT_EQ('a', get<1>(b));
|
|
||||||
|
|
||||||
// Const reference field.
|
|
||||||
const int m = 2;
|
|
||||||
tuple<bool, const int&> c(true, m);
|
|
||||||
EXPECT_TRUE(get<0>(c));
|
|
||||||
EXPECT_EQ(&m, &(get<1>(c)));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests tuple's copy constructor.
|
|
||||||
TEST(TupleConstructorTest, CopyConstructor) {
|
|
||||||
tuple<double, bool> a(0.0, true);
|
|
||||||
tuple<double, bool> b(a);
|
|
||||||
|
|
||||||
EXPECT_DOUBLE_EQ(0.0, get<0>(b));
|
|
||||||
EXPECT_TRUE(get<1>(b));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests constructing a tuple from another tuple that has a compatible
|
|
||||||
// but different type.
|
|
||||||
TEST(TupleConstructorTest, ConstructsFromDifferentTupleType) {
|
|
||||||
tuple<int, int, char> a(0, 1, 'a');
|
|
||||||
tuple<double, long, int> b(a);
|
|
||||||
|
|
||||||
EXPECT_DOUBLE_EQ(0.0, get<0>(b));
|
|
||||||
EXPECT_EQ(1, get<1>(b));
|
|
||||||
EXPECT_EQ('a', get<2>(b));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests constructing a 2-tuple from an std::pair.
|
|
||||||
TEST(TupleConstructorTest, ConstructsFromPair) {
|
|
||||||
::std::pair<int, char> a(1, 'a');
|
|
||||||
tuple<int, char> b(a);
|
|
||||||
tuple<int, const char&> c(a);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests assigning a tuple to another tuple with the same type.
|
|
||||||
TEST(TupleAssignmentTest, AssignsToSameTupleType) {
|
|
||||||
const tuple<int, long> a(5, 7L);
|
|
||||||
tuple<int, long> b;
|
|
||||||
b = a;
|
|
||||||
EXPECT_EQ(5, get<0>(b));
|
|
||||||
EXPECT_EQ(7L, get<1>(b));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests assigning a tuple to another tuple with a different but
|
|
||||||
// compatible type.
|
|
||||||
TEST(TupleAssignmentTest, AssignsToDifferentTupleType) {
|
|
||||||
const tuple<int, long, bool> a(1, 7L, true);
|
|
||||||
tuple<long, int, bool> b;
|
|
||||||
b = a;
|
|
||||||
EXPECT_EQ(1L, get<0>(b));
|
|
||||||
EXPECT_EQ(7, get<1>(b));
|
|
||||||
EXPECT_TRUE(get<2>(b));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests assigning an std::pair to a 2-tuple.
|
|
||||||
TEST(TupleAssignmentTest, AssignsFromPair) {
|
|
||||||
const ::std::pair<int, bool> a(5, true);
|
|
||||||
tuple<int, bool> b;
|
|
||||||
b = a;
|
|
||||||
EXPECT_EQ(5, get<0>(b));
|
|
||||||
EXPECT_TRUE(get<1>(b));
|
|
||||||
|
|
||||||
tuple<long, bool> c;
|
|
||||||
c = a;
|
|
||||||
EXPECT_EQ(5L, get<0>(c));
|
|
||||||
EXPECT_TRUE(get<1>(c));
|
|
||||||
}
|
|
||||||
|
|
||||||
// A fixture for testing big tuples.
|
|
||||||
class BigTupleTest : public testing::Test {
|
|
||||||
protected:
|
|
||||||
typedef tuple<int, int, int, int, int, int, int, int, int, int> BigTuple;
|
|
||||||
|
|
||||||
BigTupleTest() :
|
|
||||||
a_(1, 0, 0, 0, 0, 0, 0, 0, 0, 2),
|
|
||||||
b_(1, 0, 0, 0, 0, 0, 0, 0, 0, 3) {}
|
|
||||||
|
|
||||||
BigTuple a_, b_;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Tests constructing big tuples.
|
|
||||||
TEST_F(BigTupleTest, Construction) {
|
|
||||||
BigTuple a;
|
|
||||||
BigTuple b(b_);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests that get<N>(t) returns the N-th (0-based) field of tuple t.
|
|
||||||
TEST_F(BigTupleTest, get) {
|
|
||||||
EXPECT_EQ(1, get<0>(a_));
|
|
||||||
EXPECT_EQ(2, get<9>(a_));
|
|
||||||
|
|
||||||
// Tests that get() works on a const tuple too.
|
|
||||||
const BigTuple a(a_);
|
|
||||||
EXPECT_EQ(1, get<0>(a));
|
|
||||||
EXPECT_EQ(2, get<9>(a));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tests comparing big tuples.
|
|
||||||
TEST_F(BigTupleTest, Comparisons) {
|
|
||||||
EXPECT_TRUE(a_ == a_);
|
|
||||||
EXPECT_FALSE(a_ != a_);
|
|
||||||
|
|
||||||
EXPECT_TRUE(a_ != b_);
|
|
||||||
EXPECT_FALSE(a_ == b_);
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeTupleTest, WorksForScalarTypes) {
|
|
||||||
tuple<bool, int> a;
|
|
||||||
a = make_tuple(true, 5);
|
|
||||||
EXPECT_TRUE(get<0>(a));
|
|
||||||
EXPECT_EQ(5, get<1>(a));
|
|
||||||
|
|
||||||
tuple<char, int, long> b;
|
|
||||||
b = make_tuple('a', 'b', 5);
|
|
||||||
EXPECT_EQ('a', get<0>(b));
|
|
||||||
EXPECT_EQ('b', get<1>(b));
|
|
||||||
EXPECT_EQ(5, get<2>(b));
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(MakeTupleTest, WorksForPointers) {
|
|
||||||
int a[] = { 1, 2, 3, 4 };
|
|
||||||
const char* const str = "hi";
|
|
||||||
int* const p = a;
|
|
||||||
|
|
||||||
tuple<const char*, int*> t;
|
|
||||||
t = make_tuple(str, p);
|
|
||||||
EXPECT_EQ(str, get<0>(t));
|
|
||||||
EXPECT_EQ(p, get<1>(t));
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user