From 2faf94d368410926c69dcdb85ace13a953e95596 Mon Sep 17 00:00:00 2001 From: LambdAurora Date: Thu, 13 Dec 2018 19:28:32 +0100 Subject: [PATCH] =?UTF-8?q?:bookmark:=20=CE=BBcommon=20v1.9.4:=20Added=20R?= =?UTF-8?q?ISC-V=20archs,=20dropped=20useless=20const=20qualifier,=20and?= =?UTF-8?q?=20more...?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- include/lambdacommon/connection/address.h | 46 ++++++++++++++++-- include/lambdacommon/graphics/color.h | 19 ++++++++ include/lambdacommon/lambdacommon.h | 2 +- include/lambdacommon/lstring.h | 2 +- include/lambdacommon/object.h | 3 ++ include/lambdacommon/resources.h | 6 +-- include/lambdacommon/sizes.h | 6 +-- include/lambdacommon/system/devices.h | 8 +++- include/lambdacommon/system/system.h | 2 + src/connection/address.cpp | 58 +++++++++++------------ src/system/system.cpp | 12 ++++- tests/test.cpp | 10 ++-- 12 files changed, 124 insertions(+), 50 deletions(-) diff --git a/include/lambdacommon/connection/address.h b/include/lambdacommon/connection/address.h index 850b447..5690cf8 100644 --- a/include/lambdacommon/connection/address.h +++ b/include/lambdacommon/connection/address.h @@ -14,6 +14,11 @@ #include "../types.h" #include +#ifdef LAMBDA_WINDOWS +# pragma warning(push) +# pragma warning(disable:4251) +#endif + namespace lambdacommon { typedef std::string host; @@ -27,10 +32,13 @@ namespace lambdacommon INVALID }; - class LAMBDACOMMON_API Address : public Object + /*! + * Represents a network address. + */ + class LAMBDACOMMON_API Address : public Object, public Nullable { protected: - host *_host; + host _host; port_t _port; public: @@ -42,32 +50,62 @@ namespace lambdacommon ~Address(); + /*! + * Gets the host of the address. + * @return The host of the address. + */ const host &get_host() const; + /*! + * Gets the port of the address. + * @return The port of the address. + */ port_t get_port() const; + /*! + * Checks whether the address is an IPv4 address. + * @return True if the address is an IPv4 address, else false. + */ bool is_ipv4() const; + /*! + * Checks whether the address is an IPv6 address. + * @return True if the address is an IPv6 address, else false. + */ bool is_ipv6() const; bool is_domain_valid() const; + /*! + * Checks whether the address is empty. + * @return True if the address is empty, else false. + */ bool is_empty() const; + /*! + * Gets the type of address. + * @return The type of address. + */ AddressType get_type() const; + bool is_null() const override; + std::string to_string() const override; Address &operator=(const Address &other); Address &operator=(Address &&other) noexcept; - bool operator==(const Address &other); + bool operator==(const Address &other) const; - bool operator!=(const Address &other); + bool operator<(const Address &other) const; static Address EMPTY; }; } +#ifdef LAMBDA_WINDOWS +# pragma warning(pop) +#endif + #endif //LAMBDACOMMON_ADDRESS_H \ No newline at end of file diff --git a/include/lambdacommon/graphics/color.h b/include/lambdacommon/graphics/color.h index c3003c7..4a65cc8 100644 --- a/include/lambdacommon/graphics/color.h +++ b/include/lambdacommon/graphics/color.h @@ -207,10 +207,29 @@ namespace lambdacommon */ extern Color LAMBDACOMMON_API mix(const Color &a, const Color &b, float ratio); + /*! + * Makes a new Color instance from the given hexadecimal color value. + * @param hex_color The hexadecimal color value. + * @param has_alpha True if the hexadecimal color value includes the alpha channel, else false. + * @return A new Color instance. + */ extern Color LAMBDACOMMON_API from_hex(uint64_t hex_color, bool has_alpha = true); + /*! + * Makes a new Color instance from the given hexadecimal color value string. + * @param hex_color The hexadecimal color value as a string. + * @return A new Color instance. + */ extern Color LAMBDACOMMON_API from_hex(const std::string &hex_color); + /*! + * Makes a new Color instance from a RGB value. + * @param red Red channel. + * @param green Green channel. + * @param blue Blue channel. + * @param alpha Alpha channel. + * @return A new Color instance. + */ extern Color LAMBDACOMMON_API from_int_rgba(uint8_t red, uint8_t green, uint8_t blue, uint8_t alpha = 255); } } diff --git a/include/lambdacommon/lambdacommon.h b/include/lambdacommon/lambdacommon.h index 5458bf0..f0195a9 100644 --- a/include/lambdacommon/lambdacommon.h +++ b/include/lambdacommon/lambdacommon.h @@ -42,7 +42,7 @@ #define LAMBDACOMMON_VERSION_MAJOR 1 #define LAMBDACOMMON_VERSION_MINOR 9 -#define LAMBDACOMMON_VERSION_PATCH 3 +#define LAMBDACOMMON_VERSION_PATCH 4 #define LAMBDACOMMON_VERSION_TYPE "Release" // Deletes the pointer and sets the variable to null. It's just simpler to write like this. diff --git a/include/lambdacommon/lstring.h b/include/lambdacommon/lstring.h index 7b76a96..16d3c3a 100644 --- a/include/lambdacommon/lstring.h +++ b/include/lambdacommon/lstring.h @@ -10,8 +10,8 @@ #ifndef LAMBDACOMMON_STRING_H #define LAMBDACOMMON_STRING_H -#include #include "object.h" +#include namespace lambdacommon { diff --git a/include/lambdacommon/object.h b/include/lambdacommon/object.h index 4083614..e08a6ab 100644 --- a/include/lambdacommon/object.h +++ b/include/lambdacommon/object.h @@ -14,6 +14,9 @@ namespace lambdacommon { + /*! + * Represents an object. + */ class LAMBDACOMMON_API Object { public: diff --git a/include/lambdacommon/resources.h b/include/lambdacommon/resources.h index 196d661..2aabb9e 100644 --- a/include/lambdacommon/resources.h +++ b/include/lambdacommon/resources.h @@ -28,7 +28,7 @@ namespace lambdacommon * * Represents a resource identifier. */ - class LAMBDACOMMON_API ResourceName + class LAMBDACOMMON_API ResourceName : public Object { private: std::string _domain; @@ -66,7 +66,7 @@ namespace lambdacommon * Gets the resource name as a string. * @return The resource name as a string. */ - std::string to_string() const; + std::string to_string() const override; /*! * Creates a new {@code ResourceName} from this resource name. @@ -149,7 +149,7 @@ namespace lambdacommon lambdacommon::fs::FilePath _working_directory; public: - FileResourcesManager(const lambdacommon::fs::FilePath &working_directory = fs::get_current_working_directory()); + explicit FileResourcesManager(const lambdacommon::fs::FilePath &working_directory = fs::get_current_working_directory()); FileResourcesManager(const FileResourcesManager &other); diff --git a/include/lambdacommon/sizes.h b/include/lambdacommon/sizes.h index c984567..3866f99 100644 --- a/include/lambdacommon/sizes.h +++ b/include/lambdacommon/sizes.h @@ -34,7 +34,7 @@ namespace lambdacommon Size2D() : Size2D(0, 0) {} - Size2D(const T width, const T height) : _width(width), _height(height) + Size2D(T width, T height) : _width(width), _height(height) {} /*! @@ -87,7 +87,7 @@ namespace lambdacommon return _width == 0 && _height == 0; } - std::string to_string() const override + virtual std::string to_string() const override { return R"({"width":)" + std::to_string(_width) + R"(,"height":)" + std::to_string(_height) + "}"; } @@ -272,7 +272,7 @@ namespace lambdacommon Size3D() : Size3D(0, 0) {} - Size3D(const T width, const T height, const T depth = 0) : Size2D(width, height), _depth(depth) + Size3D(T width, T height, T depth = 0) : Size2D(width, height), _depth(depth) {} /*! diff --git a/include/lambdacommon/system/devices.h b/include/lambdacommon/system/devices.h index b6f60b3..ce31461 100644 --- a/include/lambdacommon/system/devices.h +++ b/include/lambdacommon/system/devices.h @@ -14,10 +14,14 @@ namespace lambdacommon { + /*! + * Represents the current status of a device. + */ enum DeviceStatus { - CONNECTED = 1, - DISCONNECTED = 0 + CONNECTED = true, + DISCONNECTED = false, + WAITING = 2 }; } diff --git a/include/lambdacommon/system/system.h b/include/lambdacommon/system/system.h index 07fcfba..8d8a02c 100644 --- a/include/lambdacommon/system/system.h +++ b/include/lambdacommon/system/system.h @@ -31,6 +31,8 @@ namespace lambdacommon ARM64, ARMv8_64, I386, + RISCV32, + RISCV64, X86_64, UNKNOWN }; diff --git a/src/connection/address.cpp b/src/connection/address.cpp index 9f58895..52049b4 100644 --- a/src/connection/address.cpp +++ b/src/connection/address.cpp @@ -24,23 +24,20 @@ namespace lambdacommon { - Address::Address(const host &host, port_t port) : _host(new std::string(host)), _port(port) + Address::Address(const host &host, port_t port) : _host(host), _port(port) {} - Address::Address(const Address &address) : _host(new host(*address._host)), _port(address._port) + Address::Address(const Address &address) : _host(address._host), _port(address._port) {} - Address::Address(Address &&address) noexcept : _host(new host(move(*address._host))), _port(address._port) + Address::Address(Address &&address) noexcept : _host(move(address._host)), _port(address._port) {} - Address::~Address() - { - delete _host; - } + Address::~Address() = default; const host &Address::get_host() const { - return *_host; + return _host; } port_t Address::get_port() const @@ -54,23 +51,23 @@ namespace lambdacommon char d; short ip1, ip2, ip3, ip4; std::stringstream ss; - ss << *_host; + ss << _host; ss >> ip1 >> d >> ip2 >> d >> ip3 >> d >> ip4 >> d; ss.str(""); ss.clear(); ss << (ip1 & 0xFF) << "." << (ip2 & 0xFF) << "." << (ip3 & 0xFF) << "." << (ip4 & 0xFF); - return ss.str() == *_host; + return ss.str() == _host; #else - struct sockaddr_in sa; - return inet_pton(AF_INET, _host->c_str(), &(sa.sin_addr)) != 0; + struct sockaddr_in sa{}; + return inet_pton(AF_INET, _host.c_str(), &(sa.sin_addr)) != 0; #endif } bool Address::is_ipv6() const { #ifdef __MINGW32__ - const char *s = _host->c_str(); - int colons = 0, segsize = 0, i, ix = static_cast(_host->length()); + const char *s = _host.c_str(); + int colons = 0, segsize = 0, i, ix = static_cast(_host.length()); if (s[0] == ':' || s[ix - 1] == ':') return false; for (colons = 0, i = 0, segsize = 0; i < ix; i++) @@ -88,16 +85,16 @@ namespace lambdacommon } return colons <= 7; #else - struct sockaddr_in6 sa; - return inet_pton(AF_INET6, _host->c_str(), &(sa.sin6_addr)) != 0; + struct sockaddr_in6 sa{}; + return inet_pton(AF_INET6, _host.c_str(), &(sa.sin6_addr)) != 0; #endif } bool Address::is_domain_valid() const { static const std::string tlds = "|com|net|org|edu|gov|int|mil|ac|ad|ae|af|ag|ai|al|am|an|ao|aq|ar|arpa|at|au|ax|az|ba|bb|bd|be|bf|bg|bh|bi|bj|bm|bn|bo|br|bs|bt|bv|bw|by|bz|ca|cc|cd|cf|cg|ch|ci|ck|cl|cm|cn|co|cr|cu|cv|cx|cy|cz|de|dj|dk|dm|do|dz|ec|ee|eg|er|es|et|eu|fi|fj|fk|fm|fo|fr|ga|gb|gd|ge|gf|gg|gh|gi|gl|gm|gn|gp|gq|gr|gs|gt|gu|gw|gy|hk|hm|hn|hr|ht|hu|id|ie|il|im|in|io|iq|ir|is|it|je|jm|jo|jp|ke|kg|kh|ki|km|kn|kp|kr|kw|ky|kz|la|lb|lc|li|lk|lr|ls|lt|lu|lv|ly|ma|mc|md|me|mg|mh|mk|ml|mm|mn|mo|mp|mq|ms|mt|mu|mv|mw|mx|my|mz|na|nc|ne|nf|ng|ni|nl|no|np|nr|nu|nz|om|pa|pe|pf|pg|ph|pk|pl|pm|pn|pr|ps|pt|pw|py|qa|re|ro|rs|ru|rw|sa|sb|sc|sd|se|sg|sh|si|sj|sk|sl|sm|sn|so|sr|st|su|sv|sy|sz|tc|td|tf|tg|th|tj|tk|tl|tm|tn|to|tp|tr|tt|tv|tw|tz|ua|ug|uk|us|uy|uz|va|vc|ve|vg|vi|vn|vu|wf|ws|ye|yt|za|zm|zw|aw|as|mr|bl|bq|cw|eh|mf|ss|sx|um|aaa|aarp|abarth|abb|abbott|abbvie|abc|able|abogado|abudhabi|academy|accenture|accountant|accountants|acer|aco|active|actor|adac|ads|adult|aeg|aero|aetna|afamilycompany|afl|africa|africamagic|agakhan|agency|aig|aigo|airbus|airforce|airtel|akdn|alcon|alfaromeo|alibaba|alipay|allfinanz|allfinanzberater|allfinanzberatung|allstate|ally|alsace|alstom|amazon|americanexpress|americanfamily|amex|amfam|amica|amp|amsterdam|analytics|and|android|anquan|ansons|anthem|antivirus|aol|apartments|app|apple|aquarelle|aquitaine|arab|aramco|archi|architect|are|army|art|arte|asda|asia|associates|astrium|athleta|attorney|auction|audi|audible|audio|auspost|author|auto|autoinsurance|autos|avery|avianca|axa|axis|azure|baby|baidu|banamex|bananarepublic|band|bank|banque|bar|barcelona|barclaycard|barclays|barefoot|bargains|baseball|basketball|bauhaus|bayern|bbb|bbc|bbt|bbva|bcg|bcn|beats|beauty|beer|beknown|bentley|berlin|best|bestbuy|bet|bharti|bible|bid|bike|bing|bingo|bio|biz|black|blackfriday|blanco|blockbuster|blog|bloomberg|bloomingdales|blue|bms|bmw|bnl|bnpparibas|boats|boehringer|bofa|bom|bond|boo|book|booking|boots|bosch|bostik|boston|bot|boutique|box|bradesco|bridgestone|broadway|broker|brother|brussels|budapest|bugatti|buick|build|builders|business|buy|buzz|bway|bzh|cab|cadillac|cafe|cal|call|calvinklein|cam|camera|camp|canalplus|cancerresearch|canon|capetown|capital|capitalone|caravan|cards|care|career|careers|caremore|carinsurance|cars|cartier|casa|case|caseih|cash|cashbackbonus|casino|cat|catalonia|catering|catholic|cba|cbn|cbre|cbs|ceb|center|ceo|cern|cfa|cfd|chanel|changiairport|channel|charity|chartis|chase|chat|chatr|cheap|chesapeake|chevrolet|chevy|chintai|city|chk|chloe|christmas|chrome|chrysler|church|cialis|cimb|cipriani|circle|cisco|citadel|citi|citic|cityeats|claims|cleaning|click|clinic|clinique|clothing|club|clubmed|coach|codes|coffee|college|cologne|com|comcast|commbank|community|company|compare|computer|comsec|condos|connectors|construction|consulting|contact|contractors|cooking|cookingchannel|cool|coop|corsica|country|coupon|coupons|courses|credit|creditcard|creditunion|cricket|crown|crs|cruise|cruises|csc|cuisinella|cymru|cyou|dabur|dad|dance|data|date|dating|datsun|day|dclk|dds|deal|dealer|deals|degree|delivery|dell|delmonte|deloitte|delta|democrat|dental|dentist|desi|design|deutschepost|dhl|diamonds|diet|digikey|digital|direct|directory|discount|discover|dish|diy|dnb|dnp|docomo|docs|doctor|dodge|dog|doha|domains|doosan|dot|dotafrica|download|drive|dstv|dtv|dubai|duck|dunlop|duns|dupont|durban|dvag|dvr|dwg|earth|eat|eco|ecom|edeka|education|edu|email|emerck|emerson|energy|engineer|engineering|enterprises|epost|epson|equipment|ericsson|erni|esq|est|estate|esurance|etisalat|eurovision|eus|events|everbank|exchange|expert|exposed|express|extraspace|fage|fail|fairwinds|faith|family|fan|fans|farm|farmers|fashion|fast|fedex|feedback|ferrari|ferrero|fiat|fidelity|fido|film|final|finance|financial|financialaid|finish|fire|firestone|firmdale|fish|fishing|fitness|flickr|flights|flir|florist|flowers|fls|flsmidth|fly|foo|food|foodnetwork|football|ford|forex|forsale|forum|foundation|fox|free|fresenius|frl|frogans|frontdoor|frontier|ftr|fujitsu|fujixerox|fun|fund|furniture|futbol|fyi|gai|gal|gallery|gallo|gallup|game|games|gap|garden|garnier|gay|gbiz|gcc|gdn|gea|gecompany|ged|gent|genting|george|ggee|gift|gifts|gives|giving|glade|glass|gle|glean|global|globalx|globo|gmail|gmbh|gmc|gmo|gmx|godaddy|gold|goldpoint|golf|goo|goodhands|goodyear|goog|google|gop|got|gotv|grainger|graphics|gratis|gree|green|gripe|grocery|group|guardian|guardianlife|guardianmedia|gucci|guge|guide|guitars|guru|hair|halal|hamburg|hangout|haus|hbo|hdfc|hdfcbank|health|healthcare|heart|heinz|help|helsinki|here|hermes|hgtv|hilton|hiphop|hisamitsu|hitachi|hiv|hkt|hockey|holdings|holiday|homedepot|homegoods|homes|homesense|honda|honeywell|horse|host|hosting|hoteis|hotel|hoteles|hotels|hotmail|house|how|htc|hughes|hyatt|hyundai|ibm|icbc|ice|icu|idn|ieee|ifm|iinet|ikano|imamat|imdb|immo|immobilien|indians|industries|infiniti|info|infosys|infy|ing|ink|institute|insurance|insure|intel|international|intuit|investments|ipiranga|ira|irish|iselect|islam|ismaili|ist|istanbul|itau|itv|iveco|iwc|jaguar|java|jcb|jcp|jeep|jetzt|jewelry|jio|jlc|jll|jmp|jnj|jobs|joburg|jot|joy|jpmorgan|jpmorganchase|jprs|juegos|juniper|justforu|kaufen|kddi|kerastase|kerryhotels|kerrylogisitics|kerryproperties|ketchup|kfh|kia|kid|kids|kiehls|kim|kinder|kindle|kitchen|kiwi|koeln|komatsu|konami|kone|kosher|kpmg|kpn|krd|kred|ksb|kuokgroup|kyknet|kyoto|lacaixa|ladbrokes|lamborghini|lamer|lancaster|lancia|lancome|land|landrover|lanxess|lat|latino|latrobe|lawyer|lds|lease|leclerc|lefrak|legal|lego|lexus|lgbt|liaison|lidl|life|lifeinsurance|lifestyle|lighting|lightning|like|lilly|limited|limo|lincoln|linde|link|lipsy|live|livestrong|living|lixil|llc|loan|loans|locker|locus|loft|lol|london|loreal|lotte|lotto|love|lpl|lplfinancial|ltd|ltda|lundbeck|lupin|luxe|luxury|macys|madrid|maif|maison|makeup|man|management|mango|map|market|marketing|markets|marriott|marshalls|maserati|mattel|maybelline|mba|mcd|mcdonalds|mckinsey|media|medical|meet|melbourne|meme|memorial|men|menu|meo|merck|merckmsd|metlife|miami|microsoft|mih|mii|mini|mint|mit|mitek|mitsubishi|mlb|mls|mnet|mobi|mobile|mobily|moda|moe|mom|monash|money|monster|montblanc|mopar|mormon|mortgage|moscow|moto|motorcycles|mov|movie|movistar|mozaic|mrmuscle|mrporter|mtn|mtpc|mtr|multichoice|museum|music|mutual|mutualfunds|mutuelle|mzansimagic|nab|nadex|nagoya|name|naspers|nationwide|natura|navy|nba|nec|net|netaporter|netbank|netflix|network|neustar|new|newholland|news|next|nextdirect|nexus|nfl|ngo|nhk|nico|nike|nikon|ninja|nissan|nissay|nokia|northlandinsurance|northwesternmutual|norton|now|nowruz|nowtv|nra|nrw|ntt|nyc|obi|observer|off|okinawa|olayan|olayangroup|oldnavy|ollo|olympus|omega|ong|onl|online|onyourside|ooo|open|oracle|orange|org|organic|orientexpress|origins|osaka|otsuka|ott|overheidnl|ovh|page|pamperedchef|panasonic|panerai|paris|pars|partners|parts|party|passagens|patagonia|patch|pay|payu|pccw|persiangulf|pets|pfizer|pharmacy|phd|philips|phone|photo|photography|photos|physio|piaget|pics|pictet|pictures|pid|pin|ping|pink|pioneer|piperlime|pitney|pizza|place|play|playstation|plumbing|plus|pnc|pohl|poker|politie|polo|porn|post|pramerica|praxi|press|prime|pro|prod|productions|prof|progressive|promo|properties|property|protection|pru|prudential|pub|pwc|qpon|qtel|quebec|quest|qvc|racing|radio|raid|ram|read|realestate|realtor|realty|recipes|red|redken|redstone|redumbrella|rehab|reise|reisen|reit|ren|rent|rentals|repair|report|republican|rest|restaurant|retirement|review|reviews|rexroth|rich|richardli|ricoh|rightathome|ril|rio|rip|rmit|rocher|rocks|rockwool|rodeo|rogers|roma|room|rsvp|rugby|ruhr|run|rwe|ryukyu|saarland|safe|safety|safeway|sakura|sale|salon|samsclub|samsung|sandvik|sandvikcoromant|sanofi|sap|sapo|sapphire|sarl|sas|save|saxo|sbi|sbs|sca|scb|schaeffler|schedule|schmidt|scholarhips|scholarships|schule|schwarz|schwarzgroup|science|scjohnson|scor|scot|search|seat|security|seek|select|sener|services|ses|seven|sew|sex|sexy|sfr|shangrila|sharp|shell|shia|shiksha|shirriam|shoes|shop|shopping|shopyourway|shouji|show|showtime|shriram|silk|sina|singles|ski|skin|skolkovo|sky|skydrive|skype|sling|smart|smile|sncf|soccer|social|softbank|software|sohu|solar|solutions|song|sony|soy|spa|space|spiegel|sport|sports|spot|spreadbetting|srt|stada|staples|star|starhub|statebank|statefarm|statoil|stc|stcgroup|stockholm|storage|store|stream|stroke|studio|study|style|sucks|supersport|supplies|supply|support|surf|surgery|suzuki|svr|swatch|swiftcover|swiss|symantec|systems|sydney|tab|taipei|talk|taobao|target|tata|tatamotors|tatar|tattoo|tax|taxi|tci|tdk|team|technology|tel|telecity|telefonica|temasek|tennis|terra|teva|thai|thd|theater|theatre|theguardian|thehartford|tiaa|tickets|tienda|tiffany|tips|tires|tirol|tjmaxx|tjx|tkmaxx|tmall|today|tokyo|tools|top|toray|toshiba|total|tour|tours|town|toyota|toys|trade|tradershotels|trading|training|transformers|translations|transunion|travel|travelchannel|travelers|travelersinsurance|travelguard|trust|trv|tube|tui|tunes|tushu|tvs|ubank|ubs|uconnect|ultrabook|ummah|unicom|unicorn|university|uno|uol|ups|vacations|vana|vanguard|vanish|vegas|ventures|verisign|versicherung|vet|viajes|video|vig|viking|villas|vin|vip|virgin|visa|vision|vista|vistaprint|viva|vivo|vlaanderen|vodka|volkswagen|volvo|vons|vote|voting|voto|voyage|vuelos|wales|walmart|walter|wang|wanggou|warman|watch|watches|weather|weatherchannel|web|webcam|weber|webjet|webs|website|wed|wedding|weibo|weir|whoswho|wien|wiki|williamhill|wilmar|windows|wine|winners|wme|wolterskluwer|world|woodside|work|works|wow|wtc|wtf|xbox|xerox|xfinity|xihuan|xin|xn--11b4c3d|xn--1ck2e1b|xn--1qqw23a|xn--30rr7y|xn--3bst00m|xn--3ds443g|xn--3e0b707e|xn--3oq18vl8pn36a|xn--3pxu8k|xn--42c2d9a|xn--45brj9c|xn--45q11c|xn--4gbrim|xn--4gq48lf9j|xn--54b7fta0cc|xn--55qw42g|xn--55qx5d|xn--55qx5d8y0buji4b870u|xn--5su34j936bgsg|xn--5tzm5g|xn--6frz82g|xn--6qq986b3x1|xn--6qq986b3xl|xn--6rtwn|xn--80adxhks|xn--80ao21a|xn--80aqecdr1a|xn--80asehdb|xn--80aswg|xn--8y0a063a|xn--90a3ac|xn--9et52u|xn--9krt00a|xn--b4w605ferd|xn--bck1b9a5dre4c|xn--c1avg|xn--c1yn36f|xn--c2br7g|xn--cck2b3b|xn--cckwcxetd|xn--cg4bki|xn--clchc0ea0b2g2a9gcd|xn--czr694b|xn--czrs0t|xn--czru2d|xn--d1acj3b|xn--dkwm73cwpn|xn--eckvdtc9d|xn--efvy88h|xn--estv75g|xn--fct429k|xn--fes124c|xn--fhbei|xn--fiq228c5hs|xn--fiq64b|xn--fiQ64b|xn--fiQ64B|xn--fiqs8s|xn--fiqz9s|xn--fjq720a|xn--flw351e|xn--fpcrj9c3d|xn--fzc2c9e2c|xn--fzys8d69uvgm|xn--g2xx48c|xn--gckr3f0f|xn--gecrj9c|xn--gk3at1e|xn--h2brj9c|xn--hdb9cza1b|xn--hxt035cmppuel|xn--hxt035czzpffl|xn--hxt814e|xn--i1b6b1a6a2e|xn--imr513n|xn--io0a7i|xn--j1aef|xn--j1amh|xn--j6w193g|xn--j6w470d71issc|xn--jlq480n2rg|xn--jlq61u9w7b|xn--jvr189m|xn--kcrx77d1x4a|xn--kcrx7bb75ajk3b|xn--kprw13d|xn--kpry57d|xn--kpu716f|xn--kput3i|xn--lgbbat1ad8j|xn--mgb9awbf|xn--mgba3a3ejt|xn--mgba3a4f16a|xn--mgba7c0bbn0a|xn--mgbaakc7dvf|xn--mgbaam7a8h|xn--mgbab2bd|xn--mgbai9azgqp6j|xn--mgbayh7gpa|xn--mgbb9fbpob|xn--mgbbh1a71e|xn--mgbc0a9azcg|xn--mgbca7dzdo|xn--mgberp4a5d4ar|xn--mgbi4ecexp|xn--mgbt3dhd|xn--mgbv6cfpo|xn--mgbx4cd0ab|xn--mk1bu44c|xn--mxtq1m|xn--ngbc5azd|xn--ngbe9e0a|xn--ngbrx|xn--node|xn--nqv7f|xn--nqv7fs00ema|xn--nyqy26a|xn--o3cw4h|xn--ogbpf8fl|xn--otu796d|xn--p1acf|xn--p1ai|xn--pbt977c|xn--pgb3ceoj|xn--pgbs0dh|xn--pssy2u|xn--q9jyb4c|xn--qcka1pmc|xn--rhqv96g|xn--rovu88b|xn--s9brj9c|xn--ses554g|xn--t60b56a|xn--tckwe|xn--tiq49xqyj|xn--tqq33ed31aqia|xn--unup4y|xn--vermgensberater-ctb|xn--vermgensberatung-pwb|xn--vhquv|xn--vuq861b|xn--w4r85el8fhu5dnra|xn--w4rs40l|xn--wgbh1c|xn--wgbl6a|xn--xhq521b|xn--xkc2al3hye2a|xn--xkc2dl3a5ee0h|xn--yfro4i67o|xn--ygbi2ammx|xn--zfr164b|xn—3ds443g|xn—fiq228c5hs|xperia|xxx|xyz|yachts|yahoo|yamaxun|yandex|yellowpages|yodobashi|yoga|yokohama|you|youtube|yun|zappos|zara|zero|zip|zippo|zone|zuerich|zulu|"; - const char *s = _host->c_str(); - size_t segsize = 0, i, ix = _host->length(); + const char *s = _host.c_str(); + size_t segsize = 0, i, ix = _host.length(); if (s[0] == '.' || s[ix - 1] == '.' || ix > 253) return false; for (i = 0, segsize = 0; i < ix; i++) { @@ -119,7 +116,7 @@ namespace lambdacommon } std::stringstream ss; - ss << "|" << _host->substr(ix - segsize) << "|"; // Get last domain segment. + ss << "|" << _host.substr(ix - segsize) << "|"; // Get last domain segment. return tlds.find(ss.str()) != std::string::npos; @@ -127,7 +124,7 @@ namespace lambdacommon bool Address::is_empty() const { - return _host->empty() && _port == 0; + return _host.empty() && _port == 0; } AddressType Address::get_type() const @@ -144,13 +141,18 @@ namespace lambdacommon return INVALID; } + bool Address::is_null() const + { + return is_empty(); + } + std::string Address::to_string() const { if (is_empty()) return ""; std::string l_port = (_port != 0 ? ":" + std::to_string(_port) : ""); - std::string l_host = *_host; + std::string l_host = _host; switch (get_type()) { case IPv6: l_host = ("[" + l_host + "]"); @@ -167,8 +169,7 @@ namespace lambdacommon Address &Address::operator=(const Address &other) { if (this != &other) { - delete _host; - _host = new host(*other._host); + _host = other._host; _port = other._port; } return *this; @@ -177,21 +178,20 @@ namespace lambdacommon Address &Address::operator=(Address &&other) noexcept { if (this != &other) { - delete _host; - _host = new host(move(*other._host)); + _host = move(other._host); _port = other._port; } return *this; } - bool Address::operator==(const Address &other) + bool Address::operator==(const Address &other) const { - return *_host == (*other._host) && _port == other._port; + return _host == other._host && _port == other._port; } - bool Address::operator!=(const Address &other) + bool Address::operator<(const Address &other) const { - return *_host != (*other._host) || _port != other._port; + return std::tie(_host, _port) < std::tie(other._host, other._port); } Address Address::EMPTY{"", 0}; diff --git a/src/system/system.cpp b/src/system/system.cpp index 8ee9125..2c5fb9f 100644 --- a/src/system/system.cpp +++ b/src/system/system.cpp @@ -122,6 +122,8 @@ namespace lambdacommon return SysArchitecture::I386; case PROCESSOR_ARCHITECTURE_ARM: return SysArchitecture::ARM; + case PROCESSOR_ARCHITECTURE_ARM64: + return SysArchitecture::ARM64; case PROCESSOR_ARCHITECTURE_UNKNOWN: return SysArchitecture::UNKNOWN; default: @@ -288,6 +290,10 @@ namespace lambdacommon return SysArchitecture::ARM; else if (lstring::equals_ignore_case(get_processor_arch_str(), "aarch64")) return SysArchitecture::ARMv8_64; + else if (lstring::equals_ignore_case(get_processor_arch_str(), "riscv32")) + return SysArchitecture::RISCV32; + else if (lstring::equals_ignore_case(get_processor_arch_str(), "riscv64")) + return SysArchitecture::RISCV64; else return SysArchitecture::UNKNOWN; } @@ -477,10 +483,12 @@ namespace lambdacommon return "ARMv8 64bit"; case I386: return "i386"; + case RISCV32: + return "riscv32"; + case RISCV64: + return "riscv64"; case X86_64: return "x86_64"; - case UNKNOWN: - return "Unknown"; default: return "Unknown"; } diff --git a/tests/test.cpp b/tests/test.cpp index 1b53008..765bb85 100644 --- a/tests/test.cpp +++ b/tests/test.cpp @@ -315,18 +315,18 @@ int main() tests_count++; if (test(R"(ResourceName::operator=({"tests:value/OwO"}) with object {"tests:value/path"})", []() { - auto newRes = BASE_RESOURCENAME; + auto new_res = BASE_RESOURCENAME; ResourceName owo{"tests", "value/OwO"}; - newRes = owo; - return newRes.get_name() == "value/OwO"; + new_res = owo; + return new_res.get_name() == "value/OwO"; })) tests_passed++; tests_count++; if (test(R"(ResourceName::operator/ with base object {"tests:value/path"} and argument "owo")", []() { auto base = BASE_RESOURCENAME; - auto newRes = base / "owo"; - return newRes.get_name() == "value/path/owo"; + auto new_res = base / "owo"; + return new_res.get_name() == "value/path/owo"; })) tests_passed++;