Segue da: http://forum.html.it/forum/showthrea...1#post25319059
Direi che potete tutti, con una certa tranquillità, cambiare argomento.
Segue da: http://forum.html.it/forum/showthrea...1#post25319059
Direi che potete tutti, con una certa tranquillità, cambiare argomento.
Ultima modifica di MItaly; 19-11-2015 a 02:11 Motivo: Aggiunto link a chunk precedente
"Se proprio devono piratare, almeno piratino il nostro." (Bill Gates)
"Non è possibile che 2 istituzioni statali mi mettano esami nello stesso giorno." (XWolverineX)
http://xvincentx.netsons.org/programBlog
Raccolgo il suggerimento e rilancio: esperienze particolarmente positive in fatto di bugtracker?
Perché quello che usiamo in azienda (FogBugz) sta abbandonando la versione Linux/MySQL (bene perché funzionava in maniera atroce) e, almeno per un po', intendono fornirlo hostato esclusivamente da loro (e costa abbastanza una sassata). Stavo guardando JIRA che, oltre ad essere hostabile facile da noi, anche hostato da loro costa molto meno, ha un buon import da FogBugz e Atlassian mi sta simpatica . Qualcuno l'ha usato? Consigli?
Amaro C++, il gusto pieno dell'undefined behavior.
Noi abbiamo differenti team e ognuno di questi può usare lo strumento che preferisce.
Un team usa jira sul cloud, e sembra siano contenti.
Noi abbiamo provato Jira e siamo scappati dopo poco. Era molto lento e macchinoso, oltre ad avere una UI troppo complicata. Per cui abbiamo deciso di usare Trello con le dovute label e una applicazione in Python (https://github.com/apiaryio/black-belt) che automatizza 3-4 cose per noi
Un altro team ancora usa Waffle.io, che praticamente "trellizza" le issues di github, e sembra molto interessante
"Se proprio devono piratare, almeno piratino il nostro." (Bill Gates)
"Non è possibile che 2 istituzioni statali mi mettano esami nello stesso giorno." (XWolverineX)
http://xvincentx.netsons.org/programBlog
Nel nostro caso all'interno dello stesso team ognuno usa gli strumenti che preferisce, il problema nasce quando dovrebbero essere strumenti di collaborazione come un bugtracker. Se ognuno usa il suo/non lo usa è dura usarli in maniera efficace.
Interessante... c'era qualcuno che anche da noi aveva proposto di usare Trello, ma a me come ad altri sembrava un po' troppo poco strutturato... Che genere di workflow/organizzazione avete su Trello?Un team usa jira sul cloud, e sembra siano contenti.
Noi abbiamo provato Jira e siamo scappati dopo poco. Era molto lento e macchinoso, oltre ad avere una UI troppo complicata. Per cui abbiamo deciso di usare Trello con le dovute label e una applicazione in Python (https://github.com/apiaryio/black-belt) che automatizza 3-4 cose per noi
Un altro team ancora usa Waffle.io, che praticamente "trellizza" le issues di github, e sembra molto interessante
Amaro C++, il gusto pieno dell'undefined behavior.
http://akabe.github.io/evilml/
Evil ML: ML to C++ template language
AIUTO
Amaro C++, il gusto pieno dell'undefined behavior.
Ciao,
perdonami per l'enorme ritardo.
Generalmente ogni nostro team interno utilizza le board di Trello come meglio preferisce, per cui mi limiterò a illustrare l'utilizzo del mio team.
Fondamentalmente abbiamo le seguenti board:
1. Library: Contiene tutte le registrazioni dei nostri sprint planning, retrospective, sync bisettimanali (servono fondamentalmente ad aumentare la trasparenza del nostro lavoro rispetto all'azienda)
2. Sprint board: 1 colonna per sprint che contiene tutte le card completate durante tale sprint
3. Product: Contiene l'inbox dei bugs, delle proposte e delle varie cose che devono essere discusse
4. Work overview: contiene le card dettagliate dello sprint corrente
"Se proprio devono piratare, almeno piratino il nostro." (Bill Gates)
"Non è possibile che 2 istituzioni statali mi mettano esami nello stesso giorno." (XWolverineX)
http://xvincentx.netsons.org/programBlog
Eh, perdonami tu per il ritardo ancora più clamoroso... Ti ringrazio per la panoramica d'uso, intanto anche dei nostri collaboratori lo stanno usando per loro progetti interni, vediamo come si evolve la cosa.
Meanwhile:
Due indovinelli (da bug veri che mi hanno fatto impazzire per giorni):
Dove sta il problema?codice:void someFunctionCallback(void * dummy) { std::stringstream ss; ss << atoi(((std::string)parms("max_vel")).c_str()) * 1000; some_object->setParameter("max_vx", ss.str()); some_object->setParameter("max_vy", ss.str()); ss << atoi(((std::string)parms("max_vel_inout")).c_str()) * 1000; some_object->setParameter("max_vx_inout", ss.str()); some_object->setParameter("max_vy_inout", ss.str()); }
Sintomi: "ogni tanto" nel caricamento di altri parametri del programma venivano o letti solo zeri, o valori assurdi (o meglio, il sintomo originario erano crash in parti assurde del programma, ma qui semplifichiamo ).codice:// reimposto il locale perche' se linko le QT // viene impostato il locale della macchina char * locale = setlocale(LC_ALL, NULL); setlocale(LC_ALL, "C"); FILE *mf=fopen(filename, "r"); // ... un bel po' di fscanf & co. ... if (mf) fclose(mf); setlocale(LC_ALL, locale);
Dove sta il problema? (qui ce n'è più di uno in realtà)
Altri angoli oscuri del C++ che ho scoperto per caso in tempi recenti:
- le regole di scoping del C++ sono sempre più strane di quel che sembra:
IOW: lo scoping delle variabili introdotte a livello di condizione dell'if perdura anche negli else; non riesco a cogliere completamente l'utilità di questo fatto, ma prendo atto. Mi sembra quasi peggio delle list comprehension in Python, che "pisciano fuori" la variabile di iterazione nello scope di funzione.codice:if(auto *derived_ptr = dynamic_cast<Derived *>(base_ptr)) { derived_ptr->doSomething(); } else { derived_ptr->doSomethingElse(); // <-- ho scritto derived_ptr per sbaglio, ma compila! (ovviamente crash) }- std::function non è reference counted, ma lavora per copia, per cui bisogna stare attenti a fare lambda che catturano per copia roba troppo grossa, visto che si tende a trattare la copia di std::function come copia di oggetti leggeri; non so perché, ma mi ero sempre immaginato che lavorasse per reference-counting;
- ho finalmente colto uno dei motivi per cui sto abusando di std::function: in un certo senso è un'incursione del duck typing in un linguaggio a tipizzazione statica - l'unica cosa che importa è che quello che passo abbia un'interfaccia compatibile a quella richiesta, senza menate di ereditarietà, gerarchie di classi e compagnia (e, rispetto all'uso tipico del C++, consente di mantenere un comportamento simil-polimorfico senza doversi esplicitamente portare in giro puntatori a roba allocata sullo heap); il fatto che, rispetto a linguaggi come Python, mantenga comunque un buon controllo a compile-time, rende la cosa particolarmente usabile. Mi chiedo se si riesce ad estendere in maniera sintatticamente comoda ad interfacce più complicate (rispetto alla singola funzione)
Amaro C++, il gusto pieno dell'undefined behavior.
Mi sembra abbastanza
Volendo continuare, anche atoi è discutibile: se uno dei parametri non è rappresentabile in un int, .codice:void *dummy
Di cosa, poi?
Odio Java. Mi domando come chi lo usi (quanti e dove, poi?) non sia travolto dalla tremenda inconsistenza che lo forgia.
Ultima modifica di signoredeltempo; 11-11-2015 a 18:00
Nah, quello era necessario (è un callback stile C che deve avere quella firma lì).
Assumi pure che i dati in input siano sempre buoni. C'è un problema ben più grosso, e che si verifica con praticamente qualunque valore.Volendo continuare, anche atoi è discutibile: se uno dei parametri non è rappresentabile in un int, .
(la cosa bella è che è così da tipo tre anni ma non se n'è mai accorto nessuno perché quel callback non è mai stato chiamato ; settimana scorsa ho cambiato il codice che chiama il callback per cui effettivamente viene chiamato ed è successo il finimondo)
Del functore che si porta dietro. Avevo in mente che copiare std::function fosse equivalente ad avere un altro reference allo stesso functore (come funzionano i riferimenti a closure in qualunque altro linguaggio).Di cosa, poi?
Oh be' se parliamo di linguaggi inconsistenti c'è ben di peggio.Odio Java. Mi domando come chi lo usi (quanti e dove, poi?) non sia travolto dalla tremenda inconsistenza che lo forgia.
Amaro C++, il gusto pieno dell'undefined behavior.