• úvod
  • témata
  • události
  • tržiště
  • diskuze
  • nástěnka
  • přihlásit
    registrace
    ztracené heslo?
    TENCOKACISTROMYProgramovani v C#, F# a dalsich jazycich pro .NET, Mono a ostatni CLI implementace
    MORMEGIL
    MORMEGIL --- ---
    NECROMAN: Takže bych to viděl třeba jako (převod z T[] na IEnumerable<T> ponechán jako cvičení čtenáři):

    private static Tuple<List<T>, List<T>, List<Tuple<T, T>>> CompareItems<T>(T[] oldItems, T[] newItems)
    	where T : IComparable<T>
    {
    	var i1 = 0;
    	var i2 = 0;
    	var onlyOld = new List<T>();
    	var onlyNew = new List<T>();
    	var pairs = new List<Tuple<T, T>>();
    
    	while (i1 < oldItems.Length || i2 < newItems.Length)
    	{
    		var compare = i1 < oldItems.Length && i2 < newItems.Length
    			? oldItems[i1].CompareTo(newItems[i2])
    			: i1 >= oldItems.Length ? +1 : -1;
    
    		if (compare == 0)
    		{
    			pairs.Add(Tuple.Create(oldItems[i1++], newItems[i2++]));
    		}
    		else if (compare > 0)
    		{
    			onlyNew.Add(newItems[i2++]);
    		}
    		else //if (compare < 0)
    		{
    			onlyOld.Add(oldItems[i1++]);
    		}
    	}
    
    	return Tuple.Create(onlyOld, onlyNew, pairs);
    }
    
    PJOTRIK
    PJOTRIK --- ---
    NECROMAN: Pokud to mas serazene, tak jednoduse jedna iterace, porovnanim vyber ve kterem listu se mas posunout a prihod prvek/y do spravneho seznamu. Takhle to prochazis zbytecne cele nekolikrat
    VERLIBA
    VERLIBA --- ---
    VERLIBA: radeji iteratory nez indexy
    VERLIBA
    VERLIBA --- ---
    NECROMAN: obavam se ze pro nejoptimalnejsi reseni budes potrebovat sahnout ke dvema indexum, (jeden v A druhy v B) a dokud obe indexy nebudou na konci, tak iterovat, a v kazde iteraci se rozhodovat, co udelas sanymi prvky.. Jinak exstuje urcite hodne suboptimalnich reseni, ktera budou krasnejsi na pohled.
    NECROMAN
    NECROMAN --- ---
    Jeden algoritmicky dotaz, mam dva Listy A a B s objekty typu P.
    Jak v C# co nejefektivneji ziskat seznam prvku, ktere jsou jenom v A, jen v B a potom seznam Tuplu prvku, ktere jsou v obou listech, vzdy Tuple<P,P> kde prvni prvek je z A a druhy z B?
    Ted mam toto a premyslim, zda to udelat efektivneji, aby se zbytecne nealokovala pole a nebylo tam vice pruchodu navic.
    Predpoklad je, ze pole jsou jiz sesortovane.

    private static IEnumerable<T> CompareItems<T>(T[] oldItems, T[] newItems)
    {
    T[] removedItems = oldItems.Except(newItems).ToArray();
    T[] addedItems = newItems.Except(oldItems).ToArray();

    T[] sameOld = oldItems.Except(removedItems).ToArray();
    T[] sameNew = newItems.Except(addedItems).ToArray();
    Tuple<T, T>[] zip = sameOld.Zip(sameNew, (i1, i2) => new Tuple<T, T>(i1, i2)).ToArray();
    }
    P19
    P19 --- ---
    JULIEEHARSHAW: Jj, mám, díky. Vyzkouším.
    P19
    P19 --- ---
    MORMEGIL: Jo takhle. Tak díky, už je mi to jasný.
    MORMEGIL
    MORMEGIL --- ---
    P19: Hlavička sestává z klíče a hodnoty, přičemž klíč je od hodnoty oddělen dvojtečkou. V tomto případě tedy: Klíčem (označením hlavičky) je „Content-Type“, hodnotou této hlavičky je „text/plain; charset=UTF-16“. Nic víc, nic míň. Ale taktéž bych se přimlouval raději za UTF-8 místo UTF-16…
    P19
    P19 --- ---
    JULIEEHARSHAW: No dobře, a to tam přidám jak? message.Header.Add přijímá klíč value. Tak co je klíč? Content-Type a druhý klíč je charset?
    Nebo tomu teda nerozumím.
    VERLIBA
    VERLIBA --- ---
    PECA: to posledni cislo je tusim build, ne ? Takze paklize pro dva ruzne buildy zmenis API, pak asi neco spatne. Zkus pri zmene api amenit alespon tu treti pozici, ne-li druhou nebo prvni.
    PECA
    PECA --- ---
    JULIEEHARSHAW: To je mi jasný, akorát jsem až doteď nevěděl, že poslední 2 čísla se neberou jako jiná verze. Takže tím pádem mi to přijde ještě záhadnější. Holt to musím ještě vyzkoušet.
    PECA
    PECA --- ---
    JULIEEHARSHAW: Tak to potom nechápu, proč selhalo načítání assembly funkce.dll (uvedený soubor nebyl nalezen). Podle fuslogu se (díky volání z win32 aplikace) natáhl modul1, který si natáhl funkce (verze 1.0.0.1). Později se zavolal modul2, který se pokoušel natáhnout funkce.dll (verze 1.0.0.2), ale toto načtení selhalo. Podle fuslogu se funkce.dll hledaly vedle exe, pak ve složce s modul1 a tam to zheblo. Měl jsem dojem, že právě kvůli blbý verzi.

    Tak to holt ještě jednou vyzkouším a pokud to nepůjde, budou se oba moduly deployovat spolu. Ono to bude celkem jedno. akorát že vícero win32 apps volá modul1, ale jenom jedna volá i modul2, tak jsem to nechtěl cpát úplně všude. Ale v zásadě jde o prd, až na moduly samotné je deployment prakticky totožný...
    PECA
    PECA --- ---
    JULIEEHARSHAW: Potřebuju ty knihovny distribuovat s různými moduly. Ty moduly jsou COM servery a volají se z Win32 aplikace (Delphi 7). Aktuálně tam jsou 2 - říkejme jim modul1 a modul2. No a oba používají společné funkce.dll. Jenže když se vyrobí novější verze modulu2, která potřebujě novější verzi funkce, tak mám problém. Zkoušel jsem to dávat do různých složek a registrovat knihovny do GAC, ale někde bloudím. Mám modul1 i modul2 v samostatných složkách, jenže modul 1 se načte první a natáhne svoji verzi funkce.dll. Když pak nabíhá modul2, zakopne o starší verzi funkce.dll nakešovanou při načítání modulu1.

    všechny to má strongname, ale když jsem zkoušel registraci dvou různých verzí funkce.dll v oddělených složkách do GAC, tak mi to nějak nešlo. Třeba jsem to dělal špatně. Ale přišlo mi lepší, rozlišit ta dll už v názvu - i kvůli manipulaci, distribuci a tak. Pro testy si to samozřejmě můžu přejmenovat ručně, ale nakonec bych to stejně potřeboval dělat automaticky při buildu.

    Výsledek by potom byl, že bych měl všechna dll v jedný složce s win32 exe a mohly by tam být různé verze vedle sebe... (doufám)
    PECA
    PECA --- ---
    Potřeboval bych do názvu assembly dostat verzi, a dost možná i namespace (radši). Něco jako "firma.funkce.14.2.0.1.dll".
    Získal jsem dojem, že samotné VS 2013 to neumí. A googlu se ptám asi blbě. Existuje nějaké jednoduché řešení?
    Děkuji za případné rady.
    P19
    P19 --- ---
    VERLIBA: Přidal jsem:

    message.HeadersEncoding = Encoding.Unicode;
    message.Headers.Add("Content-Type ", " text/plain");
    message.Headers.Add("charset ", " UTF-16");

    A vůbec to nepomohlo.. :/
    P19
    P19 --- ---
    VERLIBA: Plain text. Ale naivně jsem si myslel, že když kódování nastavím na Unicode, že to pošle i správnou hlavičku. Zkusím to.
    VERLIBA
    VERLIBA --- ---
    P19: posilas html, text, nebo multipart ? v multipartu se da nastavit kodovani ke kazde casti zvlast. Vlastne asi i k obyc textu se da pridat hlavicka Content-Type: text/plain; charset=UTF-8
    P19
    P19 --- ---
    Zdravím,

    mám aplikaci, ze které posílám emaily. Body i subject encoding mám Unicode. Na Gmail mi to dorazí v pořádku, ale na Seznam.cz mi dorazí změť čínských znaků a i odkazy jsou odebrány.
    Jsem na nějakém blacklistu (doména existuje pár dní a odešlo z ní asi 5 emailů), nebo se tvářím podezřele?

    Díky
    TOOMIX
    TOOMIX --- ---
    Nevíte někdo o nějakém funkčním emulátoru pro Windows CE 5, který je schopen se připojit i ven na net?
    MORMEGIL
    MORMEGIL --- ---
    JULIEEHARSHAW: Tak to jenom vypíná tu validaci na _konkrétní_ položce toho modelu, každopádně „všechno encodovat“ _samozřejmě_ platí pořád, všude a vždy! (Ovšem s tím, že s Razorem se o to nemusím v drtivé většině případů vůbec starat, protože se to děje automaticky, pozor si musím dávat prakticky jen u ručně skládaného HTML.) Pokud _uživatelům_ dovoluješ vkládat HTML tagy, tak věz, že bez nějakého filtrování/sanitizace tím umožníš komukoli hacknout všechny, kterým se jeho HTML zobrazí.
    Kliknutím sem můžete změnit nastavení reklam