| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007 | /* Distributed under the OSI-approved BSD 3-Clause License.  See accompanying   file Copyright.txt or https://cmake.org/licensing for details.  */#include "cmVisualStudio10TargetGenerator.h"#include <iterator>#include <set>#include <cm/memory>#include <cm/string_view>#include <cm/vector>#include <cmext/algorithm>#include "windows.h"#include "cmComputeLinkInformation.h"#include "cmCustomCommand.h"#include "cmCustomCommandGenerator.h"#include "cmGeneratedFileStream.h"#include "cmGeneratorExpression.h"#include "cmGeneratorTarget.h"#include "cmGlobalVisualStudio10Generator.h"#include "cmGlobalVisualStudioVersionedGenerator.h"#include "cmLinkLineDeviceComputer.h"#include "cmLocalVisualStudio10Generator.h"#include "cmMakefile.h"#include "cmSourceFile.h"#include "cmStringAlgorithms.h"#include "cmSystemTools.h"#include "cmVisualStudioGeneratorOptions.h"static void ConvertToWindowsSlash(std::string& s);static std::string cmVS10EscapeXML(std::string arg){  cmSystemTools::ReplaceString(arg, "&", "&");  cmSystemTools::ReplaceString(arg, "<", "<");  cmSystemTools::ReplaceString(arg, ">", ">");  return arg;}static std::string cmVS10EscapeAttr(std::string arg){  cmSystemTools::ReplaceString(arg, "&", "&");  cmSystemTools::ReplaceString(arg, "<", "<");  cmSystemTools::ReplaceString(arg, ">", ">");  cmSystemTools::ReplaceString(arg, "\"", """);  cmSystemTools::ReplaceString(arg, "\n", "
");  return arg;}struct cmVisualStudio10TargetGenerator::Elem{  std::ostream& S;  const int Indent;  bool HasElements = false;  bool HasContent = false;  std::string Tag;  Elem(std::ostream& s, const std::string& tag)    : S(s)    , Indent(0)    , Tag(tag)  {    this->StartElement();  }  Elem(const Elem&) = delete;  Elem(Elem& par, cm::string_view tag)    : S(par.S)    , Indent(par.Indent + 1)    , Tag(std::string(tag))  {    par.SetHasElements();    this->StartElement();  }  void SetHasElements()  {    if (!HasElements) {      this->S << ">";      HasElements = true;    }  }  std::ostream& WriteString(const char* line);  void StartElement() { this->WriteString("<") << this->Tag; }  void Element(cm::string_view tag, std::string val)  {    Elem(*this, tag).Content(std::move(val));  }  Elem& Attribute(const char* an, std::string av)  {    this->S << " " << an << "=\"" << cmVS10EscapeAttr(std::move(av)) << "\"";    return *this;  }  void Content(std::string val)  {    if (!this->HasContent) {      this->S << ">";      this->HasContent = true;    }    this->S << cmVS10EscapeXML(std::move(val));  }  ~Elem()  {    // Do not emit element which has not been started    if (Tag.empty()) {      return;    }    if (HasElements) {      this->WriteString("</") << this->Tag << ">";    } else if (HasContent) {      this->S << "</" << this->Tag << ">";    } else {      this->S << " />";    }  }  void WritePlatformConfigTag(const std::string& tag, const std::string& cond,                              const std::string& content);};class cmVS10GeneratorOptions : public cmVisualStudioGeneratorOptions{public:  using Elem = cmVisualStudio10TargetGenerator::Elem;  cmVS10GeneratorOptions(cmLocalVisualStudioGenerator* lg, Tool tool,                         cmVS7FlagTable const* table,                         cmVisualStudio10TargetGenerator* g = nullptr)    : cmVisualStudioGeneratorOptions(lg, tool, table)    , TargetGenerator(g)  {  }  void OutputFlag(std::ostream& /*fout*/, int /*indent*/,                  const std::string& tag, const std::string& content) override  {    if (!this->GetConfiguration().empty()) {      // if there are configuration specific flags, then      // use the configuration specific tag for PreprocessorDefinitions      const std::string cond =        this->TargetGenerator->CalcCondition(this->GetConfiguration());      this->Parent->WritePlatformConfigTag(tag, cond, content);    } else {      this->Parent->Element(tag, content);    }  }private:  cmVisualStudio10TargetGenerator* const TargetGenerator;  Elem* Parent = nullptr;  friend cmVisualStudio10TargetGenerator::OptionsHelper;};struct cmVisualStudio10TargetGenerator::OptionsHelper{  cmVS10GeneratorOptions& O;  OptionsHelper(cmVS10GeneratorOptions& o, Elem& e)    : O(o)  {    O.Parent = &e;  }  ~OptionsHelper() { O.Parent = nullptr; }  void OutputPreprocessorDefinitions(const std::string& lang)  {    O.OutputPreprocessorDefinitions(O.Parent->S, O.Parent->Indent + 1, lang);  }  void OutputAdditionalIncludeDirectories(const std::string& lang)  {    O.OutputAdditionalIncludeDirectories(O.Parent->S, O.Parent->Indent + 1,                                         lang);  }  void OutputFlagMap() { O.OutputFlagMap(O.Parent->S, O.Parent->Indent + 1); }  void PrependInheritedString(std::string const& key)  {    O.PrependInheritedString(key);  }};static std::string cmVS10EscapeComment(std::string comment){  // MSBuild takes the CDATA of a <Message></Message> element and just  // does "echo $CDATA" with no escapes.  We must encode the string.  // http://technet.microsoft.com/en-us/library/cc772462%28WS.10%29.aspx  std::string echoable;  for (char c : comment) {    switch (c) {      case '\r':        break;      case '\n':        echoable += '\t';        break;      case '"': /* no break */      case '|': /* no break */      case '&': /* no break */      case '<': /* no break */      case '>': /* no break */      case '^':        echoable += '^'; /* no break */        CM_FALLTHROUGH;      default:        echoable += c;        break;    }  }  return echoable;}static bool cmVS10IsTargetsFile(std::string const& path){  std::string const ext = cmSystemTools::GetFilenameLastExtension(path);  return cmSystemTools::Strucmp(ext.c_str(), ".targets") == 0;}static std::string computeProjectFileExtension(cmGeneratorTarget const* t){  std::string res;  res = ".vcxproj";  if (t->IsCSharpOnly()) {    res = ".csproj";  }  return res;}cmVisualStudio10TargetGenerator::cmVisualStudio10TargetGenerator(  cmGeneratorTarget* target, cmGlobalVisualStudio10Generator* gg)  : GeneratorTarget(target)  , Makefile(target->Target->GetMakefile())  , Platform(gg->GetPlatformName())  , Name(target->GetName())  , GUID(gg->GetGUID(this->Name))  , GlobalGenerator(gg)  , LocalGenerator(      (cmLocalVisualStudio10Generator*)target->GetLocalGenerator()){  this->Configurations =    this->Makefile->GetGeneratorConfigs(cmMakefile::ExcludeEmptyConfig);  this->NsightTegra = gg->IsNsightTegra();  this->Android = gg->TargetsAndroid();  for (int i = 0; i < 4; ++i) {    this->NsightTegraVersion[i] = 0;  }  sscanf(gg->GetNsightTegraVersion().c_str(), "%u.%u.%u.%u",         &this->NsightTegraVersion[0], &this->NsightTegraVersion[1],         &this->NsightTegraVersion[2], &this->NsightTegraVersion[3]);  this->MSTools = !this->NsightTegra && !this->Android;  this->Managed = false;  this->TargetCompileAsWinRT = false;  this->IsMissingFiles = false;  this->DefaultArtifactDir =    this->LocalGenerator->GetCurrentBinaryDirectory() + "/" +    this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);  this->InSourceBuild = (this->Makefile->GetCurrentSourceDirectory() ==                         this->Makefile->GetCurrentBinaryDirectory());  this->ClassifyAllConfigSources();}cmVisualStudio10TargetGenerator::~cmVisualStudio10TargetGenerator(){}std::string cmVisualStudio10TargetGenerator::CalcCondition(  const std::string& config) const{  std::ostringstream oss;  oss << "'$(Configuration)|$(Platform)'=='";  oss << config << "|" << this->Platform;  oss << "'";  // handle special case for 32 bit C# targets  if (this->ProjectType == csproj && this->Platform == "Win32") {    oss << " Or ";    oss << "'$(Configuration)|$(Platform)'=='";    oss << config << "|x86";    oss << "'";  }  return oss.str();}void cmVisualStudio10TargetGenerator::Elem::WritePlatformConfigTag(  const std::string& tag, const std::string& cond, const std::string& content){  Elem(*this, tag).Attribute("Condition", cond).Content(content);}std::ostream& cmVisualStudio10TargetGenerator::Elem::WriteString(  const char* line){  this->S << '\n';  this->S.fill(' ');  this->S.width(this->Indent * 2);  // write an empty string to get the fill level indent to print  this->S << "";  this->S << line;  return this->S;}#define VS10_CXX_DEFAULT_PROPS "$(VCTargetsPath)\\Microsoft.Cpp.Default.props"#define VS10_CXX_PROPS "$(VCTargetsPath)\\Microsoft.Cpp.props"#define VS10_CXX_USER_PROPS                                                   \  "$(UserRootDir)\\Microsoft.Cpp.$(Platform).user.props"#define VS10_CXX_TARGETS "$(VCTargetsPath)\\Microsoft.Cpp.targets"#define VS10_CSharp_DEFAULT_PROPS                                             \  "$(MSBuildExtensionsPath)\\$(MSBuildToolsVersion)\\Microsoft.Common.props"// This does not seem to exist by default, it's just provided for consistency// in case users want to have default custom props for C# targets#define VS10_CSharp_USER_PROPS                                                \  "$(UserRootDir)\\Microsoft.CSharp.$(Platform).user.props"#define VS10_CSharp_TARGETS "$(MSBuildToolsPath)\\Microsoft.CSharp.targets"#define VS10_CSharp_NETCF_TARGETS                                             \  "$(MSBuildExtensionsPath)\\Microsoft\\$(TargetFrameworkIdentifier)\\"       \  "$(TargetFrameworkTargetsVersion)\\Microsoft.$(TargetFrameworkIdentifier)"  \  ".CSharp.targets"void cmVisualStudio10TargetGenerator::Generate(){  // do not generate external ms projects  if (this->GeneratorTarget->GetType() == cmStateEnums::INTERFACE_LIBRARY ||      this->GeneratorTarget->GetProperty("EXTERNAL_MSPROJECT")) {    return;  }  const std::string ProjectFileExtension =    computeProjectFileExtension(this->GeneratorTarget);  if (ProjectFileExtension == ".vcxproj") {    this->ProjectType = vcxproj;    this->Managed = false;  } else if (ProjectFileExtension == ".csproj") {    if (this->GeneratorTarget->GetType() == cmStateEnums::STATIC_LIBRARY) {      std::string message = "The C# target \"" +        this->GeneratorTarget->GetName() +        "\" is of type STATIC_LIBRARY. This is discouraged (and may be "        "disabled in future). Make it a SHARED library instead.";      this->Makefile->IssueMessage(MessageType::DEPRECATION_WARNING, message);    }    this->ProjectType = csproj;    this->Managed = true;  }  if (this->Android &&      this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE &&      !this->GeneratorTarget->Target->IsAndroidGuiExecutable()) {    this->GlobalGenerator->AddAndroidExecutableWarning(this->Name);  }  // Tell the global generator the name of the project file  this->GeneratorTarget->Target->SetProperty("GENERATOR_FILE_NAME",                                             this->Name);  this->GeneratorTarget->Target->SetProperty("GENERATOR_FILE_NAME_EXT",                                             ProjectFileExtension);  this->DotNetHintReferences.clear();  this->AdditionalUsingDirectories.clear();  if (this->GeneratorTarget->GetType() <= cmStateEnums::OBJECT_LIBRARY) {    if (!this->ComputeClOptions()) {      return;    }    if (!this->ComputeRcOptions()) {      return;    }    if (!this->ComputeCudaOptions()) {      return;    }    if (!this->ComputeCudaLinkOptions()) {      return;    }    if (!this->ComputeMasmOptions()) {      return;    }    if (!this->ComputeNasmOptions()) {      return;    }    if (!this->ComputeLinkOptions()) {      return;    }    if (!this->ComputeLibOptions()) {      return;    }  }  std::string path =    cmStrCat(this->LocalGenerator->GetCurrentBinaryDirectory(), '/',             this->Name, ProjectFileExtension);  cmGeneratedFileStream BuildFileStream(path);  const std::string PathToProjectFile = path;  BuildFileStream.SetCopyIfDifferent(true);  // Write the encoding header into the file  char magic[] = { char(0xEF), char(0xBB), char(0xBF) };  BuildFileStream.write(magic, 3);  BuildFileStream << "<?xml version=\"1.0\" encoding=\""                  << this->GlobalGenerator->Encoding() << "\"?>";  {    Elem e0(BuildFileStream, "Project");    e0.Attribute("DefaultTargets", "Build");    const char* toolsVersion = this->GlobalGenerator->GetToolsVersion();    if (this->GlobalGenerator->GetVersion() ==          cmGlobalVisualStudioGenerator::VS12 &&        this->GlobalGenerator->TargetsWindowsCE()) {      toolsVersion = "4.0";    }    e0.Attribute("ToolsVersion", toolsVersion);    e0.Attribute("xmlns",                 "http://schemas.microsoft.com/developer/msbuild/2003");    if (this->NsightTegra) {      Elem e1(e0, "PropertyGroup");      e1.Attribute("Label", "NsightTegraProject");      const unsigned int nsightTegraMajorVersion = this->NsightTegraVersion[0];      const unsigned int nsightTegraMinorVersion = this->NsightTegraVersion[1];      if (nsightTegraMajorVersion >= 2) {        if (nsightTegraMajorVersion > 3 ||            (nsightTegraMajorVersion == 3 && nsightTegraMinorVersion >= 1)) {          e1.Element("NsightTegraProjectRevisionNumber", "11");        } else {          // Nsight Tegra 2.0 uses project revision 9.          e1.Element("NsightTegraProjectRevisionNumber", "9");        }        // Tell newer versions to upgrade silently when loading.        e1.Element("NsightTegraUpgradeOnceWithoutPrompt", "true");      } else {        // Require Nsight Tegra 1.6 for JCompile support.        e1.Element("NsightTegraProjectRevisionNumber", "7");      }    }    if (const char* hostArch =          this->GlobalGenerator->GetPlatformToolsetHostArchitecture()) {      Elem e1(e0, "PropertyGroup");      e1.Element("PreferredToolArchitecture", hostArch);    }    if (this->ProjectType != csproj) {      this->WriteProjectConfigurations(e0);    }    {      Elem e1(e0, "PropertyGroup");      e1.Attribute("Label", "Globals");      e1.Element("ProjectGuid", "{" + this->GUID + "}");      if ((this->MSTools || this->Android) &&          this->GeneratorTarget->GetType() <= cmStateEnums::GLOBAL_TARGET) {        this->WriteApplicationTypeSettings(e1);        this->VerifyNecessaryFiles();      }      cmProp vsProjectTypes =        this->GeneratorTarget->GetProperty("VS_GLOBAL_PROJECT_TYPES");      if (vsProjectTypes) {        const char* tagName = "ProjectTypes";        if (this->ProjectType == csproj) {          tagName = "ProjectTypeGuids";        }        e1.Element(tagName, *vsProjectTypes);      }      cmProp vsProjectName =        this->GeneratorTarget->GetProperty("VS_SCC_PROJECTNAME");      cmProp vsLocalPath =        this->GeneratorTarget->GetProperty("VS_SCC_LOCALPATH");      cmProp vsProvider =        this->GeneratorTarget->GetProperty("VS_SCC_PROVIDER");      if (vsProjectName && vsLocalPath && vsProvider) {        e1.Element("SccProjectName", *vsProjectName);        e1.Element("SccLocalPath", *vsLocalPath);        e1.Element("SccProvider", *vsProvider);        cmProp vsAuxPath =          this->GeneratorTarget->GetProperty("VS_SCC_AUXPATH");        if (vsAuxPath) {          e1.Element("SccAuxPath", *vsAuxPath);        }      }      if (this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_COMPONENT")) {        e1.Element("WinMDAssembly", "true");      }      cmProp vsGlobalKeyword =        this->GeneratorTarget->GetProperty("VS_GLOBAL_KEYWORD");      if (!vsGlobalKeyword) {        if (this->GlobalGenerator->TargetsAndroid()) {          e1.Element("Keyword", "Android");        } else {          e1.Element("Keyword", "Win32Proj");        }      } else {        e1.Element("Keyword", *vsGlobalKeyword);      }      cmProp vsGlobalRootNamespace =        this->GeneratorTarget->GetProperty("VS_GLOBAL_ROOTNAMESPACE");      if (vsGlobalRootNamespace) {        e1.Element("RootNamespace", *vsGlobalRootNamespace);      }      e1.Element("Platform", this->Platform);      cmProp projLabel = this->GeneratorTarget->GetProperty("PROJECT_LABEL");      if (!projLabel) {        projLabel = &this->Name;      }      e1.Element("ProjectName", *projLabel);      {        cmProp targetFramework =          this->GeneratorTarget->GetProperty("DOTNET_TARGET_FRAMEWORK");        if (targetFramework) {          if (std::strchr(targetFramework->c_str(), ';') != nullptr) {            e1.Element("TargetFrameworks", *targetFramework);          } else {            e1.Element("TargetFramework", *targetFramework);          }        } else {          // TODO: add deprecation warning for VS_* property?          cmProp p = this->GeneratorTarget->GetProperty(            "VS_DOTNET_TARGET_FRAMEWORK_VERSION");          if (!p) {            p = this->GeneratorTarget->GetProperty(              "DOTNET_TARGET_FRAMEWORK_VERSION");          }          const char* targetFrameworkVersion = p ? p->c_str() : nullptr;          if (!targetFrameworkVersion && this->ProjectType == csproj &&              this->GlobalGenerator->TargetsWindowsCE() &&              this->GlobalGenerator->GetVersion() ==                cmGlobalVisualStudioGenerator::VS12) {            // VS12 .NETCF default to .NET framework 3.9            targetFrameworkVersion = "v3.9";          }          if (targetFrameworkVersion) {            e1.Element("TargetFrameworkVersion", targetFrameworkVersion);          }        }        if (this->ProjectType == vcxproj &&            this->GlobalGenerator->TargetsWindowsCE()) {          e1.Element("EnableRedirectPlatform", "true");          e1.Element("RedirectPlatformValue", this->Platform);        }        if (this->ProjectType == csproj &&            this->GlobalGenerator->TargetsWindowsCE()) {          cmProp targetFrameworkId = this->GeneratorTarget->GetProperty(            "VS_TARGET_FRAMEWORK_IDENTIFIER");          e1.Element("TargetFrameworkIdentifier",                     targetFrameworkId ? *targetFrameworkId                                       : "WindowsEmbeddedCompact");          cmProp targetFrameworkVer = this->GeneratorTarget->GetProperty(            "VS_TARGET_FRAMEWORKS_TARGET_VERSION");          e1.Element("TargetFrameworkTargetsVersion",                     targetFrameworkVer ? *targetFrameworkVer : "v8.0");        }        if (!this->GlobalGenerator->GetPlatformToolsetCudaCustomDirString()               .empty()) {          e1.Element(            "CudaToolkitCustomDir",            this->GlobalGenerator->GetPlatformToolsetCudaCustomDirString() +              "nvcc");        }      }      // Disable the project upgrade prompt that is displayed the first time a      // project using an older toolset version is opened in a newer version of      // the IDE (respected by VS 2013 and above).      if (this->GlobalGenerator->GetVersion() >=          cmGlobalVisualStudioGenerator::VS12) {        e1.Element("VCProjectUpgraderObjectName", "NoUpgrade");      }      if (const char* vcTargetsPath =            this->GlobalGenerator->GetCustomVCTargetsPath()) {        e1.Element("VCTargetsPath", vcTargetsPath);      }      std::vector<std::string> keys = this->GeneratorTarget->GetPropertyKeys();      for (std::string const& keyIt : keys) {        static const cm::string_view prefix = "VS_GLOBAL_";        if (!cmHasPrefix(keyIt, prefix))          continue;        cm::string_view globalKey =          cm::string_view(keyIt).substr(prefix.length());        // Skip invalid or separately-handled properties.        if (globalKey.empty() || globalKey == "PROJECT_TYPES" ||            globalKey == "ROOTNAMESPACE" || globalKey == "KEYWORD") {          continue;        }        cmProp value = this->GeneratorTarget->GetProperty(keyIt);        if (!value)          continue;        e1.Element(globalKey, *value);      }      if (this->Managed) {        std::string outputType;        switch (this->GeneratorTarget->GetType()) {          case cmStateEnums::OBJECT_LIBRARY:          case cmStateEnums::STATIC_LIBRARY:          case cmStateEnums::SHARED_LIBRARY:            outputType = "Library";            break;          case cmStateEnums::MODULE_LIBRARY:            outputType = "Module";            break;          case cmStateEnums::EXECUTABLE:            if (this->GeneratorTarget->Target->GetPropertyAsBool(                  "WIN32_EXECUTABLE")) {              outputType = "WinExe";            } else {              outputType = "Exe";            }            break;          case cmStateEnums::UTILITY:          case cmStateEnums::GLOBAL_TARGET:            outputType = "Utility";            break;          case cmStateEnums::UNKNOWN_LIBRARY:          case cmStateEnums::INTERFACE_LIBRARY:            break;        }        e1.Element("OutputType", outputType);        e1.Element("AppDesignerFolder", "Properties");      }    }    switch (this->ProjectType) {      case vcxproj:        if (this->GlobalGenerator->GetPlatformToolsetVersion()) {          Elem(e0, "Import")            .Attribute("Project",                       this->GlobalGenerator->GetAuxiliaryToolset());        }        Elem(e0, "Import").Attribute("Project", VS10_CXX_DEFAULT_PROPS);        break;      case csproj:        Elem(e0, "Import")          .Attribute("Project", VS10_CSharp_DEFAULT_PROPS)          .Attribute("Condition", "Exists('" VS10_CSharp_DEFAULT_PROPS "')");        break;    }    this->WriteProjectConfigurationValues(e0);    if (this->ProjectType == vcxproj) {      Elem(e0, "Import").Attribute("Project", VS10_CXX_PROPS);    }    {      Elem e1(e0, "ImportGroup");      e1.Attribute("Label", "ExtensionSettings");      e1.SetHasElements();      if (this->GlobalGenerator->IsCudaEnabled()) {        auto customDir =          this->GlobalGenerator->GetPlatformToolsetCudaCustomDirString();        std::string cudaPath = customDir.empty()          ? "$(VCTargetsPath)\\BuildCustomizations\\"          : customDir +            "CUDAVisualStudioIntegration\\extras\\"            "visual_studio_integration\\MSBuildExtensions\\";        Elem(e1, "Import")          .Attribute("Project",                     std::move(cudaPath) + "CUDA " +                       this->GlobalGenerator->GetPlatformToolsetCuda() +                       ".props");      }      if (this->GlobalGenerator->IsMasmEnabled()) {        Elem(e1, "Import")          .Attribute("Project",                     "$(VCTargetsPath)\\BuildCustomizations\\masm.props");      }      if (this->GlobalGenerator->IsNasmEnabled()) {        // Always search in the standard modules location.        std::string propsTemplate =          GetCMakeFilePath("Templates/MSBuild/nasm.props.in");        std::string propsLocal =          cmStrCat(this->DefaultArtifactDir, "\\nasm.props");        ConvertToWindowsSlash(propsLocal);        this->Makefile->ConfigureFile(propsTemplate, propsLocal, false, true,                                      true, true);        Elem(e1, "Import").Attribute("Project", propsLocal);      }    }    {      Elem e1(e0, "ImportGroup");      e1.Attribute("Label", "PropertySheets");      std::string props;      switch (this->ProjectType) {        case vcxproj:          props = VS10_CXX_USER_PROPS;          break;        case csproj:          props = VS10_CSharp_USER_PROPS;          break;      }      if (cmProp p = this->GeneratorTarget->GetProperty("VS_USER_PROPS")) {        props = *p;      }      if (!props.empty()) {        ConvertToWindowsSlash(props);        Elem(e1, "Import")          .Attribute("Project", props)          .Attribute("Condition", "exists('" + props + "')")          .Attribute("Label", "LocalAppDataPlatform");      }      this->WritePlatformExtensions(e1);    }    this->WriteDotNetDocumentationFile(e0);    Elem(e0, "PropertyGroup").Attribute("Label", "UserMacros");    this->WriteWinRTPackageCertificateKeyFile(e0);    this->WritePathAndIncrementalLinkOptions(e0);    this->WriteCEDebugProjectConfigurationValues(e0);    this->WriteItemDefinitionGroups(e0);    this->WriteCustomCommands(e0);    this->WriteAllSources(e0);    this->WriteDotNetReferences(e0);    this->WritePackageReferences(e0);    this->WriteImports(e0);    this->WriteEmbeddedResourceGroup(e0);    this->WriteXamlFilesGroup(e0);    this->WriteWinRTReferences(e0);    this->WriteProjectReferences(e0);    this->WriteSDKReferences(e0);    switch (this->ProjectType) {      case vcxproj:        Elem(e0, "Import").Attribute("Project", VS10_CXX_TARGETS);        break;      case csproj:        if (this->GlobalGenerator->TargetsWindowsCE()) {          Elem(e0, "Import").Attribute("Project", VS10_CSharp_NETCF_TARGETS);        } else {          Elem(e0, "Import").Attribute("Project", VS10_CSharp_TARGETS);        }        break;    }    this->WriteTargetSpecificReferences(e0);    {      Elem e1(e0, "ImportGroup");      e1.Attribute("Label", "ExtensionTargets");      e1.SetHasElements();      this->WriteTargetsFileReferences(e1);      if (this->GlobalGenerator->IsCudaEnabled()) {        auto customDir =          this->GlobalGenerator->GetPlatformToolsetCudaCustomDirString();        std::string cudaPath = customDir.empty()          ? "$(VCTargetsPath)\\BuildCustomizations\\"          : customDir +            "CUDAVisualStudioIntegration\\extras\\"            "visual_studio_integration\\MSBuildExtensions\\";        Elem(e1, "Import")          .Attribute("Project",                     std::move(cudaPath) + "CUDA " +                       this->GlobalGenerator->GetPlatformToolsetCuda() +                       ".targets");      }      if (this->GlobalGenerator->IsMasmEnabled()) {        Elem(e1, "Import")          .Attribute("Project",                     "$(VCTargetsPath)\\BuildCustomizations\\masm.targets");      }      if (this->GlobalGenerator->IsNasmEnabled()) {        std::string nasmTargets =          GetCMakeFilePath("Templates/MSBuild/nasm.targets");        Elem(e1, "Import").Attribute("Project", nasmTargets);      }    }    if (this->ProjectType == csproj) {      for (std::string const& c : this->Configurations) {        Elem e1(e0, "PropertyGroup");        e1.Attribute("Condition", "'$(Configuration)' == '" + c + "'");        e1.SetHasElements();        this->WriteEvents(e1, c);      }      // make sure custom commands are executed before build (if necessary)      {        Elem e1(e0, "PropertyGroup");        std::ostringstream oss;        oss << "\n";        for (std::string const& i : this->CSharpCustomCommandNames) {          oss << "      " << i << ";\n";        }        oss << "      "            << "$(BuildDependsOn)\n";        e1.Element("BuildDependsOn", oss.str());      }    }  }  if (BuildFileStream.Close()) {    this->GlobalGenerator->FileReplacedDuringGenerate(PathToProjectFile);  }  // The groups are stored in a separate file for VS 10  this->WriteGroups();}void cmVisualStudio10TargetGenerator::WritePackageReferences(Elem& e0){  std::vector<std::string> packageReferences;  if (cmProp vsPackageReferences =        this->GeneratorTarget->GetProperty("VS_PACKAGE_REFERENCES")) {    cmExpandList(*vsPackageReferences, packageReferences);  }  if (!packageReferences.empty()) {    Elem e1(e0, "ItemGroup");    for (std::string const& ri : packageReferences) {      size_t versionIndex = ri.find_last_of('_');      if (versionIndex != std::string::npos) {        Elem e2(e1, "PackageReference");        e2.Attribute("Include", ri.substr(0, versionIndex));        e2.Attribute("Version", ri.substr(versionIndex + 1));      }    }  }}void cmVisualStudio10TargetGenerator::WriteDotNetReferences(Elem& e0){  std::vector<std::string> references;  if (cmProp vsDotNetReferences =        this->GeneratorTarget->GetProperty("VS_DOTNET_REFERENCES")) {    cmExpandList(*vsDotNetReferences, references);  }  cmPropertyMap const& props = this->GeneratorTarget->Target->GetProperties();  for (auto const& i : props.GetList()) {    static const cm::string_view vsDnRef = "VS_DOTNET_REFERENCE_";    if (cmHasPrefix(i.first, vsDnRef)) {      std::string path = i.second;      if (!cmsys::SystemTools::FileIsFullPath(path)) {        path = this->Makefile->GetCurrentSourceDirectory() + "/" + path;      }      ConvertToWindowsSlash(path);      this->DotNetHintReferences[""].emplace_back(        DotNetHintReference(i.first.substr(vsDnRef.length()), path));    }  }  if (!references.empty() || !this->DotNetHintReferences.empty()) {    Elem e1(e0, "ItemGroup");    for (std::string const& ri : references) {      // if the entry from VS_DOTNET_REFERENCES is an existing file, generate      // a new hint-reference and name it from the filename      if (cmsys::SystemTools::FileExists(ri, true)) {        std::string name =          cmsys::SystemTools::GetFilenameWithoutLastExtension(ri);        std::string path = ri;        ConvertToWindowsSlash(path);        this->DotNetHintReferences[""].emplace_back(          DotNetHintReference(name, path));      } else {        this->WriteDotNetReference(e1, ri, "", "");      }    }    for (const auto& h : this->DotNetHintReferences) {      // DotNetHintReferences is also populated from AddLibraries().      // The configuration specific hint references are added there.      for (const auto& i : h.second) {        this->WriteDotNetReference(e1, i.first, i.second, h.first);      }    }  }}void cmVisualStudio10TargetGenerator::WriteDotNetReference(  Elem& e1, std::string const& ref, std::string const& hint,  std::string const& config){  Elem e2(e1, "Reference");  // If 'config' is not empty, the reference is only added for the given  // configuration. This is used when referencing imported managed assemblies.  // See also cmVisualStudio10TargetGenerator::AddLibraries().  if (!config.empty()) {    e2.Attribute("Condition", this->CalcCondition(config));  }  e2.Attribute("Include", ref);  e2.Element("CopyLocalSatelliteAssemblies", "true");  e2.Element("ReferenceOutputAssembly", "true");  if (!hint.empty()) {    const char* privateReference = "True";    if (cmProp value = this->GeneratorTarget->GetProperty(          "VS_DOTNET_REFERENCES_COPY_LOCAL")) {      if (cmIsOff(*value)) {        privateReference = "False";      }    }    e2.Element("Private", privateReference);    e2.Element("HintPath", hint);  }  this->WriteDotNetReferenceCustomTags(e2, ref);}void cmVisualStudio10TargetGenerator::WriteImports(Elem& e0){  cmProp imports =    this->GeneratorTarget->Target->GetProperty("VS_PROJECT_IMPORT");  if (imports) {    std::vector<std::string> argsSplit = cmExpandedList(*imports, false);    for (auto& path : argsSplit) {      if (!cmsys::SystemTools::FileIsFullPath(path)) {        path = this->Makefile->GetCurrentSourceDirectory() + "/" + path;      }      ConvertToWindowsSlash(path);      Elem e1(e0, "Import");      e1.Attribute("Project", path);    }  }}void cmVisualStudio10TargetGenerator::WriteDotNetReferenceCustomTags(  Elem& e2, std::string const& ref){  static const std::string refpropPrefix = "VS_DOTNET_REFERENCEPROP_";  static const std::string refpropInfix = "_TAG_";  const std::string refPropFullPrefix = refpropPrefix + ref + refpropInfix;  using CustomTags = std::map<std::string, std::string>;  CustomTags tags;  cmPropertyMap const& props = this->GeneratorTarget->Target->GetProperties();  for (const auto& i : props.GetList()) {    if (cmHasPrefix(i.first, refPropFullPrefix) && !i.second.empty()) {      tags[i.first.substr(refPropFullPrefix.length())] = i.second;    }  }  for (auto const& tag : tags) {    e2.Element(tag.first, tag.second);  }}void cmVisualStudio10TargetGenerator::WriteDotNetDocumentationFile(Elem& e0){  std::string const& documentationFile =    this->GeneratorTarget->GetSafeProperty("VS_DOTNET_DOCUMENTATION_FILE");  if (this->ProjectType == csproj && !documentationFile.empty()) {    Elem e1(e0, "PropertyGroup");    Elem e2(e1, "DocumentationFile");    e2.Content(documentationFile);  }}void cmVisualStudio10TargetGenerator::WriteEmbeddedResourceGroup(Elem& e0){  if (!this->ResxObjs.empty()) {    Elem e1(e0, "ItemGroup");    std::string srcDir = this->Makefile->GetCurrentSourceDirectory();    ConvertToWindowsSlash(srcDir);    for (cmSourceFile const* oi : this->ResxObjs) {      std::string obj = oi->GetFullPath();      ConvertToWindowsSlash(obj);      bool useRelativePath = false;      if (this->ProjectType == csproj && this->InSourceBuild) {        // If we do an in-source build and the resource file is in a        // subdirectory        // of the .csproj file, we have to use relative pathnames, otherwise        // visual studio does not show the file in the IDE. Sorry.        if (cmHasPrefix(obj, srcDir)) {          obj = this->ConvertPath(obj, true);          ConvertToWindowsSlash(obj);          useRelativePath = true;        }      }      Elem e2(e1, "EmbeddedResource");      e2.Attribute("Include", obj);      if (this->ProjectType != csproj) {        std::string hFileName = obj.substr(0, obj.find_last_of(".")) + ".h";        e2.Element("DependentUpon", hFileName);        for (std::string const& c : this->Configurations) {          std::string s;          if (this->GeneratorTarget->GetProperty("VS_GLOBAL_ROOTNAMESPACE") ||              // Handle variant of VS_GLOBAL_<variable> for RootNamespace.              this->GeneratorTarget->GetProperty("VS_GLOBAL_RootNamespace")) {            s = "$(RootNamespace).";          }          s += "%(Filename).resources";          e2.WritePlatformConfigTag("LogicalName", this->CalcCondition(c), s);        }      } else {        std::string binDir = this->Makefile->GetCurrentBinaryDirectory();        ConvertToWindowsSlash(binDir);        // If the resource was NOT added using a relative path (which should        // be the default), we have to provide a link here        if (!useRelativePath) {          std::string link = this->GetCSharpSourceLink(oi);          if (link.empty()) {            link = cmsys::SystemTools::GetFilenameName(obj);          }          e2.Element("Link", link);        }        // Determine if this is a generated resource from a .Designer.cs file        std::string designerResource =          cmSystemTools::GetFilenamePath(oi->GetFullPath()) + "/" +          cmSystemTools::GetFilenameWithoutLastExtension(oi->GetFullPath()) +          ".Designer.cs";        if (cmsys::SystemTools::FileExists(designerResource)) {          std::string generator = "PublicResXFileCodeGenerator";          if (cmProp g = oi->GetProperty("VS_RESOURCE_GENERATOR")) {            generator = *g;          }          if (!generator.empty()) {            e2.Element("Generator", generator);            if (cmHasPrefix(designerResource, srcDir)) {              designerResource.erase(0, srcDir.length());            } else if (cmHasPrefix(designerResource, binDir)) {              designerResource.erase(0, binDir.length());            } else {              designerResource =                cmsys::SystemTools::GetFilenameName(designerResource);            }            ConvertToWindowsSlash(designerResource);            e2.Element("LastGenOutput", designerResource);          }        }        const cmPropertyMap& props = oi->GetProperties();        for (const std::string& p : props.GetKeys()) {          static const cm::string_view propNamePrefix = "VS_CSHARP_";          if (cmHasPrefix(p, propNamePrefix)) {            cm::string_view tagName =              cm::string_view(p).substr(propNamePrefix.length());            if (!tagName.empty()) {              const std::string& value = *props.GetPropertyValue(p);              if (!value.empty()) {                e2.Element(tagName, value);              }            }          }        }      }    }  }}void cmVisualStudio10TargetGenerator::WriteXamlFilesGroup(Elem& e0){  if (!this->XamlObjs.empty()) {    Elem e1(e0, "ItemGroup");    for (cmSourceFile const* oi : this->XamlObjs) {      std::string obj = oi->GetFullPath();      std::string xamlType;      cmProp xamlTypeProperty = oi->GetProperty("VS_XAML_TYPE");      if (xamlTypeProperty) {        xamlType = *xamlTypeProperty;      } else {        xamlType = "Page";      }      Elem e2(e1, xamlType);      this->WriteSource(e2, oi);      e2.SetHasElements();      e2.Element("SubType", "Designer");    }  }}void cmVisualStudio10TargetGenerator::WriteTargetSpecificReferences(Elem& e0){  if (this->MSTools) {    if (this->GlobalGenerator->TargetsWindowsPhone() &&        this->GlobalGenerator->GetSystemVersion() == "8.0") {      Elem(e0, "Import")        .Attribute("Project",                   "$(MSBuildExtensionsPath)\\Microsoft\\WindowsPhone\\v"                   "$(TargetPlatformVersion)\\Microsoft.Cpp.WindowsPhone."                   "$(TargetPlatformVersion).targets");    }  }}void cmVisualStudio10TargetGenerator::WriteTargetsFileReferences(Elem& e1){  for (TargetsFileAndConfigs const& tac : this->TargetsFileAndConfigsVec) {    std::ostringstream oss;    oss << "Exists('" << tac.File << "')";    if (!tac.Configs.empty()) {      oss << " And (";      for (size_t j = 0; j < tac.Configs.size(); ++j) {        if (j > 0) {          oss << " Or ";        }        oss << "'$(Configuration)'=='" << tac.Configs[j] << "'";      }      oss << ")";    }    Elem(e1, "Import")      .Attribute("Project", tac.File)      .Attribute("Condition", oss.str());  }}void cmVisualStudio10TargetGenerator::WriteWinRTReferences(Elem& e0){  std::vector<std::string> references;  if (cmProp vsWinRTReferences =        this->GeneratorTarget->GetProperty("VS_WINRT_REFERENCES")) {    cmExpandList(*vsWinRTReferences, references);  }  if (this->GlobalGenerator->TargetsWindowsPhone() &&      this->GlobalGenerator->GetSystemVersion() == "8.0" &&      references.empty()) {    references.push_back("platform.winmd");  }  if (!references.empty()) {    Elem e1(e0, "ItemGroup");    for (std::string const& ri : references) {      Elem e2(e1, "Reference");      e2.Attribute("Include", ri);      e2.Element("IsWinMDFile", "true");    }  }}// ConfigurationType Application, Utility StaticLibrary DynamicLibraryvoid cmVisualStudio10TargetGenerator::WriteProjectConfigurations(Elem& e0){  Elem e1(e0, "ItemGroup");  e1.Attribute("Label", "ProjectConfigurations");  for (std::string const& c : this->Configurations) {    Elem e2(e1, "ProjectConfiguration");    e2.Attribute("Include", c + "|" + this->Platform);    e2.Element("Configuration", c);    e2.Element("Platform", this->Platform);  }}void cmVisualStudio10TargetGenerator::WriteProjectConfigurationValues(Elem& e0){  for (std::string const& c : this->Configurations) {    Elem e1(e0, "PropertyGroup");    e1.Attribute("Condition", this->CalcCondition(c));    e1.Attribute("Label", "Configuration");    if (this->ProjectType != csproj) {      std::string configType;      if (cmProp vsConfigurationType =            this->GeneratorTarget->GetProperty("VS_CONFIGURATION_TYPE")) {        configType = cmGeneratorExpression::Evaluate(*vsConfigurationType,                                                     this->LocalGenerator, c);      } else {        switch (this->GeneratorTarget->GetType()) {          case cmStateEnums::SHARED_LIBRARY:          case cmStateEnums::MODULE_LIBRARY:            configType = "DynamicLibrary";            break;          case cmStateEnums::OBJECT_LIBRARY:          case cmStateEnums::STATIC_LIBRARY:            configType = "StaticLibrary";            break;          case cmStateEnums::EXECUTABLE:            if (this->NsightTegra &&                !this->GeneratorTarget->Target->IsAndroidGuiExecutable()) {              // Android executables are .so too.              configType = "DynamicLibrary";            } else if (this->Android) {              configType = "DynamicLibrary";            } else {              configType = "Application";            }            break;          case cmStateEnums::UTILITY:          case cmStateEnums::GLOBAL_TARGET:            if (this->NsightTegra) {              // Tegra-Android platform does not understand "Utility".              configType = "StaticLibrary";            } else {              configType = "Utility";            }            break;          case cmStateEnums::UNKNOWN_LIBRARY:          case cmStateEnums::INTERFACE_LIBRARY:            break;        }      }      e1.Element("ConfigurationType", configType);    }    if (this->MSTools) {      if (!this->Managed) {        this->WriteMSToolConfigurationValues(e1, c);      } else {        this->WriteMSToolConfigurationValuesManaged(e1, c);      }    } else if (this->NsightTegra) {      this->WriteNsightTegraConfigurationValues(e1, c);    } else if (this->Android) {      this->WriteAndroidConfigurationValues(e1, c);    }  }}void cmVisualStudio10TargetGenerator::WriteCEDebugProjectConfigurationValues(  Elem& e0){  if (!this->GlobalGenerator->TargetsWindowsCE()) {    return;  }  cmProp additionalFiles =    this->GeneratorTarget->GetProperty("DEPLOYMENT_ADDITIONAL_FILES");  cmProp remoteDirectory =    this->GeneratorTarget->GetProperty("DEPLOYMENT_REMOTE_DIRECTORY");  if (!(additionalFiles || remoteDirectory)) {    return;  }  for (std::string const& c : this->Configurations) {    Elem e1(e0, "PropertyGroup");    e1.Attribute("Condition", this->CalcCondition(c));    if (remoteDirectory) {      e1.Element("RemoteDirectory", *remoteDirectory);    }    if (additionalFiles) {      e1.Element("CEAdditionalFiles", *additionalFiles);    }  }}void cmVisualStudio10TargetGenerator::WriteMSToolConfigurationValues(  Elem& e1, std::string const& config){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  const char* mfcFlag = this->Makefile->GetDefinition("CMAKE_MFC_FLAG");  if (mfcFlag) {    std::string const mfcFlagValue = mfcFlag;    std::string useOfMfcValue = "false";    if (this->GeneratorTarget->GetType() <= cmStateEnums::OBJECT_LIBRARY) {      if (mfcFlagValue == "1") {        useOfMfcValue = "Static";      } else if (mfcFlagValue == "2") {        useOfMfcValue = "Dynamic";      }    }    e1.Element("UseOfMfc", useOfMfcValue);  }  if ((this->GeneratorTarget->GetType() <= cmStateEnums::OBJECT_LIBRARY &&       this->ClOptions[config]->UsingUnicode()) ||      this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_COMPONENT") ||      this->GlobalGenerator->TargetsWindowsPhone() ||      this->GlobalGenerator->TargetsWindowsStore() ||      this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_EXTENSIONS")) {    e1.Element("CharacterSet", "Unicode");  } else if (this->GeneratorTarget->GetType() <=               cmStateEnums::OBJECT_LIBRARY &&             this->ClOptions[config]->UsingSBCS()) {    e1.Element("CharacterSet", "NotSet");  } else {    e1.Element("CharacterSet", "MultiByte");  }  if (cmProp projectToolsetOverride =        this->GeneratorTarget->GetProperty("VS_PLATFORM_TOOLSET")) {    e1.Element("PlatformToolset", *projectToolsetOverride);  } else if (const char* toolset = gg->GetPlatformToolset()) {    e1.Element("PlatformToolset", toolset);  }  if (this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_COMPONENT") ||      this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_EXTENSIONS")) {    e1.Element("WindowsAppContainer", "true");  }  if (this->IPOEnabledConfigurations.count(config) > 0) {    e1.Element("WholeProgramOptimization", "true");  }  {    auto s = this->SpectreMitigation.find(config);    if (s != this->SpectreMitigation.end()) {      e1.Element("SpectreMitigation", s->second);    }  }}void cmVisualStudio10TargetGenerator::WriteMSToolConfigurationValuesManaged(  Elem& e1, std::string const& config){  if (this->GeneratorTarget->GetType() > cmStateEnums::OBJECT_LIBRARY) {    return;  }  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  Options& o = *(this->ClOptions[config]);  if (o.IsDebug()) {    e1.Element("DebugSymbols", "true");    e1.Element("DefineDebug", "true");  }  std::string outDir = this->GeneratorTarget->GetDirectory(config) + "/";  ConvertToWindowsSlash(outDir);  e1.Element("OutputPath", outDir);  if (o.HasFlag("Platform")) {    e1.Element("PlatformTarget", o.GetFlag("Platform"));    o.RemoveFlag("Platform");  }  if (cmProp projectToolsetOverride =        this->GeneratorTarget->GetProperty("VS_PLATFORM_TOOLSET")) {    e1.Element("PlatformToolset", *projectToolsetOverride);  } else if (const char* toolset = gg->GetPlatformToolset()) {    e1.Element("PlatformToolset", toolset);  }  std::string postfixName =    cmStrCat(cmSystemTools::UpperCase(config), "_POSTFIX");  std::string assemblyName = this->GeneratorTarget->GetOutputName(    config, cmStateEnums::RuntimeBinaryArtifact);  if (cmProp postfix = this->GeneratorTarget->GetProperty(postfixName)) {    assemblyName += *postfix;  }  e1.Element("AssemblyName", assemblyName);  if (cmStateEnums::EXECUTABLE == this->GeneratorTarget->GetType()) {    e1.Element("StartAction", "Program");    e1.Element("StartProgram", outDir + assemblyName + ".exe");  }  OptionsHelper oh(o, e1);  oh.OutputFlagMap();}//----------------------------------------------------------------------------void cmVisualStudio10TargetGenerator::WriteNsightTegraConfigurationValues(  Elem& e1, std::string const&){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  const char* toolset = gg->GetPlatformToolset();  e1.Element("NdkToolchainVersion", toolset ? toolset : "Default");  if (cmProp minApi = this->GeneratorTarget->GetProperty("ANDROID_API_MIN")) {    e1.Element("AndroidMinAPI", "android-" + *minApi);  }  if (cmProp api = this->GeneratorTarget->GetProperty("ANDROID_API")) {    e1.Element("AndroidTargetAPI", "android-" + *api);  }  if (cmProp cpuArch = this->GeneratorTarget->GetProperty("ANDROID_ARCH")) {    e1.Element("AndroidArch", *cpuArch);  }  if (cmProp stlType =        this->GeneratorTarget->GetProperty("ANDROID_STL_TYPE")) {    e1.Element("AndroidStlType", *stlType);  }}void cmVisualStudio10TargetGenerator::WriteAndroidConfigurationValues(  Elem& e1, std::string const&){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  if (cmProp projectToolsetOverride =        this->GeneratorTarget->GetProperty("VS_PLATFORM_TOOLSET")) {    e1.Element("PlatformToolset", *projectToolsetOverride);  } else if (const char* toolset = gg->GetPlatformToolset()) {    e1.Element("PlatformToolset", toolset);  }  if (cmProp stlType =        this->GeneratorTarget->GetProperty("ANDROID_STL_TYPE")) {    if (*stlType != "none") {      e1.Element("UseOfStl", *stlType);    }  }}void cmVisualStudio10TargetGenerator::WriteCustomCommands(Elem& e0){  this->CSharpCustomCommandNames.clear();  cmSourceFile const* srcCMakeLists =    this->LocalGenerator->CreateVCProjBuildRule();  for (cmGeneratorTarget::AllConfigSource const& si :       this->GeneratorTarget->GetAllConfigSources()) {    if (si.Source == srcCMakeLists) {      // Skip explicit reference to CMakeLists.txt source.      continue;    }    this->WriteCustomCommand(e0, si.Source);  }  // Add CMakeLists.txt file with rule to re-run CMake for user convenience.  if (this->GeneratorTarget->GetType() != cmStateEnums::GLOBAL_TARGET &&      this->GeneratorTarget->GetName() != CMAKE_CHECK_BUILD_SYSTEM_TARGET) {    if (srcCMakeLists) {      // Write directly rather than through WriteCustomCommand because      // we do not want the de-duplication and it has no dependencies.      if (cmCustomCommand const* command = srcCMakeLists->GetCustomCommand()) {        this->WriteCustomRule(e0, srcCMakeLists, *command);      }    }  }}void cmVisualStudio10TargetGenerator::WriteCustomCommand(  Elem& e0, cmSourceFile const* sf){  if (this->LocalGenerator->GetSourcesVisited(this->GeneratorTarget)        .insert(sf)        .second) {    if (std::vector<cmSourceFile*> const* depends =          this->GeneratorTarget->GetSourceDepends(sf)) {      for (cmSourceFile const* di : *depends) {        this->WriteCustomCommand(e0, di);      }    }    if (cmCustomCommand const* command = sf->GetCustomCommand()) {      // C# projects write their <Target> within WriteCustomRule()      this->WriteCustomRule(e0, sf, *command);    }  }}void cmVisualStudio10TargetGenerator::WriteCustomRule(  Elem& e0, cmSourceFile const* source, cmCustomCommand const& command){  std::string sourcePath = source->GetFullPath();  // VS 10 will always rebuild a custom command attached to a .rule  // file that doesn't exist so create the file explicitly.  if (source->GetPropertyAsBool("__CMAKE_RULE")) {    if (!cmSystemTools::FileExists(sourcePath)) {      // Make sure the path exists for the file      std::string path = cmSystemTools::GetFilenamePath(sourcePath);      cmSystemTools::MakeDirectory(path);      cmsys::ofstream fout(sourcePath.c_str());      if (fout) {        fout << "# generated from CMake\n";        fout.flush();        fout.close();        // Force given file to have a very old timestamp, thus        // preventing dependent rebuilds.        this->ForceOld(sourcePath);      } else {        std::string error =          cmStrCat("Could not create file: [", sourcePath, "]  ");        cmSystemTools::Error(error + cmSystemTools::GetLastSystemError());      }    }  }  cmLocalVisualStudio7Generator* lg = this->LocalGenerator;  std::unique_ptr<Elem> spe1;  std::unique_ptr<Elem> spe2;  if (this->ProjectType != csproj) {    spe1 = cm::make_unique<Elem>(e0, "ItemGroup");    spe2 = cm::make_unique<Elem>(*spe1, "CustomBuild");    this->WriteSource(*spe2, source);    spe2->SetHasElements();    if (command.GetStdPipesUTF8()) {      this->WriteStdOutEncodingUtf8(*spe2);    }  } else {    Elem e1(e0, "ItemGroup");    Elem e2(e1, "None");    this->WriteSource(e2, source);    e2.SetHasElements();  }  for (std::string const& c : this->Configurations) {    cmCustomCommandGenerator ccg(command, c, lg);    std::string comment = lg->ConstructComment(ccg);    comment = cmVS10EscapeComment(comment);    std::string script = lg->ConstructScript(ccg);    bool symbolic = false;    // input files for custom command    std::stringstream additional_inputs;    {      const char* sep = "";      if (this->ProjectType == csproj) {        // csproj files do not attach the command to a specific file        // so the primary input must be listed explicitly.        additional_inputs << source->GetFullPath();        sep = ";";      }      // Avoid listing an input more than once.      std::set<std::string> unique_inputs;      // The source is either implicit an input or has been added above.      unique_inputs.insert(source->GetFullPath());      for (std::string const& d : ccg.GetDepends()) {        std::string dep;        if (lg->GetRealDependency(d, c, dep)) {          if (!unique_inputs.insert(dep).second) {            // already listed            continue;          }          ConvertToWindowsSlash(dep);          additional_inputs << sep << dep;          sep = ";";          if (!symbolic) {            if (cmSourceFile* sf = this->Makefile->GetSource(                  dep, cmSourceFileLocationKind::Known)) {              symbolic = sf->GetPropertyAsBool("SYMBOLIC");            }          }        }      }      if (this->ProjectType != csproj) {        additional_inputs << sep << "%(AdditionalInputs)";      }    }    // output files for custom command    std::stringstream outputs;    {      const char* sep = "";      for (std::string const& o : ccg.GetOutputs()) {        std::string out = o;        ConvertToWindowsSlash(out);        outputs << sep << out;        sep = ";";        if (!symbolic) {          if (cmSourceFile* sf = this->Makefile->GetSource(                o, cmSourceFileLocationKind::Known)) {            symbolic = sf->GetPropertyAsBool("SYMBOLIC");          }        }      }    }    if (this->ProjectType == csproj) {      std::string name = "CustomCommand_" + c + "_" +        cmSystemTools::ComputeStringMD5(sourcePath);      this->WriteCustomRuleCSharp(e0, c, name, script, additional_inputs.str(),                                  outputs.str(), comment);    } else {      this->WriteCustomRuleCpp(*spe2, c, script, additional_inputs.str(),                               outputs.str(), comment, symbolic);    }  }}void cmVisualStudio10TargetGenerator::WriteCustomRuleCpp(  Elem& e2, std::string const& config, std::string const& script,  std::string const& additional_inputs, std::string const& outputs,  std::string const& comment, bool symbolic){  const std::string cond = this->CalcCondition(config);  e2.WritePlatformConfigTag("Message", cond, comment);  e2.WritePlatformConfigTag("Command", cond, script);  e2.WritePlatformConfigTag("AdditionalInputs", cond, additional_inputs);  e2.WritePlatformConfigTag("Outputs", cond, outputs);  if (this->LocalGenerator->GetVersion() >      cmGlobalVisualStudioGenerator::VS10) {    // VS >= 11 let us turn off linking of custom command outputs.    e2.WritePlatformConfigTag("LinkObjects", cond, "false");  }  if (symbolic &&      this->LocalGenerator->GetVersion() >=        cmGlobalVisualStudioGenerator::VS16) {    // VS >= 16.4 warn if outputs are not created, but one of our    // outputs is marked SYMBOLIC and not expected to be created.    e2.WritePlatformConfigTag("VerifyInputsAndOutputsExist", cond, "false");  }}void cmVisualStudio10TargetGenerator::WriteCustomRuleCSharp(  Elem& e0, std::string const& config, std::string const& name,  std::string const& script, std::string const& inputs,  std::string const& outputs, std::string const& comment){  this->CSharpCustomCommandNames.insert(name);  Elem e1(e0, "Target");  e1.Attribute("Condition", this->CalcCondition(config));  e1.S << "\n    Name=\"" << name << "\"";  e1.S << "\n    Inputs=\"" << cmVS10EscapeAttr(inputs) << "\"";  e1.S << "\n    Outputs=\"" << cmVS10EscapeAttr(outputs) << "\"";  if (!comment.empty()) {    Elem(e1, "Exec").Attribute("Command", "echo " + comment);  }  Elem(e1, "Exec").Attribute("Command", script);}std::string cmVisualStudio10TargetGenerator::ConvertPath(  std::string const& path, bool forceRelative){  return forceRelative    ? cmSystemTools::RelativePath(        this->LocalGenerator->GetCurrentBinaryDirectory(), path)    : path;}static void ConvertToWindowsSlash(std::string& s){  // first convert all of the slashes  for (auto& ch : s) {    if (ch == '/') {      ch = '\\';    }  }}void cmVisualStudio10TargetGenerator::WriteGroups(){  if (this->ProjectType == csproj) {    return;  }  // collect up group information  std::vector<cmSourceGroup> sourceGroups = this->Makefile->GetSourceGroups();  std::vector<cmGeneratorTarget::AllConfigSource> const& sources =    this->GeneratorTarget->GetAllConfigSources();  std::set<cmSourceGroup const*> groupsUsed;  for (cmGeneratorTarget::AllConfigSource const& si : sources) {    std::string const& source = si.Source->GetFullPath();    cmSourceGroup* sourceGroup =      this->Makefile->FindSourceGroup(source, sourceGroups);    groupsUsed.insert(sourceGroup);  }  if (cmSourceFile const* srcCMakeLists =        this->LocalGenerator->CreateVCProjBuildRule()) {    std::string const& source = srcCMakeLists->GetFullPath();    cmSourceGroup* sourceGroup =      this->Makefile->FindSourceGroup(source, sourceGroups);    groupsUsed.insert(sourceGroup);  }  this->AddMissingSourceGroups(groupsUsed, sourceGroups);  // Write out group file  std::string path = cmStrCat(    this->LocalGenerator->GetCurrentBinaryDirectory(), '/', this->Name,    computeProjectFileExtension(this->GeneratorTarget), ".filters");  cmGeneratedFileStream fout(path);  fout.SetCopyIfDifferent(true);  char magic[] = { char(0xEF), char(0xBB), char(0xBF) };  fout.write(magic, 3);  fout << "<?xml version=\"1.0\" encoding=\""       << this->GlobalGenerator->Encoding() << "\"?>";  {    Elem e0(fout, "Project");    e0.Attribute("ToolsVersion", this->GlobalGenerator->GetToolsVersion());    e0.Attribute("xmlns",                 "http://schemas.microsoft.com/developer/msbuild/2003");    for (auto const& ti : this->Tools) {      this->WriteGroupSources(e0, ti.first, ti.second, sourceGroups);    }    // Added files are images and the manifest.    if (!this->AddedFiles.empty()) {      Elem e1(e0, "ItemGroup");      e1.SetHasElements();      for (std::string const& oi : this->AddedFiles) {        std::string fileName =          cmSystemTools::LowerCase(cmSystemTools::GetFilenameName(oi));        if (fileName == "wmappmanifest.xml") {          Elem e2(e1, "XML");          e2.Attribute("Include", oi);          e2.Element("Filter", "Resource Files");        } else if (cmSystemTools::GetFilenameExtension(fileName) ==                   ".appxmanifest") {          Elem e2(e1, "AppxManifest");          e2.Attribute("Include", oi);          e2.Element("Filter", "Resource Files");        } else if (cmSystemTools::GetFilenameExtension(fileName) == ".pfx") {          Elem e2(e1, "None");          e2.Attribute("Include", oi);          e2.Element("Filter", "Resource Files");        } else {          Elem e2(e1, "Image");          e2.Attribute("Include", oi);          e2.Element("Filter", "Resource Files");        }      }    }    if (!this->ResxObjs.empty()) {      Elem e1(e0, "ItemGroup");      for (cmSourceFile const* oi : this->ResxObjs) {        std::string obj = oi->GetFullPath();        ConvertToWindowsSlash(obj);        Elem e2(e1, "EmbeddedResource");        e2.Attribute("Include", obj);        e2.Element("Filter", "Resource Files");      }    }    {      Elem e1(e0, "ItemGroup");      e1.SetHasElements();      std::vector<cmSourceGroup const*> groupsVec(groupsUsed.begin(),                                                  groupsUsed.end());      std::sort(groupsVec.begin(), groupsVec.end(),                [](cmSourceGroup const* l, cmSourceGroup const* r) {                  return l->GetFullName() < r->GetFullName();                });      for (cmSourceGroup const* sg : groupsVec) {        std::string const& name = sg->GetFullName();        if (!name.empty()) {          std::string guidName = "SG_Filter_" + name;          std::string guid = this->GlobalGenerator->GetGUID(guidName);          Elem e2(e1, "Filter");          e2.Attribute("Include", name);          e2.Element("UniqueIdentifier", "{" + guid + "}");        }      }      if (!this->ResxObjs.empty() || !this->AddedFiles.empty()) {        std::string guidName = "SG_Filter_Resource Files";        std::string guid = this->GlobalGenerator->GetGUID(guidName);        Elem e2(e1, "Filter");        e2.Attribute("Include", "Resource Files");        e2.Element("UniqueIdentifier", "{" + guid + "}");        e2.Element("Extensions",                   "rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;"                   "gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms");      }    }  }  fout << '\n';  if (fout.Close()) {    this->GlobalGenerator->FileReplacedDuringGenerate(path);  }}// Add to groupsUsed empty source groups that have non-empty children.void cmVisualStudio10TargetGenerator::AddMissingSourceGroups(  std::set<cmSourceGroup const*>& groupsUsed,  const std::vector<cmSourceGroup>& allGroups){  for (cmSourceGroup const& current : allGroups) {    std::vector<cmSourceGroup> const& children = current.GetGroupChildren();    if (children.empty()) {      continue; // the group is really empty    }    this->AddMissingSourceGroups(groupsUsed, children);    if (groupsUsed.count(¤t) > 0) {      continue; // group has already been added to set    }    // check if it least one of the group's descendants is not empty    // (at least one child must already have been added)    auto child_it = children.begin();    while (child_it != children.end()) {      if (groupsUsed.count(&(*child_it)) > 0) {        break; // found a child that was already added => add current group too      }      child_it++;    }    if (child_it == children.end()) {      continue; // no descendants have source files => ignore this group    }    groupsUsed.insert(¤t);  }}void cmVisualStudio10TargetGenerator::WriteGroupSources(  Elem& e0, std::string const& name, ToolSources const& sources,  std::vector<cmSourceGroup>& sourceGroups){  Elem e1(e0, "ItemGroup");  e1.SetHasElements();  for (ToolSource const& s : sources) {    cmSourceFile const* sf = s.SourceFile;    std::string const& source = sf->GetFullPath();    cmSourceGroup* sourceGroup =      this->Makefile->FindSourceGroup(source, sourceGroups);    std::string const& filter = sourceGroup->GetFullName();    std::string path = this->ConvertPath(source, s.RelativePath);    ConvertToWindowsSlash(path);    Elem e2(e1, name);    e2.Attribute("Include", path);    if (!filter.empty()) {      e2.Element("Filter", filter);    }  }}void cmVisualStudio10TargetGenerator::WriteHeaderSource(Elem& e1,                                                        cmSourceFile const* sf){  std::string const& fileName = sf->GetFullPath();  Elem e2(e1, "ClInclude");  this->WriteSource(e2, sf);  if (this->IsResxHeader(fileName)) {    e2.Element("FileType", "CppForm");  } else if (this->IsXamlHeader(fileName)) {    e2.Element("DependentUpon",               fileName.substr(0, fileName.find_last_of(".")));  }}void cmVisualStudio10TargetGenerator::ParseSettingsProperty(  const std::string& settingsPropertyValue, ConfigToSettings& toolSettings){  if (!settingsPropertyValue.empty()) {    cmGeneratorExpression ge;    std::unique_ptr<cmCompiledGeneratorExpression> cge =      ge.Parse(settingsPropertyValue);    for (const std::string& config : this->Configurations) {      std::string evaluated = cge->Evaluate(this->LocalGenerator, config);      std::vector<std::string> settings = cmExpandedList(evaluated);      for (const std::string& setting : settings) {        const std::string::size_type assignment = setting.find('=');        if (assignment != std::string::npos) {          const std::string propName = setting.substr(0, assignment);          const std::string propValue = setting.substr(assignment + 1);          if (!propValue.empty()) {            toolSettings[config][propName] = propValue;          }        }      }    }  }}bool cmVisualStudio10TargetGenerator::PropertyIsSameInAllConfigs(  const ConfigToSettings& toolSettings, const std::string& propName){  std::string firstPropValue = "";  for (const auto& configToSettings : toolSettings) {    const std::unordered_map<std::string, std::string>& settings =      configToSettings.second;    if (firstPropValue.empty()) {      if (settings.find(propName) != settings.end()) {        firstPropValue = settings.find(propName)->second;      }    }    if (settings.find(propName) == settings.end()) {      return false;    }    if (settings.find(propName)->second != firstPropValue) {      return false;    }  }  return true;}void cmVisualStudio10TargetGenerator::WriteExtraSource(Elem& e1,                                                       cmSourceFile const* sf){  bool toolHasSettings = false;  const char* tool = "None";  std::string settingsGenerator;  std::string settingsLastGenOutput;  std::string sourceLink;  std::string subType;  std::string copyToOutDir;  std::string includeInVsix;  std::string ext = cmSystemTools::LowerCase(sf->GetExtension());  ConfigToSettings toolSettings;  for (const auto& config : this->Configurations) {    toolSettings[config];  }  if (this->ProjectType == csproj && !this->InSourceBuild) {    toolHasSettings = true;  }  if (ext == "hlsl") {    tool = "FXCompile";    // Figure out the type of shader compiler to use.    if (cmProp st = sf->GetProperty("VS_SHADER_TYPE")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["ShaderType"] = *st;      }    }    // Figure out which entry point to use if any    if (cmProp se = sf->GetProperty("VS_SHADER_ENTRYPOINT")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["EntryPointName"] = *se;      }    }    // Figure out which shader model to use if any    if (cmProp sm = sf->GetProperty("VS_SHADER_MODEL")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["ShaderModel"] = *sm;      }    }    // Figure out which output header file to use if any    if (cmProp ohf = sf->GetProperty("VS_SHADER_OUTPUT_HEADER_FILE")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["HeaderFileOutput"] = *ohf;      }    }    // Figure out which variable name to use if any    if (cmProp vn = sf->GetProperty("VS_SHADER_VARIABLE_NAME")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["VariableName"] = *vn;      }    }    // Figure out if there's any additional flags to use    if (cmProp saf = sf->GetProperty("VS_SHADER_FLAGS")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["AdditionalOptions"] = *saf;      }    }    // Figure out if debug information should be generated    if (cmProp sed = sf->GetProperty("VS_SHADER_ENABLE_DEBUG")) {      cmGeneratorExpression ge;      std::unique_ptr<cmCompiledGeneratorExpression> cge = ge.Parse(*sed);      for (const std::string& config : this->Configurations) {        std::string evaluated = cge->Evaluate(this->LocalGenerator, config);        if (!evaluated.empty()) {          toolSettings[config]["EnableDebuggingInformation"] =            cmIsOn(evaluated) ? "true" : "false";        }      }    }    // Figure out if optimizations should be disabled    if (cmProp sdo = sf->GetProperty("VS_SHADER_DISABLE_OPTIMIZATIONS")) {      cmGeneratorExpression ge;      std::unique_ptr<cmCompiledGeneratorExpression> cge = ge.Parse(*sdo);      for (const std::string& config : this->Configurations) {        std::string evaluated = cge->Evaluate(this->LocalGenerator, config);        if (!evaluated.empty()) {          toolSettings[config]["DisableOptimizations"] =            cmIsOn(evaluated) ? "true" : "false";        }      }    }    if (cmProp sofn = sf->GetProperty("VS_SHADER_OBJECT_FILE_NAME")) {      for (const std::string& config : this->Configurations) {        toolSettings[config]["ObjectFileOutput"] = *sofn;      }    }  } else if (ext == "jpg" || ext == "png") {    tool = "Image";  } else if (ext == "resw") {    tool = "PRIResource";  } else if (ext == "xml") {    tool = "XML";  } else if (ext == "natvis") {    tool = "Natvis";  } else if (ext == "settings") {    settingsLastGenOutput =      cmsys::SystemTools::GetFilenameName(sf->GetFullPath());    std::size_t pos = settingsLastGenOutput.find(".settings");    settingsLastGenOutput.replace(pos, 9, ".Designer.cs");    settingsGenerator = "SettingsSingleFileGenerator";    toolHasSettings = true;  } else if (ext == "vsixmanifest") {    subType = "Designer";  }  if (cmProp c = sf->GetProperty("VS_COPY_TO_OUT_DIR")) {    tool = "Content";    copyToOutDir = *c;    toolHasSettings = true;  }  if (sf->GetPropertyAsBool("VS_INCLUDE_IN_VSIX")) {    includeInVsix = "True";    tool = "Content";    toolHasSettings = true;  }  // Collect VS_CSHARP_* property values (if some are set)  std::map<std::string, std::string> sourceFileTags;  this->GetCSharpSourceProperties(sf, sourceFileTags);  if (this->NsightTegra) {    // Nsight Tegra needs specific file types to check up-to-dateness.    std::string name = cmSystemTools::LowerCase(sf->GetLocation().GetName());    if (name == "androidmanifest.xml" || name == "build.xml" ||        name == "proguard.cfg" || name == "proguard-project.txt" ||        ext == "properties") {      tool = "AndroidBuild";    } else if (ext == "java") {      tool = "JCompile";    } else if (ext == "asm" || ext == "s") {      tool = "ClCompile";    }  }  cmProp toolOverride = sf->GetProperty("VS_TOOL_OVERRIDE");  if (cmNonempty(toolOverride)) {    tool = toolOverride->c_str();  }  std::string deployContent;  std::string deployLocation;  if (this->GlobalGenerator->TargetsWindowsPhone() ||      this->GlobalGenerator->TargetsWindowsStore()) {    cmProp content = sf->GetProperty("VS_DEPLOYMENT_CONTENT");    if (cmNonempty(content)) {      toolHasSettings = true;      deployContent = *content;      cmProp location = sf->GetProperty("VS_DEPLOYMENT_LOCATION");      if (cmNonempty(location)) {        deployLocation = *location;      }    }  }  if (ParsedToolTargetSettings.find(tool) == ParsedToolTargetSettings.end()) {    cmProp toolTargetProperty = this->GeneratorTarget->Target->GetProperty(      "VS_SOURCE_SETTINGS_" + std::string(tool));    ConfigToSettings toolTargetSettings;    if (toolTargetProperty) {      ParseSettingsProperty(*toolTargetProperty, toolTargetSettings);    }    ParsedToolTargetSettings[tool] = toolTargetSettings;  }  for (const auto& configToSetting : ParsedToolTargetSettings[tool]) {    for (const auto& setting : configToSetting.second) {      toolSettings[configToSetting.first][setting.first] = setting.second;    }  }  if (cmProp p = sf->GetProperty("VS_SETTINGS")) {    ParseSettingsProperty(*p, toolSettings);  }  if (!toolSettings.empty()) {    toolHasSettings = true;  }  Elem e2(e1, tool);  this->WriteSource(e2, sf);  if (toolHasSettings) {    e2.SetHasElements();    std::vector<std::string> writtenSettings;    for (const auto& configSettings : toolSettings) {      for (const auto& setting : configSettings.second) {        if (std::find(writtenSettings.begin(), writtenSettings.end(),                      setting.first) != writtenSettings.end()) {          continue;        }        if (PropertyIsSameInAllConfigs(toolSettings, setting.first)) {          e2.Element(setting.first, setting.second);          writtenSettings.push_back(setting.first);        } else {          e2.WritePlatformConfigTag(setting.first,                                    "'$(Configuration)|$(Platform)'=='" +                                      configSettings.first + "|" +                                      this->Platform + "'",                                    setting.second);        }      }    }    if (!deployContent.empty()) {      cmGeneratorExpression ge;      std::unique_ptr<cmCompiledGeneratorExpression> cge =        ge.Parse(deployContent);      // Deployment location cannot be set on a configuration basis      if (!deployLocation.empty()) {        e2.Element("Link", deployLocation + "\\%(FileName)%(Extension)");      }      for (size_t i = 0; i != this->Configurations.size(); ++i) {        if (cge->Evaluate(this->LocalGenerator, this->Configurations[i]) ==            "1") {          e2.WritePlatformConfigTag("DeploymentContent",                                    "'$(Configuration)|$(Platform)'=='" +                                      this->Configurations[i] + "|" +                                      this->Platform + "'",                                    "true");        } else {          e2.WritePlatformConfigTag("ExcludedFromBuild",                                    "'$(Configuration)|$(Platform)'=='" +                                      this->Configurations[i] + "|" +                                      this->Platform + "'",                                    "true");        }      }    }    if (!settingsGenerator.empty()) {      e2.Element("Generator", settingsGenerator);    }    if (!settingsLastGenOutput.empty()) {      e2.Element("LastGenOutput", settingsLastGenOutput);    }    if (!subType.empty()) {      e2.Element("SubType", subType);    }    if (!copyToOutDir.empty()) {      e2.Element("CopyToOutputDirectory", copyToOutDir);    }    if (!includeInVsix.empty()) {      e2.Element("IncludeInVSIX", includeInVsix);    }    // write source file specific tags    this->WriteCSharpSourceProperties(e2, sourceFileTags);  }}void cmVisualStudio10TargetGenerator::WriteSource(Elem& e2,                                                  cmSourceFile const* sf){  // Visual Studio tools append relative paths to the current dir, as in:  //  //  c:\path\to\current\dir\..\..\..\relative\path\to\source.c  //  // and fail if this exceeds the maximum allowed path length.  Our path  // conversion uses full paths when possible to allow deeper trees.  // However, CUDA 8.0 msbuild rules fail on absolute paths so for CUDA  // we must use relative paths.  bool forceRelative = sf->GetLanguage() == "CUDA";  std::string sourceFile = this->ConvertPath(sf->GetFullPath(), forceRelative);  if (this->LocalGenerator->GetVersion() ==        cmGlobalVisualStudioGenerator::VS10 &&      cmSystemTools::FileIsFullPath(sourceFile)) {    // Normal path conversion resulted in a full path.  VS 10 (but not 11)    // refuses to show the property page in the IDE for a source file with a    // full path (not starting in a '.' or '/' AFAICT).  CMake <= 2.8.4 used a    // relative path but to allow deeper build trees CMake 2.8.[5678] used a    // full path except for custom commands.  Custom commands do not work    // without a relative path, but they do not seem to be involved in tools    // with the above behavior.  For other sources we now use a relative path    // when the combined path will not be too long so property pages appear.    std::string sourceRel = this->ConvertPath(sf->GetFullPath(), true);    size_t const maxLen = 250;    if (sf->GetCustomCommand() ||        ((this->LocalGenerator->GetCurrentBinaryDirectory().length() + 1 +          sourceRel.length()) <= maxLen)) {      forceRelative = true;      sourceFile = sourceRel;    } else {      this->GlobalGenerator->PathTooLong(this->GeneratorTarget, sf, sourceRel);    }  }  ConvertToWindowsSlash(sourceFile);  e2.Attribute("Include", sourceFile);  if (this->ProjectType == csproj && !this->InSourceBuild) {    // For out of source projects we have to provide a link (if not specified    // via property) for every source file (besides .cs files) otherwise they    // will not be visible in VS at all.    // First we check if the file is in a source group, then we check if the    // file path is relative to current source- or binary-dir, otherwise it is    // added with the plain filename without any path. This means the file will    // show up at root-level of the csproj (where CMakeLists.txt etc. are).    std::string link = this->GetCSharpSourceLink(sf);    if (link.empty())      link = cmsys::SystemTools::GetFilenameName(sf->GetFullPath());    e2.Element("Link", link);  }  ToolSource toolSource = { sf, forceRelative };  this->Tools[e2.Tag].push_back(toolSource);}void cmVisualStudio10TargetGenerator::WriteAllSources(Elem& e0){  if (this->GeneratorTarget->GetType() > cmStateEnums::UTILITY) {    return;  }  const bool haveUnityBuild =    this->GeneratorTarget->GetPropertyAsBool("UNITY_BUILD");  if (haveUnityBuild && this->GlobalGenerator->GetSupportsUnityBuilds()) {    Elem e1(e0, "PropertyGroup");    e1.Element("EnableUnitySupport", "true");  }  Elem e1(e0, "ItemGroup");  e1.SetHasElements();  std::vector<size_t> all_configs;  for (size_t ci = 0; ci < this->Configurations.size(); ++ci) {    all_configs.push_back(ci);  }  std::vector<cmGeneratorTarget::AllConfigSource> const& sources =    this->GeneratorTarget->GetAllConfigSources();  cmSourceFile const* srcCMakeLists =    this->LocalGenerator->CreateVCProjBuildRule();  for (cmGeneratorTarget::AllConfigSource const& si : sources) {    if (si.Source == srcCMakeLists) {      // Skip explicit reference to CMakeLists.txt source.      continue;    }    const char* tool = nullptr;    switch (si.Kind) {      case cmGeneratorTarget::SourceKindAppManifest:        tool = "AppxManifest";        break;      case cmGeneratorTarget::SourceKindCertificate:        tool = "None";        break;      case cmGeneratorTarget::SourceKindCustomCommand:        // Handled elsewhere.        break;      case cmGeneratorTarget::SourceKindExternalObject:        tool = "Object";        if (this->LocalGenerator->GetVersion() <            cmGlobalVisualStudioGenerator::VS11) {          // For VS == 10 we cannot use LinkObjects to avoid linking custom          // command outputs.  If an object file is generated in this target,          // then vs10 will use it in the build, and we have to list it as          // None instead of Object.          std::vector<cmSourceFile*> const* d =            this->GeneratorTarget->GetSourceDepends(si.Source);          if (d && !d->empty()) {            tool = "None";          }        }        break;      case cmGeneratorTarget::SourceKindExtra:        this->WriteExtraSource(e1, si.Source);        break;      case cmGeneratorTarget::SourceKindHeader:        this->WriteHeaderSource(e1, si.Source);        break;      case cmGeneratorTarget::SourceKindIDL:        tool = "Midl";        break;      case cmGeneratorTarget::SourceKindManifest:        // Handled elsewhere.        break;      case cmGeneratorTarget::SourceKindModuleDefinition:        tool = "None";        break;      case cmGeneratorTarget::SourceKindUnityBatched:      case cmGeneratorTarget::SourceKindObjectSource: {        const std::string& lang = si.Source->GetLanguage();        if (lang == "C" || lang == "CXX") {          tool = "ClCompile";        } else if (lang == "ASM_MASM" &&                   this->GlobalGenerator->IsMasmEnabled()) {          tool = "MASM";        } else if (lang == "ASM_NASM" &&                   this->GlobalGenerator->IsNasmEnabled()) {          tool = "NASM";        } else if (lang == "RC") {          tool = "ResourceCompile";        } else if (lang == "CSharp") {          tool = "Compile";        } else if (lang == "CUDA" && this->GlobalGenerator->IsCudaEnabled()) {          tool = "CudaCompile";        } else {          tool = "None";        }      } break;      case cmGeneratorTarget::SourceKindResx:        this->ResxObjs.push_back(si.Source);        break;      case cmGeneratorTarget::SourceKindXaml:        this->XamlObjs.push_back(si.Source);        break;    }    if (tool) {      // Compute set of configurations to exclude, if any.      std::vector<size_t> const& include_configs = si.Configs;      std::vector<size_t> exclude_configs;      std::set_difference(all_configs.begin(), all_configs.end(),                          include_configs.begin(), include_configs.end(),                          std::back_inserter(exclude_configs));      Elem e2(e1, tool);      this->WriteSource(e2, si.Source);      bool useNativeUnityBuild = false;      if (haveUnityBuild && this->GlobalGenerator->GetSupportsUnityBuilds()) {        // Magic value taken from cmGlobalVisualStudioVersionedGenerator.cxx        static const std::string vs15 = "141";        std::string toolset =          this->GlobalGenerator->GetPlatformToolsetString();        cmSystemTools::ReplaceString(toolset, "v", "");        if (toolset.empty() ||            cmSystemTools::VersionCompareGreaterEq(toolset, vs15)) {          useNativeUnityBuild = true;        }      }      if (haveUnityBuild && strcmp(tool, "ClCompile") == 0 &&          si.Source->GetProperty("UNITY_SOURCE_FILE")) {        if (useNativeUnityBuild) {          e2.Attribute(            "IncludeInUnityFile",            si.Source->GetPropertyAsBool("SKIP_UNITY_BUILD_INCLUSION")              ? "false"              : "true");          e2.Attribute("CustomUnityFile", "true");          std::string unityDir = cmSystemTools::GetFilenamePath(            *si.Source->GetProperty("UNITY_SOURCE_FILE"));          e2.Attribute("UnityFilesDirectory", unityDir);        } else {          // Visual Studio versions prior to 2017 15.8 do not know about unity          // builds, thus we exclude the files alredy part of unity sources.          if (!si.Source->GetPropertyAsBool("SKIP_UNITY_BUILD_INCLUSION")) {            exclude_configs = si.Configs;          }        }      }      if (si.Kind == cmGeneratorTarget::SourceKindObjectSource) {        this->OutputSourceSpecificFlags(e2, si.Source);      }      if (si.Source->GetPropertyAsBool("SKIP_PRECOMPILE_HEADERS")) {        e2.Element("PrecompiledHeader", "NotUsing");      }      if (!exclude_configs.empty()) {        this->WriteExcludeFromBuild(e2, exclude_configs);      }    }  }  if (this->IsMissingFiles) {    this->WriteMissingFiles(e1);  }}void cmVisualStudio10TargetGenerator::OutputSourceSpecificFlags(  Elem& e2, cmSourceFile const* source){  cmSourceFile const& sf = *source;  std::string objectName;  if (this->GeneratorTarget->HasExplicitObjectName(&sf)) {    objectName = this->GeneratorTarget->GetObjectName(&sf);  }  std::string flags;  bool configDependentFlags = false;  std::string options;  bool configDependentOptions = false;  std::string defines;  bool configDependentDefines = false;  std::string includes;  bool configDependentIncludes = false;  if (cmProp cflags = sf.GetProperty("COMPILE_FLAGS")) {    configDependentFlags =      cmGeneratorExpression::Find(*cflags) != std::string::npos;    flags += *cflags;  }  if (cmProp coptions = sf.GetProperty("COMPILE_OPTIONS")) {    configDependentOptions =      cmGeneratorExpression::Find(*coptions) != std::string::npos;    options += *coptions;  }  if (cmProp cdefs = sf.GetProperty("COMPILE_DEFINITIONS")) {    configDependentDefines =      cmGeneratorExpression::Find(*cdefs) != std::string::npos;    defines += *cdefs;  }  if (cmProp cincludes = sf.GetProperty("INCLUDE_DIRECTORIES")) {    configDependentIncludes =      cmGeneratorExpression::Find(*cincludes) != std::string::npos;    includes += *cincludes;  }  // Force language if the file extension does not match.  // Note that MSVC treats the upper-case '.C' extension as C and not C++.  std::string const ext = sf.GetExtension();  std::string const extLang = ext == "C"    ? "C"    : this->GlobalGenerator->GetLanguageFromExtension(ext.c_str());  std::string lang = this->LocalGenerator->GetSourceFileLanguage(sf);  const char* compileAs = 0;  if (lang != extLang) {    if (lang == "CXX") {      // force a C++ file type      compileAs = "CompileAsCpp";    } else if (lang == "C") {      // force to c      compileAs = "CompileAsC";    }  }  bool noWinRT = this->TargetCompileAsWinRT && lang == "C";  // for the first time we need a new line if there is something  // produced here.  if (!objectName.empty()) {    if (lang == "CUDA") {      e2.Element("CompileOut", "$(IntDir)/" + objectName);    } else {      e2.Element("ObjectFileName", "$(IntDir)/" + objectName);    }  }  for (std::string const& config : this->Configurations) {    std::string configUpper = cmSystemTools::UpperCase(config);    std::string configDefines = defines;    std::string defPropName = cmStrCat("COMPILE_DEFINITIONS_", configUpper);    if (cmProp ccdefs = sf.GetProperty(defPropName)) {      if (!configDefines.empty()) {        configDefines += ";";      }      configDependentDefines |=        cmGeneratorExpression::Find(*ccdefs) != std::string::npos;      configDefines += *ccdefs;    }    // Add precompile headers compile options.    std::string customAndPchOptions = options;    const std::string pchSource =      this->GeneratorTarget->GetPchSource(config, lang);    if (!pchSource.empty() && !sf.GetProperty("SKIP_PRECOMPILE_HEADERS")) {      std::string pchOptions;      if (sf.GetFullPath() == pchSource) {        pchOptions =          this->GeneratorTarget->GetPchCreateCompileOptions(config, lang);      } else {        pchOptions =          this->GeneratorTarget->GetPchUseCompileOptions(config, lang);      }      customAndPchOptions = cmStrCat(customAndPchOptions, ';', pchOptions);    }    // if we have flags or defines for this config then    // use them    if (!flags.empty() || !options.empty() || !configDefines.empty() ||        !includes.empty() || compileAs || noWinRT ||        !customAndPchOptions.empty()) {      cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;      cmIDEFlagTable const* flagtable = nullptr;      const std::string& srclang = source->GetLanguage();      if (srclang == "C" || srclang == "CXX") {        flagtable = gg->GetClFlagTable();      } else if (srclang == "ASM_MASM" &&                 this->GlobalGenerator->IsMasmEnabled()) {        flagtable = gg->GetMasmFlagTable();      } else if (lang == "ASM_NASM" &&                 this->GlobalGenerator->IsNasmEnabled()) {        flagtable = gg->GetNasmFlagTable();      } else if (srclang == "RC") {        flagtable = gg->GetRcFlagTable();      } else if (srclang == "CSharp") {        flagtable = gg->GetCSharpFlagTable();      }      cmGeneratorExpressionInterpreter genexInterpreter(        this->LocalGenerator, config, this->GeneratorTarget, lang);      cmVS10GeneratorOptions clOptions(        this->LocalGenerator, cmVisualStudioGeneratorOptions::Compiler,        flagtable, this);      if (compileAs) {        clOptions.AddFlag("CompileAs", compileAs);      }      if (noWinRT) {        clOptions.AddFlag("CompileAsWinRT", "false");      }      if (configDependentFlags) {        clOptions.Parse(genexInterpreter.Evaluate(flags, "COMPILE_FLAGS"));      } else {        clOptions.Parse(flags);      }      if (!customAndPchOptions.empty()) {        std::string expandedOptions;        if (configDependentOptions) {          this->LocalGenerator->AppendCompileOptions(            expandedOptions,            genexInterpreter.Evaluate(customAndPchOptions, "COMPILE_OPTIONS"));        } else {          this->LocalGenerator->AppendCompileOptions(expandedOptions,                                                     customAndPchOptions);        }        clOptions.Parse(expandedOptions);      }      if (clOptions.HasFlag("DisableSpecificWarnings")) {        clOptions.AppendFlag("DisableSpecificWarnings",                             "%(DisableSpecificWarnings)");      }      if (clOptions.HasFlag("ForcedIncludeFiles")) {        clOptions.AppendFlag("ForcedIncludeFiles", "%(ForcedIncludeFiles)");      }      if (configDependentDefines) {        clOptions.AddDefines(          genexInterpreter.Evaluate(configDefines, "COMPILE_DEFINITIONS"));      } else {        clOptions.AddDefines(configDefines);      }      std::vector<std::string> includeList;      if (configDependentIncludes) {        this->LocalGenerator->AppendIncludeDirectories(          includeList,          genexInterpreter.Evaluate(includes, "INCLUDE_DIRECTORIES"), *source);      } else {        this->LocalGenerator->AppendIncludeDirectories(includeList, includes,                                                       *source);      }      clOptions.AddIncludes(includeList);      clOptions.SetConfiguration(config);      OptionsHelper oh(clOptions, e2);      oh.PrependInheritedString("AdditionalOptions");      oh.OutputAdditionalIncludeDirectories(lang);      oh.OutputFlagMap();      oh.OutputPreprocessorDefinitions(lang);    }  }  if (this->IsXamlSource(source->GetFullPath())) {    const std::string& fileName = source->GetFullPath();    e2.Element("DependentUpon",               fileName.substr(0, fileName.find_last_of(".")));  }  if (this->ProjectType == csproj) {    std::string f = source->GetFullPath();    using CsPropMap = std::map<std::string, std::string>;    CsPropMap sourceFileTags;    this->GetCSharpSourceProperties(&sf, sourceFileTags);    // write source file specific tags    if (!sourceFileTags.empty()) {      this->WriteCSharpSourceProperties(e2, sourceFileTags);    }  }}void cmVisualStudio10TargetGenerator::WriteExcludeFromBuild(  Elem& e2, std::vector<size_t> const& exclude_configs){  for (size_t ci : exclude_configs) {    e2.WritePlatformConfigTag("ExcludedFromBuild",                              "'$(Configuration)|$(Platform)'=='" +                                this->Configurations[ci] + "|" +                                this->Platform + "'",                              "true");  }}void cmVisualStudio10TargetGenerator::WritePathAndIncrementalLinkOptions(  Elem& e0){  cmStateEnums::TargetType ttype = this->GeneratorTarget->GetType();  if (ttype > cmStateEnums::GLOBAL_TARGET) {    return;  }  if (this->ProjectType == csproj) {    return;  }  Elem e1(e0, "PropertyGroup");  e1.Element("_ProjectFileVersion", "10.0.20506.1");  for (std::string const& config : this->Configurations) {    const std::string cond = this->CalcCondition(config);    if (ttype <= cmStateEnums::UTILITY) {      if (cmProp workingDir = this->GeneratorTarget->GetProperty(            "VS_DEBUGGER_WORKING_DIRECTORY")) {        std::string genWorkingDir = cmGeneratorExpression::Evaluate(          *workingDir, this->LocalGenerator, config);        e1.WritePlatformConfigTag("LocalDebuggerWorkingDirectory", cond,                                  genWorkingDir);      }      if (cmProp environment =            this->GeneratorTarget->GetProperty("VS_DEBUGGER_ENVIRONMENT")) {        std::string genEnvironment = cmGeneratorExpression::Evaluate(          *environment, this->LocalGenerator, config);        e1.WritePlatformConfigTag("LocalDebuggerEnvironment", cond,                                  genEnvironment);      }      if (cmProp debuggerCommand =            this->GeneratorTarget->GetProperty("VS_DEBUGGER_COMMAND")) {        std::string genDebuggerCommand = cmGeneratorExpression::Evaluate(          *debuggerCommand, this->LocalGenerator, config);        e1.WritePlatformConfigTag("LocalDebuggerCommand", cond,                                  genDebuggerCommand);      }      if (cmProp commandArguments = this->GeneratorTarget->GetProperty(            "VS_DEBUGGER_COMMAND_ARGUMENTS")) {        std::string genCommandArguments = cmGeneratorExpression::Evaluate(          *commandArguments, this->LocalGenerator, config);        e1.WritePlatformConfigTag("LocalDebuggerCommandArguments", cond,                                  genCommandArguments);      }    }    if (ttype >= cmStateEnums::UTILITY) {      e1.WritePlatformConfigTag(        "IntDir", cond, "$(Platform)\\$(Configuration)\\$(ProjectName)\\");    } else {      std::string intermediateDir = cmStrCat(        this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget), '/',        config, '/');      std::string outDir;      std::string targetNameFull;      if (ttype == cmStateEnums::OBJECT_LIBRARY) {        outDir = intermediateDir;        targetNameFull = cmStrCat(this->GeneratorTarget->GetName(), ".lib");      } else {        outDir = this->GeneratorTarget->GetDirectory(config) + "/";        targetNameFull = this->GeneratorTarget->GetFullName(config);      }      ConvertToWindowsSlash(intermediateDir);      ConvertToWindowsSlash(outDir);      e1.WritePlatformConfigTag("OutDir", cond, outDir);      e1.WritePlatformConfigTag("IntDir", cond, intermediateDir);      if (const char* sdkExecutableDirectories = this->Makefile->GetDefinition(            "CMAKE_VS_SDK_EXECUTABLE_DIRECTORIES")) {        e1.WritePlatformConfigTag("ExecutablePath", cond,                                  sdkExecutableDirectories);      }      if (const char* sdkIncludeDirectories = this->Makefile->GetDefinition(            "CMAKE_VS_SDK_INCLUDE_DIRECTORIES")) {        e1.WritePlatformConfigTag("IncludePath", cond, sdkIncludeDirectories);      }      if (const char* sdkReferenceDirectories = this->Makefile->GetDefinition(            "CMAKE_VS_SDK_REFERENCE_DIRECTORIES")) {        e1.WritePlatformConfigTag("ReferencePath", cond,                                  sdkReferenceDirectories);      }      if (const char* sdkLibraryDirectories = this->Makefile->GetDefinition(            "CMAKE_VS_SDK_LIBRARY_DIRECTORIES")) {        e1.WritePlatformConfigTag("LibraryPath", cond, sdkLibraryDirectories);      }      if (const char* sdkLibraryWDirectories = this->Makefile->GetDefinition(            "CMAKE_VS_SDK_LIBRARY_WINRT_DIRECTORIES")) {        e1.WritePlatformConfigTag("LibraryWPath", cond,                                  sdkLibraryWDirectories);      }      if (const char* sdkSourceDirectories =            this->Makefile->GetDefinition("CMAKE_VS_SDK_SOURCE_DIRECTORIES")) {        e1.WritePlatformConfigTag("SourcePath", cond, sdkSourceDirectories);      }      if (const char* sdkExcludeDirectories = this->Makefile->GetDefinition(            "CMAKE_VS_SDK_EXCLUDE_DIRECTORIES")) {        e1.WritePlatformConfigTag("ExcludePath", cond, sdkExcludeDirectories);      }      std::string name =        cmSystemTools::GetFilenameWithoutLastExtension(targetNameFull);      e1.WritePlatformConfigTag("TargetName", cond, name);      std::string ext =        cmSystemTools::GetFilenameLastExtension(targetNameFull);      if (ext.empty()) {        // An empty TargetExt causes a default extension to be used.        // A single "." appears to be treated as an empty extension.        ext = ".";      }      e1.WritePlatformConfigTag("TargetExt", cond, ext);      this->OutputLinkIncremental(e1, config);    }  }}void cmVisualStudio10TargetGenerator::OutputLinkIncremental(  Elem& e1, std::string const& configName){  if (!this->MSTools) {    return;  }  if (this->ProjectType == csproj) {    return;  }  // static libraries and things greater than modules do not need  // to set this option  if (this->GeneratorTarget->GetType() == cmStateEnums::STATIC_LIBRARY ||      this->GeneratorTarget->GetType() > cmStateEnums::MODULE_LIBRARY) {    return;  }  Options& linkOptions = *(this->LinkOptions[configName]);  const std::string cond = this->CalcCondition(configName);  if (this->IPOEnabledConfigurations.count(configName) == 0) {    const char* incremental = linkOptions.GetFlag("LinkIncremental");    e1.WritePlatformConfigTag("LinkIncremental", cond,                              (incremental ? incremental : "true"));  }  linkOptions.RemoveFlag("LinkIncremental");  const char* manifest = linkOptions.GetFlag("GenerateManifest");  e1.WritePlatformConfigTag("GenerateManifest", cond,                            (manifest ? manifest : "true"));  linkOptions.RemoveFlag("GenerateManifest");  // Some link options belong here.  Use them now and remove them so that  // WriteLinkOptions does not use them.  static const std::vector<std::string> flags{ "LinkDelaySign",                                               "LinkKeyFile" };  for (const std::string& flag : flags) {    if (const char* value = linkOptions.GetFlag(flag)) {      e1.WritePlatformConfigTag(flag, cond, value);      linkOptions.RemoveFlag(flag);    }  }}std::vector<std::string> cmVisualStudio10TargetGenerator::GetIncludes(  std::string const& config, std::string const& lang) const{  std::vector<std::string> includes;  this->LocalGenerator->GetIncludeDirectories(includes, this->GeneratorTarget,                                              lang, config);  for (std::string& i : includes) {    ConvertToWindowsSlash(i);  }  return includes;}bool cmVisualStudio10TargetGenerator::ComputeClOptions(){  for (std::string const& c : this->Configurations) {    if (!this->ComputeClOptions(c)) {      return false;    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeClOptions(  std::string const& configName){  // much of this was copied from here:  // copied from cmLocalVisualStudio7Generator.cxx 805  // TODO: Integrate code below with cmLocalVisualStudio7Generator.  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  std::unique_ptr<Options> pOptions;  switch (this->ProjectType) {    case vcxproj:      pOptions = cm::make_unique<Options>(        this->LocalGenerator, Options::Compiler, gg->GetClFlagTable());      break;    case csproj:      pOptions =        cm::make_unique<Options>(this->LocalGenerator, Options::CSharpCompiler,                                 gg->GetCSharpFlagTable());      break;  }  Options& clOptions = *pOptions;  std::string flags;  const std::string& linkLanguage =    this->GeneratorTarget->GetLinkerLanguage(configName);  if (linkLanguage.empty()) {    cmSystemTools::Error(      "CMake can not determine linker language for target: " + this->Name);    return false;  }  // Choose a language whose flags to use for ClCompile.  static const char* clLangs[] = { "CXX", "C", "Fortran" };  std::string langForClCompile;  if (this->ProjectType == csproj) {    langForClCompile = "CSharp";  } else if (cm::contains(clLangs, linkLanguage)) {    langForClCompile = linkLanguage;  } else {    std::set<std::string> languages;    this->GeneratorTarget->GetLanguages(languages, configName);    for (const char* l : clLangs) {      if (languages.count(l)) {        langForClCompile = l;        break;      }    }  }  this->LangForClCompile = langForClCompile;  if (!langForClCompile.empty()) {    this->LocalGenerator->AddLanguageFlags(flags, this->GeneratorTarget,                                           langForClCompile, configName);    this->LocalGenerator->AddCompileOptions(flags, this->GeneratorTarget,                                            langForClCompile, configName);  }  // Put the IPO enabled configurations into a set.  if (this->GeneratorTarget->IsIPOEnabled(linkLanguage, configName)) {    this->IPOEnabledConfigurations.insert(configName);  }  // Precompile Headers  std::string pchHeader =    this->GeneratorTarget->GetPchHeader(configName, linkLanguage);  if (this->MSTools && vcxproj == this->ProjectType && pchHeader.empty()) {    clOptions.AddFlag("PrecompiledHeader", "NotUsing");  }  // Get preprocessor definitions for this directory.  std::string defineFlags = this->Makefile->GetDefineFlags();  if (this->MSTools) {    if (this->ProjectType == vcxproj) {      clOptions.FixExceptionHandlingDefault();      if (this->GlobalGenerator->GetVersion() >=          cmGlobalVisualStudioGenerator::VS15) {        // Toolsets that come with VS 2017 may now enable UseFullPaths        // by default and there is no negative /FC option that projects        // can use to switch it back.  Older toolsets disable this by        // default anyway so this will not hurt them.  If the project        // is using an explicit /FC option then parsing flags will        // replace this setting with "true" below.        clOptions.AddFlag("UseFullPaths", "false");      }      clOptions.AddFlag("AssemblerListingLocation", "$(IntDir)");    }  }  // check for managed C++ assembly compiler flag. This overrides any  // /clr* compiler flags which may be defined in the flags variable(s).  if (this->ProjectType != csproj) {    // Warn if /clr was added manually. This should not be done    // anymore, because cmGeneratorTarget may not be aware that the    // target uses C++/CLI.    if (flags.find("/clr") != std::string::npos ||        defineFlags.find("/clr") != std::string::npos) {      if (configName == this->Configurations[0]) {        std::string message = "For the target \"" +          this->GeneratorTarget->GetName() +          "\" the /clr compiler flag was added manually. " +          "Set usage of C++/CLI by setting COMMON_LANGUAGE_RUNTIME "          "target property.";        this->Makefile->IssueMessage(MessageType::WARNING, message);      }    }    if (cmProp clr =          this->GeneratorTarget->GetProperty("COMMON_LANGUAGE_RUNTIME")) {      std::string clrString = *clr;      if (!clrString.empty()) {        clrString = ":" + clrString;      }      flags += " /clr" + clrString;    }  }  clOptions.Parse(flags);  clOptions.Parse(defineFlags);  std::vector<std::string> targetDefines;  switch (this->ProjectType) {    case vcxproj:      if (!langForClCompile.empty()) {        this->GeneratorTarget->GetCompileDefinitions(targetDefines, configName,                                                     langForClCompile);      }      break;    case csproj:      this->GeneratorTarget->GetCompileDefinitions(targetDefines, configName,                                                   "CSharp");      cm::erase_if(targetDefines, [](std::string const& def) {        return def.find('=') != std::string::npos;      });      break;  }  clOptions.AddDefines(targetDefines);  if (this->ProjectType == csproj) {    clOptions.AppendFlag("DefineConstants", targetDefines);  }  // Get includes for this target  if (!this->LangForClCompile.empty()) {    clOptions.AddIncludes(      this->GetIncludes(configName, this->LangForClCompile));  }  if (this->MSTools) {    clOptions.SetVerboseMakefile(      this->Makefile->IsOn("CMAKE_VERBOSE_MAKEFILE"));  }  // Add a definition for the configuration name.  std::string configDefine = cmStrCat("CMAKE_INTDIR=\"", configName, '"');  clOptions.AddDefine(configDefine);  if (const std::string* exportMacro =        this->GeneratorTarget->GetExportMacro()) {    clOptions.AddDefine(*exportMacro);  }  if (this->MSTools) {    // If we have the VS_WINRT_COMPONENT set then force Compile as WinRT    if (this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_COMPONENT")) {      clOptions.AddFlag("CompileAsWinRT", "true");      // For WinRT components, add the _WINRT_DLL define to produce a lib      if (this->GeneratorTarget->GetType() == cmStateEnums::SHARED_LIBRARY ||          this->GeneratorTarget->GetType() == cmStateEnums::MODULE_LIBRARY) {        clOptions.AddDefine("_WINRT_DLL");      }    } else if (this->GlobalGenerator->TargetsWindowsStore() ||               this->GlobalGenerator->TargetsWindowsPhone() ||               this->Makefile->IsOn("CMAKE_VS_WINRT_BY_DEFAULT")) {      if (!clOptions.IsWinRt()) {        clOptions.AddFlag("CompileAsWinRT", "false");      }    }    if (const char* winRT = clOptions.GetFlag("CompileAsWinRT")) {      if (cmIsOn(winRT)) {        this->TargetCompileAsWinRT = true;      }    }  }  if (this->ProjectType != csproj && clOptions.IsManaged()) {    this->Managed = true;    std::string managedType = clOptions.GetFlag("CompileAsManaged");    if (managedType == "Safe" || managedType == "Pure") {      // force empty calling convention if safe clr is used      clOptions.AddFlag("CallingConvention", "");    }    // The default values of these flags are incompatible to    // managed assemblies. We have to force valid values if    // the target is a managed C++ target.    clOptions.AddFlag("ExceptionHandling", "Async");    clOptions.AddFlag("BasicRuntimeChecks", "Default");  }  if (this->ProjectType == csproj) {    // /nowin32manifest overrides /win32manifest: parameter    if (clOptions.HasFlag("NoWin32Manifest")) {      clOptions.RemoveFlag("ApplicationManifest");    }  }  if (const char* s = clOptions.GetFlag("SpectreMitigation")) {    this->SpectreMitigation[configName] = s;    clOptions.RemoveFlag("SpectreMitigation");  }  this->ClOptions[configName] = std::move(pOptions);  return true;}void cmVisualStudio10TargetGenerator::WriteClOptions(  Elem& e1, std::string const& configName){  Options& clOptions = *(this->ClOptions[configName]);  if (this->ProjectType == csproj) {    return;  }  Elem e2(e1, "ClCompile");  OptionsHelper oh(clOptions, e2);  oh.PrependInheritedString("AdditionalOptions");  oh.OutputAdditionalIncludeDirectories(this->LangForClCompile);  oh.OutputFlagMap();  oh.OutputPreprocessorDefinitions(this->LangForClCompile);  if (this->NsightTegra) {    if (cmProp processMax =          this->GeneratorTarget->GetProperty("ANDROID_PROCESS_MAX")) {      e2.Element("ProcessMax", *processMax);    }  }  if (this->Android) {    e2.Element("ObjectFileName", "$(IntDir)%(filename).o");  } else if (this->MSTools) {    cmsys::RegularExpression clangToolset("v[0-9]+_clang_.*");    const char* toolset = this->GlobalGenerator->GetPlatformToolset();    if (toolset && clangToolset.find(toolset)) {      e2.Element("ObjectFileName", "$(IntDir)%(filename).obj");    } else {      e2.Element("ObjectFileName", "$(IntDir)");    }    // If not in debug mode, write the DebugInformationFormat field    // without value so PDBs don't get generated uselessly. Each tag    // goes on its own line because Visual Studio corrects it this    // way when saving the project after CMake generates it.    if (!clOptions.IsDebug()) {      Elem e3(e2, "DebugInformationFormat");      e3.SetHasElements();    }    // Specify the compiler program database file if configured.    std::string pdb = this->GeneratorTarget->GetCompilePDBPath(configName);    if (!pdb.empty()) {      if (this->GlobalGenerator->IsCudaEnabled()) {        // CUDA does not quote paths with spaces correctly when forwarding        // this to the host compiler.  Use a relative path to avoid spaces.        // FIXME: We can likely do this even when CUDA is not involved,        // but for now we will make a minimal change.        pdb = this->ConvertPath(pdb, true);      }      ConvertToWindowsSlash(pdb);      e2.Element("ProgramDataBaseFileName", pdb);    }    // add AdditionalUsingDirectories    if (this->AdditionalUsingDirectories.count(configName) > 0) {      std::string dirs;      for (auto u : this->AdditionalUsingDirectories[configName]) {        if (!dirs.empty()) {          dirs.append(";");        }        dirs.append(u);      }      e2.Element("AdditionalUsingDirectories", dirs);    }  }}bool cmVisualStudio10TargetGenerator::ComputeRcOptions(){  for (std::string const& c : this->Configurations) {    if (!this->ComputeRcOptions(c)) {      return false;    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeRcOptions(  std::string const& configName){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  auto pOptions = cm::make_unique<Options>(    this->LocalGenerator, Options::ResourceCompiler, gg->GetRcFlagTable());  Options& rcOptions = *pOptions;  std::string CONFIG = cmSystemTools::UpperCase(configName);  std::string rcConfigFlagsVar = "CMAKE_RC_FLAGS_" + CONFIG;  std::string flags = this->Makefile->GetSafeDefinition("CMAKE_RC_FLAGS") +    " " + this->Makefile->GetSafeDefinition(rcConfigFlagsVar);  rcOptions.Parse(flags);  // For historical reasons, add the C preprocessor defines to RC.  Options& clOptions = *(this->ClOptions[configName]);  rcOptions.AddDefines(clOptions.GetDefines());  // Get includes for this target  rcOptions.AddIncludes(this->GetIncludes(configName, "RC"));  this->RcOptions[configName] = std::move(pOptions);  return true;}void cmVisualStudio10TargetGenerator::WriteRCOptions(  Elem& e1, std::string const& configName){  if (!this->MSTools) {    return;  }  Elem e2(e1, "ResourceCompile");  OptionsHelper rcOptions(*(this->RcOptions[configName]), e2);  rcOptions.OutputPreprocessorDefinitions("RC");  rcOptions.OutputAdditionalIncludeDirectories("RC");  rcOptions.PrependInheritedString("AdditionalOptions");  rcOptions.OutputFlagMap();}bool cmVisualStudio10TargetGenerator::ComputeCudaOptions(){  if (!this->GlobalGenerator->IsCudaEnabled()) {    return true;  }  for (std::string const& c : this->Configurations) {    if (!this->ComputeCudaOptions(c)) {      return false;    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeCudaOptions(  std::string const& configName){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  auto pOptions = cm::make_unique<Options>(    this->LocalGenerator, Options::CudaCompiler, gg->GetCudaFlagTable());  Options& cudaOptions = *pOptions;  // Get compile flags for CUDA in this directory.  std::string flags;  this->LocalGenerator->AddLanguageFlags(flags, this->GeneratorTarget, "CUDA",                                         configName);  this->LocalGenerator->AddCompileOptions(flags, this->GeneratorTarget, "CUDA",                                          configName);  // Get preprocessor definitions for this directory.  std::string defineFlags = this->Makefile->GetDefineFlags();  cudaOptions.Parse(flags);  cudaOptions.Parse(defineFlags);  cudaOptions.ParseFinish();  // If we haven't explicitly enabled GPU debug information  // explicitly disable it  if (!cudaOptions.HasFlag("GPUDebugInfo")) {    cudaOptions.AddFlag("GPUDebugInfo", "false");  }  // The extension on object libraries the CUDA gives isn't  // consistent with how MSVC generates object libraries for C+, so set  // the default to not have any extension  cudaOptions.AddFlag("CompileOut", "$(IntDir)%(Filename).obj");  bool notPtx = true;  if (this->GeneratorTarget->GetPropertyAsBool("CUDA_SEPARABLE_COMPILATION")) {    cudaOptions.AddFlag("GenerateRelocatableDeviceCode", "true");  } else if (this->GeneratorTarget->GetPropertyAsBool(               "CUDA_PTX_COMPILATION")) {    cudaOptions.AddFlag("NvccCompilation", "ptx");    // We drop the %(Extension) component as CMake expects all PTX files    // to not have the source file extension at all    cudaOptions.AddFlag("CompileOut", "$(IntDir)%(Filename).ptx");    notPtx = false;  }  if (notPtx &&      cmSystemTools::VersionCompareGreaterEq(        "8.0", this->GlobalGenerator->GetPlatformToolsetCudaString())) {    // Explicitly state that we want this file to be treated as a    // CUDA file no matter what the file extensions is    // This is only needed for < CUDA 9    cudaOptions.AppendFlagString("AdditionalOptions", "-x cu");  }  // Specify the compiler program database file if configured.  std::string pdb = this->GeneratorTarget->GetCompilePDBPath(configName);  if (!pdb.empty()) {    // CUDA does not make the directory if it is non-standard.    std::string const pdbDir = cmSystemTools::GetFilenamePath(pdb);    cmSystemTools::MakeDirectory(pdbDir);    if (cmSystemTools::VersionCompareGreaterEq(          "9.2", this->GlobalGenerator->GetPlatformToolsetCudaString())) {      // CUDA does not have a field for this and does not honor the      // ProgramDataBaseFileName field in ClCompile.  Work around this      // limitation by creating the directory and passing the flag ourselves.      pdb = this->ConvertPath(pdb, true);      ConvertToWindowsSlash(pdb);      std::string const clFd = "-Xcompiler=\"-Fd\\\"" + pdb + "\\\"\"";      cudaOptions.AppendFlagString("AdditionalOptions", clFd);    }  }  // CUDA automatically passes the proper '--machine' flag to nvcc  // for the current architecture, but does not reflect this default  // in the user-visible IDE settings.  Set it explicitly.  if (this->Platform == "x64") {    cudaOptions.AddFlag("TargetMachinePlatform", "64");  }  // Convert the host compiler options to the toolset's abstractions  // using a secondary flag table.  cudaOptions.ClearTables();  cudaOptions.AddTable(gg->GetCudaHostFlagTable());  cudaOptions.Reparse("AdditionalCompilerOptions");  // `CUDA 8.0.targets` places AdditionalCompilerOptions before nvcc!  // Pass them through -Xcompiler in AdditionalOptions instead.  if (const char* acoPtr = cudaOptions.GetFlag("AdditionalCompilerOptions")) {    std::string aco = acoPtr;    cudaOptions.RemoveFlag("AdditionalCompilerOptions");    if (!aco.empty()) {      aco = this->LocalGenerator->EscapeForShell(aco, false);      cudaOptions.AppendFlagString("AdditionalOptions", "-Xcompiler=" + aco);    }  }  cudaOptions.FixCudaCodeGeneration();  std::vector<std::string> targetDefines;  this->GeneratorTarget->GetCompileDefinitions(targetDefines, configName,                                               "CUDA");  cudaOptions.AddDefines(targetDefines);  // Add a definition for the configuration name.  std::string configDefine = cmStrCat("CMAKE_INTDIR=\"", configName, '"');  cudaOptions.AddDefine(configDefine);  if (const std::string* exportMacro =        this->GeneratorTarget->GetExportMacro()) {    cudaOptions.AddDefine(*exportMacro);  }  // Get includes for this target  cudaOptions.AddIncludes(this->GetIncludes(configName, "CUDA"));  cudaOptions.AddFlag("UseHostInclude", "false");  // Add runtime library selection flag.  std::string const& cudaRuntime =    this->GeneratorTarget->GetRuntimeLinkLibrary("CUDA", configName);  if (cudaRuntime == "STATIC") {    cudaOptions.AddFlag("CudaRuntime", "Static");  } else if (cudaRuntime == "SHARED") {    cudaOptions.AddFlag("CudaRuntime", "Shared");  } else if (cudaRuntime == "NONE") {    cudaOptions.AddFlag("CudaRuntime", "None");  }  this->CudaOptions[configName] = std::move(pOptions);  return true;}void cmVisualStudio10TargetGenerator::WriteCudaOptions(  Elem& e1, std::string const& configName){  if (!this->MSTools || !this->GlobalGenerator->IsCudaEnabled()) {    return;  }  Elem e2(e1, "CudaCompile");  OptionsHelper cudaOptions(*(this->CudaOptions[configName]), e2);  cudaOptions.OutputAdditionalIncludeDirectories("CUDA");  cudaOptions.OutputPreprocessorDefinitions("CUDA");  cudaOptions.PrependInheritedString("AdditionalOptions");  cudaOptions.OutputFlagMap();}bool cmVisualStudio10TargetGenerator::ComputeCudaLinkOptions(){  if (!this->GlobalGenerator->IsCudaEnabled()) {    return true;  }  for (std::string const& c : this->Configurations) {    if (!this->ComputeCudaLinkOptions(c)) {      return false;    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeCudaLinkOptions(  std::string const& configName){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  auto pOptions = cm::make_unique<Options>(    this->LocalGenerator, Options::CudaCompiler, gg->GetCudaFlagTable());  Options& cudaLinkOptions = *pOptions;  cmGeneratorTarget::DeviceLinkSetter setter(*this->GeneratorTarget);  // Determine if we need to do a device link  const bool doDeviceLinking = requireDeviceLinking(    *this->GeneratorTarget, *this->LocalGenerator, configName);  cudaLinkOptions.AddFlag("PerformDeviceLink",                          doDeviceLinking ? "true" : "false");  // Add extra flags for device linking  cudaLinkOptions.AppendFlagString(    "AdditionalOptions",    this->Makefile->GetSafeDefinition("_CMAKE_CUDA_EXTRA_FLAGS"));  cudaLinkOptions.AppendFlagString(    "AdditionalOptions",    this->Makefile->GetSafeDefinition("_CMAKE_CUDA_EXTRA_DEVICE_LINK_FLAGS"));  std::vector<std::string> linkOpts;  std::string linkFlags;  this->GeneratorTarget->GetLinkOptions(linkOpts, configName, "CUDA");  // LINK_OPTIONS are escaped.  this->LocalGenerator->AppendCompileOptions(linkFlags, linkOpts);  cudaLinkOptions.AppendFlagString("AdditionalOptions", linkFlags);  // For static libraries that have device linking enabled compute  // the  libraries  if (this->GeneratorTarget->GetType() == cmStateEnums::STATIC_LIBRARY &&      doDeviceLinking) {    cmComputeLinkInformation* pcli =      this->GeneratorTarget->GetLinkInformation(configName);    if (!pcli) {      cmSystemTools::Error(        "CMake can not compute cmComputeLinkInformation for target: " +        this->Name);      return false;    }    // Would like to use:    // cmLinkLineDeviceComputer computer(this->LocalGenerator,    //                                   this->LocalGenerator->GetStateSnapshot().GetDirectory());    // std::string computed_libs = computer.ComputeLinkLibraries(cli,    // std::string{}); but it outputs in "<libA> <libB>" format instead of    // "<libA>;<libB>"    // Note:    // Any modification of this algorithm should be reflected also in    // cmLinkLineDeviceComputer    cmComputeLinkInformation& cli = *pcli;    std::vector<std::string> libVec;    const std::string currentBinDir =      this->LocalGenerator->GetCurrentBinaryDirectory();    const auto& libs = cli.GetItems();    for (cmComputeLinkInformation::Item const& l : libs) {      if (l.Target) {        auto managedType = l.Target->GetManagedType(configName);        // Do not allow C# targets to be added to the LIB listing. LIB files        // are used for linking C++ dependencies. C# libraries do not have lib        // files. Instead, they compile down to C# reference libraries (DLL        // files). The        // `<ProjectReference>` elements added to the vcxproj are enough for        // the IDE to deduce the DLL file required by other C# projects that        // need its reference library.        if (managedType == cmGeneratorTarget::ManagedType::Managed) {          continue;        }        const auto type = l.Target->GetType();        bool skip = false;        switch (type) {          case cmStateEnums::SHARED_LIBRARY:          case cmStateEnums::MODULE_LIBRARY:          case cmStateEnums::INTERFACE_LIBRARY:            skip = true;            break;          case cmStateEnums::STATIC_LIBRARY:            skip = l.Target->GetPropertyAsBool("CUDA_RESOLVE_DEVICE_SYMBOLS");            break;          default:            break;        }        if (skip) {          continue;        }      }      if (l.IsPath) {        std::string path = this->LocalGenerator->MaybeConvertToRelativePath(          currentBinDir, l.Value.Value);        ConvertToWindowsSlash(path);        if (!cmVS10IsTargetsFile(l.Value.Value)) {          libVec.push_back(path);        }      } else {        libVec.push_back(l.Value.Value);      }    }    cudaLinkOptions.AddFlag("AdditionalDependencies", libVec);  }  this->CudaLinkOptions[configName] = std::move(pOptions);  return true;}void cmVisualStudio10TargetGenerator::WriteCudaLinkOptions(  Elem& e1, std::string const& configName){  if (this->GeneratorTarget->GetType() > cmStateEnums::MODULE_LIBRARY) {    return;  }  if (!this->MSTools || !this->GlobalGenerator->IsCudaEnabled()) {    return;  }  Elem e2(e1, "CudaLink");  OptionsHelper cudaLinkOptions(*(this->CudaLinkOptions[configName]), e2);  cudaLinkOptions.OutputFlagMap();}bool cmVisualStudio10TargetGenerator::ComputeMasmOptions(){  if (!this->GlobalGenerator->IsMasmEnabled()) {    return true;  }  for (std::string const& c : this->Configurations) {    if (!this->ComputeMasmOptions(c)) {      return false;    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeMasmOptions(  std::string const& configName){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  auto pOptions = cm::make_unique<Options>(    this->LocalGenerator, Options::MasmCompiler, gg->GetMasmFlagTable());  Options& masmOptions = *pOptions;  std::string flags;  this->LocalGenerator->AddLanguageFlags(flags, this->GeneratorTarget,                                         "ASM_MASM", configName);  masmOptions.Parse(flags);  // Get includes for this target  masmOptions.AddIncludes(this->GetIncludes(configName, "ASM_MASM"));  this->MasmOptions[configName] = std::move(pOptions);  return true;}void cmVisualStudio10TargetGenerator::WriteMasmOptions(  Elem& e1, std::string const& configName){  if (!this->MSTools || !this->GlobalGenerator->IsMasmEnabled()) {    return;  }  Elem e2(e1, "MASM");  // Preprocessor definitions and includes are shared with clOptions.  OptionsHelper clOptions(*(this->ClOptions[configName]), e2);  clOptions.OutputPreprocessorDefinitions("ASM_MASM");  OptionsHelper masmOptions(*(this->MasmOptions[configName]), e2);  masmOptions.OutputAdditionalIncludeDirectories("ASM_MASM");  masmOptions.PrependInheritedString("AdditionalOptions");  masmOptions.OutputFlagMap();}bool cmVisualStudio10TargetGenerator::ComputeNasmOptions(){  if (!this->GlobalGenerator->IsNasmEnabled()) {    return true;  }  for (std::string const& c : this->Configurations) {    if (!this->ComputeNasmOptions(c)) {      return false;    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeNasmOptions(  std::string const& configName){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  auto pOptions = cm::make_unique<Options>(    this->LocalGenerator, Options::NasmCompiler, gg->GetNasmFlagTable());  Options& nasmOptions = *pOptions;  std::string flags;  this->LocalGenerator->AddLanguageFlags(flags, this->GeneratorTarget,                                         "ASM_NASM", configName);  flags += " -f";  flags += this->Makefile->GetSafeDefinition("CMAKE_ASM_NASM_OBJECT_FORMAT");  nasmOptions.Parse(flags);  // Get includes for this target  nasmOptions.AddIncludes(this->GetIncludes(configName, "ASM_NASM"));  this->NasmOptions[configName] = std::move(pOptions);  return true;}void cmVisualStudio10TargetGenerator::WriteNasmOptions(  Elem& e1, std::string const& configName){  if (!this->GlobalGenerator->IsNasmEnabled()) {    return;  }  Elem e2(e1, "NASM");  std::vector<std::string> includes =    this->GetIncludes(configName, "ASM_NASM");  OptionsHelper nasmOptions(*(this->NasmOptions[configName]), e2);  nasmOptions.OutputAdditionalIncludeDirectories("ASM_NASM");  nasmOptions.OutputFlagMap();  nasmOptions.PrependInheritedString("AdditionalOptions");  nasmOptions.OutputPreprocessorDefinitions("ASM_NASM");  // Preprocessor definitions and includes are shared with clOptions.  OptionsHelper clOptions(*(this->ClOptions[configName]), e2);  clOptions.OutputPreprocessorDefinitions("ASM_NASM");}void cmVisualStudio10TargetGenerator::WriteLibOptions(  Elem& e1, std::string const& config){  if (this->GeneratorTarget->GetType() != cmStateEnums::STATIC_LIBRARY &&      this->GeneratorTarget->GetType() != cmStateEnums::OBJECT_LIBRARY) {    return;  }  const std::string& linkLanguage =    this->GeneratorTarget->GetLinkClosure(config)->LinkerLanguage;  std::string libflags;  this->LocalGenerator->GetStaticLibraryFlags(libflags, config, linkLanguage,                                              this->GeneratorTarget);  if (!libflags.empty()) {    Elem e2(e1, "Lib");    cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;    cmVS10GeneratorOptions libOptions(this->LocalGenerator,                                      cmVisualStudioGeneratorOptions::Linker,                                      gg->GetLibFlagTable(), this);    libOptions.Parse(libflags);    OptionsHelper oh(libOptions, e2);    oh.PrependInheritedString("AdditionalOptions");    oh.OutputFlagMap();  }  // We cannot generate metadata for static libraries.  WindowsPhone  // and WindowsStore tools look at GenerateWindowsMetadata in the  // Link tool options even for static libraries.  if (this->GlobalGenerator->TargetsWindowsPhone() ||      this->GlobalGenerator->TargetsWindowsStore()) {    Elem e2(e1, "Link");    e2.Element("GenerateWindowsMetadata", "false");  }}void cmVisualStudio10TargetGenerator::WriteManifestOptions(  Elem& e1, std::string const& config){  if (this->GeneratorTarget->GetType() != cmStateEnums::EXECUTABLE &&      this->GeneratorTarget->GetType() != cmStateEnums::SHARED_LIBRARY &&      this->GeneratorTarget->GetType() != cmStateEnums::MODULE_LIBRARY) {    return;  }  std::vector<cmSourceFile const*> manifest_srcs;  this->GeneratorTarget->GetManifests(manifest_srcs, config);  cmProp dpiAware = this->GeneratorTarget->GetProperty("VS_DPI_AWARE");  if (!manifest_srcs.empty() || dpiAware) {    Elem e2(e1, "Manifest");    if (!manifest_srcs.empty()) {      std::ostringstream oss;      for (cmSourceFile const* mi : manifest_srcs) {        std::string m = this->ConvertPath(mi->GetFullPath(), false);        ConvertToWindowsSlash(m);        oss << m << ";";      }      e2.Element("AdditionalManifestFiles", oss.str());    }    if (dpiAware) {      if (*dpiAware == "PerMonitor") {        e2.Element("EnableDpiAwareness", "PerMonitorHighDPIAware");      } else if (cmIsOn(*dpiAware)) {        e2.Element("EnableDpiAwareness", "true");      } else if (cmIsOff(*dpiAware)) {        e2.Element("EnableDpiAwareness", "false");      } else {        cmSystemTools::Error("Bad parameter for VS_DPI_AWARE: " + *dpiAware);      }    }  }}void cmVisualStudio10TargetGenerator::WriteAntBuildOptions(  Elem& e1, std::string const& configName){  // Look through the sources for AndroidManifest.xml and use  // its location as the root source directory.  std::string rootDir = this->LocalGenerator->GetCurrentSourceDirectory();  {    for (cmGeneratorTarget::AllConfigSource const& source :         this->GeneratorTarget->GetAllConfigSources()) {      if (source.Kind == cmGeneratorTarget::SourceKindExtra &&          "androidmanifest.xml" ==            cmSystemTools::LowerCase(source.Source->GetLocation().GetName())) {        rootDir = source.Source->GetLocation().GetDirectory();        break;      }    }  }  // Tell MSBuild to launch Ant.  Elem e2(e1, "AntBuild");  {    std::string antBuildPath = rootDir;    ConvertToWindowsSlash(antBuildPath);    e2.Element("AntBuildPath", antBuildPath);  }  if (this->GeneratorTarget->GetPropertyAsBool("ANDROID_SKIP_ANT_STEP")) {    e2.Element("SkipAntStep", "true");  }  if (this->GeneratorTarget->GetPropertyAsBool("ANDROID_PROGUARD")) {    e2.Element("EnableProGuard", "true");  }  if (cmProp proGuardConfigLocation =        this->GeneratorTarget->GetProperty("ANDROID_PROGUARD_CONFIG_PATH")) {    e2.Element("ProGuardConfigLocation", *proGuardConfigLocation);  }  if (cmProp securePropertiesLocation =        this->GeneratorTarget->GetProperty("ANDROID_SECURE_PROPS_PATH")) {    e2.Element("SecurePropertiesLocation", *securePropertiesLocation);  }  if (cmProp nativeLibDirectoriesExpression =        this->GeneratorTarget->GetProperty("ANDROID_NATIVE_LIB_DIRECTORIES")) {    std::string nativeLibDirs = cmGeneratorExpression::Evaluate(      *nativeLibDirectoriesExpression, this->LocalGenerator, configName);    e2.Element("NativeLibDirectories", nativeLibDirs);  }  if (cmProp nativeLibDependenciesExpression =        this->GeneratorTarget->GetProperty(          "ANDROID_NATIVE_LIB_DEPENDENCIES")) {    std::string nativeLibDeps = cmGeneratorExpression::Evaluate(      *nativeLibDependenciesExpression, this->LocalGenerator, configName);    e2.Element("NativeLibDependencies", nativeLibDeps);  }  if (cmProp javaSourceDir =        this->GeneratorTarget->GetProperty("ANDROID_JAVA_SOURCE_DIR")) {    e2.Element("JavaSourceDir", *javaSourceDir);  }  if (cmProp jarDirectoriesExpression =        this->GeneratorTarget->GetProperty("ANDROID_JAR_DIRECTORIES")) {    std::string jarDirectories = cmGeneratorExpression::Evaluate(      *jarDirectoriesExpression, this->LocalGenerator, configName);    e2.Element("JarDirectories", jarDirectories);  }  if (cmProp jarDeps =        this->GeneratorTarget->GetProperty("ANDROID_JAR_DEPENDENCIES")) {    e2.Element("JarDependencies", *jarDeps);  }  if (cmProp assetsDirectories =        this->GeneratorTarget->GetProperty("ANDROID_ASSETS_DIRECTORIES")) {    e2.Element("AssetsDirectories", *assetsDirectories);  }  {    std::string manifest_xml = rootDir + "/AndroidManifest.xml";    ConvertToWindowsSlash(manifest_xml);    e2.Element("AndroidManifestLocation", manifest_xml);  }  if (cmProp antAdditionalOptions =        this->GeneratorTarget->GetProperty("ANDROID_ANT_ADDITIONAL_OPTIONS")) {    e2.Element("AdditionalOptions",               *antAdditionalOptions + " %(AdditionalOptions)");  }}bool cmVisualStudio10TargetGenerator::ComputeLinkOptions(){  if (this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE ||      this->GeneratorTarget->GetType() == cmStateEnums::SHARED_LIBRARY ||      this->GeneratorTarget->GetType() == cmStateEnums::MODULE_LIBRARY) {    for (std::string const& c : this->Configurations) {      if (!this->ComputeLinkOptions(c)) {        return false;      }    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeLinkOptions(  std::string const& config){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  auto pOptions = cm::make_unique<Options>(    this->LocalGenerator, Options::Linker, gg->GetLinkFlagTable(), this);  Options& linkOptions = *pOptions;  cmGeneratorTarget::LinkClosure const* linkClosure =    this->GeneratorTarget->GetLinkClosure(config);  const std::string& linkLanguage = linkClosure->LinkerLanguage;  if (linkLanguage.empty()) {    cmSystemTools::Error(      "CMake can not determine linker language for target: " + this->Name);    return false;  }  std::string CONFIG = cmSystemTools::UpperCase(config);  const char* linkType = "SHARED";  if (this->GeneratorTarget->GetType() == cmStateEnums::MODULE_LIBRARY) {    linkType = "MODULE";  }  if (this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE) {    linkType = "EXE";  }  std::string flags;  std::string linkFlagVarBase = cmStrCat("CMAKE_", linkType, "_LINKER_FLAGS");  flags += " ";  flags += this->Makefile->GetRequiredDefinition(linkFlagVarBase);  std::string linkFlagVar = linkFlagVarBase + "_" + CONFIG;  flags += " ";  flags += this->Makefile->GetRequiredDefinition(linkFlagVar);  cmProp targetLinkFlags = this->GeneratorTarget->GetProperty("LINK_FLAGS");  if (targetLinkFlags) {    flags += " ";    flags += *targetLinkFlags;  }  std::string flagsProp = cmStrCat("LINK_FLAGS_", CONFIG);  if (cmProp flagsConfig = this->GeneratorTarget->GetProperty(flagsProp)) {    flags += " ";    flags += *flagsConfig;  }  std::vector<std::string> opts;  this->GeneratorTarget->GetLinkOptions(opts, config, linkLanguage);  // LINK_OPTIONS are escaped.  this->LocalGenerator->AppendCompileOptions(flags, opts);  cmComputeLinkInformation* pcli =    this->GeneratorTarget->GetLinkInformation(config);  if (!pcli) {    cmSystemTools::Error(      "CMake can not compute cmComputeLinkInformation for target: " +      this->Name);    return false;  }  cmComputeLinkInformation& cli = *pcli;  std::vector<std::string> libVec;  std::vector<std::string> vsTargetVec;  this->AddLibraries(cli, libVec, vsTargetVec, config);  std::string standardLibsVar =    cmStrCat("CMAKE_", linkLanguage, "_STANDARD_LIBRARIES");  std::string const& libs = this->Makefile->GetSafeDefinition(standardLibsVar);  cmSystemTools::ParseWindowsCommandLine(libs.c_str(), libVec);  linkOptions.AddFlag("AdditionalDependencies", libVec);  // Populate TargetsFileAndConfigsVec  for (std::string const& ti : vsTargetVec) {    this->AddTargetsFileAndConfigPair(ti, config);  }  std::vector<std::string> const& ldirs = cli.GetDirectories();  std::vector<std::string> linkDirs;  for (std::string const& d : ldirs) {    // first just full path    linkDirs.push_back(d);    // next path with configuration type Debug, Release, etc    linkDirs.push_back(d + "/$(Configuration)");  }  linkDirs.push_back("%(AdditionalLibraryDirectories)");  linkOptions.AddFlag("AdditionalLibraryDirectories", linkDirs);  cmGeneratorTarget::Names targetNames;  if (this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE) {    targetNames = this->GeneratorTarget->GetExecutableNames(config);  } else {    targetNames = this->GeneratorTarget->GetLibraryNames(config);  }  if (this->MSTools) {    if (this->GeneratorTarget->GetPropertyAsBool("WIN32_EXECUTABLE")) {      if (this->GlobalGenerator->TargetsWindowsCE()) {        linkOptions.AddFlag("SubSystem", "WindowsCE");        if (this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE) {          if (this->ClOptions[config]->UsingUnicode()) {            linkOptions.AddFlag("EntryPointSymbol", "wWinMainCRTStartup");          } else {            linkOptions.AddFlag("EntryPointSymbol", "WinMainCRTStartup");          }        }      } else {        linkOptions.AddFlag("SubSystem", "Windows");      }    } else {      if (this->GlobalGenerator->TargetsWindowsCE()) {        linkOptions.AddFlag("SubSystem", "WindowsCE");        if (this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE) {          if (this->ClOptions[config]->UsingUnicode()) {            linkOptions.AddFlag("EntryPointSymbol", "mainWCRTStartup");          } else {            linkOptions.AddFlag("EntryPointSymbol", "mainACRTStartup");          }        }      } else {        linkOptions.AddFlag("SubSystem", "Console");      };    }    if (const char* stackVal = this->Makefile->GetDefinition(          "CMAKE_" + linkLanguage + "_STACK_SIZE")) {      linkOptions.AddFlag("StackReserveSize", stackVal);    }    linkOptions.AddFlag("GenerateDebugInformation", "false");    std::string pdb = cmStrCat(this->GeneratorTarget->GetPDBDirectory(config),                               '/', targetNames.PDB);    std::string imLib =      cmStrCat(this->GeneratorTarget->GetDirectory(                 config, cmStateEnums::ImportLibraryArtifact),               '/', targetNames.ImportLibrary);    linkOptions.AddFlag("ImportLibrary", imLib);    linkOptions.AddFlag("ProgramDataBaseFile", pdb);    // A Windows Runtime component uses internal .NET metadata,    // so does not have an import library.    if (this->GeneratorTarget->GetPropertyAsBool("VS_WINRT_COMPONENT") &&        this->GeneratorTarget->GetType() != cmStateEnums::EXECUTABLE) {      linkOptions.AddFlag("GenerateWindowsMetadata", "true");    } else if (this->GlobalGenerator->TargetsWindowsPhone() ||               this->GlobalGenerator->TargetsWindowsStore()) {      // WindowsPhone and WindowsStore components are in an app container      // and produce WindowsMetadata.  If we are not producing a WINRT      // component, then do not generate the metadata here.      linkOptions.AddFlag("GenerateWindowsMetadata", "false");    }    if (this->GlobalGenerator->TargetsWindowsPhone() &&        this->GlobalGenerator->GetSystemVersion() == "8.0") {      // WindowsPhone 8.0 does not have ole32.      linkOptions.AppendFlag("IgnoreSpecificDefaultLibraries", "ole32.lib");    }  } else if (this->NsightTegra) {    linkOptions.AddFlag("SoName", targetNames.SharedObject);  }  linkOptions.Parse(flags);  linkOptions.FixManifestUACFlags();  if (this->MSTools) {    cmGeneratorTarget::ModuleDefinitionInfo const* mdi =      this->GeneratorTarget->GetModuleDefinitionInfo(config);    if (mdi && !mdi->DefFile.empty()) {      linkOptions.AddFlag("ModuleDefinitionFile", mdi->DefFile);    }    linkOptions.AppendFlag("IgnoreSpecificDefaultLibraries",                           "%(IgnoreSpecificDefaultLibraries)");  }  // VS 2015 without all updates has a v140 toolset whose  // GenerateDebugInformation expects No/Debug instead of false/true.  if (gg->GetPlatformToolsetNeedsDebugEnum()) {    if (const char* debug = linkOptions.GetFlag("GenerateDebugInformation")) {      if (strcmp(debug, "false") == 0) {        linkOptions.AddFlag("GenerateDebugInformation", "No");      } else if (strcmp(debug, "true") == 0) {        linkOptions.AddFlag("GenerateDebugInformation", "Debug");      }    }  }  // Managed code cannot be linked with /DEBUG:FASTLINK  if (this->Managed) {    if (const char* debug = linkOptions.GetFlag("GenerateDebugInformation")) {      if (strcmp(debug, "DebugFastLink") == 0) {        linkOptions.AddFlag("GenerateDebugInformation", "Debug");      }    }  }  this->LinkOptions[config] = std::move(pOptions);  return true;}bool cmVisualStudio10TargetGenerator::ComputeLibOptions(){  if (this->GeneratorTarget->GetType() == cmStateEnums::STATIC_LIBRARY) {    for (std::string const& c : this->Configurations) {      if (!this->ComputeLibOptions(c)) {        return false;      }    }  }  return true;}bool cmVisualStudio10TargetGenerator::ComputeLibOptions(  std::string const& config){  cmComputeLinkInformation* pcli =    this->GeneratorTarget->GetLinkInformation(config);  if (!pcli) {    cmSystemTools::Error(      "CMake can not compute cmComputeLinkInformation for target: " +      this->Name);    return false;  }  cmComputeLinkInformation& cli = *pcli;  using ItemVector = cmComputeLinkInformation::ItemVector;  const ItemVector& libs = cli.GetItems();  std::string currentBinDir =    this->LocalGenerator->GetCurrentBinaryDirectory();  for (cmComputeLinkInformation::Item const& l : libs) {    if (l.IsPath && cmVS10IsTargetsFile(l.Value.Value)) {      std::string path = this->LocalGenerator->MaybeConvertToRelativePath(        currentBinDir, l.Value.Value);      ConvertToWindowsSlash(path);      this->AddTargetsFileAndConfigPair(path, config);    }  }  return true;}void cmVisualStudio10TargetGenerator::WriteLinkOptions(  Elem& e1, std::string const& config){  if (this->GeneratorTarget->GetType() == cmStateEnums::STATIC_LIBRARY ||      this->GeneratorTarget->GetType() > cmStateEnums::MODULE_LIBRARY) {    return;  }  if (this->ProjectType == csproj) {    return;  }  {    Elem e2(e1, "Link");    OptionsHelper linkOptions(*(this->LinkOptions[config]), e2);    linkOptions.PrependInheritedString("AdditionalOptions");    linkOptions.OutputFlagMap();  }  if (!this->GlobalGenerator->NeedLinkLibraryDependencies(        this->GeneratorTarget)) {    Elem e2(e1, "ProjectReference");    e2.Element("LinkLibraryDependencies", "false");  }}void cmVisualStudio10TargetGenerator::AddLibraries(  const cmComputeLinkInformation& cli, std::vector<std::string>& libVec,  std::vector<std::string>& vsTargetVec, const std::string& config){  using ItemVector = cmComputeLinkInformation::ItemVector;  ItemVector const& libs = cli.GetItems();  std::string currentBinDir =    this->LocalGenerator->GetCurrentBinaryDirectory();  for (cmComputeLinkInformation::Item const& l : libs) {    if (l.Target) {      auto managedType = l.Target->GetManagedType(config);      if (managedType != cmGeneratorTarget::ManagedType::Native &&          this->GeneratorTarget->GetManagedType(config) !=            cmGeneratorTarget::ManagedType::Native &&          l.Target->IsImported()) {        auto location = l.Target->GetFullPath(config);        if (!location.empty()) {          ConvertToWindowsSlash(location);          switch (this->ProjectType) {            case csproj:              // If the target we want to "link" to is an imported managed              // target and this is a C# project, we add a hint reference. This              // reference is written to project file in              // WriteDotNetReferences().              this->DotNetHintReferences[config].push_back(                DotNetHintReference(l.Target->GetName(), location));              break;            case vcxproj:              // Add path of assembly to list of using-directories, so the              // managed assembly can be used by '#using <assembly.dll>' in              // code.              this->AdditionalUsingDirectories[config].insert(                cmSystemTools::GetFilenamePath(location));              break;          }        }      }      // Do not allow C# targets to be added to the LIB listing. LIB files are      // used for linking C++ dependencies. C# libraries do not have lib files.      // Instead, they compile down to C# reference libraries (DLL files). The      // `<ProjectReference>` elements added to the vcxproj are enough for the      // IDE to deduce the DLL file required by other C# projects that need its      // reference library.      if (managedType == cmGeneratorTarget::ManagedType::Managed) {        continue;      }    }    if (l.IsPath) {      std::string path = this->LocalGenerator->MaybeConvertToRelativePath(        currentBinDir, l.Value.Value);      ConvertToWindowsSlash(path);      if (cmVS10IsTargetsFile(l.Value.Value)) {        vsTargetVec.push_back(path);      } else {        libVec.push_back(path);      }    } else if (!l.Target ||               l.Target->GetType() != cmStateEnums::INTERFACE_LIBRARY) {      libVec.push_back(l.Value.Value);    }  }}void cmVisualStudio10TargetGenerator::AddTargetsFileAndConfigPair(  std::string const& targetsFile, std::string const& config){  for (TargetsFileAndConfigs& i : this->TargetsFileAndConfigsVec) {    if (cmSystemTools::ComparePath(targetsFile, i.File)) {      if (!cm::contains(i.Configs, config)) {        i.Configs.push_back(config);      }      return;    }  }  TargetsFileAndConfigs entry;  entry.File = targetsFile;  entry.Configs.push_back(config);  this->TargetsFileAndConfigsVec.push_back(entry);}void cmVisualStudio10TargetGenerator::WriteMidlOptions(  Elem& e1, std::string const& configName){  if (!this->MSTools) {    return;  }  if (this->ProjectType == csproj) {    return;  }  // This processes *any* of the .idl files specified in the project's file  // list (and passed as the item metadata %(Filename) expressing the rule  // input filename) into output files at the per-config *build* dir  // ($(IntDir)) each.  //  // IOW, this MIDL section is intended to provide a fully generic syntax  // content suitable for most cases (read: if you get errors, then it's quite  // probable that the error is on your side of the .idl setup).  //  // Also, note that the marked-as-generated _i.c file in the Visual Studio  // generator case needs to be referred to as $(IntDir)\foo_i.c at the  // project's file list, otherwise the compiler-side processing won't pick it  // up (for non-directory form, it ends up looking in project binary dir  // only).  Perhaps there's something to be done to make this more automatic  // on the CMake side?  std::vector<std::string> const includes =    this->GetIncludes(configName, "MIDL");  std::ostringstream oss;  for (std::string const& i : includes) {    oss << i << ";";  }  oss << "%(AdditionalIncludeDirectories)";  Elem e2(e1, "Midl");  e2.Element("AdditionalIncludeDirectories", oss.str());  e2.Element("OutputDirectory", "$(ProjectDir)/$(IntDir)");  e2.Element("HeaderFileName", "%(Filename).h");  e2.Element("TypeLibraryName", "%(Filename).tlb");  e2.Element("InterfaceIdentifierFileName", "%(Filename)_i.c");  e2.Element("ProxyFileName", "%(Filename)_p.c");}void cmVisualStudio10TargetGenerator::WriteItemDefinitionGroups(Elem& e0){  if (this->ProjectType == csproj) {    return;  }  for (const std::string& c : this->Configurations) {    Elem e1(e0, "ItemDefinitionGroup");    e1.Attribute("Condition", this->CalcCondition(c));    //    output cl compile flags <ClCompile></ClCompile>    if (this->GeneratorTarget->GetType() <= cmStateEnums::OBJECT_LIBRARY) {      this->WriteClOptions(e1, c);      //    output rc compile flags <ResourceCompile></ResourceCompile>      this->WriteRCOptions(e1, c);      this->WriteCudaOptions(e1, c);      this->WriteMasmOptions(e1, c);      this->WriteNasmOptions(e1, c);    }    //    output midl flags       <Midl></Midl>    this->WriteMidlOptions(e1, c);    // write events    if (this->ProjectType != csproj) {      this->WriteEvents(e1, c);    }    //    output link flags       <Link></Link>    this->WriteLinkOptions(e1, c);    this->WriteCudaLinkOptions(e1, c);    //    output lib flags       <Lib></Lib>    this->WriteLibOptions(e1, c);    //    output manifest flags  <Manifest></Manifest>    this->WriteManifestOptions(e1, c);    if (this->NsightTegra &&        this->GeneratorTarget->Target->IsAndroidGuiExecutable()) {      this->WriteAntBuildOptions(e1, c);    }  }}void cmVisualStudio10TargetGenerator::WriteEvents(  Elem& e1, std::string const& configName){  bool addedPrelink = false;  cmGeneratorTarget::ModuleDefinitionInfo const* mdi =    this->GeneratorTarget->GetModuleDefinitionInfo(configName);  if (mdi && mdi->DefFileGenerated) {    addedPrelink = true;    std::vector<cmCustomCommand> commands =      this->GeneratorTarget->GetPreLinkCommands();    this->GlobalGenerator->AddSymbolExportCommand(this->GeneratorTarget,                                                  commands, configName);    this->WriteEvent(e1, "PreLinkEvent", commands, configName);  }  if (!addedPrelink) {    this->WriteEvent(e1, "PreLinkEvent",                     this->GeneratorTarget->GetPreLinkCommands(), configName);  }  this->WriteEvent(e1, "PreBuildEvent",                   this->GeneratorTarget->GetPreBuildCommands(), configName);  this->WriteEvent(e1, "PostBuildEvent",                   this->GeneratorTarget->GetPostBuildCommands(), configName);}void cmVisualStudio10TargetGenerator::WriteEvent(  Elem& e1, const std::string& name,  std::vector<cmCustomCommand> const& commands, std::string const& configName){  if (commands.empty()) {    return;  }  cmLocalVisualStudio7Generator* lg = this->LocalGenerator;  std::string script;  const char* pre = "";  std::string comment;  bool stdPipesUTF8 = false;  for (cmCustomCommand const& cc : commands) {    cmCustomCommandGenerator ccg(cc, configName, lg);    if (!ccg.HasOnlyEmptyCommandLines()) {      comment += pre;      comment += lg->ConstructComment(ccg);      script += pre;      pre = "\n";      script += lg->ConstructScript(ccg);      stdPipesUTF8 = stdPipesUTF8 || cc.GetStdPipesUTF8();    }  }  comment = cmVS10EscapeComment(comment);  if (this->ProjectType != csproj) {    Elem e2(e1, name);    if (stdPipesUTF8) {      this->WriteStdOutEncodingUtf8(e2);    }    e2.Element("Message", comment);    e2.Element("Command", script);  } else {    std::string strippedComment = comment;    strippedComment.erase(      std::remove(strippedComment.begin(), strippedComment.end(), '\t'),      strippedComment.end());    std::ostringstream oss;    if (!comment.empty() && !strippedComment.empty()) {      oss << "echo " << comment << "\n";    }    oss << script << "\n";    e1.Element(name, oss.str());  }}void cmVisualStudio10TargetGenerator::WriteProjectReferences(Elem& e0){  cmGlobalGenerator::TargetDependSet const& unordered =    this->GlobalGenerator->GetTargetDirectDepends(this->GeneratorTarget);  using OrderedTargetDependSet =    cmGlobalVisualStudioGenerator::OrderedTargetDependSet;  OrderedTargetDependSet depends(unordered, CMAKE_CHECK_BUILD_SYSTEM_TARGET);  Elem e1(e0, "ItemGroup");  e1.SetHasElements();  for (cmGeneratorTarget const* dt : depends) {    if (dt->GetType() == cmStateEnums::INTERFACE_LIBRARY) {      continue;    }    // skip fortran targets as they can not be processed by MSBuild    // the only reference will be in the .sln file    if (this->GlobalGenerator->TargetIsFortranOnly(dt)) {      continue;    }    cmLocalGenerator* lg = dt->GetLocalGenerator();    std::string name = dt->GetName();    std::string path;    cmProp p = dt->GetProperty("EXTERNAL_MSPROJECT");    if (p) {      path = *p;    } else {      path = cmStrCat(lg->GetCurrentBinaryDirectory(), '/', dt->GetName(),                      computeProjectFileExtension(dt));    }    ConvertToWindowsSlash(path);    Elem e2(e1, "ProjectReference");    e2.Attribute("Include", path);    e2.Element("Project", "{" + this->GlobalGenerator->GetGUID(name) + "}");    e2.Element("Name", name);    this->WriteDotNetReferenceCustomTags(e2, name);    if (dt->IsCSharpOnly() || cmHasLiteralSuffix(path, "csproj")) {      e2.Element("SkipGetTargetFrameworkProperties", "true");    }    // Don't reference targets that don't produce any output.    if (this->Configurations.empty() ||        dt->GetManagedType(this->Configurations[0]) ==          cmGeneratorTarget::ManagedType::Undefined) {      e2.Element("ReferenceOutputAssembly", "false");      e2.Element("CopyToOutputDirectory", "Never");    }  }}void cmVisualStudio10TargetGenerator::WritePlatformExtensions(Elem& e1){  // This only applies to Windows 10 apps  if (this->GlobalGenerator->TargetsWindowsStore() &&      cmHasLiteralPrefix(this->GlobalGenerator->GetSystemVersion(), "10.0")) {    cmProp desktopExtensionsVersion =      this->GeneratorTarget->GetProperty("VS_DESKTOP_EXTENSIONS_VERSION");    if (desktopExtensionsVersion) {      this->WriteSinglePlatformExtension(e1, "WindowsDesktop",                                         *desktopExtensionsVersion);    }    cmProp mobileExtensionsVersion =      this->GeneratorTarget->GetProperty("VS_MOBILE_EXTENSIONS_VERSION");    if (mobileExtensionsVersion) {      this->WriteSinglePlatformExtension(e1, "WindowsMobile",                                         *mobileExtensionsVersion);    }  }}void cmVisualStudio10TargetGenerator::WriteSinglePlatformExtension(  Elem& e1, std::string const& extension, std::string const& version){  const std::string s = "$([Microsoft.Build.Utilities.ToolLocationHelper]"                        "::GetPlatformExtensionSDKLocation(`" +    extension + ", Version=" + version +    "`, $(TargetPlatformIdentifier), $(TargetPlatformVersion), null, "    "$(ExtensionSDKDirectoryRoot), null))"    "\\DesignTime\\CommonConfiguration\\Neutral\\" +    extension + ".props";  Elem e2(e1, "Import");  e2.Attribute("Project", s);  e2.Attribute("Condition", "exists('" + s + "')");}void cmVisualStudio10TargetGenerator::WriteSDKReferences(Elem& e0){  std::vector<std::string> sdkReferences;  std::unique_ptr<Elem> spe1;  if (cmProp vsSDKReferences =        this->GeneratorTarget->GetProperty("VS_SDK_REFERENCES")) {    cmExpandList(*vsSDKReferences, sdkReferences);    spe1 = cm::make_unique<Elem>(e0, "ItemGroup");    for (std::string const& ri : sdkReferences) {      Elem(*spe1, "SDKReference").Attribute("Include", ri);    }  }  // This only applies to Windows 10 apps  if (this->GlobalGenerator->TargetsWindowsStore() &&      cmHasLiteralPrefix(this->GlobalGenerator->GetSystemVersion(), "10.0")) {    cmProp desktopExtensionsVersion =      this->GeneratorTarget->GetProperty("VS_DESKTOP_EXTENSIONS_VERSION");    cmProp mobileExtensionsVersion =      this->GeneratorTarget->GetProperty("VS_MOBILE_EXTENSIONS_VERSION");    cmProp iotExtensionsVersion =      this->GeneratorTarget->GetProperty("VS_IOT_EXTENSIONS_VERSION");    if (desktopExtensionsVersion || mobileExtensionsVersion ||        iotExtensionsVersion) {      if (!spe1) {        spe1 = cm::make_unique<Elem>(e0, "ItemGroup");      }      if (desktopExtensionsVersion) {        this->WriteSingleSDKReference(*spe1, "WindowsDesktop",                                      *desktopExtensionsVersion);      }      if (mobileExtensionsVersion) {        this->WriteSingleSDKReference(*spe1, "WindowsMobile",                                      *mobileExtensionsVersion);      }      if (iotExtensionsVersion) {        this->WriteSingleSDKReference(*spe1, "WindowsIoT",                                      *iotExtensionsVersion);      }    }  }}void cmVisualStudio10TargetGenerator::WriteSingleSDKReference(  Elem& e1, std::string const& extension, std::string const& version){  Elem(e1, "SDKReference")    .Attribute("Include", extension + ", Version=" + version);}void cmVisualStudio10TargetGenerator::WriteWinRTPackageCertificateKeyFile(  Elem& e0){  if ((this->GlobalGenerator->TargetsWindowsStore() ||       this->GlobalGenerator->TargetsWindowsPhone()) &&      (cmStateEnums::EXECUTABLE == this->GeneratorTarget->GetType())) {    std::string pfxFile;    for (cmGeneratorTarget::AllConfigSource const& source :         this->GeneratorTarget->GetAllConfigSources()) {      if (source.Kind == cmGeneratorTarget::SourceKindCertificate) {        pfxFile = this->ConvertPath(source.Source->GetFullPath(), false);        ConvertToWindowsSlash(pfxFile);        break;      }    }    if (this->IsMissingFiles &&        !(this->GlobalGenerator->TargetsWindowsPhone() &&          this->GlobalGenerator->GetSystemVersion() == "8.0")) {      // Move the manifest to a project directory to avoid clashes      std::string artifactDir =        this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);      ConvertToWindowsSlash(artifactDir);      Elem e1(e0, "PropertyGroup");      e1.Element("AppxPackageArtifactsDir", artifactDir + "\\");      std::string resourcePriFile =        this->DefaultArtifactDir + "/resources.pri";      ConvertToWindowsSlash(resourcePriFile);      e1.Element("ProjectPriFullPath", resourcePriFile);      // If we are missing files and we don't have a certificate and      // aren't targeting WP8.0, add a default certificate      if (pfxFile.empty()) {        std::string templateFolder =          cmSystemTools::GetCMakeRoot() + "/Templates/Windows";        pfxFile = this->DefaultArtifactDir + "/Windows_TemporaryKey.pfx";        cmSystemTools::CopyAFile(templateFolder + "/Windows_TemporaryKey.pfx",                                 pfxFile, false);        ConvertToWindowsSlash(pfxFile);        this->AddedFiles.push_back(pfxFile);        this->AddedDefaultCertificate = true;      }      e1.Element("PackageCertificateKeyFile", pfxFile);      std::string thumb = cmSystemTools::ComputeCertificateThumbprint(pfxFile);      if (!thumb.empty()) {        e1.Element("PackageCertificateThumbprint", thumb);      }    } else if (!pfxFile.empty()) {      Elem e1(e0, "PropertyGroup");      e1.Element("PackageCertificateKeyFile", pfxFile);      std::string thumb = cmSystemTools::ComputeCertificateThumbprint(pfxFile);      if (!thumb.empty()) {        e1.Element("PackageCertificateThumbprint", thumb);      }    }  }}void cmVisualStudio10TargetGenerator::ClassifyAllConfigSources(){  for (cmGeneratorTarget::AllConfigSource const& source :       this->GeneratorTarget->GetAllConfigSources()) {    this->ClassifyAllConfigSource(source);  }}void cmVisualStudio10TargetGenerator::ClassifyAllConfigSource(  cmGeneratorTarget::AllConfigSource const& acs){  switch (acs.Kind) {    case cmGeneratorTarget::SourceKindResx: {      // Build and save the name of the corresponding .h file      // This relationship will be used later when building the project files.      // Both names would have been auto generated from Visual Studio      // where the user supplied the file name and Visual Studio      // appended the suffix.      std::string resx = acs.Source->ResolveFullPath();      std::string hFileName = resx.substr(0, resx.find_last_of('.')) + ".h";      this->ExpectedResxHeaders.insert(hFileName);    } break;    case cmGeneratorTarget::SourceKindXaml: {      // Build and save the name of the corresponding .h and .cpp file      // This relationship will be used later when building the project files.      // Both names would have been auto generated from Visual Studio      // where the user supplied the file name and Visual Studio      // appended the suffix.      std::string xaml = acs.Source->ResolveFullPath();      std::string hFileName = xaml + ".h";      std::string cppFileName = xaml + ".cpp";      this->ExpectedXamlHeaders.insert(hFileName);      this->ExpectedXamlSources.insert(cppFileName);    } break;    default:      break;  }}bool cmVisualStudio10TargetGenerator::IsResxHeader(  const std::string& headerFile){  return this->ExpectedResxHeaders.count(headerFile) > 0;}bool cmVisualStudio10TargetGenerator::IsXamlHeader(  const std::string& headerFile){  return this->ExpectedXamlHeaders.count(headerFile) > 0;}bool cmVisualStudio10TargetGenerator::IsXamlSource(  const std::string& sourceFile){  return this->ExpectedXamlSources.count(sourceFile) > 0;}void cmVisualStudio10TargetGenerator::WriteApplicationTypeSettings(Elem& e1){  cmGlobalVisualStudio10Generator* gg = this->GlobalGenerator;  bool isAppContainer = false;  bool const isWindowsPhone = this->GlobalGenerator->TargetsWindowsPhone();  bool const isWindowsStore = this->GlobalGenerator->TargetsWindowsStore();  bool const isAndroid = this->GlobalGenerator->TargetsAndroid();  std::string const& rev = this->GlobalGenerator->GetApplicationTypeRevision();  if (isWindowsPhone || isWindowsStore) {    e1.Element("ApplicationType",               (isWindowsPhone ? "Windows Phone" : "Windows Store"));    e1.Element("DefaultLanguage", "en-US");    if (rev == "10.0") {      e1.Element("ApplicationTypeRevision", rev);      // Visual Studio 14.0 is necessary for building 10.0 apps      e1.Element("MinimumVisualStudioVersion", "14.0");      if (this->GeneratorTarget->GetType() < cmStateEnums::UTILITY) {        isAppContainer = true;      }    } else if (rev == "8.1") {      e1.Element("ApplicationTypeRevision", rev);      // Visual Studio 12.0 is necessary for building 8.1 apps      e1.Element("MinimumVisualStudioVersion", "12.0");      if (this->GeneratorTarget->GetType() < cmStateEnums::UTILITY) {        isAppContainer = true;      }    } else if (rev == "8.0") {      e1.Element("ApplicationTypeRevision", rev);      // Visual Studio 11.0 is necessary for building 8.0 apps      e1.Element("MinimumVisualStudioVersion", "11.0");      if (isWindowsStore &&          this->GeneratorTarget->GetType() < cmStateEnums::UTILITY) {        isAppContainer = true;      } else if (isWindowsPhone &&                 this->GeneratorTarget->GetType() ==                   cmStateEnums::EXECUTABLE) {        e1.Element("XapOutputs", "true");        e1.Element("XapFilename",                   this->Name + "_$(Configuration)_$(Platform).xap");      }    }  } else if (isAndroid) {    e1.Element("ApplicationType", "Android");    e1.Element("ApplicationTypeRevision",               gg->GetAndroidApplicationTypeRevision());  }  if (isAppContainer) {    e1.Element("AppContainerApplication", "true");  } else if (!isAndroid) {    if (this->Platform == "ARM64") {      e1.Element("WindowsSDKDesktopARM64Support", "true");    } else if (this->Platform == "ARM") {      e1.Element("WindowsSDKDesktopARMSupport", "true");    }  }  std::string const& targetPlatformVersion =    gg->GetWindowsTargetPlatformVersion();  if (!targetPlatformVersion.empty()) {    e1.Element("WindowsTargetPlatformVersion", targetPlatformVersion);  }  cmProp targetPlatformMinVersion = this->GeneratorTarget->GetProperty(    "VS_WINDOWS_TARGET_PLATFORM_MIN_VERSION");  if (targetPlatformMinVersion) {    e1.Element("WindowsTargetPlatformMinVersion", *targetPlatformMinVersion);  } else if (isWindowsStore && rev == "10.0") {    // If the min version is not set, then use the TargetPlatformVersion    if (!targetPlatformVersion.empty()) {      e1.Element("WindowsTargetPlatformMinVersion", targetPlatformVersion);    }  }  // Added IoT Startup Task support  if (this->GeneratorTarget->GetPropertyAsBool("VS_IOT_STARTUP_TASK")) {    e1.Element("ContainsStartupTask", "true");  }}void cmVisualStudio10TargetGenerator::VerifyNecessaryFiles(){  // For Windows and Windows Phone executables, we will assume that if a  // manifest is not present that we need to add all the necessary files  if (this->GeneratorTarget->GetType() == cmStateEnums::EXECUTABLE) {    std::vector<cmGeneratorTarget::AllConfigSource> manifestSources =      this->GeneratorTarget->GetAllConfigSources(        cmGeneratorTarget::SourceKindAppManifest);    std::string const& v = this->GlobalGenerator->GetSystemVersion();    if (this->GlobalGenerator->TargetsWindowsPhone()) {      if (v == "8.0") {        // Look through the sources for WMAppManifest.xml        bool foundManifest = false;        for (cmGeneratorTarget::AllConfigSource const& source :             this->GeneratorTarget->GetAllConfigSources()) {          if (source.Kind == cmGeneratorTarget::SourceKindExtra &&              "wmappmanifest.xml" ==                cmSystemTools::LowerCase(                  source.Source->GetLocation().GetName())) {            foundManifest = true;            break;          }        }        if (!foundManifest) {          this->IsMissingFiles = true;        }      } else if (v == "8.1") {        if (manifestSources.empty()) {          this->IsMissingFiles = true;        }      }    } else if (this->GlobalGenerator->TargetsWindowsStore()) {      if (manifestSources.empty()) {        if (v == "8.0") {          this->IsMissingFiles = true;        } else if (v == "8.1" || cmHasLiteralPrefix(v, "10.0")) {          this->IsMissingFiles = true;        }      }    }  }}void cmVisualStudio10TargetGenerator::WriteMissingFiles(Elem& e1){  std::string const& v = this->GlobalGenerator->GetSystemVersion();  if (this->GlobalGenerator->TargetsWindowsPhone()) {    if (v == "8.0") {      this->WriteMissingFilesWP80(e1);    } else if (v == "8.1") {      this->WriteMissingFilesWP81(e1);    }  } else if (this->GlobalGenerator->TargetsWindowsStore()) {    if (v == "8.0") {      this->WriteMissingFilesWS80(e1);    } else if (v == "8.1") {      this->WriteMissingFilesWS81(e1);    } else if (cmHasLiteralPrefix(v, "10.0")) {      this->WriteMissingFilesWS10_0(e1);    }  }}void cmVisualStudio10TargetGenerator::WriteMissingFilesWP80(Elem& e1){  std::string templateFolder =    cmSystemTools::GetCMakeRoot() + "/Templates/Windows";  // For WP80, the manifest needs to be in the same folder as the project  // this can cause an overwrite problem if projects aren't organized in  // folders  std::string manifestFile =    this->LocalGenerator->GetCurrentBinaryDirectory() + "/WMAppManifest.xml";  std::string artifactDir =    this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);  ConvertToWindowsSlash(artifactDir);  std::string artifactDirXML = cmVS10EscapeXML(artifactDir);  std::string targetNameXML =    cmVS10EscapeXML(this->GeneratorTarget->GetName());  cmGeneratedFileStream fout(manifestFile);  fout.SetCopyIfDifferent(true);  /* clang-format off */  fout <<    "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"    "<Deployment"    " xmlns=\"http://schemas.microsoft.com/windowsphone/2012/deployment\""    " AppPlatformVersion=\"8.0\">\n"    "\t<DefaultLanguage xmlns=\"\" code=\"en-US\"/>\n"    "\t<App xmlns=\"\" ProductID=\"{" << this->GUID << "}\""    " Title=\"CMake Test Program\" RuntimeType=\"Modern Native\""    " Version=\"1.0.0.0\" Genre=\"apps.normal\"  Author=\"CMake\""    " Description=\"Default CMake App\" Publisher=\"CMake\""    " PublisherID=\"{" << this->GUID << "}\">\n"    "\t\t<IconPath IsRelative=\"true\" IsResource=\"false\">"       << artifactDirXML << "\\ApplicationIcon.png</IconPath>\n"    "\t\t<Capabilities/>\n"    "\t\t<Tasks>\n"    "\t\t\t<DefaultTask Name=\"_default\""    " ImagePath=\"" << targetNameXML << ".exe\" ImageParams=\"\" />\n"    "\t\t</Tasks>\n"    "\t\t<Tokens>\n"    "\t\t\t<PrimaryToken TokenID=\"" << targetNameXML << "Token\""    " TaskName=\"_default\">\n"    "\t\t\t\t<TemplateFlip>\n"    "\t\t\t\t\t<SmallImageURI IsRelative=\"true\" IsResource=\"false\">"       << artifactDirXML << "\\SmallLogo.png</SmallImageURI>\n"    "\t\t\t\t\t<Count>0</Count>\n"    "\t\t\t\t\t<BackgroundImageURI IsRelative=\"true\" IsResource=\"false\">"       << artifactDirXML << "\\Logo.png</BackgroundImageURI>\n"    "\t\t\t\t</TemplateFlip>\n"    "\t\t\t</PrimaryToken>\n"    "\t\t</Tokens>\n"    "\t\t<ScreenResolutions>\n"    "\t\t\t<ScreenResolution Name=\"ID_RESOLUTION_WVGA\" />\n"    "\t\t</ScreenResolutions>\n"    "\t</App>\n"    "</Deployment>\n";  /* clang-format on */  std::string sourceFile = this->ConvertPath(manifestFile, false);  ConvertToWindowsSlash(sourceFile);  {    Elem e2(e1, "Xml");    e2.Attribute("Include", sourceFile);    e2.Element("SubType", "Designer");  }  this->AddedFiles.push_back(sourceFile);  std::string smallLogo = this->DefaultArtifactDir + "/SmallLogo.png";  cmSystemTools::CopyAFile(templateFolder + "/SmallLogo.png", smallLogo,                           false);  ConvertToWindowsSlash(smallLogo);  Elem(e1, "Image").Attribute("Include", smallLogo);  this->AddedFiles.push_back(smallLogo);  std::string logo = this->DefaultArtifactDir + "/Logo.png";  cmSystemTools::CopyAFile(templateFolder + "/Logo.png", logo, false);  ConvertToWindowsSlash(logo);  Elem(e1, "Image").Attribute("Include", logo);  this->AddedFiles.push_back(logo);  std::string applicationIcon =    this->DefaultArtifactDir + "/ApplicationIcon.png";  cmSystemTools::CopyAFile(templateFolder + "/ApplicationIcon.png",                           applicationIcon, false);  ConvertToWindowsSlash(applicationIcon);  Elem(e1, "Image").Attribute("Include", applicationIcon);  this->AddedFiles.push_back(applicationIcon);}void cmVisualStudio10TargetGenerator::WriteMissingFilesWP81(Elem& e1){  std::string manifestFile =    this->DefaultArtifactDir + "/package.appxManifest";  std::string artifactDir =    this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);  ConvertToWindowsSlash(artifactDir);  std::string artifactDirXML = cmVS10EscapeXML(artifactDir);  std::string targetNameXML =    cmVS10EscapeXML(this->GeneratorTarget->GetName());  cmGeneratedFileStream fout(manifestFile);  fout.SetCopyIfDifferent(true);  /* clang-format off */  fout <<    "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"    "<Package xmlns=\"http://schemas.microsoft.com/appx/2010/manifest\""    " xmlns:m2=\"http://schemas.microsoft.com/appx/2013/manifest\""    " xmlns:mp=\"http://schemas.microsoft.com/appx/2014/phone/manifest\">\n"    "\t<Identity Name=\"" << this->GUID << "\" Publisher=\"CN=CMake\""    " Version=\"1.0.0.0\" />\n"    "\t<mp:PhoneIdentity PhoneProductId=\"" << this->GUID << "\""    " PhonePublisherId=\"00000000-0000-0000-0000-000000000000\"/>\n"    "\t<Properties>\n"    "\t\t<DisplayName>" << targetNameXML << "</DisplayName>\n"    "\t\t<PublisherDisplayName>CMake</PublisherDisplayName>\n"    "\t\t<Logo>" << artifactDirXML << "\\StoreLogo.png</Logo>\n"    "\t</Properties>\n"    "\t<Prerequisites>\n"    "\t\t<OSMinVersion>6.3.1</OSMinVersion>\n"    "\t\t<OSMaxVersionTested>6.3.1</OSMaxVersionTested>\n"    "\t</Prerequisites>\n"    "\t<Resources>\n"    "\t\t<Resource Language=\"x-generate\" />\n"    "\t</Resources>\n"    "\t<Applications>\n"    "\t\t<Application Id=\"App\""    " Executable=\"" << targetNameXML << ".exe\""    " EntryPoint=\"" << targetNameXML << ".App\">\n"    "\t\t\t<m2:VisualElements\n"    "\t\t\t\tDisplayName=\"" << targetNameXML << "\"\n"    "\t\t\t\tDescription=\"" << targetNameXML << "\"\n"    "\t\t\t\tBackgroundColor=\"#336699\"\n"    "\t\t\t\tForegroundText=\"light\"\n"    "\t\t\t\tSquare150x150Logo=\"" << artifactDirXML << "\\Logo.png\"\n"    "\t\t\t\tSquare30x30Logo=\"" << artifactDirXML << "\\SmallLogo.png\">\n"    "\t\t\t\t<m2:DefaultTile ShortName=\"" << targetNameXML << "\">\n"    "\t\t\t\t\t<m2:ShowNameOnTiles>\n"    "\t\t\t\t\t\t<m2:ShowOn Tile=\"square150x150Logo\" />\n"    "\t\t\t\t\t</m2:ShowNameOnTiles>\n"    "\t\t\t\t</m2:DefaultTile>\n"    "\t\t\t\t<m2:SplashScreen"    " Image=\"" << artifactDirXML << "\\SplashScreen.png\" />\n"    "\t\t\t</m2:VisualElements>\n"    "\t\t</Application>\n"    "\t</Applications>\n"    "</Package>\n";  /* clang-format on */  this->WriteCommonMissingFiles(e1, manifestFile);}void cmVisualStudio10TargetGenerator::WriteMissingFilesWS80(Elem& e1){  std::string manifestFile =    this->DefaultArtifactDir + "/package.appxManifest";  std::string artifactDir =    this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);  ConvertToWindowsSlash(artifactDir);  std::string artifactDirXML = cmVS10EscapeXML(artifactDir);  std::string targetNameXML =    cmVS10EscapeXML(this->GeneratorTarget->GetName());  cmGeneratedFileStream fout(manifestFile);  fout.SetCopyIfDifferent(true);  /* clang-format off */  fout <<    "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"    "<Package xmlns=\"http://schemas.microsoft.com/appx/2010/manifest\">\n"    "\t<Identity Name=\"" << this->GUID << "\" Publisher=\"CN=CMake\""    " Version=\"1.0.0.0\" />\n"    "\t<Properties>\n"    "\t\t<DisplayName>" << targetNameXML << "</DisplayName>\n"    "\t\t<PublisherDisplayName>CMake</PublisherDisplayName>\n"    "\t\t<Logo>" << artifactDirXML << "\\StoreLogo.png</Logo>\n"    "\t</Properties>\n"    "\t<Prerequisites>\n"    "\t\t<OSMinVersion>6.2.1</OSMinVersion>\n"    "\t\t<OSMaxVersionTested>6.2.1</OSMaxVersionTested>\n"    "\t</Prerequisites>\n"    "\t<Resources>\n"    "\t\t<Resource Language=\"x-generate\" />\n"    "\t</Resources>\n"    "\t<Applications>\n"    "\t\t<Application Id=\"App\""    " Executable=\"" << targetNameXML << ".exe\""    " EntryPoint=\"" << targetNameXML << ".App\">\n"    "\t\t\t<VisualElements"    " DisplayName=\"" << targetNameXML << "\""    " Description=\"" << targetNameXML << "\""    " BackgroundColor=\"#336699\" ForegroundText=\"light\""    " Logo=\"" << artifactDirXML << "\\Logo.png\""    " SmallLogo=\"" << artifactDirXML << "\\SmallLogo.png\">\n"    "\t\t\t\t<DefaultTile ShowName=\"allLogos\""    " ShortName=\"" << targetNameXML << "\" />\n"    "\t\t\t\t<SplashScreen"    " Image=\"" << artifactDirXML << "\\SplashScreen.png\" />\n"    "\t\t\t</VisualElements>\n"    "\t\t</Application>\n"    "\t</Applications>\n"    "</Package>\n";  /* clang-format on */  this->WriteCommonMissingFiles(e1, manifestFile);}void cmVisualStudio10TargetGenerator::WriteMissingFilesWS81(Elem& e1){  std::string manifestFile =    this->DefaultArtifactDir + "/package.appxManifest";  std::string artifactDir =    this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);  ConvertToWindowsSlash(artifactDir);  std::string artifactDirXML = cmVS10EscapeXML(artifactDir);  std::string targetNameXML =    cmVS10EscapeXML(this->GeneratorTarget->GetName());  cmGeneratedFileStream fout(manifestFile);  fout.SetCopyIfDifferent(true);  /* clang-format off */  fout <<    "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"    "<Package xmlns=\"http://schemas.microsoft.com/appx/2010/manifest\""    " xmlns:m2=\"http://schemas.microsoft.com/appx/2013/manifest\">\n"    "\t<Identity Name=\"" << this->GUID << "\" Publisher=\"CN=CMake\""    " Version=\"1.0.0.0\" />\n"    "\t<Properties>\n"    "\t\t<DisplayName>" << targetNameXML << "</DisplayName>\n"    "\t\t<PublisherDisplayName>CMake</PublisherDisplayName>\n"    "\t\t<Logo>" << artifactDirXML << "\\StoreLogo.png</Logo>\n"    "\t</Properties>\n"    "\t<Prerequisites>\n"    "\t\t<OSMinVersion>6.3</OSMinVersion>\n"    "\t\t<OSMaxVersionTested>6.3</OSMaxVersionTested>\n"    "\t</Prerequisites>\n"    "\t<Resources>\n"    "\t\t<Resource Language=\"x-generate\" />\n"    "\t</Resources>\n"    "\t<Applications>\n"    "\t\t<Application Id=\"App\""    " Executable=\"" << targetNameXML << ".exe\""    " EntryPoint=\"" << targetNameXML << ".App\">\n"    "\t\t\t<m2:VisualElements\n"    "\t\t\t\tDisplayName=\"" << targetNameXML << "\"\n"    "\t\t\t\tDescription=\"" << targetNameXML << "\"\n"    "\t\t\t\tBackgroundColor=\"#336699\"\n"    "\t\t\t\tForegroundText=\"light\"\n"    "\t\t\t\tSquare150x150Logo=\"" << artifactDirXML << "\\Logo.png\"\n"    "\t\t\t\tSquare30x30Logo=\"" << artifactDirXML << "\\SmallLogo.png\">\n"    "\t\t\t\t<m2:DefaultTile ShortName=\"" << targetNameXML << "\">\n"    "\t\t\t\t\t<m2:ShowNameOnTiles>\n"    "\t\t\t\t\t\t<m2:ShowOn Tile=\"square150x150Logo\" />\n"    "\t\t\t\t\t</m2:ShowNameOnTiles>\n"    "\t\t\t\t</m2:DefaultTile>\n"    "\t\t\t\t<m2:SplashScreen"    " Image=\"" << artifactDirXML << "\\SplashScreen.png\" />\n"    "\t\t\t</m2:VisualElements>\n"    "\t\t</Application>\n"    "\t</Applications>\n"    "</Package>\n";  /* clang-format on */  this->WriteCommonMissingFiles(e1, manifestFile);}void cmVisualStudio10TargetGenerator::WriteMissingFilesWS10_0(Elem& e1){  std::string manifestFile =    this->DefaultArtifactDir + "/package.appxManifest";  std::string artifactDir =    this->LocalGenerator->GetTargetDirectory(this->GeneratorTarget);  ConvertToWindowsSlash(artifactDir);  std::string artifactDirXML = cmVS10EscapeXML(artifactDir);  std::string targetNameXML =    cmVS10EscapeXML(this->GeneratorTarget->GetName());  cmGeneratedFileStream fout(manifestFile);  fout.SetCopyIfDifferent(true);  /* clang-format off */  fout <<    "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n"    "<Package\n\t"    "xmlns=\"http://schemas.microsoft.com/appx/manifest/foundation/windows10\""    "\txmlns:mp=\"http://schemas.microsoft.com/appx/2014/phone/manifest\"\n"    "\txmlns:uap=\"http://schemas.microsoft.com/appx/manifest/uap/windows10\""    "\n\tIgnorableNamespaces=\"uap mp\">\n\n"    "\t<Identity Name=\"" << this->GUID << "\" Publisher=\"CN=CMake\""    " Version=\"1.0.0.0\" />\n"    "\t<mp:PhoneIdentity PhoneProductId=\"" << this->GUID <<    "\" PhonePublisherId=\"00000000-0000-0000-0000-000000000000\"/>\n"    "\t<Properties>\n"    "\t\t<DisplayName>" << targetNameXML << "</DisplayName>\n"    "\t\t<PublisherDisplayName>CMake</PublisherDisplayName>\n"    "\t\t<Logo>" << artifactDirXML << "\\StoreLogo.png</Logo>\n"    "\t</Properties>\n"    "\t<Dependencies>\n"    "\t\t<TargetDeviceFamily Name=\"Windows.Universal\" "    "MinVersion=\"10.0.0.0\" MaxVersionTested=\"10.0.0.0\" />\n"    "\t</Dependencies>\n"    "\t<Resources>\n"    "\t\t<Resource Language=\"x-generate\" />\n"    "\t</Resources>\n"    "\t<Applications>\n"    "\t\t<Application Id=\"App\""    " Executable=\"" << targetNameXML << ".exe\""    " EntryPoint=\"" << targetNameXML << ".App\">\n"    "\t\t\t<uap:VisualElements\n"    "\t\t\t\tDisplayName=\"" << targetNameXML << "\"\n"    "\t\t\t\tDescription=\"" << targetNameXML << "\"\n"    "\t\t\t\tBackgroundColor=\"#336699\"\n"    "\t\t\t\tSquare150x150Logo=\"" << artifactDirXML << "\\Logo.png\"\n"    "\t\t\t\tSquare44x44Logo=\"" << artifactDirXML <<    "\\SmallLogo44x44.png\">\n"    "\t\t\t\t<uap:SplashScreen"    " Image=\"" << artifactDirXML << "\\SplashScreen.png\" />\n"    "\t\t\t</uap:VisualElements>\n"    "\t\t</Application>\n"    "\t</Applications>\n"    "</Package>\n";  /* clang-format on */  this->WriteCommonMissingFiles(e1, manifestFile);}void cmVisualStudio10TargetGenerator::WriteCommonMissingFiles(  Elem& e1, const std::string& manifestFile){  std::string templateFolder =    cmSystemTools::GetCMakeRoot() + "/Templates/Windows";  std::string sourceFile = this->ConvertPath(manifestFile, false);  ConvertToWindowsSlash(sourceFile);  {    Elem e2(e1, "AppxManifest");    e2.Attribute("Include", sourceFile);    e2.Element("SubType", "Designer");  }  this->AddedFiles.push_back(sourceFile);  std::string smallLogo = this->DefaultArtifactDir + "/SmallLogo.png";  cmSystemTools::CopyAFile(templateFolder + "/SmallLogo.png", smallLogo,                           false);  ConvertToWindowsSlash(smallLogo);  Elem(e1, "Image").Attribute("Include", smallLogo);  this->AddedFiles.push_back(smallLogo);  std::string smallLogo44 = this->DefaultArtifactDir + "/SmallLogo44x44.png";  cmSystemTools::CopyAFile(templateFolder + "/SmallLogo44x44.png", smallLogo44,                           false);  ConvertToWindowsSlash(smallLogo44);  Elem(e1, "Image").Attribute("Include", smallLogo44);  this->AddedFiles.push_back(smallLogo44);  std::string logo = this->DefaultArtifactDir + "/Logo.png";  cmSystemTools::CopyAFile(templateFolder + "/Logo.png", logo, false);  ConvertToWindowsSlash(logo);  Elem(e1, "Image").Attribute("Include", logo);  this->AddedFiles.push_back(logo);  std::string storeLogo = this->DefaultArtifactDir + "/StoreLogo.png";  cmSystemTools::CopyAFile(templateFolder + "/StoreLogo.png", storeLogo,                           false);  ConvertToWindowsSlash(storeLogo);  Elem(e1, "Image").Attribute("Include", storeLogo);  this->AddedFiles.push_back(storeLogo);  std::string splashScreen = this->DefaultArtifactDir + "/SplashScreen.png";  cmSystemTools::CopyAFile(templateFolder + "/SplashScreen.png", splashScreen,                           false);  ConvertToWindowsSlash(splashScreen);  Elem(e1, "Image").Attribute("Include", splashScreen);  this->AddedFiles.push_back(splashScreen);  if (this->AddedDefaultCertificate) {    // This file has already been added to the build so don't copy it    std::string keyFile =      this->DefaultArtifactDir + "/Windows_TemporaryKey.pfx";    ConvertToWindowsSlash(keyFile);    Elem(e1, "None").Attribute("Include", keyFile);  }}bool cmVisualStudio10TargetGenerator::ForceOld(const std::string& source) const{  HANDLE h =    CreateFileW(cmSystemTools::ConvertToWindowsExtendedPath(source).c_str(),                FILE_WRITE_ATTRIBUTES, FILE_SHARE_WRITE, 0, OPEN_EXISTING,                FILE_FLAG_BACKUP_SEMANTICS, 0);  if (!h) {    return false;  }  FILETIME const ftime_20010101 = { 3365781504u, 29389701u };  if (!SetFileTime(h, &ftime_20010101, &ftime_20010101, &ftime_20010101)) {    CloseHandle(h);    return false;  }  CloseHandle(h);  return true;}void cmVisualStudio10TargetGenerator::GetCSharpSourceProperties(  cmSourceFile const* sf, std::map<std::string, std::string>& tags){  if (this->ProjectType == csproj) {    const cmPropertyMap& props = sf->GetProperties();    for (const std::string& p : props.GetKeys()) {      static const cm::string_view propNamePrefix = "VS_CSHARP_";      if (cmHasPrefix(p, propNamePrefix)) {        std::string tagName = p.substr(propNamePrefix.length());        if (!tagName.empty()) {          const std::string& val = *props.GetPropertyValue(p);          if (!val.empty()) {            tags[tagName] = val;          } else {            tags.erase(tagName);          }        }      }    }  }}void cmVisualStudio10TargetGenerator::WriteCSharpSourceProperties(  Elem& e2, const std::map<std::string, std::string>& tags){  for (const auto& i : tags) {    e2.Element(i.first, i.second);  }}std::string cmVisualStudio10TargetGenerator::GetCSharpSourceLink(  cmSourceFile const* source){  // For out of source files, we first check if a matching source group  // for this file exists, otherwise we check if the path relative to current  // source- or binary-dir is used within the link and return that  std::string link;  std::string const& fullFileName = source->GetFullPath();  std::string const& srcDir = this->Makefile->GetCurrentSourceDirectory();  std::string const& binDir = this->Makefile->GetCurrentBinaryDirectory();  // unfortunately we have to copy the source groups, because  // FindSourceGroup uses a regex which is modifying the group  std::vector<cmSourceGroup> sourceGroups = this->Makefile->GetSourceGroups();  cmSourceGroup* sourceGroup =    this->Makefile->FindSourceGroup(fullFileName, sourceGroups);  if (sourceGroup && !sourceGroup->GetFullName().empty()) {    link = sourceGroup->GetFullName() + "/" +      cmsys::SystemTools::GetFilenameName(fullFileName);  } else if (cmHasPrefix(fullFileName, srcDir)) {    link = fullFileName.substr(srcDir.length() + 1);  } else if (cmHasPrefix(fullFileName, binDir)) {    link = fullFileName.substr(binDir.length() + 1);  } else if (cmProp l = source->GetProperty("VS_CSHARP_Link")) {    link = *l;  }  ConvertToWindowsSlash(link);  return link;}std::string cmVisualStudio10TargetGenerator::GetCMakeFilePath(  const char* relativeFilePath) const{  // Always search in the standard modules location.  std::string path =    cmStrCat(cmSystemTools::GetCMakeRoot(), '/', relativeFilePath);  ConvertToWindowsSlash(path);  return path;}void cmVisualStudio10TargetGenerator::WriteStdOutEncodingUtf8(Elem& e1){  if (this->GlobalGenerator->IsStdOutEncodingSupported()) {    e1.Element("StdOutEncoding", "UTF-8");  }}
 |